/* ──────────────────────────────────────────────────────────────────
   FRITZ — liquid mercury system
   ────────────────────────────────────────────────────────────────── */
:root{
  /* palette — locked */
  --bg:#F5F5F7;
  --bg-deep:#EDEEF2;
  --txt:#1D1D1F;
  --txt-70:rgba(29,29,31,.70);
  --txt-55:rgba(29,29,31,.55);
  --txt-40:rgba(29,29,31,.40);
  --txt-24:rgba(29,29,31,.24);
  --hairline:rgba(29,29,31,.10);
  --hairline-2:rgba(29,29,31,.18);
  --chrome-1:#C7CCD6;
  --chrome-2:#8E96A3;
  --lilac:#D9D4E8;
  --blue:#0071E3;
  --glass:rgba(255,255,255,.55);
  --glass-edge:rgba(255,255,255,.75);

  /* type — neo-grotesk display/body + mono for technical micro-labels */
  --sans:"Switzer","Inter","Helvetica Neue",system-ui,sans-serif;
  --mono:"Geist Mono",ui-monospace,"SF Mono","Cascadia Mono",monospace;

  /* grid */
  --margin:clamp(20px,5vw,72px);
  --gutter:clamp(14px,1.8vw,28px);

  /* motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-inout:cubic-bezier(.65,0,.35,1);
  --dur-micro:160ms;
  --dur-short:320ms;
  --dur-std:480ms;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
html,body{
  background:var(--bg);color:var(--txt);
  font-family:var(--sans);font-weight:400;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
body{min-height:100vh;overflow-x:clip}

/* keep Geist Mono only on technical micro-labels (the "instrument" accent) */
.eyebrow,.hero-eyebrow,.hero-lockup,
.wordmark,.wordmark .tag,.index-link,
.readout,.hint,.chaprail,
.pre-word,.pre-count,
.menu .m-head,.menu .m-label,.menu .n,.menu .sub,.menu .m-foot,
.page-meta,
.mq-head,
.disc-row .n,.disc-row .meta,.disc-row .go,.disc-row .t .sub,
.pkg-n,.pkg .period,.pkg .deliv,.pkg .price,
.steps .step-n,
.case-head .c-n,.case-head .c-disc,.case-head .c-status,.case-acts .act h4,.case-specs,
.plate-body .tag,.plate-visual .pv-cap,.plate-visual .pv-status,
.btn,.xlink,
.field label,.submit-row .note,.form-status code,
.sf-h,.sf-base,.outro-meta,.outro-btn,
.works-foot{
  font-family:var(--mono);
}
::selection{background:var(--blue);color:#fff}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
img,canvas,video{display:block;max-width:100%}
:focus-visible{outline:1.5px solid var(--blue);outline-offset:3px;border-radius:2px}

/* ambient light fields — pure CSS radial gradients, layered per zone */
body{
  background-image:
    radial-gradient(110% 70% at 88% -8%, rgba(217,212,232,.55) 0%, transparent 60%),
    radial-gradient(120% 80% at -10% 18%, rgba(255,255,255,.9) 0%, transparent 55%),
    radial-gradient(90% 60% at 70% 38%, rgba(199,204,214,.35) 0%, transparent 62%);
  background-attachment:fixed;
}

/* thin graphite scrollbar */
html{scrollbar-width:thin;scrollbar-color:var(--chrome-2) transparent}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--chrome-2);border-radius:999px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--txt-40)}

/* press states (transform-safe for magnetic buttons via filter) */
.btn:active{filter:brightness(.93)}
.index-link:active,.xlink:active,.case-head:active,.sf-mark:active,.wordmark:active{transform:scale(.985)}

/* ──────────────────────────────────────────────────────────────────
   PRELOADER
   ────────────────────────────────────────────────────────────────── */
.pre{
  position:fixed;inset:0;z-index:100;background:var(--bg-deep);
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:var(--margin);
  background-image:radial-gradient(90% 70% at 50% 110%, rgba(199,204,214,.6), transparent 65%);
}
.pre .pre-word{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--txt-55)}
.pre .pre-count{font-size:clamp(64px,10vw,140px);font-weight:300;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}
.pre .pre-bar{position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--hairline)}
.pre .pre-bar i{display:block;height:100%;width:100%;background:var(--blue);transform-origin:left;transform:scaleX(0)}

/* scroll progress hairline */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:90;pointer-events:none}
.progress i{display:block;height:100%;background:var(--blue);transform-origin:left;transform:scaleX(0)}

/* ──────────────────────────────────────────────────────────────────
   CHROME — wordmark, index, readout, hint
   ────────────────────────────────────────────────────────────────── */
.glass{
  background:var(--glass);
  -webkit-backdrop-filter:blur(18px) saturate(1.5);
  backdrop-filter:blur(18px) saturate(1.5);
  border:1px solid var(--glass-edge);
  box-shadow:0 1px 1px rgba(29,29,31,.04),0 8px 28px rgba(29,29,31,.05);
}
.wordmark{
  position:fixed;left:var(--margin);top:22px;z-index:80;
  display:inline-flex;align-items:center;gap:12px;
  padding:11px 18px;border-radius:999px;
  font-size:12px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;
}
.wordmark sup{font-size:8px;letter-spacing:0;vertical-align:super;color:var(--txt-55)}
.wordmark .wm-mark{display:inline-flex;align-items:flex-start;gap:2px}
.wordmark .wm-logo{height:15px;width:auto;display:block}
.wordmark .wm-r{font-size:7px;font-weight:500;line-height:1;letter-spacing:0;color:var(--txt-55);margin-top:1px}
.wordmark .tag{font-size:9px;font-weight:400;letter-spacing:.26em;color:var(--txt-55);padding-left:12px;border-left:1px solid var(--hairline-2)}
@media (max-width:767px){.wordmark .wm-logo{height:13px}}

.index-link{
  position:fixed;right:var(--margin);top:22px;z-index:86;
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;border-radius:999px;
  font-size:10px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  transition:color var(--dur-short) var(--ease-out);
}
.index-link .plus{position:relative;width:10px;height:10px}
.index-link .plus::before,.index-link .plus::after{
  content:"";position:absolute;inset:0;margin:auto;background:currentColor;
  transition:transform var(--dur-std) var(--ease-inout);
}
.index-link .plus::before{width:10px;height:1.5px}
.index-link .plus::after{width:1.5px;height:10px}
body.menu-open .index-link .plus::before{transform:rotate(135deg)}
body.menu-open .index-link .plus::after{transform:rotate(135deg)}

/* live readout — bottom left */
.readout{
  position:fixed;left:var(--margin);bottom:20px;z-index:80;
  display:flex;align-items:center;gap:16px;
  padding:9px 16px;border-radius:999px;
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-55);
}
.readout b{font-weight:500;color:var(--txt);font-variant-numeric:tabular-nums}
.readout .pulse{width:5px;height:5px;border-radius:50%;background:var(--blue);animation:pulse 2.4s var(--ease-inout) infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}
.readout .d{width:1px;height:10px;background:var(--hairline-2)}

