:root{--bg:#0b0918;--bg-2:#1a1140;--card:#251a55;--card-2:#2e2168;--line:#3c2f78;--text:#f6f3ff;--muted:#b3a9e0;--accent:#ff3d8b;--accent-2:#8b5cff;--accent-3:#22d3ee;--gold:#ffd23f;--good:#2ee6a6;--bad:#ff5b6e;--grad:linear-gradient(105deg, var(--accent) 0%, var(--accent-2) 55%, var(--accent-3) 120%);--radius:18px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;margin:0;overflow:hidden}body{background:radial-gradient(90% 60% at 8% -5%, #ff3d8b38, transparent 60%), radial-gradient(85% 65% at 100% 5%, #22d3ee29, transparent 55%), radial-gradient(120% 130% at 50% 110%, #8b5cff47, transparent 60%), var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif}#app{height:100%}.screen{max-width:560px;padding:max(14px, env(safe-area-inset-top)) 16px calc(16px + env(safe-area-inset-bottom));flex-direction:column;gap:12px;height:100dvh;margin:0 auto;display:flex;overflow:hidden}.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}@supports not ((-webkit-background-clip:text) or (background-clip:text)){.title{color:var(--accent);background:0 0}}.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:14px 20px;font-weight:800;transition:transform 80ms,filter .15s,box-shadow .15s}.btn:active{filter:brightness(1.08);transform:scale(.96)}.btn.big{width:100%;min-height:54px;margin-top:auto;font-size:1.1rem}.btn-primary{color:#fff;background:var(--grad);background-size:180% 180%;box-shadow:0 8px 22px -8px #ff3d8b99,0 2px 8px -2px #8b5cff80}.btn-ghost{background:var(--card);border:1px solid var(--line)}.btn-ghost:active{background:var(--card-2)}.btn-steal{color:#2a1c00;background:linear-gradient(100deg, #ffe680, var(--gold) 55%, #ff9d00);animation:1.1s ease-in-out infinite steal-pulse;box-shadow:0 0 #ffd23f8c}@keyframes steal-pulse{0%,to{box-shadow:0 0 #ffd23f8c}50%{box-shadow:0 0 0 10px #ffd23f00}}.btn-round{background:var(--card);border:1px solid var(--line);border-radius:50%;width:50px;height:50px;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)}}.mystery-block{flex-direction:column;gap:10px;display:flex}.audio-progress{background:var(--card);border-radius:999px;height:6px;overflow:hidden}.audio-progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:999px;width:0;height:100%;transition:width .2s linear}.audio-error{color:var(--bad);font-weight:700}.hear-btn{align-self:center;margin-top:0;padding:10px 20px;font-size:.95rem}.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;min-height:48px;color:var(--accent-2);cursor:pointer;background:#7c5cff1f;border-radius:12px;font-size:1.4rem;font-weight:800}.gap-tap:disabled{opacity:.5}.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}.confirm-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#05040cb8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:18px;width:100%;max-width:380px;padding:22px;display:flex;box-shadow:0 20px 60px #00000080}.confirm-msg{margin:0;font-size:1.05rem;font-weight:600;line-height:1.35}.confirm-actions{gap:10px;display:flex}.confirm-actions .btn{flex:1;min-height:52px;margin-top:0}.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)}.gap-pending{border:2px dashed var(--accent);width:30px;color:var(--accent);background:#ff4d8d24;border-radius:12px;justify-content:center;align-self:stretch;align-items:center;font-size:1.2rem;font-weight:800;display:flex}.timeline:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px;border-radius:12px}.copy-link{margin-top:0;padding:12px 16px;font-size:.95rem}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.mystery-disc{animation:none!important}}@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}}.board{gap:10px}.board>.timeline,.board>.timeline-block{flex:1 1 0;min-height:0}.timeline-block{flex-direction:column;gap:8px;min-height:0;display:flex}.timeline-block>.timeline{flex:1 1 0;min-height:0}.timeline{overflow-y:hidden}.card{background:linear-gradient(160deg, var(--card-2), var(--card));justify-content:center;box-shadow:0 6px 16px -10px #000}.card-year{color:var(--accent-3)}@keyframes card-pop{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.06)}to{opacity:1;transform:scale(1)}}.card-new{border-color:var(--good);box-shadow:0 0 0 2px var(--good), 0 0 22px -6px var(--good);animation:.45s cubic-bezier(.2,1.3,.4,1) both card-pop}.scores{gap:6px}.score{background:linear-gradient(160deg, var(--card), var(--bg-2))}.score-active{box-shadow:0 0 0 2px var(--accent), 0 8px 20px -10px var(--accent);border-color:#0000}.score-value{color:#fff}.score-tokens{color:var(--gold);letter-spacing:.02em;font-size:.78rem;font-weight:800}.mystery{background:linear-gradient(140deg, var(--card-2), var(--bg-2));border-color:var(--accent-2);box-shadow:0 0 34px -16px var(--accent-2) inset}.mystery-disc{filter:drop-shadow(0 0 8px var(--accent))}.reveal{background:linear-gradient(140deg, var(--card-2), var(--bg-2))}.reveal-correct{box-shadow:0 0 24px -12px var(--good)}.reveal-steal{border-color:var(--gold);box-shadow:0 0 26px -10px var(--gold)}.reveal-steal .reveal-verdict,.reveal-steal .reveal-year{color:var(--gold)}.steal-window{border:1px solid var(--gold);background:linear-gradient(140deg,#ffd23f29,#ff9d000f);border-radius:14px;flex-direction:column;gap:6px;padding:8px 12px;display:flex}.steal-window-row{color:var(--gold);justify-content:center;align-items:center;gap:8px;font-weight:800;display:flex}.steal-bolt{font-size:1.2rem;animation:.8s ease-in-out infinite steal-bolt}@keyframes steal-bolt{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}.steal-bar-track{background:#ffffff24;border-radius:999px;height:7px;overflow:hidden}.steal-bar{transform-origin:0;background:linear-gradient(90deg, var(--gold), #ff9d00);width:100%;height:100%;animation-name:steal-shrink;animation-timing-function:linear;animation-fill-mode:forwards}@keyframes steal-shrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.steal-hint{color:var(--gold);font-weight:700}.lobby,.setup{justify-content:flex-start;gap:8px}.lobby .qr{width:154px;height:154px;margin:2px auto;padding:8px}.lobby .name-list,.setup .name-list{min-height:0;overflow-y:auto}@media (height<=720px){.turn-banner{font-size:1.25rem}.mystery{padding:12px;font-size:1.05rem}.reveal-art{width:66px;height:66px}}@media (height<=620px){.screen{gap:8px}.turn-banner{font-size:1.1rem}.mystery{padding:9px;font-size:1rem}.scores{gap:5px}.title{font-size:1.9rem}}.standings{flex:1 1 0;justify-content:flex-start;min-height:0;margin:0}.standings-list{flex:1 1 0;min-height:0;overflow-y:auto}.lobby .name-list{flex:1 1 0}.reconnect-banner{top:max(10px, env(safe-area-inset-top));z-index:60;margin:0;position:fixed;left:50%;transform:translate(-50%)}@media (height<=640px){.lobby .qr{width:118px;height:118px}.trophy{font-size:2.6rem}}.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}
