/* ============================================================
   PULSARI — landing page
   A page staged as the game's own HUD: void black, cyan
   targeting reticles, monospace telemetry, glowing combo stats.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* void + panels */
  --void:#04060b;
  --void2:#070b13;
  --panel:#0a0f19;
  --panel2:#0d1521;
  --line:#15212f;
  --line2:#223547;
  --line3:#2f4860;

  /* ink */
  --ink:#eaf3f8;
  --muted:#92a6b6;
  --faint:#5b6f80;

  /* brand cyan */
  --cyan:#35dfe6;
  --cyan-soft:#8af0f3;
  --cyan-dim:#13929c;
  --cyan-deep:#0a5158;
  --glow:rgba(53,223,230,.55);

  /* secondary track palettes (used sparingly, for energy) */
  --magenta:#ff3ea5;
  --amber:#f4c34a;
  --acid:#9be36b;
  --aurora:#5fe0a6;
  --inferno:#ff5a47;

  --display:'Chakra Petch', system-ui, sans-serif;
  --mono:'Space Mono', ui-monospace, monospace;

  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--void);
  color:var(--ink);
  font-family:var(--display);
  font-weight:400;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--cyan-soft);text-decoration:none}
::selection{background:var(--cyan);color:#021014}

/* faint grid that lives under the whole page */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(53,223,230,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(53,223,230,.035) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 32%, #000 0%, transparent 78%);
          mask-image:radial-gradient(circle at 50% 32%, #000 0%, transparent 78%);
  opacity:.6;
}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px;position:relative;z-index:2}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--cyan);font-weight:400;margin:0 0 18px;display:flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--cyan);opacity:.7}
.eyebrow.amber{color:var(--amber)}.eyebrow.amber::before{background:var(--amber)}
.eyebrow.magenta{color:var(--magenta)}.eyebrow.magenta::before{background:var(--magenta)}