/* interaction hint — bottom right */
.hint{
  position:fixed;right:var(--margin);bottom:20px;z-index:80;
  font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40);
  display:flex;align-items:center;gap:10px;
}
.hint .vline{width:1px;height:22px;background:var(--hairline-2);overflow:hidden;position:relative}
.hint .vline::after{content:"";position:absolute;left:0;top:-100%;width:100%;height:100%;background:var(--blue);animation:drip 2.2s var(--ease-inout) infinite}
@keyframes drip{0%{top:-100%}60%,100%{top:100%}}

/* ──────────────────────────────────────────────────────────────────
   MENU — full glass overlay
   ────────────────────────────────────────────────────────────────── */
.menu{
  position:fixed;inset:0;z-index:84;visibility:hidden;
  background:rgba(245,245,247,.72);
  -webkit-backdrop-filter:blur(34px) saturate(1.6);
  backdrop-filter:blur(34px) saturate(1.6);
  display:flex;flex-direction:column;justify-content:center;
  padding:0 var(--margin);
  clip-path:inset(0 0 100% 0);
}
.menu .m-head{position:absolute;top:30px;left:var(--margin);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--txt-55)}
.menu .m-wrap{max-width:880px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:clamp(16px,3vh,32px)}
.menu .m-label{display:flex;align-items:baseline;gap:12px;padding-bottom:8px;border-bottom:1px solid var(--hairline-2);margin-bottom:1px;font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--txt-40)}
.menu .m-label b{color:var(--blue);font-weight:500;font-variant-numeric:tabular-nums}
.menu ul{list-style:none;width:100%}
.menu li{border-bottom:1px solid var(--hairline)}
.menu li[aria-current],.menu li a[aria-current]{color:var(--txt)}
.menu li a[aria-current] .arr{color:var(--blue)}
.menu li a{
  display:flex;align-items:baseline;gap:clamp(16px,3vw,40px);
  padding:clamp(9px,1.7vh,16px) 0;
  transition:padding-left var(--dur-std) var(--ease-out);
}
.menu li a:hover{padding-left:18px}
.menu .n{font-size:10px;letter-spacing:.2em;color:var(--txt-40);font-variant-numeric:tabular-nums}
.menu .lbl{font-size:clamp(19px,2.7vw,32px);font-weight:300;letter-spacing:-.02em;flex:1}
.menu .sub{display:block;font-size:9px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-40);margin-top:3px}
.menu .arr{font-size:18px;color:var(--txt-24);transition:color var(--dur-short) var(--ease-out),transform var(--dur-short) var(--ease-out)}
.menu li a:hover .arr{color:var(--blue);transform:translateX(6px)}
.menu .m-foot{position:absolute;bottom:30px;left:var(--margin);right:var(--margin);display:flex;justify-content:space-between;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40)}

/* ──────────────────────────────────────────────────────────────────
   HERO — fluid canvas + wordmark
   ────────────────────────────────────────────────────────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:clip}
.fluid-wrap{position:absolute;inset:0;z-index:0}
.fluid-wrap canvas{width:100%;height:100%}
.fluid-wrap .fluid-fallback{
  position:absolute;inset:0;opacity:0;
  background:
    radial-gradient(120% 100% at 28% -5%, #FFFFFF 0%, transparent 60%),
    radial-gradient(140% 110% at 82% 105%, #AEB6C4 0%, transparent 70%),
    radial-gradient(100% 90% at 12% 92%, #D9D4E8 0%, transparent 65%),
    radial-gradient(60% 50% at 62% 42%, rgba(0,113,227,.35) 0%, transparent 70%),
    #EDEEF2;
}
.fluid-wrap.fallback canvas{display:none}
.fluid-wrap.fallback .fluid-fallback{opacity:1}

.hero-inner{position:relative;z-index:2;text-align:center;padding:0 var(--margin);width:100%;pointer-events:none}
.hero-inner a{pointer-events:auto}

.hero-eyebrow{
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--txt-55);
  margin-bottom:clamp(18px,3vh,34px);
}
.hero-eyebrow .hr{width:44px;height:1px;background:var(--hairline-2)}

.hero-title{
  font-size:clamp(72px,16.5vw,288px);
  font-weight:300;letter-spacing:-.045em;line-height:.92;
  margin-left:-.03em;
}
.hero-title sup{font-size:.09em;font-weight:400;letter-spacing:0;vertical-align:.55em;color:var(--txt-55)}
.hero-title .hero-logo{width:clamp(190px,40vw,500px);height:auto;display:block;margin:0 auto;will-change:transform}
.hero-lockup{
  display:flex;align-items:center;justify-content:center;gap:18px;
  margin-top:clamp(10px,1.8vh,20px);
  font-size:clamp(9px,1vw,12px);letter-spacing:.62em;text-transform:uppercase;color:var(--txt-70);
}
.hero-lockup .hr{flex:0 0 clamp(30px,6vw,110px);height:1px;background:var(--hairline-2)}

.hero-sub{
  max-width:560px;margin:clamp(22px,4vh,44px) auto 0;
  font-size:clamp(13px,1.2vw,15px);line-height:1.8;color:var(--txt-70);
}
.hero-cta{display:flex;gap:14px;justify-content:center;margin-top:clamp(24px,4vh,40px)}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:15px 26px;border-radius:999px;
  font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;
  border:1px solid var(--txt);background:var(--txt);color:var(--bg);
  position:relative;overflow:hidden;
  transition:color var(--dur-short) var(--ease-out),border-color var(--dur-short) var(--ease-out);
}
.btn::before{
  content:"";position:absolute;inset:0;background:var(--blue);
  transform:translateY(101%);transition:transform var(--dur-std) var(--ease-inout);
}
.btn span{position:relative;z-index:1}
.btn:hover::before{transform:translateY(0)}
.btn:hover{color:#fff;border-color:var(--blue)}
.btn.ghost{background:transparent;color:var(--txt);border-color:var(--hairline-2)}
.btn.ghost:hover{color:#fff}
.btn .arr{position:relative;z-index:1;width:14px;height:1.5px;background:currentColor;transition:width var(--dur-short) var(--ease-out)}
.btn:hover .arr{width:22px}

/* ──────────────────────────────────────────────────────────────────
   MARQUEE — client ticker, base drift + scroll-velocity boost
   ────────────────────────────────────────────────────────────────── */
