@import url('fonts.css');

/* =========================================================
   FATHOM — main.css
   Dark cinematic descent. One accent, one easing.
   ========================================================= */

:root{
  --base-top:#05090c;
  --base-deep:#01060a;     /* scroll darkens toward this via --depth */
  --surface:#0b161c;
  --text:#e6edef;
  --text-dim:#aebcc1;
  --muted:#5c6f76;
  --hairline:rgba(230,237,239,.12);
  --hairline-soft:rgba(230,237,239,.06);
  --accent:#46f0c8;        /* bioluminescent aqua — the only color */
  --accent-2:#2fa9e0;      /* cold deep-water cyan, atmosphere only */
  --glow:rgba(70,240,200,.55);

  --display:'Clash Display',-apple-system,sans-serif;
  --sans:'Satoshi',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'Space Grotesk',ui-monospace,monospace;

  --ease:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);

  --pad:clamp(20px,4vw,72px);
  --depth:0;               /* 0 = surface, 1 = hadal. set by JS */
  --vh:1vh;

  /* seamless-figure system: the ONE color images melt into (bg-agnostic) */
  --page-bg:#01060a;
  --seam-soft:clamp(40px,6vw,64px);
  --seam-edge:clamp(64px,12vw,128px);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-stopped{overflow:clip}

body{
  font-family:var(--sans);
  background:var(--base-deep);
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  cursor:auto;
}
@media (pointer:fine){ body{cursor:none} }

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#02100c}

/* ---------- Background depth layers (fixed) ---------- */
.stage{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-depth{
  position:absolute;inset:0;
  /* top is lit, bottom is void; --depth slides the whole field darker */
  background:
    radial-gradient(120% 80% at 50% -25%,
      rgba(70,240,200,calc(.06 * (1 - var(--depth)))) 0%,
      rgba(47,169,224,calc(.035 * (1 - var(--depth)))) 16%,
      transparent 48%),
    linear-gradient(180deg,
      color-mix(in srgb, var(--base-top), var(--base-deep) calc(var(--depth)*100%)) 0%,
      var(--base-deep) 100%);
  transition:background .15s linear;
}
#gl{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
/* controlled spectral shift: a cold indigo wash that rises from the deep as you descend */
.depth-tint{position:absolute;inset:0;opacity:var(--depth);transition:opacity .2s linear;
  background:radial-gradient(135% 100% at 50% 120%,rgba(72,40,150,.30),rgba(44,32,108,.12) 48%,transparent 72%)}
.vignette{
  position:absolute;inset:0;
  background:radial-gradient(130% 120% at 50% 38%,transparent 40%,rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}
.grain{
  position:absolute;inset:-50%;width:200%;height:200%;
  background-image:var(--grain-url);
  opacity:.06;mix-blend-mode:overlay;pointer-events:none;
  will-change:transform;
}

/* ---------- Custom cursor ---------- */
.cursor{position:fixed;top:0;left:0;z-index:120;pointer-events:none;will-change:transform;opacity:0;transition:opacity .35s var(--ease)}
body.cursor-on .cursor{opacity:1}
.cursor__ring{
  position:absolute;width:54px;height:54px;margin:-27px 0 0 -27px;border-radius:50%;
  border:1px solid var(--accent);opacity:0;transform:scale(.5);
  transition:opacity .35s var(--ease),transform .45s var(--ease);
}
.cursor__dot{position:absolute;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;background:var(--accent);box-shadow:0 0 7px var(--glow)}
body.cur-hover .cursor__ring{opacity:1;transform:scale(1)}
body.cur-hover .cursor__dot{opacity:0}
.cursor__label{position:absolute;transform:translate(-50%,-50%);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#fff;opacity:0;transition:opacity .3s;white-space:nowrap}
body.cur-label .cursor__label{opacity:1}
@media (pointer:coarse){ .cursor{display:none} }

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:200;background:var(--base-deep);display:grid;place-items:center;overflow:hidden}
.preloader__inner{width:min(86vw,560px);text-align:left}
.preloader__top{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--hairline);padding-bottom:14px}
.preloader__count{font-family:var(--display);font-weight:500;font-size:clamp(4rem,18vw,11rem);line-height:.9;letter-spacing:-.03em;color:var(--text);margin-top:6vh;display:flex;align-items:flex-end;gap:.1em}
.preloader__count small{font-family:var(--mono);font-size:.13em;letter-spacing:.1em;color:var(--muted);margin-bottom:1.1em}
.preloader__bar{height:1px;background:var(--hairline);margin-top:5vh;position:relative;overflow:hidden}
.preloader__bar i{position:absolute;inset:0 100% 0 0;background:var(--accent);box-shadow:0 0 12px var(--glow)}
.preloader__meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:18px}
.curtain{position:fixed;inset:0;z-index:190;background:var(--base-deep);transform:translateY(0)}