h1,h2,h3{margin:0;font-weight:600;line-height:1.05;letter-spacing:-.01em}
.h-display{
  font-size:clamp(2.4rem,6.2vw,5.2rem);font-weight:700;line-height:.98;letter-spacing:-.02em;
}
.h-section{font-size:clamp(2rem,4.6vw,3.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.02}
.lead{font-size:clamp(1.05rem,1.7vw,1.3rem);color:#cddae4;font-weight:300;line-height:1.6}
.body{color:var(--muted);font-weight:300;font-size:1.04rem}
.tele{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}

em{font-style:normal;color:var(--cyan-soft)}

section{position:relative;z-index:2}

/* ============================================================
   NAV
   ============================================================ */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  transition:background .3s var(--ease), border-color .3s var(--ease), backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
header.nav.scrolled{
  background:rgba(4,6,11,.72);backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
}
.nav-in{display:flex;align-items:center;gap:22px;height:66px;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;letter-spacing:.36em;font-size:.95rem;color:#fff}
.brand .sigil{width:18px;height:18px;flex:none;position:relative}
.brand .sigil::before{
  content:"";position:absolute;inset:0;
  background:var(--cyan);
  clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%);
  box-shadow:0 0 14px var(--glow);
}
.brand .sigil::after{content:"";position:absolute;inset:6px;background:var(--void);clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%)}
.nav-links{display:flex;gap:26px;margin-left:auto;align-items:center}
.nav-links a{color:var(--muted);font-size:.84rem;font-weight:500;letter-spacing:.06em;transition:color .15s}
.nav-links a:hover{color:#fff}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:.92rem;
  letter-spacing:.02em;padding:12px 22px;border-radius:3px;border:1px solid var(--line2);
  background:rgba(13,21,33,.6);color:var(--ink);cursor:pointer;transition:.18s var(--ease);white-space:nowrap;
  position:relative;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;
}
.btn:hover{border-color:var(--cyan-dim);color:#fff;transform:translateY(-2px)}
.btn .ar{font-size:1em;line-height:1;transition:transform .18s}
.btn:hover .ar{transform:translateX(3px)}
.btn.primary{
  background:linear-gradient(180deg,#48eef5,#159aa4);border-color:transparent;color:#021416;font-weight:700;
  box-shadow:0 0 0 1px rgba(72,238,245,.4), 0 10px 34px -10px var(--glow);
}
.btn.primary:hover{box-shadow:0 0 0 1px rgba(72,238,245,.7), 0 16px 44px -10px var(--glow);color:#01191c}
.btn.ghost{background:transparent}
.btn.big{padding:17px 34px;font-size:.92rem}
.nav .btn{padding:9px 17px;font-size:.76rem}

/* corner-bracket decoration utility */
.brackets{position:relative}
.brackets::before,.brackets::after{
  content:"";position:absolute;width:14px;height:14px;border:1px solid var(--cyan-dim);opacity:.6;
}
.brackets::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.brackets::after{bottom:-1px;right:-1px;border-left:0;border-top:0}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100svh;min-height:680px;overflow:hidden;display:flex;flex-direction:column}
#nexus{position:absolute;inset:0;width:100%;height:100%;z-index:1;display:block}
.hero-fallback{position:absolute;inset:0;z-index:1;background:center/cover no-repeat;opacity:0;pointer-events:none}
.hero-vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 42%, transparent 38%, rgba(4,6,11,.55) 78%, var(--void) 100%);}
.hero-grad-bottom{position:absolute;left:0;right:0;bottom:0;height:30%;z-index:2;pointer-events:none;
  background:linear-gradient(transparent, var(--void))}

/* hero HUD telemetry overlays */
.hud{position:absolute;z-index:4;font-family:var(--mono);text-transform:uppercase;color:var(--cyan);
  font-size:.74rem;letter-spacing:.16em;pointer-events:none;opacity:.92}
.hud .dim{color:var(--faint)}
.hud-tl{top:88px;left:26px}
.hud-tr{top:88px;right:26px;text-align:right}
.hud-bl{bottom:30px;left:26px}
.hud-track{font-size:.82rem;color:var(--ink);letter-spacing:.22em}

/* layer stack indicator (top-left, like the game) */
.layers{position:absolute;z-index:4;top:130px;left:26px;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.layer{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--line2);color:var(--faint);padding:6px 11px;min-width:104px;border-radius:2px;
  display:flex;justify-content:space-between;gap:14px;transition:.35s var(--ease);background:rgba(8,12,20,.4);
}
.layer.on{color:#021014;background:var(--cyan);border-color:var(--cyan);box-shadow:0 0 18px -2px var(--glow)}
.layer .lv{opacity:.6}
.layer.on .lv{opacity:.9}

.hero-content{position:relative;z-index:5;margin-top:auto;width:100%}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:0 26px 64px;display:flex;flex-direction:column;align-items:flex-start}
.hero-logo{width:min(440px,72vw);margin:0 0 10px;filter:drop-shadow(0 4px 40px var(--glow))}
.hero-tag{font-family:var(--mono);font-size:clamp(.92rem,1.5vw,1.18rem);color:var(--cyan-soft);
  letter-spacing:.04em;margin:6px 0 18px;text-transform:none}
.hero-sub{font-size:clamp(1.02rem,1.6vw,1.24rem);color:#c4d4df;font-weight:300;max-width:600px;margin:0 0 30px;line-height:1.55}
.hero-sub b{color:var(--ink);font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.price-tag{display:flex;flex-direction:column;gap:1px;font-family:var(--mono);margin-left:6px}
.price-tag .now{color:var(--amber);font-size:1.04rem;font-weight:700;letter-spacing:.04em}
.price-tag .meta{color:var(--faint);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}

/* sound toggle */
.sound-btn{
  position:absolute;z-index:6;bottom:32px;right:26px;display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan);background:rgba(8,12,20,.55);border:1px solid var(--line2);padding:10px 15px;border-radius:3px;
  cursor:pointer;transition:.2s var(--ease);backdrop-filter:blur(6px);
}
.sound-btn:hover{border-color:var(--cyan-dim);color:#fff}
.sound-btn .bars{display:flex;align-items:flex-end;gap:2px;height:13px}
.sound-btn .bars i{width:2.5px;background:var(--cyan);height:30%;border-radius:1px;transition:.2s}
.sound-btn.playing .bars i{animation:eq .9s ease-in-out infinite}
.sound-btn.playing .bars i:nth-child(2){animation-delay:.15s}
.sound-btn.playing .bars i:nth-child(3){animation-delay:.3s}
.sound-btn.playing .bars i:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:25%}50%{height:100%}}

/* "tap to summon" prompt pulsing in hero before audio starts */
.summon-hint{
  position:absolute;z-index:6;left:63%;top:83%;transform:translate(-50%,-50%);
  font-family:var(--mono);font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan-soft);
  text-align:center;pointer-events:none;transition:opacity .5s;width:max-content;max-width:90vw;
}
.summon-hint .key{display:inline-block;border:1px solid var(--cyan-dim);border-radius:3px;padding:2px 9px;margin:0 3px;color:#fff}
.summon-hint.gone{opacity:0}

.scroll-cue{position:absolute;z-index:5;left:50%;bottom:20px;transform:translateX(-50%);
  font-family:var(--mono);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint);
  display:flex;flex-direction:column;align-items:center;gap:7px;animation:bob 2.4s ease-in-out infinite}
