/* =====================================================================
   YAKOOHA — Studio, precisely.  ·  style.css
   Cool gallery minimalism for a design & engineering studio.
   Porcelain + graphite + one electric cobalt, used surgically.
   Type: Bricolage Grotesque (display) · Geist (text) · Geist Mono (labels)
   ===================================================================== */

/* ---- fonts (self-hosted, variable) ---- */
@font-face{font-family:"Bricolage";src:url("../assets/fonts/Bricolage.woff2") format("woff2");font-weight:200 800;font-display:swap}
@font-face{font-family:"Geist";src:url("../assets/fonts/Geist.woff2") format("woff2");font-weight:100 900;font-display:swap}
@font-face{font-family:"Geist Mono";src:url("../assets/fonts/GeistMono.woff2") format("woff2");font-weight:100 900;font-display:swap}

:root{
  /* brighter, airier porcelain + near-white paper (lifted from the original) */
  --porcelain:#F6F5F1;
  --paper:#FFFFFF;
  --paper-2:#ECEBE4;
  --ink:#15161B;
  --ink-85:#23252B;
  --ink-2:#5C5E66;
  --ink-3:#9EA0A7;
  --line:rgba(20,21,25,.10);
  --line-2:rgba(20,21,25,.20);
  --line-rev:rgba(241,240,236,.16);
  --accent:#2D2AF0;
  --accent-2:#5B58FF;          /* brighter cobalt for glows / light accents */
  --accent-soft:rgba(45,42,240,.10);
  --accent-glow:rgba(91,88,255,.16);

  /* soft, light elevation — airier than heavy drop-shadows */
  --shadow-sm:0 2px 10px -6px rgba(20,21,25,.14);
  --shadow-md:0 18px 40px -26px rgba(20,21,25,.28);
  --shadow-lg:0 44px 80px -40px rgba(20,21,25,.34);

  --f-display:"Bricolage","Geist",sans-serif;
  --f-text:"Geist",system-ui,sans-serif;
  --f-mono:"Geist Mono",ui-monospace,monospace;

  --pad:clamp(1.25rem,4.5vw,4.5rem);
  --maxw:1400px;
  --nav-h:84px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-io:cubic-bezier(.65,0,.15,1);
  --dur:.8s;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:auto}
body{
  font-family:var(--f-text);
  background:var(--porcelain);
  color:var(--ink);
  line-height:1.5;
  font-weight:400;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* soft ambient light — a gentle brightness lift from the top, plus a faint cobalt bloom */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, #FFFFFF 0%, rgba(255,255,255,0) 55%),
    radial-gradient(90% 60% at 100% 0%, var(--accent-glow) 0%, rgba(91,88,255,0) 42%);
  opacity:.9;
}
body.is-loading{overflow:hidden;height:100vh}
::selection{background:var(--ink);color:var(--porcelain)}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

/* ---------------------------------------------------- layout primitives */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{position:relative;padding-block:clamp(5rem,10vw,9rem)}
.section-sm{padding-block:clamp(3.5rem,7vw,6rem)}
.divider{height:1px;background:var(--line);border:0}

.eyebrow{font-family:var(--f-mono);font-size:12px;font-weight:500;letter-spacing:.02em;
  text-transform:uppercase;color:var(--ink-2);display:inline-flex;align-items:center;gap:.7em}
.eyebrow .idx{color:var(--accent)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none}
.eyebrow.plain::before{display:none}

.display{font-family:var(--f-display);font-weight:700;line-height:.98;letter-spacing:-.03em}
.h1{font-family:var(--f-display);font-weight:700;line-height:.96;letter-spacing:-.035em;
  font-size:clamp(2.7rem,7.6vw,7rem)}
.h2{font-family:var(--f-display);font-weight:700;line-height:1;letter-spacing:-.03em;
  font-size:clamp(2.1rem,5vw,4.2rem)}
.h3{font-family:var(--f-display);font-weight:600;line-height:1.02;letter-spacing:-.02em;
  font-size:clamp(1.4rem,2.6vw,2rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.5;color:var(--ink-2);max-width:52ch;font-weight:400}
.muted{color:var(--ink-2)}
.accent{color:var(--accent)}

/* section header block */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;
  margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head .l{max-width:60ch}
.sec-head .eyebrow{margin-bottom:1.4rem}
.sec-head .num{font-family:var(--f-mono);font-size:12px;color:var(--ink-3);letter-spacing:.02em}

/* reveal helpers (JS adds .in) */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
.line-mask{display:block;overflow:hidden}
.line-mask>span{display:block}
.wm{display:inline-block;overflow:hidden;vertical-align:top}
.wm>span{display:inline-block}

/* ---------------------------------------------------- buttons / links */
.btn{position:relative;display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-mono);
  font-size:13px;font-weight:500;letter-spacing:.02em;text-transform:uppercase;
  padding:1.05em 1.5em;border-radius:100px;border:1px solid var(--ink);color:var(--ink);
  overflow:hidden;isolation:isolate;transition:color .45s var(--ease)}
.btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .45s var(--ease)}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--ink);transform:translateY(100%);transition:transform .5s var(--ease)}
.btn:hover{color:var(--porcelain)}
.btn:hover::after{transform:translateY(0)}
.btn:hover svg{transform:translate(3px,-3px)}
.btn--solid{background:var(--ink);color:var(--porcelain);border-color:var(--ink)}
.btn--solid::after{background:var(--accent)}
.btn--solid:hover{color:#fff}
.btn--accent{background:var(--accent);border-color:var(--accent);color:#fff}
.btn--accent::after{background:var(--ink)}
.btn--rev{border-color:var(--porcelain);color:var(--porcelain)}
.btn--rev::after{background:var(--porcelain)}
.btn--rev:hover{color:var(--ink)}

.link{position:relative;display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-mono);
  font-size:12.5px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink);padding-bottom:2px}
