/* HH DESIGNERS v3 — glass, dual theme, zero italics, zero ornament */
:root{
  --paper:#FFFFFF;--paper-2:#F5F5F4;--ink:#181818;--ink-2:#3F3F3F;--mute:#8A8A8A;
  --line:rgba(24,24,24,.12);--dark:#161616;--dark-2:#101010;
  --glass:rgba(255,255,255,.55);--glass-line:rgba(255,255,255,.6);--glass-shadow:0 10px 36px rgba(24,24,24,.12);
  --sans:"Inter",-apple-system,Helvetica,Arial,sans-serif;
  --tight:"Inter Tight","Inter",-apple-system,Helvetica,Arial,sans-serif;
  --max:1320px;--pad:clamp(20px,4vw,56px);--ease:cubic-bezier(.22,.8,.24,1);
}
[data-theme="dark"]{
  --paper:#0F0F0F;--paper-2:#1A1A1A;--ink:#F2F2F1;--ink-2:#C9C9C7;--mute:#8E8E8C;
  --line:rgba(242,242,241,.14);--dark:#161616;--dark-2:#0B0B0B;
  --glass:rgba(18,18,18,.55);--glass-line:rgba(255,255,255,.12);--glass-shadow:0 10px 36px rgba(0,0,0,.5);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:clip}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;transition:background .35s var(--ease),color .35s var(--ease)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--paper)}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px}

.display{font-family:var(--tight);font-weight:600;letter-spacing:-.035em;line-height:.99}
.display em{font-style:normal;font-weight:inherit;color:inherit}
em,i{font-style:normal}
.d-xl{font-size:clamp(48px,8vw,118px);letter-spacing:-.04em}
.d-lg{font-size:clamp(36px,5.4vw,76px)}
.d-md{font-size:clamp(28px,3.6vw,48px)}
.d-sm{font-size:clamp(22px,2.6vw,32px);line-height:1.08}
.lede{font-size:clamp(17px,1.5vw,20px);line-height:1.6;color:var(--ink-2);max-width:62ch;font-weight:450}
.meta{font-size:13px;color:var(--mute);font-weight:500}
.num{font-feature-settings:"tnum" 1,"lnum" 1;font-variant-numeric:tabular-nums lining-nums}
.type-word{color:var(--ink)}
.caret{display:inline-block;width:.05em;min-width:3px;height:.82em;background:var(--ink);margin-left:.06em;transform:translateY(.08em);animation:blink 1.05s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding:clamp(72px,9vw,140px) 0}
.section.tight{padding:clamp(48px,6vw,88px) 0}
.hairline{border:0;border-top:1px solid var(--line)}
.row-split{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(24px,4vw,72px);align-items:end}
@media(max-width:860px){.row-split{grid-template-columns:1fr;align-items:start}}

/* scroll progress — every page */
.readbar{position:fixed;top:0;left:0;height:2.5px;background:var(--ink);width:0;z-index:75;transition:background .35s}

