*{box-sizing:border-box}:root{color-scheme:dark;--bg: #14161f;--surface: #1e2230;--surface-2: #272c3f;--text: #e8eaf2;--muted: #9aa1b5;--accent: #7c6cf0;--accent-hover: #9286f5;--error: #f06c6c;--success: #5fd08a}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}h1{font-size:1.8rem}h2{font-size:1.2rem;margin-top:0}h3{font-size:1rem;margin:.5rem 0}.app{min-height:100vh}.page{max-width:960px;margin:0 auto;padding:1.5rem 1rem}.page-narrow{max-width:480px}.center{text-align:center}.muted{color:var(--muted)}.error{color:var(--error);margin:.5rem 0 0}.highlight{color:var(--success);font-weight:600}.card{background:var(--surface);border-radius:12px;padding:1rem 1.25rem;margin:1rem 0}.row{display:flex;gap:.5rem;align-items:center}.space-between{justify-content:space-between}.field{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--muted)}input,textarea{width:100%;background:var(--surface-2);border:1px solid #3a4158;border-radius:8px;color:var(--text);padding:.6rem .75rem;font-size:1rem;font-family:inherit;resize:vertical}input:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent}button{background:var(--surface-2);border:1px solid #3a4158;border-radius:8px;color:var(--text);padding:.6rem 1.1rem;font-size:1rem;cursor:pointer}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);font-weight:600}button.primary:hover:not(:disabled){background:var(--accent-hover)}.mode-grid,.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.5rem;margin-bottom:1rem}.mode-card{display:flex;flex-direction:column;gap:.25rem;text-align:left;padding:.75rem}.mode-card span{font-size:.8rem;color:var(--muted)}.mode-card.selected{border-color:var(--accent);outline:1px solid var(--accent)}.room-code{font-size:2.4rem;font-weight:700;letter-spacing:.35em;padding:.5rem 0;-webkit-user-select:all;user-select:all}.player-list{list-style:none;margin:0;padding:0}.player-list li{padding:.4rem 0;border-bottom:1px solid var(--surface-2)}.player-list li:last-child{border-bottom:none}.toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:var(--error);color:#fff;padding:.6rem 1.2rem;border-radius:8px;z-index:10;max-width:90vw}.game-layout{max-width:1100px;margin:0 auto;padding:1rem}.game-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .25rem}.timer{font-variant-numeric:tabular-nums;font-weight:700;font-size:1.3rem}.timer.urgent{color:var(--error)}.game-body{display:grid;grid-template-columns:1fr 240px;gap:1rem;align-items:start}.score-panel{background:var(--surface);border-radius:12px;padding:.75rem 1rem}.score-panel ul{list-style:none;margin:0;padding:0}.score-panel li{display:flex;justify-content:space-between;padding:.3rem 0}.score-panel li.me span{color:var(--accent-hover);font-weight:600}.score-panel li.offline{opacity:.4}.subject{color:var(--accent-hover)}.forbidden-chip{display:inline-block;background:var(--surface-2);border:1px solid var(--error);color:var(--error);border-radius:999px;padding:.1rem .6rem;margin:.15rem .25rem .15rem 0;font-size:.85rem}.image-display img{width:100%;max-width:560px;display:block;margin:0 auto;border-radius:12px}.timer-bar{height:6px;background:var(--surface-2);border-radius:3px;max-width:560px;margin:.5rem auto 0;overflow:hidden}.timer-bar-fill{height:100%;background:var(--accent);transition:width 1s linear}.guess-feed{list-style:none;margin:1rem auto 0;padding:0;max-width:560px}.guess-feed li{padding:.3rem 0;color:var(--muted);font-size:.9rem}.guess-feed li.correct{color:var(--success);font-weight:600}.final-ranking{margin:0;padding-left:1.5rem}.final-ranking li{display:flex;justify-content:space-between;padding:.4rem 0}.final-ranking li.me{color:var(--accent-hover);font-weight:600}.spinner{width:36px;height:36px;margin:1rem auto;border:4px solid var(--surface-2);border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:700px){.game-body{grid-template-columns:1fr}.score-panel{order:2}}