.marquee{
  position:relative;overflow:hidden;
  padding:clamp(12px,2.2vh,20px) 0;
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  background-image:radial-gradient(120% 150% at 50% 50%, rgba(255,255,255,.62), transparent 72%);
}
.mq-head{
  display:flex;align-items:center;gap:12px;
  padding:0 var(--margin);margin-bottom:clamp(8px,1.4vh,14px);
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--txt-55);
}
.mq-head .hr{width:44px;height:1px;background:var(--hairline-2)}
.mq-head .mq-count{margin-left:auto;color:var(--txt-40);letter-spacing:.24em}
.mq-viewport{
  position:relative;width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.mq-track{display:flex;width:max-content;will-change:transform;animation:mq-scroll 60s linear infinite}
.marquee[data-js="1"] .mq-track{animation:none}
.marquee:hover .mq-track{animation-play-state:paused}
@keyframes mq-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.mq-group{display:flex;align-items:center;flex:0 0 auto}
.mq-item{
  font-size:clamp(13px,1.5vw,20px);font-weight:400;letter-spacing:.01em;
  text-transform:uppercase;color:var(--txt-70);white-space:nowrap;
  padding:clamp(10px,1.5vh,18px) clamp(30px,3.8vw,68px);
  transition:color var(--dur-short) var(--ease-out);
}
.mq-item:hover{color:var(--blue)}
.mq-item.has-logo{display:inline-flex;align-items:center}
.mq-logo{height:1.15em;width:auto;max-height:100%;display:block;object-fit:contain;opacity:.66;transition:opacity .35s var(--ease-out)}
.mq-item:hover .mq-logo{opacity:.95}
.mq-sep{display:none}
@media (max-width:767px){
  .mq-item{font-size:13px;padding:0 22px}
  .mq-sep{width:4px;height:4px}
  .mq-head .mq-count{display:none}
}

/* ──────────────────────────────────────────────────────────────────
   SECTION FURNITURE
   ────────────────────────────────────────────────────────────────── */
section{position:relative}
.eyebrow{
  display:flex;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--txt-55);
}
.eyebrow .hr{width:44px;height:1px;background:var(--hairline-2)}
.eyebrow b{font-weight:500;color:var(--txt)}

/* ──────────────────────────────────────────────────────────────────
   MANIFESTO — pinned, lines sharpen out of blur
   ────────────────────────────────────────────────────────────────── */
.manifesto{
  min-height:clamp(460px,76svh,820px);display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:0 var(--margin);
  /* centred wash holds the type over the 3D mercury */
  background-image:radial-gradient(64% 64% at 50% 50%, rgba(245,245,247,.84), transparent 74%);
}
.mfilm{width:clamp(170px,24vh,300px);aspect-ratio:1/1;margin:clamp(4px,1vh,14px) auto clamp(14px,2.4vh,30px);position:relative;z-index:1;pointer-events:none;
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 55%, transparent 80%);
          mask-image:radial-gradient(circle at 50% 50%, #000 55%, transparent 80%)}
.mfilm-v{width:100%;height:100%;object-fit:cover;display:block}
.manifesto .eyebrow{position:absolute;top:clamp(88px,14vh,140px);left:var(--margin)}
/* let the 3D mercury read through the sections that host a scene */
.manifesto .m-lines{position:relative;z-index:1;text-shadow:0 1px 30px rgba(245,245,247,.9)}
.m-lines{position:relative;width:min(88%,820px);margin:0 auto;min-height:clamp(92px,15vh,150px)}
.mline{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  font-size:clamp(19px,2.6vw,38px);
  font-weight:300;letter-spacing:-.025em;line-height:1.14;
  will-change:filter,opacity,transform;
}
.mline em{font-style:normal;color:var(--blue)}

/* ──────────────────────────────────────────────────────────────────
   DISCIPLINES — oversized index rows + floating preview
   ────────────────────────────────────────────────────────────────── */
.disciplines{padding:clamp(90px,16vh,180px) var(--margin)}
.disc-head{display:flex;flex-direction:column;gap:22px;margin-bottom:clamp(40px,7vh,80px);max-width:900px}
.disc-head h2{font-size:clamp(30px,4.6vw,72px);font-weight:300;letter-spacing:-.035em;line-height:1.05}
.disc-head h2 em{font-style:normal;color:var(--txt-40)}

.disc-list{list-style:none;border-top:1px solid var(--hairline-2)}
.disc-row{
  position:relative;display:grid;
  grid-template-columns:minmax(48px,80px) 1fr minmax(180px,260px) auto;
  align-items:baseline;gap:var(--gutter);
  padding:clamp(26px,4.4vh,46px) 0;
  border-bottom:1px solid var(--hairline-2);
  cursor:pointer;
}
.disc-row .n{font-size:11px;letter-spacing:.2em;color:var(--txt-40);font-variant-numeric:tabular-nums}
.disc-row .t{font-size:clamp(24px,3.4vw,52px);font-weight:300;letter-spacing:-.03em;line-height:1.05;transition:transform var(--dur-std) var(--ease-out)}
.disc-row .t .sub{display:block;font-size:10px;font-weight:400;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40);margin-top:8px}
.disc-row .meta{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--txt-55);line-height:1.9}
.disc-row .go{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--txt-55);
  transition:color var(--dur-short) var(--ease-out);
}
.disc-row .go .lin{width:22px;height:1.5px;background:currentColor;transition:width var(--dur-short) var(--ease-out)}
.disc-row:hover .go{color:var(--blue)}
.disc-row:hover .go .lin{width:34px}
.disc-row:hover .t{transform:translateX(14px)}
.disc-row .fill{
  position:absolute;left:calc(-1 * var(--margin));right:calc(-1 * var(--margin));top:0;bottom:0;
  background:rgba(255,255,255,.55);opacity:0;transition:opacity var(--dur-std) var(--ease-out);z-index:-1;
}
.disc-row:hover .fill{opacity:1}

/* floating preview window — follows cursor over rows */
/* ──────────────────────────────────────────────────────────────────
   WORKS — chrome plates
   ────────────────────────────────────────────────────────────────── */
.works{
  padding:clamp(52px,8vh,96px) var(--margin);
  background-image:radial-gradient(90% 60% at 100% 0%, rgba(199,204,214,.4), transparent 65%);
}
.works-head{display:flex;flex-direction:column;gap:16px;margin-bottom:clamp(26px,4vh,48px);max-width:900px}
.works-head h2{font-size:clamp(30px,4.6vw,72px);font-weight:300;letter-spacing:-.035em;line-height:1.05}
.works-head h2 em{font-style:normal;color:var(--txt-40)}
.works-head p{font-size:13px;line-height:1.8;color:var(--txt-70);max-width:520px}

