:root{
  --bg:#0d1220; --panel:#161d31; --panel2:#1e2740; --line:#2c3860;
  --gold:#ffcf5c; --gold2:#f0a92e; --text:#e8ecf7; --muted:#8b96b5;
  --green:#4fd07a; --red:#ff5a6a; --blue:#5aa8ff;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:'Segoe UI',system-ui,sans-serif}
html,body{height:100%;background:var(--bg);color:var(--text);overflow:hidden;user-select:none}
.hidden{display:none !important}
button{cursor:pointer;font-family:inherit}

/* ---------------- LOGIN ---------------- */
.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 30%,#1a2murky 0,#0a0e1a 70%);
  background:radial-gradient(circle at 50% 30%,#1a2340 0,#080b14 75%);z-index:50}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;
  padding:34px 30px;width:340px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.login-card h1{font-size:30px;letter-spacing:2px;background:linear-gradient(#ffe08a,#f0a92e);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.subtitle{color:var(--muted);font-size:13px;margin:4px 0 18px}
.tabs{display:flex;gap:6px;margin-bottom:16px}
.tab{flex:1;padding:9px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  color:var(--muted);font-weight:600}
.tab.active{background:var(--gold);color:#20160a;border-color:var(--gold)}
.login-card input{width:100%;padding:12px;margin-bottom:10px;background:var(--panel2);
  border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px}
.btn-primary{width:100%;padding:13px;background:linear-gradient(var(--gold),var(--gold2));
  border:0;border-radius:11px;color:#20160a;font-weight:800;font-size:16px;letter-spacing:.5px}
.btn-primary:active{transform:translateY(1px)}
.error{color:var(--red);font-size:13px;min-height:18px;margin-bottom:6px}
.hint{color:var(--muted);font-size:11px;margin-top:12px}

/* ---------------- GAME SHELL ---------------- */
#game{position:fixed;inset:0}
#scene{position:absolute;inset:0}
#scene canvas{display:block}

#topbar{position:absolute;top:12px;right:14px;display:flex;gap:8px;z-index:6}
.pill{background:rgba(22,29,49,.85);border:1px solid var(--line);border-radius:20px;
  padding:7px 14px;font-weight:700;font-size:14px;backdrop-filter:blur(6px)}
.pill.gems{color:var(--gold)}
/* match mode badge: instantly readable for everyone in the room */
.pill.modebadge{font-weight:800;border:0;letter-spacing:.3px}
.pill.modebadge.normal{background:#22406a;color:#cfe0ff}
.pill.modebadge.hardcore{background:#7a1f2b;color:#ffd7dc;box-shadow:0 0 10px -2px #ff5a6a}
.pill.modebadge.infinity{background:#5a2a7a;color:#efd7ff}

/* connection-lost / reconnected banner (never logs you out) */
#conn-banner{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:300;
  padding:9px 18px;border-radius:12px;font-size:13px;font-weight:700;
  box-shadow:0 8px 26px rgba(0,0,0,.55)}
#conn-banner.down{background:#7a1f2b;color:#ffd7dc}
#conn-banner.up{background:#1f6b3a;color:#d7ffe4}

#bottombar{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;z-index:6}
.navbtn{background:rgba(22,29,49,.9);border:1px solid var(--line);color:var(--text);
  padding:12px 18px;border-radius:13px;font-weight:700;font-size:14px;backdrop-filter:blur(6px)}
.navbtn:hover{border-color:var(--gold);color:var(--gold)}
.navbtn.play{background:linear-gradient(var(--gold),var(--gold2));color:#20160a;border:0;
  font-size:15px;padding:12px 26px}

#chatbox{position:absolute;left:14px;bottom:16px;width:280px;z-index:6}
#chatlog{max-height:150px;overflow-y:auto;font-size:12px;margin-bottom:6px;
  display:flex;flex-direction:column;gap:3px}
#chatlog .cm{background:rgba(13,18,32,.65);padding:4px 8px;border-radius:8px;width:fit-content;max-width:100%}
#chatlog .cm b{color:var(--gold)}
#chatinput{width:100%;padding:8px 11px;background:rgba(22,29,49,.9);border:1px solid var(--line);
  border-radius:10px;color:var(--text);font-size:13px}

/* nametags */
#labels{position:absolute;inset:0;pointer-events:none;z-index:4;overflow:hidden}
.nametag{position:absolute;transform:translate(-50%,-100%);white-space:nowrap;font-size:12px;
  font-weight:700;text-shadow:0 1px 3px #000;padding:1px 6px;background:rgba(13,18,32,.55);
  border-radius:8px}
.nametag .tag{color:var(--gold)}

/* ---------------- WINDOWS ---------------- */
.window{position:absolute;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  box-shadow:0 18px 50px rgba(0,0,0,.55);z-index:20;display:flex;flex-direction:column;overflow:hidden}
.window .titlebar{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;
  background:var(--panel2);cursor:grab;border-bottom:1px solid var(--line)}
.window .titlebar b{font-size:15px}
.window .close{background:none;border:0;color:var(--muted);font-size:20px;line-height:1}
.window .close:hover{color:var(--red)}
.window .body{padding:14px;overflow-y:auto;flex:1}
.window-fs{inset:0 !important;width:auto !important;height:auto !important;border-radius:0}

/* grids & cards */
.grid{display:grid;gap:10px}
.card{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:11px}
.card h4{font-size:14px;margin-bottom:3px}
.card .desc{color:var(--muted);font-size:11px;line-height:1.35;min-height:30px}
.card .stat{font-size:11px;color:var(--muted);margin-top:5px}
.card .emoji{font-size:26px}
.locked{opacity:.55}
.equipped{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
.btn{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:7px 10px;
  border-radius:9px;font-weight:700;font-size:12px;width:100%;margin-top:7px}
.btn.buy{background:linear-gradient(var(--gold),var(--gold2));color:#20160a;border:0}
.btn.danger{border-color:var(--red);color:var(--red)}
.btn.small{width:auto;padding:5px 10px;margin:0}
.btn:disabled{opacity:.4;cursor:default}

.maptile{display:flex;flex-direction:column;gap:8px;text-align:center}
.maptile .banner{height:74px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:30px;color:#fff;text-shadow:0 2px 6px #000}
.modes{display:flex;gap:6px}
.modes .btn{margin:0}
.rowbtns{display:flex;gap:6px;flex-wrap:wrap}

/* leaderboard / clan lists */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:7px 8px;text-align:left;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
tr.me{background:rgba(255,207,92,.12)}
.rank{color:var(--gold);font-weight:800;width:38px}
.role{font-size:10px;padding:2px 6px;border-radius:6px;background:var(--panel);color:var(--muted)}
.role.leader{background:var(--gold);color:#20160a}
.role.coleader{background:var(--blue);color:#08111f}
.bar{height:6px;border-radius:4px;background:var(--panel);overflow:hidden;margin-top:4px}
.bar > i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2))}

.clanchat{height:140px;overflow-y:auto;background:var(--bg);border:1px solid var(--line);
  border-radius:10px;padding:8px;font-size:12px;display:flex;flex-direction:column;gap:4px;margin-top:8px}
.clanchat b{color:var(--gold)}
.field{display:flex;flex-direction:column;gap:4px;margin-bottom:9px}
.field label{font-size:11px;color:var(--muted)}
.field input,.field select,.field textarea{padding:9px;background:var(--panel2);border:1px solid var(--line);
  border-radius:9px;color:var(--text);font-size:13px;width:100%}

/* ---------------- MATCH ---------------- */
#match-root{position:fixed;inset:0;background:#05070d;z-index:40}
#match-root canvas{display:block}
.mhud{position:absolute;z-index:3;pointer-events:none}
#m-top{top:12px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
#m-top .pill{pointer-events:auto}
#m-tray{bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;pointer-events:auto}
.tcard{background:rgba(22,29,49,.92);border:1px solid var(--line);border-radius:11px;padding:8px 10px;
  text-align:center;min-width:74px;cursor:pointer}
.tcard.sel{border-color:var(--gold);box-shadow:0 0 12px rgba(255,207,92,.5)}
.tcard.cant{opacity:.5}
.tcard .e{font-size:22px}
.tcard .n{font-size:10px;color:var(--muted)}
.tcard .c{font-size:11px;color:var(--gold);font-weight:700}
#m-wave{top:12px;left:14px}
#m-controls{top:12px;right:14px;display:flex;gap:8px;pointer-events:auto}
.hbar{position:absolute;height:5px;border-radius:3px;background:#3a0d12;overflow:hidden;pointer-events:none;z-index:2}
.hbar > i{display:block;height:100%;background:linear-gradient(90deg,#ff5a6a,#ffb020)}
#m-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:5;
  background:rgba(5,7,13,.75)}
.result{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:30px;text-align:center;width:330px}
.result h2{font-size:26px;margin-bottom:8px}
.result .win{color:var(--green)} .result .lose{color:var(--red)}
.reward{font-size:15px;margin:12px 0;color:var(--gold)}
.sel-hint{position:absolute;bottom:70px;left:50%;transform:translateX(-50%);color:var(--muted);
  font-size:12px;background:rgba(13,18,32,.7);padding:5px 12px;border-radius:10px;pointer-events:none}

/* ---------------- TOAST ---------------- */
#toast{position:absolute;top:60px;left:50%;transform:translateX(-50%);z-index:60;
  display:flex;flex-direction:column;gap:8px;align-items:center}
.tmsg{background:var(--panel);border:1px solid var(--gold);color:var(--text);padding:10px 18px;
  border-radius:12px;font-weight:600;font-size:14px;animation:pop .3s;box-shadow:0 8px 30px rgba(0,0,0,.5)}
@keyframes pop{from{transform:translateY(-12px);opacity:0}}

/* ---------------- TUTORIAL ---------------- */
/* overlay never blocks clicks, only the box is interactive, so the highlighted button stays clickable */
#tutorial{position:fixed;inset:0;z-index:70;pointer-events:none}
.tut-box{position:absolute;bottom:96px;left:50%;transform:translateX(-50%);width:min(360px,92vw);
  background:var(--panel);border:1px solid var(--gold);border-radius:14px;padding:18px;text-align:center;
  pointer-events:auto;box-shadow:0 10px 40px rgba(0,0,0,.6)}
.tut-box.top{bottom:auto;top:70px}
.tut-box p{font-size:14px;line-height:1.5;margin-bottom:12px}
.tut-box .btn{width:auto;padding:8px 20px;margin:0 auto;background:var(--gold);color:#20160a;border:0}
/* tutorial: the thing to click BLINKS gold (no screen dimming) */
.tut-blink{animation:tutblink 1s infinite;outline:3px solid var(--gold);outline-offset:3px;border-radius:12px;position:relative;z-index:71}
@keyframes tutblink{
  0%,100%{outline-color:var(--gold);box-shadow:0 0 18px rgba(255,207,92,.85)}
  50%{outline-color:transparent;box-shadow:none}
}

/* ---------------- TRAY BADGE ---------------- */
.tcard{position:relative}
.selbadge{position:absolute;top:-9px;left:50%;transform:translateX(-50%);background:var(--gold);color:#20160a;
  font-size:9px;font-weight:800;padding:1px 6px;border-radius:6px;white-space:nowrap;box-shadow:0 2px 6px rgba(0,0,0,.4)}

/* ---------------- MOBILE / TOUCH ---------------- */
#toast{position:fixed}
#scene canvas,#match-root canvas{touch-action:none}

#joystick{position:fixed;bottom:96px;left:22px;width:120px;height:120px;border-radius:50%;
  background:rgba(22,29,49,.4);border:2px solid var(--line);z-index:60;touch-action:none}   /* above #match-root(40)! */
#joyknob{position:absolute;left:50%;top:50%;width:52px;height:52px;margin:-26px 0 0 -26px;border-radius:50%;
  background:rgba(255,207,92,.85);border:2px solid var(--gold)}

@media (max-width: 820px), (pointer: coarse) {
  #topbar{top:8px;right:8px;gap:5px}
  .pill{padding:5px 9px;font-size:12px}
  #bottombar{bottom:10px;gap:5px;width:97vw;justify-content:center;flex-wrap:wrap}
  .navbtn{padding:9px 11px;font-size:12px;border-radius:10px}
  .navbtn.play{padding:9px 16px;font-size:13px}
  #chatbox{display:none}
  .window{width:min(95vw,560px) !important;max-height:min(82vh,660px) !important;
    left:calc(50vw - min(47.5vw,280px)) !important;top:6vh !important}   /* iPad: not full width */
  .grid[style*="1fr 1fr"]{grid-template-columns:1fr 1fr}
  #m-tray{max-width:97vw;overflow-x:auto;padding-bottom:4px}
  .tcard{min-width:62px;padding:6px 7px}
  .tcard .e{font-size:20px}
  .sel-hint{font-size:11px;width:94vw;bottom:98px;line-height:1.35}
  #m-controls{top:8px;right:8px;gap:5px}
  #m-controls .navbtn{padding:8px 10px;font-size:12px}
  #m-top{top:44px;left:8px;transform:none;gap:5px;justify-content:flex-start;max-width:none}
  #m-top .pill:nth-child(3){display:none}   /* hide map-name pill on phones */
  #m-wave .pill{font-size:12px}
  .result{width:90vw}
  .login-card{width:90vw}
  #m-players{top:96px;left:8px}
  .pchip{font-size:11px;padding:3px 7px}
  .wait-card{width:92vw;padding:20px}
  #invitebox{width:94vw;flex-wrap:wrap}
}

/* ---------------- CO-OP: waiting room, rooms list, invites ---------------- */
#wait-overlay{position:fixed;inset:0;z-index:70;display:flex;align-items:center;justify-content:center;
  background:rgba(5,7,13,.78)}
.wait-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px;
  text-align:center;width:400px;max-height:84vh;overflow-y:auto}
.wait-card h2{margin-bottom:4px}
.wait-players{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.pchip{display:flex;align-items:center;gap:6px;background:rgba(22,29,49,.92);border:1px solid var(--line);
  border-radius:20px;padding:4px 10px;font-size:12px}
.pchip i{width:10px;height:10px;border-radius:50%;flex:none}
.pchip.big{font-size:14px;padding:7px 14px}
.pchip.me{border-color:var(--gold)}
.pchip b{color:var(--gold);font-weight:600}
.invite-list{margin-top:12px;border-top:1px solid var(--line);padding-top:10px;text-align:left}
#m-players{position:absolute;top:56px;left:14px;display:flex;flex-direction:column;gap:5px;z-index:3;pointer-events:none}
/* PvP duel scoreboard: YOU vs OPPONENT */
#m-vs{top:56px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:10px;z-index:3;pointer-events:none}
#m-vs .vs-side{display:flex;flex-direction:column;align-items:center;background:rgba(13,18,32,.82);border:1px solid var(--line);border-radius:12px;padding:5px 12px;min-width:88px}
#m-vs .vs-side b{font-size:12px;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#m-vs .vs-side span{font-size:15px;font-weight:700}
#m-vs .vs-side.me{border-color:#3aa0ff}
#m-vs .vs-side.opp{border-color:#ff5a5a}
#m-vs .vs-side.lead span{color:var(--gold)}
#m-vs .vs-mid{font-size:20px}
@media(max-width:760px){#m-vs{top:80px;gap:6px}#m-vs .vs-side{min-width:64px;padding:4px 8px}#m-vs .vs-side b{font-size:10px;max-width:70px}}
#invitebox{position:fixed;bottom:86px;left:50%;transform:translateX(-50%);z-index:75;
  display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--gold);
  border-radius:14px;padding:10px 14px;font-size:13px;box-shadow:0 6px 24px rgba(0,0,0,.5)}
.roomsbox{margin-bottom:10px}
.proom{display:flex;align-items:center;gap:8px;background:rgba(22,29,49,.7);border:1px solid var(--line);
  border-radius:10px;padding:7px 10px;margin-bottom:6px;font-size:13px}
.modes.coop{margin-top:6px;display:flex;gap:6px;align-items:center}
.coopmode{flex:0 0 auto;max-width:96px;font-size:12px;padding:5px}
.navbtn.small{padding:7px 11px;font-size:12px}

/* ---- "join other rounds" button (Play) + public-room browser window ---- */
.joinrooms-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:12px;font-size:15px;padding:12px}
.jr-main{font-weight:800}
.jr-count{min-width:24px;height:24px;padding:0 7px;border-radius:12px;display:inline-flex;
  align-items:center;justify-content:center;font-size:12px;font-weight:800;background:rgba(0,0,0,.28);color:#cfe0ff}
.jr-count.hot{background:#e23a4e;color:#fff;box-shadow:0 0 10px -1px #ff5a6a;animation:jrpulse 1.4s ease-in-out infinite}
@keyframes jrpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}

.rb-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.roombrowser{display:flex;flex-direction:column;gap:10px}
.rbcard{display:flex;align-items:center;gap:12px;background:var(--panel2);border:1px solid var(--line);
  border-radius:12px;padding:10px}
.rb-banner{flex:0 0 auto;width:56px;height:56px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:28px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.rb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.rb-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rb-top b{font-size:15px}
.rb-players{font-size:12px;letter-spacing:1px}
.rb-join{flex:0 0 auto;width:auto;margin-top:0;padding:9px 16px;align-self:center}
.rb-join.off{opacity:.5;cursor:default;filter:grayscale(.6)}
.rb-empty{text-align:center;padding:34px 10px;color:#c7cede}
.rb-empty.hidden{display:none}

/* ================= BATCH 14: events / dailies / quests / stats / news ========= */
.pill.tickets{background:#3a2d0e;color:#ffe08a}

.playtabs{margin-bottom:10px}
.summerhead{background:linear-gradient(160deg,rgba(46,197,214,.28),rgba(255,210,63,.12));border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.summerhead h3{margin:0}
.maptile.summer{border-color:#ffd23f}
.pvpcard{padding:22px}

/* daily bonus strip */
.daystrip{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.daycell{flex:1;min-width:50px;text-align:center;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:7px 4px;font-size:11px}
.daycell .dn{display:block;color:var(--muted);margin-bottom:3px}
.daycell.past{opacity:.5}
.daycell.cur{border-color:var(--gold);box-shadow:0 0 12px -3px var(--gold);background:#2a230c}

/* quests */
.questrow{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:8px 10px;margin-bottom:7px}
.questrow.done{border-color:var(--green)}
.qtext{flex:1;min-width:0}
.qtext .bar{height:7px;background:#0d1428;border-radius:5px;overflow:hidden;margin:5px 0 3px}
.qtext .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2))}
.qreward{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;gap:4px;align-items:flex-end}

/* stats grid */
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.statcell{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px}
.statcell b{display:block;font-size:20px;color:var(--gold)}
.statcell span{font-size:12px;color:var(--muted)}

/* news */
.newsitem{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:8px}
.newshead{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px}
.newshead b{font-size:14px}
.newsbody{font-size:13px;color:#cdd6e6;white-space:pre-wrap}
.newslist{max-height:52vh;overflow:auto}

/* match summary (end screen) */
.matchsum{margin:8px auto 0;text-align:left;max-width:340px}
.sumrow{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-bottom:1px solid var(--line);font-size:14px}
.sumtable{width:100%;margin-top:8px;border-collapse:collapse;font-size:13px}
.sumtable th,.sumtable td{padding:4px 6px;text-align:left;border-bottom:1px solid var(--line)}
.sumtable tr.me td{color:var(--gold)}

/* login popups (daily / news) */
.pop-overlay{position:fixed;inset:0;z-index:120;background:rgba(5,8,16,.72);display:flex;align-items:center;justify-content:center;padding:16px}
.popcard{background:var(--panel);border:1px solid var(--gold);border-radius:16px;padding:22px;max-width:360px;width:100%;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,.6)}
.popcard.wide{max-width:460px;text-align:left}
.popcard h2{margin-bottom:6px}
.bigreward{font-size:34px;font-weight:800;color:var(--gold);margin:8px 0}
.popcard .navbtn,.popcard .btn{width:100%}

/* ===================== BATCH 14b: nicer clan UI ===================== */
.clancreate{background:linear-gradient(150deg,rgba(255,207,92,.10),var(--panel))}
.clanbanner{background:linear-gradient(150deg,rgba(255,207,92,.16),rgba(22,29,49,.6));border:1px solid var(--gold);border-radius:14px;padding:14px;margin-bottom:6px}
.clanbanner-top{display:flex;align-items:center;gap:12px}
.clanname{margin:0;font-size:19px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.clanlvl-big{flex:0 0 auto;background:rgba(255,207,92,.15);color:var(--gold);border:1px solid var(--gold);border-radius:10px;padding:6px 12px;font-weight:800;font-size:14px}
.clantag-badge{flex:0 0 auto;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:linear-gradient(var(--gold),var(--gold2));color:#20160a;font-weight:800;border-radius:12px;font-size:15px;box-shadow:0 3px 10px -2px rgba(0,0,0,.5)}
.clantag-badge.big{width:60px;height:60px;font-size:17px}
.xpwrap{position:relative;margin-top:10px}
.bar.big{height:16px;border-radius:8px}
.xplabel{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.85)}
.chiprow.tight{margin:4px 0}

.clancard{display:flex;align-items:center;gap:11px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:8px}
.clancard-mid{flex:1;min-width:0}
.clancard-name{display:flex;align-items:center;gap:8px}
.clancard-name b{font-size:15px}
.clanjoin{flex:0 0 auto;width:auto;margin-top:0;padding:9px 14px}
.clanjoin.off{opacity:.5;filter:grayscale(.6);cursor:default}

.clantable{width:100%;border-collapse:collapse}
.clantable td,.clantable th{padding:6px 6px;border-bottom:1px solid var(--line);vertical-align:middle}
.clantable th{font-size:11px;color:var(--muted);text-align:left}
.clantable .rank{text-align:center;font-size:15px;width:30px}
.clantable tr.me td{color:var(--gold)}
.mrow{display:flex;align-items:center;gap:7px}
.bar.mini{height:5px;width:110px;margin-top:3px}

/* ---------------- RARITIES / CRATES ---------------- */
.r-basic{--rc:#9aa5b8} .r-rare{--rc:#4da6ff} .r-epic{--rc:#b366ff}
.r-legendary{--rc:#ffcf5c} .r-mythic{--rc:#ff4d6a} .r-secret{--rc:#00ffd0}
.rchip{display:inline-block;padding:2px 9px;border-radius:8px;font-size:11px;font-weight:700;
  background:var(--rc,#9aa5b8);color:#0d1220;margin:3px 0}
.card.rar{border-color:var(--rc);border-top:3px solid var(--rc);text-align:center;position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,.035),transparent 45%),var(--panel2)}
.card.rar .emoji{font-size:34px;filter:drop-shadow(0 3px 8px rgba(0,0,0,.55));margin:2px 0 4px}
.card.rar.equipped{box-shadow:0 0 0 1px var(--gold) inset,0 0 16px -4px var(--gold)}
.eqbadge{position:absolute;top:7px;right:7px;background:var(--gold);color:#20160a;font-weight:800;
  font-size:12px;width:20px;height:20px;line-height:20px;border-radius:50%;text-align:center}
.cratecard{border:1px solid var(--gold);text-align:center;
  background:radial-gradient(120% 90% at 50% 0%,rgba(255,207,92,.10),transparent 55%),var(--panel2)}
.cratecard h4{font-size:16px}
.cratecard .rowbtns{justify-content:center}
.crate-results{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;justify-content:center}
.crate-res{border:2px solid var(--rc,#9aa5b8);border-radius:12px;padding:8px 10px;text-align:center;
  background:rgba(22,29,49,.9);min-width:86px;animation:crate-pop .35s ease;
  box-shadow:0 0 12px -4px var(--rc,transparent)}
.crate-res .e{font-size:26px}
.crate-res .n{font-size:12px;font-weight:600}
@keyframes crate-pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.chance-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:9px;margin-bottom:4px;
  background:rgba(22,29,49,.6);border:1px solid var(--line);border-left:3px solid var(--rc,var(--line))}
.chance-row .pct{color:var(--rc);min-width:44px;font-size:14px}
.chance-row .units{font-size:12px;color:var(--muted);flex:1}

/* ---------------- TOWER UPGRADE PANEL ---------------- */
.upg-card{position:fixed;bottom:160px;left:50%;transform:translateX(-50%);z-index:6;
  background:var(--panel);border:1px solid var(--gold);border-radius:14px;padding:14px 20px;
  text-align:center;box-shadow:0 8px 30px rgba(0,0,0,.55);min-width:230px}
.upg-card h4{margin-bottom:4px}
.upg-stats{font-size:13px;margin-top:5px}
.upg-stats b{color:var(--green)}

/* ---------------- MATCH CHAT / CORE HUD / LEADERBOARD TABS / CLAN ---------------- */
#m-chat{left:14px;bottom:130px;width:250px;pointer-events:auto;z-index:4}
#mc-log{max-height:118px;overflow-y:auto;font-size:12px;background:rgba(13,18,32,.55);border-radius:10px;
  padding:6px 8px;margin-bottom:5px}
#mc-log .cm{margin-bottom:2px;text-shadow:0 1px 2px #000}
#mc-log b{color:var(--gold)}
#mc-in{width:100%;background:rgba(13,18,32,.75);border:1px solid var(--line);border-radius:9px;color:#fff;
  padding:7px 10px;font-size:12px}
#m-chat.collapsed{display:none}
#m-chatbtnwrap{top:56px;right:14px;pointer-events:auto}
#corehud{position:fixed;left:10px;bottom:6px;z-index:80;pointer-events:none;
  color:#596480;font-size:11px;letter-spacing:.3px}
.lbtabs{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.lbtabs .btn{width:auto;flex:1;white-space:nowrap;margin-top:0}
.lbreset{color:var(--gold);margin-bottom:8px}
.clanhead .clantitle{display:flex;align-items:center;gap:9px}
.clantag{background:var(--gold);color:#20160a;font-weight:800;border-radius:8px;padding:3px 9px;font-size:13px}
.clanlvl{margin-left:auto;background:rgba(255,207,92,.15);color:var(--gold);border:1px solid var(--gold);
  border-radius:9px;padding:2px 9px;font-size:12px;font-weight:700}
.chiprow{display:flex;gap:7px;flex-wrap:wrap;margin:9px 0}
.chip{background:rgba(22,29,49,.9);border:1px solid var(--line);border-radius:9px;padding:4px 10px;font-size:12px}
.chip.gold{border-color:var(--gold);color:var(--gold)}
html,body{touch-action:manipulation}
@media (max-width:820px),(pointer:coarse){
  #m-chat{left:8px;bottom:150px;width:210px}
}
@media (max-width:820px),(pointer:coarse){
  .upg-card{bottom:190px;min-width:200px;padding:10px 14px}
  .crate-res{min-width:72px}
}

/* ---------------- SETTINGS (shirt color, language) ---------------- */
.shirtgrid{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.shirt{width:42px;height:42px;border-radius:11px;border:2px solid var(--line);cursor:pointer;
  color:#fff;font-weight:800;font-size:15px;text-shadow:0 1px 2px #000}
.shirt.sel{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,207,92,.35)}
.langsel{width:100%;background:#161d31;color:#e8ecf5;border:1px solid var(--line);border-radius:9px;
  padding:9px 10px;font-size:14px;margin-bottom:12px}

/* ---------------- active skills: match bar (right side) ---------------- */
#m-skills{right:12px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;pointer-events:auto;z-index:4}
.skillbtn{position:relative;width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.28);
  background:rgba(13,18,34,.85);cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 10px rgba(0,0,0,.45);transition:transform .1s,border-color .15s}
.skillbtn .ske{font-size:26px;line-height:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.6))}
.skillbtn:hover{transform:scale(1.08)}
.skillbtn:active{transform:scale(.94)}
.skillbtn.aim{border-color:var(--gold);box-shadow:0 0 0 4px rgba(255,207,92,.35),0 3px 10px rgba(0,0,0,.45);animation:skpulse 1s infinite}
.skillbtn.cooldown{border-color:rgba(255,255,255,.12);cursor:default}
.skillbtn.cooldown .ske{opacity:.25;filter:grayscale(1)}
.skillbtn .skcd{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:17px;color:#fff;text-shadow:0 1px 3px #000;pointer-events:none}
@keyframes skpulse{0%,100%{box-shadow:0 0 0 4px rgba(255,207,92,.35)}50%{box-shadow:0 0 0 8px rgba(255,207,92,.15)}}

/* slow-motion screen tint (Zeitlupe) */
#slowmo-ov{position:absolute;inset:0;background:rgba(60,140,255,.14);opacity:0;transition:opacity .6s;pointer-events:none;z-index:2}
#slowmo-ov.on{opacity:1}

/* ---------------- skills window (lobby) ---------------- */
.skillhead{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.skillcount{font-weight:800;color:var(--gold);white-space:nowrap}
.skillcard{display:flex;gap:12px;align-items:center;background:#141b2f;border:1px solid var(--line);
  border-radius:13px;padding:11px 12px;margin-bottom:8px}
.skillcard .ske{font-size:32px;flex:0 0 auto;filter:drop-shadow(0 2px 3px rgba(0,0,0,.5))}
.skillcard.eq{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,207,92,.18)}
.skillcard.locked{opacity:.75}
.skillcard.locked .ske{filter:grayscale(1);opacity:.5}
.skinfo{flex:1;min-width:0}
.skname{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.skbadge{font-size:11px;font-weight:800;color:#1a1305;background:var(--gold);border-radius:7px;padding:2px 7px}
.skmeta{font-size:12px;color:#9aa7c7;margin-top:3px}
.skside{flex:0 0 auto;display:flex;flex-direction:column;gap:4px;align-items:flex-end;max-width:130px}
.skside .btn{width:auto;margin-top:0;padding:8px 14px}
.stat.small{font-size:11px}

@media (max-width:820px){
  #m-skills{right:6px;gap:7px}
  .skillbtn{width:46px;height:46px}
  .skillbtn .ske{font-size:22px}
  .skillbtn .skcd{font-size:14px}
}