/* ---------- liquid glass header ---------- */
.site-head{position:fixed;top:12px;left:0;right:0;z-index:60;pointer-events:none;transition:transform .45s var(--ease)}
.site-head.hide{transform:translateY(calc(-100% - 16px))}
.head-in{
  pointer-events:auto;
  max-width:calc(var(--max) - 2*var(--pad) + 48px);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  height:62px;padding:0 12px 0 22px;border-radius:999px;
  background:var(--glass);
  -webkit-backdrop-filter:blur(22px) saturate(1.7);backdrop-filter:blur(22px) saturate(1.7);
  border:1px solid var(--glass-line);
  box-shadow:var(--glass-shadow), inset 0 1px 0 rgba(255,255,255,.35);
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
}
[data-theme="dark"] .head-in{box-shadow:var(--glass-shadow), inset 0 1px 0 rgba(255,255,255,.07)}
.brand{display:flex;align-items:center}
.brand img{height:28px;width:auto;display:none}
:root:not([data-theme="dark"]) .brand .logo-light{display:block}
[data-theme="dark"] .brand .logo-dark{display:block}
.nav{display:flex;align-items:center;gap:clamp(12px,2vw,26px)}
.nav a.link{font-size:13.5px;font-weight:550;color:var(--ink-2);position:relative;padding:6px 0}
.nav a.link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--ink);transition:right .3s var(--ease)}
.nav a.link:hover{color:var(--ink)}
.nav a.link:hover::after,.nav a.link[aria-current]::after{right:0}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:14px;font-weight:600;padding:14px 22px;border:1px solid var(--ink);border-radius:0;background:transparent;color:var(--ink);cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease),opacity .25s}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn.primary{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn.primary:hover{opacity:.88}
.head-in .btn.primary{border-radius:999px;padding:12px 20px}
.btn.on-dark{background:#fff;border-color:#fff;color:#141414}
.btn.on-dark:hover{background:#E9E9E7;color:#141414}
.btn.ghost-light{background:transparent;border-color:rgba(255,255,255,.35);color:#fff}
.btn.ghost-light:hover{background:#fff;color:#141414;border-color:#fff}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.search-pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--mute);border:1px solid var(--line);border-radius:999px;padding:10px 14px;cursor:pointer;background:transparent;transition:border-color .25s,color .25s}
.search-pill:hover{border-color:var(--ink);color:var(--ink)}
.search-pill kbd{font-family:var(--sans);font-size:11px;border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:var(--mute)}
.theme-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--ink-2);cursor:pointer;transition:border-color .25s,color .25s,transform .4s var(--ease)}
.theme-btn:hover{border-color:var(--ink);color:var(--ink)}
.theme-btn:active{transform:rotate(40deg)}
.theme-btn svg{width:16px;height:16px}
.theme-btn .sun{display:none}.theme-btn .moon{display:block}
[data-theme="dark"] .theme-btn .sun{display:block}
[data-theme="dark"] .theme-btn .moon{display:none}
.menu-btn{display:none}

/* ---------- hero ---------- */
.hero{padding-top:clamp(150px,19vh,210px)}
.hero-sub{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-top:38px;flex-wrap:wrap}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-media{margin-top:clamp(40px,6vw,72px);position:relative;overflow:hidden;height:clamp(380px,70vh,740px);background:var(--paper-2)}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.045);transition:opacity 1.1s var(--ease),transform 5.2s linear}
.hero-media img.on{opacity:1;transform:scale(1)}
.hero-media .tag{position:absolute;left:14px;bottom:14px;z-index:2;background:rgba(14,14,14,.5);-webkit-backdrop-filter:blur(16px) saturate(1.5);backdrop-filter:blur(16px) saturate(1.5);border:1px solid rgba(255,255,255,.18);border-radius:999px;color:#fff;font-size:12.5px;font-weight:600;padding:11px 18px;display:flex;gap:12px;align-items:center;min-width:min(250px,calc(100% - 28px));box-shadow:0 8px 28px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2)}
.hero-media .tag i{color:rgba(255,255,255,.55)}
.hero-media .tag .ct{margin-left:auto;color:rgba(255,255,255,.45);font-weight:550}
.ledger{display:grid;grid-template-columns:repeat(4,1fr);border-top:2px solid var(--ink);margin-top:clamp(40px,5vw,64px)}
.ledger>div{padding:22px 18px 6px 0;border-right:1px solid var(--line)}
.ledger>div:last-child{border-right:0}
.ledger b{font-family:var(--tight);font-weight:650;font-size:clamp(26px,2.8vw,40px);display:block;letter-spacing:-.025em}
.ledger span{font-size:12.5px;color:var(--mute);font-weight:500}
@media(max-width:760px){.ledger{grid-template-columns:1fr 1fr}.ledger>div:nth-child(2n){border-right:0}}
.intro .io{opacity:0;transform:translateY(22px);animation:rise .7s var(--ease) forwards}
.intro .io.i2{animation-delay:.1s}.intro .io.i3{animation-delay:.2s}.intro .io.i4{animation-delay:.3s}
@keyframes rise{to{opacity:1;transform:none}}

/* ---------- sectors ---------- */
.sectors{border-top:1px solid var(--line)}
.sector-row{display:grid;grid-template-columns:64px 1fr auto 28px;align-items:center;gap:clamp(12px,3vw,40px);padding:clamp(20px,2.6vw,30px) 0;border-bottom:1px solid var(--line)}
.sector-row .idx{font-size:12.5px;color:var(--mute);font-weight:550}
.sector-row h3{font-family:var(--tight);font-weight:600;font-size:clamp(24px,3.4vw,46px);letter-spacing:-.03em;line-height:1.02;transition:transform .35s var(--ease)}
.sector-row .for{font-size:13px;color:var(--mute);max-width:300px;text-align:right;font-weight:480}
.sector-row .go{color:var(--mute);transition:transform .3s var(--ease),color .3s}
.sector-row:hover h3{transform:translateX(10px)}
.sector-row:hover .go{transform:translateX(4px);color:var(--ink)}
.sector-stage{position:sticky;top:96px;height:min(70vh,560px);overflow:hidden;background:var(--paper-2)}
.sector-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.04);transition:opacity .5s var(--ease),transform 1.2s var(--ease)}
.sector-stage img.on{opacity:1;transform:scale(1)}
.sectors-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(28px,4vw,64px);align-items:start}
@media(max-width:960px){.sectors-grid{grid-template-columns:1fr}.sector-stage{display:none}.sector-row{grid-template-columns:44px 1fr 24px}.sector-row .for{display:none}}

