:root{
  --void:#0a0a18; --void2:#10122a;
  --hex:#34e0e8; --hex-deep:#0f7a82;
  --gold:#f4c95d; --crimson:#ff4d6d; --magenta:#c45cff; --lime:#5cffa0; --orange:#ff7a3c; --pink:#ff5cc8;
  --ink:#e8ecff; --mute:#7d83a8;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;}
html,body{height:100%;overflow:hidden;background:var(--void);font-family:'Trebuchet MS',system-ui,sans-serif;color:var(--ink);}
#wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;}
canvas#game{display:block;background:radial-gradient(circle at 50% 40%, #16183a 0%, #0a0a18 70%);touch-action:none;cursor:crosshair;}

#hud{position:fixed;inset:0;pointer-events:none;font-variant-numeric:tabular-nums;}
#topbar{position:absolute;top:0;left:0;right:0;padding:10px 14px;display:flex;flex-direction:column;gap:6px;}
#xpbar-bg{height:9px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;}
#xpbar{height:100%;width:0;background:linear-gradient(90deg,var(--gold),#fff3c9);border-radius:999px;transition:width .12s linear;box-shadow:0 0 12px var(--gold);}
#toprow{display:flex;justify-content:space-between;align-items:center;font-weight:bold;letter-spacing:.5px;}
#lvl{color:var(--gold);text-shadow:0 0 10px rgba(244,201,93,.6);}
#timer{font-size:24px;text-shadow:0 0 12px rgba(255,255,255,.3);}
#stats{display:flex;gap:12px;color:var(--mute);font-size:13px;align-items:center;}
#stats b{color:var(--ink);font-size:15px;}
#conn{color:var(--lime);font-size:10px;}#conn.bad{color:var(--crimson);}

#party{position:absolute;top:64px;left:14px;display:flex;flex-direction:column;gap:7px;}
.pcard{background:rgba(16,18,42,.6);border-radius:9px;padding:6px 9px;width:160px;border:1px solid rgba(255,255,255,.06);}
.pcard.me{border-color:rgba(52,224,232,.4);}
.pcard .pn{font-size:11px;font-weight:bold;letter-spacing:.5px;margin-bottom:4px;display:flex;justify-content:space-between;}
.pcard .pn .you{color:var(--hex);} .pcard .pn .bot{color:var(--mute);}
.pcard .hpb{height:7px;background:rgba(255,77,109,.15);border-radius:999px;overflow:hidden;position:relative;}
.pcard .hpf{height:100%;background:linear-gradient(90deg,#ff3355,#ff7a90);border-radius:999px;transition:width .15s;}
.pcard .shf{position:absolute;top:0;left:0;height:100%;background:rgba(124,200,255,.6);border-radius:999px;}
.pcard.down{opacity:.5;} .pcard.down .hpf{background:#444;}

#mini{position:absolute;top:14px;right:14px;background:rgba(8,10,26,.66);border:1px solid rgba(255,255,255,.12);border-radius:10px;}

#botbar{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:16px;align-items:flex-end;}
.glab{font-size:9px;letter-spacing:1px;color:var(--mute);text-transform:uppercase;text-align:center;margin-bottom:3px;}
.group{display:flex;gap:7px;}
.slot{width:52px;height:52px;border-radius:11px;background:rgba(12,14,34,.75);border:1px solid rgba(255,255,255,.1);position:relative;display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;}
.slot .key{position:absolute;top:2px;left:4px;font-size:8px;color:var(--mute);font-weight:bold;letter-spacing:.5px;}
.slot .cd{position:absolute;left:0;bottom:0;width:100%;background:rgba(0,0,0,.62);}
.slot .pips{position:absolute;bottom:2px;left:0;width:100%;display:flex;gap:2px;justify-content:center;}
.slot .pip{width:5px;height:3px;border-radius:1px;background:rgba(255,255,255,.18);}
.slot .pip.on{background:var(--gold);box-shadow:0 0 4px var(--gold);}
.slot.ab{border-color:rgba(52,224,232,.45);}
.slot.max{border-color:var(--gold);box-shadow:0 0 14px rgba(244,201,93,.5);}
.slot.empty{opacity:.35;font-size:14px;color:var(--mute);}
.slot .star{position:absolute;bottom:1px;font-size:11px;color:var(--gold);text-shadow:0 0 6px var(--gold);}
.slot .sklv{position:absolute;bottom:2px;right:4px;font-size:9px;color:var(--gold);font-weight:bold;}

#aimhint{position:absolute;bottom:74px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--gold);letter-spacing:1px;background:rgba(16,18,42,.7);padding:5px 12px;border-radius:999px;border:1px solid rgba(244,201,93,.3);}

.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;background:radial-gradient(circle at 50% 35%, rgba(20,22,55,.92), rgba(6,6,18,.98));backdrop-filter:blur(3px);z-index:20;padding:20px;overflow:auto;}
.hidden{display:none!important;}
h1{font-size:clamp(34px,8vw,68px);letter-spacing:8px;font-weight:900;background:linear-gradient(180deg,#fff,var(--hex));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 40px rgba(52,224,232,.4);margin-bottom:4px;text-align:center;}
.tag{color:var(--mute);letter-spacing:3px;font-size:13px;text-transform:uppercase;margin-bottom:22px;text-align:center;}
.money b{color:var(--gold);}
.panel{background:rgba(16,18,42,.7);border:1px solid rgba(52,224,232,.25);border-radius:16px;padding:22px 26px;max-width:600px;width:100%;text-align:center;box-shadow:0 0 40px rgba(52,224,232,.08);}
.panel p{color:#c3c8ea;line-height:1.55;font-size:14px;margin-bottom:8px;}
.btn{cursor:pointer;border:none;border-radius:12px;padding:13px 32px;font-size:16px;font-weight:bold;letter-spacing:2px;color:#04121a;background:linear-gradient(180deg,#5cf0f7,var(--hex));margin-top:10px;box-shadow:0 0 24px rgba(52,224,232,.4);transition:transform .12s,box-shadow .12s;font-family:inherit;text-transform:uppercase;}
.btn:hover{transform:translateY(-2px);box-shadow:0 0 36px rgba(52,224,232,.7);}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn.ghost{background:transparent;color:var(--mute);box-shadow:none;border:1px solid rgba(255,255,255,.14);}
.btn.ghost:hover{color:var(--ink);border-color:var(--hex);}
.btn.sm{padding:9px 18px;font-size:13px;}
input.txt{font-family:inherit;font-size:15px;padding:11px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.25);color:var(--ink);width:100%;margin-bottom:10px;-webkit-user-select:text;user-select:text;}
input.txt:focus{outline:none;border-color:var(--hex);}
.err{color:var(--crimson);font-size:12px;min-height:16px;margin-top:8px;}
.waithint{color:var(--mute);font-size:12px;margin-top:10px;}

.tabs{display:flex;gap:8px;margin-bottom:16px;}
.tab{flex:1;padding:9px;border-radius:9px;background:rgba(0,0,0,.2);cursor:pointer;font-size:13px;letter-spacing:1px;color:var(--mute);border:1px solid transparent;}
.tab.active{color:var(--hex);border-color:var(--hex);background:rgba(52,224,232,.08);}

.shop-title,.map-title{font-size:11px;letter-spacing:1px;color:var(--mute);text-transform:uppercase;margin:6px 0 10px;}
.shop{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;}
.shopcard{background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:12px 10px;text-align:center;}
.shopcard .si{font-size:26px;margin-bottom:4px;filter:drop-shadow(0 0 6px currentColor);}
.shopcard .sn{font-size:12px;font-weight:bold;color:#fff;margin-bottom:3px;}
.shopcard .sd{font-size:10px;color:var(--mute);line-height:1.3;min-height:26px;}
.shopcard .pips{display:flex;gap:3px;justify-content:center;margin:6px 0;}
.shopcard .pip{width:14px;height:5px;border-radius:2px;background:rgba(255,255,255,.15);}
.shopcard .pip.on{background:var(--gold);box-shadow:0 0 5px var(--gold);}
.shopcard button{width:100%;margin-top:4px;padding:7px;font-size:12px;border-radius:8px;border:none;cursor:pointer;font-family:inherit;font-weight:bold;letter-spacing:.5px;background:linear-gradient(180deg,#5cf0f7,var(--hex));color:#04121a;}
.shopcard button:disabled{opacity:.4;cursor:default;background:#333;color:var(--mute);}
.shopcard.max button{background:rgba(244,201,93,.2);color:var(--gold);}

#roomCode{font-size:40px;font-weight:900;letter-spacing:10px;color:var(--gold);text-shadow:0 0 20px rgba(244,201,93,.5);margin:2px 0;}
.maps{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:12px;}
.mapb{background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px;cursor:pointer;transition:all .12s;}
.mapb .mn{font-weight:bold;font-size:14px;}
.mapb .md{font-size:10px;color:var(--mute);margin-top:2px;line-height:1.3;}
.mapb.sel{border-color:var(--hex);background:rgba(52,224,232,.1);box-shadow:0 0 16px rgba(52,224,232,.25);}
.mapb.locked{opacity:.7;cursor:default;}
.plist{display:flex;flex-direction:column;gap:8px;margin:8px 0 14px;}
.prow{display:flex;justify-content:space-between;align-items:center;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 14px;}
.prow .host{color:var(--gold);font-size:11px;}

.hlist{display:flex;flex-direction:column;gap:7px;margin:14px 0;max-height:340px;overflow:auto;}
.hrow{display:flex;justify-content:space-between;align-items:center;background:rgba(0,0,0,.22);border-left:3px solid var(--hex);border-radius:8px;padding:9px 13px;font-size:13px;}
.hrow.spek{border-left-color:var(--gold);}
.hrow .ht{font-weight:bold;font-size:16px;color:var(--gold);}
.hrow .hd{font-size:11px;color:var(--mute);}
.hrow .hr{text-align:right;}
.empty-h{color:var(--mute);font-size:13px;padding:24px;text-align:center;}

.choosebox{pointer-events:auto;background:rgba(8,10,26,.82);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:18px 20px;backdrop-filter:blur(4px);box-shadow:0 0 40px rgba(0,0,0,.5);}
.ctitle{font-size:26px;letter-spacing:4px;font-weight:900;text-align:center;margin-bottom:2px;color:var(--hex);}
.csub{color:var(--mute);font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px;text-align:center;}
#timerbar-bg{width:min(680px,84vw);height:6px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden;margin:0 auto 16px;}
#timerbar{height:100%;width:100%;background:linear-gradient(90deg,var(--crimson),var(--gold));border-radius:999px;}
.cards{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;max-width:700px;}
.card{cursor:pointer;width:190px;background:rgba(16,18,42,.92);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:18px 14px;text-align:center;transition:transform .12s,box-shadow .12s;border-top:3px solid var(--hex);}
.card:hover{transform:translateY(-6px);box-shadow:0 0 30px rgba(255,255,255,.12);}
.card .ic{font-size:38px;margin-bottom:8px;filter:drop-shadow(0 0 8px currentColor);}
.card .cls{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;opacity:.85;}
.card .nm{font-weight:bold;font-size:16px;margin-bottom:6px;color:#fff;}
.card .lv{font-size:11px;letter-spacing:1px;color:var(--gold);margin-bottom:8px;text-transform:uppercase;}
.card .ds{font-size:12px;color:var(--mute);line-height:1.4;}
.card.spek{border:2px solid var(--gold);box-shadow:0 0 36px rgba(244,201,93,.45);background:linear-gradient(180deg,rgba(60,46,10,.6),rgba(16,18,42,.9));}
.card.spek .nm{color:var(--gold);text-shadow:0 0 12px var(--gold);}

#overStats{display:flex;gap:26px;justify-content:center;margin:18px 0;flex-wrap:wrap;}
#overStats .n{font-size:32px;font-weight:900;color:var(--hex);}
#overStats .l{font-size:11px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;}
.earned{font-size:18px;color:var(--gold);margin-bottom:14px;font-weight:bold;}
.dead h1{background:linear-gradient(180deg,#fff,var(--crimson));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 40px rgba(255,77,109,.4);}

#stick{position:fixed;bottom:84px;left:20px;width:116px;height:116px;border-radius:50%;border:2px solid rgba(52,224,232,.3);background:rgba(52,224,232,.06);display:none;z-index:15;touch-action:none;}
#nub{position:absolute;top:50%;left:50%;width:50px;height:50px;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,#5cf0f7,var(--hex-deep));box-shadow:0 0 16px rgba(52,224,232,.6);}
.hint{font-size:11px;color:var(--mute);margin-top:14px;text-align:center;line-height:1.6;}
.hint b{color:var(--hex);}
