/* =========================================================================
   SAVE TaB SODA — shared design system  ·  SYNTHWAVE / OUTRUN edition
   Neon magenta + electric cyan on deep-space indigo. Sunset disc, grid floor,
   starfield, spinning sunburst. The Pink Pioneer, electrified.
   ========================================================================= */

:root{
  /* neon palette */
  --pink:        #ff2d8b;
  --pink-deep:   #ff5fa8;
  --magenta:     #ff1f6b;
  --cyan:        #1fe5ff;
  --blue:        #3b6dff;
  --violet:      #8a3cff;
  --amber:       #ffb24a;   /* the "sun" */
  --gold:        #ffb24a;   /* legacy alias → amber */

  /* space ground */
  --bg0:         #080318;
  --bg1:         #140733;
  --bg2:         #20104a;   /* panel base */
  --panel:       rgba(31,16,74,.55);
  --panel-2:     rgba(20,9,44,.72);

  /* text */
  --txt:         #f3ecff;
  --txt-dim:     rgba(243,236,255,.66);
  --ink:         #160427;   /* dark text for use on bright/neon surfaces */
  --line:        rgba(180,150,255,.20);

  /* glows */
  --glow-pink: 0 0 6px rgba(255,45,139,.85), 0 0 22px rgba(255,45,139,.45);
  --glow-cyan: 0 0 6px rgba(31,229,255,.85), 0 0 22px rgba(31,229,255,.40);
  --glow-amber:0 0 6px rgba(255,178,74,.85), 0 0 20px rgba(255,178,74,.40);

  /* legacy aliases so existing markup keeps working */
  --paper:       #f3ecff;
  --paper-2:     var(--bg1);
  --card:        var(--panel);
  --cream-line:  var(--line);
  --pink-soft:   #ffd9ea;
  --ink-soft:    #b79fe0;
  --gold-deep:   #e0902f;

  --f-juice: "Shrikhand", Georgia, serif;
  --f-poster:"Archivo Expanded","Archivo",sans-serif;
  --f-sans:  "Archivo", system-ui, sans-serif;

  --maxw: 1220px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 18px;
}

/* ------------------------------------------------------------- reset */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--f-sans);
  color:var(--txt);
  background:var(--bg0);
  background-image:
    radial-gradient(120% 70% at 50% 116%, rgba(255,45,139,.22), transparent 60%),
    radial-gradient(90% 60% at 50% 0%, rgba(58,40,150,.30), transparent 60%),
    linear-gradient(180deg, #080318 0%, #140733 46%, #240c4d 78%, #3a0f54 100%);
  background-attachment:fixed;
  line-height:1.55;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3,h4{margin:0;line-height:.96;font-weight:800}
p{margin:0}
ul{margin:0}

/* faint star dust across whole page */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.5;
  background-image:
    radial-gradient(1px 1px at 12% 22%, rgba(255,255,255,.7), transparent),
    radial-gradient(1px 1px at 78% 14%, rgba(180,230,255,.7), transparent),
    radial-gradient(1px 1px at 64% 62%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 33% 78%, rgba(255,180,230,.6), transparent),
    radial-gradient(1px 1px at 88% 44%, rgba(255,255,255,.55), transparent);
  background-size:520px 520px,420px 420px,600px 600px,500px 500px,380px 380px;
  mix-blend-mode:screen;
}

