:root{--bg:#0d0b1a;--bg-2:#171331;--card:#211a45;--line:#322a5c;--text:#f3f1ff;--muted:#a7a0cf;--accent:#ff4d8d;--accent-2:#7c5cff;--good:#2ee6a6;--bad:#ff5b5b;--radius:18px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;margin:0}body{background:radial-gradient(120% 120% at 50% 0%, var(--bg-2) 0%, var(--bg) 60%);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif}#app{min-height:100%}.screen{max-width:560px;padding:max(20px, env(safe-area-inset-top)) 20px calc(28px + env(safe-area-inset-bottom));flex-direction:column;gap:18px;min-height:100vh;margin:0 auto;display:flex}.title{letter-spacing:-.02em;background:linear-gradient(90deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:2.4rem;font-weight:800}.subtitle{color:var(--muted);margin:-8px 0 0}.hint{color:var(--muted);text-align:center;margin:0}.btn{font:inherit;color:var(--text);border-radius:var(--radius);cursor:pointer;border:none;padding:16px 20px;font-weight:700;transition:transform 60ms,filter .15s}.btn:active{transform:scale(.97)}.btn.big{width:100%;min-height:60px;margin-top:auto;font-size:1.15rem}.btn-primary{background:linear-gradient(90deg, var(--accent), var(--accent-2))}.btn-ghost{background:var(--card);border:1px solid var(--line)}.btn-round{background:var(--card);border:1px solid var(--line);border-radius:50%;width:52px;height:52px;font-size:1.5rem;line-height:1}.gate{justify-content:center}.gate-box{text-align:center;flex-direction:column;gap:16px;display:flex}.gate-input{font:inherit;text-align:center;letter-spacing:.25em;text-transform:uppercase;color:var(--text);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:100%;padding:16px 18px;font-size:1.4rem;font-weight:700}.gate-input::placeholder{color:var(--muted);letter-spacing:normal;text-transform:none;font-weight:400}.gate-input:focus{border-color:var(--accent-2);outline:none}.gate-error{color:var(--bad);min-height:1.2em;margin:0;font-size:.9rem}.setup{justify-content:center}.stepper{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.stepper-label{font-weight:600}.stepper-controls{align-items:center;gap:14px;display:flex}.stepper-value{text-align:center;min-width:28px;font-size:1.3rem;font-weight:800}.name-list{gap:10px;display:grid}.name-input{font:inherit;background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:14px;padding:14px 16px}.name-input:focus{outline:2px solid var(--accent-2)}.scores{flex-wrap:wrap;gap:8px;display:flex}.score{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;flex-direction:column;min-width:86px;padding:8px 12px;display:flex}.score-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.score-me .score-name{color:var(--text)}.score-name{color:var(--muted);font-size:.8rem}.score-value{font-size:1.1rem;font-weight:800}.turn-banner{text-align:center;font-size:1.5rem;font-weight:800}.mystery{background:var(--bg-2);border:1px dashed var(--line);border-radius:var(--radius);justify-content:center;align-items:center;gap:12px;padding:18px;font-size:1.2rem;font-weight:700;display:flex}.mystery-disc{font-size:1.8rem;animation:3s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.timeline{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;align-items:stretch;gap:6px;padding:8px 2px 16px;display:flex;overflow-x:auto}.card{background:var(--card);border:1px solid var(--line);scroll-snap-align:center;border-radius:14px;flex-direction:column;flex:none;gap:4px;width:116px;padding:12px 10px;display:flex}.card-new{border-color:var(--good);box-shadow:0 0 0 2px var(--good)}.card-year{color:var(--accent);font-size:1.5rem;font-weight:800}.card-title{font-size:.9rem;font-weight:700;line-height:1.15}.card-artist{color:var(--muted);font-size:.78rem}.gap{flex:none;align-self:stretch;width:14px}.gap-tap{border:2px dashed var(--accent-2);width:46px;color:var(--accent-2);cursor:pointer;background:#7c5cff1f;border-radius:12px;font-size:1.4rem;font-weight:800}.gap-tap:active{background:#7c5cff4d}.timeline-block{flex-direction:column;gap:10px;display:flex}.gap-tap.gap-selected{background:var(--accent-2);color:#fff;border-style:solid;box-shadow:0 0 0 3px #7c5cff73}.confirm-bar{display:none}.confirm-bar.is-visible{display:flex}.confirm-place{flex:1;min-height:56px}.reveal{border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-2);align-items:center;gap:14px;padding:14px;display:flex}.reveal-correct{border-color:var(--good)}.reveal-wrong{border-color:var(--bad)}.reveal-art{object-fit:cover;background:var(--card);border-radius:12px;width:84px;height:84px}.reveal-year{color:var(--accent);font-size:1.8rem;font-weight:800}.reveal-title{font-weight:700}.reveal-artist{color:var(--muted);font-size:.9rem}.reveal-verdict{margin-top:6px;font-weight:700}.reveal-correct .reveal-verdict{color:var(--good)}.reveal-wrong .reveal-verdict{color:var(--bad)}.switcher{flex-wrap:wrap;gap:8px;display:flex}.switch-tab{font:inherit;color:var(--muted);background:var(--bg-2);border:1px solid var(--line);cursor:pointer;border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:700;transition:transform 60ms}.switch-tab:active{transform:scale(.96)}.switch-selected{color:#fff;background:linear-gradient(90deg, var(--accent), var(--accent-2));border-color:#0000}.switch-label{color:var(--muted);margin:0;font-size:.85rem;font-weight:700}.spectating{color:var(--accent-2);font-weight:700}.trophy{font-size:4rem}.standings{text-align:center;flex-direction:column;align-items:center;gap:14px;margin:auto 0;display:flex}.standings-list{flex-direction:column;gap:8px;width:100%;display:flex}.standing-row{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;align-items:center;gap:12px;padding:12px 16px;display:flex}.standing-rank{text-align:center;min-width:1.6em;font-size:1.3rem;font-weight:800}.standing-name{text-align:left;flex:1;font-weight:700}.standing-score{color:var(--accent);font-size:1.2rem;font-weight:800}.standing-winner{border-color:var(--good);box-shadow:0 0 0 1px var(--good)}.standing-me .standing-name{color:var(--accent-2)}@media (orientation:landscape) and (height<=600px){.screen{max-width:860px;min-height:0;padding:max(10px, env(safe-area-inset-top)) 16px calc(14px + env(safe-area-inset-bottom));gap:10px}.title{font-size:1.6rem}.turn-banner{font-size:1.15rem}.mystery{padding:10px;font-size:1rem}.mystery-disc{font-size:1.3rem}.card{width:104px;padding:9px}.card-year{font-size:1.25rem}.reveal-art{width:60px;height:60px}.reveal-year{font-size:1.4rem}.btn.big{min-height:50px;font-size:1.05rem}.trophy{font-size:2.6rem}.gate,.setup,.landing,.waiting,.join{justify-content:center}}.btn-row{gap:10px;margin-top:auto;display:flex}.btn-row .btn{flex:1;min-height:56px;margin-top:0}.qr{width:220px;height:220px;image-rendering:pixelated;background:#fff;border-radius:14px;margin:4px auto;padding:10px;display:block}.room-code{text-align:center;letter-spacing:.15em;font-size:1.2rem;font-weight:800}.join-link{text-align:center;word-break:break-all;opacity:.6;color:inherit;font-size:.78rem;display:block}.roster-name{background:#ffffff0f;border-radius:12px;padding:12px 14px;font-weight:600}.landing,.waiting,.join{text-align:center;justify-content:center;gap:16px}.landing .btn{margin-top:0}.reconnect-banner{text-align:center;color:var(--text);background:var(--card);border:1px solid var(--accent-2);border-radius:999px;margin-bottom:14px;padding:8px 14px;font-size:.85rem;font-weight:700}.skip-player{color:var(--muted);margin:10px auto 0;padding:8px 16px;font-size:.85rem;display:block}.reset-game{color:var(--bad);margin:24px auto 0;padding:8px 16px;font-size:.85rem;display:block}
