/* ============================================================
   ARCADIO — arcade 8-bit retro theme
   Palette
   bg        #0a0a0f   near-black
   ink       #f4f4f0   off-white
   neon-red  #ff2e4d   primary accent (the cabinet red)
   amber     #ffc400   secondary accent (the cabinet yellow)
   cyan      #2effd5   tertiary glow
   grid      #1b1b2a   faint grid lines
   ============================================================ */
:root{
  --bg:#0a0a0f;
  --bg2:#101019;
  --ink:#f4f4f0;
  --muted:#8a8aa0;
  --red:#ff2e4d;
  --amber:#ffc400;
  --cyan:#2effd5;
  --grid:#1b1b2a;
  --pixel: 'Press Start 2P', monospace;
  --mono: 'VT323', monospace;
  --sans: 'Space Grotesk', system-ui, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ============================================================
   GLOBAL ANIMATED 8-BIT BACKGROUND
   A fixed layer behind everything: a slow scrolling pixel grid,
   a drifting star/pixel field, and faint floating space invaders.
   ============================================================ */
.bg8{position:fixed;inset:0;z-index:-2;pointer-events:none;overflow:hidden;background:var(--bg)}
/* layer 1: pixel grid that scrolls upward (parallax floor everywhere) */
.bg8::before{
  content:"";position:absolute;inset:-50% -10% -10% -10%;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:44px 44px;
  opacity:.35;
  animation:bgScroll 8s linear infinite;
}
/* layer 2: twinkling pixel stars (two tones) */
.bg8::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(2px 2px at 20px 30px, rgba(255,196,0,.5) 50%, transparent 51%),
    radial-gradient(2px 2px at 120px 90px, rgba(46,255,213,.45) 50%, transparent 51%),
    radial-gradient(2px 2px at 200px 160px, rgba(255,46,77,.45) 50%, transparent 51%),
    radial-gradient(2px 2px at 300px 60px, rgba(244,244,240,.4) 50%, transparent 51%),
    radial-gradient(2px 2px at 380px 220px, rgba(255,196,0,.4) 50%, transparent 51%),
    radial-gradient(2px 2px at 90px 260px, rgba(46,255,213,.4) 50%, transparent 51%);
  background-size:420px 320px;
  animation:bgStars 6s steps(8) infinite, bgDrift 40s linear infinite;
  opacity:.7;
}
@keyframes bgScroll{to{background-position:0 44px}}
@keyframes bgStars{0%,100%{opacity:.7}50%{opacity:.3}}
@keyframes bgDrift{to{background-position:-420px 320px}}

/* floating pixel invaders drifting across the whole page */
.bg8-invaders{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.bg8-invaders span{
  position:absolute;font-family:var(--pixel);font-size:18px;opacity:.10;
  animation:floatUp linear infinite;
  will-change:transform;
}
@keyframes floatUp{
  0%{transform:translateY(110vh) translateX(0)}
  100%{transform:translateY(-15vh) translateX(40px)}
}

/* ---- CRT + scanline overlays ---- */
.crt-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:9998;
  background:radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.55) 100%);
  mix-blend-mode:multiply;
}
.scanlines{
  position:fixed;inset:0;pointer-events:none;z-index:9999;
  background:repeating-linear-gradient(to bottom, rgba(0,0,0,.18) 0 1px, transparent 1px 3px);
  opacity:.5;
}
@media (prefers-reduced-motion:no-preference){
  .scanlines{animation:flick 6s steps(60) infinite}
}
@keyframes flick{0%,97%{opacity:.5}98%{opacity:.35}99%{opacity:.6}100%{opacity:.5}}