/* ------------------------------------------------------------- layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);position:relative;z-index:2}
.section{padding-block:clamp(64px,9vw,128px);position:relative}
.section--tight{padding-block:clamp(44px,6vw,80px)}

.eyebrow{
  font-family:var(--f-sans);
  font-weight:800;font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;color:var(--cyan);
  text-shadow:var(--glow-cyan);
}
.eyebrow::before{content:"";width:34px;height:2px;background:currentColor;display:inline-block;box-shadow:var(--glow-cyan)}
.eyebrow--center{justify-content:center}

/* ------------------------------------------------------------- type */
.display{
  font-family:var(--f-poster);font-weight:900;text-transform:uppercase;
  letter-spacing:-.015em;line-height:.9;
  font-size:clamp(2.6rem,7.4vw,6.6rem);color:#fff;
  text-shadow:0 0 4px rgba(255,255,255,.5), 0 0 18px rgba(255,45,139,.55), 0 0 44px rgba(255,45,139,.35);
}
.juice{
  font-family:var(--f-sans);font-weight:800;text-transform:none;letter-spacing:-.01em;
  line-height:1.02;color:var(--pink);
  text-shadow:0 0 8px rgba(255,45,139,.9), 0 0 26px rgba(255,45,139,.55);
}
.h2{
  font-family:var(--f-poster);font-weight:900;text-transform:uppercase;
  letter-spacing:-.01em;line-height:.94;font-size:clamp(2rem,4.6vw,3.7rem);color:#fff;
  text-shadow:0 0 14px rgba(138,60,255,.45), 0 0 30px rgba(31,229,255,.18);
}
.h3{
  font-family:var(--f-poster);font-weight:800;text-transform:uppercase;
  letter-spacing:.005em;font-size:clamp(1.15rem,2vw,1.5rem);color:#fff;
}
.lead{font-size:clamp(1.12rem,1.7vw,1.42rem);line-height:1.5;max-width:60ch;color:var(--txt)}
.muted{color:var(--txt-dim)}
.tab-word{font-family:var(--f-sans);color:var(--pink);font-weight:800;text-shadow:var(--glow-pink)}

/* ------------------------------------------------------------- buttons */
.btn{
  --bg:var(--pink);--fg:#fff;--gl:var(--glow-pink);
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--f-poster);font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;font-size:.92rem;
  padding:.92em 1.5em;border-radius:999px;border:1.5px solid transparent;
  background:var(--bg);color:var(--fg);text-decoration:none;cursor:pointer;
  box-shadow:var(--gl);transition:transform .18s cubic-bezier(.2,.9,.3,1.2), box-shadow .2s, filter .2s;
}
.btn:hover{transform:translateY(-3px);filter:brightness(1.08);
  box-shadow:0 0 10px rgba(255,45,139,.9), 0 0 34px rgba(255,45,139,.6), 0 10px 26px rgba(0,0,0,.4)}
.btn:active{transform:translateY(-1px)}
.btn{white-space:nowrap}
@media (max-width:520px){.btn{white-space:normal}}
.btn--ink{--bg:rgba(255,255,255,.05);--fg:#fff;--gl:inset 0 0 0 1.5px rgba(31,229,255,.55), var(--glow-cyan)}
.btn--gold{--bg:var(--amber);--fg:var(--ink);--gl:var(--glow-amber)}
.btn--ghost{--bg:transparent;--fg:var(--cyan);--gl:inset 0 0 0 1.5px var(--cyan), 0 0 14px rgba(31,229,255,.35)}
.btn--ghost:hover{--bg:rgba(31,229,255,.12)}
.btn--lg{font-size:1.05rem;padding:1.05em 1.8em}
.btn .arrow{font-size:1.1em;line-height:0}

.chip{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--f-poster);font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  font-size:.72rem;padding:.45em .9em;border-radius:999px;
  background:rgba(31,229,255,.12);color:var(--cyan);
  border:1px solid rgba(31,229,255,.5);box-shadow:0 0 12px rgba(31,229,255,.25)}

/* ------------------------------------------------------------- header / nav */
.site-head{
  position:sticky;top:0;z-index:200;
  background:rgba(10,4,28,.72);backdrop-filter:blur(11px);
  border-bottom:1px solid rgba(255,45,139,.4);
  box-shadow:0 1px 0 rgba(31,229,255,.18), 0 8px 30px rgba(0,0,0,.4);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;
  height:72px;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;flex-shrink:0}
/* brand mark — a bold sans-serif "T" (echoing the TaB can lettering) on the pink disc */
.brand__mark{
  width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 50% 35%,#ff8ac4,var(--pink));
  display:grid;place-items:center;color:#fff;
  font-family:var(--f-sans);font-weight:900;font-size:1.35rem;line-height:1;
  border:1.5px solid #ff9ed0;transform:rotate(-6deg);
  box-shadow:var(--glow-pink)}