/* ---------- features ---------- */
.feature{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(24px,4vw,72px);align-items:center;margin-top:clamp(56px,7vw,104px)}
.feature:nth-child(even){grid-template-columns:minmax(0,5fr) minmax(0,7fr)}
.feature:nth-child(even) .f-media{order:2}
.f-media{overflow:hidden;position:relative}
.f-media img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:grayscale(1);transform:scale(1.03);transition:transform .8s var(--ease),filter .45s var(--ease)}
.f-media.lit img{filter:grayscale(0)}
a.f-card:hover .f-media img{transform:scale(1)}
.f-meta h3{margin:0 0 14px}
.f-meta p{color:var(--ink-2);max-width:46ch;margin-bottom:22px}
.text-link{display:inline-flex;gap:10px;align-items:center;font-weight:600;font-size:14px;border-bottom:1.5px solid var(--ink);padding-bottom:4px;transition:gap .25s var(--ease),opacity .25s}
.text-link:hover{gap:14px;opacity:.7}
@media(max-width:860px){.feature,.feature:nth-child(even){grid-template-columns:1fr}.feature:nth-child(even) .f-media{order:0}}

/* ---------- dark band ---------- */
.band{background:var(--dark);color:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band blockquote{font-family:var(--tight);font-weight:550;font-size:clamp(26px,3.6vw,48px);line-height:1.1;letter-spacing:-.03em;max-width:24ch}
.band .attr{margin-top:26px;font-size:13px;color:rgba(255,255,255,.5)}
.logo-marquee{overflow:hidden;margin-top:54px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logo-track{display:flex;align-items:center;width:max-content;animation:logoscroll 26s linear infinite}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-track img{height:42px;width:auto;max-width:180px;object-fit:contain;flex:0 0 auto;margin-right:clamp(48px,7vw,96px);filter:brightness(0) invert(1);opacity:.85}
@keyframes logoscroll{to{transform:translateX(-50%)}}

/* ---------- process / journal / spec ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(36px,5vw,56px)}
.step{background:var(--paper);padding:clamp(22px,2.6vw,34px)}
.step .idx{font-size:12.5px;color:var(--mute);font-weight:600}
.step h4{font-family:var(--tight);font-weight:600;font-size:clamp(20px,2vw,27px);letter-spacing:-.02em;margin:14px 0 10px}
.step p{font-size:14px;color:var(--ink-2)}
@media(max-width:960px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.j-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(36px,5vw,56px)}
.j-card{border-top:2px solid var(--ink);padding-top:18px}
.j-card h4{font-family:var(--tight);font-weight:600;font-size:clamp(19px,1.8vw,24px);letter-spacing:-.02em;line-height:1.14;margin-bottom:12px;transition:opacity .25s}
.j-card:hover h4{opacity:.65}
@media(max-width:860px){.j-grid{grid-template-columns:1fr}}
.spec{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;border:2px solid var(--ink);padding:clamp(24px,3.4vw,44px)}
@media(max-width:760px){.spec{grid-template-columns:1fr}}

/* ---------- work ---------- */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:30px}
.chip{font-size:13.5px;font-weight:550;padding:11px 16px;border:1px solid var(--line);border-radius:0;cursor:pointer;background:transparent;color:var(--ink-2);transition:all .2s var(--ease)}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.chip .num{color:inherit;opacity:.5;margin-left:6px;font-size:12px}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,32px);margin-top:clamp(34px,4vw,52px)}
.w-card{position:relative}
.w-card .wm{overflow:hidden;background:var(--paper-2)}
.w-card img{width:100%;aspect-ratio:4/3.1;object-fit:cover;filter:grayscale(1);transform:scale(1.02);transition:filter .45s var(--ease),transform .6s var(--ease)}
.w-card.lit img,.w-card:hover img{filter:grayscale(0);transform:scale(1)}
.w-card .wt{display:flex;justify-content:space-between;gap:14px;align-items:baseline;padding:13px 2px 0}
.w-card h4{font-family:var(--tight);font-weight:600;font-size:17px;letter-spacing:-.015em;line-height:1.18}
.w-card .wc{font-size:12px;color:var(--mute);white-space:nowrap;font-weight:500}
.w-card .cs-tag{position:absolute;top:0;left:0;z-index:2;background:var(--dark);color:#fff;font-size:11.5px;font-weight:650;padding:8px 12px}
.w-card.dim{display:none}
@media(max-width:960px){.work-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.work-grid{grid-template-columns:1fr}}

/* ---------- project / case study ---------- */
.cs-hero{position:relative;height:min(86vh,760px);overflow:hidden;margin-top:0}
.cs-hero img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.92);transform:scale(1.04);transition:filter .8s var(--ease),transform 1s var(--ease)}
.cs-hero.lit img{filter:grayscale(0) brightness(.96);transform:scale(1)}
.cs-hero .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(16,16,16,.66),rgba(16,16,16,0) 55%)}
.cs-hero .cs-title{position:absolute;left:0;right:0;bottom:clamp(28px,5vw,64px);color:#fff}
.factbar{position:sticky;top:0;z-index:40;background:var(--glass);-webkit-backdrop-filter:blur(20px) saturate(1.6);backdrop-filter:blur(20px) saturate(1.6);border-bottom:1px solid var(--line)}
.factbar .in{display:flex;gap:clamp(18px,3.4vw,48px);overflow-x:auto;padding-top:16px;padding-bottom:16px;scrollbar-width:none}
.factbar .in::-webkit-scrollbar{display:none}
.fact{white-space:nowrap;font-size:13.5px}
.fact span{color:var(--mute);margin-right:8px;font-size:12px;font-weight:500}
.fact b{font-weight:650}
.prose{max-width:68ch;color:var(--ink-2);font-size:clamp(16px,1.35vw,18px)}
.prose p+p{margin-top:1em}
.cs-block{display:grid;grid-template-columns:minmax(0,4fr) minmax(0,8fr);gap:clamp(20px,4vw,72px);padding:clamp(48px,6vw,88px) 0;border-top:1px solid var(--line)}
.cs-block:first-of-type{border-top:0}
.cs-block .bl{position:sticky;top:100px;align-self:start}
.cs-block .bl h5{font-family:var(--tight);font-weight:600;font-size:18px;letter-spacing:-.01em}
@media(max-width:860px){.cs-block{grid-template-columns:1fr}.cs-block .bl{position:static}}
.cs-gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2vw,24px)}
.cs-gallery .full{grid-column:1/-1}
.cs-gallery figure{overflow:hidden;background:var(--paper-2)}
.cs-gallery img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);transform:scale(1.01);transition:filter .45s var(--ease),transform .6s var(--ease)}
.cs-gallery figure.lit img{filter:grayscale(0);transform:scale(1)}
.outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.16)}
.outcome{background:var(--dark);padding:clamp(22px,2.8vw,36px)}
.outcome h4{font-family:var(--tight);font-weight:600;font-size:clamp(19px,1.9vw,25px);letter-spacing:-.02em;margin-bottom:10px}
.outcome p{font-size:14px;color:rgba(255,255,255,.7)}
@media(max-width:860px){.outcomes{grid-template-columns:1fr}}
.next-proj{display:block;background:var(--paper-2);transition:background .3s}
.next-proj:hover{background:var(--line)}
.next-in{display:flex;justify-content:space-between;align-items:center;gap:24px;padding-top:clamp(40px,6vw,72px);padding-bottom:clamp(40px,6vw,72px)}

