:root{--bg: #0f0f1a;--bg2: #1a1a2e;--surface: #16213e;--surface2: #1f2b47;--accent: #e94560;--accent2: #f5a623;--green: #27ae60;--text: #f0f0f0;--text-muted: #8892a4;--border: rgba(255, 255, 255, .08);--radius: 12px;--radius-lg: 20px;--shadow: 0 4px 24px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}.error-msg{color:var(--accent);font-size:.9rem;margin-top:.5rem;text-align:center}.error-banner{background:var(--accent);color:#fff;text-align:center;padding:.6rem 1rem;font-weight:600;font-size:.95rem}.loading-spinner{font-size:1.4rem;color:var(--text-muted);text-align:center;padding:4rem}.waiting-sub{color:var(--text-muted);font-size:.9rem;margin-top:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.4rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s,transform .1s;text-decoration:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:not(:disabled):hover{opacity:.88}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:not(:disabled):hover{background:var(--surface)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text)}.btn-large{padding:.9rem 2rem;font-size:1.15rem}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 60% 40%,#1e2a50 0%,var(--bg) 70%);padding:2rem}.landing-card{text-align:center;max-width:520px;width:100%}.game-title{font-size:clamp(3rem,8vw,5.5rem);font-weight:900;letter-spacing:-2px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.4rem}.game-title-sm{font-size:2rem;font-weight:900;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1.5rem}.game-subtitle{color:var(--text-muted);font-size:1.15rem;margin-bottom:2.5rem}.landing-buttons{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.landing-hint{color:var(--text-muted);font-size:.85rem;margin-top:1.5rem}.join-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 40% 60%,#1e2a50 0%,var(--bg) 70%);padding:1.5rem}.join-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 2rem 2.5rem;width:100%;max-width:400px;box-shadow:var(--shadow);text-align:center}.join-card h2{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--text)}.join-form{display:flex;flex-direction:column;gap:.5rem;text-align:left}.join-form label{font-size:.85rem;color:var(--text-muted);margin-top:.5rem;font-weight:600}.join-form input{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1.1rem;padding:.75rem 1rem;width:100%;outline:none;transition:border-color .15s}.join-form input:focus{border-color:var(--accent)}.input-code{font-size:2rem!important;text-align:center;letter-spacing:.3em;font-weight:800!important;text-transform:uppercase}.join-form .btn{margin-top:1.25rem;width:100%}.host-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}.host-page{display:grid;grid-template-rows:auto auto 1fr;grid-template-columns:1fr 220px;grid-template-areas:"header header" "debug  debug" "main   sidebar";min-height:100vh}.host-header{grid-area:header;display:flex;align-items:center;gap:1.5rem;padding:1rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.host-room-code{display:flex;flex-direction:column}.room-code-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.room-code-value{font-size:2rem;font-weight:900;letter-spacing:.2em;color:var(--accent2)}.host-phase-badge{flex:1;font-size:1.1rem;font-weight:600;color:var(--text-muted)}.host-controls{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.debug-panel{grid-area:debug;background:#1a1200;border-bottom:1px solid #3d2e00;padding:.5rem 1rem;font-size:.85rem;color:var(--accent2);display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.host-main{grid-area:main;padding:2rem;overflow-y:auto}.host-sidebar{grid-area:sidebar;background:var(--surface);border-left:1px solid var(--border);padding:1rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.sidebar-player{display:flex;align-items:center;gap:.5rem;font-size:.9rem;padding:.4rem .3rem;border-radius:6px}.sidebar-rank{color:var(--text-muted);font-size:.75rem;width:24px;flex-shrink:0}.sidebar-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-score{font-weight:700;color:var(--accent2)}.host-lobby{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start;max-width:900px}.host-lobby h2{font-size:1.5rem;margin-bottom:1rem}.qr-code{width:240px;height:240px;border-radius:var(--radius);border:4px solid var(--accent2);display:block}.qr-placeholder{width:240px;height:240px;border-radius:var(--radius);background:var(--surface2);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.join-url{margin-top:.75rem;font-size:.85rem;color:var(--text-muted);word-break:break-all}.player-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.player-item{display:flex;align-items:center;gap:.6rem;font-size:1.1rem;padding:.6rem .8rem;background:var(--surface2);border-radius:var(--radius)}.player-item.waiting{color:var(--text-muted);font-style:italic}.player-item.disconnected{opacity:.5}.tag-offline{font-size:.75rem;color:var(--accent)}.player-dot{width:10px;height:10px;border-radius:50%;background:var(--green);flex-shrink:0}.player-item.disconnected .player-dot{background:var(--text-muted)}.host-answering{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;padding:1rem 0}.round-label{font-size:1rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.1em}.prompt-display{font-size:clamp(1.5rem,3.5vw,2.8rem);font-weight:800;max-width:820px;line-height:1.25;color:var(--text)}.submitted-count{font-size:1.1rem;color:var(--text-muted)}.answer-dots{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.answer-dot{width:16px;height:16px;border-radius:50%;transition:background .3s}.answer-dot.answered{background:var(--green)}.answer-dot.waiting{background:var(--surface2);border:2px solid var(--border)}.timer{position:relative;width:80px;height:80px;flex-shrink:0}.timer-ring{width:80px;height:80px}.timer-track{stroke:var(--surface2)}.timer-progress{stroke:var(--accent2);transition:stroke-dasharray .3s}.timer.urgent .timer-progress{stroke:var(--accent)}.timer-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800}.timer.urgent .timer-text{color:var(--accent)}.timer-compact{font-size:1.1rem;font-weight:700;color:var(--accent2);text-align:center;padding:.25rem .75rem;background:var(--surface2);border-radius:8px;display:inline-block}.timer-compact.urgent{color:var(--accent);animation:pulse .8s infinite alternate}@keyframes pulse{0%{opacity:1}to{opacity:.5}}.host-voting{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.voting-answers{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:700px}.voting-answer-card{display:flex;align-items:center;gap:1rem;background:var(--surface2);border-radius:var(--radius);padding:1rem 1.25rem;text-align:left;border:1px solid var(--border)}.answer-letter{font-size:1.5rem;font-weight:900;color:var(--accent2);width:32px;flex-shrink:0}.answer-text{font-size:1.15rem}.host-results{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.results-list{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:700px}.result-card{display:flex;align-items:center;gap:1rem;background:var(--surface2);border-radius:var(--radius);padding:1rem 1.25rem;text-align:left;border:1px solid var(--border);transition:border-color .3s}.result-card.winner{border-color:var(--accent2);background:linear-gradient(90deg,var(--surface2),#2a2000)}.result-rank{font-size:1.25rem;font-weight:800;color:var(--text-muted);width:32px;flex-shrink:0}.result-card.winner .result-rank{color:var(--accent2)}.result-content{flex:1}.result-answer{font-size:1.1rem;font-weight:600;margin-bottom:.2rem}.result-meta{font-size:.85rem;color:var(--text-muted)}.result-points{font-size:1.1rem;font-weight:700;color:var(--green);flex-shrink:0}.host-gameover{display:flex;flex-direction:column;align-items:center;gap:2rem;text-align:center;padding:1rem 0}.gameover-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:900;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gameover-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.leaderboard{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:500px}.leaderboard-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-radius:var(--radius);background:var(--surface2);border:1px solid var(--border);font-size:1.15rem}.leaderboard-row.rank-1{background:linear-gradient(90deg,#2a2000,var(--surface2));border-color:var(--accent2)}.leaderboard-row.rank-2{border-color:#7f8c8d}.leaderboard-row.rank-3{border-color:#8b4513}.lb-rank{font-size:1.5rem;flex-shrink:0}.lb-name{flex:1;font-weight:600}.lb-score{font-weight:800;color:var(--accent2);font-size:1.25rem}.controller-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);max-width:480px;margin:0 auto}.controller-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.ctrl-name{font-weight:700;font-size:.95rem}.ctrl-room{font-size:.8rem;color:var(--text-muted);font-family:monospace;letter-spacing:.1em}.controller-body{flex:1;padding:1.25rem;display:flex;flex-direction:column}.ctrl-waiting{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.75rem;padding:2rem}.waiting-icon{font-size:3rem;color:var(--accent);animation:bounce 1.5s infinite}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.ctrl-waiting p{font-size:1.15rem;font-weight:600}.waiting-players{color:var(--text-muted);font-size:.9rem}.ctrl-answering{display:flex;flex-direction:column;gap:1rem}.ctrl-round{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.ctrl-prompt{font-size:1.3rem;font-weight:700;line-height:1.35;color:var(--text);background:var(--surface);border-radius:var(--radius);padding:1rem 1.1rem;border-left:3px solid var(--accent)}.ctrl-answer-form{display:flex;flex-direction:column;gap:.5rem}.ctrl-answer-form textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1.05rem;padding:.9rem 1rem;width:100%;resize:vertical;min-height:100px;outline:none;font-family:inherit;transition:border-color .15s}.ctrl-answer-form textarea:focus{border-color:var(--accent)}.ctrl-answer-form .btn{width:100%}.char-count{font-size:.75rem;color:var(--text-muted);text-align:right}.ctrl-submitted{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;text-align:center}.submitted-check{font-size:3rem;color:var(--green);font-weight:900}.submitted-answer{background:var(--surface2);border-left:3px solid var(--green);padding:.75rem 1rem;border-radius:0 var(--radius) var(--radius) 0;font-style:italic;text-align:left;width:100%;max-width:340px}.ctrl-voting{display:flex;flex-direction:column;gap:1rem}.vote-instruction{font-size:1.05rem;font-weight:600;color:var(--text-muted)}.ctrl-vote-list{display:flex;flex-direction:column;gap:.75rem}.vote-btn{display:flex;align-items:center;gap:.9rem;background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;text-align:left;cursor:pointer;color:var(--text);font-size:1rem;transition:border-color .15s,background .15s;width:100%}.vote-btn:not(:disabled):hover{border-color:var(--accent);background:var(--surface)}.vote-btn.selected{border-color:var(--green);background:#27ae601f}.vote-btn:disabled:not(.selected){opacity:.5;cursor:not-allowed}.vote-letter{font-size:1.3rem;font-weight:900;color:var(--accent2);width:28px;flex-shrink:0}.vote-text{font-size:1rem;line-height:1.35}.ctrl-results{display:flex;flex-direction:column;gap:1rem}.scoreboard-mini{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.score-row{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;background:var(--surface2);border-radius:var(--radius);border:1px solid var(--border);font-size:.95rem}.score-row.me{border-color:var(--accent)}.score-rank{width:28px;color:var(--text-muted);font-size:.85rem}.score-name{flex:1;font-weight:600}.score-pts{font-weight:800;color:var(--accent2)}.ctrl-gameover{display:flex;flex-direction:column;gap:1.5rem;align-items:center;padding:1rem;text-align:center}.ctrl-gameover h2{font-size:2rem;font-weight:900;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media (max-width: 768px){.host-page{grid-template-columns:1fr;grid-template-rows:auto auto 1fr;grid-template-areas:"header" "debug" "main"}.host-sidebar{display:none}.host-lobby{grid-template-columns:1fr}.qr-code{width:180px;height:180px}}.game-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;margin-top:.5rem}.game-select-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem .5rem;background:var(--surface2);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;transition:border-color .15s,transform .1s;font-size:.85rem;color:var(--text)}.game-select-card:hover:not(.disabled){border-color:var(--accent);transform:translateY(-2px)}.game-select-card.selected{border-color:var(--accent2);background:#38bdf81a}.game-select-card.disabled{opacity:.4;cursor:not-allowed}.game-card-emoji{font-size:2rem}.game-card-name{font-weight:600;text-align:center;font-size:.8rem}.game-card-min{font-size:.7rem;color:var(--text-muted)}.acronym-display{font-size:3rem;font-weight:900;letter-spacing:.15em;color:var(--accent2);text-align:center;margin:1rem 0}.acronym-display-sm{font-size:1.8rem;font-weight:900;letter-spacing:.15em;color:var(--accent2);text-align:center;margin:.5rem 0}.word-chain-display{text-align:center;margin:1rem 0}.current-word{font-size:3rem;font-weight:900;color:var(--accent);margin-bottom:.5rem}.last-letter-hint{font-size:1rem;color:var(--text-muted)}.chain-history{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin:.5rem 0}.chain-word{background:var(--surface2);border-radius:999px;padding:.2rem .75rem;font-size:.85rem;color:var(--text-muted)}.current-player-label{text-align:center;font-size:1.2rem;color:var(--accent2);margin:.5rem 0}.player-status-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.5rem}.player-status-chip{padding:.3rem .75rem;background:var(--surface2);border-radius:999px;font-size:.85rem;font-weight:600}.player-status-chip.eliminated{opacity:.4;text-decoration:line-through}
