@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#090b14;--color-surface:#ffffff0a;--color-border:#ffffff14;--color-text:#e2e8f0;--color-text-muted:#64748b;--color-text-dim:#334155;--color-primary:#7c3aed;--color-primary-dim:#7c3aed26;--color-accent:#0ea5e9;--color-success:#4ade80;--color-warning:#fbbf24;--color-danger:#f87171;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"Courier New", Courier, monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px}html,body{background:var(--color-bg);height:100%;color:var(--color-text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5;overflow:hidden}#root{height:100dvh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#7c3aed4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7c3aed80}button,input,select,textarea{font-family:var(--font-sans)}button{white-space:nowrap;line-height:1.3}.btn-primary{border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:.92rem;font-weight:700;font-family:var(--font-sans);background:linear-gradient(135deg,#7c3aed,#5b21b6);border:none;justify-content:center;align-items:center;gap:.4rem;padding:.75rem 1.5rem;transition:all .2s;display:inline-flex;box-shadow:0 4px 16px #7c3aed59}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed80}.btn-primary:active{transform:translateY(0)}.btn-secondary{border-radius:var(--radius-lg);color:#94a3b8;cursor:pointer;font-size:.92rem;font-weight:600;font-family:var(--font-sans);background:#ffffff0d;border:1px solid #ffffff1f;justify-content:center;align-items:center;gap:.4rem;padding:.75rem 1.5rem;transition:all .2s;display:inline-flex}.btn-secondary:hover{color:var(--color-text);border-color:#fff3}.btn-ghost{border-radius:var(--radius-md);color:#64748b;cursor:pointer;font-size:.85rem;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;justify-content:center;align-items:center;gap:.4rem;padding:.6rem 1rem;transition:color .2s;display:inline-flex}.btn-ghost:hover{color:var(--color-text)}.abcjs-container,.abcjs-container>div{background:0 0!important}.score-display-container{background:#fff}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@supports (padding-bottom:env(safe-area-inset-bottom)){body{padding-bottom:0}}.welcome-screen{background:#090b14;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.welcome-bg-grid{pointer-events:none;background-image:linear-gradient(#8b5cf60d 1px,#0000 1px),linear-gradient(90deg,#8b5cf60d 1px,#0000 1px);background-size:50px 50px;position:absolute;inset:0}.welcome-orbs{pointer-events:none;position:absolute;inset:0}.orb{filter:blur(80px);opacity:.35;border-radius:50%;animation:8s ease-in-out infinite orb-drift;position:absolute}.orb-1{background:radial-gradient(circle,#7c3aed,#0000 70%);width:500px;height:500px;animation-delay:0s;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#0ea5e9,#0000 70%);width:400px;height:400px;animation-delay:-3s;bottom:-50px;right:10%}.orb-3{background:radial-gradient(circle,#f59e0b,#0000 70%);width:300px;height:300px;animation-delay:-6s;top:50%;left:60%}@keyframes orb-drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-20px)scale(1.05)}66%{transform:translate(-20px,30px)scale(.95)}}.welcome-content{z-index:1;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:700px;padding:2rem;transition:opacity .4s,transform .4s;display:flex;position:relative}.welcome-content.fade-out{opacity:0;transform:translateY(-20px)}.welcome-logo{align-items:center;gap:1rem;display:flex}.welcome-logo-icon{background:linear-gradient(135deg,#7c3aed,#0ea5e9);border-radius:18px;justify-content:center;align-items:center;width:70px;height:70px;font-size:3rem;animation:3s ease-in-out infinite logo-glow;display:flex;box-shadow:0 8px 32px #7c3aed66}@keyframes logo-glow{0%,to{box-shadow:0 8px 32px #7c3aed66}50%{box-shadow:0 8px 48px #7c3aedb3}}.welcome-logo-text{flex-direction:column;gap:.2rem;display:flex}.logo-ja{color:#e2e8f0;letter-spacing:.02em;font-size:1.1rem;font-weight:700}.logo-en{color:#94a3b8;font-size:.85rem;font-weight:500}.welcome-tagline{text-align:center}.tagline-ja{color:#c4b5fd;margin:0 0 .3rem;font-size:1.1rem;font-weight:500}.tagline-en{color:#64748b;margin:0;font-size:.9rem}.welcome-features{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.feature-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:14px;flex-direction:column;align-items:center;gap:.4rem;min-width:160px;padding:1.2rem 1.5rem;transition:transform .2s,border-color .2s;display:flex}.feature-card:hover{border-color:#7c3aed66;transform:translateY(-3px)}.feature-icon{font-size:1.8rem}.feature-ja{color:#e2e8f0;text-align:center;font-size:.8rem;font-weight:500}.feature-en{color:#64748b;text-align:center;font-size:.72rem}.welcome-language-select{flex-direction:column;align-items:center;gap:1rem;display:flex}.language-prompt{color:#94a3b8;margin:0;font-size:.9rem}.language-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.lang-btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.6rem;padding:.9rem 2rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.lang-btn-ja{color:#fff;background:linear-gradient(135deg,#7c3aed,#5b21b6);box-shadow:0 4px 20px #7c3aed66}.lang-btn-ja:hover{transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed8c}.lang-btn-en{color:#fff;background:linear-gradient(135deg,#0ea5e9,#0284c7);box-shadow:0 4px 20px #0ea5e966}.lang-btn-en:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0ea5e98c}.lang-flag{font-size:1.3rem}.welcome-env-notice{color:#d97706;text-align:center;background:#f59e0b14;border:1px solid #f59e0b33;border-radius:10px;align-items:center;gap:.6rem;padding:.7rem 1.2rem;font-size:.78rem;display:flex}.env-icon{flex-shrink:0;font-size:1.1rem}@media (width<=600px){.welcome-features{flex-direction:column}.feature-card{min-width:unset;width:100%}.language-buttons{flex-direction:column;width:100%}.lang-btn{justify-content:center;width:100%}}.calibration-screen{background:#090b14;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.calibration-card{background:#ffffff0a;border:1px solid #ffffff17;border-radius:20px;width:100%;max-width:500px;padding:2.5rem}.calibration-header{flex-direction:column;align-items:center;gap:.8rem;margin-bottom:2rem;display:flex}.calibration-icon{font-size:2.5rem}.calibration-header h1{color:#e2e8f0;text-align:center;margin:0;font-size:1.5rem;font-weight:700}.calibration-desc,.calibration-instruction{color:#94a3b8;text-align:center;margin:0 0 1rem;font-size:.9rem;line-height:1.6}.calibration-actions{flex-direction:column;gap:.8rem;margin-top:1.5rem;display:flex}.calibration-note{color:#7dd3fc;background:#0ea5e914;border:1px solid #0ea5e933;border-radius:8px;align-items:center;gap:.5rem;margin-top:1rem;padding:.7rem 1rem;font-size:.78rem;display:flex}.calibration-measuring{flex-direction:column;align-items:center;gap:1.5rem;display:flex}.click-indicator{flex-direction:column;align-items:center;gap:.8rem;display:flex}.click-circle{color:#fff;background:linear-gradient(135deg,#7c3aed,#0ea5e9);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-size:1.2rem;font-weight:700;display:flex}.click-circle.pulse{animation:.15s ease-out click-pulse}@keyframes click-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.click-indicator p{color:#94a3b8;margin:0;font-size:.9rem}.tap-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#5b21b6);border:none;border-radius:14px;width:100%;padding:1rem 2.5rem;font-size:1.1rem;font-weight:700;transition:transform .1s}.tap-btn:active{transform:scale(.96)}.latency-log{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.latency-entry{color:#c4b5fd;background:#7c3aed33;border-radius:6px;padding:.2rem .6rem;font-family:monospace;font-size:.8rem}.calibration-done-actions{flex-direction:column;align-items:center;gap:.8rem;width:100%;display:flex}.calibration-done-actions p{color:#94a3b8;text-align:center;margin:0;font-size:.9rem}.avg-result{color:#4ade80!important;font-size:1rem!important}.score-display-wrapper{background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;width:100%;min-height:180px;overflow:hidden}.score-display-container{width:100%;padding:8px}.score-display-container svg{margin:0 auto;display:block;width:100%!important;max-width:100%!important;height:auto!important}.score-display-container svg path{fill:#000;stroke:#000;stroke-width:.6px}.score-display-container svg text{font-weight:700;fill:#000!important}.score-display-container .abcjs-note{transition:opacity .15s}.score-display-container .note-current *{filter:drop-shadow(0 0 6px #ffd70088);fill:gold!important}.score-display-container .note-next *{opacity:.85;fill:#4fc3f7!important}.score-display-container .note-passed *{opacity:.5;fill:#4caf50!important}.score-display-container .abcjs-chord{font-size:13px;font-weight:600;fill:#a78bfa!important}.note-hint-label{fill:#ffc86499;pointer-events:none;font-family:Outfit,sans-serif;font-size:9px}.placement-screen{background:#090b14;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.placement-card{background:#ffffff0a;border:1px solid #ffffff17;border-radius:20px;width:100%;max-width:560px;padding:2.5rem}.placement-header{text-align:center;flex-direction:column;align-items:center;gap:.6rem;margin-bottom:2rem;display:flex}.placement-icon{font-size:2.5rem}.placement-header h1{color:#e2e8f0;margin:0;font-size:1.5rem;font-weight:700}.placement-header p{color:#94a3b8;margin:0;font-size:.88rem}.placement-steps{flex-direction:column;gap:.8rem;margin-bottom:1.5rem;display:flex}.step-item{color:#cbd5e1;align-items:center;gap:.8rem;font-size:.9rem;display:flex}.step-num{color:#fff;background:linear-gradient(135deg,#7c3aed,#0ea5e9);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.mic-error{color:#f87171;text-align:center;background:#f871711a;border-radius:8px;margin-bottom:1rem;padding:.6rem;font-size:.85rem}.placement-actions{flex-direction:column;gap:.8rem;display:flex}.question-progress{color:#94a3b8;align-items:center;gap:1rem;margin-bottom:1rem;font-size:.85rem;display:flex}.progress-dots{gap:6px;display:flex}.dot{background:#ffffff1a;border-radius:50%;width:10px;height:10px;transition:background .3s}.dot.done{background:#4ade80}.dot.active{background:#fbbf24;animation:.8s ease-in-out infinite dot-pulse}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.question-score-area{background:#fff;border-radius:12px;margin-bottom:1rem;overflow:hidden}.feedback-display{border-radius:8px;justify-content:center;align-items:center;height:40px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.feedback-display.correct{color:#4ade80;background:#4ade801a}.feedback-display.wrong{color:#f87171;background:#f871711a}.listening-pulse{color:#94a3b8;animation:1.2s ease-in-out infinite listening-anim}@keyframes listening-anim{0%,to{opacity:1}50%{opacity:.4}}.question-label{text-align:center;color:#94a3b8;margin:.5rem 0;font-size:.88rem}.question-label strong{color:#e2e8f0}.skip-btn{color:#64748b;margin-top:.5rem;font-size:.82rem}.placement-result{flex-direction:column;align-items:center;gap:1.2rem;display:flex}.result-circle{background:linear-gradient(135deg,#7c3aed,#0ea5e9);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;box-shadow:0 8px 32px #7c3aed66}.result-score{color:#fff;font-size:1.4rem;font-weight:800}.result-label{color:#94a3b8;margin:0;font-size:.9rem}.result-level{border-radius:10px;padding:.6rem 2rem;font-size:1.3rem;font-weight:700}.result-level.level-beginner{color:#4ade80;background:#4ade801a}.result-level.level-intermediate{color:#fbbf24;background:#fbbf241a}.result-level.level-advanced{color:#f87171;background:#f871711a}.app-shell{background:#090b14;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.app-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#090b14f2;border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.header-logo{align-items:center;gap:.5rem;display:flex}.header-logo-icon{background:linear-gradient(135deg,#7c3aed,#0ea5e9);border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.4rem;display:flex}.header-title{color:#e2e8f0;letter-spacing:-.01em;font-size:.9rem;font-weight:700}.header-stats{align-items:center;gap:.5rem;display:flex}.stat-badge{color:#e2e8f0;background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;align-items:center;gap:.3rem;padding:.3rem .65rem;font-size:.78rem;font-weight:600;display:flex}.stat-icon{font-size:.85rem}.currency-badge{color:#fbbf24}.app-main{scrollbar-width:thin;scrollbar-color:#7c3aed4d transparent;flex:1;overflow:hidden auto}.app-nav{padding:.5rem 0 max(.5rem, env(safe-area-inset-bottom));z-index:10;background:#090b14f7;border-top:1px solid #ffffff12;flex-shrink:0;justify-content:space-around;align-items:center;display:flex}.nav-item{cursor:pointer;background:0 0;border:none;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.4rem .8rem;transition:all .2s;display:flex;position:relative}.nav-item:hover{background:#ffffff0a}.nav-icon{font-size:1.2rem;transition:transform .2s}.nav-item.active .nav-icon{transform:scale(1.15)}.nav-label{color:#64748b;white-space:nowrap;font-size:.64rem;font-weight:500;transition:color .2s}.nav-item.active .nav-label{color:#a78bfa;font-weight:600}.nav-indicator{background:linear-gradient(90deg,#7c3aed,#0ea5e9);border-radius:2px;width:20px;height:3px;animation:.2s ease-out indicator-in;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.app-footer{text-align:center;margin-top:auto;padding:2rem 1rem 1.5rem}.app-footer a{color:#64748b;letter-spacing:.05em;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:500;text-decoration:none;transition:all .2s}.app-footer a:hover{color:#a78bfa;text-shadow:0 0 8px #a78bfa66}@keyframes indicator-in{0%{width:0}to{width:20px}}@media (width<=480px){.header-title{display:none}.stat-badge{padding:.25rem .4rem;font-size:.72rem}.nav-label{font-size:.6rem}}.manual-accordion{background:#7c3aed0d;border:1px solid #7c3aed33;border-radius:12px;overflow:hidden}.manual-toggle{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.6rem;width:100%;padding:.75rem 1rem;display:flex}.manual-toggle-icon{font-size:1rem}.manual-toggle-title{color:#a78bfa;flex:1;font-size:.82rem;font-weight:600}.manual-chevron{color:#6d28d9;font-size:.65rem}.manual-body{padding:0 1rem 1rem;animation:.2s slide-down}.manual-body p{color:#94a3b8;margin:0;font-size:.83rem;line-height:1.7}.home-screen{flex-direction:column;gap:1.5rem;max-width:700px;margin:0 auto;padding:1.25rem;display:flex}.home-hero{background:#ffffff08;border:1px solid #ffffff14;border-radius:18px;align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.hero-level-ring{flex-shrink:0;width:80px;height:80px;position:relative}.level-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#ffffff14;stroke-width:6px}.ring-fill{fill:none;stroke:url(#ring-grad);stroke-width:6px;stroke-linecap:round;transition:stroke-dasharray .5s}.level-ring-text{flex-direction:column;justify-content:center;align-items:center;gap:.1rem;display:flex;position:absolute;inset:0}.level-num{color:#e2e8f0;font-size:1.5rem;font-weight:800;line-height:1}.level-lbl{color:#64748b;font-size:.6rem;font-weight:600}.hero-info{flex-direction:column;flex:1;gap:1rem;display:flex}.hero-exp{flex-direction:column;gap:.4rem;display:flex}.exp-label{color:#64748b;justify-content:space-between;font-size:.75rem;display:flex}.exp-bar{background:#ffffff14;border-radius:4px;height:8px;overflow:hidden}.exp-fill{background:linear-gradient(90deg,#7c3aed,#0ea5e9);border-radius:4px;height:100%;transition:width .6s}.hero-badges{flex-wrap:wrap;gap:.8rem;display:flex}.hero-badge{align-items:center;gap:.4rem;display:flex}.badge-icon{font-size:1.1rem}.badge-info{flex-direction:column;gap:.05rem;display:flex}.badge-value{color:#e2e8f0;font-size:.9rem;font-weight:700;line-height:1}.badge-lbl{color:#64748b;font-size:.65rem}.streak-banner{color:#fbbf24;background:linear-gradient(135deg,#f59e0b1f,#fbbf240f);border:1px solid #f59e0b4d;border-radius:12px;align-items:center;gap:.6rem;padding:.75rem 1.2rem;font-size:.87rem;display:flex}.streak-banner strong{color:#f59e0b}.home-section{flex-direction:column;gap:.75rem;display:flex}.section-title{color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.8rem;font-weight:700}.quick-start-btn{cursor:pointer;text-align:left;background:linear-gradient(135deg,#7c3aed26,#0ea5e914);border:1px solid #7c3aed4d;border-radius:14px;align-items:center;gap:1rem;width:100%;padding:1rem 1.2rem;transition:all .2s;display:flex}.quick-start-btn:hover{border-color:#7c3aed80;transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed33}.qs-icon{font-size:2rem}.qs-info{flex-direction:column;flex:1;gap:.2rem;display:flex}.qs-title{color:#e2e8f0;font-size:1rem;font-weight:700}.qs-sub{color:#64748b;font-size:.78rem}.qs-arrow{color:#7c3aed;font-size:1.5rem;font-weight:300}.progress-cards{grid-template-columns:repeat(3,1fr);gap:.8rem;display:grid}.progress-card{background:#ffffff08;border:1px solid #ffffff12;border-radius:12px;flex-direction:column;align-items:center;gap:.4rem;padding:1rem;display:flex}.pc-icon{font-size:1.4rem}.pc-value{color:#e2e8f0;font-size:1.4rem;font-weight:800}.pc-label{color:#64748b;text-align:center;font-size:.7rem}.no-activity{text-align:center;color:#475569;border:1px dashed #ffffff14;border-radius:12px;padding:1.5rem;font-size:.85rem}.activity-list{flex-direction:column;gap:.5rem;display:flex}.activity-item{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;justify-content:space-between;align-items:center;padding:.6rem 1rem;font-size:.82rem;display:flex}.activity-song{color:#cbd5e1}.activity-score{color:#7c3aed;font-weight:600}@media (width<=480px){.home-hero{flex-direction:column;align-items:flex-start;gap:1rem}.progress-cards{grid-template-columns:repeat(3,1fr)}}.count-in-overlay{z-index:100;pointer-events:none;background:#090b1473;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.count-in-number{color:#fff;text-shadow:0 0 0 8px #090b14cc,0 0 40px #7c3aed,0 0 80px #0ea5e999,0 2px 8px #000000e6;-webkit-text-stroke:3px #090b14b3;font-size:9rem;font-weight:900;line-height:1;animation:.4s ease-out forwards count-pulse}@keyframes count-pulse{0%{opacity:0;transform:scale(1.6)}30%{opacity:1;transform:scale(1.1)}70%{opacity:1;transform:scale(1)}to{opacity:.7;transform:scale(.9)}}.count-in-label{letter-spacing:.3em;color:#64748b;font-size:.9rem;font-weight:700}.count-in-dots{gap:.6rem;display:flex}.count-dot{background:#ffffff26;border-radius:50%;width:12px;height:12px;transition:all .15s}.count-dot.filled{background:#7c3aed}.count-dot.active{background:#fff;transform:scale(1.3);box-shadow:0 0 10px #ffffffb3}.combo-display{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:.4rem;padding:.4rem .8rem;transition:all .2s;display:flex;position:relative;overflow:visible}.combo-count{font-size:1.6rem;font-weight:900;line-height:1;transition:all .15s}.combo-bump{animation:.3s ease-out combo-bump}@keyframes combo-bump{0%{transform:scale(1)}40%{transform:scale(1.4)}to{transform:scale(1)}}.combo-meta{flex-direction:column;gap:.05rem;display:flex}.combo-word{letter-spacing:.1em;color:#64748b;font-size:.6rem;font-weight:700}.combo-mult{font-size:.75rem;font-weight:700}.combo-tier-label{letter-spacing:.12em;white-space:nowrap;opacity:0;font-size:.65rem;font-weight:800;position:absolute;top:-1.5rem;left:50%;transform:translate(-50%)}.combo-tier-flash{animation:.8s ease-out forwards tier-rise}@keyframes tier-rise{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-20px)}}.tier-none .combo-count{color:#94a3b8}.tier-good .combo-count,.tier-good .combo-mult{color:#4ade80}.tier-cool .combo-count,.tier-cool .combo-mult{color:#60a5fa}.tier-hot .combo-count,.tier-hot .combo-mult,.tier-hot .combo-tier-label{color:#fbbf24}.tier-blazing .combo-count,.tier-blazing .combo-mult,.tier-blazing .combo-tier-label{color:#f97316}.tier-blazing.flash{box-shadow:0 0 20px #f9731666}.tier-legendary .combo-count,.tier-legendary .combo-mult,.tier-legendary .combo-tier-label{color:#e879f9}.tier-legendary.flash{animation:.6s legendary-glow;box-shadow:0 0 30px #e879f980,0 0 60px #e879f933}@keyframes legendary-glow{0%,to{box-shadow:0 0 30px #e879f980}50%{box-shadow:0 0 60px #e879f9cc}}.metro-display{background:#0000004d;border:1px solid #ffffff0f;border-radius:10px;justify-content:center;align-items:center;gap:.3rem;padding:.4rem .8rem;display:flex}.metro-beat-group{align-items:center;gap:.2rem;display:flex}.metro-beat,.metro-sub{color:#334155;text-align:center;border-radius:4px;min-width:18px;padding:.2rem .3rem;font-size:.85rem;font-weight:700;transition:all 50ms}.metro-beat.beat-active{color:#fff;background:#7c3aed80;transform:scale(1.15)}.metro-beat.beat-accent.beat-active{color:#fff;background:#f59e0b99}.metro-sub.sub-active{color:#94a3b8;transform:scale(1.1)}.metro-sub{color:#1e293b;font-size:.7rem}.practice-screen{background:#090b14;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.practice-header{z-index:10;border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:1rem;padding:.6rem 1rem;display:flex}.practice-back-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;padding:.3rem .7rem;font-size:.82rem;transition:all .2s}.practice-back-btn:hover{color:#e2e8f0;border-color:#fff3}.practice-title{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:600;overflow:hidden}.practice-key-badge{color:#94a3b8;white-space:nowrap;background:#7c3aed26;border:1px solid #7c3aed40;border-radius:6px;padding:.2rem .6rem;font-size:.78rem}.practice-key-badge strong{color:#a78bfa}.loop-indicator{flex-shrink:0;align-items:center;gap:.4rem;padding:.4rem 1rem;display:flex}.loop-dot{background:#ffffff1a;border-radius:50%;width:8px;height:8px;transition:all .3s}.loop-dot.done{background:#4ade80}.loop-dot.active{background:#fbbf24;transform:scale(1.3)}.loop-label{color:#64748b;margin-left:.4rem;font-size:.75rem}.practice-score-area{scroll-behavior:smooth;flex:1;padding:.5rem .75rem;position:relative;overflow:hidden auto}.practice-score-area::-webkit-scrollbar{width:4px}.practice-score-area::-webkit-scrollbar-track{background:#ffffff08}.practice-score-area::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:2px}.practice-score-area::-webkit-scrollbar-thumb:hover{background:#7c3aed80}.practice-score-area .score-display-wrapper{background:#fffffff7;justify-content:center;padding:1rem 0;display:flex}.transposition-banner{color:#94a3b8;z-index:50;background:#090b14e6;border:2px solid #7c3aed;border-radius:16px;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 2.5rem;font-size:1rem;animation:.3s banner-fade-in;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.transition-key{color:#a78bfa;font-size:1.5rem;font-weight:800}@keyframes banner-fade-in{0%{opacity:0;transform:translate(-50%,-50%)scale(.8)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.practice-hud{background:#0006;border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.hud-center{align-items:center;gap:.6rem;display:flex}.mic-level-bar{background:#ffffff14;border-radius:3px;flex-direction:column-reverse;width:6px;height:40px;display:flex;overflow:hidden}.mic-level-fill{background:linear-gradient(#fbbf24,#4ade80);border-radius:3px;transition:height 80ms}.note-feedback{text-align:center;border-radius:6px;justify-content:center;align-items:center;min-width:80px;height:28px;font-size:.85rem;font-weight:700;transition:all .15s;display:flex}.note-feedback.correct{color:#4ade80;background:#4ade801f;animation:.3s feedback-pop}.note-feedback.miss{color:#f87171;background:#f871711f;animation:.3s feedback-pop}.listening-text{color:#334155;font-size:1.1rem}@keyframes feedback-pop{0%{transform:scale(1.2)}to{transform:scale(1)}}.setup-panel{z-index:80;background:#090b14f0;border-left:1px solid #7c3aed40;flex-direction:column;width:340px;animation:.25s slide-in-right;display:flex;position:absolute;top:0;bottom:0;right:0;overflow-y:auto;box-shadow:-8px 0 32px #00000080}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.setup-content{flex-direction:column;flex:1;gap:1.1rem;padding:1.5rem;display:flex}.setup-top-bar{align-items:center;display:flex}.setup-back-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;padding:.3rem .8rem;font-size:.82rem;transition:all .2s}.setup-back-btn:hover{color:#e2e8f0;background:#ffffff0f;border-color:#ffffff40}.setup-content h3{color:#e2e8f0;margin:0;font-size:1rem;font-weight:700;line-height:1.35}.setup-info{color:#64748b;flex-direction:column;gap:.3rem;font-size:.8rem;display:flex}.setup-info strong{color:#c4b5fd}.key-select-group{flex-direction:column;gap:.5rem;display:flex}.key-select-label{color:#94a3b8;font-size:.8rem}.key-select-grid{grid-template-columns:repeat(4,1fr);gap:.35rem;display:grid}.key-btn{cursor:pointer;color:#64748b;text-align:center;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;padding:.3rem 0;font-size:.78rem;font-weight:600;transition:all .15s}.key-btn:hover{color:#c4b5fd;background:#7c3aed26;border-color:#7c3aed4d}.key-btn.active{color:#a78bfa;background:#7c3aed40;border-color:#7c3aed99;font-weight:700}.bpm-control{flex-direction:column;gap:.4rem;display:flex}.bpm-control label{color:#94a3b8;font-size:.82rem}.bpm-control label strong{color:#e2e8f0}.bpm-slider{accent-color:#7c3aed;width:100%}.bpm-range{color:#475569;font-size:.7rem}.setup-toggle{color:#94a3b8;justify-content:space-between;align-items:center;font-size:.82rem;display:flex}.toggle-btn{cursor:pointer;color:#64748b;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:.3rem 1rem;font-size:.78rem;font-weight:700;transition:all .2s}.toggle-btn.on{color:#a78bfa;background:#7c3aed33;border-color:#7c3aed66}.setup-items{flex-wrap:wrap;gap:.4rem;display:flex}.item-btn{cursor:pointer;color:#94a3b8;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;padding:.35rem .7rem;font-size:.75rem;transition:all .2s}.item-btn.active{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b59}.setup-actions{gap:.6rem;display:flex}.start-btn{width:100%;padding:.85rem;font-size:1rem}.preview-mode{background:#090b14;flex-direction:column;height:100%;display:flex}.preview-header{background:#0000004d;border-bottom:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:.8rem;padding:.6rem 1rem;display:flex}.preview-title{color:#e2e8f0;flex:1;font-size:.9rem;font-weight:600}.preview-key-badge{color:#a78bfa;background:#7c3aed26;border:1px solid #7c3aed4d;border-radius:5px;margin-left:.4rem;padding:.15rem .5rem;font-size:.75rem;font-weight:700}.preview-start-btn{white-space:nowrap;padding:.35rem 1rem;font-size:.85rem}.preview-score-area{background:#fff;flex:1;padding:.75rem 1rem;overflow-y:auto}.preview-score-area .score-display-wrapper{background:0 0;border:none}.result-overlay{z-index:90;background:#090b14eb;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:absolute;inset:0}.result-panel{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;align-items:center;gap:1.2rem;width:100%;max-width:380px;padding:2rem;display:flex}.result-badge{font-size:4rem;animation:.5s cubic-bezier(.34,1.56,.64,1) badge-in}@keyframes badge-in{0%{opacity:0;transform:scale(0)rotate(-20deg)}to{opacity:1;transform:scale(1)rotate(0)}}.result-panel h2{color:#e2e8f0;text-align:center;margin:0;font-size:1.3rem;font-weight:800}.result-stats{justify-content:center;gap:1.5rem;display:flex}.result-stat{flex-direction:column;align-items:center;gap:.25rem;display:flex}.rs-label{color:#64748b;font-size:.7rem}.rs-value{color:#e2e8f0;font-size:1.2rem;font-weight:800}.result-actions{flex-direction:column;gap:.7rem;width:100%;display:flex}.master-screen{flex-direction:column;gap:1.25rem;max-width:700px;margin:0 auto;padding:1.25rem;display:flex}.master-header{text-align:center}.master-header h1{color:#e2e8f0;margin:0 0 .3rem;font-size:1.4rem;font-weight:800}.master-header p{color:#64748b;margin:0 0 .5rem;font-size:.85rem}.master-disclaimer{max-width:90%;font-style:italic;color:#9ca3af!important;margin:0 auto!important;font-size:.75rem!important}.difficulty-tabs{background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;gap:4px;padding:4px;display:flex}.diff-tab{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:9px;flex:1;padding:.55rem;font-family:Outfit,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s}.diff-tab.active{background:color-mix(in srgb, var(--diff-color) 18%, transparent);color:var(--diff-color);border:1px solid color-mix(in srgb, var(--diff-color) 35%, transparent)}.song-list{flex-direction:column;gap:.6rem;display:flex}.song-card{cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #ffffff12;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:.9rem 1.1rem;transition:all .2s;display:flex}.song-card:hover{background:#7c3aed0d;border-color:#7c3aed4d;transform:translate(2px)}.song-card-title{color:#e2e8f0;margin-bottom:.2rem;font-size:.92rem;font-weight:600}.song-card-meta{color:#475569;gap:.6rem;font-size:.72rem;display:flex}.song-card-right{flex-direction:column;align-items:flex-end;gap:.3rem;display:flex}.song-stars{gap:2px;display:flex}.stage-star{color:#334155;font-size:.9rem}.stage-star.filled{color:#fbbf24}.song-cleared{color:#64748b;font-size:.7rem}.stage-select{flex-direction:column;gap:1rem;display:flex}.stage-select-header{align-items:center;gap:1rem;display:flex}.back-link:hover{color:#e2e8f0}.stage-song-title{color:#e2e8f0;font-size:1rem;font-weight:700}.stage-list{flex-direction:column;gap:.6rem;display:flex}.stage-card{cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #ffffff12;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:.9rem 1.1rem;transition:all .2s;display:flex}.stage-card.selected{background:#7c3aed1a;border-color:#7c3aed80}.stage-card.cleared{border-color:#4ade8033}.stage-card-left{align-items:center;gap:.9rem;display:flex}.stage-num{color:#64748b;background:#ffffff0f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.stage-name{color:#e2e8f0;margin-bottom:.15rem;font-size:.9rem;font-weight:600}.stage-meta{color:#475569;gap:.4rem;font-size:.72rem;display:flex}.stage-card-right{align-items:center;gap:.5rem;display:flex}.title-badge{font-size:1.1rem}.clear-check{color:#4ade80;font-size:1rem;font-weight:700}.stage-arrow{color:#7c3aed;font-size:1.3rem}.start-practice-btn{width:100%;padding:.9rem;font-size:1rem}.master-manual{margin-top:.5rem}.scale-screen{flex-direction:column;gap:1rem;max-width:700px;margin:0 auto;padding:1.25rem;display:flex}.scale-header{flex-direction:column;gap:.4rem;display:flex}.scale-header h1{color:#e2e8f0;margin:0;font-size:1.3rem;font-weight:800}.scale-header p{color:#64748b;margin:0;font-size:.82rem}.achievement-toggle-btn{color:#a78bfa;cursor:pointer;background:#7c3aed1f;border:1px solid #7c3aed40;border-radius:20px;align-self:flex-start;padding:.35rem .9rem;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:600;transition:all .2s}.achievement-toggle-btn:hover{background:#7c3aed33}.scale-cat-tabs{flex-wrap:wrap;gap:.4rem;display:flex}.cat-tab{color:#64748b;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:20px;padding:.35rem .9rem;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:600;transition:all .2s}.cat-tab.active{color:#38bdf8;background:#0ea5e926;border-color:#0ea5e959}.scale-list{flex-wrap:wrap;gap:.5rem;display:flex}.scale-item{cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #ffffff12;border-radius:10px;flex-direction:column;padding:.5rem .9rem;font-family:Outfit,sans-serif;transition:all .2s;display:flex}.scale-item.selected{color:#a78bfa;background:#7c3aed26;border-color:#7c3aed66}.scale-item span:first-child{color:#e2e8f0;font-size:.85rem;font-weight:600}.scale-item.selected span:first-child{color:#a78bfa}.scale-item-en{color:#475569;font-size:.68rem}.key-grid{grid-template-columns:repeat(6,1fr);gap:.4rem;display:grid}.key-btn{color:#94a3b8;cursor:pointer;text-align:center;background:#ffffff08;border:1px solid #ffffff12;border-radius:8px;padding:.5rem .3rem;font-family:Outfit,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s;position:relative}.key-btn.selected{color:#fbbf24;background:#f59e0b26;border-color:#f59e0b66}.key-btn.cleared{border-color:#4ade8033}.key-check{color:#4ade80;font-size:.55rem;position:absolute;top:1px;right:2px}.scale-options{flex-direction:column;gap:.75rem;display:flex}.option-group{align-items:center;gap:.8rem;display:flex}.option-group label{color:#64748b;white-space:nowrap;min-width:80px;font-size:.8rem}.option-group label strong{color:#e2e8f0}.option-btns{flex-wrap:wrap;gap:.4rem;display:flex}.opt-btn{color:#475569;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;padding:.3rem .7rem;font-family:Outfit,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.opt-btn.active{color:#38bdf8;background:#0ea5e926;border-color:#0ea5e959}.bpm-group{flex-direction:column;align-items:flex-start}.bpm-group .bpm-slider{accent-color:#7c3aed;width:100%}.scale-score-wrap{border-radius:12px;overflow:hidden}.scale-start-btn{width:100%;padding:.9rem;font-size:1rem}.scale-playing-controls{background:#0006;border:1px solid #ffffff0f;border-radius:12px;flex-wrap:wrap;align-items:center;gap:.8rem;padding:.75rem 1rem;display:flex}.mic-badge{color:#4ade80;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.mini-level-bar{background:#ffffff14;border-radius:3px;width:60px;height:6px;overflow:hidden}.mini-level-fill{background:linear-gradient(90deg,#4ade80,#fbbf24);border-radius:3px;height:100%;transition:width 80ms}.detected-note{color:#e2e8f0;font-family:monospace;font-size:.8rem;font-weight:700}.scale-done-btns{gap:.5rem;margin-left:auto;display:flex}.btn-success{color:#fff;cursor:pointer;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;padding:.5rem 1.2rem;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700;transition:all .2s}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.scale-done-banner{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:12px;justify-content:space-between;align-items:center;padding:.9rem 1.2rem;font-size:.9rem;font-weight:600;animation:.3s slide-down;display:flex}.achievement-screen{flex-direction:column;gap:1rem;display:flex}.achievement-header{align-items:center;gap:1rem;display:flex}.achievement-header h2{color:#e2e8f0;flex:1;margin:0;font-size:1.1rem;font-weight:700}.achievement-count{color:#a78bfa;font-size:.85rem;font-weight:700}.achievement-progress-bar{background:#ffffff14;border-radius:3px;height:6px;overflow:hidden}.achievement-progress-fill{background:linear-gradient(90deg,#7c3aed,#0ea5e9);border-radius:3px;height:100%;transition:width .5s}.achievement-matrix{border:1px solid #ffffff12;border-radius:10px;overflow-x:auto}.matrix-header,.matrix-row{display:flex}.matrix-cell{border-bottom:1px solid #ffffff0a;border-right:1px solid #ffffff0a;justify-content:center;align-items:center;min-width:38px;height:32px;font-size:.68rem;display:flex}.matrix-scale-label{color:#64748b;background:#0003;justify-content:flex-end;min-width:90px;padding:0 .5rem;font-size:.65rem}.matrix-key-label{color:#475569;background:#00000026;font-weight:700}.matrix-check-cell{cursor:pointer;color:#1e293b;transition:background .15s}.matrix-check-cell:hover{background:#7c3aed1a}.matrix-check-cell.cleared{color:#4ade80;background:#4ade801a;font-weight:700}.back-link{color:#64748b;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:8px;padding:.3rem .7rem;font-family:Outfit,sans-serif;font-size:.82rem;transition:all .2s}.titles-screen{flex-direction:column;gap:1.4rem;max-width:700px;margin:0 auto;padding:1.25rem;display:flex}.titles-header{flex-direction:column;gap:.75rem;display:flex}.titles-header h1{color:#e2e8f0;margin:0;font-size:1.4rem;font-weight:800}.titles-progress{align-items:center;gap:.8rem;display:flex}.titles-progress-bar{background:#ffffff14;border-radius:4px;flex:1;height:8px;overflow:hidden}.titles-progress-fill{background:linear-gradient(90deg,#7c3aed,#fbbf24);border-radius:4px;height:100%;transition:width .6s}.titles-count{color:#a78bfa;white-space:nowrap;font-size:.82rem;font-weight:700}.grand-master-card{background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;align-items:center;gap:1rem;padding:1.2rem;transition:all .3s;display:flex}.grand-master-card.unlocked{background:linear-gradient(135deg,#fbbf241a,#7c3aed1a);border-color:#fbbf2466;box-shadow:0 4px 20px #fbbf2426}.gm-icon{font-size:2.5rem}.gm-info{flex:1}.gm-name{color:#e2e8f0;margin-bottom:.2rem;font-size:1rem;font-weight:700}.gm-desc{color:#64748b;font-size:.78rem}.gm-status{gap:.4rem;display:flex}.gm-dot{background:#ffffff1a;border-radius:50%;width:10px;height:10px;transition:background .3s}.gm-dot.done{background:#4ade80}.diff-section{flex-direction:column;gap:.75rem;display:flex}.diff-section-title{text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.82rem;font-weight:700}.titles-grid{flex-direction:column;gap:.5rem;display:flex}.title-row{background:#ffffff05;border:1px solid #ffffff0d;border-radius:10px;align-items:center;gap:.75rem;padding:.6rem .9rem;display:flex}.title-song-name{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.8rem;overflow:hidden}.title-stages{flex-shrink:0;gap:.4rem;display:flex}.title-cell{background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;flex-direction:column;align-items:center;gap:.1rem;width:46px;padding:.3rem .2rem;transition:all .2s;display:flex}.title-cell.earned{background:#fbbf241a;border-color:#fbbf2459}.title-cell.cleared{background:#4ade8012;border-color:#4ade8033}.title-cell-icon{font-size:1rem}.title-cell-lock{color:#1e293b;font-size:.9rem;font-weight:700}.title-cell-label{color:#475569;text-align:center;font-size:.58rem;line-height:1.2}.title-cell.earned .title-cell-label{color:#fbbf24}@media (width<=480px){.title-cell{width:38px}.title-cell-label{font-size:.52rem}}.settings-screen{flex-direction:column;gap:1.25rem;max-width:640px;margin:0 auto;padding:1.25rem;display:flex}.settings-header h1{color:#e2e8f0;margin:0;font-size:1.4rem;font-weight:800}.settings-notification{border-radius:10px;padding:.75rem 1rem;font-size:.85rem;font-weight:600;animation:.3s slide-down}.settings-notification.success{color:#4ade80;background:#22c55e1f;border:1px solid #22c55e4d}.settings-notification.error{color:#f87171;background:#f871711f;border:1px solid #f871714d}.settings-section{background:#ffffff08;border:1px solid #ffffff12;border-radius:14px;overflow:hidden}.settings-section-title{text-transform:uppercase;letter-spacing:.08em;color:#64748b;border-bottom:1px solid #ffffff0d;margin:0;padding:.75rem 1rem .5rem;font-size:.75rem;font-weight:700}.settings-section-body{padding:.5rem 0}.settings-row{justify-content:space-between;align-items:center;gap:1rem;min-height:44px;padding:.6rem 1rem;display:flex}.settings-row-label{color:#94a3b8;flex:1;font-size:.85rem}.settings-row-control{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.settings-toggle{cursor:pointer;color:#475569;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;min-width:52px;padding:.3rem .9rem;font-family:Outfit,sans-serif;font-size:.78rem;font-weight:700;transition:all .2s}.settings-toggle.on{color:#a78bfa;background:#7c3aed33;border-color:#7c3aed66}.lang-selector{gap:.5rem;display:flex}.lang-opt{color:#475569;cursor:pointer;background:#ffffff08;border:1px solid #ffffff1a;border-radius:9px;padding:.4rem 1rem;font-family:Outfit,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s}.lang-opt.active{color:#a78bfa;background:#7c3aed2e;border-color:#7c3aed66}.settings-slider{accent-color:#7c3aed;width:120px}.slider-value{color:#64748b;text-align:right;min-width:35px;font-size:.78rem}.settings-select{color:#e2e8f0;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;max-width:200px;padding:.3rem .6rem;font-family:Outfit,sans-serif;font-size:.8rem}.settings-note{color:#475569;align-items:flex-start;gap:.5rem;padding:.6rem 1rem;font-size:.75rem;line-height:1.5;display:flex}.calib-control{align-items:center;gap:.6rem;display:flex}.calib-value{color:#a78bfa;min-width:40px;font-size:.85rem;font-weight:700}.calib-panel{background:#7c3aed12;border:1px solid #7c3aed33;border-radius:10px;flex-direction:column;gap:.6rem;margin:0 1rem .5rem;padding:1rem;display:flex}.calib-panel p{color:#94a3b8;margin:0;font-size:.85rem}.calib-progress{color:#a78bfa;font-size:.85rem;font-weight:600}.tap-btn-small{width:auto;padding:.5rem 1.2rem;font-size:.9rem}.calib-log{flex-wrap:wrap;gap:.4rem;display:flex}.calib-entry{color:#c4b5fd;background:#7c3aed26;border-radius:6px;padding:.15rem .5rem;font-family:monospace;font-size:.75rem}.calib-avg{color:#94a3b8;margin:0;font-size:.85rem}.calib-avg strong{color:#4ade80}.calib-done-btns{gap:.5rem;display:flex}.radio-group{flex-wrap:wrap;gap:.5rem;display:flex}.radio-opt{cursor:pointer;color:#64748b;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:.4rem;padding:.35rem .8rem;font-size:.8rem;transition:all .2s;display:flex}.radio-opt.active{color:#38bdf8;background:#0ea5e91f;border-color:#0ea5e94d}.radio-opt input{display:none}.data-actions{flex-direction:column;gap:.6rem;padding:.75rem 1rem;display:flex}.btn-danger{color:#f87171;cursor:pointer;text-align:left;background:#f871711a;border:1px solid #f871714d;border-radius:10px;padding:.6rem 1.2rem;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.btn-danger:hover{background:#f871712e}.btn-outline{color:#94a3b8;cursor:pointer;text-align:left;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;padding:.6rem 1.2rem;font-family:Outfit,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.btn-outline:hover{color:#e2e8f0;border-color:#fff3}