.link svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .4s var(--ease)}
.link::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:0 50%;transition:transform .45s var(--ease)}
.link:hover::after{transform:scaleX(1)}
.link:hover svg{transform:translate(3px,-3px)}

/* ---------------------------------------------------- overlays / cursor */
.grain{position:fixed;inset:-120%;z-index:9998;pointer-events:none;opacity:.022;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='150' height='150'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
.progress{position:fixed;top:0;left:0;height:2px;width:100%;z-index:9990;background:var(--accent);transform:scaleX(0);transform-origin:0 50%}
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;will-change:transform}
.cursor{width:38px;height:38px;margin:-19px 0 0 -19px;border:1px solid var(--ink-2);
  transition:width .4s var(--ease),height .4s var(--ease),margin .4s var(--ease),background-color .4s,border-color .4s,opacity .3s}
.cursor .cl{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--f-mono);font-size:9px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--porcelain);opacity:0;transition:opacity .25s}
.cursor-dot{width:5px;height:5px;margin:-2.5px 0 0 -2.5px;background:var(--ink)}
.cursor.is-lg{width:88px;height:88px;margin:-44px 0 0 -44px;background:var(--ink);border-color:var(--ink)}
.cursor.is-lg .cl{opacity:1}
.cursor.is-accent{background:var(--accent);border-color:var(--accent)}
.cursor.hide{opacity:0}
@media (hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none!important}}