.scroll-cue .ln{width:1px;height:26px;background:linear-gradient(var(--cyan-dim),transparent)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.band{padding:clamp(80px,11vw,150px) 0;position:relative}
.band.line-top{border-top:1px solid var(--line)}
.section-head{max-width:760px;margin-bottom:54px}
.section-head .h-section{margin-bottom:18px}

/* tick label used like a track index, e.g. "01 // SUMMON" */
.track-label{font-family:var(--mono);font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.track-label b{color:var(--cyan);font-weight:400}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

/* ============================================================
   PITCH — summon / trance / restart triptych
   ============================================================ */
.pitch-lead{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:70px}
.pitch-lead .big{font-size:clamp(2.2rem,4.6vw,3.7rem);font-weight:700;line-height:1.04;letter-spacing:-.02em}
.pitch-lead .big em{display:block}
.pitch-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{
  position:relative;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel),var(--void2));
  border-radius:6px;padding:30px 28px 32px;overflow:hidden;
}
.step .num{font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;color:var(--cyan);margin-bottom:auto}
.step h3{font-size:1.45rem;font-weight:700;margin:20px 0 12px;letter-spacing:-.01em}
.step p{margin:0;color:var(--muted);font-weight:300;font-size:.98rem;line-height:1.58}
.step .glowline{position:absolute;left:0;top:0;height:2px;width:100%;background:linear-gradient(90deg,transparent,var(--accent,var(--cyan)),transparent);opacity:.7}
.step.s1{--accent:var(--cyan)}
.step.s2{--accent:var(--amber)}
.step.s3{--accent:var(--magenta)}
.step .ic{color:var(--accent,var(--cyan));font-size:1.3rem;margin-bottom:4px}

/* mini layer-build visualization */
.buildviz{margin-top:18px;display:flex;flex-direction:column;gap:7px}
.buildviz .row{display:flex;align-items:center;gap:12px}
.buildviz .nm{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;color:var(--faint);width:58px;text-transform:uppercase}
.buildviz .bar{flex:1;height:6px;border-radius:3px;background:var(--line);overflow:hidden;position:relative}
.buildviz .bar i{position:absolute;inset:0;width:var(--w,0%);background:linear-gradient(90deg,var(--cyan-dim),var(--cyan));border-radius:3px;
  box-shadow:0 0 10px -1px var(--glow)}

/* ============================================================
   TRANCE showcase — full bleed image
   ============================================================ */
.trance{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;border-top:1px solid var(--line)}
.trance-bg{position:absolute;inset:0;z-index:0;background:center/cover no-repeat;transform:scale(1.04)}
.trance-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg, var(--void) 0%, rgba(4,6,11,.55) 42%, transparent 78%),
  linear-gradient(0deg, var(--void), transparent 40%)}
