/* =====================================================================
   ARK IDLE: The Long Awakening — Broken Ark Studios
   Visual language pulled straight from the game assets:
   chamfered gunmetal bulkhead panels, edge-lit cyan light bars,
   salvage-gold accents, and a rare "anomaly" purple held in reserve.
   ===================================================================== */

/* ----------  DESIGN TOKENS  ---------- */
:root{
  /* surfaces */
  --void:      #04070b;
  --void-2:    #070c12;
  --panel:     #0b1119;
  --panel-2:   #0f1722;
  --steel:     #1b242e;
  --steel-2:   #28323d;
  --edge:      #3c4b59;   /* lit metal edge */
  --edge-soft: #223040;

  /* ink */
  --ink:       #e9f3f8;
  --ink-dim:   #93a7b6;
  --ink-faint: #5b6e7d;

  /* energy accents */
  --cyan:      #46d8f2;
  --cyan-hi:   #8fefff;
  --cyan-deep: #0c3b48;
  --gold:      #f2a63f;
  --gold-hi:   #ffcf86;
  --purple:    #b15cff;
  --purple-hi: #e2bbff;

  /* crew colors */
  --c-alpha:   #4a9bff;  /* Survey  */
  --c-bravo:   #f5a93a;  /* Recovery */
  --c-charlie: #57f29a;  /* Biology */
  --c-delta:   #ff7e2d;  /* Thermal */
  --c-echo:    #8b6cff;  /* Signal  */
  --c-foxtrot: #34dcf2;  /* Deep Dive */

  /* geometry */
  --chamfer: 14px;
  --maxw: 1200px;

  /* type */
  --display: 'Orbitron', sans-serif;
  --label:   'Rajdhani', sans-serif;
  --body:    'Barlow', sans-serif;
}

/* ----------  RESET  ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}
body{
  font-family:var(--body);
  background:var(--void);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ambient backdrop: deep space + faint grid + vignette */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1200px 800px at 50% -10%, #0a1822 0%, transparent 60%),
    radial-gradient(900px 600px at 90% 110%, #120a1c 0%, transparent 55%),
    linear-gradient(180deg,#04070b 0%,#05080d 100%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(70,216,242,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(70,216,242,.035) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 80%);
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 80%);
}

/* ----------  SHARED TYPE UTILITIES  ---------- */
.eyebrow{
  font-family:var(--label);
  font-weight:600;
  letter-spacing:.38em;
  text-transform:uppercase;
  font-size:.74rem;
  color:var(--cyan);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--cyan));
}
.section-title{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(1.7rem,3.6vw,2.9rem);
  letter-spacing:.02em;
  line-height:1.08;
  margin:.5rem 0 1rem;
}
.lede{
  color:var(--ink-dim);
  font-size:clamp(1rem,1.4vw,1.18rem);
  max-width:62ch;
}
.data{
  font-family:var(--label);
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
}

/* ----------  LAYOUT  ---------- */
.wrap{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}
section{padding:clamp(4rem,8vw,7rem) 0;position:relative}
.section-head{max-width:760px;margin-bottom:2.6rem}

/* ----------  CHAMFERED BULKHEAD PANEL  ----------
   single-element chamfer: clip-path cuts the corners, the border
   rides the cut to read as a beveled metal edge.                */
.bulkhead{
  position:relative;
  background:
    linear-gradient(160deg,var(--panel-2) 0%,var(--panel) 55%,var(--void-2) 100%);
  border:1px solid var(--edge-soft);
  clip-path:polygon(
    var(--chamfer) 0, calc(100% - var(--chamfer)) 0,
    100% var(--chamfer), 100% calc(100% - var(--chamfer)),
    calc(100% - var(--chamfer)) 100%, var(--chamfer) 100%,
    0 calc(100% - var(--chamfer)), 0 var(--chamfer));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), inset 0 0 38px rgba(0,0,0,.55);
}
/* edge-lit corner light bars (the blue ticks seen on every asset) */
.bulkhead::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(90deg,var(--cyan),transparent 22%) top left/70px 2px no-repeat,
    linear-gradient(-90deg,var(--cyan),transparent 22%) top right/70px 2px no-repeat,
    linear-gradient(90deg,var(--cyan),transparent 22%) bottom left/70px 2px no-repeat,
    linear-gradient(-90deg,var(--cyan),transparent 22%) bottom right/70px 2px no-repeat;
  opacity:.55;
}