/* ---------------------------------------------------- preloader (YKH · techy boot) */
#preloader{position:fixed;inset:0;z-index:10000;background:var(--porcelain);display:grid;place-items:center;overflow:hidden}
#preloader::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:46px 46px;opacity:.16;
  -webkit-mask:radial-gradient(58% 54% at 50% 46%,#000 0%,transparent 78%);
          mask:radial-gradient(58% 54% at 50% 46%,#000 0%,transparent 78%)}
#preloader::after{content:"";position:absolute;inset:0;
  background:radial-gradient(44% 40% at 50% 46%, var(--accent-glow) 0%, rgba(0,0,0,0) 72%)}
.pl-stage{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:1.4rem;width:min(66vw,360px)}
.pl-frame{position:relative;width:100%;padding:26px 30px}
.pl-frame .c{position:absolute;width:13px;height:13px;opacity:0}
.pl-frame .c1{top:0;left:0;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.pl-frame .c2{top:0;right:0;border-top:2px solid var(--accent);border-right:2px solid var(--accent)}
.pl-frame .c3{bottom:0;left:0;border-bottom:2px solid var(--accent);border-left:2px solid var(--accent)}
.pl-frame .c4{bottom:0;right:0;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.pl-ykh{display:block;width:100%;height:auto;overflow:visible;color:var(--ink)}
.pl-ykh .pl-strokes path{stroke-dasharray:1;stroke-dashoffset:1}
.pl-node{transform-box:fill-box;transform-origin:center}
.pl-ykh.glitch{filter:drop-shadow(2.5px 0 rgba(255,42,90,.9)) drop-shadow(-2.5px 0 rgba(0,214,255,.9))}
.pl-scan{position:absolute;top:0;left:22px;right:22px;height:2px;background:var(--accent);opacity:0;
  box-shadow:0 0 14px 1px var(--accent);border-radius:2px;pointer-events:none}
.pl-readout{width:100%;display:flex;align-items:baseline;justify-content:space-between;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.pl-status{color:var(--accent)}
.pl-pct{color:var(--ink-2);letter-spacing:.1em}
.pl-pct b{font-weight:500;color:var(--ink-3);margin-left:1px}
.pl-bar{width:100%;height:2px;background:var(--line-2);position:relative;overflow:hidden}
.pl-bar i{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.pl-curtain{position:fixed;inset:0;z-index:9999;background:var(--ink);transform:scaleY(0);transform-origin:50% 100%;pointer-events:none}
/* fallback so content is never trapped if JS/GSAP is unavailable */
.no-js #preloader,.no-gsap #preloader{display:none}

/* ---------------------------------------------------- nav */
.nav{position:fixed;top:0;left:0;width:100%;z-index:900;transition:transform .5s var(--ease),background-color .4s,border-color .4s,backdrop-filter .4s;border-bottom:1px solid transparent}
.nav.hide{transform:translateY(-102%)}
.nav.solid{background:rgba(241,240,236,.75);backdrop-filter:blur(16px) saturate(1.2);border-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1.1rem var(--pad)}
.brand{display:flex;align-items:center;gap:.6rem}
.brand .mk{height:19px;width:auto}
.brand .wd{height:16px;width:auto}
.nav-links{display:flex;gap:.15rem;align-items:center}
.nav-links a{font-family:var(--f-mono);font-size:12px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-2);
  padding:.55em .9em;position:relative;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:.9em;right:.9em;bottom:.4em;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:0 50%;transition:transform .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{transform:scaleX(1);background:var(--accent)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:1rem}
.status{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;
  text-transform:uppercase;color:var(--ink-2)}
.status .dot{width:7px;height:7px;border-radius:50%;background:#3E9D5D;box-shadow:0 0 0 0 rgba(62,157,93,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(62,157,93,.45)}70%{box-shadow:0 0 0 7px rgba(62,157,93,0)}100%{box-shadow:0 0 0 0 rgba(62,157,93,0)}}
.nav-cta{padding:.7em 1.1em}
.burger{display:none;width:30px;height:16px;position:relative}
.burger span{position:absolute;left:0;height:1.6px;width:100%;background:var(--ink);transition:transform .4s var(--ease),opacity .3s}
.burger span:nth-child(1){top:1px}.burger span:nth-child(2){top:7px}.burger span:nth-child(3){top:13px}
body.menu-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.sheet{position:fixed;inset:0;z-index:899;background:var(--ink);color:var(--porcelain);display:flex;flex-direction:column;
  justify-content:center;padding:var(--pad);gap:.1rem;clip-path:inset(0 0 100% 0);transition:clip-path .6s var(--ease-io)}
body.menu-open .sheet{clip-path:inset(0 0 0 0)}
.sheet a.sl{display:flex;align-items:baseline;justify-content:space-between;font-family:var(--f-display);font-weight:600;
  font-size:clamp(2rem,9vw,3.2rem);letter-spacing:-.03em;padding:.3em 0;border-bottom:1px solid var(--line-rev)}
.sheet a.sl .n{font-family:var(--f-mono);font-size:.9rem;color:var(--ink-3)}
.sheet .sfoot{margin-top:2rem;font-family:var(--f-mono);font-size:12px;letter-spacing:.03em;color:var(--ink-3);text-transform:uppercase}

/* ---------------------------------------------------- hero */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(2rem,5vh,4rem);position:relative;overflow:hidden}
.hero-top{position:absolute;top:clamp(6.5rem,14vh,9rem);left:var(--pad);right:var(--pad);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.hero-top .meta{font-family:var(--f-mono);font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-2);line-height:1.9}
.hero-top .meta .a{color:var(--ink)}
.hero h1{max-width:15ch}
.hero .display-xl{font-family:var(--f-display);font-weight:700;line-height:.92;letter-spacing:-.04em;
  font-size:clamp(3rem,10.5vw,10.5rem)}
.hero .display-xl .ac{color:var(--accent);text-shadow:0 0 46px var(--accent-glow)}
.hero-sub{display:flex;justify-content:space-between;align-items:flex-end;gap:2.5rem;flex-wrap:wrap;margin-top:clamp(2rem,4vw,3.4rem)}
.hero-lead{max-width:46ch}
.hero-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.scroll-cue{position:absolute;left:var(--pad);bottom:1.2rem;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:.6rem}
.scroll-cue .bar{width:1px;height:32px;background:var(--line-2);position:relative;overflow:hidden}
.scroll-cue .bar::after{content:"";position:absolute;inset:0;background:var(--ink);animation:cue 2s var(--ease-io) infinite}
@keyframes cue{0%{transform:translateY(-100%)}55%,100%{transform:translateY(100%)}}

/* ---------------------------------------------------- marquee */
.marquee{border-block:1px solid var(--line);padding-block:clamp(.9rem,1.6vw,1.3rem);overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;align-items:center;gap:2.6rem;will-change:transform}
.marquee-item{font-family:var(--f-display);font-weight:500;font-size:clamp(1.1rem,2vw,1.7rem);letter-spacing:-.02em;color:var(--ink);
  display:inline-flex;align-items:center;gap:2.6rem}
.marquee-item::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-3)}

/* ---------------------------------------------------- statement */
.statement{padding-block:clamp(6rem,13vw,12rem)}
.statement p{font-family:var(--f-display);font-weight:600;letter-spacing:-.025em;line-height:1.22;
  font-size:clamp(1.6rem,4vw,3.2rem);max-width:20ch}
.statement .word{opacity:.2;transition:opacity .1s linear}
.statement .ac{color:var(--accent)}
.statement .sign{margin-top:clamp(2.5rem,5vw,4rem);display:flex;align-items:center;gap:1rem;font-family:var(--f-mono);
  font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}
.statement .sign .l{width:52px;height:1px;background:var(--line-2)}

/* ---------------------------------------------------- work */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,3vw,2.6rem)}
.work-card{position:relative;display:block;border-radius:16px;overflow:hidden;background:var(--paper);
  border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .6s var(--ease)}
.work-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.work-cover{aspect-ratio:16/11;position:relative;overflow:hidden}
.work-cover svg{width:100%;height:100%;display:block;transition:transform .8s var(--ease)}
.work-card:hover .work-cover svg{transform:scale(1.04)}
.work-meta{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:clamp(1.2rem,2vw,1.6rem)}
.work-meta .nm{font-family:var(--f-display);font-weight:600;font-size:clamp(1.3rem,2.4vw,1.9rem);letter-spacing:-.02em;line-height:1.05}
.work-meta .sub{color:var(--ink-2);font-size:.95rem;margin-top:.3rem}
.work-meta .rt{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);text-align:right;line-height:1.8;flex:none}
.work-card .go{position:absolute;top:clamp(1.2rem,2vw,1.6rem);right:clamp(1.2rem,2vw,1.6rem);width:40px;height:40px;border-radius:50%;
  background:var(--porcelain);border:1px solid var(--line);display:grid;place-items:center;opacity:0;transform:scale(.8);transition:opacity .4s,transform .4s var(--ease)}
.work-card .go svg{width:16px;height:16px;fill:none;stroke:var(--ink);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.work-card:hover .go{opacity:1;transform:scale(1)}
.tag{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--line);border-radius:100px;padding:.3em .7em;display:inline-block}

/* ---------------------------------------------------- capabilities (index) */
.cap{border-top:1px solid var(--line)}
.cap-row{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1rem,3vw,2.5rem);align-items:start;
  padding:clamp(1.5rem,3vw,2.4rem) 0;border-bottom:1px solid var(--line);cursor:pointer;transition:padding-left .5s var(--ease)}
.cap-row .no{font-family:var(--f-mono);font-size:12px;color:var(--ink-3);padding-top:.45em}
.cap-row .body h3{font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,3.2vw,2.5rem);letter-spacing:-.025em;transition:color .4s}
.cap-row .body p{max-width:52ch;margin-top:.7rem;color:var(--ink-2);max-height:0;opacity:0;overflow:hidden;
  transition:max-height .55s var(--ease),opacity .4s,margin .4s}