/* ---------- sector pages ---------- */
.cap-list{border-top:2px solid var(--ink)}
.cap{display:grid;grid-template-columns:56px 1fr 2fr;gap:clamp(14px,3vw,44px);padding:clamp(20px,2.4vw,28px) 0;border-bottom:1px solid var(--line)}
.cap .idx{font-size:12.5px;color:var(--mute);font-weight:600}
.cap h4{font-family:var(--tight);font-weight:600;font-size:clamp(19px,2vw,27px);letter-spacing:-.02em}
.cap p{font-size:15px;color:var(--ink-2);max-width:56ch}
@media(max-width:760px){.cap{grid-template-columns:40px 1fr}.cap p{grid-column:2}}
.rv{opacity:1;transform:none}

/* ---------- footer ---------- */
.site-foot{background:var(--dark);color:#fff;border-top:1px solid var(--line)}
.foot-cta{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,4fr);gap:clamp(32px,5vw,80px);align-items:end;padding-top:clamp(80px,10vw,150px);padding-bottom:clamp(56px,7vw,90px);border-bottom:1px solid rgba(255,255,255,.14)}
.foot-cta .display{color:#fff}
.direct{font-size:14px}
.direct a.big{display:block;font-family:var(--tight);font-weight:600;font-size:clamp(20px,1.8vw,26px);letter-spacing:-.02em;color:#fff;border-bottom:1.5px solid rgba(255,255,255,.35);padding-bottom:6px;margin-bottom:18px;transition:border-color .25s}
.direct a.big:hover{border-color:#fff}
.direct p{color:rgba(255,255,255,.6);line-height:1.7}
.direct a:not(.big){color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.25);transition:border-color .25s}
.direct a:not(.big):hover{border-color:#fff}
@media(max-width:860px){.foot-cta{grid-template-columns:1fr}}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1.15fr 1.05fr 1.05fr;gap:40px;padding-top:56px;padding-bottom:56px;font-size:14px}
.foot-grid h5{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:16px;font-weight:550}
.foot-grid a{display:block;color:rgba(255,255,255,.78);padding:4px 0;transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-grid .blurb{color:rgba(255,255,255,.6);font-size:13.5px;max-width:38ch;margin-top:14px;line-height:1.7}
.clock{margin-top:18px;font-size:13px;color:rgba(255,255,255,.5)}
.clock b{color:rgba(255,255,255,.85);font-weight:600}
.socials{display:flex;gap:14px;margin-top:18px}
.socials a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.8);transition:border-color .25s,color .25s,background .25s}
.socials a:hover{border-color:#fff;color:#141414;background:#fff}
.socials svg{width:15px;height:15px;fill:currentColor}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-base{display:flex;justify-content:space-between;gap:20px;padding-top:22px;padding-bottom:22px;border-top:1px solid rgba(255,255,255,.14);font-size:12.5px;color:rgba(255,255,255,.5);flex-wrap:wrap}
.foot-base a:hover{color:#fff}

/* ---------- palette ---------- */
.pal-veil{position:fixed;inset:0;z-index:90;background:rgba(10,10,10,.5);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .22s}
.pal-veil.open{opacity:1;pointer-events:auto}
.pal{position:fixed;z-index:91;left:50%;top:14vh;transform:translateX(-50%) translateY(8px) scale(.99);width:min(640px,92vw);background:var(--paper);border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease);overflow:hidden;border-radius:18px}
.pal.open{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0) scale(1)}
.pal input{width:100%;border:0;outline:0;background:transparent;font-family:var(--sans);font-size:17px;padding:18px 20px;border-bottom:1px solid var(--line);color:var(--ink)}
.pal-list{max-height:46vh;overflow-y:auto;padding:8px}
.pal-item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:11px 12px;cursor:pointer;font-size:14.5px;border-radius:10px}
.pal-item .k{color:var(--mute);font-size:12px;white-space:nowrap;font-weight:500}
.pal-item.sel,.pal-item:hover{background:var(--paper-2)}
.pal-group{font-size:11.5px;color:var(--mute);padding:12px 12px 6px;font-weight:650}
.pal-empty{padding:28px 16px;color:var(--mute);font-size:14px;text-align:center}
.pal-foot{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--line);font-size:11.5px;color:var(--mute)}
.pal-foot kbd{border:1px solid var(--line);border-radius:4px;padding:1px 5px;font-size:10.5px}