.plate-photo,.plate-film{text-decoration:none;color:inherit}
.plate-visual .pp-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease-out)}
.plate-photo:hover .pp-img{transform:scale(1.04)}
.pf-visual{background:#0c0c0e}
.pf-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;background:#0c0c0e;transition:transform .7s var(--ease-out)}
.works-grid .plate-visual{aspect-ratio:16/9}
.plate-film .pv-status{color:#fff;background:rgba(0,0,0,.4);border-color:rgba(255,255,255,.18)}
.plate-film:hover .pf-vid{transform:scale(1.03)}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);align-items:start}
.plate{display:flex;flex-direction:column;gap:14px}
.plate-visual{
  position:relative;aspect-ratio:4/3;border-radius:20px;overflow:hidden;
  border:1px solid var(--glass-edge);
}
.plate-visual .pg{position:absolute;inset:-12%;will-change:transform}
.plate-visual .pv-cap{
  position:absolute;left:16px;top:14px;z-index:2;display:flex;align-items:center;gap:10px;
  font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:rgba(29,29,31,.55);
}
.plate-visual .pv-status{
  position:absolute;right:14px;top:12px;z-index:2;
  padding:6px 12px;border-radius:999px;
  font-size:8px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--glass-edge);
}
.pg.pg-1{background:radial-gradient(120% 90% at 72% 112%, rgba(0,113,227,.55), transparent 60%),radial-gradient(110% 85% at 12% -4%, #fff, transparent 58%),#D6DAE1}
.pg.pg-2{background:radial-gradient(120% 100% at 28% 115%, rgba(217,212,232,1), transparent 68%),radial-gradient(100% 80% at 82% -6%, #fff, transparent 55%),#C5CAD4}
.pg.pg-3{background:radial-gradient(110% 90% at 75% 110%, rgba(0,194,184,.4), transparent 62%),radial-gradient(120% 95% at 22% 105%, rgba(0,113,227,.45), transparent 65%),#DDE0E6}
.plate-body{display:flex;flex-direction:column;gap:10px;padding:0 4px}
.plate-body .tag{font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--txt-40)}
.plate-body h3{font-size:clamp(17px,1.6vw,22px);font-weight:500;letter-spacing:-.01em}
.plate-body p{font-size:12px;line-height:1.75;color:var(--txt-70)}
.works-foot{display:flex;justify-content:center;margin-top:clamp(28px,4vh,52px)}

/* ──────────────────────────────────────────────────────────────────
   OUTRO — bloom + magnetic CTA + imprint
   ────────────────────────────────────────────────────────────────── */
.outro{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:clamp(52px,9vh,112px) var(--margin) 86px;overflow:clip;text-align:center;
}
.outro .bloom{
  position:absolute;left:50%;bottom:-30%;width:120vmin;height:120vmin;
  transform:translateX(-50%) scale(1);border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side, rgba(0,113,227,.28), rgba(217,212,232,.3) 45%, transparent 72%);
  will-change:transform,opacity;opacity:.5;
}
.outro .o-flare{
  position:absolute;left:50%;top:42%;width:74vmin;height:74vmin;
  transform:translate(-50%,-50%) scale(.5);border-radius:50%;pointer-events:none;opacity:0;z-index:0;
  background:radial-gradient(closest-side, rgba(0,113,227,.55), rgba(0,113,227,.14) 40%, transparent 70%);
  will-change:transform,opacity;mix-blend-mode:plus-lighter;
}
.outro .o-defs{position:absolute;width:0;height:0;pointer-events:none}
.outro .o-grain{
  position:absolute;inset:-60%;pointer-events:none;z-index:2;opacity:.45;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.86' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:220px 220px;mix-blend-mode:soft-light;will-change:transform;
  animation:o-grain 1s steps(5) infinite;
}
@keyframes o-grain{
  0%{transform:translate(0,0)}   20%{transform:translate(-6%,-4%)} 40%{transform:translate(4%,-7%)}
  60%{transform:translate(-5%,5%)} 80%{transform:translate(6%,3%)}  100%{transform:translate(0,0)}
}
@media (prefers-reduced-motion: reduce){ .outro .o-grain{animation:none;opacity:.3} }
.outro .eyebrow,.outro-cta{position:relative;z-index:1}
.outro .eyebrow{justify-content:center;margin-bottom:clamp(28px,5vh,52px)}
.outro-cta{
  position:relative;display:inline-block;
  font-size:clamp(40px,7.5vw,116px);font-weight:300;letter-spacing:-.045em;line-height:1.0;
  text-shadow:0 0 46px rgba(245,245,247,.92),0 0 14px rgba(245,245,247,.85),0 1px 2px rgba(245,245,247,.7);
  will-change:transform;
}
.outro-cta .ln{display:block}
.o-noise{font-style:normal;display:inline-block;will-change:filter,transform}
.outro-cta:hover{color:var(--blue)}
.outro-cta{transition:color var(--dur-std) var(--ease-out)}
.outro-btn{margin-top:clamp(30px,5vh,56px);position:relative;z-index:1;padding:18px 40px;font-size:11px;letter-spacing:.26em}
.outro-btn .arr{width:18px}
.outro-btn:hover .arr{width:30px}
.outro-meta{
  margin-top:clamp(26px,4.5vh,48px);display:flex;gap:18px;align-items:center;
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-55);
}
.outro-meta .d{width:1px;height:12px;background:var(--hairline-2)}

.imprint{
  width:100%;margin-top:clamp(70px,12vh,130px);
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--txt-40);
}

.imprint b{font-weight:500;color:var(--txt-55)}

/* ══════════════════════════════════════════════════════════════════
   INNER PAGES — shared components (mercury system)
   ══════════════════════════════════════════════════════════════════ */

/* page intro / hero band */
.page-hero{position:relative;padding:clamp(120px,21vh,230px) var(--margin) clamp(46px,8vh,86px)}
.page-hero .eyebrow{margin-bottom:clamp(22px,4vh,40px)}
.page-hero h1{font-size:clamp(40px,7.4vw,116px);font-weight:300;letter-spacing:-.045em;line-height:.96;max-width:15ch}
.page-hero h1 em{font-style:normal;color:var(--txt-40)}
.page-lede{margin-top:clamp(22px,3.2vh,36px);max-width:620px;font-size:clamp(14px,1.25vw,17px);line-height:1.78;color:var(--txt-70)}
.page-meta{margin-top:clamp(30px,5vh,54px);display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,66px)}
.page-meta > div{display:flex;flex-direction:column;gap:8px}
.page-meta span{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40)}
.page-meta b{font-size:13px;font-weight:500;letter-spacing:.01em;font-variant-numeric:tabular-nums}

/* generic content section */
.section{position:relative;padding:clamp(58px,10vh,120px) var(--margin)}
.section > .eyebrow{margin-bottom:clamp(20px,3vh,32px)}
.section h2{font-size:clamp(28px,4.6vw,68px);font-weight:300;letter-spacing:-.035em;line-height:1.05;max-width:18ch}
.section h2 em{font-style:normal;color:var(--blue)}
.section .body{margin-top:clamp(20px,3vh,30px);max-width:640px}
.section .body p{font-size:14px;line-height:1.8;color:var(--txt-70);margin-bottom:14px}
.section .body p em{font-style:normal;color:var(--txt)}

