*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4f8;--surface:#fff;--surface2:#e8edf4;--border:#cbd5e1;--text:#1e293b;--muted:#64748b;--accent:#6366f1;--green:#10b981;--yellow:#d97706;--red:#ef4444}:root[data-theme=dark]{--bg:#0b0f1a;--surface:#131929;--surface2:#161d30;--border:#1e2d45;--text:#e2e8f0;--muted:#64748b;--accent:#818cf8;--green:#34d399;--yellow:#fbbf24;--red:#f87171}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.game-root{justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:560px;padding:28px}.panel-title{letter-spacing:-.03em;margin-bottom:4px;font-size:1.6rem;font-weight:800}.panel-title span{color:var(--accent)}.panel-sub{color:var(--muted);margin-bottom:16px;font-size:.85rem}.how-to-play{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;margin-bottom:20px;padding:12px 16px;display:flex}.how-to-play p{color:var(--muted);font-size:.85rem;line-height:1.5}.how-to-play strong{color:var(--accent);font-weight:700}.field{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.field label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.75rem;font-weight:700}.field input[type=text]{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:10px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:1rem;transition:border-color .15s}.field input[type=text]:focus{border-color:var(--accent)}.field input[type=text]::placeholder{color:var(--muted)}.field select{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;padding:12px 22px;font-family:inherit;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#0b0f1a}.btn-primary:hover:not(:disabled){opacity:.88}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){border-color:var(--accent)}.btn-full{width:100%}.input-row{align-items:stretch;gap:8px;display:flex}.input-row input[type=text]{flex:1;min-width:0}.btn-icon{white-space:nowrap;flex-shrink:0}.error-msg{border:1px solid var(--red);color:var(--red);text-align:center;background:#f871711a;border-radius:8px;margin-top:12px;padding:10px 14px;font-size:.88rem}.players-list{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.player-row{background:var(--bg);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:.92rem;display:flex}.player-row.me{border-color:var(--accent)}.player-row.disconnected{opacity:.4}.player-name{font-weight:600}.badge{text-transform:uppercase;letter-spacing:.08em;border-radius:20px;padding:3px 8px;font-size:.68rem;font-weight:700}.badge-admin{color:var(--accent);background:#818cf826}.badge-you{color:var(--green);background:#34d3991f}.badge-dc{color:var(--muted);background:#64748b1f}.config-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.config-row label{color:var(--muted);white-space:nowrap;font-size:.85rem}.section-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:10px;font-size:.7rem;font-weight:700}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.countdown-screen{text-align:center}.countdown-number{color:var(--accent);letter-spacing:-.04em;font-size:clamp(5rem,20vw,8rem);font-weight:900;line-height:1;animation:1s ease-out countdown-pop}@keyframes countdown-pop{0%{opacity:.3;transform:scale(1.4)}40%{opacity:1;transform:scale(1)}to{opacity:1;transform:scale(1)}}.countdown-label{color:var(--muted);margin-top:16px;font-size:1rem}.round-badge{color:var(--accent);letter-spacing:.08em;background:#818cf81f;border-radius:20px;margin-bottom:20px;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-block}.target-section{text-align:center;margin-bottom:24px}.target-prompt{color:var(--muted);margin-bottom:8px;font-size:.85rem}.target-word{color:var(--text);letter-spacing:-.03em;font-size:clamp(2rem,8vw,3.5rem);font-weight:900}.guess-row{align-items:stretch;gap:10px;display:flex}.guess-row input[type=text]{background:var(--bg);border:1px solid var(--border);color:var(--text);text-align:right;border-radius:10px;outline:none;flex:1;padding:12px 14px;font-family:inherit;font-size:1rem;transition:border-color .15s}.guess-row input[type=text]:focus{border-color:var(--accent)}.guess-row input[type=text]:disabled{opacity:.5}.waiting-who{color:var(--accent);margin-bottom:4px;font-size:1.1rem;font-weight:700}.waiting-label{color:var(--muted);margin-bottom:20px;font-size:.85rem}.chain-live{flex-direction:column;gap:6px;display:flex}.chain-live-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:.85rem;animation:.3s ease-out slide-in;display:flex}@keyframes slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.chain-live-nick{color:var(--muted);min-width:70px}.chain-live-word{flex:1;font-weight:700}.chain-live-score{font-size:.8rem;font-weight:700}.round-end-title{color:var(--text);margin-bottom:20px;font-size:1.3rem;font-weight:800}.chain-display{flex-direction:column;align-items:center;gap:0;margin-bottom:24px;display:flex}.chain-start-box{background:var(--surface2);border:1px solid var(--border);text-align:center;border-radius:10px;width:100%;max-width:320px;padding:10px 18px}.chain-start-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:4px;font-size:.68rem}.chain-start-word{font-size:1.4rem;font-weight:800}.chain-arrow{color:var(--muted);padding:4px 0;font-size:1.2rem}.chain-entry-box{background:var(--bg);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;width:100%;max-width:320px;padding:10px 18px;animation:.4s ease-out both reveal;display:flex}@keyframes reveal{0%{opacity:0;transform:scale(.95)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.chain-entry-left{flex-direction:column;gap:2px;display:flex}.chain-entry-nick{color:var(--muted);font-size:.78rem}.chain-entry-word{font-size:1.1rem;font-weight:700}.chain-entry-score{border-radius:20px;padding:4px 10px;font-size:1rem;font-weight:800}.score-high{color:var(--green);background:#34d39926}.score-mid{color:var(--yellow);background:#fbbf2426}.score-low{color:var(--muted);background:#64748b1f}.leaderboard{flex-direction:column;gap:8px;display:flex}.lb-row{background:var(--bg);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;padding:10px 14px;animation:.4s ease-out both reveal;display:flex}.lb-row.leader{border-color:var(--yellow);background:#fbbf240d}.lb-rank{color:var(--muted);min-width:24px;font-size:.85rem;font-weight:800}.lb-row.leader .lb-rank{color:var(--yellow)}.lb-name{flex:1;font-weight:600}.lb-score{color:var(--accent);font-size:1rem;font-weight:800}.game-over-header{text-align:center;margin-bottom:24px}.trophy{margin-bottom:8px;font-size:2.5rem}.game-over-title{letter-spacing:-.03em;font-size:1.6rem;font-weight:900}.winner-name{color:var(--accent);margin-top:6px;font-size:1.1rem}.dot-spin{align-items:center;gap:5px;margin-top:8px;display:inline-flex}.dot-spin span{background:var(--muted);border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite bounce}.dot-spin span:nth-child(2){animation-delay:.2s}.dot-spin span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.timer-container{align-items:center;gap:10px;margin-bottom:24px;display:flex}.timer-bar-wrap{background:var(--surface2);border-radius:4px;flex:1;height:6px;overflow:hidden}.timer-bar-fill{border-radius:4px;height:100%;transition:width 1s linear,background-color .5s}.timer-bar-fill.timer-ok{background:var(--green)}.timer-bar-fill.timer-warning{background:var(--yellow)}.timer-bar-fill.timer-urgent{background:var(--red);animation:.6s ease-in-out infinite timer-pulse}.timer-label{text-align:right;min-width:28px;font-size:.8rem;font-weight:700}.timer-label.timer-ok{color:var(--green)}.timer-label.timer-warning{color:var(--yellow)}.timer-label.timer-urgent{color:var(--red)}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.4}}.submissions-list{flex-direction:column;gap:6px;display:flex}.submission-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;animation:.3s ease-out slide-in;display:flex}.submission-item.submitted{border-color:#34d3994d}.submission-item.timed-out{opacity:.5}.submission-nick{font-weight:600}.submission-status{color:var(--muted);font-size:.8rem}.submission-item.submitted .submission-status{color:var(--green)}.my-result-banner{background:#818cf814;border:1px solid #818cf84d;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;animation:.4s ease-out reveal;display:flex}.my-result-word{font-size:1.1rem;font-weight:700}.my-result-score{border-radius:20px;padding:4px 10px;font-size:1rem;font-weight:800}.chain-entry-box.entry-timed-out{opacity:.5;border-style:dashed}.chain-entry-timeout{color:var(--muted);font-size:.88rem;font-style:italic}.game-over-winner-panel{border-color:var(--yellow);box-shadow:0 0 40px #fbbf241f}.winner-celebration{text-align:center;padding:16px 0 8px;position:relative}.confetti-container{pointer-events:none;height:100%;position:absolute;top:0;left:0;right:0;overflow:hidden}.confetti-dot{border-radius:2px;width:8px;height:8px;animation:2s ease-in forwards confetti-fall;position:absolute;top:-10px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(160px)rotate(540deg)}}.winner-trophy{margin-bottom:8px;font-size:4rem;animation:.7s cubic-bezier(.36,.07,.19,.97) both trophy-bounce,2.5s ease-in-out .9s infinite trophy-sway;display:block}@keyframes trophy-bounce{0%{opacity:0;transform:scale(0)rotate(-10deg)}55%{opacity:1;transform:scale(1.35)rotate(6deg)}75%{transform:scale(.92)rotate(-3deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes trophy-sway{0%,to{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}.winner-title{color:var(--yellow);letter-spacing:-.03em;font-size:2.2rem;font-weight:900;animation:.5s ease-out .35s both winner-pop}.winner-subtitle{color:var(--muted);margin-top:4px;font-size:1rem;animation:.5s ease-out .55s both winner-pop}@keyframes winner-pop{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.lb-winner-row{animation:1.8s ease-in-out .8s infinite lb-winner-glow}@keyframes lb-winner-glow{0%,to{box-shadow:0 0 #fbbf2400}50%{box-shadow:0 0 14px #fbbf2466}}.loser-header{text-align:center;margin-bottom:4px;padding:12px 0 4px}.loser-emoji{margin-bottom:8px;font-size:2.8rem;animation:.9s ease-out .2s both loser-droop;display:block}@keyframes loser-droop{0%{opacity:0;transform:translateY(-18px)rotate(-8deg)}55%{transform:translateY(5px)rotate(4deg)}to{opacity:1;transform:translateY(0)rotate(0)}}.winner-announce{color:var(--muted);margin-top:8px;font-size:.9rem}.all-rounds{flex-direction:column;gap:20px;display:flex}.history-round{border:1px solid var(--border);border-radius:12px;overflow:hidden}.history-round-header{background:var(--surface2);color:var(--muted);letter-spacing:.04em;border-bottom:1px solid var(--border);padding:8px 14px;font-size:.8rem;font-weight:700}.history-start-word{color:var(--text);font-weight:800}.history-round .chain-display{padding:8px 14px 12px}.next-round-notice{text-align:center;color:var(--muted);margin-top:16px;font-size:.82rem}.copy-link{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.8rem;text-decoration:underline}.copy-link:hover{opacity:.7}.room-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.room-id-text{color:var(--muted);margin-bottom:18px;font-size:.82rem}.chat-box{margin-top:20px;margin-bottom:4px}.chat-messages{background:var(--bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:5px;max-height:160px;margin-bottom:8px;padding:10px 12px;display:flex;overflow-y:auto}.chat-empty{color:var(--muted);text-align:center;padding:8px 0;font-size:.82rem}.chat-msg{direction:rtl;font-size:.88rem;line-height:1.45}.chat-nick{color:var(--accent);font-weight:700}.chat-text{color:var(--text)}.chat-input-row{align-items:stretch;gap:8px;display:flex}.chat-input-row input[type=text]{background:var(--bg);border:1px solid var(--border);min-width:0;color:var(--text);border-radius:10px;outline:none;flex:1;padding:9px 12px;font-family:inherit;font-size:.92rem;transition:border-color .15s}.chat-input-row input[type=text]:focus{border-color:var(--accent)}.chat-input-row input[type=text]::placeholder{color:var(--muted)}.emoji-bar{border-top:1px solid var(--border);justify-content:center;gap:10px;margin-top:20px;padding-top:16px;display:flex}.emoji-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:8px 12px;font-size:1.8rem;line-height:1;transition:transform .1s;position:relative;overflow:hidden}.emoji-btn:active:not(:disabled){transform:scale(.9)}.emoji-btn:disabled{cursor:not-allowed;opacity:.6}.emoji-btn.cooling:after{content:"";transform-origin:bottom;background:#0000008c;animation:3s linear forwards cooldown-shrink;position:absolute;inset:0}@keyframes cooldown-shrink{0%{transform:scaleY(1)}to{transform:scaleY(0)}}.floating-emojis-container{pointer-events:none;z-index:200;position:fixed;inset:0;overflow:hidden}.floating-emoji{flex-direction:column;align-items:center;gap:4px;animation:3.5s ease-out forwards float-up;display:flex;position:absolute;bottom:18%}.floating-emoji-glyph{filter:drop-shadow(0 2px 8px #0009);font-size:2.6rem;line-height:1}.floating-emoji-nick{color:#e2e8f0d9;white-space:nowrap;background:#00000080;border-radius:20px;padding:2px 7px;font-size:.68rem}@keyframes float-up{0%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0;transform:translateY(-60vh)}}.dual-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;padding:14px 16px 16px;position:relative;overflow:hidden}.dual-word-badge{color:var(--accent);text-align:center;letter-spacing:.02em;margin-bottom:12px;font-size:1.15rem;font-weight:800}.dual-row{align-items:center;gap:8px;margin-bottom:7px;transition:opacity .45s;display:flex}.dual-row-exit{opacity:.4}.dual-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;min-width:68px;display:flex}.dual-ref{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:66px;font-size:.8rem;font-weight:700;overflow:hidden}.dual-role{color:var(--muted);margin-top:1px;font-size:.65rem}.dual-track{background:var(--border);border-radius:5px;flex:1;height:9px;overflow:hidden}.dual-fill{border-radius:5px;height:100%;transition:width 1.1s cubic-bezier(.25,.46,.45,.94)}.dual-fill-chain{background:var(--accent)}.dual-fill-own{background:#f472b6}.dual-num{text-align:right;min-width:34px;color:var(--text);font-size:.88rem;font-weight:700}.dual-num-float{animation:.45s ease-in forwards dual-num-drop}@keyframes dual-num-drop{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(22px)}}.dual-merge{opacity:0;justify-content:center;align-items:center;gap:8px;margin-top:4px;display:flex;transform:translateY(18px)scale(.85)}.dual-merge-in{animation:.45s cubic-bezier(.22,1,.36,1) forwards dual-merge-rise}@keyframes dual-merge-rise{0%{opacity:0;transform:translateY(18px)scale(.85)}to{opacity:1;transform:translateY(0)scale(1)}}.dual-merge-eq{color:var(--muted);font-size:.75rem;font-weight:600}.dual-merge-score{font-size:1.45rem;font-weight:800;line-height:1}.dual-merge-pts{color:var(--muted);align-self:flex-end;padding-bottom:3px;font-size:.75rem}.lobby-root{justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 16px 60px;display:flex}.lobby-panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:640px;padding:28px}.lobby-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;display:flex}.lobby-header-btns{flex-shrink:0;gap:8px;display:flex}.btn-sm{padding:8px 14px;font-size:.82rem}.btn-link{color:var(--accent);font-size:inherit;cursor:pointer;opacity:.8;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:underline}.btn-link:hover{opacity:1}.back-link{color:var(--muted);font-size:.8rem;text-decoration:none}.back-link:hover{color:var(--accent)}.room-list{flex-direction:column;gap:8px;margin-top:20px;display:flex}.room-list-empty{color:var(--muted);text-align:center;padding:32px 0;font-size:.9rem}.room-row{background:var(--bg);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;transition:border-color .15s;display:flex}.room-row:hover{border-color:#818cf859}.room-row-info{flex-direction:column;gap:4px;min-width:0;display:flex}.room-row-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:700;overflow:hidden}.room-row-meta{align-items:center;gap:10px;font-size:.78rem;display:flex}.room-player-count{color:var(--muted)}.room-lock{font-size:.8rem}.room-state{text-transform:uppercase;letter-spacing:.08em;border-radius:20px;padding:2px 8px;font-size:.68rem;font-weight:700}.room-state-waiting{color:var(--green);background:#34d3991f}.room-state-playing{color:var(--yellow);background:#fbbf241f}.room-state-over{color:var(--muted);background:#64748b1f}.room-row-action{flex-shrink:0}.row-password-input{align-items:center;gap:6px;display:flex}.row-password-input input[type=password]{background:var(--surface);border:1px solid var(--accent);color:var(--text);border-radius:8px;outline:none;width:110px;padding:6px 10px;font-family:inherit;font-size:.85rem}.modal-overlay{z-index:500;background:#000000b3;justify-content:center;align-items:center;padding:16px;animation:.15s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:400px;padding:24px 24px 20px;animation:.2s cubic-bezier(.22,1,.36,1) modal-rise}@keyframes modal-rise{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{margin-bottom:20px;font-size:1.1rem;font-weight:800}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.theme-toggle{z-index:600;border:1px solid var(--border);background:var(--surface);width:38px;height:38px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.15rem;line-height:1;transition:border-color .15s,background .15s;display:flex;position:fixed;top:14px;left:14px;box-shadow:0 2px 8px #00000026}.theme-toggle:hover{border-color:var(--accent)}