/* ---------- mobile ---------- */
@media(max-width:860px){
  .site-head{top:8px;padding:0 8px}
  .head-in{height:54px;padding:0 6px 0 12px;gap:8px}
  .nav{gap:8px}
  .brand img{height:21px}
  .nav .link,.search-pill kbd,.nav .btn.primary,.sp-t{display:none}
  .search-pill{width:40px;height:40px;justify-content:center;padding:0;gap:0}
  .theme-btn{width:40px;height:40px}
  .menu-btn{display:inline-flex;align-items:center;gap:8px;background:none;border:1px solid var(--line);border-radius:999px;padding:10px 16px;font-size:13.5px;font-weight:600;cursor:pointer;color:var(--ink)}
  .m-nav{position:fixed;inset:0;z-index:80;background:color-mix(in srgb,var(--paper) 72%,transparent);-webkit-backdrop-filter:blur(28px) saturate(1.6);backdrop-filter:blur(28px) saturate(1.6);display:flex;flex-direction:column;padding:96px var(--pad) 40px;gap:4px;opacity:0;pointer-events:none;transition:opacity .25s;overflow-y:auto}
  .m-nav.open{opacity:1;pointer-events:auto}
  .m-nav a.big{font-family:var(--tight);font-size:38px;font-weight:600;letter-spacing:-.03em;padding:14px 0;border-bottom:1px solid var(--line)}
  .m-nav .btn{margin-top:22px;justify-content:center}
  .m-nav .m-meta{margin-top:auto;padding-top:28px;font-size:13.5px;color:var(--mute);line-height:1.8}
  .m-nav .m-meta a{color:var(--ink);font-weight:550}
  .m-close{display:none!important;position:fixed;top:14px;right:var(--pad);z-index:81}
  body.menu-open .m-close{display:inline-flex!important;background:var(--paper)}
}
@media(min-width:861px){.m-nav,.m-close{display:none}}
@media(hover:none){
  .w-card img,.f-media img,.cs-gallery img,.cs-hero img{filter:none!important;transform:none!important}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.001s!important;animation-duration:.001s!important;scroll-behavior:auto!important}
  .logo-track{animation:none;flex-wrap:wrap;gap:30px}
  .caret{animation:none}
  .intro .io{opacity:1;transform:none;animation:none}
}