.cap-row .plus{align-self:center;width:34px;height:34px;position:relative;flex:none}
.cap-row .plus::before,.cap-row .plus::after{content:"";position:absolute;background:var(--ink-2);transition:transform .45s var(--ease),background .4s}
.cap-row .plus::before{left:50%;top:8px;bottom:8px;width:1.4px;transform:translateX(-50%)}
.cap-row .plus::after{top:50%;left:8px;right:8px;height:1.4px;transform:translateY(-50%)}
.cap-row:hover{padding-left:1.2rem}
.cap-row:hover .body h3{color:var(--accent)}
.cap-row:hover .body p{max-height:8rem;opacity:1;margin-top:1rem}
.cap-row:hover .plus::before{transform:translateX(-50%) rotate(90deg);background:var(--accent)}
.cap-row:hover .plus::after{background:var(--accent)}

/* ---------------------------------------------------- process */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.step{background:var(--porcelain);padding:clamp(1.6rem,2.6vw,2.2rem);min-height:220px;display:flex;flex-direction:column;justify-content:space-between;transition:background .4s}
.step:hover{background:var(--paper)}
.step .sn{font-family:var(--f-mono);font-size:12px;color:var(--accent);letter-spacing:.03em}
.step h4{font-family:var(--f-display);font-weight:600;font-size:1.3rem;letter-spacing:-.02em;margin-top:1.2rem}
.step p{color:var(--ink-2);font-size:.95rem;margin-top:.5rem}

/* ---------------------------------------------------- dark band / studio preview */
.band{background:var(--ink);color:var(--porcelain)}
.band .eyebrow{color:var(--ink-3)} .band .muted{color:rgba(241,240,236,.66)}
.band .h2,.band .display{color:var(--porcelain)} .band .accent{color:#7d7bff}
.band .divider{background:var(--line-rev)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.stat .n{font-family:var(--f-display);font-weight:700;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1;letter-spacing:-.03em}
.stat .l{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:rgba(241,240,236,.55);margin-top:.6rem}

/* ---------------------------------------------------- quote */
.quote-lg{max-width:26ch}
.quote-lg p{font-family:var(--f-display);font-weight:600;font-size:clamp(1.6rem,3.6vw,2.9rem);letter-spacing:-.025em;line-height:1.16}
.quote-lg figcaption{display:flex;align-items:center;gap:.9rem;margin-top:2rem}
.quote-lg .av{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--porcelain);display:grid;place-items:center;font-family:var(--f-display);font-weight:600}
.quote-lg .qn{font-weight:500} .quote-lg .qr{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}

/* ---------------------------------------------------- team */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.member{background:var(--porcelain);padding:clamp(1.3rem,2.2vw,1.8rem);min-height:210px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:background .4s}
.member:hover{background:var(--paper)}
.member .av{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--porcelain);display:grid;place-items:center;font-family:var(--f-display);font-weight:600;font-size:.95rem}
.member .av.ac{background:var(--accent)}
.member h4{font-family:var(--f-display);font-weight:600;font-size:1.2rem;letter-spacing:-.02em;margin-top:1.2rem;line-height:1.05}
.member .role{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:.4rem}
.member .idx{position:absolute;top:1.1rem;right:1.1rem;font-family:var(--f-mono);font-size:11px;color:var(--ink-3)}