/* PRICING — glass cards */
.pricing{position:relative;padding:clamp(20px,4vh,44px) var(--margin) clamp(70px,12vh,140px)}
.pricing > .eyebrow{margin-bottom:clamp(28px,4.6vh,52px)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);align-items:start}
.pkg{
  position:relative;display:flex;flex-direction:column;gap:15px;min-height:100%;
  padding:clamp(24px,2vw,36px);border-radius:22px;
  border:1px solid var(--hairline);background:rgba(255,255,255,.48);
  -webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);
  transition:transform var(--dur-std) var(--ease-out),border-color var(--dur-std) var(--ease-out),background var(--dur-std) var(--ease-out);
}
.pkg:hover{transform:translateY(-6px);border-color:var(--hairline-2);background:rgba(255,255,255,.62)}
.pkg.feat{border-color:var(--blue);background:rgba(255,255,255,.66)}
.pkg-badge{
  position:absolute;top:-1px;right:22px;transform:translateY(-50%);
  padding:6px 13px;border-radius:999px;background:var(--blue);color:#fff;
  font-size:8px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
}
.pkg .pkg-n{display:flex;justify-content:space-between;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40)}
.pkg .pkg-n b{color:var(--txt);font-weight:500}
.pkg.feat .pkg-n b{color:var(--blue)}
.pkg h3{font-size:clamp(20px,2vw,28px);font-weight:400;letter-spacing:-.02em}
.pkg .pkg-tag{font-size:12.5px;line-height:1.7;color:var(--txt-70)}
.pkg .price{display:flex;align-items:baseline;gap:6px;margin-top:4px}
.pkg .price .cur{font-size:13px;color:var(--txt-55);letter-spacing:.06em}
.pkg .price .amt{font-size:clamp(38px,4.4vw,58px);font-weight:300;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.pkg .period{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--txt-40)}
.pkg .deliv{font-size:11px;color:var(--txt-55);padding:13px 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.pkg .deliv b{color:var(--txt);font-weight:500}
.pkg ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin:2px 0}
.pkg li{position:relative;padding-left:20px;font-size:12.5px;line-height:1.5;color:var(--txt-70)}
.pkg li::before{content:"";position:absolute;left:0;top:6px;width:6px;height:6px;background:var(--chrome-2);transform:rotate(45deg)}
.pkg.feat li::before{background:var(--blue)}
.pkg .btn{margin-top:auto;justify-content:center}
.pricing-foot{margin-top:clamp(26px,4vh,44px);text-align:center;font-size:12px;letter-spacing:.01em;line-height:1.7;color:var(--txt-55)}
.pricing-foot b{color:var(--txt);font-weight:500}

