:root{--bg: #13111c;--card: #1e1b2e;--card-2: #2a2640;--text: #f1eefb;--muted: #9b94b8;--accent: #8b5cf6;--accent-2: #06b6d4;--good: #22c55e;--bad: #ef4444;--radius: 14px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:radial-gradient(1200px 800px at 80% -10%,#2c2350 0%,var(--bg) 55%);color:var(--text);min-height:100vh}.app{max-width:520px;margin:0 auto;padding:0 16px 32px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 4px}.logo{font-weight:800;font-size:1.1rem;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.session-chip{font-size:.8rem;color:var(--muted);background:var(--card);padding:6px 12px;border-radius:999px;letter-spacing:.05em}.card{background:var(--card);border:1px solid #322d4d;border-radius:var(--radius);padding:24px 20px;box-shadow:0 10px 40px #00000059}h1{margin:0 0 12px;font-size:1.5rem}h2{margin:20px 0 8px;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.muted{color:var(--muted);font-size:.9rem}.center,.center-text{text-align:center}label{display:block;margin:14px 0 6px;font-size:.9rem;color:var(--muted)}input[type=text],input[type=password],input:not([type]){width:100%;margin-top:6px;padding:14px;font-size:1.05rem;border-radius:10px;border:1px solid #3b3560;background:var(--card-2);color:var(--text);outline:none}input:focus{border-color:var(--accent)}input[type=range]{width:100%;margin-top:10px;accent-color:var(--accent)}.code-input{text-transform:uppercase;letter-spacing:.4em;text-align:center;font-weight:700;font-size:1.4rem!important}button{display:block;width:100%;margin-top:14px;padding:15px;font-size:1.05rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:transform .05s,opacity .2s}button:active{transform:scale(.98)}button:disabled{opacity:.45;cursor:not-allowed}.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#fff}.secondary{background:var(--card-2);color:var(--text);border:1px solid #3b3560}.ghost{background:transparent;color:var(--muted);border:1px solid #3b3560}.ghost.small{width:auto;margin:10px auto 0;padding:8px 18px;font-size:.85rem}.divider{text-align:center;color:var(--muted);margin:18px 0 4px;font-size:.85rem}.join-code-box{text-align:center;background:var(--card-2);border-radius:var(--radius);padding:18px;margin-bottom:8px}.join-code{font-size:3rem;font-weight:800;letter-spacing:.35em;margin:6px 0 2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.player-list{list-style:none;padding:0;margin:8px 0}.player-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--card-2);border-radius:10px;margin-bottom:8px}.player-list li.disconnected{opacity:.4}.badge{font-size:.75rem;background:#3b3560;color:var(--text);padding:4px 10px;border-radius:999px}.badge.good{background:#22c55e33;color:var(--good)}.badge.bad{background:#ef44442e;color:var(--bad)}.topic-badge{max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.question-meta{display:flex;align-items:center;gap:8px;margin-bottom:14px}.timer{margin-left:auto;font-size:1.5rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--accent-2);min-width:2ch;text-align:right}.timer.urgent{color:var(--bad);animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.4}}.question-text{font-size:1.3rem;line-height:1.35}.options{display:grid;gap:10px;margin-top:18px}.option{display:flex;align-items:center;gap:12px;text-align:left;background:var(--card-2);color:var(--text);border:2px solid #3b3560;margin-top:0;font-weight:600;font-size:1rem}.option .letter{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;border-radius:8px;background:#3b3560;font-size:.85rem}.option.selected{border-color:var(--accent);background:#8b5cf626}.option.correct{border-color:var(--good);background:#22c55e26}.option.correct .letter{background:var(--good)}.option.wrong{border-color:var(--bad);background:#ef44441f}.option.dim{opacity:.45}.reveal-results{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px}.standings{list-style:none;padding:0;margin:12px 0}.standings li{display:flex;align-items:center;gap:12px;padding:14px;background:var(--card-2);border-radius:10px;margin-bottom:8px;font-size:1.05rem}.standings li:first-child{border:1px solid rgba(139,92,246,.6)}.standings .rank{width:2.2em}.standings .name{flex:1;font-weight:600}.standings .score{font-weight:800;font-variant-numeric:tabular-nums;color:var(--accent-2)}.spinner{width:44px;height:44px;margin:10px auto 18px;border:4px solid #3b3560;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.checkmark{font-size:2.5rem;color:var(--good);margin:10px 0}.error-text{color:var(--bad);font-size:.9rem;margin:10px 0 0}.topbar-right{display:flex;align-items:center;gap:8px}.leave-btn{width:auto;margin:0;padding:6px 12px;font-size:.78rem;font-weight:600;background:transparent;color:var(--muted);border:1px solid #3b3560;border-radius:999px}.row-actions{display:flex;align-items:center;gap:8px}.kick-btn{width:26px;height:26px;margin:0;padding:0;display:grid;place-items:center;font-size:.85rem;line-height:1;background:transparent;color:var(--muted);border:1px solid #3b3560;border-radius:8px}.kick-btn:hover{color:var(--bad);border-color:var(--bad)}.reconnect-banner{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:#b45309;color:#fff;font-size:.85rem;font-weight:600;z-index:20}.reconnect-dot{width:9px;height:9px;border-radius:50%;background:#fff;animation:pulse 1s infinite}.spectator-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;margin:0 auto 12px;max-width:640px;border:1px solid var(--accent);background:#8b5cf61f;color:var(--text);border-radius:10px;font-size:.85rem;font-weight:600}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--bad);color:#fff;padding:12px 20px;border-radius:10px;font-weight:600;font-size:.9rem;max-width:90vw;box-shadow:0 8px 24px #0006;z-index:10}@media (min-width: 700px){.app{padding-top:16px}h1{font-size:1.7rem}}.chat-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:10px 12px;margin-bottom:10px;background:var(--card-2);border-radius:10px;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.chat-list::-webkit-scrollbar{width:8px}.chat-list::-webkit-scrollbar-track{background:transparent;margin:4px 0}.chat-list::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px;border:2px solid var(--card-2)}.chat-list::-webkit-scrollbar-thumb:hover{background:var(--accent-2)}.chat-msg{font-size:.92rem;line-height:1.35;word-break:break-word}.chat-msg.mine .chat-name{color:var(--accent-2)}.chat-name{font-weight:700;font-size:.82rem;letter-spacing:.01em;color:var(--accent)}.chat-text{font-weight:400;color:var(--text)}.chat-form{display:flex;gap:8px;margin-bottom:4px}.chat-form input{flex:1;min-width:0}.chat-send{flex:0 0 auto;width:auto}.reaction-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:14px}.reaction-btn{display:inline-flex;width:auto;margin:0;padding:6px 12px;font-size:1.4rem;line-height:1;background:var(--card-2);border:1px solid transparent;border-radius:999px;transition:transform .08s,border-color .15s}.reaction-btn:hover{border-color:var(--accent)}.reaction-btn:active{transform:scale(1.25)}.reaction-overlay{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:30}.floating-reaction{position:absolute;bottom:90px;display:flex;flex-direction:column;align-items:center;animation-name:float-up;animation-timing-function:ease-out;animation-fill-mode:forwards;will-change:transform,opacity}.floating-emoji{font-size:2rem;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}.floating-name{margin-top:2px;font-size:.7rem;font-weight:600;color:var(--muted);white-space:nowrap}@keyframes float-up{0%{transform:translateY(0) scale(.6);opacity:0}15%{transform:translateY(-12px) scale(1);opacity:1}to{transform:translateY(-62vh) scale(1);opacity:0}}@keyframes fade-inout{0%,to{opacity:0}20%,80%{opacity:1}}@media (prefers-reduced-motion: reduce){.floating-reaction{animation-name:fade-inout}}