/* ---------------------------------------------------- values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.6rem)}
.value{border-top:1px solid var(--line);padding-top:1.4rem}
.value .vn{font-family:var(--f-mono);font-size:12px;color:var(--accent)}
.value h4{font-family:var(--f-display);font-weight:600;font-size:1.35rem;letter-spacing:-.02em;margin-top:1rem}
.value p{color:var(--ink-2);margin-top:.5rem;font-size:.98rem}

/* ---------------------------------------------------- cta */
.cta{background:var(--ink);color:var(--porcelain);text-align:center;position:relative;overflow:hidden;padding-block:clamp(6rem,13vw,11rem)}
.cta::before{content:"";position:absolute;left:50%;top:120%;width:min(90vw,900px);height:min(90vw,900px);transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(91,88,255,.28) 0%, rgba(91,88,255,0) 60%);pointer-events:none}
.cta .display-xl{font-family:var(--f-display);font-weight:700;line-height:.94;letter-spacing:-.04em;font-size:clamp(2.6rem,9vw,7.5rem);color:var(--porcelain)}
.cta .display-xl .ac{color:#7d7bff}
.cta p{max-width:46ch;margin:1.6rem auto 0;color:rgba(241,240,236,.66)}
.cta .cta-actions{margin-top:2.4rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.cta .mark-ghost{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(60vw,620px);opacity:.05;will-change:transform}

/* ---------------------------------------------------- footer */
.footer{background:var(--porcelain);padding-block:clamp(3rem,6vw,5rem) 2rem;position:relative;overflow:hidden}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:2rem;padding-bottom:2.6rem;border-bottom:1px solid var(--line)}
.footer-brand .wd{height:20px;margin-bottom:1rem}
.footer-brand p{max-width:32ch;color:var(--ink-2);font-size:.95rem}
.footer-col h5{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col a{color:var(--ink-2);font-size:.96rem;transition:color .3s}
.footer-col a:hover{color:var(--accent)}
.socials{display:flex;gap:.5rem;margin-top:1rem}
.socials a{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:background .3s,border-color .3s,color .3s}
.socials a svg{width:16px;height:16px}
.socials a:hover{background:var(--ink);border-color:var(--ink);color:var(--porcelain)}
.footer-huge{font-family:var(--f-display);font-weight:700;letter-spacing:-.04em;line-height:.85;
  font-size:clamp(4rem,20vw,18rem);color:var(--ink);margin-top:2.5rem;overflow:hidden}
.footer-huge [data-footword]{display:inline-block;transform:translateY(105%);transition:transform 1.1s var(--ease)}
.footer-huge.in [data-footword]{transform:none}
.footer-bot{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}
.footer-bot .to-top{cursor:pointer}

/* ---------------------------------------------------- page hero (secondary pages) */
.page-hero{padding-top:clamp(8rem,16vh,12rem);padding-bottom:clamp(3rem,6vw,5rem)}
.page-hero .h1{max-width:16ch}
.page-hero .lead{margin-top:1.6rem}

/* ---------------------------------------------------- contact / form */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.contact-info .row{padding:1.2rem 0;border-top:1px solid var(--line)}
.contact-info .row .k{font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
.contact-info .row .v{font-family:var(--f-display);font-weight:500;font-size:1.3rem;letter-spacing:-.02em;margin-top:.3rem}
.contact-info .row a.v:hover{color:var(--accent)}
.form{display:grid;gap:1.4rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-family:var(--f-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2)}
.field input,.field textarea,.field select{font-family:var(--f-text);font-size:1rem;color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:10px;padding:.9em 1em;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{min-height:130px;resize:vertical}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;flex-direction:row}
.hp{position:absolute;left:-9999px}
.form-note{font-size:.85rem;color:var(--ink-3)}
.form-status{font-family:var(--f-mono);font-size:12px;letter-spacing:.02em;padding:.9em 1.1em;border-radius:10px;display:none}
.form-status.ok{display:block;background:rgba(62,157,93,.12);color:#2f7d49}
.form-status.err{display:block;background:rgba(190,35,26,.1);color:#a12318}

/* ---------------------------------------------------- faq */
.faq{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 0;cursor:pointer;
  font-family:var(--f-display);font-weight:600;font-size:clamp(1.15rem,2vw,1.5rem);letter-spacing:-.02em}
.faq-q .plus{width:22px;height:22px;position:relative;flex:none}
.faq-q .plus::before,.faq-q .plus::after{content:"";position:absolute;background:var(--ink-2);transition:transform .4s var(--ease)}
.faq-q .plus::before{left:50%;top:2px;bottom:2px;width:1.5px;transform:translateX(-50%)}
.faq-q .plus::after{top:50%;left:2px;right:2px;height:1.5px;transform:translateY(-50%)}
.faq-item.open .plus::before{transform:translateX(-50%) rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a p{padding-bottom:1.5rem;color:var(--ink-2);max-width:70ch}

/* =====================================================================
   PROJECT DETAIL  ·  case-study pages (same gallery minimalism)
   ===================================================================== */
.project-hero{padding-top:clamp(7.5rem,15vh,11rem);padding-bottom:clamp(2rem,4vw,3.2rem)}
.project-hero .eyebrow{margin-bottom:1.4rem}
.project-hero .h1{max-width:18ch}
.project-lede{margin-top:1.6rem;max-width:60ch}
.p-cover{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);
  margin-top:clamp(2rem,4vw,3.4rem)}
.p-cover svg{width:100%;height:auto;display:block}
.p-cover .p-tagpin{position:absolute;left:clamp(1rem,2vw,1.6rem);bottom:clamp(1rem,2vw,1.6rem);
  display:flex;gap:.5rem;flex-wrap:wrap}
.p-cover .p-tagpin .tag{background:rgba(255,255,255,.86);backdrop-filter:blur(6px);border-color:transparent}

.p-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:clamp(2rem,4vw,3rem)}
.p-fact{background:var(--paper);padding:clamp(1.1rem,2vw,1.5rem)}
.p-fact .k{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}
.p-fact .v{font-family:var(--f-display);font-weight:500;font-size:1.05rem;letter-spacing:-.01em;margin-top:.5rem;line-height:1.25}

.p-body{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,7fr);gap:clamp(2rem,5vw,5rem);align-items:start}
.p-body .p-aside{position:sticky;top:calc(var(--nav-h,86px) + 1.5rem)}
.p-aside .eyebrow{margin-bottom:1rem}
.p-aside p{color:var(--ink-2);font-size:.98rem;max-width:34ch}
.p-sections{display:flex;flex-direction:column;gap:clamp(2.4rem,5vw,4rem)}
.p-section h3{font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:-.025em}
.p-section .p-num{font-family:var(--f-mono);font-size:12px;color:var(--accent);letter-spacing:.03em;display:block;margin-bottom:.7rem}
.p-section p{color:var(--ink-2);margin-top:1rem;font-size:clamp(1rem,1.3vw,1.12rem);max-width:66ch}
.p-section p + p{margin-top:1rem}
.p-list{list-style:none;margin-top:1.2rem;display:flex;flex-direction:column;gap:.7rem}
.p-list li{display:flex;gap:.8rem;align-items:baseline;color:var(--ink-2);font-size:1rem}
.p-list li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none;transform:translateY(-2px)}

.p-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2.4rem);
  margin-top:clamp(2.6rem,5vw,4rem);border-top:1px solid var(--line);padding-top:clamp(2rem,4vw,3rem)}
.p-metric .n{font-family:var(--f-display);font-weight:700;font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:-.03em;line-height:1}
.p-metric .n .u{color:var(--accent)}
.p-metric .l{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:.6rem}

.p-quote{margin-top:clamp(2.6rem,5vw,4rem)}
.p-quote blockquote{font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,3.2vw,2.4rem);letter-spacing:-.025em;line-height:1.2;max-width:24ch}
.p-quote blockquote .ac{color:var(--accent)}
.p-quote figcaption{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:1.4rem}

.p-gallery{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2vw,1.6rem);margin-top:clamp(2.6rem,5vw,4rem)}
.p-gallery figure{border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow-sm)}
.p-gallery svg{width:100%;height:auto;display:block}
.p-gallery .span2{grid-column:1 / -1}