/* ---------- Layout primitives ---------- */
.wrap{position:relative;z-index:2}
main{position:relative;z-index:2}
section{position:relative;padding:clamp(90px,16vh,200px) var(--pad)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,28px)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block;box-shadow:0 0 8px var(--glow)}
.accent{color:var(--accent)}
.serifless{font-family:var(--display)}

/* reveal — only active when html.js; default visible (no-JS safe) */
.line-mask{overflow:hidden;display:block}
.js .reveal .line-mask>*{transform:translateY(115%);opacity:.001}
.js .reveal.is-in .line-mask>*{transform:translateY(0);opacity:1;transition:transform 1.05s var(--ease),opacity 1.05s var(--ease)}
.js .fade{opacity:.001;transform:translateY(26px)}
.js .fade.is-in{opacity:1;transform:none;transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.js .reveal .line-mask>*,.js .reveal.is-in .line-mask>*{transition-delay:var(--d,0s)}
.js .fade.is-in{transition-delay:var(--d,0s)}

/* ---------- Header ---------- */
.site-head{position:fixed;top:0;left:0;width:100%;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:22px var(--pad);mix-blend-mode:difference;pointer-events:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.site-head.tuck{opacity:0;transform:translateY(-120%)}
.site-head a,.site-head button{pointer-events:auto}
.brand{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:.02em}
.brand b{color:var(--accent);font-weight:600}
.head-meta{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;display:flex;gap:26px}
.head-meta span{opacity:.7}
@media (max-width:720px){ .head-meta span.hide-sm{display:none} }

/* ---------- Depth HUD (fixed gauge) ---------- */
.hud{position:fixed;z-index:90;right:var(--pad);bottom:26px;text-align:right;font-family:var(--mono);mix-blend-mode:difference;pointer-events:none;opacity:0;transform:translateY(10px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.hud.show{opacity:1;transform:none}
.hud__depth{font-size:clamp(13px,1.1vw,15px);letter-spacing:.04em;color:#fff;display:flex;align-items:baseline;gap:6px;justify-content:flex-end}
.hud__depth b{font-family:var(--display);font-weight:500;font-size:clamp(26px,3vw,40px);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.hud__zone{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.hud__rail{position:fixed;left:22px;top:0;height:100%;width:1px;background:var(--hairline-soft);z-index:90;pointer-events:none}
.hud__rail i{position:absolute;left:-1px;top:0;width:3px;height:0;background:var(--accent);box-shadow:0 0 10px var(--glow)}
.hud__ticks{display:none}
@media (max-width:720px){ .hud{right:16px} .hud__rail{left:14px} }

/* ---------- HERO ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:18vh;padding-bottom:12vh}
.hero__kicker{margin-bottom:clamp(24px,5vh,60px)}
.hero__title{font-family:var(--display);font-weight:600;font-size:clamp(4.2rem,21vw,20rem);line-height:.86;letter-spacing:-.04em;text-wrap:balance}
.hero__title .ch{display:inline-block;will-change:transform}
.hero__sub{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px;margin-top:clamp(28px,5vh,56px);border-top:1px solid var(--hairline);padding-top:26px}
.hero__q{font-family:var(--display);font-weight:400;font-size:clamp(1.3rem,2.6vw,2.3rem);line-height:1.12;max-width:18ch;letter-spacing:-.01em}
.hero__meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-align:right;line-height:2}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue i{width:1px;height:46px;background:linear-gradient(var(--accent),transparent);display:block;animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Section heading system ---------- */
.zone-head{display:flex;align-items:flex-start;gap:clamp(16px,3vw,48px);flex-wrap:wrap}
.zone-num{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--accent);padding-top:.6em;font-variant-numeric:tabular-nums}
.zone-depth{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
/* pressure typography: tracking tightens as the descent deepens (--depth) */
.zone-title{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,9vw,8.5rem);line-height:.92;letter-spacing:calc(-.03em - var(--depth)*.012em);text-wrap:balance}
.lede{font-family:var(--display);font-weight:300;font-size:clamp(1.35rem,3vw,2.5rem);line-height:calc(1.22 - var(--depth)*.06);letter-spacing:calc(-.008em - var(--depth)*.006em);max-width:20ch;color:var(--text)}
.body-copy{font-size:clamp(1rem,1.25vw,1.15rem);line-height:1.65;color:var(--text-dim);max-width:42ch;text-wrap:pretty}
.lede{text-wrap:balance}
.body-copy.muted{color:var(--muted)}

/* sunlight zone */
.sunlight .grid{align-items:end}
/* STEP 0 (the real seam-killer): paint the figure surface to the PAGE bg,
   not a lighter --surface (#0b161c, ~4x brighter than the page = the rectangle). */
.fig{position:relative;overflow:hidden;background:var(--page-bg)}
.fig img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.02);transform:scale(1.06);transition:transform 1.4s var(--ease)}
.fig.is-in img{transform:scale(1)}

/* ---- seamless modifiers (apply alongside .fig) — dissolve edges into --page-bg ----
   pick by what the EDGES measure, not by image "type". bg-agnostic, no-JS, mobile-safe. */
.seam--soft{                                   /* gentle 4-edge feather (faint multi-edge scenes / cards) */
  -webkit-mask-image:
    linear-gradient(to right ,transparent,#000 var(--seam-soft),#000 calc(100% - var(--seam-soft)),transparent),
    linear-gradient(to bottom,transparent,#000 var(--seam-soft),#000 calc(100% - var(--seam-soft)),transparent);
  -webkit-mask-composite:source-in;            /* WebKit keyword = intersect */
          mask-composite:intersect;
          mask-image:
    linear-gradient(to right ,transparent,#000 var(--seam-soft),#000 calc(100% - var(--seam-soft)),transparent),
    linear-gradient(to bottom,transparent,#000 var(--seam-soft),#000 calc(100% - var(--seam-soft)),transparent);
}
.seam--top   { -webkit-mask-image:linear-gradient(to bottom,transparent,#000 var(--seam-edge)); mask-image:linear-gradient(to bottom,transparent,#000 var(--seam-edge)); }
.seam--bottom{ -webkit-mask-image:linear-gradient(to top   ,transparent,#000 var(--seam-edge)); mask-image:linear-gradient(to top   ,transparent,#000 var(--seam-edge)); }
.seam--vbleed{                                 /* full-bleed bg image: feather top & bottom into the scroll only */
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 var(--seam-edge),#000 calc(100% - var(--seam-edge)),transparent);
          mask-image:linear-gradient(to bottom,transparent,#000 var(--seam-edge),#000 calc(100% - var(--seam-edge)),transparent);
}
/* glow-on-black: black field composites away onto the page (kept only where a live
   render confirms it reaches the backdrop; otherwise STEP 0 + feather carries it). */
.seam--glow{ background:transparent; isolation:isolate; }
.seam--glow img{ mix-blend-mode:screen; }
@media (max-width:760px){ :root{ --seam-soft:clamp(20px,5vw,32px); --seam-edge:clamp(40px,12vw,72px); } }
@supports not ((mask-composite:intersect) or (-webkit-mask-composite:source-in)){
  .seam--soft{ -webkit-mask-image:none; mask-image:none; }
}
.fig__cap{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:14px;display:flex;justify-content:space-between;gap:16px}
.fig__cap b{color:var(--text-dim);font-weight:500}
.ar-169{aspect-ratio:16/9}.ar-45{aspect-ratio:4/5}.ar-11{aspect-ratio:1/1}.ar-32{aspect-ratio:3/2}.ar-219{aspect-ratio:21/9}

/* ---------- Twilight horizontal gallery ---------- */
.h-pin{position:relative;height:100svh;overflow:hidden;padding:0}
/* edge fades — partial cards dissolve into the deep instead of hard-cropping */
.h-pin::before,.h-pin::after{content:"";position:absolute;top:0;bottom:0;z-index:5;pointer-events:none;width:clamp(36px,8vw,130px)}
.h-pin::before{left:0;background:linear-gradient(90deg,var(--base-deep) 12%,transparent)}
.h-pin::after{right:0;background:linear-gradient(270deg,var(--base-deep) 12%,transparent)}
.h-track{position:absolute;top:0;left:0;height:100%;display:flex;align-items:center;gap:clamp(28px,5vw,90px);padding-inline:var(--pad);will-change:transform}
.h-intro{flex:0 0 auto;width:min(78vw,520px);align-self:center}
.card{flex:0 0 auto;width:min(70vw,430px);position:relative}
.card .fig{aspect-ratio:4/5}
.card__spec{margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);display:grid;grid-template-columns:1fr auto;gap:6px 18px;line-height:1.5}
.card__name{grid-column:1/-1;font-family:var(--display);font-weight:500;font-size:clamp(1.3rem,2vw,1.8rem);color:var(--text);letter-spacing:-.01em;margin-bottom:6px;display:flex;justify-content:space-between;align-items:baseline}
.card__name em{font-family:var(--mono);font-style:normal;font-size:11px;letter-spacing:.1em;color:var(--accent)}
.card__spec .k{color:var(--muted)}.card__spec .v{color:var(--text-dim);text-align:right}
.h-veil{position:absolute;inset:0;z-index:7;background:var(--base-deep);opacity:0;pointer-events:none}
.h-foot{position:absolute;left:0;right:0;bottom:0;height:140px;z-index:4;pointer-events:none;background:linear-gradient(0deg,var(--base-deep) 34%,rgba(2,6,10,.55) 70%,transparent)}
.h-progress{position:absolute;left:var(--pad);right:var(--pad);bottom:40px;height:1px;background:var(--hairline);z-index:6}
.h-progress i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--accent);box-shadow:0 0 8px var(--glow)}
.h-label{position:absolute;left:var(--pad);bottom:52px;z-index:6;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.h-rangelabel{position:absolute;right:var(--pad);bottom:52px;z-index:6;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}

/* ---------- Midnight full-bleed reveal ---------- */
.midnight{padding:0}
.midnight__media{position:relative;height:140svh}
.midnight__media .fig{position:sticky;top:0;height:100svh;aspect-ratio:auto}
.midnight__media img{transform:scale(1.12)}
.midnight__type{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;padding:var(--pad);pointer-events:none}
.midnight__type .zone-depth{position:absolute;top:84px;left:var(--pad)}
.midnight__big{font-family:var(--display);font-weight:600;font-size:clamp(3rem,16vw,15rem);line-height:.82;letter-spacing:-.04em;text-wrap:balance;mix-blend-mode:difference;color:#fff}
.midnight__cap{margin-top:30px;max-width:34ch;font-size:clamp(1rem,1.3vw,1.2rem);line-height:1.6;color:var(--text);mix-blend-mode:difference}
.midnight__after{padding:clamp(90px,16vh,180px) var(--pad)}

/* ---------- Abyss stats ---------- */
.abyss .stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);border-top:1px solid var(--hairline);margin-top:clamp(50px,8vh,90px);padding-top:40px}
.stat{}
.stat b{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,5rem);line-height:1;letter-spacing:-.03em;display:block;font-variant-numeric:tabular-nums}
.stat span{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-top:14px;max-width:24ch}
@media (max-width:720px){ .abyss .stat-row{grid-template-columns:1fr;gap:30px} }

/* ---------- Hadal — climactic arrival at the bottom ---------- */
.hadal{position:relative;min-height:112svh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;padding:clamp(110px,19vh,210px) 0 0}
.hadal__bleed{position:absolute;inset:0;z-index:0}
.hadal__bleed img{width:100%;height:100%;object-fit:cover;object-position:center 78%;opacity:.6;transform:scale(1.08);filter:saturate(.9) contrast(1.05)}
.hadal.is-in .hadal__bleed img{transform:scale(1);transition:transform 2.6s var(--ease)}
.hadal__grade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,var(--base-deep) 6%,rgba(2,6,10,.5) 40%,rgba(2,6,10,.12) 70%,rgba(2,6,10,.78) 100%)}
.hadal__type{position:relative;z-index:2;padding:0 var(--pad);max-width:1120px}
.hadal__title{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,9vw,8rem);line-height:.9;letter-spacing:calc(-.03em - var(--depth)*.012em);margin-top:18px}
.hadal__deep{margin-top:clamp(34px,7vh,78px);display:flex;align-items:flex-end;gap:clamp(20px,3vw,48px);flex-wrap:wrap}
.hadal__deep b{font-family:var(--display);font-weight:500;font-size:clamp(4rem,15vw,13.5rem);line-height:.8;letter-spacing:-.045em;font-variant-numeric:tabular-nums;display:inline-flex;align-items:flex-start;color:var(--text)}
.hadal__deep b i{font-family:var(--mono);font-style:normal;font-size:.12em;letter-spacing:.05em;color:var(--accent);margin:1.3em 0 0 .25em;text-shadow:0 0 14px var(--glow)}
.hadal__deeplabel{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);max-width:26ch;margin-bottom:1.1em;line-height:1.7}
.hadal__coda{position:relative;z-index:2;padding:clamp(40px,8vh,90px) var(--pad) clamp(56px,9vh,110px);max-width:52ch;margin-left:auto;color:var(--text-dim)}

/* ---------- Marquee ---------- */
.marquee{padding:0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);overflow:hidden;white-space:nowrap}
.marquee__row{display:inline-flex;gap:.5em;padding:26px 0;will-change:transform}
.marquee__row span{font-family:var(--display);font-weight:500;font-size:clamp(2rem,7vw,5.5rem);letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1px var(--text-dim);text-stroke:1px var(--text-dim)}
.marquee__row span em{font-style:normal;color:var(--accent);-webkit-text-stroke:0;text-shadow:0 0 22px var(--glow)}
.marquee__row b{align-self:center;color:var(--accent);font-size:1rem;-webkit-text-stroke:0}

/* ---------- Outro ---------- */
.outro{min-height:100svh;display:flex;flex-direction:column;justify-content:space-between;padding-bottom:40px}
.outro__big{font-family:var(--display);font-weight:500;font-size:clamp(2rem,6.4vw,6rem);line-height:1.02;letter-spacing:-.03em;max-width:16ch;text-wrap:balance}
.outro__big .accent{position:relative}
.cta{position:relative;display:inline-flex;align-items:center;gap:16px;margin-top:clamp(40px,7vh,70px);padding:20px 34px;border:1px solid var(--accent);border-radius:100px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--text);overflow:hidden;will-change:transform}
.cta::before{content:"";position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease);z-index:-1}
.cta:hover{color:#02100c}.cta:hover::before{transform:scaleX(1)}
.cta i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--glow)}
.cta:hover i{background:#02100c;box-shadow:none}
.outro__foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;border-top:1px solid var(--hairline);padding-top:28px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.outro__foot b{color:var(--text-dim);font-weight:500}
.clock{color:var(--accent)}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero__sub{flex-direction:column;align-items:flex-start}
  .hero__meta{text-align:left}
  .zone-title{font-size:clamp(2.4rem,13vw,5rem)}
}
@media (max-width:560px){
  .hero__title{font-size:clamp(3rem,17vw,6rem)}
  .hero{padding-top:22vh}
  .midnight__big{font-size:clamp(2.6rem,15vw,7rem)}
  .hud__depth b{font-size:26px}
  section{padding-left:20px;padding-right:20px}
  .hadal{min-height:128svh}
  .hadal__deep{flex-direction:column;align-items:flex-start;gap:14px}
  .hadal__deep b{font-size:clamp(3.4rem,23vw,7rem)}
  .hadal__deeplabel{margin-bottom:0;max-width:34ch}
  /* lift the closing paragraph off the busy fish texture */
  .hadal__coda{max-width:none;margin:0;padding:26px 20px 64px;
    background:linear-gradient(0deg,rgba(1,6,10,.96) 60%,rgba(1,6,10,.55) 85%,transparent)}
  .midnight__cap{max-width:90vw}
  .hero__q{font-size:clamp(1.2rem,5.4vw,2rem)}
  .h-pin::before,.h-pin::after{width:62px}
  .card{width:78vw}
}
.show-mobile{display:none}
.col-half{grid-column:span 6}.col-7{grid-column:span 7}.col-5{grid-column:span 5}.col-4{grid-column:span 4}.col-8{grid-column:span 8}.col-6{grid-column:span 6}.col-full{grid-column:1/-1}
@media (max-width:760px){
  [class*="col-"]{grid-column:1/-1}
  .grid{gap:32px}
  /* twilight becomes a clean vertical stack on mobile — no partial cards, no chopped metadata */
  .h-pin{height:auto;overflow:visible}
  .h-track{position:static;flex-direction:column;height:auto;gap:54px;padding:96px var(--pad) 40px;transform:none !important;will-change:auto}
  .h-intro{width:100% !important}
  .card{width:100% !important;max-width:520px}
  .card .fig{aspect-ratio:4/5}
  .h-pin::before,.h-pin::after,.h-foot,.h-progress,.h-label,.h-rangelabel,.h-veil{display:none}
  .hide-mobile{display:none}
  .show-mobile{display:inline}
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.001s !important;scroll-behavior:auto !important}
  .js .reveal .line-mask>*,.js .fade{transform:none !important;opacity:1 !important}
  .grain,#gl,.scrollcue i{animation:none}
}

/* no-js: ensure everything visible */
.no-js .preloader,.no-js .curtain,.no-js .cursor{display:none}
.no-js #gl{opacity:.5}
