:root{
  --bg:#070a09; --bg2:#0c100f; --panel:#111614; --panel2:#161d1a;
  --line:#222c28; --line2:#2c3a34;
  --txt:#e9f3ee; --mut:#8aa097; --mut2:#5e716a;
  --green:#22e08a; --green-d:#15b86e; --green-glow:rgba(34,224,138,.35);
  --gold:#ffd23f; --gold-d:#e0b400;
  --red:#ff4d5e; --blue:#5b8cff; --purple:#a06bff;
  --radius:14px;
  --menu-blur:7px;       /* controllable from admin (MENU_BLUR_PX) */
  font-synthesis:none;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:radial-gradient(1200px 700px at 50% -10%, #11201a 0%, var(--bg) 60%);
  color:var(--txt); font-family:"Segoe UI",system-ui,Roboto,Arial,sans-serif;
  overflow:hidden; -webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:none;color:inherit}
input{font-family:inherit}
.hidden{display:none !important}
.mono{font-variant-numeric:tabular-nums}
.col{display:flex;flex-direction:column;gap:18px}

/* inline svg icons */
.ic{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em;vertical-align:-0.16em}
.ic svg{width:100%;height:100%;display:block}
.btn .ic, .modebtn .ic, .tab .ic, h3 .ic, h4 .ic{margin-right:2px}
.btn-icon{width:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.btn-icon.off{opacity:.5}

/* ---------- top bar ---------- */
.topbar{position:fixed;top:0;left:0;right:0;height:58px;display:flex;align-items:center;
  justify-content:space-between;padding:0 22px;z-index:30}
.welcome{font-weight:700;font-size:18px}
.welcome span{color:var(--green)}
.btn{background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  padding:9px 16px;font-weight:600;font-size:14px;transition:.15s;color:var(--txt)}
.btn:hover{border-color:var(--line2);background:#1c2521}
.btn-green{background:linear-gradient(180deg,var(--green),var(--green-d));color:#07140d;
  border:none;box-shadow:0 4px 18px var(--green-glow)}
.btn-green:hover{filter:brightness(1.07);background:linear-gradient(180deg,var(--green),var(--green-d))}
.btn-gold{background:linear-gradient(180deg,var(--gold),var(--gold-d));color:#1a1400;border:none}
.btn-ghost{background:transparent;border:1px solid var(--line2)}
.btn-block{width:100%;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-lg{padding:14px 20px;font-size:16px}

/* blurred fake-gameplay backdrop */
#bgCanvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;
  filter:blur(var(--menu-blur)) brightness(0.62) saturate(1.15)}

/* ---------- lobby ---------- */
#lobby{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  padding-top:62px;overflow:auto;z-index:1}
.brand{font-size:46px;font-weight:800;letter-spacing:-1px;margin:18px 0 2px}
.brand b{color:var(--green)}
.brand-sub{color:var(--mut);letter-spacing:6px;font-size:11px;font-weight:600;text-transform:uppercase;margin-bottom:24px}
.grid{display:grid;grid-template-columns:300px 460px 300px;gap:18px;width:min(1120px,96vw);align-items:start}
.card{background:linear-gradient(180deg,rgba(17,22,20,.72),rgba(12,16,15,.72));border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;backdrop-filter:blur(6px)}
.card h3{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--mut);
  display:flex;align-items:center;gap:8px;margin-bottom:14px}
.card h3 .ic{color:var(--gold)}

/* join card */
.join .modepick{display:flex;gap:8px;margin-bottom:12px}
.modebtn{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  padding:10px;text-align:center;font-weight:600;font-size:13px;transition:.15s}
.modebtn small{display:block;color:var(--mut2);font-weight:500;font-size:11px;margin-top:3px}
.modebtn.active{border-color:var(--green);background:#13251c;box-shadow:0 0 0 1px var(--green) inset}
.nick{width:100%;background:#0a0f0d;border:1px solid var(--line2);border-radius:10px;
  padding:13px 14px;color:var(--txt);font-size:15px;text-align:center;font-weight:600;margin-bottom:12px}
.nick:focus{outline:none;border-color:var(--green)}
.stakes{display:flex;gap:8px;margin-bottom:12px}
.stake{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px 0;
  text-align:center;font-weight:700;font-size:16px;transition:.15s}
.stake.active{border-color:var(--gold);background:#231d05;color:var(--gold)}
.global-won{text-align:center;color:var(--mut);font-size:12px;margin-top:12px}
.global-won b{color:var(--gold)}

/* leaderboard card */
.lb-row{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}
.lb-row:last-child{border:none}
.lb-rank{width:22px;height:22px;border-radius:50%;background:var(--panel2);display:flex;
  align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--mut)}
.lb-row.top1 .lb-rank{background:var(--gold);color:#1a1400}
.lb-name{flex:1;font-weight:600;font-size:14px}
.lb-val{color:var(--green);font-weight:700;font-size:14px}

/* wallet card */
.wallet-amt{font-size:34px;font-weight:800;text-align:center;margin:6px 0 2px}
.wallet-sub{text-align:center;color:var(--mut2);font-size:12px;margin-bottom:14px}
.wallet-actions{display:flex;gap:8px}
.shop-preview{height:80px;border-radius:10px;background:#0a0f0d;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;margin-bottom:12px;overflow:hidden}

/* ---------- modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(2,5,4,.72);backdrop-filter:blur(3px);
  z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:linear-gradient(180deg,var(--panel),#0a0e0c);border:1px solid var(--line2);
  border-radius:18px;width:min(760px,96vw);max-height:90vh;overflow:auto;padding:20px}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.modal-head h2{font-size:18px;display:flex;align-items:center;gap:9px}
.x{background:var(--panel2);border-radius:8px;width:32px;height:32px;font-size:16px;color:var(--mut)}
.tabs{display:flex;gap:8px;margin-bottom:16px}
.tab{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:11px;
  font-weight:600;font-size:14px;text-align:center;transition:.15s}
.tab.active{background:linear-gradient(180deg,var(--green),var(--green-d));color:#07140d;border:none}

/* cosmetics grid */
.cos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cos{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px;transition:.15s;position:relative}
.cos:hover{border-color:var(--line2)}
.cos.equipped{border-color:var(--green)}
.cos .swatch{height:64px;border-radius:8px;margin-bottom:8px;background-size:cover}
.cos .nm{font-weight:600;font-size:13px}
.cos .rar{font-size:11px;color:var(--mut2)}
.cos .pr{font-size:12px;font-weight:700;color:var(--gold);float:right}
.cos .badge{position:absolute;top:8px;right:8px;font-size:10px;background:var(--green);color:#07140d;
  padding:2px 7px;border-radius:6px;font-weight:700;z-index:2}
.cos .badge.sold{background:var(--red);color:#fff}
.cos .badge.own{background:var(--line2);color:var(--txt)}
.subtab{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.subtab .st{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600}
.subtab .st.active{background:var(--green);color:#07140d;border:none}

/* add funds */
.fund-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.fund{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:18px 0;
  text-align:center;font-size:20px;font-weight:800;color:var(--green)}
.fund:hover{border-color:var(--green)}

/* rules modal */
.rules-intro{color:var(--mut);font-size:13px;line-height:1.6;margin-bottom:16px}
.rules-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rule{display:flex;gap:12px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:11px;align-items:center}
.rule canvas{flex:0 0 auto;border-radius:8px;background:#070a09;border:1px solid var(--line)}
.rule .rt{font-size:12.5px;line-height:1.45;color:var(--mut)}
.rule .rt b{color:var(--txt)}
.rule .rt .gold{color:var(--gold)}
@media(max-width:640px){.rules-list{grid-template-columns:1fr}}

/* lb modal list */
.lbm-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border:1px solid var(--line);
  border-radius:12px;margin-bottom:8px}
.lbm-row.top1{border-color:var(--gold)}
.lbm-row.top3{border-color:#cd7f32}
.lbm-rank{width:30px;height:30px;border-radius:50%;background:var(--panel2);display:flex;
  align-items:center;justify-content:center;font-weight:700}
.lbm-row.top1 .lbm-rank{background:var(--gold);color:#1a1400}
.lbm-name{flex:1;font-weight:700}
.lbm-val{color:var(--green);font-weight:800}

/* ---------- game ---------- */
#game{position:absolute;inset:0;display:none}
#game.on{display:block}
#canvas{display:block;width:100%;height:100%;background:#050706}
.hud{position:absolute;inset:0;pointer-events:none}
.hud > *{pointer-events:auto}
.hud-top-left{position:absolute;top:14px;left:14px;background:rgba(8,12,10,.7);border:1px solid var(--line);
  border-radius:12px;padding:10px 14px;min-width:170px}
.hud-balance{font-size:13px;color:var(--mut)}
.hud-balance b{display:block;font-size:24px;color:var(--gold);font-weight:800}
.hud-stat{font-size:12px;color:var(--mut);display:flex;justify-content:space-between;margin-top:3px}
.hud-stat b{color:var(--txt)}
.hud-lb{position:absolute;top:14px;right:14px;background:rgba(8,12,10,.7);border:1px solid var(--line);
  border-radius:12px;padding:10px 14px;min-width:190px}
.hud-lb h4{font-size:11px;color:var(--gold);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.hud-lb .r{display:flex;justify-content:space-between;font-size:12px;padding:2px 0}
.hud-lb .r.me{color:var(--green);font-weight:700}
.hud-lb .r .v{color:var(--green)}
.minimap{position:absolute;bottom:14px;right:14px;width:150px;height:150px;
  background:rgba(8,12,10,.7);border:1px solid var(--line);border-radius:12px}
.actionbar{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  display:flex;gap:12px;align-items:center}
.cashbtn{background:linear-gradient(180deg,var(--gold),var(--gold-d));color:#1a1400;font-weight:800;
  padding:13px 26px;border-radius:12px;font-size:15px;box-shadow:0 6px 22px rgba(255,210,63,.3);
  display:flex;align-items:center;gap:8px;user-select:none;touch-action:none}
.cashbtn.holding{background:linear-gradient(180deg,#fff0a8,var(--gold));animation:pulse .6s infinite}
@keyframes pulse{50%{filter:brightness(1.15)}}
.cashbtn small{font-weight:600;opacity:.8}
.boostbtn{background:linear-gradient(180deg,#3a4a44,#1c2521);color:var(--txt);font-weight:800;
  padding:13px 24px;border-radius:12px;font-size:15px;border:1px solid var(--line2);
  display:flex;align-items:center;gap:8px;user-select:none;touch-action:none}
.boostbtn:active{background:linear-gradient(180deg,var(--green),var(--green-d));color:#07140d}

/* mobile-only controls */
.mobile-only{display:none}
body.touch .mobile-only{display:block}
/* in-game: no zoom, no text selection, no long-press callout */
#game,#canvas{touch-action:none;-webkit-user-select:none;user-select:none;
  -webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}
.hud,.hud *{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.cashbtn{-webkit-tap-highlight-color:transparent}
/* double-tap-to-boost hint shown briefly at round start */
.boost-hint{position:absolute;bottom:84px;left:50%;transform:translateX(-50%);
  background:rgba(8,12,10,.82);border:1px solid var(--line2);border-radius:10px;
  padding:8px 14px;font-size:13px;font-weight:600;color:var(--green);white-space:nowrap;
  pointer-events:none;animation:hintpulse 1s ease-in-out infinite}
@keyframes hintpulse{50%{opacity:.6}}

/* joystick control preset */
.joystick{position:absolute;left:22px;bottom:28px;width:122px;height:122px;border-radius:50%;
  background:rgba(20,28,24,.4);border:2px solid rgba(255,255,255,.14);touch-action:none;z-index:9}
.joyknob{position:absolute;left:50%;top:50%;width:54px;height:54px;margin:-27px 0 0 -27px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#41544c,#1c2521);border:1px solid var(--line2);
  box-shadow:0 4px 14px rgba(0,0,0,.5)}
.joybtn{position:absolute;right:22px;bottom:34px;width:86px;height:86px;border-radius:50%;
  background:linear-gradient(180deg,var(--green),var(--green-d));color:#07140d;
  display:flex;align-items:center;justify-content:center;touch-action:none;z-index:9;
  box-shadow:0 6px 22px var(--green-glow)}
.joybtn .ic{width:36px;height:36px}
.joybtn:active{filter:brightness(1.12)}
.ctrl-preset .cp-row{display:flex;gap:6px;margin-top:6px}
.cp{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:8px;
  padding:8px 6px;font-size:12px;font-weight:600;color:var(--txt)}
.cp.active{background:linear-gradient(180deg,var(--green),var(--green-d));color:#07140d;border:none}
.modepick.big{gap:10px;margin-bottom:14px}
.modepick.big .modebtn{padding:14px 10px;font-size:15px}
.modepick.big .modebtn small{font-size:11px;margin-top:4px}

/* chat */
.chatbox{position:absolute;bottom:14px;left:14px;width:300px;max-width:38vw}
.chatlog{max-height:150px;overflow-y:auto;font-size:13px;margin-bottom:6px;
  display:flex;flex-direction:column;gap:3px;
  scrollbar-width:none;-ms-overflow-style:none}
.chatlog::-webkit-scrollbar{display:none;width:0;height:0}
.chatlog .m{background:rgba(8,12,10,.6);border-radius:8px;padding:4px 9px;width:fit-content;max-width:100%}
.chatlog .m b{color:var(--green)}
.chatin{width:100%;background:rgba(8,12,10,.8);border:1px solid var(--line);border-radius:9px;
  padding:8px 11px;color:var(--txt);font-size:13px;display:none}
.chatin:focus{outline:none;border-color:var(--green)}
.chatbox.typing .chatin{display:block}

/* countdown */
.countdown{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:9;pointer-events:none}
.cd-num{font-size:130px;font-weight:900;color:var(--green);text-shadow:0 0 40px var(--green-glow),0 6px 30px rgba(0,0,0,.6)}
.cd-num.go{color:var(--gold);font-size:96px;text-shadow:0 0 40px rgba(255,210,63,.5)}
.cd-num.pop{animation:cdpop .42s ease-out}
@keyframes cdpop{0%{transform:scale(.3);opacity:0}40%{transform:scale(1.15);opacity:1}100%{transform:scale(1)}}

/* out-of-bounds warning */
.oob-warn{position:absolute;top:16%;left:50%;transform:translateX(-50%);text-align:center;z-index:8;pointer-events:none}
.oob-title{color:var(--red);font-weight:800;font-size:26px;text-shadow:0 0 18px rgba(255,77,94,.6);animation:blink .55s steps(2) infinite}
.oob-count{color:#fff;font-size:46px;font-weight:900;text-shadow:0 2px 12px rgba(0,0,0,.6)}
@keyframes blink{50%{opacity:.35}}

/* overlays */
.overlay{position:absolute;inset:0;background:rgba(3,6,5,.8);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:10;animation:ovfade .35s ease}
@keyframes ovfade{from{opacity:0}to{opacity:1}}
.overlay .over-card{animation:overpop .45s cubic-bezier(.2,.9,.3,1.25)}
@keyframes overpop{0%{transform:scale(.7) translateY(24px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
.over-ic{width:54px;height:54px;margin:0 auto 4px;color:var(--red)}
.over-ic svg{width:100%;height:100%}
.over-card{background:linear-gradient(180deg,var(--panel),#0a0e0c);border:1px solid var(--line2);
  border-radius:18px;padding:30px 36px;text-align:center;min-width:320px}
.over-card h1{font-size:30px;margin-bottom:6px}
.over-card .big{font-size:42px;font-weight:800;margin:8px 0}
.over-card .big.win{color:var(--green)}
.over-card .big.lose{color:var(--red)}
.over-card p{color:var(--mut);margin-bottom:18px}
.over-actions{display:flex;gap:10px;justify-content:center}

.toast{position:fixed;top:70px;left:50%;transform:translateX(-50%);background:var(--panel2);
  border:1px solid var(--line2);border-radius:10px;padding:11px 18px;font-weight:600;z-index:100;
  opacity:0;transition:.25s}
.toast.show{opacity:1}
.toast.err{border-color:var(--red);color:#ffb3ba}

@media(max-width:1000px){
  .grid{grid-template-columns:1fr;width:94vw}
  .brand{font-size:34px}
  .hud-lb{min-width:150px}
  .chatbox{width:200px}
}
/* phones / small touch screens */
@media(max-width:640px){
  .brand{font-size:30px;margin-top:8px}
  .brand-sub{font-size:9px;letter-spacing:4px;margin-bottom:16px}
  .topbar{padding:0 12px;height:50px}
  #lobby{padding-top:54px}
  .hud-top-left{min-width:120px;padding:7px 10px;top:8px;left:8px}
  .hud-balance b{font-size:18px}
  .hud-lb{min-width:120px;padding:7px 10px;top:8px;right:8px;font-size:11px}
  .minimap{width:96px;height:96px;bottom:88px;right:8px}
  .chatbox{width:160px;bottom:84px;left:8px}
  .chatlog{max-height:90px}
  .actionbar{bottom:12px;gap:8px;width:calc(100% - 16px);justify-content:center}
  .cashbtn,.boostbtn{padding:15px 18px;font-size:15px;flex:1;justify-content:center;max-width:50%}
  .cashbtn small{display:none}
}
/* hide the boost button hint on fine-pointer (desktop) is fine to keep; it just works */