@media(max-width:680px){
  .logo-track img{height:32px;max-width:150px;margin-right:44px}
}
/* ---------- article / legacy content ---------- */
.article-hero{padding-top:clamp(150px,19vh,210px)}
.article-hero h1{max-width:18ch}
.prose-article{max-width:760px;margin:clamp(40px,6vw,72px) auto 0;font-size:clamp(16px,1.3vw,18px);color:var(--ink-2)}
.prose-article h2{font-family:var(--tight);font-weight:600;letter-spacing:-.02em;font-size:clamp(24px,2.6vw,34px);color:var(--ink);margin:1.6em 0 .5em}
.prose-article h3{font-family:var(--tight);font-weight:600;letter-spacing:-.015em;font-size:clamp(19px,1.9vw,24px);color:var(--ink);margin:1.4em 0 .4em}
.prose-article p{margin:.85em 0}
.prose-article ul,.prose-article ol{margin:.85em 0 .85em 1.2em}
.prose-article li{margin:.35em 0}
.prose-article img{margin:1.6em 0;width:100%;height:auto}
.prose-article a{border-bottom:1px solid var(--ink);transition:opacity .2s}
.prose-article a:hover{opacity:.65}
.prose-article strong{color:var(--ink)}
.idx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(36px,5vw,56px)}
@media(max-width:960px){.idx-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.idx-grid{grid-template-columns:1fr}}
.idx-card{border-top:2px solid var(--ink);padding-top:16px}
.idx-card h4{font-family:var(--tight);font-weight:600;font-size:clamp(18px,1.7vw,22px);letter-spacing:-.015em;line-height:1.16;transition:opacity .25s}
.idx-card:hover h4{opacity:.65}
.idx-card .meta{display:block;margin-top:8px}
/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,4fr);gap:clamp(28px,5vw,80px);align-items:start;margin-top:clamp(36px,5vw,60px)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .full{grid-column:1/-1}
@media(max-width:560px){.form{grid-template-columns:1fr}}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--mute);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:15.5px;color:var(--ink);
  background:var(--paper-2);border:1px solid var(--line);border-radius:0;
  padding:14px 14px;outline:none;transition:border-color .2s,background .2s;
  -webkit-appearance:none;appearance:none;
}
.field select{background-image:linear-gradient(45deg,transparent 50%,var(--mute) 50%),linear-gradient(135deg,var(--mute) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px;background-repeat:no-repeat}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink);background:var(--paper)}
.form .btn{justify-content:center}
.contact-rail{position:sticky;top:100px;border:1px solid var(--line);padding:clamp(22px,3vw,34px)}
.contact-rail h4{font-family:var(--tight);font-weight:600;font-size:20px;letter-spacing:-.015em;margin-bottom:14px}
.contact-rail a.row{display:block;padding:10px 0;border-bottom:1px solid var(--line);font-weight:550;transition:opacity .2s}
.contact-rail a.row:hover{opacity:.65}
.contact-rail p{font-size:14px;color:var(--ink-2);margin-top:14px;line-height:1.7}

/* ---------- SEO landing system ---------- */
.seo-hero{margin-top:clamp(36px,5vw,60px);overflow:hidden;background:var(--paper-2)}
.seo-hero img{width:100%;height:clamp(320px,52vh,560px);object-fit:cover;filter:grayscale(1);transform:scale(1.03);transition:filter .8s var(--ease),transform 1s var(--ease)}
.seo-hero.lit img{filter:none;transform:scale(1)}
.seo-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,24px)}
.seo-gallery figure{overflow:hidden;background:var(--paper-2)}
.seo-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:grayscale(1);transform:scale(1.02);transition:filter .45s var(--ease),transform .6s var(--ease)}
.seo-gallery figure.lit img{filter:none;transform:scale(1)}
@media(max-width:760px){.seo-gallery{grid-template-columns:1fr 1fr}}

/* ---------- FAQ accordions ---------- */
.faq-list{border-top:2px solid var(--ink)}
details.faq{border-bottom:1px solid var(--line)}
details.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px 0;font-family:var(--tight);font-weight:600;font-size:clamp(17px,1.7vw,21px);letter-spacing:-.015em;line-height:1.25}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-weight:400;font-size:26px;color:var(--mute);transition:transform .25s var(--ease);flex:0 0 auto;line-height:1}
details.faq[open] summary::after{transform:rotate(45deg)}
details.faq .faq-a{padding:0 0 24px;max-width:72ch;color:var(--ink-2);font-size:15.5px;line-height:1.65}

/* ---------- index thumbs ---------- */
.idx-thumb{overflow:hidden;background:var(--paper-2);margin-bottom:14px}
.idx-thumb img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:grayscale(1);transform:scale(1.02);transition:filter .45s var(--ease),transform .6s var(--ease)}
.idx-card:hover .idx-thumb img,.idx-thumb.lit img{filter:none;transform:scale(1)}

/* mobile footer (must follow base rules) */
@media(max-width:560px){.foot-cta .hero-actions .btn{width:100%;justify-content:center}.foot-grid{grid-template-columns:1fr;gap:34px}}

/* ---------- v4: logo, studio, lightbox, video ---------- */
.brand img{height:30px}
@media(max-width:860px){.brand img{height:18px}}
.studio-media{margin-top:clamp(36px,5vw,60px);overflow:hidden;background:var(--paper-2)}
.studio-media img{width:100%;height:clamp(320px,56vh,620px);object-fit:cover;filter:grayscale(1);transform:scale(1.02);transition:filter .8s var(--ease),transform 1s var(--ease)}
.studio-media.lit img{filter:none;transform:scale(1)}
.cs-gallery figure,.seo-gallery figure{cursor:zoom-in}

