@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&family=Inter:wght@300;400;500;600&display=swap";:root{--ink: #111111;--ink-2: #2a2a2a;--muted: #6b6b6b;--muted-2: #9a9a9a;--line: #e6e3dd;--line-2: #d4d0c8;--bg: #f7f5f0;--bg-elev: #ffffff;--bg-soft: #efece5;--accent: #b8533a;--accent-soft: #e9d8cf;--success: #2f7a55;--error: #b34141;--font-display: "Fraunces", "Times New Roman", serif;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--fs-xs: .75rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-md: 1.125rem;--fs-lg: 1.25rem;--fs-xl: 1.5rem;--fs-2xl: clamp(1.75rem, 2.5vw, 2.25rem);--fs-3xl: clamp(2.25rem, 4vw, 3rem);--fs-4xl: clamp(3rem, 6vw, 4.5rem);--fs-5xl: clamp(4rem, 9vw, 7.5rem);--fs-6xl: clamp(5rem, 12vw, 10rem);--lh-tight: 1.05;--lh-snug: 1.2;--lh-base: 1.5;--lh-loose: 1.7;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;--space-9: 6rem;--space-10: 8rem;--space-11: 12rem;--container: 1280px;--container-narrow: 880px;--container-wide: 1500px;--gutter: clamp(1.25rem, 4vw, 3rem);--r-sm: 4px;--r-md: 8px;--r-lg: 14px;--ease: cubic-bezier(.2, .7, .2, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--dur-fast: .18s;--dur-base: .32s;--dur-slow: .6s;--dur-reveal: .9s;--shadow-1: 0 1px 2px rgba(17, 17, 17, .04);--shadow-2: 0 8px 24px rgba(17, 17, 17, .06);--shadow-3: 0 24px 60px rgba(17, 17, 17, .1);--nav-h: 76px;color-scheme:light}[data-theme=dark]{--ink: #f1efe9;--ink-2: #d6d3c9;--muted: #9a978d;--muted-2: #6e6c64;--line: #2a2926;--line-2: #3a3935;--bg: #0e0e0c;--bg-elev: #161614;--bg-soft: #1a1a17;--accent: #d77855;--accent-soft: #2b1d18;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 8px 24px rgba(0, 0, 0, .35);--shadow-3: 0 24px 60px rgba(0, 0, 0, .55);color-scheme:dark}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0;font-family:var(--font-sans);font-size:var(--fs-base);line-height:var(--lh-base);color:var(--ink);background:var(--bg);transition:background-color var(--dur-base) var(--ease),color var(--dur-base) var(--ease);overflow-x:hidden}img,picture,video,canvas,svg{display:block;max-width:100%}img{height:auto}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;background:none;border:none;color:inherit;padding:0}input,textarea,select{font:inherit;color:inherit}::selection{background:var(--ink);color:var(--bg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:400;line-height:var(--lh-snug);letter-spacing:-.01em;color:var(--ink)}h1{font-size:var(--fs-4xl);line-height:var(--lh-tight);letter-spacing:-.02em}h2{font-size:var(--fs-3xl);line-height:var(--lh-tight);letter-spacing:-.015em}h3{font-size:var(--fs-2xl)}h4{font-size:var(--fs-xl)}h5{font-size:var(--fs-lg)}h6{font-size:var(--fs-base)}p{color:var(--ink-2);line-height:var(--lh-base)}.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}.container-narrow{width:100%;max-width:var(--container-narrow);margin-inline:auto;padding-inline:var(--gutter)}.container-wide{width:100%;max-width:var(--container-wide);margin-inline:auto;padding-inline:var(--gutter)}.section{padding-block:var(--space-9)}.section-sm{padding-block:var(--space-7)}.section-lg{padding-block:var(--space-10)}.eyebrow{font-family:var(--font-sans);font-size:var(--fs-xs);font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.lead{font-family:var(--font-sans);font-size:var(--fs-md);line-height:var(--lh-loose);color:var(--ink-2);max-width:60ch}.display{font-family:var(--font-display);font-size:var(--fs-5xl);line-height:var(--lh-tight);letter-spacing:-.025em;font-weight:400;color:var(--ink)}.display-italic{font-style:italic}.serif{font-family:var(--font-display)}.sans{font-family:var(--font-sans)}.italic{font-style:italic}.rule{height:1px;background:var(--line);width:100%;border:0}.rule-vertical{width:1px;background:var(--line);height:100%}.btn-primary,.btn-ghost,.btn-link{font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:500;letter-spacing:.04em;text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;transition:all var(--dur-base) var(--ease);border-radius:0}.btn-primary{background:var(--ink);color:var(--bg);padding:var(--space-4) var(--space-6);border:1px solid var(--ink)}.btn-primary:hover{background:transparent;color:var(--ink)}.btn-ghost{background:transparent;color:var(--ink);padding:var(--space-4) var(--space-6);border:1px solid var(--ink)}.btn-ghost:hover{background:var(--ink);color:var(--bg)}.btn-link{color:var(--ink);padding:var(--space-2) 0;border-bottom:1px solid var(--ink);text-transform:none;letter-spacing:.02em}.btn-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.arrow-link{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--ink);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.04em;text-transform:uppercase;font-weight:500;position:relative}.arrow-link:after{content:"→";transition:transform var(--dur-base) var(--ease)}.arrow-link:hover:after{transform:translate(6px)}.reveal{opacity:0;transform:translateY(24px);transition:opacity var(--dur-reveal) var(--ease-out),transform var(--dur-reveal) var(--ease-out)}.reveal.is-visible{opacity:1;transform:none}.reveal-delay-1{transition-delay:80ms}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}.lift{transition:transform var(--dur-base) var(--ease)}.lift:hover{transform:translateY(-4px)}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}.whatsapp-icon,.phone-icon{position:fixed;left:clamp(12px,2vw,24px);width:48px;height:48px;display:grid;place-items:center;background:var(--ink);color:var(--bg);border-radius:50%;z-index:900;cursor:pointer;box-shadow:var(--shadow-2);transition:transform var(--dur-base) var(--ease),background var(--dur-base) var(--ease)}.whatsapp-icon{bottom:24px}.phone-icon{bottom:84px}.whatsapp-icon:hover,.phone-icon:hover{transform:translateY(-3px);background:var(--accent)}.faWhatsapp,.fa-phone{color:inherit!important;font-size:20px}.text-button{font:inherit;cursor:pointer;background:transparent;border:none;color:var(--accent)}body,header,footer,section,nav,article,aside{transition:background-color var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease)}[dir=rtl] body{font-family:Tajawal,Inter,system-ui,-apple-system,sans-serif;text-align:right}[dir=rtl] p,[dir=rtl] h1,[dir=rtl] h2,[dir=rtl] h3,[dir=rtl] h4,[dir=rtl] h5,[dir=rtl] h6,[dir=rtl] li,[dir=rtl] span,[dir=rtl] label,[dir=rtl] .lead,[dir=rtl] .eyebrow{text-align:right}[dir=rtl] .arrow-link:after{content:"←";transform:none}[dir=rtl] .arrow-link:hover:after{transform:translate(-6px)}[dir=rtl] .arrow-link,[dir=rtl] .btn-primary,[dir=rtl] .btn-ghost,[dir=rtl] .btn-link,[dir=rtl] .nav__links{flex-direction:row-reverse}[dir=rtl] .nav__menu{right:auto;left:0}[dir=rtl] .nav__drawer{right:0;left:auto}[dir=rtl] .service-tiles__grid{direction:rtl}[dir=rtl] .service-process__item,[dir=rtl] .phase-list__item{flex-direction:row-reverse;text-align:right}[dir=rtl] .service-features__list{padding-right:0;padding-left:0}[dir=rtl] .service-features__list li{padding-left:0;padding-right:var(--space-6);position:relative}[dir=rtl] .service-features__list li:before{right:auto;left:0}[dir=rtl] .contact__field,[dir=rtl] .contact__row{text-align:right}[dir=rtl] input,[dir=rtl] textarea,[dir=rtl] select{text-align:right;direction:rtl}[dir=rtl] .service-cta__actions{flex-direction:row-reverse;gap:var(--space-4)}[dir=rtl] .footer__cols{direction:rtl}[dir=rtl] .showcase__caption,[dir=rtl] .showcase__foot,[dir=rtl] .hero-home__inner{text-align:right}[dir=rtl] .hero-home__actions{flex-direction:row-reverse;gap:var(--space-4)}[dir=rtl] .stats-grid,[dir=rtl] .service-intro__stats{direction:rtl}[dir=rtl] .def-grid__item,[dir=rtl] .project-card-3d,[dir=rtl] .work-card{text-align:right}[dir=rtl] .modal-content{text-align:right;direction:rtl}[dir=rtl] .empty-state,[dir=rtl] .cta-block{text-align:right}[dir=rtl] .phase-list{padding-right:0}[dir=rtl] .about-principles__item{flex-direction:row-reverse;text-align:right}[dir=rtl] .about-story__copy{text-align:right}[dir=rtl] .goog-te-banner-frame,[dir=rtl] .skiptranslate{display:none!important}.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:1000;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid transparent;transition:background var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease),box-shadow var(--dur-base) var(--ease)}.nav--scrolled{background:color-mix(in srgb,var(--bg) 92%,transparent);border-bottom-color:var(--line)}.nav__inner{height:100%;max-width:var(--container-wide);margin-inline:auto;padding-inline:var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:var(--space-6)}.nav__brand{display:inline-flex;align-items:center;gap:var(--space-3);flex-shrink:0}.nav__logo{width:38px;height:38px;object-fit:contain;display:block}.nav__wordmark{font-family:var(--font-display);font-size:1.15rem;letter-spacing:-.015em;font-weight:500;color:var(--ink);white-space:nowrap}.nav__dot{color:var(--accent)}.nav__links{display:flex;align-items:center;gap:clamp(1rem,2vw,2rem)}.nav__link{font-family:var(--font-sans);font-size:.85rem;font-weight:500;letter-spacing:.02em;color:var(--ink-2);padding:var(--space-3) 0;position:relative;transition:color var(--dur-base) var(--ease);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.nav__link:hover,.nav__link.active{color:var(--ink)}.nav__link.active:after,.nav__link:hover:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ink)}.nav__link--has-menu{cursor:pointer}.nav__chev{font-size:.7rem;opacity:.6;transition:transform var(--dur-base) var(--ease)}.nav__group:hover .nav__chev{transform:rotate(180deg)}.nav__group{position:relative}.nav__menu{position:absolute;top:100%;left:50%;transform:translate(-50%,8px);min-width:280px;background:var(--bg-elev);border:1px solid var(--line);padding:var(--space-3);opacity:0;pointer-events:none;transition:opacity var(--dur-base) var(--ease),transform var(--dur-base) var(--ease);box-shadow:var(--shadow-2)}.nav__group:hover .nav__menu,.nav__group:focus-within .nav__menu{opacity:1;pointer-events:auto;transform:translate(-50%)}.nav__menu-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);color:var(--ink-2);font-size:var(--fs-sm);font-family:var(--font-sans);transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease)}.nav__menu-item:hover{background:var(--bg-soft);color:var(--ink)}.nav__menu-meta{font-family:var(--font-sans);font-size:.7rem;color:var(--muted-2);letter-spacing:.1em}.nav__tools{display:inline-flex;align-items:center;gap:var(--space-4)}.nav__hamburger{display:none;width:36px;height:36px;position:relative;flex-shrink:0;cursor:pointer;z-index:2;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.nav__hamburger span{position:absolute;left:6px;right:6px;height:1.5px;background:var(--ink);pointer-events:none;transition:transform var(--dur-base) var(--ease),opacity var(--dur-base) var(--ease),top var(--dur-base) var(--ease)}.nav__hamburger span:nth-child(1){top:12px}.nav__hamburger span:nth-child(2){top:17px}.nav__hamburger span:nth-child(3){top:22px}.nav__hamburger.is-open span:nth-child(1){top:17px;transform:rotate(45deg)}.nav__hamburger.is-open span:nth-child(2){opacity:0}.nav__hamburger.is-open span:nth-child(3){top:17px;transform:rotate(-45deg)}.nav__drawer{position:fixed;inset:var(--nav-h) 0 0 0;background:var(--bg);transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--dur-base) var(--ease),transform var(--dur-base) var(--ease);overflow-y:auto;z-index:999}.nav__drawer.is-open{opacity:1;transform:none;pointer-events:auto}.nav__drawer-inner{max-width:var(--container);margin-inline:auto;padding:var(--space-7) var(--gutter) var(--space-9);display:flex;flex-direction:column;gap:var(--space-3)}.nav__drawer-eyebrow{margin-top:var(--space-6);margin-bottom:var(--space-3)}.nav__drawer-link{font-family:var(--font-display);font-size:clamp(1.5rem,5vw,2.25rem);letter-spacing:-.015em;color:var(--ink);padding:var(--space-3) 0;border-bottom:1px solid var(--line);transition:color var(--dur-base) var(--ease),padding-left var(--dur-base) var(--ease)}.nav__drawer-link:hover{color:var(--accent);padding-left:6px}.nav__drawer-link--sub{font-size:clamp(1.1rem,3.5vw,1.5rem);color:var(--ink-2)}.nav__drawer-section{display:flex;flex-direction:column}.nav__drawer-foot{margin-top:var(--space-7);display:flex;flex-direction:column;gap:var(--space-4)}@media (max-width: 980px){.nav__links{display:none}.nav__hamburger{display:inline-block}.nav__inner,.nav__tools{gap:var(--space-3)}}@media (max-width: 480px){.nav__wordmark{display:none}.nav__tools{gap:var(--space-2)}}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:999px;transition:opacity var(--dur-base) var(--ease)}.theme-toggle:hover{opacity:.85}.theme-toggle__track{position:relative;display:inline-block;width:44px;height:24px;background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;transition:background var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease)}.theme-toggle__thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:999px;background:var(--ink);color:var(--bg);display:grid;place-items:center;transition:transform var(--dur-base) var(--ease),background var(--dur-base) var(--ease)}.theme-toggle__thumb--dark{transform:translate(20px)}.lang-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .7rem;background:transparent;border:1px solid var(--line);color:var(--ink-2);font-family:var(--font-sans);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border-radius:999px;transition:border-color var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.lang-toggle:hover{border-color:var(--ink);color:var(--ink)}.lang-toggle__opt{font-weight:600;opacity:.5;transition:opacity var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.lang-toggle__opt.is-active{opacity:1;color:var(--ink)}.lang-toggle__sep{opacity:.4}[dir=rtl] .lang-toggle__opt:last-of-type{font-size:.95rem;line-height:1}.footer{background:var(--bg);color:var(--ink-2);border-top:1px solid var(--line);margin-top:clamp(4rem,8vw,7rem)}.footer__inner{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter) clamp(2rem,4vw,3rem);display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,2fr);gap:clamp(2rem,5vw,5rem);align-items:start}.footer__lede{display:flex;flex-direction:column;gap:var(--space-4);max-width:38ch}.footer__brand{display:inline-flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.footer__logo{width:42px;height:42px;object-fit:contain}.footer__wordmark{font-family:var(--font-display);font-size:1.35rem;letter-spacing:-.015em;font-weight:500;color:var(--ink)}.footer__dot{color:var(--accent)}.footer__statement{font-family:var(--font-display);font-size:clamp(1.15rem,1.8vw,1.45rem);line-height:1.4;color:var(--ink);letter-spacing:-.01em;margin:0}.footer__cta{margin-top:var(--space-2)}.footer__cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(1.25rem,3vw,2.5rem)}.footer__col-title{margin:0 0 var(--space-4);color:var(--muted)}.footer__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.footer__list a{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-2);letter-spacing:.01em;transition:color var(--dur-base) var(--ease)}.footer__list a:hover,.footer__list--plain a{color:var(--ink)}.footer__list--plain a:hover{color:var(--accent)}.footer__addr{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--muted);line-height:1.55;max-width:28ch}.footer__base{border-top:1px solid var(--line)}.footer__base-inner{max-width:var(--container-wide);margin-inline:auto;padding:var(--space-4) var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--muted);letter-spacing:.04em}.footer__copy,.footer__credit{margin:0}.footer__social{display:inline-flex;align-items:center;gap:var(--space-4)}.footer__social a{width:30px;height:30px;display:inline-grid;place-items:center;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;transition:color var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease),background var(--dur-base) var(--ease);font-size:.8rem}.footer__social a:hover{color:var(--bg);background:var(--ink);border-color:var(--ink)}@media (max-width: 1024px){.footer__inner{grid-template-columns:1fr;gap:clamp(2rem,5vw,3rem)}}@media (max-width: 720px){.footer__cols{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-6) var(--space-5)}.footer__base-inner{flex-direction:column;align-items:flex-start;gap:var(--space-3)}}@media (max-width: 420px){.footer__cols{grid-template-columns:1fr}}#root{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}main{flex:1;padding-top:var(--nav-h)}.page-section{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,7vw,6rem) var(--gutter)}.page-section--narrow{max-width:var(--container-narrow)}.section-heading{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.25rem);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:var(--space-3) 0 var(--space-7);max-width:22ch}.about-story{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(2rem,5vw,5rem);align-items:start}.about-story__media img{width:100%;height:auto;display:block;filter:grayscale(20%);transition:filter var(--dur-slow) var(--ease)}.about-story__media:hover img{filter:grayscale(0%)}.about-story__caption{margin-top:var(--space-3);font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--muted);letter-spacing:.06em;text-transform:uppercase}.about-story__copy{display:flex;flex-direction:column;gap:var(--space-4)}.about-story__heading{font-family:var(--font-display);font-size:clamp(1.7rem,3.4vw,2.5rem);line-height:1.15;letter-spacing:-.015em;color:var(--ink);margin:0}.about-story__body{display:flex;flex-direction:column;gap:var(--space-4);color:var(--ink-2)}@media (max-width: 880px){.about-story{grid-template-columns:1fr}}.about-principles__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.8vw,2.75rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin:var(--space-3) 0 var(--space-7);max-width:18ch}.about-principles__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-7) var(--space-6);border-top:1px solid var(--line);padding-top:var(--space-6)}.about-principles__item{display:flex;gap:var(--space-4);align-items:flex-start}.about-principles__num{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--accent);letter-spacing:.08em;font-weight:600;padding-top:.3em}.about-principles__title{font-family:var(--font-display);font-size:clamp(1.2rem,2vw,1.5rem);letter-spacing:-.01em;color:var(--ink);margin:0 0 var(--space-2)}.about-principles__body{font-family:var(--font-sans);color:var(--ink-2);line-height:1.6;margin:0}@media (max-width: 720px){.about-principles__list{grid-template-columns:1fr;gap:var(--space-6)}}.def-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-5) var(--space-6);border-top:1px solid var(--line);padding-top:var(--space-6)}.def-grid__item{padding:var(--space-3) 0}.def-grid__label{font-family:var(--font-display);font-size:1.25rem;letter-spacing:-.01em;color:var(--ink);margin:0 0 var(--space-2)}.def-grid__body{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-2);line-height:1.6;margin:0}.phase-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.phase-list__item{display:grid;grid-template-columns:64px 1fr;gap:var(--space-5);align-items:start;padding:var(--space-5) 0;border-bottom:1px solid var(--line)}.phase-list__num{font-family:var(--font-sans);font-size:.9rem;color:var(--accent);letter-spacing:.08em;font-weight:600;padding-top:.5em}.phase-list__title{font-family:var(--font-display);font-size:clamp(1.25rem,2.2vw,1.6rem);color:var(--ink);margin:0 0 var(--space-2);letter-spacing:-.01em}.phase-list__body{font-family:var(--font-sans);color:var(--ink-2);line-height:1.6;margin:0;max-width:60ch}.cta-block{border-top:1px solid var(--line);padding-top:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.cta-block__lead{font-family:var(--font-display);font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.35;color:var(--ink);letter-spacing:-.01em;margin:0;max-width:50ch}.empty-state{display:flex;flex-direction:column;gap:var(--space-3);border-top:1px solid var(--line);padding-top:var(--space-6)}.empty-state__title{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.5rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:0;max-width:22ch}.empty-state__body{font-family:var(--font-sans);color:var(--ink-2);line-height:1.6;margin:0;max-width:56ch}.empty-state__links{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.video-strip{background:var(--bg)}.video-strip__inner{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,7vw,6rem) var(--gutter)}.video-strip__head{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--line)}.video-strip__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.6vw,2.75rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-2) 0 0;max-width:22ch}.video-strip__media{width:100%;aspect-ratio:16 / 9;background:var(--bg-soft);overflow:hidden}.video-strip__media video{width:100%;height:100%;object-fit:cover;display:block}.studio-statement{background:var(--bg-soft);border-block:1px solid var(--line)}.studio-statement__inner{max-width:var(--container-narrow);margin-inline:auto;padding:clamp(4rem,9vw,7rem) var(--gutter);display:flex;flex-direction:column;gap:var(--space-4);text-align:left}.studio-statement__heading{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,3rem);letter-spacing:-.02em;line-height:1.2;color:var(--ink);margin:0;max-width:30ch}.studio-statement__body{font-family:var(--font-sans);font-size:var(--fs-md);line-height:1.65;color:var(--ink-2);margin:0;max-width:56ch}.notfound{max-width:var(--container-narrow);margin-inline:auto;padding:clamp(2rem,4vw,3rem) var(--gutter) clamp(4rem,8vw,6rem);display:flex;justify-content:flex-start}.hero-home{position:relative;width:100%;min-height:clamp(640px,92vh,920px);overflow:hidden;background:var(--bg-soft);margin-top:calc(var(--nav-h) * -1);padding-top:var(--nav-h);color:var(--bg)}.hero-home__media{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-home__slide{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s var(--ease);transform:scale(1.04)}.hero-home__slide.is-active{opacity:1;transform:scale(1);transition:opacity 1.6s var(--ease),transform 8s var(--ease)}.hero-home__veil{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0f0e0c8c,#0f0e0c40 35%,#0f0e0cb3)}.hero-home__inner{position:relative;z-index:1;max-width:var(--container-wide);margin-inline:auto;padding:var(--space-7) var(--gutter) var(--space-6);min-height:clamp(640px,92vh,920px);display:grid;grid-template-rows:auto 1fr auto;gap:var(--space-5)}.hero-home__top{display:flex}.hero-home__eyebrow{color:color-mix(in srgb,white 78%,transparent)}.hero-home__body{align-self:end;max-width:22ch}.hero-home__title{font-family:var(--font-display);font-size:clamp(2.5rem,6.5vw,5.5rem);line-height:1.02;letter-spacing:-.025em;color:#fff;margin:0 0 var(--space-4)}.hero-home__lead{font-family:var(--font-display);font-size:clamp(1.05rem,1.6vw,1.3rem);color:color-mix(in srgb,white 82%,transparent);margin:0 0 var(--space-5);max-width:38ch;line-height:1.4}.hero-home__actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.hero-home__primary{display:inline-flex;align-items:center;gap:var(--space-2);background:#fff;color:var(--ink);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.06em;text-transform:uppercase;transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.hero-home__primary:hover{background:var(--accent);color:#fff}.hero-home__ghost{display:inline-flex;align-items:center;gap:var(--space-2);color:#fff;padding:var(--space-3) var(--space-5);border:1px solid color-mix(in srgb,white 45%,transparent);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.06em;text-transform:uppercase;transition:background var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease)}.hero-home__ghost:hover{background:color-mix(in srgb,white 12%,transparent);border-color:#fff}.hero-home__bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-5);border-top:1px solid color-mix(in srgb,white 25%,transparent);padding-top:var(--space-4)}.hero-home__caption{display:flex;flex-direction:column;gap:var(--space-1);font-family:var(--font-sans);font-size:var(--fs-sm);color:color-mix(in srgb,white 82%,transparent);margin:0;max-width:50ch}.hero-home__kicker{font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:color-mix(in srgb,white 60%,transparent)}.hero-home__cap-text{line-height:1.4}.hero-home__counter{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-sans);font-size:var(--fs-sm);color:#fff;letter-spacing:.06em;font-feature-settings:"tnum" 1}.hero-home__counter-line{width:40px;height:1px;background:color-mix(in srgb,white 50%,transparent)}@media (max-width: 720px){.hero-home__bottom{flex-direction:column;align-items:flex-start}}.showcase{max-width:var(--container-wide);margin:clamp(3rem,7vw,6rem) auto;padding-inline:var(--gutter);display:flex;flex-direction:column;gap:var(--space-5)}.showcase__head{display:flex;justify-content:space-between;align-items:end;gap:var(--space-4);border-bottom:1px solid var(--line);padding-bottom:var(--space-4)}.showcase__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.6vw,2.75rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-2) 0 0;max-width:22ch}.showcase__controls{display:flex;gap:var(--space-2);flex-shrink:0}.showcase__nav{width:40px;height:40px;border:1px solid var(--line);background:transparent;color:var(--ink);border-radius:999px;display:grid;place-items:center;cursor:pointer;transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease)}.showcase__nav:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.showcase__viewport{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-soft)}.showcase__track{display:flex;height:100%;transition:transform .7s var(--ease);will-change:transform}.showcase__slide{flex:0 0 100%;height:100%}.showcase__image,.showcase__slide .image-container{width:100%;height:100%}.showcase__slide .image-container{position:relative;background:var(--bg-soft)}.showcase__slide img{width:100%;height:100%;object-fit:cover;display:block}.image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg-soft);z-index:1}.image-loading-spinner{width:26px;height:26px;border:1px solid var(--line);border-top-color:var(--ink-2);border-radius:50%;animation:showcase-spin .8s linear infinite}@keyframes showcase-spin{to{transform:rotate(360deg)}}.image{opacity:0;transition:opacity .5s var(--ease)}.image.loaded{opacity:1}.showcase__foot{display:flex;justify-content:space-between;align-items:end;gap:var(--space-4)}.showcase__caption{display:flex;flex-direction:column;gap:4px}.showcase__title{font-family:var(--font-display);font-size:clamp(1.25rem,2.2vw,1.6rem);letter-spacing:-.01em;color:var(--ink);margin:0}.showcase__meta{font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0}.showcase__progress{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--muted);font-feature-settings:"tnum" 1}.showcase__num{color:var(--ink)}.showcase__bar{display:inline-block;width:clamp(80px,15vw,160px);height:1px;background:var(--line);position:relative;overflow:hidden}.showcase__bar-fill{position:absolute;inset:0 auto 0 0;background:var(--ink);transition:width .5s var(--ease)}@media (max-width: 720px){.showcase__head,.showcase__foot{flex-direction:column;align-items:flex-start}}.work-grid{max-width:var(--container-wide);margin:clamp(3rem,7vw,6rem) auto;padding-inline:var(--gutter)}.work-grid__head{margin-bottom:var(--space-6)}.work-grid__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.6vw,2.75rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-2) 0 0;max-width:22ch}.work-grid__items{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1.5rem,3vw,2.5rem);border-top:1px solid var(--line);padding-top:var(--space-6)}.work-card{display:flex;flex-direction:column;gap:var(--space-3);color:var(--ink);transition:transform var(--dur-base) var(--ease)}.work-card:hover{transform:translateY(-4px)}.work-card__media{aspect-ratio:4 / 3;overflow:hidden;background:var(--bg-soft)}.work-card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}.work-card:hover .work-card__media img{transform:scale(1.05)}.work-card__body{display:flex;flex-direction:column;gap:var(--space-2)}.work-card__meta{font-family:var(--font-sans);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0}.work-card__title{font-family:var(--font-display);font-size:clamp(1.4rem,2.2vw,1.7rem);letter-spacing:-.01em;color:var(--ink);margin:0}.work-card__copy{font-family:var(--font-sans);font-size:var(--fs-sm);line-height:1.55;color:var(--ink-2);margin:0}.work-card__more{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--accent);margin-top:var(--space-2);letter-spacing:.02em;transition:color var(--dur-base) var(--ease)}.work-card:hover .work-card__more{color:var(--ink)}@media (max-width: 880px){.work-grid__items{grid-template-columns:1fr}}.contact{background:var(--bg);border-top:1px solid var(--line)}.contact__inner{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,7vw,6rem) var(--gutter);display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:clamp(2rem,5vw,5rem);align-items:start}.contact__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.6rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-2) 0 var(--space-6)}.contact__details{display:flex;flex-direction:column}.contact__list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.contact__list li{display:grid;grid-template-columns:90px 1fr;gap:var(--space-4);padding:var(--space-4) 0;border-bottom:1px solid var(--line);font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-2);line-height:1.55;align-items:start}.contact__label{font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding-top:.15em}.contact__list a{color:var(--ink)}.contact__form-wrap{display:flex;flex-direction:column}.contact__form{display:flex;flex-direction:column;gap:var(--space-4)}.contact__field{display:flex;flex-direction:column;gap:var(--space-2)}.contact__field-label{font-family:var(--font-sans);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.contact__field input,.contact__field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);border-radius:0;padding:var(--space-3) 0;font-family:var(--font-sans);font-size:var(--fs-md);color:var(--ink);outline:none;transition:border-color var(--dur-base) var(--ease)}.contact__field input::placeholder,.contact__field textarea::placeholder{color:var(--muted-2)}.contact__field input:focus,.contact__field textarea:focus{border-bottom-color:var(--ink)}.contact__field textarea{resize:vertical;min-height:120px}.contact__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.contact__submit{align-self:flex-start;margin-top:var(--space-3)}.contact__note{font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--muted);letter-spacing:.04em;margin:0}.contact__success{border:1px solid var(--line);padding:var(--space-6);background:var(--bg-soft);font-family:var(--font-display);font-size:1.25rem;color:var(--ink)}@media (max-width: 880px){.contact__inner{grid-template-columns:1fr}}@media (max-width: 560px){.contact__row{grid-template-columns:1fr}.contact__list li{grid-template-columns:1fr;gap:var(--space-1)}}.page-hero{background:var(--bg);padding:clamp(3rem,7vw,6rem) 0 clamp(2rem,4vw,3rem);border-bottom:1px solid var(--line)}.page-hero__inner{max-width:var(--container-wide);margin-inline:auto;padding-inline:var(--gutter);display:flex;flex-direction:column;gap:clamp(1.25rem,3vw,2rem)}.page-hero__eyebrow{margin:0}.page-hero__row{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:clamp(1.5rem,4vw,4rem);align-items:end}.page-hero__title{margin:0;font-size:clamp(2.5rem,7vw,5.5rem);line-height:1.02;letter-spacing:-.025em;color:var(--ink)}.page-hero__aside{display:flex;flex-direction:column;gap:var(--space-4);padding-bottom:var(--space-3)}.page-hero__lead{margin:0;color:var(--ink-2);max-width:42ch}.page-hero__meta{display:flex;flex-direction:column;gap:var(--space-2);font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--muted);letter-spacing:.04em}.page-hero__rule{margin-top:clamp(1rem,3vw,2rem)}.page-hero__legacy{margin-top:var(--space-4);color:var(--ink-2)}@media (max-width: 820px){.page-hero__row{grid-template-columns:1fr;align-items:start;gap:var(--space-5)}.page-hero__aside{padding-bottom:0}}.service-page{background:var(--bg)}.service-intro{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter);display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:end;border-bottom:1px solid var(--line)}.service-intro__lede{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.3;letter-spacing:-.015em;color:var(--ink);margin:0;max-width:32ch}.service-intro__stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-3)}.service-intro__stat{display:flex;flex-direction:column;gap:var(--space-1);padding-top:var(--space-3);border-top:1px solid var(--line)}.service-intro__num{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:500;line-height:1;color:var(--ink);letter-spacing:-.02em}.service-intro__lbl{font-family:var(--font-sans);font-size:var(--fs-xs);letter-spacing:.08em;color:var(--muted);text-transform:uppercase}@media (max-width: 820px){.service-intro{grid-template-columns:1fr;align-items:start}}.service-tiles{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter)}.service-tiles__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.6rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-3) 0 var(--space-7);max-width:26ch}.service-tiles__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(1.5rem,3vw,2.5rem)}.service-tile{display:flex;flex-direction:column;gap:var(--space-3)}.service-tile__media{position:relative;aspect-ratio:4 / 5;overflow:hidden;background:var(--bg-soft)}.service-tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}.service-tile:hover .service-tile__media img{transform:scale(1.04)}.service-tile__title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:-.01em;color:var(--ink);margin:0}.service-tile__body{font-family:var(--font-sans);font-size:var(--fs-sm);line-height:1.55;color:var(--ink-2);margin:0}.service-process{background:var(--bg-soft);border-block:1px solid var(--line)}.service-process__inner{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter)}.service-process__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.6rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-3) 0 var(--space-7);max-width:22ch}.service-process__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;border-top:1px solid var(--line)}.service-process__item{padding:var(--space-5) var(--space-4);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:var(--space-3)}.service-process__item:last-child{border-right:0}.service-process__num{font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--accent);letter-spacing:.1em;font-weight:600}.service-process__title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:-.01em;color:var(--ink);margin:0}.service-process__body{font-family:var(--font-sans);font-size:var(--fs-sm);line-height:1.55;color:var(--ink-2);margin:0}@media (max-width: 980px){.service-process__list{grid-template-columns:repeat(2,minmax(0,1fr))}.service-process__item:nth-child(2n){border-right:0}.service-process__item{border-bottom:1px solid var(--line)}.service-process__item:nth-last-child(-n+2){border-bottom:0}}@media (max-width: 560px){.service-process__list{grid-template-columns:1fr}.service-process__item{border-right:0;border-bottom:1px solid var(--line)}.service-process__item:last-child{border-bottom:0}}.service-features{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter);display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:start}.service-features__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.6rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:var(--space-3) 0 var(--space-5);max-width:22ch}.service-features__lead{font-family:var(--font-sans);color:var(--ink-2);line-height:1.6;margin:0 0 var(--space-6);max-width:56ch}.service-features__list{list-style:none;margin:0 0 var(--space-6);padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3) var(--space-5)}.service-features__list li{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink);padding:var(--space-3) 0;border-bottom:1px solid var(--line)}.service-features__highlights{display:flex;flex-direction:column;gap:var(--space-5);border-top:1px solid var(--line);padding-top:var(--space-5)}.service-features__highlight h4{font-family:var(--font-display);font-size:1.15rem;margin:0 0 var(--space-2);color:var(--ink);letter-spacing:-.01em}.service-features__highlight p{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-2);line-height:1.55;margin:0}@media (max-width: 880px){.service-features,.service-features__list{grid-template-columns:1fr}}.service-cta{border-top:1px solid var(--line);background:var(--ink);color:var(--bg)}.service-cta__inner{max-width:var(--container-wide);margin-inline:auto;padding:clamp(3rem,6vw,5rem) var(--gutter);display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:center}.service-cta__heading{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.75rem);letter-spacing:-.02em;line-height:1.1;color:var(--bg);margin:0;max-width:22ch}.service-cta__body{font-family:var(--font-sans);color:color-mix(in srgb,var(--bg) 75%,transparent);line-height:1.6;margin:0 0 var(--space-4);max-width:50ch}.service-cta__actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.service-cta__primary{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--bg);color:var(--ink);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.06em;text-transform:uppercase;transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.service-cta__primary:hover{background:var(--accent);color:var(--bg)}.service-cta__ghost{display:inline-flex;align-items:center;gap:var(--space-2);border:1px solid color-mix(in srgb,var(--bg) 40%,transparent);color:var(--bg);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.06em;text-transform:uppercase;transition:background var(--dur-base) var(--ease),border-color var(--dur-base) var(--ease)}.service-cta__ghost:hover{background:color-mix(in srgb,var(--bg) 12%,transparent);border-color:var(--bg)}@media (max-width: 880px){.service-cta__inner{grid-template-columns:1fr}}.threed-design-container{width:100%;background:var(--bg);padding-bottom:clamp(3rem,6vw,5rem)}.header-section{max-width:var(--container-wide);margin-inline:auto;padding:clamp(2.5rem,5vw,4rem) var(--gutter) clamp(2rem,4vw,3rem);border-bottom:1px solid var(--line)}.header-content{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:clamp(1.5rem,4vw,4rem);align-items:end}.main-title{display:none}.main-description{font-family:var(--font-display);font-size:clamp(1.15rem,1.8vw,1.4rem);line-height:1.4;color:var(--ink);margin:0;max-width:50ch}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-5)}.stat-item{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) 0;border-top:1px solid var(--line)}.stat-number{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.75rem);font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1}.stat-label{font-family:var(--font-sans);font-size:var(--fs-xs);color:var(--muted);letter-spacing:.08em;text-transform:uppercase}@media (max-width: 820px){.header-content{grid-template-columns:1fr;gap:var(--space-5);align-items:start}}.projects-grid-3d{max-width:var(--container-wide);margin:clamp(2rem,5vw,4rem) auto 0;padding-inline:var(--gutter);display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:clamp(1.5rem,3vw,2.5rem)}.project-card-3d{cursor:pointer;background:transparent;display:flex;flex-direction:column;gap:var(--space-3);transition:transform var(--dur-base) var(--ease)}.project-card-3d:hover{transform:translateY(-4px)}.project-image-container-3d{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--bg-soft)}.project-image-3d{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}.project-card-3d:hover .project-image-3d{transform:scale(1.04)}.project-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--ink) 78%,transparent);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--dur-base) var(--ease)}.project-card-3d:hover .project-overlay{opacity:1}.overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--bg);font-family:var(--font-sans);font-size:var(--fs-sm);letter-spacing:.06em;text-transform:uppercase}.overlay-icon{width:22px;height:22px}.project-info{display:flex;flex-direction:column;gap:var(--space-1)}.project-title{font-family:var(--font-display);font-size:1.25rem;letter-spacing:-.01em;color:var(--ink);margin:0;text-transform:capitalize}.project-description{font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--ink-2);line-height:1.55;margin:0}.gallery-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:color-mix(in srgb,var(--ink) 92%,transparent);z-index:1100;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .25s var(--ease)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:1200px;max-height:92vh;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line);animation:slideUp .3s var(--ease)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--line)}.modal-title{font-family:var(--font-display);font-size:1.4rem;letter-spacing:-.01em;color:var(--ink);margin:0;text-transform:capitalize}.modal-actions{display:flex;gap:var(--space-2)}.close-btn{width:36px;height:36px;border:1px solid var(--line);background:transparent;border-radius:999px;display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.close-btn:hover{background:var(--ink);color:var(--bg)}.close-icon{width:16px;height:16px}.image-display{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-soft);padding:var(--space-5);overflow:hidden}.main-image{max-width:100%;max-height:60vh;object-fit:contain}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:var(--bg);border:1px solid var(--line);border-radius:999px;display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease)}.nav-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.nav-prev{left:var(--space-4)}.nav-next{right:var(--space-4)}.nav-icon{width:18px;height:18px}.image-counter{position:absolute;bottom:var(--space-4);left:50%;transform:translate(-50%);background:var(--bg);border:1px solid var(--line);color:var(--ink-2);font-family:var(--font-sans);font-size:var(--fs-xs);padding:6px 12px;letter-spacing:.06em}.thumbnail-strip{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--line);overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--line) transparent}.thumbnail-strip::-webkit-scrollbar{height:6px}.thumbnail-strip::-webkit-scrollbar-thumb{background:var(--line)}.thumbnail-btn{flex-shrink:0;width:72px;height:54px;border:1px solid transparent;background:none;padding:0;cursor:pointer;overflow:hidden;transition:border-color var(--dur-base) var(--ease),opacity var(--dur-base) var(--ease);opacity:.6}.thumbnail-btn:hover{opacity:1}.thumbnail-btn.active{border-color:var(--ink);opacity:1}.thumbnail-image{width:100%;height:100%;object-fit:cover;display:block}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (max-width: 720px){.modal-header{padding:var(--space-3) var(--space-4)}.nav-prev{left:var(--space-3)}.nav-next{right:var(--space-3)}}