/* ----------  BUTTONS  ---------- */
.btn{
  --c:var(--cyan);
  font-family:var(--label);
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.92rem;
  color:#04141a;
  background:linear-gradient(180deg,var(--cyan-hi),var(--cyan));
  padding:.95rem 1.9rem;
  display:inline-flex;align-items:center;gap:.7rem;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow:0 0 0 1px rgba(143,239,255,.5),0 12px 30px -12px var(--cyan);
  transition:transform .15s ease,box-shadow .25s ease,filter .2s ease;
  cursor:pointer;border:none;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.08);box-shadow:0 0 0 1px var(--cyan-hi),0 16px 38px -10px var(--cyan)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid var(--cyan-hi);outline-offset:3px}
.btn--gold{
  color:#1a0f02;
  background:linear-gradient(180deg,var(--gold-hi),var(--gold));
  box-shadow:0 0 0 1px rgba(255,207,134,.5),0 12px 30px -12px var(--gold);
}
.btn--gold:hover{box-shadow:0 0 0 1px var(--gold-hi),0 16px 38px -10px var(--gold)}
.btn--gold:focus-visible{outline-color:var(--gold-hi)}
.btn--ghost{
  color:var(--ink);
  background:linear-gradient(180deg,var(--steel-2),var(--steel));
  box-shadow:inset 0 0 0 1px var(--edge);
}
.btn--ghost:hover{box-shadow:inset 0 0 0 1px var(--cyan),0 10px 26px -14px var(--cyan);filter:none}

/* ====================================================================
   TOP NAV
   ==================================================================== */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:linear-gradient(180deg,rgba(5,9,14,.92),rgba(5,9,14,.6));
  border-bottom:1px solid var(--edge-soft);
}
.nav__inner{display:flex;align-items:center;gap:1.5rem;padding:.7rem 0;width:min(100% - 2.4rem,1320px);margin-inline:auto}
.nav__brand{display:flex;align-items:center;gap:.7rem}
.nav__brand img{width:38px;height:38px}
.nav__brand b{font-family:var(--display);font-weight:700;font-size:.95rem;letter-spacing:.06em}
.nav__brand span{display:block;font-family:var(--label);font-size:.64rem;letter-spacing:.34em;color:var(--ink-faint);text-transform:uppercase}
.nav__links{display:flex;gap:1.7rem;margin-left:auto}
.nav__links a{
  font-family:var(--label);font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  font-size:.82rem;color:var(--ink-dim);padding:.3rem 0;position:relative;transition:color .2s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--cyan);transition:width .25s}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{width:100%}
.nav__cta{margin-left:1rem}
.nav__cta .btn{padding:.7rem 1.3rem;font-size:.82rem}
.nav__toggle{display:none;background:none;border:1px solid var(--edge);color:var(--cyan);width:42px;height:38px;cursor:pointer;margin-left:auto;clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px)}
.nav__toggle span{display:block;width:18px;height:2px;background:currentColor;margin:3px auto}

/* ====================================================================
   HERO
   ==================================================================== */
.hero{padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(3rem,6vw,5rem);overflow:hidden}
/* ambient wreck-ship layer (swap: assets/ark-splash.png) */
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:url("assets/ark-splash.png") center 20%/cover no-repeat;
  opacity:.16;filter:saturate(.8) contrast(1.05);
  mask-image:linear-gradient(180deg,#000 0%,#000 40%,transparent 92%);
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 40%,transparent 92%);
}
.hero__inner{display:flex;flex-direction:column;align-items:center;text-align:center}
.hero__badge{
  font-family:var(--label);font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  font-size:.74rem;color:var(--cyan);
  border:1px solid var(--edge);padding:.45rem 1.1rem;margin-bottom:1.6rem;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  background:rgba(70,216,242,.05);
}
/* HERO TITLE ART — swap: assets/ark-title.png */
.hero__title{width:min(760px,100%);filter:drop-shadow(0 18px 50px rgba(70,216,242,.18));margin-bottom:1.5rem}
.hero__tag{
  font-family:var(--label);font-weight:500;
  font-size:clamp(1.05rem,2vw,1.45rem);letter-spacing:.04em;
  color:var(--ink);max-width:32ch;margin-bottom:2.2rem;
}
.hero__tag b{color:var(--cyan-hi);font-weight:600}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}

/* telemetry readout strip — the idle "number-go-up" signature */
.readout{
  margin-top:3rem;width:min(960px,100%);
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--edge-soft);
  padding:1px;
}
.readout__cell{
  background:linear-gradient(160deg,var(--panel-2),var(--void-2));
  padding:1.1rem .8rem;text-align:center;position:relative;
}
.readout__k{font-family:var(--label);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.62rem;color:var(--ink-faint)}
.readout__v{font-family:var(--display);font-weight:700;font-size:clamp(1.05rem,2vw,1.5rem);color:var(--cyan-hi);margin-top:.25rem;text-shadow:0 0 18px rgba(70,216,242,.4)}
.readout__cell--gold .readout__v{color:var(--gold-hi);text-shadow:0 0 18px rgba(242,166,63,.4)}