.p-next{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(1.6rem,4vw,2.8rem) 0;margin-top:clamp(1rem,2vw,2rem);
  transition:padding-left .5s var(--ease)}
.p-next:hover{padding-left:1rem}
.p-next .lbl{font-family:var(--f-mono);font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}
.p-next .nm{font-family:var(--f-display);font-weight:600;font-size:clamp(1.8rem,4vw,3rem);letter-spacing:-.03em;transition:color .4s}
.p-next:hover .nm{color:var(--accent)}
.p-next .arrow{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:background .4s,border-color .4s,transform .5s var(--ease)}
.p-next .arrow svg{width:20px;height:20px;fill:none;stroke:var(--ink);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .4s}
.p-next:hover .arrow{background:var(--ink);border-color:var(--ink);transform:translateX(6px)}
.p-next:hover .arrow svg{stroke:var(--porcelain)}

/* =====================================================================
   TEAM MEMBER CARDS + MODAL  (portfolio & skills)
   ===================================================================== */
.member{cursor:pointer;-webkit-tap-highlight-color:transparent}
.member .peek{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:var(--ink);opacity:0;transform:scale(.6);transition:opacity .4s var(--ease),transform .4s var(--ease);z-index:2}
.member .peek svg{width:13px;height:13px;fill:none;stroke:var(--porcelain);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.member:hover,.member:focus-visible{background:var(--paper);box-shadow:var(--shadow-sm);outline:none}
.member:hover .peek,.member:focus-visible .peek{opacity:1;transform:none}
.member:hover .idx,.member:focus-visible .idx{opacity:0}
.member .idx{transition:opacity .3s}
.member:hover .av{transform:translateY(-2px)}
.member .av{transition:transform .4s var(--ease)}
.member .new-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:.5em;vertical-align:middle}
.member .tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.9rem;max-width:92%}
.member .tags .tag{font-size:9.5px;padding:.25em .55em}

/* modal */
.tm-modal{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:clamp(1rem,4vw,2.5rem);
  opacity:0;pointer-events:none;transition:opacity .45s var(--ease)}
.tm-modal.open{opacity:1;pointer-events:auto}
.tm-scrim{position:absolute;inset:0;background:rgba(16,17,22,.55);backdrop-filter:blur(6px)}
.tm-card{position:relative;width:min(720px,100%);max-height:min(86vh,780px);overflow:auto;
  background:var(--porcelain);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-lg);
  transform:translateY(24px) scale(.98);opacity:0;transition:transform .5s var(--ease),opacity .5s var(--ease);-webkit-overflow-scrolling:touch}
.tm-modal.open .tm-card{transform:none;opacity:1}
.tm-card .tm-close{position:absolute;top:1rem;right:1rem;z-index:2;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);background:var(--paper);display:grid;place-items:center;transition:background .3s,border-color .3s,transform .3s}
.tm-card .tm-close svg{width:16px;height:16px;fill:none;stroke:var(--ink);stroke-width:1.8;stroke-linecap:round}
.tm-card .tm-close:hover{background:var(--ink);border-color:var(--ink);transform:rotate(90deg)}
.tm-card .tm-close:hover svg{stroke:var(--porcelain)}
.tm-head{display:flex;align-items:center;gap:1.2rem;padding:clamp(1.6rem,3vw,2.4rem);border-bottom:1px solid var(--line)}
.tm-head .tm-av{width:74px;height:74px;flex:none;border-radius:50%;background:var(--ink);color:var(--porcelain);
  display:grid;place-items:center;font-family:var(--f-display);font-weight:600;font-size:1.6rem;letter-spacing:-.02em}
.tm-head .tm-av.ac{background:var(--accent)}
.tm-head h3{font-family:var(--f-display);font-weight:700;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.03em;line-height:1.02}
.tm-head .tm-role{font-family:var(--f-mono);font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--accent);margin-top:.4rem}
.tm-head .tm-since{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:.3rem}
.tm-body{padding:clamp(1.6rem,3vw,2.4rem);display:flex;flex-direction:column;gap:1.8rem}
.tm-bio{color:var(--ink-2);font-size:1.05rem;line-height:1.55;max-width:60ch}
.tm-block h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.9rem}
.tm-skills{display:flex;flex-wrap:wrap;gap:.5rem}
.tm-skills .tag{font-size:11px;padding:.4em .8em}
.tm-skills .tag.key{background:var(--ink);color:var(--porcelain);border-color:var(--ink)}
.tm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.tm-stat{border-top:1px solid var(--line);padding-top:.8rem}
.tm-stat .n{font-family:var(--f-display);font-weight:700;font-size:1.7rem;letter-spacing:-.02em;line-height:1}
.tm-stat .l{font-family:var(--f-mono);font-size:10px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:.4rem}
.tm-port{list-style:none;display:flex;flex-direction:column;gap:.2rem}
.tm-port li{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;padding:.85rem 0;border-top:1px solid var(--line)}
.tm-port li .pjwrap{display:flex;flex-direction:column;gap:.12rem;min-width:0}
.tm-port li .pj{font-family:var(--f-display);font-weight:600;font-size:1.1rem;letter-spacing:-.01em}
.tm-port li .rl{color:var(--ink-2);font-size:.9rem}
.tm-port li .yr{font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3)}
.tm-port li .dot{width:9px;height:9px;border-radius:50%;background:var(--accent)}
.tm-links{display:flex;flex-wrap:wrap;gap:.6rem}
.tm-links a{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-mono);font-size:11px;letter-spacing:.03em;
  text-transform:uppercase;color:var(--ink);border:1px solid var(--line);border-radius:100px;padding:.55em 1em;transition:background .3s,color .3s,border-color .3s}
