:root{--bg: #1a1a2e;--panel: #23233f;--tile: #2c2c4a;--tile-border: #3d3d63;--fg: #f0f0f5;--muted: #9c9cb8;--accent: #e94560;--accent-dark: #c2334b;--ok: #2ecc71;--win: #f4c542;font-family:system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);min-height:100dvh}h1{font-size:1.5rem;margin:0}h2{font-size:1.05rem;margin:0 0 .6rem}.shell{display:grid;place-content:center;min-height:100dvh;text-align:center;gap:.75rem;padding:1rem}.page{max-width:720px;margin:0 auto;padding:1rem .75rem 3rem;display:flex;flex-direction:column;gap:1rem}.page header{text-align:center}.sub{color:var(--muted);margin:.25rem 0 0;font-size:.9rem}.room-title{color:var(--muted);margin:0}.panel{background:var(--panel);border-radius:14px;padding:1rem;display:flex;flex-direction:column;gap:.75rem;text-align:left}label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--muted)}label.check{flex-direction:row;align-items:center;gap:.5rem}input,select,textarea{font:inherit;color:var(--fg);background:var(--tile);border:1px solid var(--tile-border);border-radius:8px;padding:.6rem}.invite-input{letter-spacing:.15em;font-family:ui-monospace,monospace;text-transform:uppercase}button{font:inherit;color:var(--fg);background:var(--tile);border:1px solid var(--tile-border);border-radius:10px;padding:.6rem 1rem;cursor:pointer}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent-dark);font-weight:600}button.primary:not(:disabled):active{transform:scale(.98)}button.big{padding:.9rem;font-size:1.1rem}button.danger{border-color:var(--accent);color:var(--accent);background:transparent}.row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:end}.row.buttons{align-items:center}.error{color:var(--accent);margin:0}.hint{color:var(--muted);font-size:.85rem;margin:0;text-align:center}.codes{background:var(--tile);border-radius:8px;padding:.75rem;font-size:1.05rem;letter-spacing:.1em;overflow-x:auto;margin:0}code{font-family:ui-monospace,monospace}.card-grid{display:grid;grid-template-columns:repeat(var(--size),1fr);gap:6px}.tile{min-height:clamp(72px,18vw,110px);padding:.45rem .35rem;background:var(--tile);border:1px solid var(--tile-border);border-radius:10px;color:var(--fg);display:flex;align-items:center;justify-content:center;text-align:center;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto;white-space:normal;line-height:1.25;transition:background .15s,transform .1s}.tile.fs-l{font-size:clamp(13px,2.6vw,16px)}.tile.fs-m{font-size:clamp(12px,2.2vw,14px)}.tile.fs-s{font-size:clamp(11px,1.9vw,13px)}button.tile:not(:disabled):active{transform:scale(.94)}.tile.marked{background:var(--accent);border-color:var(--accent-dark);font-weight:600;text-decoration:line-through;text-decoration-thickness:2px}.tile.free{background:var(--panel);color:var(--win);font-weight:700;letter-spacing:.05em}.tile.win{background:var(--win);border-color:var(--win);color:#1a1a2e;animation:pop .5s ease}@keyframes pop{0%{transform:scale(.8)}60%{transform:scale(1.08)}to{transform:scale(1)}}textarea.tile{resize:none;font-size:clamp(12px,2.2vw,14px);text-align:center}textarea.tile:focus{outline:2px solid var(--accent)}.player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.player-list li{display:flex;align-items:center;gap:.5rem;background:var(--tile);border-radius:8px;padding:.5rem .7rem}.player-list li.ready{border-left:3px solid var(--ok)}.player-list .name{font-weight:600;flex:1}.player-list .detail{color:var(--muted);font-size:.85rem}.collapse summary{cursor:pointer;font-weight:600}.waiting{text-align:center;align-items:center}.finished .win-banner h1{font-size:2.2rem}.winner-name{font-size:1.4rem;font-weight:700;color:var(--win);margin:.25rem 0 0}canvas.confetti{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:99}@media(min-width:700px){.tile.fs-l{font-size:16px}.tile.fs-m{font-size:14px}.tile.fs-s{font-size:13px}}