/* MARKETING — cinematic hero aura (drifting mercury) */
.hero-cine{overflow:hidden;padding-top:clamp(100px,15vh,170px);padding-bottom:clamp(40px,7vh,70px)}
.hero-cine > *:not(.hero-aura){position:relative;z-index:1}
.hero-aura{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-aura b{position:absolute;display:block;border-radius:50%;filter:blur(64px);opacity:.45;mix-blend-mode:multiply;will-change:transform}
.hero-aura .a1{width:46vw;height:46vw;left:-8vw;top:-8vw;background:radial-gradient(circle,#D9D4E8,transparent 70%);animation:auraA 19s ease-in-out infinite alternate}
.hero-aura .a2{width:40vw;height:40vw;right:-6vw;top:8vw;background:radial-gradient(circle,rgba(0,113,227,.45),transparent 70%);animation:auraB 23s ease-in-out infinite alternate}
.hero-aura .a3{width:38vw;height:38vw;left:32vw;bottom:-14vw;background:radial-gradient(circle,#C7CCD6,transparent 70%);animation:auraC 27s ease-in-out infinite alternate}
@keyframes auraA{to{transform:translate(7vw,5vw) scale(1.15)}}
@keyframes auraB{to{transform:translate(-6vw,4vw) scale(1.12)}}
@keyframes auraC{to{transform:translate(5vw,-6vw) scale(1.2)}}

/* MARKETING — kinetic keynote (big type, masked reveal) */
.keynote{text-align:center;padding-top:clamp(44px,7vh,90px);padding-bottom:clamp(44px,7vh,90px)}
.kn-stage{position:relative;height:clamp(166px,21vh,214px);max-width:880px;margin:0 auto}
.kn-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(6px,1vh,12px)}
.kn-mask{overflow:hidden;padding:0 2px}
.kn-num{display:block;font-family:var(--mono);font-size:12px;letter-spacing:.3em;color:var(--blue)}
.kn-word{font-size:clamp(26px,4.2vw,52px);font-weight:300;letter-spacing:-.04em;line-height:1.12;color:var(--txt)}
.kn-line{font-size:clamp(15px,1.6vw,20px);font-weight:300;line-height:1.4;color:var(--txt-55);max-width:32ch}
.kn-line em{font-style:normal;color:var(--blue)}
.kn-hook{font-size:clamp(28px,4.6vw,60px);font-weight:300;letter-spacing:-.035em;line-height:1.08;color:var(--txt);max-width:18ch}
.kn-hook em{font-style:normal;color:var(--blue)}
.kn-progress{display:flex;gap:10px;justify-content:center;margin-top:clamp(22px,4vh,40px)}
.kn-tick{width:30px;height:2px;border-radius:2px;background:var(--hairline-2)}

/* WORK — selected work, editorial rows */
.wk-list{max-width:1200px;margin:clamp(26px,5vh,56px) auto 0;padding:0 var(--margin)}
.wk-row{display:grid;grid-template-columns:1.22fr 1fr;gap:clamp(28px,4.6vw,76px);align-items:center;margin-bottom:clamp(54px,10vh,124px)}
.wk-row:nth-child(even) .wk-row-media{order:2}
@media(min-width:900px){ .wk-row.wk-lead{grid-template-columns:1.6fr .9fr} }
.wk-row-n{font-family:var(--mono);font-size:11px;letter-spacing:.3em;color:var(--txt-40)}
.wk-row-name{font-size:clamp(26px,3.4vw,46px);font-weight:300;letter-spacing:-.03em;line-height:1.04;margin-top:14px}
.wk-row-name em{font-style:normal;color:var(--txt-40)}
.wk-row-type{display:inline-block;margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue)}
.wk-row-desc{margin-top:16px;font-size:clamp(14px,1.05vw,16px);line-height:1.72;color:var(--txt-70);max-width:46ch}
.wk-row-specs{margin-top:22px;display:flex;flex-wrap:wrap;gap:13px 30px;padding-top:16px;border-top:1px solid var(--hairline)}
.wk-row-specs > div{display:flex;flex-direction:column;gap:5px}
.wk-row-specs span{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-40)}
.wk-row-specs b{font-size:12px;font-weight:500}
.wk-frame{position:relative;border-radius:16px;overflow:hidden;background:var(--chrome-1);border:1px solid var(--glass-edge);box-shadow:0 20px 56px rgba(29,29,31,.10);transition:transform .55s var(--ease-out),box-shadow .55s var(--ease-out)}
.wk-row-media:hover .wk-frame{transform:translateY(-7px);box-shadow:0 34px 82px rgba(29,29,31,.18)}
.wk-bar{height:32px;display:flex;align-items:center;gap:7px;padding:0 13px;background:rgba(255,255,255,.72);border-bottom:1px solid var(--hairline)}
.wk-bar i{width:8px;height:8px;border-radius:50%;background:var(--chrome-2);opacity:.55}
.wk-url{margin-left:10px;font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:var(--txt-40)}
.wk-canvas{position:relative;overflow:hidden}
.wk-visit-link{display:block;position:relative;color:inherit;text-decoration:none}
.wk-visit{position:absolute;z-index:3;right:12px;bottom:12px;font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:#fff;background:rgba(29,29,31,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:6px 11px;border-radius:999px;opacity:0;transform:translateY(6px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);pointer-events:none}
.wk-visit-link:hover .wk-visit{opacity:1;transform:translateY(0)}
.wk-canvas.r-1610{aspect-ratio:16/10}.wk-canvas.r-169{aspect-ratio:16/9}.wk-canvas.r-45{aspect-ratio:4/5}
.wk-media{position:absolute;inset:0;transition:transform .7s var(--ease-out)}
.wk-img,.wk-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .7s var(--ease-out)}
.wk-row-media:hover .wk-media,.wk-row-media:hover .wk-img,.wk-row-media:hover .wk-vid{transform:scale(1.04)}
.wk-canvas.is-playing .wk-play{display:none}
.m-brand{background:radial-gradient(120% 95% at 70% 112%, rgba(217,212,232,.95), transparent 60%),linear-gradient(180deg,#ECEAF3,#C7C5D5)}
.m-web{background:radial-gradient(120% 95% at 76% 112%, rgba(0,113,227,.4), transparent 60%),linear-gradient(180deg,#E4E9F1,#BAC2CE)}
.m-growth{background:radial-gradient(110% 95% at 72% 114%, rgba(0,194,184,.4), transparent 60%),linear-gradient(180deg,#E1E6E6,#BCC4C5)}
.m-video{background:radial-gradient(120% 110% at 50% 45%, rgba(40,40,46,.65), rgba(20,20,24,.92))}
.wk-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);z-index:2;transition:transform .4s var(--ease-out)}
.wk-play::after{content:"";position:absolute;top:50%;left:54%;transform:translate(-50%,-50%);border-style:solid;border-width:8px 0 8px 13px;border-color:transparent transparent transparent #fff}
.wk-row-media:hover .wk-play{transform:translate(-50%,-50%) scale(1.12)}
.wk-vtag{position:absolute;left:13px;bottom:12px;z-index:2;font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.82)}
@media(max-width:899px){ .wk-row{grid-template-columns:1fr;gap:24px} .wk-row:nth-child(even) .wk-row-media{order:0} }

/* WORK — cinematic Method (ghost-numeral readings) */
.mth{text-align:center;padding:clamp(48px,8vh,104px) var(--margin)}
.mth .eyebrow{justify-content:center}
.mth-stage{position:relative;height:clamp(300px,46vh,440px);max-width:820px;margin:clamp(24px,4.5vh,48px) auto 0;overflow:hidden}
.mth-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.mth-hook{font-size:clamp(28px,4.6vw,62px);font-weight:300;letter-spacing:-.035em;line-height:1.08;max-width:17ch;color:var(--txt)}
.mth-hook em{font-style:normal;color:var(--blue)}
.mth-ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:300;font-size:clamp(150px,32vh,340px);line-height:1;letter-spacing:-.05em;color:rgba(29,29,31,.06);font-variant-numeric:tabular-nums;z-index:0;pointer-events:none}
.mth-fg{position:relative;z-index:1}
.mth-word{font-size:clamp(32px,5.4vw,76px);font-weight:300;letter-spacing:-.04em;line-height:1;color:var(--txt)}
.mth-line{margin:16px auto 0;font-size:clamp(14px,1.4vw,18px);line-height:1.6;color:var(--txt-55);max-width:34ch}
.mth-progress{display:flex;gap:10px;justify-content:center;margin-top:clamp(20px,3.5vh,38px)}
.mth-progress span{width:30px;height:2px;border-radius:2px;background:var(--hairline-2)}
@media (prefers-reduced-motion:reduce){ .hero-aura b{animation:none} }

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter);margin-top:clamp(34px,5.5vh,64px)}
.step{display:flex;flex-direction:column;gap:14px;padding:clamp(26px,2.2vw,38px) clamp(22px,1.9vw,30px);border-radius:18px}
.step .step-n{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-40)}
.step .step-n b{display:block;font-size:clamp(30px,3.3vw,46px);font-weight:300;color:var(--txt);margin-top:8px;font-variant-numeric:tabular-nums}
.step h3{font-size:19px;font-weight:500;letter-spacing:-.01em}
.step p{font-size:13px;line-height:1.72;color:var(--txt-70)}

/* VALUES */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);margin-top:clamp(34px,5.5vh,64px)}
.value{padding:clamp(24px,2.2vw,36px);border-radius:20px;border:1px solid var(--hairline);background:rgba(255,255,255,.42)}
.value h4{font-size:clamp(20px,2.3vw,32px);font-weight:300;letter-spacing:-.025em;line-height:1.12}
.value h4 em{font-style:normal;color:var(--blue)}
.value p{margin-top:13px;font-size:12.5px;line-height:1.72;color:var(--txt-70)}
.value .ba{display:flex;align-items:baseline;flex-wrap:wrap;gap:9px;margin-top:16px;padding-top:14px;border-top:1px solid var(--hairline);font-size:11.5px;line-height:1.45}
.value .ba .b{color:var(--txt-40)}
.value .ba .arr{color:var(--chrome-2);font-weight:500}
.value .ba .a{color:var(--txt);font-weight:500}

/* ORIGIN — founder portrait beside the text */
.origin-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:clamp(32px,5vw,84px);align-items:center}
.origin-text .body{max-width:none}
.origin-visual{
  position:relative;border-radius:22px;overflow:hidden;
  aspect-ratio:4/5;height:min(56vh,470px);width:auto;justify-self:end;
  border:1px solid var(--glass-edge);background:var(--bg-deep);
  box-shadow:0 26px 64px rgba(29,29,31,.12);
}
.origin-visual img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block;filter:contrast(1.05);transition:transform .7s var(--ease-out)}
.origin-visual:hover img{transform:scale(1.045)}
.origin-visual::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, transparent 60%, rgba(29,29,31,.14))}
.origin-visual figcaption{
  position:absolute;left:14px;bottom:13px;z-index:1;display:inline-flex;align-items:center;gap:8px;
  padding:7px 13px;border-radius:999px;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt);
  background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-edge);
}
.origin-visual figcaption b{color:var(--blue);font-weight:500}
@media (max-width:1023px){
  .origin-grid{grid-template-columns:1fr;gap:clamp(28px,5vh,44px)}
  .origin-visual{height:auto;width:100%;max-width:360px;margin:0 auto;justify-self:auto}
}

