:root{
  --bg:#10131c; --bg2:#1a2030; --card:#202840; --card2:#283255;
  --ink:#eef2ff; --muted:#9aa6c8; --accent:#ffcf3f; --accent2:#ff5d73;
  --green:#5bd97a; --line:#33406b;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:'Nunito',system-ui,sans-serif;color:var(--ink);
  background:radial-gradient(1200px 600px at 50% -10%,#2a3358,#10131c 60%);
  overflow:hidden;
}
.screen{display:none;position:absolute;inset:0;overflow:auto}
.screen.active{display:block}
.hidden{display:none !important}
.muted{color:var(--muted)}
.error{color:var(--accent2);min-height:1.2em;font-weight:700;margin-top:8px}

/* HOME */
.home-wrap{max-width:980px;margin:0 auto;padding:28px 18px 40px}
.brand{text-align:center;margin:14px 0 26px}
.logo{
  font-family:'Luckiest Guy',cursive;font-size:clamp(48px,9vw,108px);margin:0;
  color:var(--accent);letter-spacing:3px;
  text-shadow:0 4px 0 #b8860b,0 8px 22px rgba(0,0,0,.5);
}
.tag{color:var(--muted);margin:.2em 0 0;font-weight:700}
.home-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.home-cols{grid-template-columns:1fr}}
.card{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
  border-radius:16px;padding:20px;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.card h2{margin:0 0 14px;font-family:'Luckiest Guy',cursive;letter-spacing:1px;color:#fff}
label{display:block;font-weight:800;color:var(--muted);margin:10px 0 6px;font-size:14px}
input{width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--line);
  background:#141a2b;color:var(--ink);font:inherit;font-weight:700}
input:focus{outline:2px solid var(--accent)}
#codeInput{text-transform:uppercase;letter-spacing:4px;text-align:center}

.skin-picker{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:6px}
.skin-picker.small{grid-template-columns:repeat(7,1fr)}
@media(max-width:760px){.skin-picker{grid-template-columns:repeat(5,1fr)}}
.skin-cell{aspect-ratio:1;border:2px solid var(--line);border-radius:12px;background:#141a2b;
  cursor:pointer;display:flex;align-items:center;justify-content:center;padding:2px;transition:.12s}
.skin-cell:hover{border-color:var(--accent)}
.skin-cell.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset;background:#1d2742}
.skin-cell canvas{width:100%;height:100%}
.skin-desc{min-height:2.4em;margin-top:10px;color:var(--muted);font-weight:700;font-size:14px}

/* skin carousel: one big skin with arrows */
.skin-carousel{display:flex;align-items:center;gap:12px;background:#141a2b;border:1px solid var(--line);
  border-radius:14px;padding:12px;margin-top:6px}
.skin-carousel .arrow{width:44px;height:44px;flex:none;border-radius:50%;border:1px solid var(--line);
  background:var(--card2);color:#fff;font-size:22px;font-weight:900;cursor:pointer;line-height:1}
.skin-carousel .arrow:hover{background:var(--accent);color:#211a00}
.skin-carousel .stage{flex:1;text-align:center;min-width:0}
.skin-carousel canvas{width:120px;height:120px}
.skin-carousel.small canvas{width:88px;height:88px}
.skin-carousel .sk-name{font-family:'Luckiest Guy',cursive;font-size:22px;color:var(--accent);margin-top:2px}
.skin-carousel .sk-desc{font-size:13px;color:var(--muted);font-weight:700;min-height:2.2em}

/* team picker */
.team-picker{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.team-cell{flex:1;min-width:70px;border:2px solid var(--line);border-radius:10px;padding:8px;cursor:pointer;
  text-align:center;font-weight:900;background:#141a2b;color:#fff}
.team-cell .dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px;vertical-align:middle}
.team-cell.sel{border-color:#fff;box-shadow:0 0 0 2px #fff inset}
.player-list .pteam{width:10px;height:10px;border-radius:50%;flex:none}

.btn{padding:12px 16px;border:none;border-radius:11px;background:var(--card2);color:#fff;
  font:inherit;font-weight:900;cursor:pointer;transition:.12s;border:1px solid var(--line)}
.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn.primary{background:linear-gradient(180deg,#ffd84d,#f5a623);color:#211a00;border:none}
.btn.ghost{background:transparent}
.btn-row{display:flex;gap:10px;margin-top:16px}
.btn-row .btn{flex:1}
.join-row{display:flex;gap:10px;margin-top:10px}
.join-row input{flex:1}
.btn.full{width:100%;margin-top:10px}

.ranking-list{margin:0;padding-left:0;list-style:none;counter-reset:r}
.ranking-list li{counter-increment:r;display:flex;align-items:center;gap:10px;
  padding:9px 6px;border-bottom:1px solid var(--line);font-weight:800}
.ranking-list li::before{content:counter(r);width:26px;height:26px;flex:none;border-radius:50%;
  background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--accent)}
.ranking-list li:nth-child(1)::before{background:var(--accent);color:#211a00}
.ranking-list .wins{margin-left:auto;color:var(--green)}
.foot{text-align:center;color:var(--muted);margin-top:26px;font-weight:700}

/* LOBBY */
#lobby{display:none;place-items:center}
#lobby.active{display:grid}
.lobby-card{max-width:760px;width:94%;margin:24px auto}
.code{font-family:'Luckiest Guy',cursive;color:var(--accent);letter-spacing:4px}
.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:14px 0}
@media(max-width:640px){.lobby-grid{grid-template-columns:1fr}}
.player-list{list-style:none;padding:0;margin:0}
.player-list li{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;
  background:#141a2b;margin-bottom:7px;font-weight:800}
.player-list canvas{width:34px;height:34px}
.player-list .host{margin-left:auto;color:var(--accent);font-size:12px}
.map-picker{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.map-cell{flex:1;min-width:120px;border:2px solid var(--line);border-radius:12px;padding:10px;
  cursor:pointer;background:#141a2b}
.map-cell.sel{border-color:var(--accent)}
.map-cell b{display:block;color:#fff}
.map-cell span{font-size:12px;color:var(--muted)}

/* GAME */
#game{background:#05070d}
.game-stage{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}
#canvas{width:100%;max-width:100vw;max-height:100vh;image-rendering:auto;background:#0b1020;display:block}
.topbar{position:absolute;top:10px;left:50%;transform:translateX(-50%);display:flex;gap:16px;
  align-items:center;background:rgba(10,14,28,.7);border:1px solid var(--line);
  padding:6px 16px;border-radius:30px;font-weight:900;backdrop-filter:blur(4px)}
.turn-info{color:#fff}
.wind{color:var(--muted);font-size:13px;white-space:nowrap}
.timer{color:var(--accent);min-width:38px;text-align:center}
.mute{background:transparent;border:none;cursor:pointer;font-size:18px;padding:0 2px}
.weapon-bar{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;
  background:rgba(10,14,28,.72);padding:8px;border-radius:14px;border:1px solid var(--line);flex-wrap:wrap;
  max-width:96vw;justify-content:center}
.wpn{position:relative;width:52px;height:52px;border-radius:10px;border:2px solid var(--line);
  background:#141a2b;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#fff;font-weight:900;font-size:10px;text-align:center;padding:2px}
.wpn.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}
.wpn.disabled{opacity:.32;cursor:default}
.wpn .cnt{position:absolute;top:-7px;right:-7px;background:var(--accent2);color:#fff;border-radius:50%;
  min-width:18px;height:18px;font-size:11px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.wpn .key{position:absolute;bottom:-2px;left:3px;color:var(--muted);font-size:9px}
.power-wrap{position:absolute;bottom:78px;left:50%;transform:translateX(-50%);width:240px;height:14px;
  background:rgba(0,0,0,.5);border-radius:8px;overflow:hidden;border:1px solid var(--line);display:none}
.power-wrap.show{display:block}
.power-bar{height:100%;width:0;background:linear-gradient(90deg,#5bd97a,#ffd84d,#ff5d73)}
.toast{position:absolute;top:60px;left:50%;transform:translateX(-50%);background:rgba(10,14,28,.85);
  padding:8px 16px;border-radius:20px;font-weight:800;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1}
.controls-help{position:absolute;bottom:0;left:0;right:0;display:flex;gap:14px;justify-content:center;
  flex-wrap:wrap;padding:4px;font-size:12px;color:var(--muted);background:rgba(0,0,0,.3)}
.controls-help b{color:var(--ink)}
.gameover{position:absolute;inset:0;display:grid;place-items:center;background:rgba(5,7,13,.86);z-index:5}
.gameover .card{text-align:center;max-width:440px}
.winner{font-family:'Luckiest Guy',cursive;font-size:28px;color:var(--accent);margin:10px 0 20px}