.tm-links a svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.tm-links a:hover{background:var(--ink);color:var(--porcelain);border-color:var(--ink)}
body.tm-lock{overflow:hidden}

/* =====================================================================
   THE VOYAGE  ·  scroll-driven boat sailing bow-to-stern through the crew
   ===================================================================== */
.voyage{position:relative;background:linear-gradient(180deg, var(--porcelain) 0%, #EFF3F6 46%, var(--porcelain) 100%)}
.voyage-head{padding-top:clamp(4rem,8vw,7rem)}
.voyage-scroll{position:relative;height:calc(100vh + var(--voyage-extra,150vh))}
.voyage-viewport{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.voyage-scene{position:relative;width:min(1180px,92vw);margin-inline:auto;height:min(56vh,440px)}

/* horizontal sea baseline */
.voyage-rail{position:absolute;left:0;right:0;top:50%;height:2px;
  background-image:linear-gradient(90deg, var(--line-2) 0 8px, transparent 8px 18px);background-size:18px 2px;background-repeat:repeat-x;opacity:.8}
.voyage-rail-fill{position:absolute;left:0;top:50%;height:2px;width:0;transform:translateY(-.5px);
  background:linear-gradient(90deg, transparent, var(--accent));opacity:.7}
.voyage-wave{position:absolute;left:0;right:0;top:50%;width:100%;height:120px;transform:translateY(-60px);overflow:visible;pointer-events:none;color:var(--accent)}
.voyage-wave path{fill:none;stroke:currentColor;stroke-width:1.4;opacity:.22}

/* a port = one crew member */
.port{position:absolute;top:50%;left:calc(var(--x) * 100%);transform:translate(-50%,-50%);
  display:block;width:0;height:0;z-index:2;background:none;border:0;padding:0;font:inherit;color:inherit}
.port-node{position:absolute;left:50%;top:50%;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);
  background:var(--porcelain);border:2px solid var(--line-2);transition:all .45s var(--ease);z-index:2}
.port-card{position:absolute;left:50%;width:150px;transform:translateX(-50%);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;opacity:.42;cursor:pointer;
  transition:opacity .45s var(--ease),transform .45s var(--ease)}
.port[data-side="up"] .port-card{bottom:26px}
.port[data-side="down"] .port-card{top:26px}
.port[data-side="up"]::after,.port[data-side="down"]::after{content:"";position:absolute;left:50%;width:1px;height:16px;
  background:var(--line-2);transform:translateX(-50%);opacity:.6;transition:background .45s}
.port[data-side="up"]::after{bottom:8px}
.port[data-side="down"]::after{top:8px}
.port-av{width:44px;height:44px;border-radius:50%;background:var(--paper);border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--f-display);font-weight:600;font-size:1rem;color:var(--ink);
  box-shadow:var(--shadow-sm);transition:all .45s var(--ease)}
.port-name{font-family:var(--f-display);font-weight:600;font-size:.95rem;letter-spacing:-.01em;line-height:1.05}
.port-role{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
/* visited / active states (added by JS) */
.port.visited .port-node{background:var(--accent);border-color:var(--accent)}
.port.visited .port-card{opacity:.7}
.port.active .port-card{opacity:1;transform:translateX(-50%) translateY(0) scale(1.04)}
.port.active .port-av{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 30px -12px var(--accent)}
.port.active .port-node{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 6px var(--accent-soft)}
.port:hover .port-card{opacity:1}

/* the boat */
.voyage-boat{position:absolute;top:50%;left:0;width:78px;height:78px;margin:-39px 0 0 -39px;z-index:3;
  will-change:transform;pointer-events:none}
.voyage-boat svg{width:100%;height:100%;overflow:visible}
.voyage-boat .wake{opacity:.5}

.voyage-caption{margin:clamp(1.4rem,3vw,2.2rem) auto 0;text-align:center;min-height:2.2rem}
.voyage-caption .vc-idx{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.voyage-caption .vc-name{font-family:var(--f-display);font-weight:600;font-size:clamp(1.2rem,2.4vw,1.7rem);letter-spacing:-.02em;margin-top:.3rem}
.voyage-hint{position:absolute;left:50%;bottom:2.2rem;transform:translateX(-50%);font-family:var(--f-mono);font-size:10.5px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:.6rem}
.voyage-hint .bar{width:26px;height:1px;background:var(--line-2);position:relative;overflow:hidden}
.voyage-hint .bar::after{content:"";position:absolute;inset:0;background:var(--accent);animation:cue 2s var(--ease-io) infinite}

/* vertical fallback layout (mobile / short) */
.voyage-scene.is-vertical{width:100%;height:auto;min-height:auto}
.voyage-scene.is-vertical .voyage-wave{display:none}
.voyage-scene.is-vertical .voyage-rail{left:34px;right:auto;top:0;bottom:0;width:2px;height:auto;
  background-image:linear-gradient(180deg, var(--line-2) 0 8px, transparent 8px 18px);background-size:2px 18px;background-repeat:repeat-y}
.voyage-scene.is-vertical .voyage-rail-fill{left:34px;top:0;width:2px;height:0;background:linear-gradient(180deg, transparent, var(--accent))}
.voyage-scene.is-vertical .port{left:34px;top:calc(var(--x) * 100%);transform:translate(-50%,-50%)}
.voyage-scene.is-vertical .port[data-side="up"] .port-card,
.voyage-scene.is-vertical .port[data-side="down"] .port-card{position:absolute;left:0;top:50%;bottom:auto;
  transform:translateY(-50%);flex-direction:row;gap:.7rem;text-align:left;width:max-content;max-width:min(72vw,320px);
  white-space:normal;align-items:center;padding-left:2.4rem}
.voyage-scene.is-vertical .port[data-side="up"]::after,
.voyage-scene.is-vertical .port[data-side="down"]::after{display:none}
.voyage-scene.is-vertical .port.active .port-card{transform:translateY(-50%) scale(1.02)}
.voyage-scene.is-vertical .voyage-boat{top:0;left:34px;margin:-39px 0 0 -39px}

/* responsive helpers for voyage scene sizing handled in media block */

/* =====================================================================
   NEW-PROJECT / detail small helpers
   ===================================================================== */
.pill-new{display:inline-flex;align-items:center;gap:.45em;font-family:var(--f-mono);font-size:10px;letter-spacing:.05em;
  text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:100px;padding:.28em .7em;
  background:var(--accent-soft)}
.work-card .new-flag{position:absolute;top:clamp(1.2rem,2vw,1.6rem);left:clamp(1.2rem,2vw,1.6rem);z-index:2}

/* =====================================================================
   RESPONSIVE  ·  rebuilt for every device (ultra-wide → phone → landscape)
   ===================================================================== */

/* ---- ultra-wide: keep the composition centred, let it breathe ---- */
@media (min-width:1660px){
  :root{--maxw:1520px}
  .hero .display-xl{font-size:clamp(3rem,9.6vw,11rem)}
}
@media (min-width:2100px){
  :root{--maxw:1640px;--pad:clamp(4.5rem,6vw,7rem)}
}

/* ---- large desktop / small desktop ---- */
@media (max-width:1200px){
  .p-body{grid-template-columns:minmax(0,3.4fr) minmax(0,6.6fr);gap:clamp(1.6rem,3.5vw,3rem)}
}

/* ---- tablet-landscape / narrow desktop ---- */
@media (max-width:1080px){
  .footer-top{grid-template-columns:1fr 1fr;gap:2.4rem}
  .team-grid,.process{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:2rem}
  .p-facts{grid-template-columns:repeat(2,1fr)}
  .p-metrics{grid-template-columns:repeat(3,1fr)}
  .voyage-scene{width:94vw}
  .port-card{width:132px}
}

/* ---- tablet portrait: fold the nav, single-column the heavy grids ---- */
@media (max-width:900px){
  .nav-links,.status{display:none}
  .burger{display:block}
  .nav-cta{display:none}
  .work-grid{grid-template-columns:1fr;gap:1.5rem}
  .values{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .cap-row .body p{max-height:none;opacity:1;margin-top:1rem}
  .cap-row{cursor:default}
  .cap-row:hover{padding-left:0}
  /* project detail stacks; aside stops sticking */
  .p-body{grid-template-columns:1fr;gap:2rem}
  .p-body .p-aside{position:static;top:auto}
  .p-aside p{max-width:none}
  .p-next{grid-template-columns:1fr auto}
  .p-next .lbl{grid-column:1 / -1}
  .tm-stats{grid-template-columns:repeat(3,1fr)}
}

/* ---- large phone ---- */
@media (max-width:680px){
  .team-grid,.process{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .hero-sub{flex-direction:column;align-items:flex-start;gap:1.8rem}
  .hero-actions{width:100%}
  .field.row2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:1.6rem}
  .p-facts{grid-template-columns:1fr 1fr}
  .p-metrics{grid-template-columns:1fr;gap:1.4rem}
  .p-gallery{grid-template-columns:1fr}
  .p-gallery .span2{grid-column:auto}
  .tm-stats{grid-template-columns:1fr 1fr}
  .tm-head{flex-wrap:wrap}
  .sec-head{gap:1.4rem}
  .btn{padding:1em 1.3em}
  /* voyage becomes a vertical crew line */
  .voyage-scroll{height:auto}
  .voyage-viewport{position:static;height:auto;padding-block:clamp(2rem,7vw,3.5rem)}
  .voyage-hint{display:none}
}

/* ---- small phone ---- */
@media (max-width:460px){
  .stats{grid-template-columns:1fr}
  .tm-stats{grid-template-columns:1fr}
  .tm-port li{grid-template-columns:auto 1fr;row-gap:.2rem}
  .tm-port li .yr{grid-column:2;justify-self:start}
  .nav-inner{padding:.9rem var(--pad)}
  .footer-bot{gap:.6rem}
}

/* ---- SHORT desktop / laptop heights: stop the hero title colliding with the top meta ---- */
@media (min-width:901px) and (max-height:860px){
  .hero .display-xl{font-size:clamp(3rem,8.2vw,7.6rem)}
  .hero-top{top:clamp(5.5rem,10vh,7rem)}
  .hero h1{max-width:16ch}
}
@media (min-width:901px) and (max-height:720px){
  .hero .display-xl{font-size:clamp(2.8rem,7vw,6.2rem)}
  .hero-sub{margin-top:1.4rem}
  .hero-lead{max-width:40ch}
}

/* ---- landscape phones: give the hero room, drop 100svh lock ---- */
@media (max-width:900px) and (max-height:560px) and (orientation:landscape){
  .hero{min-height:auto;padding-top:7rem;padding-bottom:2.5rem}
  .hero-top{position:static;margin-bottom:1.4rem}
  .hero .display-xl{font-size:clamp(2.4rem,8vw,4rem)}
}

/* ---- coarse pointers: reveal card affordances that normally need hover ---- */
@media (hover:none),(pointer:coarse){
  .member .peek{opacity:1;transform:none}
  .work-card .go{opacity:1;transform:none}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.06s!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .line-mask>span,.wm>span,.pl-word span{transform:none!important}
  .statement .word{opacity:1!important}
  .cursor,.cursor-dot{display:none!important}
  .progress{display:none}
  #preloader{display:none!important}
  .pl-ykh .pl-strokes path{stroke-dashoffset:0!important}
  .port-card{opacity:1!important}
  .voyage-boat{display:none}
}