/* ====================================================================
   PREMISE
   ==================================================================== */
.premise__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:center}
.premise__copy p{color:var(--ink-dim);margin-top:1.1rem;max-width:58ch}
.premise__copy p strong{color:var(--ink);font-weight:600}
.premise__art{padding:10px}
/* swap: assets/ark-splash.png */
.premise__art img{width:100%;clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px)}

/* ====================================================================
   FEATURE CARDS
   ==================================================================== */
.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.feature{padding:1.7rem 1.5rem 1.6rem;transition:transform .2s ease}
.feature:hover{transform:translateY(-4px)}
.feature:hover::before{opacity:1}
.feature__icon{
  width:54px;height:54px;display:grid;place-items:center;margin-bottom:1.1rem;
  color:var(--cyan);
}
.feature__icon img{width:54px;height:54px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(70,216,242,.4))}
.feature__icon svg{width:30px;height:30px}
.feature h3{font-family:var(--display);font-weight:700;font-size:1.02rem;letter-spacing:.02em;margin-bottom:.5rem}
.feature p{color:var(--ink-dim);font-size:.94rem}
.feature[data-accent="gold"] .feature__icon{color:var(--gold)}
.feature[data-accent="gold"] .feature__icon svg{filter:drop-shadow(0 0 10px rgba(242,166,63,.5))}
.feature[data-accent="purple"] .feature__icon{color:var(--purple)}

/* ====================================================================
   PROGRESSION TIMELINE
   ==================================================================== */
.timeline{position:relative}
.track{
  display:flex;gap:0;overflow-x:auto;padding:1.5rem .2rem 2rem;
  scrollbar-width:thin;scrollbar-color:var(--edge) transparent;
}
.track::-webkit-scrollbar{height:6px}
.track::-webkit-scrollbar-thumb{background:var(--edge);border-radius:3px}
.node{flex:1 1 0;min-width:104px;text-align:center;position:relative;padding-top:2.2rem}
.node::before{ /* connector line */
  content:"";position:absolute;top:calc(2.2rem - 6px);left:50%;width:100%;height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--edge-soft));
}
.node:last-child::before{display:none}
.node__dot{
  position:absolute;top:calc(2.2rem - 14px);left:calc(50% - 8px);
  width:16px;height:16px;background:var(--void);border:2px solid var(--cyan);
  transform:rotate(45deg);box-shadow:0 0 12px var(--cyan);
}
.node__step{font-family:var(--label);font-weight:600;font-size:.62rem;letter-spacing:.2em;color:var(--ink-faint)}
.node__name{font-family:var(--display);font-weight:600;font-size:.82rem;margin-top:.3rem;color:var(--ink)}
/* late-game nodes read as locked / encrypted */
.node--late .node__dot{border-color:var(--gold);box-shadow:0 0 12px var(--gold)}
.node--late::before{background:linear-gradient(90deg,var(--gold),var(--edge-soft))}
.node--locked .node__name{color:var(--ink-dim)}
.node--locked .node__dot{border-color:var(--ink-faint);box-shadow:none;background:var(--panel)}
.node--anomaly .node__dot{border-color:var(--purple);box-shadow:0 0 16px var(--purple);animation:pulse 2.4s ease-in-out infinite}
.node--anomaly .node__name{color:var(--purple-hi);text-shadow:0 0 14px rgba(177,92,255,.5)}
.node--anomaly::before{display:none}
@keyframes pulse{0%,100%{box-shadow:0 0 10px var(--purple)}50%{box-shadow:0 0 22px var(--purple)}}

/* ====================================================================
   LORE
   ==================================================================== */
.lore{position:relative}
.lore__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem;margin-top:2.4rem}
.lore__card{padding:1.7rem 1.6rem}
.lore__card h3{font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:.04em;margin-bottom:.7rem;color:var(--cyan-hi);display:flex;align-items:center;gap:.6rem}
.lore__card h3 .tag{font-family:var(--label);font-size:.6rem;letter-spacing:.2em;color:var(--ink-faint);border:1px solid var(--edge-soft);padding:.15rem .5rem}
.lore__card p{color:var(--ink-dim);font-size:.95rem}

/* ====================================================================
   CREW EXPLORATION
   ==================================================================== */