/* lightbox */
.lb{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;background:rgba(10,10,10,.78);-webkit-backdrop-filter:blur(22px) saturate(1.4);backdrop-filter:blur(22px) saturate(1.4)}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:84vh;object-fit:contain;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.lb-btn{position:fixed;z-index:121;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:rgba(20,20,20,.45);-webkit-backdrop-filter:blur(14px) saturate(1.5);backdrop-filter:blur(14px) saturate(1.5);color:#fff;cursor:pointer;transition:background .2s,border-color .2s}
.lb-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5)}
.lb-btn svg{width:18px;height:18px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}
.lb-close{top:18px;right:18px}
.lb-count{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:121;color:#fff;font-size:12.5px;font-weight:600;padding:9px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(20,20,20,.45);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}
@media(max-width:700px){.lb-prev{left:8px}.lb-next{right:8px}.lb-btn{width:42px;height:42px}}

/* glass vimeo player */
.hh-video{position:relative;overflow:hidden;background:#101010;aspect-ratio:16/9;isolation:isolate}
.hh-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;pointer-events:none}
.hh-video .vc{position:absolute;left:58px;right:12px;bottom:12px;z-index:3;display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:999px;opacity:1;transition:opacity .4s var(--ease);background:rgba(14,14,14,.45);-webkit-backdrop-filter:blur(18px) saturate(1.6);backdrop-filter:blur(18px) saturate(1.6);border:1px solid rgba(255,255,255,.22);box-shadow:0 8px 28px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2)}
.hh-video .vmute{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;flex:0 0 auto;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;cursor:pointer;flex:0 0 auto;transition:background .2s}
.hh-video .vmute:hover{background:rgba(255,255,255,.18)}
.hh-video .vmute svg{width:13px;height:13px}
.hh-video .vseek{-webkit-appearance:none;appearance:none;flex:1;height:2.5px;border-radius:99px;background:rgba(255,255,255,.28);outline:none;cursor:pointer}
.hh-video .vseek::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:11px;border-radius:50%;background:#fff;border:0;box-shadow:0 1px 6px rgba(0,0,0,.4)}
.hh-video .vseek::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:#fff;border:0}
.hh-video .vtime{color:rgba(255,255,255,.75);font-size:10.5px;font-weight:600;flex:0 0 auto;min-width:30px;text-align:right}

.film-wrap{margin-top:clamp(36px,5vw,60px)}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2vw,24px)}
@media(max-width:760px){.video-grid{grid-template-columns:1fr}}

.hh-video.controls-off .vc{opacity:0;pointer-events:none}

.film-strip{display:flex;gap:clamp(12px,1.6vw,20px);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:clamp(28px,4vw,44px)}
.film-strip::-webkit-scrollbar{display:none}
.film-strip .hh-video{flex:0 0 min(620px,86vw);scroll-snap-align:start}

/* proposal form */
.fgroup{grid-column:1/-1;margin-top:6px}
.fgroup>label{display:block;font-size:12.5px;font-weight:600;color:var(--mute);margin-bottom:10px}
.opt-grid{display:flex;flex-wrap:wrap;gap:9px}
.chip-opt{position:relative}
.chip-opt input{position:absolute;opacity:0;pointer-events:none}
.chip-opt span{display:inline-flex;align-items:center;padding:11px 16px;border:1px solid var(--line);font-size:13.5px;font-weight:550;cursor:pointer;color:var(--ink-2);background:transparent;transition:all .18s var(--ease);user-select:none}
.chip-opt span:hover{border-color:var(--ink);color:var(--ink)}
.chip-opt input:checked+span{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip-opt input:focus-visible+span{outline:2px solid var(--ink);outline-offset:2px}
.field input[type="file"]{padding:11px;border-style:dashed;cursor:pointer}
.field input[type="file"]::file-selector-button{font-family:var(--sans);font-size:12.5px;font-weight:600;border:1px solid var(--ink);background:transparent;color:var(--ink);padding:8px 12px;margin-right:12px;cursor:pointer}
.promise{display:inline-flex;gap:9px;align-items:center;border:1.5px solid var(--ink);padding:9px 15px;font-size:12.5px;font-weight:650;margin-top:18px}
.promise i{width:7px;height:7px;border-radius:99px;background:var(--ink);display:inline-block}
.live-sum{grid-column:1/-1;font-size:13px;color:var(--mute);font-weight:550;border-top:1px solid var(--line);padding-top:14px;min-height:20px}
.rail-steps{margin:18px 0 6px}
.rail-steps div{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink-2)}
.rail-steps b{font-feature-settings:"tnum" 1;color:var(--mute);font-weight:600}

