*{box-sizing:border-box}html,body{height:100%}body{
  margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:#0b0c10;color:#e5e7eb;
}
.appbar{position:sticky;top:0;display:flex;justify-content:space-between;align-items:center;
  padding:12px 16px;background:#111827;border-bottom:1px solid #1f2937;z-index:10}
.brand{font-weight:800;letter-spacing:.3px}
.room-info{display:flex;gap:8px;align-items:center}
.card{background:#111827;border:1px solid #1f2937;border-radius:16px;padding:16px;margin:16px auto;max-width:700px}
.card.subtle{background:#0f1623}
.hidden{display:none}
h1{margin:0 0 12px 0;font-size:22px}
h2{margin:4px 0 12px 0;font-size:18px}
.field{display:flex;flex-direction:column;gap:6px;margin:8px 0}
input{background:#0b1220;border:1px solid #233048;color:#e5e7eb;border-radius:12px;padding:12px 14px;font-size:16px}
button{border:0;border-radius:14px;padding:10px 14px;font-weight:700;cursor:pointer}
button.primary{background:#2563eb;color:white}
button.ghost{background:transparent;color:#93c5fd;border:1px solid #1f2937}
button.small{padding:6px 10px;font-size:12px}
button.large{font-size:18px;padding:14px 18px}
button.wide{width:100%}
.grid2{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:700px){.grid2{grid-template-columns:1fr 1fr}}
.pill-row{display:flex;gap:8px;flex-wrap:wrap}
.pill{background:#0b1220;border:1px solid #233048;border-radius:999px;padding:8px 12px}
.row{display:flex;gap:10px;align-items:center}
.center{text-align:center}.muted{color:#94a3b8}.bold{font-weight:800}
.game-shell{display:grid;grid-template-rows:auto auto;gap:12px;padding:8px}
.board-wrap{width:100%;max-width:700px;margin:0 auto;background:#0b0c10;border-radius:16px;overflow:hidden;border:1px solid #1f2937}
#board{width:100%;height:auto;display:block;background:#0d1017}
.hud{display:flex;justify-content:center}
.status{display:grid;grid-auto-flow:column;gap:16px;align-items:center}
.dice-area{display:flex;align-items:center;gap:8px}
.dice-val{font-size:28px;font-weight:900;min-width:24px;text-align:center}
.msg{min-height:24px;color:#fbbf24}
.legend{display:flex;gap:10px}
.legend .dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:6px}
.dot.red{background:#ef4444}.dot.blue{background:#3b82f6}.dot.green{background:#22c55e}.dot.yellow{background:#f59e0b}
/* Tokens */
.token{stroke:#0b0c10;stroke-width:2}
.token.red{fill:#ef4444}.token.blue{fill:#3b82f6}.token.green{fill:#22c55e}.token.yellow{fill:#f59e0b}
.cell{stroke:#111827;stroke-width:1}
.safe{fill:#192235}.normal{fill:#0f172a}
.start{opacity:.25}
.locked-glow{filter:url(#glow)}