.crew__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-bottom:3rem}
.crew{padding:1.4rem 1.3rem 1.5rem;text-align:center;--cc:var(--cyan);transition:transform .2s ease}
.crew:hover{transform:translateY(-5px)}
.crew__badge{position:relative;width:148px;margin:0 auto 1rem}
.crew__badge img{width:148px;height:148px;transition:filter .25s,transform .25s}
.crew:hover .crew__badge img{filter:drop-shadow(0 0 22px var(--cc));transform:scale(1.04)}
.crew__name{font-family:var(--display);font-weight:700;font-size:.96rem;letter-spacing:.02em}
.crew__role{font-family:var(--label);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.64rem;color:var(--cc);margin-top:.25rem}
.crew__region{margin-top:.7rem;font-size:.86rem;color:var(--ink-dim)}
.crew__region b{color:var(--ink);font-weight:600}
.crew__meta{margin-top:.9rem;display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap}
.crew__chip{
  font-family:var(--label);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.58rem;
  color:var(--ink-dim);border:1px solid var(--edge-soft);padding:.2rem .55rem;
  background:rgba(255,255,255,.015);
}
/* crew accent assignment */
.crew[data-crew="alpha"]  {--cc:var(--c-alpha)}
.crew[data-crew="bravo"]  {--cc:var(--c-bravo)}
.crew[data-crew="charlie"]{--cc:var(--c-charlie)}
.crew[data-crew="delta"]  {--cc:var(--c-delta)}
.crew[data-crew="echo"]   {--cc:var(--c-echo)}
.crew[data-crew="foxtrot"]{--cc:var(--c-foxtrot)}

/* regions strip */
.regions{margin-top:.5rem}
.regions__head{font-family:var(--label);font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:.72rem;color:var(--ink-faint);margin-bottom:1rem;text-align:center}
.regions__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.region{
  padding:1rem 1.1rem;display:flex;align-items:center;gap:.8rem;
  background:linear-gradient(160deg,var(--panel-2),var(--void-2));
  border:1px solid var(--edge-soft);
  clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px);
  transition:border-color .2s;
}
.region:hover{border-color:var(--cyan)}
.region__idx{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--cyan);opacity:.7;min-width:2.4ch}
.region__name{font-family:var(--label);font-weight:600;letter-spacing:.06em;font-size:.92rem}
.region__sub{font-size:.72rem;color:var(--ink-faint);letter-spacing:.06em}

/* ====================================================================
   MYSTERY SIGNAL / ANOMALY
   ==================================================================== */
.signal{position:relative;overflow:hidden}
.signal::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(900px 460px at 50% 40%,rgba(177,92,255,.16),transparent 70%);
}
.signal__inner{
  max-width:880px;margin-inline:auto;text-align:center;
  padding:clamp(2.4rem,5vw,3.6rem) clamp(1.4rem,4vw,3rem);
  --chamfer:18px;
  border-color:rgba(177,92,255,.4);
}
.signal__inner::before{
  background:
    linear-gradient(90deg,var(--purple),transparent 22%) top left/70px 2px no-repeat,
    linear-gradient(-90deg,var(--purple),transparent 22%) top right/70px 2px no-repeat,
    linear-gradient(90deg,var(--purple),transparent 22%) bottom left/70px 2px no-repeat,
    linear-gradient(-90deg,var(--purple),transparent 22%) bottom right/70px 2px no-repeat;
}
/* swap: assets/anomaly.png */
.signal__art{width:min(520px,86%);margin:0 auto 1.8rem;filter:drop-shadow(0 0 30px rgba(177,92,255,.45))}
.signal__line{
  font-family:var(--label);font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  font-size:.74rem;color:var(--purple-hi);margin-bottom:1.4rem;
}
.signal__inner p{color:var(--ink-dim);max-width:60ch;margin:0 auto 1rem;font-size:1.02rem}
.signal__inner p .glitch{color:var(--purple-hi);font-weight:600}
.signal__status{
  margin-top:1.8rem;display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--label);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;
  color:var(--purple-hi);
}
.signal__status .blip{width:9px;height:9px;background:var(--purple);border-radius:50%;box-shadow:0 0 12px var(--purple);animation:blip 1.6s ease-in-out infinite}
@keyframes blip{0%,100%{opacity:.35;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}

/* ====================================================================
   GALLERY
   ==================================================================== */
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:.9rem}
.shot{
  position:relative;overflow:hidden;border:1px solid var(--edge-soft);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  background:var(--panel);
}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .3s}
.shot:hover img{transform:scale(1.06)}
.shot--wide{grid-column:span 2}
.shot--tall{grid-row:span 2}
.shot__cap{
  position:absolute;left:0;bottom:0;right:0;padding:.5rem .8rem;
  font-family:var(--label);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.62rem;
  color:var(--ink);background:linear-gradient(0deg,rgba(4,7,11,.92),transparent);
}
/* placeholder slot — drop a real screenshot in here */
.shot--ph{display:grid;place-items:center;background:repeating-linear-gradient(45deg,var(--panel),var(--panel) 12px,var(--panel-2) 12px,var(--panel-2) 24px)}
.shot--ph span{font-family:var(--label);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.66rem;color:var(--ink-faint);text-align:center;padding:1rem}

