:root{--bg: #0a0a0a;--surface: #181818;--surface-2: #232323;--border: #2e2e2e;--accent: #3b82f6;--accent-dim: #2563eb;--text: #f0f0f0;--correct: #22c55e;--wrong: #ef4444;--warn: #ff9500;--bg-page: #0a0a0c;--bg-card: rgba(255, 255, 255, .03);--bg-input: rgba(255, 255, 255, .04);--border-subtle: rgba(255, 255, 255, .08);--border-default: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .2);--text-primary: #ffffff;--text-body: rgba(255, 255, 255, .85);--text-secondary: rgba(255, 255, 255, .65);--text-muted: rgba(255, 255, 255, .55);--text-tertiary: rgba(255, 255, 255, .4);--text-faint: rgba(255, 255, 255, .35);--text-muted-alpha: rgba(255, 255, 255, .45);--success: #22d46a;--success-bg: rgba(34, 212, 106, .15);--danger: #E24B4A;--danger-bg: rgba(226, 75, 74, .15);--button-primary-bg: #ffffff;--button-primary-text: #0a0a0c;font-family:Inter,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-page);color:var(--text-primary);min-height:100dvh;display:flex;align-items:center;justify-content:center}#root{width:100%}h1,h2,h3{font-family:Inter,system-ui,sans-serif;font-weight:500;letter-spacing:normal}.app{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:1rem}.screen{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--bg-card);border-radius:12px;border:.5px solid var(--border-subtle)}.btn-white{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:var(--button-primary-bg);color:var(--button-primary-text);border:none;border-radius:8px;padding:14px 16px;font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s,transform .1s}.btn-white:hover{opacity:.9}.btn-white:active{transform:scale(.98)}.btn-white:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-outline{display:flex;align-items:center;justify-content:center;gap:.5rem;background:transparent;color:#ffffffb3;border:.5px solid var(--border-strong);border-radius:8px;padding:14px 16px;font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s}.btn-outline:hover{opacity:.8}.btn-outline:disabled{opacity:.35;cursor:not-allowed}.text-link{background:none;border:none;padding:0 0 2px;font-family:Inter,system-ui,sans-serif;font-size:13px;color:var(--text-muted);text-decoration:none;border-bottom:.5px solid rgba(255,255,255,.2);cursor:pointer}.text-link:hover{opacity:.75}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 2rem;border:none;border-radius:.5rem;font-family:Inter,system-ui,sans-serif;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .1s,opacity .15s;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.35;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.97)}.btn-primary{background:var(--button-primary-bg);color:var(--button-primary-text)}.btn-secondary{background:transparent;color:#ffffffb3;border:.5px solid var(--border-strong)}.btn-large{padding:1rem;width:100%}.input-field{width:100%;background:var(--bg-input);border:.5px solid var(--border-strong);border-radius:8px;padding:12px 14px;color:var(--text-primary);font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:400;outline:none;transition:border-color .2s}.input-field:focus{border-color:#fff6}.input-field::placeholder{color:var(--text-faint)}.input-field:disabled{opacity:.4}.input-group{width:100%;display:flex;flex-direction:column;gap:.4rem}.input-label-row{display:flex;align-items:center;justify-content:space-between;padding:0 .1rem}.micro-label{font-size:11px;font-weight:400;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.pts-hint{font-size:11px;color:var(--text-faint)}.cd-logo-wrap{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 45%,#6b4fa0 0%,#2e1a5e 50%,transparent 75%);flex-shrink:0}.cd-logo-img{width:80%;height:80%;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 0 12px rgba(180,140,255,.5))}.progress-bar-row{display:flex;width:100%;gap:4px}.progress-segment{flex:1;height:3px;border-radius:2px;transition:background .3s ease}.session-header{display:flex;justify-content:space-between;align-items:center;width:100%;font-size:13px;color:var(--text-muted)}.session-score{color:var(--text-primary);font-weight:500;font-variant-numeric:tabular-nums}.audio-loading{display:flex;align-items:center;gap:.35rem;color:var(--text-muted);font-size:.9rem}.loading-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:pulse 1s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{opacity:.3;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}.welcome-screen{position:relative;max-width:380px;text-align:center;gap:0}.logo-glow-wrap{width:160px;height:160px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 45%,#4a3a6e 0%,#1a1530 60%,transparent 80%);margin:0 auto 1.5rem;flex-shrink:0}.welcome-logo-img{width:110px;height:auto;mix-blend-mode:screen;filter:drop-shadow(0 0 24px rgba(180,160,255,.35))}.welcome-header{margin-bottom:2rem}.welcome-title{font-family:Inter,system-ui,sans-serif;font-size:28px;font-weight:500;letter-spacing:-.01em;color:var(--text-primary);margin:0 0 .4rem}.welcome-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.stat-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;width:100%;margin-bottom:2rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.stat-value{font-size:22px;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.stat-value--empty{opacity:.5}.stat-divider{width:.5px;height:2rem;background:var(--border-default);flex-shrink:0}.cta-daily{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:var(--button-primary-bg);color:var(--button-primary-text);border:none;border-radius:.75rem;padding:1rem;font-family:Inter,system-ui,sans-serif;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s,transform .1s;margin-bottom:.75rem}.cta-daily:hover{opacity:.9}.cta-daily:active{transform:scale(.98)}.cta-caption{font-size:13px;color:var(--text-muted-alpha);margin:0 0 1.5rem}.free-play-link{background:none;border:none;padding:0;font-family:Inter,system-ui,sans-serif;font-size:13px;color:var(--text-secondary);text-decoration:underline;text-decoration-color:var(--border-strong);text-underline-offset:3px;cursor:pointer}.free-play-link:hover{opacity:.75}.help-btn{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border-radius:50%;border:.5px solid var(--border-strong);background:transparent;color:var(--text-primary);font-family:Inter,system-ui,sans-serif;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}.help-btn:hover{background:#ffffff12}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100}.modal-sheet{background:#181818;border-radius:1.25rem 1.25rem 0 0;padding:2rem 1.5rem;width:100%;max-width:480px;display:flex;flex-direction:column;gap:.4rem}.modal-title{font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:500;letter-spacing:normal;color:var(--text-primary);margin:.75rem 0 .1rem}.modal-title:first-child{margin-top:0}.modal-body{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.modal-got-it{margin-top:1.25rem}.game-screen{gap:1.25rem}.player-card{width:100%;background:var(--bg-card);border:.5px solid var(--border-subtle);border-radius:12px;padding:1.25rem}.player-row{display:flex;align-items:center;gap:.75rem}.play-btn{width:44px;height:44px;border-radius:50%;background:var(--button-primary-bg);color:var(--button-primary-text);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}.play-btn:disabled{opacity:.4;cursor:not-allowed}.play-btn:not(:disabled):hover{opacity:.9}.waveform{display:flex;align-items:center;gap:2px;height:28px;flex:1}.waveform-bar{flex:1;border-radius:1px;min-width:2px;transition:background .4s ease}.timer-compact{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.timer-compact-num{position:absolute;font-size:13px;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.player-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.625rem;border-top:.5px solid var(--border-subtle);font-size:11px;color:var(--text-muted)}.player-footer strong{color:var(--text-primary);font-weight:500;font-variant-numeric:tabular-nums}.btn-row{display:flex;gap:8px;width:100%}.audio-error-msg{font-size:13px;color:var(--danger);text-align:center;padding:.5rem 0}.result-screen{gap:1.25rem}.result-card{width:100%;background:var(--bg-card);border:.5px solid var(--border-subtle);border-radius:12px;padding:1.25rem}.result-top-row{display:flex;gap:.75rem;align-items:flex-start}.album-thumb{width:64px;height:64px;border-radius:8px;object-fit:cover;flex-shrink:0}.album-thumb-placeholder{width:64px;height:64px;border-radius:8px;background:#ffffff0d;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.status-tag{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:400;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.2rem}.status-tag--correct{color:var(--success)}.status-tag--missed{color:var(--danger)}.status-tag--skipped{color:var(--text-muted)}.result-song-title{font-size:17px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-meta{font-size:14px;color:var(--text-secondary)}.answer-divider{height:.5px;background:var(--border-subtle);margin:.75rem 0}.answer-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.answer-row+.answer-row{margin-top:.5rem}.answer-left{display:flex;flex-direction:column;gap:.15rem;min-width:0}.answer-value{font-size:14px;color:var(--text-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pts-display{font-size:13px;color:var(--text-tertiary);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.points-sentence{font-size:13px;color:var(--text-muted);text-align:center;line-height:1.6}.pts-highlight{font-size:20px;font-weight:500;color:var(--text-primary);font-variant-numeric:tabular-nums}.final-screen{gap:1.25rem;text-align:center}.hero-score{display:flex;flex-direction:column;align-items:center;gap:.25rem}.score-main{display:flex;align-items:baseline;gap:.35rem}.score-display{font-size:56px;font-weight:500;color:var(--text-primary);letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}.score-suffix{font-size:20px;font-weight:400;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.flavor-msg{font-size:15px;color:var(--text-secondary);margin-top:.25rem}.breakdown-section{width:100%;display:flex;flex-direction:column;gap:.5rem;text-align:left}.breakdown-list{display:flex;flex-direction:column;gap:8px}.breakdown-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;background:var(--bg-card);border:.5px solid var(--border-subtle);border-left-width:2px;gap:.5rem}.breakdown-row--correct{border-left-color:var(--success)}.breakdown-row--missed{border-left-color:var(--danger)}.breakdown-row--skipped{border-left-color:#ffffff40}.breakdown-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.round-num{font-size:11px;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.breakdown-song{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.breakdown-artist{color:var(--text-muted)}.breakdown-right{display:flex;align-items:center;gap:4px;flex-shrink:0}.result-badge-sm{width:16px;height:16px;border-radius:3px;display:flex;align-items:center;justify-content:center}.result-badge-sm--correct{background:var(--success-bg)}.result-badge-sm--missed{background:var(--danger-bg)}.breakdown-pts{font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:28px;text-align:right}.next-challenge-caption{font-size:13px;color:var(--text-muted)}.next-challenge-caption strong{font-weight:500;color:var(--text-body)}.share-emoji-grid{display:flex;gap:.5rem;justify-content:center;font-size:1.5rem;margin:.5rem 0 .25rem}.share-emoji-legend{font-size:.7rem;color:var(--text-muted);text-align:center;margin-bottom:.25rem;letter-spacing:.03em}.icon-correct{color:var(--success)}.icon-missed{color:var(--danger)}@media (max-width: 480px){.screen{padding:1.25rem 1rem;border-radius:0;border-left:none;border-right:none}.btn-row{flex-wrap:nowrap}}