/* CASES — accordion */
.cases-list{border-top:1px solid var(--hairline-2);margin-top:clamp(30px,5vh,52px)}
.case{border-bottom:1px solid var(--hairline-2)}
.case-head{
  width:100%;display:grid;grid-template-columns:64px 1fr 168px 124px 28px;
  align-items:center;gap:var(--gutter);padding:clamp(20px,3.2vh,34px) 0;text-align:left;
}
.case-head .c-n{font-size:11px;letter-spacing:.2em;color:var(--txt-40);font-variant-numeric:tabular-nums}
.case-head .c-name{font-size:clamp(20px,2.7vw,40px);font-weight:300;letter-spacing:-.025em;transition:transform var(--dur-std) var(--ease-out)}
.case-head .c-name em{font-style:normal;color:var(--txt-40)}
.case-head .c-disc{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-55)}
.case-head .c-status{justify-self:start;font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-55);padding:6px 11px;border:1px solid var(--hairline-2);border-radius:999px}
.case-head .c-tog{position:relative;width:14px;height:14px;justify-self:end}
.case-head .c-tog::before,.case-head .c-tog::after{content:"";position:absolute;inset:0;margin:auto;background:var(--txt-55);transition:transform var(--dur-std) var(--ease-inout),background var(--dur-short) var(--ease-out)}
.case-head .c-tog::before{width:14px;height:1.5px}
.case-head .c-tog::after{width:1.5px;height:14px}
.case.open .c-tog::after{transform:rotate(90deg)}
.case.open .c-tog::before,.case.open .c-tog::after{background:var(--blue)}
.case-head:hover .c-name{transform:translateX(10px)}
.case-head:hover .c-tog::before,.case-head:hover .c-tog::after{background:var(--blue)}
.case-detail{height:0;overflow:hidden;transition:height var(--dur-std) var(--ease-inout)}
.case-inner{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.3fr);gap:clamp(24px,3.5vw,56px);padding:8px 0 clamp(30px,5vh,52px)}
.case-plate{position:relative;aspect-ratio:5/4;border-radius:18px;overflow:hidden;border:1px solid var(--glass-edge)}
.case-plate .pg{position:absolute;inset:0}
.case-plate .cap{position:absolute;left:14px;top:12px;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:rgba(29,29,31,.55)}
.case-acts{display:flex;flex-direction:column;gap:18px}
.case-acts .lead{font-size:14px;line-height:1.7;color:var(--txt)}
.case-acts .act h4{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40);margin-bottom:6px}
.case-acts .act p{font-size:12.5px;line-height:1.7;color:var(--txt-70)}
.case-specs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding-top:18px;border-top:1px solid var(--hairline);margin-top:4px}
.case-specs > div{display:flex;flex-direction:column;gap:6px}
.case-specs span{font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:var(--txt-40)}
.case-specs b{font-size:12px;font-weight:500}

/* CONTACT */
.contact-wrap{display:grid;grid-template-columns:1.45fr .85fr;gap:clamp(30px,5vw,84px);align-items:start}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter)}
.field{display:flex;flex-direction:column;gap:9px;margin-bottom:18px}
.field label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-55)}
.field .req{color:var(--blue)}
.field input,.field select,.field textarea{
  font-family:var(--mono);font-size:14px;color:var(--txt);width:100%;
  background:rgba(255,255,255,.5);border:1px solid var(--hairline-2);border-radius:12px;
  padding:14px 16px;transition:border-color var(--dur-short) var(--ease-out),background var(--dur-short) var(--ease-out),box-shadow var(--dur-short) var(--ease-out);
}
.field textarea{resize:vertical;min-height:120px;line-height:1.6}
.field input::placeholder,.field textarea::placeholder{color:var(--txt-40)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:rgba(255,255,255,.88);box-shadow:0 0 0 3px rgba(0,113,227,.12),0 8px 26px rgba(0,113,227,.10)}
.field label{transition:color var(--dur-short) var(--ease-out)}
.field:focus-within label{color:var(--blue)}
.submit-row{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:6px}
.submit-row .note{font-size:11px;line-height:1.6;color:var(--txt-40);max-width:360px}
.submit-row .note b{color:var(--txt-55);font-weight:500}
.form-status{font-size:12.5px;line-height:1.6;padding:14px 16px;border-radius:12px;margin-bottom:18px}
.form-status.pending{background:rgba(199,204,214,.3);color:var(--txt-70)}
.form-status.ok{background:rgba(0,113,227,.08);color:var(--blue)}
.form-status.err{background:rgba(216,90,48,.08);color:#993c1d}
.form-status a{color:var(--blue);text-decoration:underline}
.form-status code{font-family:var(--mono);font-size:11px}
.contact-aside{display:flex;flex-direction:column;gap:clamp(22px,3vh,32px)}
.contact-aside .block h4{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-40);margin-bottom:10px}
.contact-aside .block p{font-size:13px;line-height:1.65;color:var(--txt-70)}
.contact-aside .block p.small{font-size:11px;color:var(--txt-55)}
.contact-aside .block .big{font-size:clamp(16px,1.6vw,21px);font-weight:400;letter-spacing:-.01em;color:var(--txt);transition:color var(--dur-short) var(--ease-out)}
.contact-aside .block .big:hover{color:var(--blue)}

/* CROSSLINKS — end-of-page CTA */
.crosslinks{
  position:relative;padding:clamp(70px,13vh,160px) var(--margin);
  display:flex;flex-direction:column;gap:clamp(28px,5vh,52px);
  border-top:1px solid var(--hairline);
  background-image:radial-gradient(80% 80% at 30% 120%, rgba(217,212,232,.5), transparent 70%),radial-gradient(60% 60% at 90% 0%, rgba(0,113,227,.08), transparent 70%);
}
.crosslinks h2{font-size:clamp(34px,6.4vw,104px);font-weight:300;letter-spacing:-.04em;line-height:1}
.crosslinks h2 em{font-style:normal;color:var(--blue)}
.xl-row{display:flex;flex-wrap:wrap;gap:12px}
.xlink{
  display:inline-flex;align-items:center;gap:11px;padding:13px 20px;border-radius:999px;
  border:1px solid var(--hairline-2);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-70);
  transition:color var(--dur-short) var(--ease-out),border-color var(--dur-short) var(--ease-out),background var(--dur-short) var(--ease-out);
}
.xlink .arr{width:14px;height:1.5px;background:currentColor;transition:width var(--dur-short) var(--ease-out)}
.xlink:hover{color:var(--blue);border-color:var(--blue);background:rgba(0,113,227,.05)}
.xlink:hover .arr{width:22px}