.trance .wrap{position:relative;z-index:2}
.trance-card{max-width:560px}
.trance-card .h-section{margin-bottom:22px}
.trance-card .quote{font-size:clamp(1.3rem,2.4vw,1.9rem);font-weight:400;line-height:1.3;color:#eaf6f7;margin-bottom:18px;letter-spacing:-.01em}
.trance-card .quote em{color:var(--cyan)}

/* ============================================================
   FEATURES grid
   ============================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat{
  position:relative;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel),var(--void2));
  border-radius:6px;padding:28px 26px 30px;transition:.25s var(--ease);overflow:hidden;
}
.feat:hover{border-color:var(--line3);transform:translateY(-3px);box-shadow:0 18px 40px -22px #000}
.feat::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 100% at 0% 0%, rgba(53,223,230,.07), transparent 55%);opacity:0;transition:.3s}
.feat:hover::after{opacity:1}
.feat .ic{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  color:var(--cyan);font-size:1.3rem;position:relative;
}
.feat .ic::before{content:"";position:absolute;inset:0;border:1px solid var(--line2);
  clip-path:polygon(50% 0,93% 25%,93% 75%,50% 100%,7% 75%,7% 25%);background:rgba(53,223,230,.08)}
.feat .ic span{position:relative;z-index:1}
.feat h3{font-size:1.18rem;font-weight:700;margin-bottom:9px;letter-spacing:-.01em}
.feat p{margin:0;color:var(--muted);font-weight:300;font-size:.95rem;line-height:1.55}
.feat .tag{position:absolute;top:18px;right:20px;font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;color:var(--faint);text-transform:uppercase}

/* ============================================================
   STATS strip
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--panel)}
.stat{padding:40px 30px;border-right:1px solid var(--line);position:relative}
.stat:last-child{border-right:none}
.stat .n{font-size:clamp(2.6rem,5vw,4.2rem);font-weight:700;line-height:.9;letter-spacing:-.02em;
  color:#fff;text-shadow:0 0 30px var(--statglow,var(--glow))}
.stat .n .x{color:var(--statc,var(--cyan));font-size:.55em;vertical-align:super;margin-left:2px}
.stat .lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:14px}
.stat.c-cyan{--statc:var(--cyan);--statglow:var(--glow)}
.stat.c-amber{--statc:var(--amber);--statglow:rgba(244,195,74,.5)}
.stat.c-magenta{--statc:var(--magenta);--statglow:rgba(255,62,165,.5)}
.stat.c-acid{--statc:var(--acid);--statglow:rgba(155,227,107,.5)}

/* ============================================================
   GALLERY
   ============================================================ */
.gal{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;grid-auto-rows:1fr}
.shot{position:relative;border:1px solid var(--line);border-radius:5px;overflow:hidden;cursor:zoom-in;
  background:var(--void2);min-height:0}
.shot img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9;transition:transform .5s var(--ease);display:block}
.shot:hover img{transform:scale(1.06)}
.shot::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);pointer-events:none}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;
  text-transform:uppercase;color:#dbeaf2;padding:26px 14px 11px;background:linear-gradient(transparent,rgba(3,6,11,.92));
  opacity:0;transform:translateY(6px);transition:.22s}
.shot:hover figcaption{opacity:1;transform:none}
.shot .zoom{position:absolute;top:11px;right:11px;width:26px;height:26px;border:1px solid var(--line2);border-radius:3px;
  display:flex;align-items:center;justify-content:center;color:var(--cyan);background:rgba(4,6,11,.6);font-size:.8rem;opacity:0;transition:.22s}
.shot:hover .zoom{opacity:1}
/* spans for an editorial mosaic */
.shot.w6{grid-column:span 6}.shot.w4{grid-column:span 4}.shot.w3{grid-column:span 3}.shot.w12{grid-column:span 12}.shot.w8{grid-column:span 8}

