*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d26;--border: #2d3148;--text: #e2e8f0;--muted: #8892a4;--primary: #6366f1;--primary-hover: #4f52d9;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:1rem;text-align:center;padding:2rem}.page{max-width:720px;margin:0 auto;padding:2rem 1rem;display:flex;flex-direction:column;gap:1.5rem}header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}h1{font-size:2rem;font-weight:700}h2{font-size:1rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}.subtitle{color:var(--muted);font-size:1.1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;max-width:380px;width:100%}input{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;padding:.6rem .9rem;width:100%;outline:none;transition:border-color .15s}input:focus{border-color:var(--primary)}input::placeholder{color:var(--muted)}button,.btn-primary{background:var(--primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.65rem 1.25rem;transition:background .15s,opacity .15s;display:inline-block;text-decoration:none}button:hover:not(:disabled),.btn-primary:hover{background:var(--primary-hover);text-decoration:none}button:disabled{opacity:.5;cursor:not-allowed}.btn-sm{background:var(--primary);border-radius:6px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .65rem;display:inline-block;text-decoration:none;white-space:nowrap}.btn-sm:hover{background:var(--primary-hover);text-decoration:none}.badge{border-radius:999px;font-size:.7rem;font-weight:700;padding:.2rem .7rem;text-transform:uppercase;letter-spacing:.05em}.badge-waiting{background:#2d3148;color:var(--muted)}.badge-in_progress{background:#0f2d18;color:var(--success)}.badge-finished{background:#2d1a0f;color:var(--warning)}.error{color:var(--danger);font-size:.9rem}.info{color:var(--muted);font-size:.95rem}.player-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}.player-list li{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.35rem .8rem;font-size:.9rem}.player-list li.is-winner{border-color:var(--warning);color:var(--warning)}.game-list{display:flex;flex-direction:column;gap:.5rem}.game-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.65rem 1rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-size:.95rem}.game-card.my-game{border-color:var(--primary)}.vs{color:var(--muted);font-size:.8rem}.game-winner-name{font-weight:700;color:var(--success)}.game-result{margin-left:auto;color:var(--success);font-size:.85rem}.game-status{margin-left:auto;color:var(--muted);font-size:.8rem}.my-game-banner{background:#1a1d3a;border:1px solid var(--primary);border-radius:10px;padding:1rem;text-align:center}.winner-banner{background:linear-gradient(135deg,#1a1d26,#2d2a10);border:1px solid var(--warning);border-radius:12px;color:var(--warning);font-size:1.2rem;font-weight:700;padding:1rem 1.5rem;text-align:center}.share-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.85rem}.share-url{font-family:monospace;color:var(--muted);word-break:break-all;flex:1}.game-header{display:flex;align-items:center;gap:1rem}.timer{font-size:1.5rem;font-weight:800;color:var(--success)}.timer-urgent{color:var(--danger);animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.score{display:flex;align-items:center;justify-content:center;gap:2rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem 2rem}.score-side{display:flex;flex-direction:column;align-items:center;gap:.2rem}.score-side.won .score-num{color:var(--success)}.score-side.lost .score-num{color:var(--danger)}.score-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.score-num{font-size:2.5rem;font-weight:800;line-height:1}.score-sep{font-size:1.5rem;color:var(--border)}.moves{text-align:center}.move-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.btn-move{font-size:1.1rem;padding:.9rem 1.4rem;border-radius:12px;min-width:130px}.result-banner{text-align:center;padding:1.5rem;border-radius:12px;font-size:1.1rem;font-weight:600;display:flex;flex-direction:column;gap:.75rem;align-items:center}.result-banner.win{background:#0a2a0a;border:1px solid var(--success);color:var(--success)}.result-banner.lose{background:#2a0a0a;border:1px solid var(--danger);color:var(--danger)}.round-history{display:flex;flex-direction:column;gap:.4rem}.round-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .9rem;border-radius:8px;font-size:.9rem;flex-wrap:wrap}.round-row.win{background:#0a2a0a}.round-row.lose{background:#2a0a0a}.round-row.draw{background:var(--surface);border:1px solid var(--border)}.round-outcome{margin-left:auto;font-weight:700;font-size:.8rem;text-transform:uppercase}nav{color:var(--muted);font-size:.9rem}