/* SITE FOOTER — ordered columns: brand · services · studio · contact */
.site-foot{position:relative;padding:clamp(54px,8vh,88px) var(--margin) clamp(40px,6vh,60px);border-top:1px solid var(--hairline-2);background-image:radial-gradient(70% 90% at 88% 0%, rgba(217,212,232,.35), transparent 70%)}
.sf-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:clamp(24px,4vw,60px)}
.sf-brand{display:flex;flex-direction:column;gap:15px}
.sf-mark{font-size:18px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;display:inline-block}
.sf-mark sup{font-size:9px;letter-spacing:0;vertical-align:super;color:var(--txt-55)}
.sf-mark .sf-logo{height:24px;width:auto;display:block}
.sf-tag{font-size:12px;line-height:1.7;color:var(--txt-55);max-width:270px}
.sf-social{display:flex;gap:11px;margin-top:6px}
.sf-social a{
  display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:999px;
  border:1px solid var(--hairline-2);color:var(--txt-55);
  transition:color var(--dur-short) var(--ease-out),border-color var(--dur-short) var(--ease-out),background var(--dur-short) var(--ease-out),transform var(--dur-short) var(--ease-out);
}
.sf-social a:hover{color:var(--blue);border-color:var(--blue);background:rgba(0,113,227,.06)}
.sf-social a:active{transform:scale(.94)}
.sf-social svg{width:17px;height:17px;display:block}
.sf-col{display:flex;flex-direction:column;gap:11px}
.sf-h{font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--txt-40);margin-bottom:5px}
.sf-col a{font-size:13px;color:var(--txt-70);width:fit-content;transition:color var(--dur-short) var(--ease-out)}
.sf-col a:hover{color:var(--blue)}
.sf-muted{font-size:11px;letter-spacing:.04em;color:var(--txt-40)}
.sf-base{display:flex;flex-wrap:wrap;gap:14px 26px;margin-top:clamp(40px,6vh,66px);padding-top:22px;border-top:1px solid var(--hairline);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--txt-40)}
.sf-base b{color:var(--txt-55);font-weight:500}
@media (max-width:1023px){
  .sf-grid{grid-template-columns:1fr 1fr}
  .sf-brand{grid-column:1 / -1}
}
@media (max-width:600px){ .sf-grid{grid-template-columns:1fr} }

@media (max-width:1023px){
  .pricing-grid{grid-template-columns:1fr;max-width:520px}
  .steps{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr}
  .case-head{grid-template-columns:48px 1fr 30px;row-gap:6px}
  .case-head .c-disc,.case-head .c-status{display:none}
  .case-inner{grid-template-columns:1fr}
  .contact-wrap{grid-template-columns:1fr}
}
@media (max-width:767px){
  .steps{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .case-specs{grid-template-columns:1fr 1fr}
  .page-meta{gap:20px 32px}
  /* phones: Method AND Contact are content-height — no tall svh voids,
     so the gap below the Method lines is just intentional padding */
  .manifesto{min-height:auto;padding:clamp(108px,19vh,156px) var(--margin) clamp(16px,3vh,30px)}
  .outro{min-height:auto;padding:clamp(40px,7vh,72px) var(--margin) clamp(48px,8vh,80px)}
}

/* ══════════════════════════════════════════════════════════════════
   PHASE 1 — motion furniture
   ══════════════════════════════════════════════════════════════════ */
/* traveling ambient light (JS-injected, scrubbed down the page) */
.ambient{position:fixed;inset:-30% 0;z-index:-1;pointer-events:none;will-change:transform;
  background:radial-gradient(46% 38% at 68% 28%, rgba(0,113,227,.09), transparent 62%)}

/* masked-line heading reveal safety */
.split-line{will-change:transform}

/* three.js mercury canvas — behind content, above ambient light */
.three-bg{position:fixed;inset:0;z-index:-1;pointer-events:none}

/* live sim coverage in the readout */
.readout .cov{display:flex;align-items:center;gap:9px}
.readout .cov-v{font-weight:500;color:var(--blue);font-variant-numeric:tabular-nums}
@media (max-width:767px){.readout .cov{display:none}}

/* ink page-transition sheet — a liquid panel that rises to cover */
.inkwipe{
  position:fixed;left:-6vw;right:-6vw;top:0;bottom:0;z-index:95;pointer-events:none;
  transform:translateY(105%);border-radius:50% 50% 0 0 / 14% 14% 0 0;
  will-change:transform,border-radius;
  background:
    radial-gradient(120% 90% at 28% 0%, #FFFFFF, transparent 56%),
    radial-gradient(140% 110% at 82% 100%, #AEB6C4, transparent 72%),
    radial-gradient(90% 80% at 50% 50%, #D9D4E8, transparent 70%),
    #E7E9EE;
}

/* plates: material depth — grain overlay, slow drift, cursor tilt */
.plate-visual,.case-plate{transform-style:preserve-3d;transition:transform .35s var(--ease-out)}
.plate-visual .pg,.case-plate .pg{animation:pg-shift 22s var(--ease-inout) infinite}
@keyframes pg-shift{0%{background-position:0% 0%}50%{background-position:7% 5%}100%{background-position:0% 0%}}
.plate-visual::after,.case-plate::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* steps progress rail (about · process) */
.steps{position:relative}
.steps-dots{grid-column:1 / -1;display:flex;justify-content:center;gap:15px;margin:0 0 clamp(20px,3.5vh,40px)}
.sdot{position:relative;width:10px;height:10px;border-radius:50%;background:var(--hairline-2);overflow:hidden;transition:transform .5s var(--ease-out)}
.sdot.on{transform:scale(1.2)}
.sdot i{position:absolute;inset:0;border-radius:50%;background:var(--blue);transform:scale(0);transform-origin:center}
.step .step-n b{transition:color var(--dur-std) var(--ease-out)}
.step.lit .step-n b,.step.active .step-n b{color:var(--blue)}
/* self-playing process timeline (gsap drives the motion; CSS holds the highlight) */
.steps .step{transition:box-shadow .6s var(--ease-out);will-change:transform,opacity;transform-origin:center bottom}
.step.active{box-shadow:0 14px 36px rgba(29,29,31,.06)}

/* chapter rail — wayfinding (JS-injected) */
.chaprail{
  position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:80;pointer-events:none;
  display:flex;align-items:center;gap:11px;padding:9px 17px;border-radius:999px;
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-55);
  opacity:0;transition:opacity var(--dur-std) var(--ease-out);
}
.chaprail.ready{opacity:1}
.chaprail .cr-n{color:var(--txt);font-weight:500;font-variant-numeric:tabular-nums}
.chaprail .cr-l{max-width:150px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.chaprail .cr-t{color:var(--txt-40);font-variant-numeric:tabular-nums}
@media (max-width:767px){.chaprail{display:none}}

/* ──────────────────────────────────────────────────────────────────
   RESPONSIVE
   ────────────────────────────────────────────────────────────────── */
@media (max-width:1023px){
  .works-grid{grid-template-columns:1fr 1fr}
  .disc-row{grid-template-columns:minmax(36px,52px) 1fr auto}
  .disc-row .meta{display:none}
}
@media (max-width:767px){
  .wordmark .tag{display:none}
  .hint{display:none}
  .readout{gap:10px;padding:8px 13px}
  .readout .peek{display:none}
  .hero-cta{flex-direction:column;align-items:center}
  .works-grid{grid-template-columns:1fr}
  .disc-row{grid-template-columns:36px 1fr;row-gap:10px}
  .disc-row .go{grid-column:2}
  .menu .lbl{font-size:24px}
  .imprint{justify-content:center;text-align:center}
}

/* ──────────────────────────────────────────────────────────────────
   REDUCED MOTION
   ────────────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .pre{display:none}
  .fluid-wrap{opacity:1 !important}
}