/* ============================================================
   FINAL CTA
   ============================================================ */
.finale{position:relative;text-align:center;padding:clamp(100px,16vw,200px) 0;overflow:hidden;border-top:1px solid var(--line)}
.finale .glow{position:absolute;left:50%;top:42%;width:900px;height:900px;transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(53,223,230,.16), transparent 62%);pointer-events:none;z-index:0}
.finale .wrap{z-index:2}
.finale .h-display{margin-bottom:20px}
.finale .sub{font-size:1.2rem;color:#c4d4df;font-weight:300;max-width:560px;margin:0 auto 36px}
.finale .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;align-items:center}
.finale .chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.chip{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#aebecb;
  background:rgba(13,21,33,.6);border:1px solid var(--line);padding:8px 15px;border-radius:999px}
.chip b{color:var(--cyan);font-weight:400}

/* ============================================================
   FOOTER
   ============================================================ */
footer{border-top:1px solid var(--line);padding:54px 0 60px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
footer .brand-lg{font-weight:700;letter-spacing:.34em;font-size:1.1rem;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:11px}
footer h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin:0 0 16px;font-weight:400}
footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
footer a, footer .copy{color:var(--muted);font-size:.92rem;font-weight:300;transition:color .15s}
footer a:hover, footer .copy:hover{color:#fff}
.copy{cursor:pointer;border:none;background:transparent;font:inherit;padding:0;font-weight:300}
.copied{color:var(--cyan)!important}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:26px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--faint)}
.foot-bottom .warn{color:var(--amber);opacity:.8}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lb{position:fixed;inset:0;z-index:200;background:rgba(2,4,8,.96);display:none;align-items:center;justify-content:center;
  flex-direction:column;padding:36px;backdrop-filter:blur(8px)}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:80vh;border-radius:6px;box-shadow:0 40px 100px -24px #000;border:1px solid var(--line2)}
.lb-cap{font-family:var(--mono);color:var(--cyan-soft);margin-top:16px;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase}
.lb-x{position:absolute;top:22px;right:28px;font-size:1.8rem;color:#fff;cursor:pointer;line-height:1;opacity:.7;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.lb-x:hover{opacity:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:2.4rem;color:#fff;cursor:pointer;user-select:none;opacity:.5;padding:14px 20px}
.lb-nav:hover{opacity:1}
.lb-prev{left:8px}.lb-next{right:8px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1000px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .pitch-lead{grid-template-columns:1fr;gap:26px}
  .pitch-steps{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .gal .shot{grid-column:span 6 !important}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .layers{display:none}
  .hud-tr{display:none}
  .feat-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:none}
  .gal .shot{grid-column:span 12 !important}
  .foot-grid{grid-template-columns:1fr}
  .hero-inner{padding-bottom:48px}
  .sound-btn{bottom:auto;top:80px;right:14px}
  .summon-hint{left:50%;top:auto;bottom:128px;transform:translateX(-50%)}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .scroll-cue,.sound-btn.playing .bars i{animation:none}
}

/* ============================================================
   COOKIE CONSENT (Consent Mode v2) — staged in the HUD palette
   ============================================================ */
.cookie{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:210;max-width:640px;margin:0 auto;
  background:rgba(10,15,25,.96);border:1px solid var(--line2);border-radius:6px;padding:15px 18px;
  display:flex;gap:16px;align-items:center;flex-wrap:wrap;
  box-shadow:0 24px 60px -26px #000;backdrop-filter:blur(12px) saturate(1.1);
}
.cookie[hidden]{display:none}
.cookie p{margin:0;flex:1;min-width:240px;font-size:.84rem;line-height:1.5;color:var(--muted);font-weight:300}
.cookie p a{color:var(--cyan-soft)}
.cookie-btns{display:flex;gap:9px;margin-left:auto}
.cookie .btn{padding:9px 20px;font-size:.74rem}
@media(max-width:680px){
  .cookie{flex-direction:column;align-items:stretch}
  .cookie-btns{margin-left:0;justify-content:flex-end}
}