/* ============ NAV ============ */
.nav{
  position:sticky;top:0;z-index:1000;
  background:rgba(10,10,15,.85);
  backdrop-filter:blur(8px);
  border-bottom:2px solid var(--grid);
}
.nav-inner{
  max-width:1200px;margin:0 auto;padding:.7rem 1.2rem;
  display:flex;align-items:center;gap:1.2rem;
}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--pixel);font-size:.85rem;letter-spacing:1px}
.brand-coin{color:var(--amber);animation:spin 3s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotateY(360deg)}}
.brand-name{color:var(--ink);text-shadow:2px 2px 0 var(--red)}
.nav-links{display:flex;gap:1.4rem;margin-left:auto;font-family:var(--mono);font-size:1.25rem}
.nav-links a{color:var(--muted);transition:color .15s, text-shadow .15s}
.nav-links a:hover{color:var(--cyan);text-shadow:0 0 8px var(--cyan)}
.nav-actions{display:flex;gap:.5rem}
.pill{
  display:flex;align-items:center;gap:.4rem;
  border:2px solid var(--grid);background:#15151f;
  padding:.4rem .6rem;border-radius:0;cursor:pointer;
  font-family:var(--pixel);font-size:.55rem;color:var(--ink);
  transition:transform .1s, border-color .15s;
}
.pill:active{transform:translate(1px,1px)}
.pill-label{color:var(--muted)}
.pill-ca{border-color:var(--cyan)}
.pill-ca .pill-value{color:var(--cyan)}
.pill-ca.copied{border-color:var(--amber)}
.pill-buy{border-color:var(--red);background:var(--red);color:#fff}
.pill-buy .pill-label{color:rgba(255,255,255,.7)}
.pill-buy[aria-disabled="true"]{opacity:.85;cursor:not-allowed}
.nav-burger{display:none;background:none;border:none;color:var(--ink);font-size:1.4rem;cursor:pointer}
.nav-mobile{display:none;flex-direction:column;gap:.2rem;padding:0 1.2rem 1rem;font-family:var(--mono);font-size:1.4rem}
.nav-mobile a{padding:.4rem 0;border-bottom:1px solid var(--grid);color:var(--muted)}
.nav-mobile.open{display:flex}

/* ============ SCOREBOARD ============ */
.scoreboard{
  display:flex;justify-content:space-between;align-items:flex-start;
  max-width:1100px;margin:0 auto;padding:1.4rem 1.2rem .4rem;
  font-family:var(--pixel);
}
.score-col{display:flex;flex-direction:column;gap:.4rem;font-size:.7rem}
.score-center{align-items:center}
.score-right{align-items:flex-end}
.score-tag{color:var(--ink)}
.score-num{color:var(--red);font-size:.75rem}
.score-num.hi{color:var(--amber)}

/* ============ HERO ============ */
.hero{position:relative;min-height:92vh;display:flex;flex-direction:column;overflow:hidden;padding-bottom:2rem}
.hero-grid{
  position:absolute;left:-20%;right:-20%;bottom:0;height:55%;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:48px 48px;
  transform:perspective(420px) rotateX(62deg);
  transform-origin:bottom center;
  opacity:.6;
  z-index:0;
}
@media (prefers-reduced-motion:no-preference){
  .hero-grid{animation:scrollgrid 4s linear infinite}
}
@keyframes scrollgrid{to{background-position:0 48px}}
.hero-inner{
  position:relative;z-index:2;text-align:center;
  max-width:880px;margin:auto;padding:1rem 1.2rem;
}
.hero-eyebrow{font-family:var(--mono);font-size:1.35rem;color:var(--cyan);letter-spacing:1px;margin-bottom:.4rem}
.hero-title{
  font-family:var(--pixel);
  font-size:clamp(2.6rem,9vw,6rem);
  line-height:1;color:var(--red);
  letter-spacing:2px;
  text-shadow:
    4px 4px 0 #7a0016,
    8px 8px 0 var(--amber);
  position:relative;margin:.4rem 0 1.2rem;
}
.hero-sub{
  font-size:clamp(1rem,2.2vw,1.35rem);
  color:var(--ink);max-width:620px;margin:0 auto 2rem;
}
.hero-sub strong{color:var(--amber)}
.hero-menu{display:flex;flex-direction:column;align-items:center;gap:.7rem;margin-bottom:1.8rem;font-family:var(--pixel)}
.menu-item{font-size:1rem;color:var(--muted);transition:color .15s, transform .15s}
.menu-item:hover{color:var(--ink);transform:translateX(4px)}
.menu-start{color:var(--ink)}
.menu-start .cursor{color:var(--red)}
.cursor{animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.hero-meta{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.meta-chip{
  font-family:var(--mono);font-size:1.2rem;
  border:1px solid var(--grid);padding:.25rem .7rem;color:var(--muted);
}
.meta-chip.live{color:var(--ink);border-color:var(--red)}
.meta-chip .dot{display:inline-block;width:8px;height:8px;background:var(--red);border-radius:50%;margin-right:.3rem;animation:pulse 1.2s infinite}
@keyframes pulse{50%{opacity:.3}}

/* countdown */
.countdown{position:relative;z-index:2;display:flex;justify-content:center;align-items:center;gap:.6rem;margin:1.4rem auto 0}
.cd-block{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:#13131d;border:2px solid var(--grid);padding:.6rem .8rem;min-width:64px}
.cd-num{font-family:var(--pixel);font-size:1.3rem;color:var(--amber)}
.cd-lbl{font-family:var(--mono);font-size:.95rem;color:var(--muted);letter-spacing:1px}
.cd-sep{font-family:var(--pixel);color:var(--red);font-size:1.2rem}
.credit{text-align:center;font-family:var(--mono);font-size:1.05rem;color:var(--muted);margin-top:1.6rem}

/* ============ SECTION SHELL ============ */
.section{max-width:1100px;margin:0 auto;padding:5rem 1.2rem}
.sec-head{text-align:center;max-width:680px;margin:0 auto 3rem}
.sec-tag{display:inline-block;font-family:var(--pixel);font-size:.6rem;color:var(--bg);background:var(--amber);padding:.4rem .6rem;margin-bottom:1rem}
.sec-head h2{font-family:var(--pixel);font-size:clamp(1.2rem,3.5vw,1.9rem);color:var(--ink);line-height:1.4;margin-bottom:1rem;text-shadow:3px 3px 0 var(--red)}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* ============ HOW ============ */
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.2rem}
.how-card{
  border:2px solid var(--grid);background:linear-gradient(180deg,rgba(19,19,29,.82),rgba(13,13,20,.82));
  padding:1.6rem 1.3rem;position:relative;transition:transform .15s, border-color .15s;
}
.how-card:hover{transform:translateY(-4px);border-color:var(--cyan)}
.how-icon{font-size:2rem;margin-bottom:.8rem}
.how-card h3{font-family:var(--pixel);font-size:.85rem;color:var(--amber);margin-bottom:.7rem}
.how-card p{color:var(--muted);font-size:.98rem}

/* ============ PLAYGROUND ============ */
.section-pg{padding-top:3rem}
.cabinet{max-width:760px;margin:0 auto;border:4px solid var(--red);background:#1a0c10;padding:.6rem;box-shadow:0 0 0 4px var(--bg),0 0 30px rgba(255,46,77,.25)}
.cabinet-top{display:flex;align-items:center;justify-content:center;gap:.8rem;padding:.5rem;font-family:var(--pixel);font-size:.55rem;color:var(--amber)}
.cab-light{width:10px;height:10px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);animation:pulse 1.4s infinite}
.screen{background:#05050a;border:3px solid #2a2a3a;padding:1.4rem;min-height:300px;position:relative}
.screen::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(transparent 0 2px,rgba(46,255,213,.025) 2px 4px);pointer-events:none}
.screen-prompt label{display:block;font-family:var(--pixel);font-size:.6rem;color:var(--cyan);margin-bottom:.6rem}
.screen-input-wrap{display:flex;gap:.5rem;flex-wrap:wrap}
#tokenInput{
  flex:1;min-width:180px;background:#0d0d14;border:2px solid #2a2a3a;color:var(--ink);
  font-family:var(--mono);font-size:1.3rem;padding:.6rem .8rem;
}
#tokenInput:focus{outline:none;border-color:var(--cyan)}
.screen-go{
  background:var(--red);color:#fff;border:none;font-family:var(--pixel);font-size:.6rem;
  padding:0 1rem;cursor:pointer;transition:transform .1s, background .15s;
}
.screen-go:hover{background:#ff5570}
.screen-go:active{transform:translate(1px,1px)}
.screen-go:disabled{opacity:.5;cursor:wait}
.presets{display:flex;flex-wrap:wrap;gap:.4rem;margin:.9rem 0}
.preset{background:#13131d;border:1px solid #2a2a3a;color:var(--muted);font-family:var(--mono);font-size:1.15rem;padding:.25rem .7rem;cursor:pointer;transition:.15s}
.preset:hover{color:var(--cyan);border-color:var(--cyan)}
.screen-output{margin-top:1rem;font-family:var(--mono);font-size:1.3rem;color:var(--ink);min-height:120px;line-height:1.5}
.output-idle{color:var(--muted)}
.output-quest{border-left:3px solid var(--amber);padding-left:1rem;margin-top:.6rem}
.output-quest .q-tier{color:var(--cyan);font-family:var(--pixel);font-size:.55rem;display:block;margin-bottom:.5rem}
.output-quest .q-line{display:block;margin-bottom:.35rem}
.output-quest .q-line b{color:var(--amber)}
.typing::after{content:"▋";color:var(--cyan);animation:blink 1s steps(2) infinite}
.cabinet-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem .8rem .4rem}
.dpad{display:grid;grid-template-columns:repeat(2,18px);grid-template-rows:repeat(2,18px);gap:3px}
.dpad span{background:var(--red);width:18px;height:18px}
.abtn{display:flex;gap:.6rem}
.ab{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--pixel);font-size:.7rem;color:#fff;background:var(--red);border:2px solid #7a0016}
.pg-note{text-align:center;font-family:var(--mono);font-size:1.05rem;color:var(--muted);margin-top:1.4rem;max-width:560px;margin-left:auto;margin-right:auto}

/* ============ SKILL TREE ============ */
.tree{position:relative;max-width:800px;margin:0 auto;height:420px}
.tree-lines{position:absolute;inset:0;width:100%;height:100%}
.tree-lines line{stroke:var(--grid);stroke-width:2}
.node{
  position:absolute;transform:translate(-50%,-50%);
  width:88px;height:88px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;
  background:#13131d;border:3px solid var(--cyan);cursor:pointer;z-index:2;transition:transform .15s, box-shadow .15s;
}
.node:hover{transform:translate(-50%,-50%) scale(1.08);box-shadow:0 0 16px rgba(46,255,213,.5)}
.node-root{border-color:var(--amber);box-shadow:0 0 16px rgba(255,196,0,.4)}
.node-locked{border-color:var(--grid);opacity:.6}
.node-ic{font-size:1.4rem}
.node-name{font-family:var(--pixel);font-size:.5rem;color:var(--ink)}
.node-tip{
  position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  width:170px;background:#05050a;border:1px solid var(--cyan);padding:.5rem .6rem;
  font-family:var(--mono);font-size:1.05rem;color:var(--ink);
  opacity:0;pointer-events:none;transition:opacity .15s;z-index:5;
}
.node:hover .node-tip{opacity:1}

/* ============ ARCADE: SIGNAL RACE ============ */
.section-arcade{padding-top:3rem}
.arcade-cabinet{max-width:760px;margin:0 auto;border:4px solid var(--amber);background:#1a1505;padding:.6rem;box-shadow:0 0 0 4px var(--bg),0 0 30px rgba(255,196,0,.22)}
.arcade-cabinet .cabinet-top{color:var(--cyan)}
.arcade-cabinet .cab-light{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.race-screen{position:relative;background:#05050a;border:3px solid #2a2a3a;padding:1.2rem;min-height:420px;overflow:hidden}
.race-screen::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(transparent 0 2px,rgba(46,255,213,.025) 2px 4px);pointer-events:none;z-index:1}
.race-hud{display:flex;justify-content:space-between;font-family:var(--pixel);font-size:.6rem;color:var(--ink);margin-bottom:1rem;position:relative;z-index:2}
#hudScore{color:var(--amber)}
#hudStreak{color:var(--cyan)}
#hudTime{color:var(--red)}

/* track */
.track{position:relative;height:170px;background:linear-gradient(180deg,#0a0a14,#0d0d18);border:2px solid #1b1b2a;border-radius:0;overflow:hidden;margin-bottom:1rem;z-index:2}
.track::before{content:"";position:absolute;top:50%;left:0;right:0;height:0;border-top:3px dashed #2a2a3a;transform:translateY(-50%)}
@media (prefers-reduced-motion:no-preference){
  .track::before{animation:dash 0.6s linear infinite}
}
@keyframes dash{to{background-position:40px 0}}
.finish-line{position:absolute;right:2%;top:0;bottom:0;width:14px;background:repeating-linear-gradient(45deg,#fff 0 6px,#000 6px 12px);writing-mode:vertical-rl;text-align:center;font-family:var(--pixel);font-size:.45rem;color:transparent;opacity:.85}
.racer{position:absolute;display:flex;flex-direction:column;align-items:center;gap:.2rem;transition:left .35s cubic-bezier(.3,.8,.4,1);z-index:3}
.racer-emoji{font-size:1.8rem;line-height:1}
.racer-tag{font-family:var(--pixel);font-size:.4rem;color:var(--ink)}
.racer-you{top:18%}
.racer-you .racer-tag{color:var(--amber)}
.racer-market{top:60%;filter:grayscale(.3)}
.racer-market .racer-tag{color:var(--red)}
.racer.boost .racer-emoji{animation:boostshake .3s}
@keyframes boostshake{25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}

/* signal box */
.signal-box{text-align:center;padding:.8rem;border:2px solid #2a2a3a;background:#0a0a14;margin-bottom:1rem;position:relative;z-index:2;min-height:78px;display:flex;flex-direction:column;justify-content:center}
.signal-call{font-family:var(--pixel);font-size:1.4rem;color:var(--cyan);letter-spacing:2px;transition:color .1s}
.signal-call.go{animation:flashcall .4s}
.signal-call.buy{color:var(--cyan)}
.signal-call.sell{color:var(--red)}
.signal-call.hold{color:var(--amber)}
@keyframes flashcall{0%{transform:scale(1.3);filter:brightness(2)}100%{transform:scale(1)}}
.signal-hint{font-family:var(--mono);font-size:1.1rem;color:var(--muted);margin-top:.4rem}

/* controls */
.race-controls{display:flex;gap:.6rem;justify-content:center;position:relative;z-index:2}
.race-btn{flex:1;max-width:160px;font-family:var(--pixel);font-size:.75rem;padding:.9rem .5rem;border:3px solid;background:#13131d;color:#fff;cursor:pointer;transition:transform .08s, box-shadow .12s;border-radius:0}
.race-btn:active{transform:translateY(2px)}
.rb-buy{border-color:var(--cyan);color:var(--cyan)}
.rb-buy:hover{box-shadow:0 0 14px rgba(46,255,213,.4)}
.rb-hold{border-color:var(--amber);color:var(--amber)}
.rb-hold:hover{box-shadow:0 0 14px rgba(255,196,0,.4)}
.rb-sell{border-color:var(--red);color:var(--red)}
.rb-sell:hover{box-shadow:0 0 14px rgba(255,46,77,.4)}
.race-btn.hit{background:#fff;color:var(--bg)!important}
.race-btn.wrong{background:var(--red);color:#fff!important}

/* overlay */
.race-overlay{position:absolute;inset:0;background:rgba(5,5,10,.94);display:flex;align-items:center;justify-content:center;z-index:10;text-align:center;padding:2rem}
.race-overlay.hidden{display:none}
.overlay-inner{max-width:440px}
.overlay-inner h3{font-family:var(--pixel);font-size:1.3rem;color:var(--red);text-shadow:3px 3px 0 var(--amber);margin-bottom:1rem;line-height:1.4}
.overlay-inner p{font-family:var(--mono);font-size:1.3rem;color:var(--ink);margin-bottom:1.6rem}
.overlay-inner .screen-go{padding:.9rem 1.4rem;font-size:.7rem}
.race-keys{text-align:center;font-family:var(--mono);font-size:1.05rem;color:var(--muted);margin-top:1.2rem}
.race-keys kbd{background:#13131d;border:1px solid var(--grid);padding:.05rem .4rem;color:var(--cyan);font-family:var(--mono)}


.lbp{max-width:680px;margin:0 auto;border:2px solid var(--grid);background:rgba(13,13,20,.82)}
.lbp-row{display:grid;grid-template-columns:44px 1fr 44px 90px 64px;align-items:center;padding:.7rem 1rem;border-bottom:1px solid var(--grid);font-family:var(--mono);font-size:1.25rem;color:var(--ink)}
.lbp-row:last-child{border-bottom:none}
.lbp-head{font-family:var(--pixel);font-size:.5rem;color:var(--muted);background:#13131d}
.lbp-xp{color:var(--amber);text-align:right}
.lbp-w{color:var(--cyan);text-align:right}
.lbp-r1{color:var(--amber)}

.section-tok{background:transparent;max-width:none}
.section-tok .sec-head,.section-tok .tok-wrap,.section-tok .tok-util{max-width:1100px;margin-left:auto;margin-right:auto}
.tok-wrap{display:grid;grid-template-columns:1fr 1.3fr;gap:2.4rem;align-items:center;padding:0 1.2rem}
.tok-stats{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.tok-stat{border:2px solid var(--grid);background:rgba(19,19,29,.8);padding:.9rem 1rem;display:flex;flex-direction:column;gap:.3rem}
.tok-k{font-family:var(--mono);font-size:1.05rem;color:var(--muted)}
.tok-v{font-family:var(--pixel);font-size:.7rem;color:var(--amber)}
.tok-bars{display:flex;flex-direction:column;gap:1.1rem}
.bar-head{display:flex;justify-content:space-between;font-family:var(--mono);font-size:1.15rem;margin-bottom:.35rem;color:var(--ink)}
.bar{height:20px;background:#13131d;border:1px solid var(--grid);overflow:hidden}
.bar-fill{height:100%;width:var(--w);background:var(--red);box-shadow:inset 0 0 8px rgba(255,255,255,.2);animation:grow 1s ease both}
.bar-fill.alt1{background:var(--amber)}
.bar-fill.alt2{background:var(--cyan)}
.bar-fill.alt3{background:#7a7aff}
@keyframes grow{from{width:0}}
.tok-util{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:2.4rem 1.2rem 0}
.util{border-left:3px solid var(--red);padding:.4rem 0 .4rem 1rem}
.util h4{font-family:var(--pixel);font-size:.75rem;color:var(--cyan);margin-bottom:.5rem}
.util p{color:var(--muted);font-size:.98rem}

/* ============ WAITLIST ============ */
.section-wl{padding-top:2rem}
.wl-card{max-width:620px;margin:0 auto;text-align:center;border:3px solid var(--amber);background:linear-gradient(180deg,#1a1505,#0d0d14);padding:2.6rem 1.6rem}
.wl-card h2{font-family:var(--pixel);font-size:clamp(1.1rem,3vw,1.5rem);margin:.8rem 0;color:var(--ink)}
.wl-card>p{color:var(--muted);margin-bottom:1.6rem}
.wl-form{display:flex;gap:.5rem;max-width:420px;margin:0 auto;flex-wrap:wrap}
#wlEmail{flex:1;min-width:180px;background:#0d0d14;border:2px solid var(--grid);color:var(--ink);font-family:var(--mono);font-size:1.3rem;padding:.7rem .9rem}
#wlEmail:focus{outline:none;border-color:var(--amber)}
.wl-go{background:var(--amber);color:var(--bg);border:none;font-family:var(--pixel);font-size:.65rem;padding:0 1.2rem;cursor:pointer;transition:transform .1s}
.wl-go:active{transform:translate(1px,1px)}
.wl-msg{font-family:var(--mono);font-size:1.2rem;margin-top:1rem;min-height:1.4rem}
.wl-msg.ok{color:var(--cyan)}
.wl-msg.err{color:var(--red)}
.wl-socials{display:flex;gap:1.4rem;justify-content:center;margin-top:1.6rem;font-family:var(--mono);font-size:1.2rem}
.wl-socials a{color:var(--muted);transition:color .15s}
.wl-socials a:hover{color:var(--amber)}

/* ============ FOOTER ============ */
.footer{position:relative;border-top:2px solid var(--grid);padding:3rem 0 2rem;overflow:hidden;text-align:center}
.footer-score{padding-top:0}
.gameover{font-family:var(--pixel);font-size:clamp(1.1rem,3.5vw,1.9rem);color:var(--red);text-shadow:3px 3px 0 var(--amber);margin:2rem 0 1.4rem;position:relative;z-index:2}
.footer-menu{display:flex;flex-direction:column;align-items:center;gap:.6rem;font-family:var(--pixel);font-size:.85rem;position:relative;z-index:2}
.footer-menu a{color:var(--muted);transition:color .15s}
.footer-menu a:hover{color:var(--ink)}
.footer-menu .cursor{color:var(--red)}
.footer-credit{font-family:var(--mono);font-size:1.1rem;color:var(--muted);max-width:560px;margin:2rem auto 0;position:relative;z-index:2;padding:0 1rem}
.footer-grid{
  position:absolute;left:-20%;right:-20%;bottom:0;height:60%;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:48px 48px;transform:perspective(420px) rotateX(62deg);transform-origin:bottom center;opacity:.4;z-index:0;
}

/* ============ RESPONSIVE ============ */
@media (max-width:820px){
  .tok-wrap{grid-template-columns:1fr}
  .tok-util{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-burger{display:block;margin-left:auto}
  .nav-actions{order:2}
}
@media (max-width:560px){
  .tree{height:360px}
  .node{width:70px;height:70px}
  .node-ic{font-size:1.1rem}
  .scoreboard{padding:1rem .8rem .4rem}
  .score-col{font-size:.55rem}
  .hero-title{text-shadow:3px 3px 0 #7a0016,6px 6px 0 var(--amber)}
  .cd-block{min-width:52px;padding:.5rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
}
:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

/* ============================================================
   PIXEL DECORATIONS
   ============================================================ */
/* sections get a relative context + a little more breathing room
   so floating sprites can sit at the edges */
.section{position:relative}

/* floating pixel sprite (emoji-based, cheap) that bobs */
.deco{position:absolute;font-size:1.6rem;opacity:.22;pointer-events:none;z-index:0;animation:bob 4s ease-in-out infinite}
.deco.d2{animation-duration:5.5s;animation-delay:-1s}
.deco.d3{animation-duration:6.5s;animation-delay:-2.5s}
@keyframes bob{50%{transform:translateY(-12px)}}

/* spinning pixel coin used as a section accent / bullet */
.pcoin{display:inline-block;width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--amber) 0 45%, var(--red) 46% 100%);
  box-shadow:0 0 6px rgba(255,196,0,.5);animation:spin 3s linear infinite;vertical-align:middle}

/* animated "press start" blinking dot row under section tags */
.sec-head .sec-tag{position:relative}

/* dashed pixel divider between major sections */
.pixel-divider{max-width:1100px;margin:0 auto;height:0;border-top:3px dashed var(--grid);
  position:relative;opacity:.7}
.pixel-divider::before,.pixel-divider::after{content:"◆";position:absolute;top:-12px;
  font-size:.8rem;color:var(--red)}
.pixel-divider::before{left:0}
.pixel-divider::after{right:0;color:var(--cyan)}

/* corner brackets that frame key cards (arcade UI feel) */
.bracketed{position:relative}
.bracketed::before,.bracketed::after{content:"";position:absolute;width:16px;height:16px;pointer-events:none}
.bracketed::before{top:-3px;left:-3px;border-top:3px solid var(--amber);border-left:3px solid var(--amber)}
.bracketed::after{bottom:-3px;right:-3px;border-bottom:3px solid var(--amber);border-right:3px solid var(--amber)}

/* marquee strip of pixel icons that scrolls horizontally */
.pixel-strip{overflow:hidden;border-top:2px solid var(--grid);border-bottom:2px solid var(--grid);
  background:rgba(13,13,20,.6);padding:.6rem 0;margin:0}
.pixel-strip-track{display:flex;gap:2.6rem;width:max-content;
  font-family:var(--pixel);font-size:.7rem;color:var(--muted);
  animation:marquee 22s linear infinite;white-space:nowrap;align-items:center}
.pixel-strip-track span{display:inline-flex;align-items:center;gap:.5rem}
.pixel-strip-track .em{font-size:1.1rem;opacity:.9}
@keyframes marquee{to{transform:translateX(-50%)}}

/* keep section content above the floating deco */
.sec-head,.how-grid,.cabinet,.tree,.tok-wrap,.tok-util,.lbp,.wl-card,.arcade-cabinet{position:relative;z-index:1}

@media (prefers-reduced-motion:reduce){
  .bg8::before,.bg8::after,.bg8-invaders span,.deco,.pcoin,.pixel-strip-track{animation:none!important}
}
@media (max-width:560px){
  .deco{font-size:1.1rem;opacity:.16}
}