/* glass whatsapp fab */
.wa-fab{position:fixed;right:16px;bottom:16px;z-index:64;display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:999px;background:rgba(16,16,16,.55);-webkit-backdrop-filter:blur(18px) saturate(1.6);backdrop-filter:blur(18px) saturate(1.6);border:1px solid rgba(255,255,255,.25);color:#fff;box-shadow:0 12px 34px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.2);transition:transform .25s var(--ease)}
.wa-fab:hover{transform:scale(1.06)}
.wa-fab svg{width:24px;height:24px}
.wa-fab .dot{position:absolute;top:3px;right:3px;width:11px;height:11px;border-radius:99px;background:#34d27b;border:2px solid rgba(16,16,16,.8)}
.wa-fab::after{content:"";position:absolute;inset:-5px;border-radius:999px;border:1.5px solid rgba(255,255,255,.28);animation:wapulse 2.6s var(--ease) infinite}
@keyframes wapulse{0%{transform:scale(.92);opacity:.9}70%{transform:scale(1.18);opacity:0}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.wa-fab::after{animation:none;display:none}}

/* proposal v2 */
.cs-hero .lede{font-weight:450}
.step-strip{display:grid;grid-template-columns:repeat(3,1fr);border:2px solid var(--ink)}
.step-strip>div{padding:clamp(18px,2.4vw,28px);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.step-strip>div:last-child{border-right:0}
.step-strip b{font-family:var(--tight);font-weight:650;font-size:clamp(22px,2.2vw,30px);letter-spacing:-.02em}
.step-strip span{font-size:14px;color:var(--ink-2);line-height:1.55}
@media(max-width:760px){.step-strip{grid-template-columns:1fr}.step-strip>div{border-right:0;border-bottom:1px solid var(--line)}.step-strip>div:last-child{border-bottom:0}}
.fsec{grid-column:1/-1;display:flex;gap:14px;align-items:baseline;border-top:2px solid var(--ink);padding-top:16px;margin-top:18px}
.fsec b{font-size:13px;color:var(--mute);font-weight:650}
.rail-24 b{display:block;font-size:clamp(64px,5vw,84px);font-weight:650;letter-spacing:-.04em;line-height:.95}
.rail-24 span{display:block;margin-top:8px;font-size:14px;color:var(--ink-2);line-height:1.5;font-weight:550}

@media(max-width:860px){.f-grid{grid-template-columns:1fr 1fr!important;row-gap:36px}.f-grid>div:first-child{grid-column:1/-1}}
.news-row{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:20px 0;border-bottom:1px solid var(--line);font-size:clamp(16px,1.6vw,20px);font-weight:600;color:var(--ink)}
.news-row:hover .arr{transform:translateX(5px)}
.news-row .arr{transition:transform .25s var(--ease)}

.stages{display:grid;grid-template-columns:200px 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.stage-nav{position:sticky;top:110px}
.stage-nav a{display:block;padding:12px 0;border-top:1px solid var(--line);color:var(--mute);font-weight:600;font-size:13.5px;transition:color .2s}
.stage-nav a.on{color:var(--ink)}
.spanel{padding:clamp(26px,3.4vw,42px) 0;border-top:1px solid var(--line)}
.spanel:first-child{border-top:0;padding-top:0}
.spanel h3{margin-bottom:14px;max-width:24ch}
.spanel .slab{display:none}
@media(max-width:860px){.stages{grid-template-columns:1fr}.stage-nav{display:none}.spanel .slab{display:block;font-size:12.5px;color:var(--mute);font-weight:650;margin-bottom:10px}}
.why-list p{border-top:1px solid var(--line);padding:clamp(16px,2vw,24px) 0;max-width:62ch;margin:0}

.next-proj{position:relative;display:block;overflow:hidden}
.next-proj img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.next-proj .veil{position:absolute;inset:0;background:linear-gradient(rgba(8,8,8,.5),rgba(8,8,8,.78))}
.next-proj .next-in{position:relative;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:clamp(54px,8vw,100px) 0}
.np-label{display:block;font-size:12px;font-weight:650;color:rgba(255,255,255,.65);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}
.hh-video iframe{z-index:1}
.hh-video .vc{z-index:5}
.hh-video .vmute{z-index:6}
/* authoritative mute button: wins cascade no matter what came before */
.hh-video .vmute{position:absolute!important;left:12px!important;bottom:12px!important;top:auto!important;z-index:7!important;display:inline-flex!important;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,.35);background:rgba(14,14,14,.55);-webkit-backdrop-filter:blur(14px) saturate(1.5);backdrop-filter:blur(14px) saturate(1.5);color:#fff;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.35);opacity:1!important;pointer-events:auto!important}
.hh-video .vmute svg{width:16px;height:16px}
.hh-video .vc{left:66px!important;z-index:6!important}
@media(max-width:860px){
.foot-grid{display:grid!important;grid-template-columns:1fr 1fr!important;column-gap:24px;row-gap:38px}
.foot-grid>div:first-child{grid-column:1/-1}
}
