/* ============================================================
   ANSEM LEAGUE — retro arcade cabinet styling
   ============================================================ */
:root{
  --neon:#39ff14;
  --neon2:#00e5ff;
  --hot:#ff2e63;
  --gold:#ffd23f;
  --sol:#14f195;
  --sol2:#9945ff;
  --ink:#05060a;
  --panel:#11131c;
  --steel:#2a2e3e;
  --scan:rgba(0,0,0,.28);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Press Start 2P',monospace;
  background:
    radial-gradient(1200px 700px at 50% -10%, #1b1140 0%, #0a0a14 55%, #05060a 100%);
  color:#e9eefb;
  min-height:100vh;
  overflow-x:hidden;
}
#game{image-rendering:auto}

/* ===================== SITE NAV ===================== */
#site-nav{
  position:fixed;top:0;left:0;right:0;z-index:120;height:52px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;
  background:rgba(8,9,16,.72);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,229,255,.18);
}
.nav-logo{font-size:13px;color:var(--gold);text-shadow:0 0 8px #ff8a00;letter-spacing:1px;cursor:pointer}
.nav-logo span{color:var(--neon2);text-shadow:0 0 8px var(--neon2)}
.nav-links{display:flex;gap:16px;align-items:center}
.nav-links a{font-size:8px;color:#9fb0d6;text-decoration:none;letter-spacing:1px}
.nav-links a:hover{color:#fff;text-shadow:0 0 8px var(--neon2)}
.nav-cta{font-family:inherit;font-size:9px;cursor:pointer;border:0;color:#fff;
  background:linear-gradient(180deg,var(--sol),#0c9d63);padding:9px 14px;border-radius:7px;
  box-shadow:0 3px 0 #06593a,0 0 14px rgba(20,241,149,.4);text-shadow:1px 1px 0 #000}
.nav-cta:active{transform:translateY(2px);box-shadow:0 1px 0 #06593a}
@media (max-width:720px){ .nav-links a{display:none} }

/* ===================== HERO ===================== */
#hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:64px 12px 14px;gap:10px}
.hero-tag{max-width:860px;text-align:center}
.hero-tag h2{font-size:clamp(13px,2.4vw,20px);line-height:1.5;color:#fff;text-shadow:0 0 10px var(--neon2)}
.hero-tag h2 b{color:var(--sol);text-shadow:0 0 10px var(--sol)}
.hero-tag p{font-size:9px;color:#9fb0d6;margin-top:8px;line-height:1.8}
.hero-cta{display:flex;gap:10px;justify-content:center;margin-top:12px;flex-wrap:wrap}
.scroll-hint{font-size:8px;color:#5a6b8c;margin-top:6px;animation:bob 1.6s ease-in-out infinite}

/* ===================== SECTIONS ===================== */
.section{max-width:1080px;margin:0 auto;padding:54px 16px;border-top:1px solid rgba(255,255,255,.06)}
.sec-head{text-align:center;margin-bottom:8px}
.sec-kicker{font-size:8px;color:var(--neon2);letter-spacing:3px}
.sec-title{font-size:clamp(15px,3vw,24px);color:var(--gold);text-shadow:0 0 10px #ff8a00;margin-top:8px}
.sec-sub{font-size:9px;color:#9fb0d6;margin-top:10px;line-height:1.9;text-align:center;max-width:680px;margin-left:auto;margin-right:auto}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:26px}
.card{background:linear-gradient(180deg,#11131c,#0a0c14);border:2px solid #1f2433;border-radius:12px;padding:18px;
  box-shadow:inset 0 0 30px rgba(0,229,255,.05)}
.card .num{font-size:18px;color:var(--gold);text-shadow:0 0 8px #ff8a00}
.card .ico{font-size:24px;margin-bottom:8px}
.card h3{font-size:11px;color:#fff;margin:8px 0;line-height:1.5}
.card p{font-size:8.5px;color:#9fb0d6;line-height:1.9}
.card.hot{border-color:var(--sol);box-shadow:0 0 18px rgba(20,241,149,.25)}
.card .pill{display:inline-block;font-size:7px;padding:3px 7px;border-radius:20px;margin-top:8px;letter-spacing:1px}
.pill.live{background:rgba(20,241,149,.16);color:var(--sol);border:1px solid var(--sol)}
.pill.soon{background:rgba(255,210,63,.14);color:var(--gold);border:1px solid var(--gold)}
.prize-tag{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:12px 0 6px;
  background:linear-gradient(180deg,#1a1407,#0d0a04);border:1px solid var(--gold);border-radius:8px;padding:8px 10px;font-size:7px;color:#cdb86a;letter-spacing:1px}
.prize-tag b{font-size:15px;color:var(--gold);text-shadow:0 0 10px #ff8a00}
.rchip{font-size:6px;padding:2px 6px;border-radius:20px;margin-left:8px;vertical-align:middle;letter-spacing:1px}
.rchip.live{background:rgba(20,241,149,.18);color:var(--sol);border:1px solid var(--sol)}
.rchip.next{background:rgba(255,210,63,.16);color:var(--gold);border:1px solid var(--gold)}

/* token */
.token-wrap{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:24px;align-items:center}
@media (max-width:720px){ .token-wrap{grid-template-columns:1fr} }
.token-stats{display:flex;flex-direction:column;gap:8px}
.tk-row{display:flex;justify-content:space-between;font-size:9px;background:#0a0c16;border:1px solid #1f2433;border-radius:8px;padding:11px 12px}
.tk-row span{color:#8aa0c8}.tk-row b{color:var(--sol)}
.ca-box{margin-top:14px;background:#05060c;border:1px dashed var(--sol2);border-radius:8px;padding:12px;text-align:center}
.ca-box .lbl{font-size:7px;color:#8aa0c8;letter-spacing:2px}
.ca-box .ca{font-size:9px;color:var(--gold);margin-top:8px;word-break:break-all}
.ca-copy{margin-top:10px;font-family:inherit;font-size:8px;cursor:pointer;border:0;color:#000;background:var(--gold);padding:8px 12px;border-radius:6px}
.token-coin{font-size:90px;text-align:center;filter:drop-shadow(0 0 24px rgba(20,241,149,.5));animation:bob 2s ease-in-out infinite}

/* roster */
.roster-show{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;margin-top:26px}
.rs-cell{background:#0c0e1a;border:2px solid #1f2433;border-radius:10px;padding:6px;text-align:center;transition:transform .12s,border-color .12s}
.rs-cell:hover{transform:translateY(-4px);border-color:var(--neon2)}
.rs-cell canvas{width:100%;height:auto;image-rendering:auto}
.rs-cell .rn{font-size:7px;color:#cdd8f2;margin-top:4px}
.rs-cell .rt{font-size:6px;margin-top:2px;color:#9fb0d6}

/* roadmap */
.road{display:flex;flex-direction:column;gap:12px;margin-top:24px;max-width:760px;margin-left:auto;margin-right:auto}
.road-item{display:flex;gap:14px;align-items:flex-start;background:#0a0c14;border:2px solid #1f2433;border-radius:10px;padding:14px}
.road-item .ph{font-size:9px;color:var(--gold);min-width:74px}
.road-item.done{border-color:var(--sol)}
.road-item .rt2{font-size:9px;color:#fff;line-height:1.6}
.road-item .rd{font-size:8px;color:#9fb0d6;line-height:1.8;margin-top:4px}

/* faq */
.faq{max-width:760px;margin:24px auto 0}
.faq details{background:#0a0c14;border:2px solid #1f2433;border-radius:10px;padding:12px 14px;margin-bottom:10px}
.faq summary{font-size:9px;color:#fff;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+ ";color:var(--sol)}
.faq details[open] summary::before{content:"– "}
.faq p{font-size:8.5px;color:#9fb0d6;line-height:1.9;margin-top:10px}

/* footer */
#site-foot{border-top:1px solid rgba(255,255,255,.08);padding:30px 16px;text-align:center;margin-top:20px}
.foot-logo{font-size:14px;color:var(--gold);text-shadow:0 0 8px #ff8a00}
.foot-logo span{color:var(--neon2)}
.foot-soc{display:flex;gap:14px;justify-content:center;margin:14px 0;flex-wrap:wrap}
.foot-soc a{font-size:9px;color:#9fb0d6;text-decoration:none;border:1px solid #1f2433;border-radius:7px;padding:8px 12px}
.foot-soc a:hover{color:#fff;border-color:var(--neon2)}
.foot-dis{font-size:7px;color:#5a6b8c;line-height:1.9;max-width:680px;margin:0 auto}

/* ===================== CABINET ===================== */
#cabinet{
  width:min(1560px,97vw);
  background:linear-gradient(180deg,#171a26,#0d0f18);
  border:3px solid #000;
  border-radius:26px 26px 14px 14px;
  box-shadow:
    0 0 0 6px #1d2130,
    0 0 0 9px #000,
    0 30px 80px rgba(0,0,0,.7),
    inset 0 2px 0 rgba(255,255,255,.06);
  padding:16px 16px 22px;
  position:relative;
}
/* side art glow strips */
#cabinet::before,#cabinet::after{
  content:"";position:absolute;top:60px;bottom:60px;width:8px;border-radius:6px;
  background:linear-gradient(180deg,var(--hot),var(--sol2),var(--neon2));
  filter:blur(1px);opacity:.55;
}
#cabinet::before{left:-2px}
#cabinet::after{right:-2px}

/* ===================== MARQUEE ===================== */
#marquee{
  position:relative;text-align:center;padding:8px 8px 9px;margin-bottom:8px;
  background:linear-gradient(180deg,#241552,#120a2e);
  border:3px solid #000;border-radius:14px;
  box-shadow:inset 0 0 40px rgba(153,69,255,.4);
  overflow:hidden;
}
.marquee-glow{
  position:absolute;inset:0;
  background:radial-gradient(120% 140% at 50% 0%, rgba(0,229,255,.25), transparent 60%);
  pointer-events:none;
}
.marquee-title{
  font-size:clamp(20px,5.4vw,40px);line-height:1;letter-spacing:1px;
  display:flex;gap:.4ch;justify-content:center;align-items:baseline;
}
.ml-a{color:var(--gold);text-shadow:0 0 8px #ff8a00,3px 3px 0 #7a1f00}
.ml-b{color:var(--neon2);text-shadow:0 0 10px var(--neon2),3px 3px 0 #003}
.marquee-sub{margin-top:10px;font-size:9px;color:var(--hot);letter-spacing:2px;text-shadow:0 0 6px var(--hot)}

/* ===================== BEZEL / SCREEN ===================== */
#bezel{
  position:relative;
  background:
    radial-gradient(circle at 15px 15px, #4a5163 0 2.6px, #0e1016 2.6px 4px, transparent 4.6px),
    radial-gradient(circle at calc(100% - 15px) 15px, #4a5163 0 2.6px, #0e1016 2.6px 4px, transparent 4.6px),
    radial-gradient(circle at 15px calc(100% - 15px), #4a5163 0 2.6px, #0e1016 2.6px 4px, transparent 4.6px),
    radial-gradient(circle at calc(100% - 15px) calc(100% - 15px), #4a5163 0 2.6px, #0e1016 2.6px 4px, transparent 4.6px),
    linear-gradient(180deg,#262a35,#0b0c11);
  border:3px solid #000;border-radius:22px;
  padding:18px;
  box-shadow:
    inset 0 2px 1px rgba(255,255,255,.10),
    inset 0 -4px 10px rgba(0,0,0,.85),
    0 14px 30px rgba(0,0,0,.6);
}
/* inner black mask ring (tube housing) */
#bezel::before{ content:"";position:absolute;inset:13px;border-radius:18px;pointer-events:none;z-index:1;
  box-shadow:inset 0 0 0 3px #000, inset 0 0 0 5px rgba(255,255,255,.05), inset 0 0 26px rgba(0,0,0,.9); }
#screen{
  position:relative;aspect-ratio:16/9;border-radius:26px/17px;overflow:hidden;z-index:2;
  height:min(calc(100vh - 250px), calc((min(1560px,97vw) - 80px) * 0.5625));
  width:auto;max-width:100%;margin:0 auto;
  background:#04060c;
  box-shadow:inset 0 0 70px rgba(0,0,0,.9), inset 0 0 150px rgba(0,0,0,.85), 0 0 0 2px #000;
}
#game{position:absolute;inset:0;width:100%;height:100%;display:block;background:#04060c}
/* curved glass reflection / glare */
#screen::after{content:"";position:absolute;inset:0;z-index:44;pointer-events:none;border-radius:inherit;
  background:
    radial-gradient(130% 70% at 50% -18%, rgba(255,255,255,.14), rgba(255,255,255,0) 42%),
    linear-gradient(122deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 20%, rgba(255,255,255,0) 64%, rgba(255,255,255,.05) 100%);
  mix-blend-mode:screen;}

/* ===================== PHOTOREAL CABINET (AI image frame) ===================== */
#cabinet.real-cab{
  width:auto; max-width:96vw;
  aspect-ratio:900/870;
  height:min(calc(100vh - 150px), calc(96vw*0.9667));
  margin:0 auto; position:relative;
  background:url(../assets/cabinet.jpg) top center / 100% auto no-repeat;
  border:0; border-radius:0; box-shadow:none; padding:0;
}
#cabinet.real-cab::before, #cabinet.real-cab::after{ display:none; }
.real-cab #marquee, .real-cab #control-deck, .real-cab #cab-foot{ display:none; }
.real-cab #bezel{ position:static; background:none; border:0; box-shadow:none; padding:0; }
.real-cab #bezel::before{ display:none; }
.real-cab #screen{
  position:absolute; left:23.3%; top:41%; width:53.4%;
  height:auto; aspect-ratio:16/9; max-width:none; margin:0;
  border-radius:6px; box-shadow:inset 0 0 50px rgba(0,0,0,.9);
}
.real-cab #screen::after{ border-radius:6px; }
.cab-brand{
  position:absolute; top:7.5%; left:0; right:0; z-index:6; text-align:center; pointer-events:none;
  font-size:clamp(13px,2vw,26px); letter-spacing:1px;
  color:var(--gold); text-shadow:0 0 12px #ff8a00,0 0 22px rgba(255,138,0,.6),2px 2px 0 #5a1500;
}
.cab-brand span{ color:var(--neon2); text-shadow:0 0 12px var(--neon2),0 0 22px rgba(0,229,255,.6); }
@media (max-width:760px){
  #cabinet.real-cab{ height:min(calc(100vh - 120px), calc(96vw*0.9667)); }
}

/* CRT effects */
.crt-overlay{
  position:absolute;inset:0;pointer-events:none;z-index:40;
  background:
    repeating-linear-gradient(0deg, var(--scan) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;opacity:.55;
}
.crt-vignette{
  position:absolute;inset:0;pointer-events:none;z-index:41;
  background:radial-gradient(120% 120% at 50% 50%, transparent 55%, rgba(0,0,0,.65) 100%);
  border-radius:12px;
}
.crt-flicker{
  position:absolute;inset:0;pointer-events:none;z-index:42;
  background:rgba(120,160,255,.03);animation:flick 6s steps(60) infinite;
}
@keyframes flick{0%,100%{opacity:.02}50%{opacity:.06}}

/* ===================== UI LAYER ===================== */
#ui{position:absolute;inset:0;z-index:30}
.ui-screen{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:14px;text-align:center;
}
.ui-screen[hidden]{display:none}

/* BOOT */
.boot-box{align-self:flex-start;text-align:left;font-size:10px;color:var(--neon);line-height:2.1;padding:20px;text-shadow:0 0 6px var(--neon)}
.boot-line{white-space:nowrap}

/* TITLE */
.title-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}
.title-logo{display:flex;flex-direction:column;line-height:.9}
.tl-1{font-size:clamp(26px,7vw,52px);color:var(--gold);text-shadow:0 0 14px #ff8a00,4px 4px 0 #6a1500,-1px -1px 0 #fff3}
.tl-2{font-size:clamp(26px,7vw,52px);color:var(--neon2);text-shadow:0 0 16px var(--neon2),4px 4px 0 #002b3a}
.title-bull{font-size:42px;filter:drop-shadow(0 0 10px var(--hot));animation:bob 1.4s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-6px) rotate(-3deg)}}
.press-start{
  font-family:inherit;cursor:pointer;border:0;color:#fff;
  background:linear-gradient(180deg,var(--hot),#b3003a);
  padding:14px 18px;border-radius:8px;font-size:13px;line-height:1.5;
  box-shadow:0 4px 0 #6a0022,0 0 18px rgba(255,46,99,.5);
  text-shadow:1px 1px 0 #000;
}
.press-start small{font-size:7px;opacity:.85}
.press-start:active{transform:translateY(2px);box-shadow:0 2px 0 #6a0022}
.press-start.ghost{background:linear-gradient(180deg,#2a2e3e,#171a26);box-shadow:0 4px 0 #000}
.press-start.full{width:100%;margin-top:6px}
.title-credits{display:flex;gap:18px;font-size:9px;color:var(--neon2);margin-top:4px}
.title-credits span{cursor:pointer}
.title-credits span:hover{color:#fff;text-shadow:0 0 8px var(--neon2)}
.copyright{font-size:6.5px;color:#5a6b8c;margin-top:8px;letter-spacing:1px}

/* CHARACTER SELECT */
.select-header{font-size:13px;color:var(--gold);margin-bottom:10px;text-shadow:0 0 8px #ff8a00;letter-spacing:2px}
.select-body{display:flex;gap:10px;width:100%;align-items:stretch;justify-content:center;flex:1;min-height:0}
.portrait-pane{
  width:22%;min-width:90px;background:#0a0c16;border:3px solid #000;border-radius:8px;
  box-shadow:inset 0 0 24px rgba(0,229,255,.15);display:flex;align-items:flex-end;justify-content:center;
  position:relative;overflow:hidden;
}
.portrait-pane canvas{width:100%;height:100%}
.portrait-pane .pp-tag{position:absolute;top:6px;left:6px;font-size:7px;color:var(--neon2)}
#p2-portrait .pp-tag{left:auto;right:6px;color:var(--hot)}
.roster-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:6px;align-content:start;flex:1;max-width:380px;
}
.roster-cell{
  aspect-ratio:1;background:#0c0e1a;border:2px solid #2a2e3e;border-radius:6px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;
}
.roster-cell canvas{width:100%;height:100%}
.roster-cell .rc-lock{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.62);font-size:14px}
.roster-cell.p1{border-color:var(--neon2);box-shadow:0 0 12px var(--neon2)}
.roster-cell.p2{border-color:var(--hot);box-shadow:0 0 12px var(--hot)}
.roster-cell.p1.p2{border-color:var(--gold);box-shadow:0 0 12px var(--gold)}
.select-foot{margin-top:8px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.sel-info{text-align:center}
.fighter-name{font-size:16px;color:#fff;text-shadow:0 0 8px var(--neon2)}
.fighter-title{font-size:8px;color:#9fb0d6;margin-top:6px}
.fighter-quote{font-size:8px;color:var(--gold);margin-top:5px;font-style:italic;opacity:.9}
.sel-stats{display:flex;flex-direction:column;gap:3px;min-width:150px}
.stat{display:flex;align-items:center;gap:6px;font-size:7px;color:#9fb0d6}
.stat span{width:24px;text-align:right}
.stat-bar{flex:1;height:7px;background:#0a0c16;border:1px solid #2a2e3e;border-radius:2px;overflow:hidden;display:block}
.stat-bar b{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--sol),var(--neon2));transition:width .25s ease}
.stat-tier{font-size:8px;color:#9fb0d6;margin-top:2px}
.stat-tier b{color:var(--gold);text-shadow:0 0 6px #ff8a00}

/* VERSUS */
.versus-wrap{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;animation:vsin .4s ease}
@keyframes vsin{from{transform:scale(.7);opacity:0}}
.vs-fighter{display:flex;flex-direction:column;align-items:center}
.vs-left{animation:slideL .5s ease}
.vs-right{animation:slideR .5s ease}
@keyframes slideL{from{transform:translateX(-120%)}}
@keyframes slideR{from{transform:translateX(120%)}}
.vs-fighter canvas{width:140px;height:auto;image-rendering:auto;filter:drop-shadow(0 6px 10px rgba(0,0,0,.6))}
.vs-name{font-size:13px;margin-top:6px;color:#fff;text-shadow:0 0 8px var(--neon2)}
.vs-bolt{font-size:30px;color:var(--gold);text-shadow:0 0 16px #ff8a00,3px 3px 0 #000;animation:pulse .6s ease-in-out infinite alternate}
@keyframes pulse{to{transform:scale(1.2)}}

/* HUD */
.hud{justify-content:flex-start;pointer-events:none}
.hud-top{display:flex;width:100%;gap:8px;align-items:flex-start;padding:6px 6px 0}
.hud-side{flex:1;display:flex;flex-direction:column;gap:4px}
.hud-name{font-size:9px;color:#fff;text-shadow:1px 1px 0 #000}
.hud-right{align-items:flex-end}
.hud-right .hud-name{text-align:right}
.health-bar{
  height:20px;background:#1a0008;border:2px solid #000;border-radius:3px;position:relative;overflow:hidden;
  box-shadow:inset 0 0 8px rgba(0,0,0,.8),0 0 0 1px rgba(255,255,255,.06);
  transform:skewX(-12deg);
}
.hud-left .health-bar{transform:skewX(-12deg)}
.hud-right .health-bar{transform:skewX(12deg)}
.health-bar>*{transform:skewX(0)}
.health-chip{position:absolute;inset:0 auto 0 0;height:100%;width:100%;background:#ffae00;opacity:.6;transition:width .45s ease .12s;z-index:1}
.health-fill{position:absolute;inset:0 auto 0 0;height:100%;width:100%;
  background:linear-gradient(180deg,#7CFC00,#13a800);z-index:2;transition:width .12s linear}
.health-bar.reverse .health-fill,.health-bar.reverse .health-chip{left:auto;right:0}
.hud-mid{display:flex;flex-direction:column;align-items:center}
.hud-timer{font-size:22px;color:var(--gold);text-shadow:0 0 8px #ff8a00,2px 2px 0 #000;min-width:48px}
.hud-stage{font-size:7px;color:var(--neon2);text-shadow:0 0 6px var(--neon2);margin-top:2px;letter-spacing:1px}
.round-pips{display:flex;gap:4px}
.hud-right .round-pips{justify-content:flex-end}
.pip{width:10px;height:10px;border-radius:50%;border:2px solid #000;background:#222636}
.pip.on{background:var(--gold);box-shadow:0 0 8px var(--gold)}
.hud-center-msg{
  margin:auto;font-size:30px;color:#fff;text-shadow:0 0 18px var(--hot),3px 3px 0 #000;
  letter-spacing:2px;opacity:0;transition:opacity .15s;
}
.hud-center-msg.show{opacity:1;animation:msgpop .4s ease}
@keyframes msgpop{from{transform:scale(.4);opacity:0}}

/* RESULTS */
.results-wrap{display:flex;flex-direction:column;gap:8px;align-items:center}
.results-title{font-size:34px;color:var(--hot);text-shadow:0 0 20px var(--hot),4px 4px 0 #000;animation:pulse .5s ease-in-out infinite alternate}
#results-portrait{width:96px;height:120px;image-rendering:pixelated}
.results-winner{font-size:11px;color:var(--gold);text-shadow:0 0 8px #ff8a00;line-height:1.6}
.results-btns{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap;justify-content:center}
.results-btns .press-start{font-size:10px;padding:10px 14px}

/* SPECIAL meter (in HUD, added under bars) */
.meter{height:7px;background:#01121a;border:1px solid #000;border-radius:2px;overflow:hidden;margin-top:2px}
.meter-fill{height:100%;width:0;background:linear-gradient(90deg,var(--neon2),var(--sol2));transition:width .15s}
.meter.full .meter-fill{animation:meterglow .5s linear infinite}
@keyframes meterglow{50%{filter:brightness(1.6)}}

/* ===================== CONTROL DECK ===================== */
#control-deck{
  margin-top:9px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:linear-gradient(180deg,#202434,#10131d);
  border:3px solid #000;border-radius:14px;padding:8px 18px;
  box-shadow:inset 0 2px 0 rgba(255,255,255,.05);
}
.deck-left,.deck-right{display:flex;flex-direction:column;align-items:center;gap:8px}
.deck-label{font-size:7px;color:#8aa0c8;letter-spacing:1px;text-align:center;line-height:1.6}
.joystick{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#3a4056,#171a26);border:3px solid #000;position:relative;box-shadow:0 4px 0 #000}
.joy-ball{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#ff6b81,#b3003a);box-shadow:0 3px 0 #5a0018,0 0 12px rgba(255,46,99,.6)}
.deck-buttons{display:flex;gap:12px}
.abtn{
  width:48px;height:48px;border-radius:50%;border:3px solid #000;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  font-size:13px;color:#000;box-shadow:0 5px 0 rgba(0,0,0,.6);user-select:none;
}
.abtn small{font-size:5px;color:#000a}
.abtn:active{transform:translateY(3px);box-shadow:0 2px 0 rgba(0,0,0,.6)}
.abtn.red{background:radial-gradient(circle at 35% 30%,#ff7a8c,#e11d48)}
.abtn.blue{background:radial-gradient(circle at 35% 30%,#7cc6ff,#2563eb)}
.abtn.green{background:radial-gradient(circle at 35% 30%,#8cffb0,#16a34a)}
.abtn.yellow{background:radial-gradient(circle at 35% 30%,#ffe27a,#eab308)}
.coin-slot{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px}
.coin-mouth{width:14px;height:42px;border-radius:4px;background:#000;border:3px solid #3a4056;box-shadow:inset 0 0 8px #000}
.coin-slot:hover .coin-mouth{border-color:var(--gold);box-shadow:0 0 12px var(--gold)}

#cab-foot{text-align:center;font-size:7px;color:#46567a;margin-top:12px;letter-spacing:2px}

/* ===================== MODALS ===================== */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  background:rgba(2,3,8,.82);padding:20px;backdrop-filter:blur(3px)}
.modal[hidden]{display:none}
.modal-card{
  position:relative;width:min(440px,100%);background:linear-gradient(180deg,#141826,#0a0c16);
  border:3px solid #000;border-radius:14px;padding:26px 22px;text-align:center;
  box-shadow:0 0 0 3px #2a2e3e,0 24px 60px rgba(0,0,0,.7),inset 0 0 50px rgba(153,69,255,.18);
  animation:vsin .25s ease;
}
.modal-x{position:absolute;top:8px;right:10px;background:none;border:0;color:#7184ad;font-size:20px;cursor:pointer;font-family:inherit}
.modal-x:hover{color:#fff}
.modal-card h2{font-size:15px;letter-spacing:1px;margin-bottom:8px;color:#fff;line-height:1.5}
.modal-card h2 span{color:var(--sol)}
.bet-coin{font-size:40px;color:var(--sol);text-shadow:0 0 18px var(--sol);margin-bottom:6px}
.bet-soon{color:var(--gold);font-size:13px;margin:10px 0;animation:pulse .8s ease-in-out infinite alternate;text-shadow:0 0 10px #ff8a00}
.bet-copy{font-size:8.5px;color:#aebada;line-height:1.9;margin-bottom:14px}
.bet-rows{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.bet-row{display:flex;justify-content:space-between;font-size:8.5px;background:#0a0c16;border:1px solid #2a2e3e;border-radius:6px;padding:8px 10px}
.bet-row span{color:#8aa0c8}.bet-row b{color:var(--sol)}
.bet-disclaimer{font-size:6.5px;color:#5a6b8c;margin-top:10px;line-height:1.7}
.howto-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin:14px 0;text-align:left}
.howto-grid div{display:flex;align-items:center;gap:6px;font-size:8px;color:#cdd8f2}
kbd{font-family:inherit;font-size:8px;background:#0a0c16;border:1px solid #3a4056;border-bottom-width:3px;border-radius:4px;padding:4px 6px;color:#fff;min-width:18px;text-align:center}
.howto-tip{font-size:8px;color:#aebada;line-height:1.9;margin:10px 0}

/* ===================== TOUCH PAD ===================== */
#touch-pad{position:fixed;left:0;right:0;bottom:0;z-index:150;display:none;justify-content:space-between;align-items:flex-end;
  padding:10px 14px env(safe-area-inset-bottom,12px);pointer-events:none}
body.is-touch.in-game #touch-pad{display:flex}
#touch-pad button{pointer-events:auto}
.tp-dpad{display:grid;grid-template-columns:repeat(3,52px);grid-template-rows:repeat(3,52px);gap:4px}
.tp-dpad .tp:nth-child(1){grid-area:2/1}
.tp-dpad .tp:nth-child(2){grid-area:1/2}
.tp-dpad .tp:nth-child(3){grid-area:3/2}
.tp-dpad .tp:nth-child(4){grid-area:2/3}
.tp{font-family:inherit;font-size:16px;border:2px solid #000;border-radius:10px;background:#202434e6;color:#fff;
  width:52px;height:52px;cursor:pointer;user-select:none;touch-action:none;box-shadow:0 3px 0 rgba(0,0,0,.6)}
.tp:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(0,0,0,.6);filter:brightness(1.3)}
.tp.red{background:#e11d48e6}.tp.blue{background:#2563ebe6}.tp.green{background:#16a34ae6}.tp.yellow{background:#eab308e6;color:#000}
.tp-actions{display:grid;grid-template-columns:repeat(2,58px);grid-template-rows:repeat(2,58px);gap:10px}
.tp-actions .tp{width:58px;height:58px;border-radius:50%;font-size:18px}

/* ===================== RESPONSIVE ===================== */
@media (max-width:760px){
  #cabinet{padding:8px 8px 12px}
  #hero{padding:56px 6px 8px;gap:6px}
  .hero-tag h2{font-size:13px}
  .hero-tag p{font-size:8px}
  .marquee-sub{font-size:7px}
  .deck-buttons{gap:8px}
  .abtn{width:42px;height:42px}
  .portrait-pane{min-width:62px}
}
/* touch devices: drop the decorative control deck, grow the screen (touch-pad handles input) */
body.is-touch #control-deck{display:none}
body.is-touch #screen{height:min(calc(100vh - 138px), calc((97vw - 36px) * 0.5625))}
@media (orientation:landscape){
  body.is-touch #site-nav{height:42px}
  body.is-touch #screen{height:min(calc(100vh - 92px), calc((97vw - 36px) * 0.5625))}
}
@media (max-width:430px){
  .select-body{gap:4px}
  .portrait-pane{min-width:52px;width:19%}
  .select-header{font-size:11px}
  .nav-logo{font-size:11px}
  .hero-cta .press-start{font-size:11px;padding:11px 12px}
}