.brand__txt{font-family:var(--f-poster);font-weight:900;text-transform:uppercase;
  letter-spacing:.02em;font-size:1.02rem;line-height:.95;color:#fff}
.brand__txt b{color:var(--pink);text-shadow:var(--glow-pink)}
.nav__links{display:flex;align-items:center;gap:26px;list-style:none;padding:0;margin:0}
.nav__links a{
  text-decoration:none;font-family:var(--f-poster);font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;white-space:nowrap;
  padding:.3em 0;position:relative;color:rgba(243,236,255,.82)}
.nav__links a:hover{color:#fff}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;
  background:var(--cyan);box-shadow:var(--glow-cyan);transition:right .25s}
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{right:0}
.nav__links a[aria-current="page"]{color:#fff}
.nav__cta{display:flex;align-items:center;gap:10px}
.nav__cta .btn{padding:.62em 1.15em;font-size:.8rem;white-space:nowrap}

/* ---- “More” dropdown ---- */
.nav__more{position:relative}
.nav__more-btn{
  font-family:var(--f-poster);font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:.82rem;white-space:nowrap;color:rgba(243,236,255,.82);background:none;border:0;cursor:pointer;
  padding:.3em 0;display:inline-flex;align-items:center;gap:.45em}
.nav__more-btn:hover,.nav__more-btn.is-current,.nav__more[data-open="true"] .nav__more-btn{color:#fff}
.nav__caret{font-size:.66em;transition:transform .2s}
.nav__more[data-open="true"] .nav__caret{transform:rotate(180deg)}
.nav__submenu{
  position:absolute;top:calc(100% + 16px);right:0;min-width:172px;list-style:none;margin:0;padding:8px;
  background:rgba(12,5,34,.98);backdrop-filter:blur(11px);
  border:1px solid rgba(255,45,139,.4);border-radius:12px;
  box-shadow:0 18px 40px rgba(0,0,0,.6),0 0 0 1px rgba(31,229,255,.14);
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .18s, transform .18s, visibility .18s}
.nav__more[data-open="true"] .nav__submenu{opacity:1;visibility:visible;transform:none}
.nav__submenu a{display:block;padding:11px 13px;border-radius:8px;
  font-family:var(--f-poster);font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:.8rem;color:rgba(243,236,255,.82);text-decoration:none;white-space:nowrap}
.nav__submenu a::after{display:none}
.nav__submenu a:hover{color:#fff;background:rgba(31,229,255,.1)}
.nav__submenu a[aria-current="page"]{color:var(--cyan);text-shadow:var(--glow-cyan)}
@media (min-width:901px){
  .nav__more:hover .nav__submenu,.nav__more:focus-within .nav__submenu{opacity:1;visibility:visible;transform:none}
  .nav__more:hover .nav__caret,.nav__more:focus-within .nav__caret{transform:rotate(180deg)}
}
.nav__toggle{display:none;background:none;border:1.5px solid var(--cyan);border-radius:10px;
  width:44px;height:40px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 0 12px rgba(31,229,255,.3)}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{
  content:"";display:block;width:20px;height:2px;background:var(--cyan);position:relative;box-shadow:var(--glow-cyan)}
.nav__toggle span::before{position:absolute;top:-6px}
.nav__toggle span::after{position:absolute;top:6px}

@media (max-width:900px){
  .nav__toggle{display:inline-flex}
  .nav__links{
    position:fixed;inset:72px 0 auto 0;flex-direction:column;gap:0;
    background:rgba(12,5,34,.97);border-bottom:1px solid rgba(255,45,139,.4);
    padding:8px var(--gutter) 22px;transform:translateY(-130%);transition:transform .3s;
    box-shadow:0 18px 40px rgba(0,0,0,.6)}
  .nav[data-open="true"] .nav__links{transform:translateY(0)}
  .nav__links a{padding:14px 0;border-bottom:1px solid var(--line);font-size:1rem;width:100%}
  /* the sliding cyan underline is a desktop hover affordance — drop it in the
     stacked mobile menu so its glow doesn't streak across the menu words */
  .nav__links a::after{display:none}
  .nav__links a[aria-current="page"]{color:var(--cyan)}
  .nav__cta .btn--ghost{display:none}
  /* flatten the “More” dropdown into the stacked mobile menu */
  .nav__more{width:100%}
  .nav__more-btn{display:none}
  .nav__submenu{position:static;opacity:1;visibility:visible;transform:none;
    background:none;border:0;box-shadow:none;backdrop-filter:none;padding:0;min-width:0}
  .nav__submenu a{padding:14px 0;border-radius:0;border-bottom:1px solid var(--line);font-size:1rem;width:100%}
}

/* ------------------------------------------------------------- marquee */
.marquee{overflow:hidden;border-block:1px solid rgba(255,45,139,.45);
  background:linear-gradient(90deg,#1a0838,#2a0d50);color:#fff;
  box-shadow:inset 0 0 30px rgba(255,45,139,.18)}
.marquee--ink{background:linear-gradient(90deg,#0c0524,#170a36)}
.marquee--gold{background:linear-gradient(90deg,#2a1140,#3a1352);border-color:rgba(255,178,74,.5)}
.marquee__track{display:flex;width:max-content;animation:marq 32s linear infinite;will-change:transform}
.marquee--rev .marquee__track{animation-direction:reverse}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{
  font-family:var(--f-poster);font-weight:900;text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(1.1rem,2.3vw,1.9rem);padding:.5em 0;display:inline-flex;align-items:center;
  color:#fff;text-shadow:0 0 14px rgba(255,45,139,.6)}
.marquee__track span::after{content:"✦";margin:0 .7em;color:var(--cyan);font-size:.7em;text-shadow:var(--glow-cyan)}
.marquee--gold .marquee__track span::after{color:var(--amber);text-shadow:var(--glow-amber)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ------------------------------------------------------------- section bgs */
.bg-ink{background:rgba(8,3,22,.55);box-shadow:inset 0 1px 0 rgba(31,229,255,.12),inset 0 -1px 0 rgba(255,45,139,.18)}
.bg-ink .eyebrow{color:var(--amber);text-shadow:var(--glow-amber)}
.bg-ink .eyebrow::before{box-shadow:var(--glow-amber)}
.bg-paper2{background:rgba(20,9,44,.5)}
.bg-pink{
  background:linear-gradient(135deg,#ff2d8b 0%,#c81e8e 55%,#8a2bd0 100%);color:#fff;
  box-shadow:inset 0 0 80px rgba(0,0,0,.25)}
.bg-pink .eyebrow{color:#fff;text-shadow:0 0 14px rgba(255,255,255,.6)}
.bg-pink .eyebrow::before{box-shadow:0 0 10px rgba(255,255,255,.6)}
.bg-pink .muted{color:rgba(255,255,255,.85)}
.bg-pink .display,.bg-pink .h2{color:#fff;text-shadow:0 0 18px rgba(0,0,0,.25)}

/* ------------- spinning sunburst (KEPT — recolored neon) ------------- */
.sunburst{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.sunburst::before{
  content:"";position:absolute;left:50%;top:42%;width:300vmax;height:300vmax;
  transform:translate(-50%,-50%);
  background:repeating-conic-gradient(from 0deg,
     var(--ray,rgba(255,45,139,.16)) 0deg 5deg, transparent 5deg 11deg);
  animation:spin 90s linear infinite;mix-blend-mode:screen}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
/* On mobile, sections stack taller than the disc — re-center it and grow it so
   the spinning rays always reach the section edges instead of cutting off. */
@media (max-width:760px){
  .sunburst::before{top:50%;width:420vmax;height:420vmax}
  body{background-attachment:scroll}
}
.halftone{background-image:radial-gradient(var(--dot,rgba(31,229,255,.18)) 22%, transparent 23%);
  background-size:15px 15px}

/* ------------- starfield layer ------------- */
.starfield{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.starfield::before,.starfield::after{
  content:"";position:absolute;inset:-20%;
  background-image:
    radial-gradient(1.4px 1.4px at 10% 20%, #fff, transparent),
    radial-gradient(1.2px 1.2px at 30% 70%, #bfe9ff, transparent),
    radial-gradient(1.6px 1.6px at 55% 35%, #fff, transparent),
    radial-gradient(1.2px 1.2px at 72% 80%, #ffd0ec, transparent),
    radial-gradient(1.4px 1.4px at 85% 25%, #fff, transparent),
    radial-gradient(1.1px 1.1px at 47% 88%, #cfe, transparent);
  background-size:300px 300px;background-repeat:repeat;opacity:.85;
  animation:twinkle 4.5s ease-in-out infinite alternate}
.starfield::after{background-size:460px 460px;animation-delay:1.6s;opacity:.55}
@keyframes twinkle{from{opacity:.3}to{opacity:.9}}

/* ------------- outrun grid floor ------------- */
.grid-floor{position:absolute;left:0;right:0;bottom:0;height:46%;z-index:0;pointer-events:none;
  perspective:340px;perspective-origin:50% 0%;overflow:hidden;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 38%);
          mask-image:linear-gradient(to bottom, transparent 0%, #000 38%)}
.grid-floor::before{
  content:"";position:absolute;left:-50%;right:-50%;top:0;height:300%;
  background-image:
    linear-gradient(90deg, rgba(31,229,255,.55) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(255,45,139,.55) 1px, transparent 1px);
  background-size:54px 54px;
  transform:rotateX(78deg);transform-origin:50% 0%;
  animation:gridrun 5.2s linear infinite}
@keyframes gridrun{from{background-position:0 0,0 0}to{background-position:0 54px,0 54px}}

/* ------------- sunset disc ------------- */
.sun{position:absolute;border-radius:50%;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,#ffd66b 0%,#ffb24a 24%,#ff5db1 56%,#c23bd6 100%);
  box-shadow:0 0 70px rgba(255,93,177,.5), 0 0 130px rgba(255,45,139,.35)}
.sun::after{content:"";position:absolute;inset:48% 0 0 0;border-radius:0 0 50% 50%/0 0 100% 100%;
  background-image:repeating-linear-gradient(180deg, rgba(8,3,22,.85) 0 6px, transparent 6px 16px)}

/* ------------------------------------------------------------- cards */
.card{
  background:var(--panel);backdrop-filter:blur(7px);
  border:1.5px solid rgba(255,45,139,.45);border-radius:var(--radius);padding:28px;color:var(--txt);
  box-shadow:0 0 0 1px rgba(255,255,255,.03), 0 14px 40px rgba(0,0,0,.45), inset 0 0 34px rgba(255,45,139,.07)}
.card .h3{color:#fff}
.card--pink{background:linear-gradient(150deg,#ff2d8b,#a32bc8);border-color:rgba(255,255,255,.45);color:#fff;
  box-shadow:var(--glow-pink),0 14px 40px rgba(0,0,0,.45)}
.card--pink .muted{color:rgba(255,255,255,.85)}
.card--gold{background:linear-gradient(150deg,#ffb24a,#ff6f9c);border-color:rgba(255,255,255,.5);color:var(--ink);
  box-shadow:var(--glow-amber),0 14px 40px rgba(0,0,0,.4)}
.card--gold .h3{color:var(--ink)}

/* photo slots — dark dashed neon */
image-slot{border:1.5px dashed rgba(31,229,255,.5);background:rgba(31,229,255,.05);border-radius:12px}
.slot-cap{font-family:var(--f-sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--txt-dim);font-weight:700;margin-top:10px}

/* stat */
.stat__num{font-family:var(--f-juice);color:var(--pink);font-size:clamp(2.6rem,6vw,4.4rem);line-height:.9;
  text-shadow:var(--glow-pink)}
.bg-ink .stat__num{color:var(--cyan);text-shadow:var(--glow-cyan)}
.stat__lbl{font-family:var(--f-poster);font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:.78rem;margin-top:.5em;color:var(--txt-dim)}

.starline{display:flex;align-items:center;gap:14px;color:var(--cyan)}
.starline::before,.starline::after{content:"";height:1px;background:var(--line);flex:1}

/* ------------------------------------------------------------- footer */
.site-foot{position:relative;background:#080318;color:var(--txt);padding-block:74px 30px;overflow:hidden;
  border-top:1px solid rgba(255,45,139,.4)}
.site-foot a{color:var(--txt);text-decoration:none}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;position:relative;z-index:2}
.foot-links{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:10px}
.foot-links a{font-family:var(--f-poster);font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  font-size:.82rem;color:rgba(243,236,255,.75)}
.foot-links a:hover{color:var(--cyan);text-shadow:var(--glow-cyan)}
.foot-head{font-family:var(--f-poster);font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  font-size:.78rem;color:var(--cyan);text-shadow:var(--glow-cyan)}
.disclaimer{font-size:.82rem;line-height:1.55;color:rgba(243,236,255,.5);max-width:60ch;margin-top:14px}
.foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-top:42px;padding-top:22px;border-top:1px solid var(--line);font-size:.8rem;
  color:rgba(243,236,255,.55);position:relative;z-index:2}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ------------------------------------------------------------- reveal
   Visible by DEFAULT (failsafe): if JS fails OR a throttled browser freezes
   the transition, content still shows. The hidden/animated state only applies
   while <html class="anim"> is set and the element hasn't entered yet. */
.reveal{opacity:1;transform:none}
html.anim .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1)}
html.anim .reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  html.anim .reveal{opacity:1;transform:none;transition:none}
  .marquee__track,.sunburst::before,.grid-floor::before,.starfield::before,.starfield::after{animation:none}
}

/* ------------------------------------------------------------- utils */
.grid{display:grid;gap:clamp(20px,3vw,36px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.flex{display:flex}.center{align-items:center}.between{justify-content:space-between}
.wrap-gap{flex-wrap:wrap;gap:14px}
.tac{text-align:center}.mxa{margin-inline:auto}
.mt-s{margin-top:14px}.mt-m{margin-top:24px}.mt-l{margin-top:40px}
@media (max-width:880px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:1fr}}
@media (max-width:680px){.g-2,.g-4{grid-template-columns:1fr}.hide-sm{display:none}}

/* ------------------------------------------------------------- cookie consent */
.cookie-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:400;
  padding:14px clamp(16px,4vw,30px) max(14px,env(safe-area-inset-bottom));
  background:rgba(9,3,24,.93);backdrop-filter:blur(12px);
  border-top:1.5px solid rgba(31,229,255,.45);
  box-shadow:0 -1px 0 rgba(255,45,139,.32),0 -12px 40px rgba(0,0,0,.5);
  transform:translateY(120%);transition:transform .42s cubic-bezier(.2,.8,.2,1)}
.cookie-bar.is-in{transform:none}
.cookie-bar__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;
  gap:clamp(14px,3vw,32px);flex-wrap:wrap;justify-content:space-between}
.cookie-bar__txt{flex:1 1 320px;margin:0;font-size:.92rem;line-height:1.5;color:var(--txt-dim)}
.cookie-bar__txt b{color:var(--cyan);font-weight:700;text-shadow:var(--glow-cyan)}
.cookie-bar__btns{display:flex;gap:10px;flex-shrink:0}
.cookie-bar .btn{padding:.7em 1.5em;font-size:.82rem}
@media (max-width:560px){
  .cookie-bar__btns{width:100%}
  .cookie-bar__btns .btn{flex:1;justify-content:center}
}
.cookie-reopen{background:none;border:0;cursor:pointer;padding:0;
  font-family:var(--f-poster);font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  font-size:.8rem;color:rgba(243,236,255,.55)}
.cookie-reopen:hover{color:var(--cyan);text-shadow:var(--glow-cyan)}