/* ====================================================================
   STEAM / WISHLIST BAND
   ==================================================================== */
.steam{position:relative}
.steam__panel{
  --chamfer:20px;
  display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center;
  padding:clamp(2rem,4vw,3rem);
  background:linear-gradient(135deg,var(--panel-2) 0%,var(--void-2) 70%);
}
.steam__panel::before{
  background:
    linear-gradient(90deg,var(--gold),transparent 22%) top left/80px 2px no-repeat,
    linear-gradient(-90deg,var(--gold),transparent 22%) top right/80px 2px no-repeat,
    linear-gradient(90deg,var(--gold),transparent 22%) bottom left/80px 2px no-repeat,
    linear-gradient(-90deg,var(--gold),transparent 22%) bottom right/80px 2px no-repeat;
}
.steam__tags{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}
.steam__tag{font-family:var(--label);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.66rem;color:var(--gold-hi);border:1px solid rgba(242,166,63,.35);padding:.3rem .7rem}
.steam__panel h2{font-family:var(--display);font-weight:800;font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.1;margin-bottom:.8rem}
.steam__panel p{color:var(--ink-dim);max-width:46ch}
.steam__cta{display:flex;flex-direction:column;gap:.8rem}
.steam__cta .btn{justify-content:center}
.steam__note{font-family:var(--label);font-size:.72rem;letter-spacing:.1em;color:var(--ink-faint);text-align:center}

/* ====================================================================
   FOOTER
   ==================================================================== */
.footer{border-top:1px solid var(--edge-soft);padding:3rem 0 2.2rem;background:linear-gradient(180deg,transparent,rgba(4,7,11,.6))}
.footer__top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.footer__brand{display:flex;align-items:center;gap:1rem;max-width:360px}
.footer__brand img{width:64px;height:64px}
.footer__brand b{font-family:var(--display);font-weight:700;font-size:1.05rem;letter-spacing:.04em;display:block}
.footer__brand p{color:var(--ink-faint);font-size:.85rem;margin-top:.3rem}
.footer__cols{display:flex;gap:3.5rem;flex-wrap:wrap}
.footer__col h4{font-family:var(--label);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem;color:var(--cyan);margin-bottom:.9rem}
.footer__col a{display:block;color:var(--ink-dim);font-size:.9rem;padding:.25rem 0;transition:color .2s}
.footer__col a:hover{color:var(--ink)}
.footer__bottom{margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid var(--edge-soft);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--ink-faint);font-size:.78rem;font-family:var(--label);letter-spacing:.06em}

/* ====================================================================
   SCROLL REVEAL
   ==================================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media (max-width:960px){
  .nav__links,.nav__cta{display:none}
  .nav__toggle{display:block}
  .nav.open .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--void-2);border-bottom:1px solid var(--edge-soft);padding:.5rem 1.2rem 1.2rem}
  .nav.open .nav__links a{padding:.8rem 0;border-bottom:1px solid var(--edge-soft)}
  .nav.open .nav__cta{display:block;position:absolute;top:100%;margin-top:0;left:0;right:0;background:var(--void-2);padding:1.2rem;transform:translateY(180px)}
  .premise__grid{grid-template-columns:1fr}
  .features__grid{grid-template-columns:repeat(2,1fr)}
  .lore__grid{grid-template-columns:1fr}
  .crew__grid{grid-template-columns:repeat(2,1fr)}
  .regions__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .steam__panel{grid-template-columns:1fr}
  .readout{grid-template-columns:repeat(3,1fr)}
  .readout__cell:nth-child(4),.readout__cell:nth-child(5){display:none}
}
@media (max-width:560px){
  :root{--chamfer:10px}
  .features__grid,.crew__grid,.regions__grid,.gallery__grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;width:100%}
  .hero__cta .btn{justify-content:center}
  .readout{grid-template-columns:repeat(2,1fr)}
  .readout__cell:nth-child(3){display:none}
  .shot--wide,.shot--tall{grid-column:auto;grid-row:auto}
}
