*{box-sizing:border-box}.skip-link{z-index:100;color:#111;text-transform:none;background:#f4f1ea;border:.125rem solid #111;padding:.7rem 1rem;font-weight:900;text-decoration:none;transition:transform .18s;position:fixed;top:1rem;left:1rem;transform:translateY(-150%)}.skip-link:focus{transform:translateY(0)}a:focus-visible,button:focus-visible{outline-offset:.25rem;outline:.16rem solid}:root{--viewport-height:100svh;--viewport-width:100vw;--hero-scroll-height:145svh;--portfolio-scroll-height:500svh;--section-padding:clamp(2rem, 7vw, 8.5rem);--header-offset:clamp(.875rem, 1.35vw, 1.75rem);--font-h1:clamp(4rem, min(11vw, 18svh), 10rem);--font-h2:clamp(3rem, min(7vw, 11svh), 6.8rem);--font-h3:clamp(1.15rem, 1.55vw, 1.55rem);--font-body:clamp(1rem, 1.2vw, 1.18rem);--title-size:clamp(7rem, min(24vw, 38svh), 27rem);--project-title-size:clamp(4.5rem, min(12vw, 18svh), 12rem);--contact-title-size:clamp(5rem, min(16vw, 26svh), 17rem)}html{scroll-behavior:smooth}body{font-optical-sizing:auto;color:#111;background:#111;margin:0;font-family:Geist,Arial,Helvetica,sans-serif;overflow-x:clip}main{width:100%}h1,h2{font-optical-sizing:auto;font-family:Archivo Black,Arial,Helvetica,sans-serif}h1{font-size:var(--font-h1)}h2{font-size:var(--font-h2)}h3{font-optical-sizing:auto;font-family:Geist,Arial,Helvetica,sans-serif;font-size:var(--font-h3)}p{font-size:var(--font-body)}.site-header{top:var(--header-offset);left:var(--header-offset);right:var(--header-offset);z-index:20;color:#f4f1ea;mix-blend-mode:difference;pointer-events:none;justify-content:space-between;align-items:center;gap:1rem;min-height:3.5rem;padding:.5rem .5rem .5rem .625rem;transition:color .32s,opacity .32s;display:flex;position:fixed}.desktop-navbar{display:flex}.mobile-navbar{display:none}.site-header.is-over-hero{color:#fff;mix-blend-mode:normal}.site-logo,.menu-toggle,.site-menu{pointer-events:auto}.site-logo{color:inherit;transform-origin:50%;align-items:center;gap:.7rem;text-decoration:none;transition:color .18s,transform .18s;display:inline-flex}.site-logo:hover,.site-logo:focus-visible{transform:scale(1.04)}.logo-image{mix-blend-mode:difference;object-fit:contain;width:auto;height:clamp(2.15rem,3vw,2.75rem);display:block}.logo-mark{text-transform:uppercase;border:.125rem solid;place-items:center;width:2.625rem;height:2.625rem;font-size:.9rem;font-weight:900;line-height:1;display:grid}.logo-text{text-transform:uppercase;white-space:nowrap;font-variation-settings:"opsz" 96, "wdth" 100, "wght" 700;align-items:baseline;gap:.12em;font-family:Geist,Arial,Helvetica,sans-serif;font-size:clamp(1.18rem,1.4vw,1.55rem);font-weight:700;line-height:1;display:inline-flex}.logo-letter{text-align:center;transform-origin:50% 55%;will-change:font-variation-settings, transform, opacity;width:auto;display:inline-block}.logo-letter-space{width:.45em}.menu-toggle{z-index:22;width:3rem;height:3rem;color:inherit;cursor:pointer;background:0 0;border:0;place-items:center;padding:0;display:grid;position:relative}.menu-toggle span{transform-origin:50%;background:currentColor;grid-area:1/1;width:2rem;height:.125rem;transition:transform .18s,opacity .18s}.menu-toggle span:first-child{transform:translateY(-.5rem)}.menu-toggle span:nth-child(3){transform:translateY(.5rem)}.site-header.is-menu-open .menu-toggle span:first-child{transform:rotate(45deg)}.site-header.is-menu-open .menu-toggle span:nth-child(2){opacity:0}.site-header.is-menu-open .menu-toggle span:nth-child(3){transform:rotate(-45deg)}.site-menu{top:clamp(4.75rem,7vw,5.5rem);right:var(--header-offset);visibility:hidden;opacity:0;flex-direction:column;align-items:flex-end;gap:.35rem;transition:opacity .18s,transform .18s,visibility .18s;display:flex;position:fixed;transform:translateY(-.5rem)}.site-header.is-menu-open .site-menu{visibility:visible;opacity:1;transform:translateY(0)}.site-menu a,.portfolio-menu-toggle{color:inherit;font-variation-settings:"opsz" 96, "wdth" 75, "wght" 720;letter-spacing:.01em;text-align:right;text-transform:uppercase;cursor:pointer;transform-origin:100%;background:0 0;border:0;padding:0;font-family:inherit;font-size:clamp(2.1rem,5vw,4.75rem);font-weight:720;font-stretch:75%;line-height:.86;text-decoration:none;transition:font-variation-settings .22s,font-stretch .22s,font-weight .22s,letter-spacing .22s,transform .22s,opacity .22s;display:inline-block}.site-menu a:hover,.site-menu a:focus-visible,.portfolio-menu-toggle:hover,.portfolio-menu-toggle:focus-visible{font-variation-settings:"opsz" 96, "wdth" 92, "wght" 800;letter-spacing:.035em;font-weight:800;font-stretch:92%;transform:translate(-.18em)}.site-menu a:active,.site-menu a.is-pressed,.portfolio-menu-toggle:active,.portfolio-menu-toggle.is-pressed{font-variation-settings:"opsz" 96, "wdth" 75, "wght" 800;letter-spacing:.015em;font-weight:800;font-stretch:75%;transform:translate(-.08em)scale(.98)}.menu-item{flex-direction:column;align-items:flex-end;display:flex}.portfolio-submenu{opacity:0;justify-items:end;gap:.2rem;max-height:0;transition:max-height .24s,opacity .18s,transform .22s;display:grid;overflow:hidden;transform:translateY(-.25rem)}.portfolio-submenu-open .portfolio-submenu{opacity:1;max-height:9rem;transform:translateY(0)}.portfolio-submenu a{font-variation-settings:"opsz" 96, "wdth" 86, "wght" 760;font-size:clamp(1.05rem,2vw,1.75rem);font-weight:760;font-stretch:86%;line-height:1}.hero{min-height:var(--hero-scroll-height);color:#f4f1ea;background:#111}.hero-scene{height:var(--viewport-height);min-height:var(--viewport-height);isolation:isolate;place-items:center;padding:0;display:grid;position:sticky;top:0;overflow:hidden}.hero-background{z-index:0;pointer-events:none;object-fit:cover;transform-origin:50%;will-change:transform, filter;width:100%;height:100%;position:absolute;inset:0;transform:scale(1)}.logo-3d-stage{z-index:2;pointer-events:none;contain:layout paint size;backface-visibility:hidden;position:absolute;inset:0;transform:translateZ(0)}.logo-3d-stage canvas{backface-visibility:hidden;width:100%;height:100%;display:block;transform:translateZ(0)}.logo-3d-stage .three-black-cover{z-index:2;opacity:0;pointer-events:none;will-change:opacity;background:#f4f1ea;width:100%;height:100%;display:block;position:absolute;inset:0;transform:translateZ(0)}.logo-loading-rect{aspect-ratio:1.65;background:#000;border:.125rem solid #fff;width:clamp(4.5rem,11vw,9rem);animation:1.1s cubic-bezier(.7,0,.2,1) infinite logo-loading-rect-spin;display:block}@keyframes logo-loading-rect-spin{0%{transform:rotate(0)scale(.92)}50%{transform:rotate(180deg)scale(1)}to{transform:rotate(360deg)scale(.92)}}.hero-title{z-index:1;width:var(--viewport-width);height:var(--viewport-height);isolation:isolate;mix-blend-mode:difference;position:relative}.title-base{font-size:var(--title-size);font-variation-settings:"opsz" 96, "wdth" 75, "wght" 800;text-align:center;letter-spacing:0;white-space:nowrap;mix-blend-mode:difference;z-index:3;color:#f4f1ea;place-items:center;margin:0;font-weight:800;font-stretch:75%;line-height:.72;display:grid;position:absolute;inset:0}.title-line{display:block;overflow:visible}.title-char{transform-origin:50% 75%;font-variation-settings:"opsz" 96, "wdth" 75, "wght" 800;will-change:transform, opacity, font-variation-settings, filter;display:inline-block}.portfolio{--project-count:2;z-index:5;min-height:var(--portfolio-scroll-height);margin-top:calc(var(--viewport-height) * -1);color:#111;background:#f4f1ea;position:relative}.portfolio-window{height:var(--viewport-height);background:#f4f1ea;position:sticky;top:0;overflow:hidden}.project-track{width:calc(var(--project-count) * var(--viewport-width));height:100%;transform:translate3d(calc(var(--portfolio-x,0) * -1vw), 0, 0);will-change:transform;display:flex}.project-panel{flex:0 0 var(--viewport-width);height:100%;padding:var(--section-padding);flex-direction:column;justify-content:center;display:flex}.portfolio-intro{background:#f4f1ea;grid-template-columns:minmax(16rem,34vw) minmax(0,1fr);align-items:start;gap:clamp(2rem,6vw,7rem);display:grid}.studio-intro-section{z-index:5;min-height:var(--viewport-height);padding:var(--section-padding);color:#111;position:relative}.intro-image{--intro-image-bleed:10%;aspect-ratio:4/5;color:#111;background:#f4f1ea;border:.125rem solid;width:100%;position:relative;overflow:hidden}.intro-image-layer{top:calc(0% - var(--intro-image-bleed));left:calc(0% - var(--intro-image-bleed));width:calc(100% + var(--intro-image-bleed) + var(--intro-image-bleed));height:calc(100% + var(--intro-image-bleed) + var(--intro-image-bleed));backface-visibility:hidden;transform-style:preserve-3d;transform-origin:50%;will-change:transform;display:block;position:absolute}img.intro-image-layer{object-fit:cover}.intro-image-layer img{object-fit:cover;width:100%;height:100%;display:block}.intro-image-layer-back{z-index:1}.intro-image-depth{display:none}.intro-image-depth-back{z-index:2;mix-blend-mode:multiply;background:linear-gradient(#0000 48%,#0000006b 74%,#000000bd 100%)}.intro-image-layer-middle{z-index:3}.intro-image-depth-front{z-index:4;mix-blend-mode:multiply;background:linear-gradient(#0000 46%,#00000085 72%,#000000e0 100%)}.intro-image-layer-front{z-index:5;overflow:visible}.intro-image-layer-front img{will-change:transform}.intro-content{grid-template-rows:auto auto minmax(0,1fr) auto;align-self:stretch;max-width:60rem;display:grid}.portfolio-intro h2{text-transform:uppercase;text-wrap:balance;max-width:100rem;margin:0;font-size:clamp(3.25rem,min(5.4vw,8svh),7.6rem);font-weight:800;line-height:.84}.intro-heading{margin:0 0 clamp(1.4rem,2.7vw,2.4rem)}.intro-heading .section-label{text-transform:none;margin-bottom:clamp(.65rem,1.2vw,.95rem)}.intro-reveal-word{display:inline-block}.intro-reveal-line{display:block;overflow:hidden}.intro-reveal-line-inner{will-change:transform, opacity, filter;display:block}.portfolio-intro>.intro-content>.intro-description{text-wrap:pretty;max-width:100rem;margin:0;font-size:clamp(1.18rem,1.45vw,1.5rem);font-weight:560;line-height:1.3}.intro-lists{grid-template-columns:repeat(3,minmax(0,1fr));align-self:center;gap:clamp(1.25rem,2.6vw,2.2rem);margin-top:clamp(1.5rem,3vw,2.4rem);margin-bottom:clamp(1.5rem,3vw,2.4rem);display:grid}.intro-lists h3{letter-spacing:.02em;text-transform:uppercase;margin:0 0 .7rem;font-size:clamp(.92rem,1vw,1.08rem);font-weight:800;line-height:1}.intro-lists p{text-wrap:pretty;margin:0;font-size:clamp(.98rem,1.05vw,1.12rem);font-weight:500;line-height:1.5}.logo-carousel{--logo-size:clamp(4.75rem, 7.2vw, 7.4rem);--logo-gap:clamp(.7rem, 1.4vw, 1.15rem);width:100%;margin-top:0;padding-top:0;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 7% 93%,#0000);mask-image:linear-gradient(90deg,#0000,#000 7% 93%,#0000)}.logo-carousel-track{gap:var(--logo-gap);will-change:transform;width:max-content;animation:28s linear infinite logo-carousel-scroll;display:flex}.client-logo{flex:0 0 var(--logo-size);width:var(--logo-size);aspect-ratio:1;background:0 0;place-items:center;padding:clamp(.8rem,1.2vw,1.1rem);display:grid}.client-logo img{object-fit:contain;width:100%;height:100%;display:block}.client-logo-ergo img{width:105%;height:105px}@keyframes logo-carousel-scroll{0%{transform:translate(0,0)}to{transform:translate3d(calc(-50% - (var(--logo-gap) / 2)), 0, 0)}}@media (prefers-reduced-motion:reduce){.logo-carousel-track{animation-duration:1ms;animation-iteration-count:1}}.portfolio-3d{background:#d8ff3e;position:relative;overflow:hidden}.portfolio-category-copy{z-index:4;max-width:54rem;position:relative}.portfolio-image-grid{top:50%;right:var(--section-padding);z-index:1;pointer-events:none;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(.45rem,1vw,.9rem);width:min(54vw,56rem);display:grid;position:absolute;transform:translateY(-50%)}.portfolio-image-grid img{aspect-ratio:4/5;object-fit:cover;object-position:center center;opacity:1;filter:saturate(1.08)contrast(1.04);will-change:opacity, transform, filter;width:100%;display:block;transform:translate(0,0)scale(1)}@media (prefers-reduced-motion:reduce){.portfolio-image-grid img{animation:none;transform:none}}.section-label{text-transform:uppercase;will-change:opacity, transform, filter;margin:0 0 1.125rem;font-size:.875rem;font-weight:800}.project-panel h2{max-width:53.75rem;font-size:var(--project-title-size);will-change:opacity, transform, filter;margin:0 0 1.125rem;font-weight:800;line-height:.78}.project-panel p:not(.section-label){will-change:opacity, transform, filter;max-width:38.75rem;margin:0;font-size:clamp(1.125rem,2vw,1.5rem);font-weight:600;line-height:1.6}.contact{z-index:6;min-height:var(--viewport-height);padding:var(--section-padding);color:#f4f1ea;background:#111;align-items:center;display:flex;position:relative}.contact-inner{width:100%}.contact h2{font-size:var(--contact-title-size);text-transform:uppercase;margin:0 0 1.5rem;font-weight:800;font-stretch:120%;line-height:.78}.contact a{color:inherit;font-size:clamp(1.75rem,5vw,5rem);font-weight:800;line-height:1;text-decoration:none}.contact a:hover{text-underline-offset:.12em;text-decoration:underline}@media (width<=720px){.desktop-navbar{display:none}.mobile-navbar{display:flex}.title-base{font-size:clamp(4.25rem,28vw,8.5rem);line-height:.76}.project-panel{justify-content:flex-end;padding:7rem 1.25rem 3rem}.portfolio-intro{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:1.5rem;display:flex}.intro-image{aspect-ratio:1/1.18;width:min(18rem,58vw)}.portfolio-intro h2{font-size:clamp(3.2rem,15vw,5.75rem);line-height:.86}.portfolio-intro>.intro-content>p:not(.section-label){font-size:clamp(1.05rem,4.4vw,1.34rem);line-height:1.48}.intro-lists{grid-template-columns:1fr;gap:1.05rem;margin-top:1.65rem;margin-bottom:0}.intro-content{align-self:auto;display:block}.logo-carousel{margin-top:clamp(1.75rem,6vw,2.4rem);padding-top:0}.project-panel h2{font-size:clamp(3.5rem,20vw,6rem)}.contact{padding:7rem 1.25rem 3rem}.contact h2{font-size:clamp(4.5rem,24vw,8rem)}.contact a{overflow-wrap:anywhere;max-width:100%;font-size:clamp(1.75rem,9vw,3rem);display:inline-block}}@media (width<=420px){.logo-text{font-size:clamp(.88rem,5vw,1rem)}.title-base{font-size:clamp(3.75rem,29vw,7rem)}}.hero-copy{z-index:4;color:#f4f1ea;text-align:center;mix-blend-mode:normal;justify-items:center;max-width:34rem;display:grid;position:absolute;bottom:clamp(2rem,6vw,5rem);left:50%;transform:translate(-50%)}.hero-cta{min-height:3.25rem;color:inherit;text-transform:uppercase;border:.125rem solid;border-radius:999rem;justify-content:center;align-items:center;margin-bottom:clamp(1.35rem,3vw,2.25rem);padding:.2rem 1.65rem .08rem;font-size:clamp(1.15rem,1.9vw,1.55rem);font-weight:850;line-height:1;text-decoration:none;transition:color .18s,background-color .18s,transform .18s;display:inline-flex}.hero-cta:hover,.hero-cta:focus-visible{color:#111;background:#f4f1ea;transform:translateY(-.12rem)}.hero-copy p{margin:0;font-size:clamp(1.1rem,2vw,1.45rem);font-weight:620;line-height:1.35}.panel-link{width:fit-content;color:inherit;text-transform:uppercase;text-underline-offset:.18em;margin-top:1.5rem;font-size:clamp(1rem,1.6vw,1.35rem);font-weight:850;text-decoration-thickness:.1em;display:inline-block}.services{z-index:6;padding:var(--section-padding);color:#111;background:#f4f1ea;position:relative}.services-inner{max-width:90rem;margin:0 auto}.services h2{text-transform:uppercase;max-width:68rem;margin:0 0 clamp(2rem,5vw,4rem);font-size:clamp(3.2rem,min(9vw,13svh),8rem);font-weight:800;line-height:.82}.service-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(1.25rem,3vw,2.5rem);display:grid}.service-grid article{border-top:.125rem solid;padding-top:1rem}.service-grid h3{text-transform:uppercase;margin:0 0 .75rem;font-size:clamp(1.2rem,2vw,1.7rem);font-weight:800;line-height:1}.service-grid p,.contact p{max-width:44rem;margin:0 0 1.5rem;font-size:clamp(1.1rem,2vw,1.45rem);font-weight:560;line-height:1.45}.no-script-content{color:#111;background:#f4f1ea;padding:2rem}.no-script-content a{color:inherit;font-weight:900}.project-page{color:#111;background:#f4f1ea}.project-page .site-header{color:#f4f1ea}.project-hero{min-height:var(--viewport-height);padding:var(--section-padding);color:#f4f1ea;background:#111;align-items:end;display:grid;position:relative;overflow:hidden}.project-hero:after{content:"";z-index:1;pointer-events:none;background:linear-gradient(#11111114,#111111c7);position:absolute;inset:0}.project-hero-media{background:#111;position:absolute;inset:0}.project-hero-media video,.project-hero-media img{object-fit:cover;width:100%;height:100%;display:block}.project-hero-image{background:linear-gradient(90deg,#d8ff3ef2 0 25%,#0000 25% 100%),#111;place-items:center;padding:clamp(5rem,12vw,11rem);display:grid}.project-hero-image img{object-fit:contain;mix-blend-mode:difference;width:min(42rem,72vw);height:auto}.project-hero-copy{z-index:2;max-width:72rem;position:relative}.project-hero h1{text-transform:uppercase;max-width:68rem;margin:0 0 1.25rem;font-size:clamp(4.5rem,min(13vw,20svh),13rem);font-weight:800;line-height:.78}.project-hero p:not(.section-label),.project-detail-intro p:not(.section-label),.project-contact p{max-width:47rem;margin:0;font-size:clamp(1.15rem,2vw,1.55rem);font-weight:590;line-height:1.45}.project-hero-copy .section-label,.project-hero-copy h1,.project-hero-copy p,.project-hero-copy .project-cta,.project-detail .section-label,.project-detail h2,.project-detail h3,.project-detail p,.project-contact .section-label,.project-contact h2,.project-contact p,.project-contact a{will-change:opacity, transform, filter}.project-cta{width:fit-content;color:inherit;text-transform:uppercase;text-underline-offset:.18em;margin-top:1.75rem;font-size:clamp(1rem,1.55vw,1.35rem);font-weight:900;text-decoration-thickness:.1em;display:inline-block}.project-detail{padding:var(--section-padding);color:#111;background:#f4f1ea;grid-template-columns:minmax(18rem,.8fr) minmax(0,1.2fr);gap:clamp(2rem,6vw,6rem);display:grid}.project-page-3d .project-detail{background:#d8ff3e}.project-index{min-height:var(--viewport-height);padding:calc(var(--section-padding) * 1.45) var(--section-padding) var(--section-padding);color:#111;background:#f4f1ea}.project-index-heading{max-width:72rem;margin-bottom:clamp(2.5rem,7vw,6rem)}.project-index-heading h1{text-transform:uppercase;margin:0 0 1.25rem;font-size:clamp(4.5rem,min(13vw,20svh),13rem);font-weight:800;line-height:.78}.project-index-heading p:not(.section-label){max-width:48rem;margin:0;font-size:clamp(1.15rem,2vw,1.55rem);font-weight:590;line-height:1.45}.project-list{border-top:.125rem solid;gap:0;display:grid}.project-list-row{color:inherit;cursor:pointer;border-bottom:.125rem solid;grid-template-columns:minmax(22rem,.82fr) minmax(0,1.18fr);gap:clamp(1.25rem,3vw,3rem);padding:clamp(1.25rem,3vw,2rem) 0;text-decoration:none;transition:background-color .22s,padding-inline .22s;display:grid}.project-list-row:hover,.project-list-row:focus-visible{background:#1111110d;outline:none;padding-inline:clamp(.75rem,1.5vw,1.25rem)}.project-list-meta{text-align:left;grid-template-rows:auto 1fr auto;grid-template-columns:1fr;align-content:stretch;gap:clamp(.9rem,1.6vw,1.4rem);margin-block:clamp(.35rem,1vw,.85rem);display:grid}.project-list-meta-row{align-content:start;display:grid}.project-list-meta-row:nth-child(2){align-content:center}.project-list-meta-row:last-child{align-content:end}.project-list-meta span{text-transform:uppercase;margin-bottom:.55rem;font-family:Geist,system-ui,sans-serif;font-size:clamp(.72rem,.9vw,.86rem);font-weight:760;line-height:1;display:block}.project-list-meta h2,.project-list-meta p{margin:0}.project-list-meta h2{text-transform:uppercase;font-size:clamp(2.35rem,5vw,5rem);font-weight:850;line-height:.84}.project-list-meta p{text-transform:uppercase;max-width:34rem;font-size:clamp(1.02rem,1.5vw,1.35rem);font-weight:680;line-height:1.18}.project-list-meta-title p,.project-list-meta-row:last-child p{text-transform:none;max-width:24rem;font-size:clamp(.9rem,1vw,1.02rem);font-weight:590;line-height:1.3}.project-list-images{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:0;display:grid}.project-list-images figure{aspect-ratio:3.5/5;background:#111;justify-content:center;align-items:center;margin:0;display:flex;overflow:hidden}.project-list-images img,.project-list-images video{object-fit:cover;object-position:center center;transform-origin:50%;will-change:transform;background:#111;flex:none;width:122%;height:122%;display:block;transform:translate(0,0)scale(1.08)}.project-list-row--wip .project-list-images figure{background:#f4f1ea}body:after,.project-case-page:before,.transition-page:before{content:"";--page-transition-bleed:max(2rem, 8svh);inset:calc(var(--page-transition-bleed) * -1);z-index:200;pointer-events:none;background:#111;position:fixed}body:after{transform:translateY(100%)}body.is-page-exiting:after{animation:.42s cubic-bezier(.76,0,.24,1) forwards page-exit-up}.project-case-page:before,.transition-page:before{animation:.68s cubic-bezier(.76,0,.24,1) forwards page-enter-up}@keyframes page-exit-up{to{transform:translateY(0)}}@keyframes page-enter-up{to{transform:translateY(-100%)}}.project-case{min-height:var(--viewport-height);padding:calc(var(--section-padding) * 1.45) var(--section-padding) var(--section-padding);color:#111;background:#f4f1ea;grid-template-columns:minmax(18rem,.42fr) minmax(0,.58fr);align-items:start;gap:clamp(2rem,5vw,5rem);display:grid}.project-case-copy{left:var(--section-padding);top:calc(var(--header-offset) + 5rem);bottom:var(--section-padding);z-index:4;width:min(40rem, calc(42vw - var(--section-padding) - 1.5rem));max-width:calc(100vw - (var(--section-padding) * 2));pointer-events:none;flex-direction:column;justify-content:flex-end;display:flex;position:fixed}.project-case-copy a{pointer-events:auto}.project-case-media{grid-column:2}.project-back-link{width:fit-content;color:inherit;text-transform:uppercase;text-underline-offset:.18em;margin-bottom:auto;font-size:clamp(.82rem,1vw,.95rem);font-weight:820;line-height:1;text-decoration-thickness:.1em}.project-case-copy h1{text-transform:uppercase;margin:0 0 1.15rem;font-size:clamp(3.6rem,min(8vw,13svh),9rem);font-weight:840;line-height:.78}.project-case-copy>p:not(.section-label){max-width:34rem;margin:0;font-size:clamp(1.05rem,1.55vw,1.32rem);font-weight:570;line-height:1.42}.project-case-data{border-top:.125rem solid;grid-template-columns:minmax(0,1fr) auto;gap:clamp(1rem,2vw,2rem);margin:clamp(2rem,4vw,3.5rem) 0 0;padding-top:1rem;display:grid}.project-case-data dt,.project-case-data dd{margin:0}.project-case-data dt{text-transform:uppercase;margin-bottom:.5rem;font-family:Geist,system-ui,sans-serif;font-size:clamp(.72rem,.9vw,.86rem);font-weight:760;line-height:1}.project-case-data dd{max-width:16rem;font-size:clamp(.98rem,1.2vw,1.12rem);font-weight:600;line-height:1.25}.project-case-video{aspect-ratio:5/4;background:#111;width:100%;position:relative;overflow:hidden}.project-case-video iframe{border:0;width:142%;height:100%;display:block;transform:translate(-14.8%)}.project-case-video-sound{z-index:2;color:#f4f1ea;min-height:2.4rem;font:inherit;text-transform:uppercase;cursor:pointer;-webkit-backdrop-filter:blur(.7rem);backdrop-filter:blur(.7rem);background:#111111b8;border:.1rem solid #f4f1eac7;border-radius:999rem;justify-content:center;align-items:center;padding:.7rem .9rem;font-size:clamp(.72rem,.85vw,.82rem);font-weight:760;line-height:1;transition:background-color .18s,color .18s,border-color .18s;display:inline-flex;position:absolute;top:clamp(.75rem,1.5vw,1.2rem);left:clamp(.75rem,1.5vw,1.2rem)}.project-case-video-sound:hover,.project-case-video-sound:focus-visible,.project-case-video-sound.is-unmuted{color:#111;background:#f4f1ea;border-color:#f4f1ea;outline:none}.project-case-media img,.project-case-media video{object-fit:cover;object-position:center center;background:#111;width:100%;min-height:min(78svh,52rem);display:block}.project-case-media img:nth-of-type(2n),.project-case-media video:nth-of-type(2n){aspect-ratio:4/5}.project-case-media img:nth-of-type(odd),.project-case-media video:nth-of-type(odd){aspect-ratio:5/4}.project-detail h2{text-transform:uppercase;max-width:50rem;margin:0 0 1.25rem;font-size:clamp(3.3rem,min(7vw,11svh),7.5rem);font-weight:800;line-height:.82}.project-service-list{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:clamp(1.25rem,3vw,2.5rem);display:grid}.project-service-list article{border-top:.125rem solid;padding-top:1rem}.project-service-list h3{text-transform:uppercase;margin:0 0 .75rem;font-size:clamp(1.25rem,2vw,1.8rem);font-weight:800;line-height:1}.project-service-list p{margin:0;font-size:clamp(1.05rem,1.55vw,1.28rem);font-weight:560;line-height:1.42}.project-contact{min-height:80svh;padding:var(--section-padding);color:#f4f1ea;background:#111;flex-direction:column;justify-content:center;display:flex}.project-contact h2{text-transform:uppercase;max-width:64rem;margin:0 0 1.35rem;font-size:clamp(4rem,min(11vw,17svh),11rem);font-weight:800;line-height:.8}.project-contact p{margin-bottom:1.5rem}.project-contact a{width:fit-content;color:inherit;font-size:clamp(1.75rem,5vw,5rem);font-weight:850;line-height:1;text-decoration:none}.project-contact a:hover{text-underline-offset:.12em;text-decoration:underline}@media (width<=900px){.service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-detail,.project-list-row,.project-list-meta{grid-template-columns:1fr}.project-list-meta{grid-template-rows:auto;gap:1rem}.project-list-meta-row:nth-child(2),.project-list-meta-row:last-child{align-content:start}.project-case{grid-template-columns:1fr}.project-case-copy{pointer-events:auto;width:auto;min-height:auto;position:relative;top:auto;bottom:auto;left:auto}.project-case-media{grid-column:auto}.project-back-link{margin-bottom:2.5rem}.project-case-data{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){:root{--section-padding:1.25rem;--project-title-size:clamp(2.9rem, 14vw, 4.75rem);--contact-title-size:clamp(3.2rem, 16vw, 5.25rem)}.hero-copy{mix-blend-mode:normal;width:calc(100% - 2.5rem);max-width:min(100%,26rem);inset:auto auto 2rem 50%;transform:translate(-50%)}.hero-copy p{font-size:clamp(1rem,4.8vw,1.25rem)}.hero-cta{min-height:2.85rem;margin-bottom:1.15rem;padding-inline:1.25rem;font-size:1.05rem}.portfolio{min-height:auto;margin-top:0}.hero{min-height:var(--hero-scroll-height)}.hero-scene{height:var(--viewport-height);min-height:var(--viewport-height);position:sticky;top:0}.hero-background{transform:scale(1.08)}.portfolio-window{height:auto;position:relative;overflow:visible}.project-track{width:100%;height:auto;display:block;transform:none!important}.project-panel{width:100%;min-height:var(--viewport-height);height:auto;padding:5.25rem 1.25rem 2.5rem}.portfolio-category{justify-content:center}.portfolio-3d{min-height:var(--viewport-height);justify-content:center;padding-bottom:min(48svh,24rem)}.portfolio-category-copy{max-width:100%}.portfolio-image-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-content:end;width:auto;height:min(46svh,24rem);inset:auto 1.25rem 0;transform:none}.portfolio-image-grid img:nth-child(n+5){display:none}.portfolio-intro{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:clamp(1.1rem,5vw,1.6rem);min-height:auto;padding-top:4.75rem;padding-bottom:2.75rem;display:flex}.project-index{padding-top:5.25rem}.project-index-heading{margin-bottom:2.5rem}.project-index-heading h1{font-size:clamp(3.1rem,18vw,5.8rem)}.project-list-row{gap:1.25rem}.project-list-images{grid-template-columns:repeat(2,minmax(0,1fr))}.project-case{gap:2.5rem;padding-top:5.25rem}.project-case-copy h1{font-size:clamp(3.1rem,17vw,5.6rem)}.project-case-data{grid-template-columns:1fr}.project-case-media img,.project-case-media video{min-height:auto}.intro-image{aspect-ratio:4/4.85;width:min(100%,28rem);margin:0 auto}.portfolio-intro h2{max-width:100%;font-size:clamp(2.7rem,12vw,4.4rem);line-height:.88}.portfolio-intro>.intro-content>p:not(.section-label){max-width:100%;font-size:clamp(1rem,4.1vw,1.18rem);line-height:1.5}.intro-lists{grid-template-columns:1fr;gap:1rem;margin-top:clamp(1.25rem,5vw,1.65rem)}.project-panel h2{max-width:100%;font-size:var(--project-title-size);line-height:.84}.project-panel p:not(.section-label){max-width:100%;font-size:clamp(1rem,4.3vw,1.2rem)}.services{padding:7rem 1.25rem 3rem}.services h2{font-size:clamp(3.4rem,17vw,6.5rem)}.service-grid{grid-template-columns:1fr}.project-hero,.project-detail,.project-contact{padding:7rem 1.25rem 3rem}.project-hero h1{font-size:clamp(3.55rem,17vw,6.5rem)}.project-detail h2{font-size:clamp(3rem,14vw,5.5rem)}.project-service-list{grid-template-columns:1fr}.project-contact h2{font-size:clamp(3.5rem,17vw,6.5rem)}.project-contact a{overflow-wrap:anywhere;max-width:100%;font-size:clamp(1.75rem,9vw,3rem)}:root{--viewport-height:100svh;--hero-scroll-height:180svh}html,body{width:100%;max-width:100%;overflow-x:clip}main,section,.hero,.hero-scene,.portfolio,.portfolio-window,.project-track,.project-panel,.portfolio-intro,.services,.contact{width:100%;max-width:100%}.hero-scene{height:var(--viewport-height);min-height:var(--viewport-height);position:sticky;top:0;overflow:hidden}.project-track{overflow:visible}.project-panel{flex:none;overflow:hidden}.portfolio-intro{overflow:visible}.hero{height:var(--hero-scroll-height);min-height:var(--hero-scroll-height);background:#111;position:relative;overflow:visible}.hero-scene{z-index:1;width:100%;height:var(--viewport-height);min-height:var(--viewport-height);max-height:var(--viewport-height);isolation:isolate;background:#111;position:relative;overflow:hidden}.hero-title,.logo-3d-stage{height:var(--viewport-height);max-height:var(--viewport-height);overflow:hidden}.logo-3d-stage{background:#111;width:100%;height:100%;position:absolute;inset:0}.logo-3d-stage canvas{width:100%;height:100%;display:block}.logo-3d-stage .three-black-cover{z-index:2;opacity:0;pointer-events:none;will-change:opacity;background:#111;width:100%;height:100%;display:block;position:absolute;inset:0;transform:translateZ(0)}.portfolio-intro{z-index:2;background:#f4f1ea;border-radius:0;margin-top:0;padding-top:13.25rem;position:relative}.hero-scene>.hero-copy{top:auto;left:50%;bottom:calc(1.75rem + env(safe-area-inset-bottom));z-index:6;color:#f4f1ea;pointer-events:auto;width:calc(100% - 2.5rem);max-width:min(100%,26rem);position:absolute;transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}.project-track{transform:none!important}.portfolio,.hero{min-height:auto;margin-top:0}.portfolio-window,.hero-scene{height:auto;min-height:var(--viewport-height);position:relative}.project-track{width:100%;display:block}.project-panel{min-height:var(--viewport-height)}}.work-in-process{z-index:999999;letter-spacing:.08em;text-transform:uppercase;color:#01010114;text-align:center;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:.36em;width:max-content;max-width:140vw;font-family:Geist,Arial,Helvetica,sans-serif;font-size:clamp(.5rem,min(2.2vw,4.4svh),3.5rem);font-weight:700;line-height:.95;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-18deg)}@media (width<=720px){.work-in-process{gap:.42em;font-size:clamp(.9rem,min(5.6vw,5.8svh),2.6rem)}h1,h2,h3,p,a{overflow-wrap:anywhere;max-width:100%}h1,h2,h3{text-wrap:balance}.title-base{font-size:clamp(3.35rem,23vw,6.25rem)}.portfolio-intro h2,.services h2,.project-index-heading h1,.project-case-copy h1,.project-hero h1,.project-detail h2,.project-contact h2{font-size:clamp(2.45rem,12vw,4.35rem);line-height:.88}.project-panel h2,.contact h2{font-size:clamp(2.75rem,14vw,4.75rem);line-height:.86}.portfolio-intro h2{font-size:clamp(2.65rem,11.5vw,4.2rem);line-height:.88}.hero-copy p,.portfolio-intro>.intro-content>p:not(.section-label),.project-panel p:not(.section-label),.service-grid p,.contact p,.project-hero p:not(.section-label),.project-detail-intro p:not(.section-label),.project-contact p,.project-case-copy>p:not(.section-label),.project-service-list p{font-size:clamp(.98rem,4vw,1.18rem);line-height:1.42}.portfolio-intro>.intro-content>p:not(.section-label){font-size:clamp(1rem,4.1vw,1.18rem);line-height:1.5}.intro-lists h3{font-size:clamp(.9rem,3.3vw,1rem)}.intro-lists p{font-size:clamp(.94rem,3.7vw,1.04rem);line-height:1.5}.contact a,.project-contact a{font-size:clamp(1.35rem,7vw,2.35rem);line-height:1.05}}@media (width<=420px){.title-base{font-size:clamp(3rem,21vw,5rem)}.portfolio-intro h2,.services h2,.project-index-heading h1,.project-case-copy h1,.project-hero h1,.project-detail h2,.project-contact h2{font-size:clamp(2.1rem,10.5vw,3.35rem)}.portfolio-intro h2{font-size:clamp(2.2rem,10vw,3.2rem)}.project-panel h2,.contact h2{font-size:clamp(2.35rem,12vw,3.85rem)}}@media (width<=720px){.hero{height:var(--hero-scroll-height);min-height:var(--hero-scroll-height);background:#111;position:relative;overflow:visible}.hero-scene{z-index:1;opacity:1;visibility:visible;isolation:isolate;background:#111;width:100%;transition:none;overflow:hidden;transform:translateZ(0);height:var(--viewport-height)!important;min-height:var(--viewport-height)!important;max-height:var(--viewport-height)!important;position:sticky!important;inset:0 auto auto!important}.hero-title,.logo-3d-stage{width:100%;height:var(--viewport-height);min-height:var(--viewport-height);max-height:var(--viewport-height);position:absolute;inset:0;overflow:hidden}.logo-3d-stage{background:#111}.logo-3d-stage canvas{width:100%;height:100%;display:block}.portfolio-intro{z-index:10;background:#f4f1ea;border-radius:0;margin-top:0;padding-top:4.75rem;position:relative}}.title-base,.project-hero h1,.project-index-heading h1,.project-case-copy h1,h1{font-size:var(--font-h1)}.portfolio-intro h2,.project-panel h2,.contact h2,.services h2,.project-detail h2,.project-contact h2,h2{font-size:var(--font-h2)}.intro-lists h3,.service-grid h3,.project-service-list h3,.project-list-meta h2,.site-menu a,.portfolio-menu-toggle,.contact a,.project-contact a,h3{font-size:var(--font-h3)}.section-label,.portfolio-submenu a,.hero-cta,.panel-link,.project-cta,.project-back-link,.project-list-meta span,.project-case-data dt,.hero-copy p,.portfolio-intro>.intro-content>.intro-description,.portfolio-intro>.intro-content>p:not(.section-label),.intro-lists p,.project-panel p:not(.section-label),.service-grid p,.contact p,.project-hero p:not(.section-label),.project-detail-intro p:not(.section-label),.project-index-heading p:not(.section-label),.project-list-meta p,.project-case-copy>p:not(.section-label),.project-case-data dd,.project-service-list p,.project-contact p,p{font-size:var(--font-body)}@media (width<=720px){:root{--font-h1:clamp(3rem, 14vw, 5.2rem);--font-h2:clamp(2.35rem, 10vw, 4rem);--font-h3:clamp(1.08rem, 4.3vw, 1.28rem);--font-body:clamp(.98rem, 3.8vw, 1.1rem)}}html.lenis,html.lenis body{height:auto}.lenis:not(.lenis-autoToggle).lenis-stopped{overflow:clip}.lenis [data-lenis-prevent],.lenis [data-lenis-prevent-wheel],.lenis [data-lenis-prevent-touch],.lenis [data-lenis-prevent-vertical],.lenis [data-lenis-prevent-horizontal]{overscroll-behavior:contain}.lenis.lenis-smooth iframe{pointer-events:none}.lenis.lenis-autoToggle{transition-behavior:allow-discrete;transition-property:overflow;transition-duration:1ms}
