:root{--bg-0: #0d0f14;--bg-1: #14171f;--bg-2: #1b1f29;--bg-3: #232838;--panel-border: #2c3242;--text-0: #e6e9f0;--text-1: #aab2c5;--text-2: #6b7283;--accent: #2dd4bf;--accent-dim: #1c8a7e;--amber: #f5b942;--amber-dim: #b9821f;--danger: #f0556b;--ok: #4ade80;--shadow: 0 4px 20px rgba(0, 0, 0, .45);--radius: 10px;--mono: "SF Mono", "JetBrains Mono", "Consolas", "Menlo", monospace;--sans: "Inter", -apple-system, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-0);color:var(--text-0);font-family:var(--sans);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:var(--bg-1)}::-webkit-scrollbar-thumb{background:#3a4153;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#4a5268}.app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;gap:18px;padding:0 20px;height:58px;background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border-bottom:1px solid var(--panel-border);flex-shrink:0}.brand{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:.5px;font-size:17px}.brand .logo{color:var(--accent)}.brand .sub{font-size:11px;color:var(--text-2);font-weight:500;letter-spacing:0}.nav{display:flex;gap:4px;background:var(--bg-0);padding:4px;border-radius:var(--radius);border:1px solid var(--panel-border)}.nav button{display:flex;align-items:center;gap:7px;padding:7px 14px;border:none;background:transparent;color:var(--text-1);border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.nav button:hover{color:var(--text-0);background:var(--bg-3)}.nav button.active{background:var(--accent);color:#042b27}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}.audio-pill{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-1);padding:6px 12px;border-radius:20px;border:1px solid var(--panel-border);background:var(--bg-0)}.audio-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--text-2)}.audio-pill.ready .dot{background:var(--ok);box-shadow:0 0 8px var(--ok)}.audio-pill.loading .dot{background:var(--amber);animation:pulse 1s infinite}.audio-pill.error .dot{background:var(--danger)}@keyframes pulse{50%{opacity:.3}}.key-select,.bpm-box{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-1)}select,.btn{background:var(--bg-3);color:var(--text-0);border:1px solid var(--panel-border);border-radius:7px;padding:6px 10px;font-size:13px;font-family:var(--sans);cursor:pointer}select:focus,.btn:focus{outline:1px solid var(--accent)}.content{flex:1;overflow-y:auto;padding:24px}.panel{background:var(--bg-1);border:1px solid var(--panel-border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--panel-border);font-weight:600;font-size:13px;color:var(--text-1);letter-spacing:.3px}.panel-head .tag{margin-left:auto;font-size:11px;color:var(--text-2);font-family:var(--mono)}.panel-body{padding:18px}.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;transition:all .15s}.btn:hover{border-color:var(--accent-dim)}.btn.primary{background:var(--accent);color:#042b27;border-color:var(--accent)}.btn.primary:hover{background:#38e6d2}.btn.amber{background:var(--amber);color:#2b1d02;border-color:var(--amber)}.btn:disabled{opacity:.45;cursor:not-allowed}.hint{color:var(--text-2);font-size:12px;line-height:1.6}input[type=range]{accent-color:var(--accent);cursor:pointer}.staff-host{background:linear-gradient(180deg,#161a22,#11141b);border:1px solid var(--panel-border);border-radius:8px;padding:6px 4px;overflow-x:auto}.staff-host svg{display:block}.jianpu{display:flex;flex-wrap:wrap;align-items:flex-start;gap:6px;padding:14px 6px;font-family:var(--mono);min-height:84px}.jp-note{display:flex;flex-direction:column;align-items:center;padding:4px 5px;border-radius:7px;transition:background .12s,transform .12s}.jp-note.active{background:#2dd4bf29;transform:translateY(-2px)}.jp-dots{display:flex;gap:3px;height:9px;align-items:center;justify-content:center}.jp-dot{width:4px;height:4px;border-radius:50%;background:var(--text-1)}.jp-note.active .jp-dot{background:var(--accent)}.jp-row{display:flex;align-items:flex-end;gap:2px}.jp-digit-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.jp-acc{position:absolute;left:-10px;top:2px;font-size:13px;color:var(--amber)}.jp-digit{font-size:26px;font-weight:600;line-height:1;color:var(--text-0)}.jp-note.active .jp-digit{color:var(--accent)}.jp-underlines{display:flex;flex-direction:column;gap:2px;width:100%;margin-top:2px}.jp-uline{height:1.5px;background:var(--text-0);border-radius:1px}.jp-note.active .jp-uline{background:var(--accent)}.jp-dash{font-size:22px;color:var(--text-1);line-height:1;padding-bottom:2px}.jp-solfege{margin-top:5px;font-size:11px;color:var(--text-2)}.jp-note.active .jp-solfege{color:var(--accent)}.fretboard-host{width:100%;overflow-x:auto}.fretboard-host svg{display:block;margin:0 auto}.fret-dot:hover circle{filter:brightness(1.35)}.dualscore{display:flex;flex-direction:column;gap:16px;max-width:860px;margin:0 auto}.toolbar-body{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-bottom:10px}.ex-select{display:flex;align-items:center;gap:8px;color:var(--text-1)}.ex-select select{min-width:220px}.bpm-box{display:flex;align-items:center;gap:10px}.bpm-box input[type=range]{width:120px}.bpm-val{font-family:var(--mono);font-size:12px;color:var(--accent);min-width:62px}.chk.sm{font-size:12px;gap:5px}.countdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#080a0e8c;z-index:50;pointer-events:none}.countdown-num{font-family:var(--mono);font-size:120px;font-weight:700;color:var(--accent);text-shadow:0 0 40px rgba(45,212,191,.6);animation:cd-pop .5s ease-out}@keyframes cd-pop{0%{transform:scale(1.5);opacity:0}to{transform:scale(1);opacity:1}}.ex-desc{margin:0;padding:0 18px 14px;color:var(--text-2);font-size:12.5px;line-height:1.6}.explorer{display:flex;flex-direction:column;gap:16px;max-width:920px;margin:0 auto}.explorer-controls{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:16px}.chk{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-1);cursor:pointer}.chk input{accent-color:var(--accent);cursor:pointer}.now-playing{display:flex;align-items:center;gap:14px;margin-top:16px;padding:14px 18px;background:var(--bg-0);border:1px solid var(--panel-border);border-radius:var(--radius);min-height:30px}.np-icon{color:var(--accent)}.np-name{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--accent)}.np-meta{font-size:13px;color:var(--text-1)}.np-degree{margin-left:auto;font-size:13px;color:var(--amber)}.np-degree b{font-size:16px}.tips{margin:0;padding-left:20px;color:var(--text-1);font-size:13px;line-height:2}.tips b{color:var(--accent);font-family:var(--mono)}.eartrainer{display:flex;flex-direction:column;gap:16px;max-width:720px;margin:0 auto}.type-tabs{display:flex;gap:8px;flex-wrap:wrap}.type-tab{padding:9px 16px;border:1px solid var(--panel-border);background:var(--bg-0);color:var(--text-1);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.type-tab:hover{color:var(--text-0);border-color:var(--accent-dim)}.type-tab.active{background:var(--accent);color:#042b27;border-color:var(--accent)}.start-box{display:flex;flex-direction:column;align-items:center;gap:14px;padding:24px 0}.btn.lg{padding:12px 26px;font-size:15px}.play-row{display:flex;align-items:center;gap:16px;margin-bottom:18px}.verdict{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14px}.verdict.ok{color:var(--ok)}.verdict.bad{color:var(--danger)}.choices{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:10px}.choice{padding:16px 10px;border:1px solid var(--panel-border);background:var(--bg-2);color:var(--text-0);border-radius:9px;font-size:15px;font-weight:600;font-family:var(--mono);cursor:pointer;transition:all .12s}.choice:hover:not(:disabled){border-color:var(--accent);background:var(--bg-3)}.choice.picked{border-color:var(--accent);background:var(--bg-3)}.choice.right{border-color:var(--ok);background:#4ade8026;color:var(--ok)}.choice.wrong{border-color:var(--danger);background:#f0556b26;color:var(--danger)}.choice:disabled{cursor:default}.explain-box{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:18px;padding-top:16px;border-top:1px solid var(--panel-border);flex-wrap:wrap}.explain{margin:0;color:var(--text-1);font-size:13.5px;line-height:1.6;flex:1;min-width:200px}.mode-switch{display:flex;gap:4px;background:var(--bg-0);border:1px solid var(--panel-border);border-radius:var(--radius);padding:4px;max-width:860px;margin:0 auto 16px}.mode-switch button{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:none;background:transparent;color:var(--text-1);border-radius:7px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.mode-switch button:hover{background:var(--bg-3);color:var(--text-0)}.mode-switch button.active{background:var(--accent);color:#042b27}.mode-switch button:disabled{opacity:.5;cursor:not-allowed}.mode-switch button:disabled:hover{background:transparent;color:var(--text-1)}.mic-unavailable{display:flex;align-items:center;gap:10px;max-width:860px;margin:0 auto 16px;padding:12px 16px;border:1px solid var(--amber-dim);background:#f5b94214;border-radius:var(--radius);color:var(--amber);font-size:13px;line-height:1.5}.play-tip{color:var(--amber);font-weight:600}.best-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--amber);font-family:var(--mono)}.pitch-meter{display:flex;align-items:center;gap:28px;padding:8px 4px}.pm-note{display:flex;flex-direction:column;align-items:center;min-width:88px}.pm-name{font-family:var(--mono);font-size:40px;font-weight:700;line-height:1;color:var(--text-1)}.pitch-meter.good .pm-name{color:var(--ok);text-shadow:0 0 18px rgba(74,222,128,.5)}.pitch-meter.close .pm-name{color:var(--amber)}.pitch-meter.off .pm-name{color:var(--danger)}.pm-hz{font-family:var(--mono);font-size:12px;color:var(--text-2);margin-top:4px}.pm-gauge{flex:1}.pm-scale{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);margin-bottom:4px}.pm-center-mark{width:1px}.pm-track{position:relative;height:26px;background:var(--bg-0);border:1px solid var(--panel-border);border-radius:13px;overflow:hidden}.pm-center-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--text-2);transform:translate(-1px)}.pm-needle{position:absolute;top:3px;bottom:3px;width:6px;border-radius:3px;background:var(--accent);transform:translate(-3px);transition:left .08s linear}.pitch-meter.good .pm-needle{background:var(--ok)}.pitch-meter.close .pm-needle{background:var(--amber)}.pitch-meter.off .pm-needle{background:var(--danger)}.pm-cents{text-align:center;font-family:var(--mono);font-size:12px;color:var(--text-1);margin-top:6px}.pm-target{font-size:13px;color:var(--text-1)}.pm-target b{font-family:var(--mono);color:var(--accent);font-size:16px}.mic-error{color:var(--danger);font-size:13px;margin:0}.jp-note.hit .jp-digit{color:var(--ok)}.jp-note.hit{background:#4ade801f}.jp-note.miss .jp-digit{color:var(--danger)}.jp-note.miss{background:#f0556b1f}.result-card{display:flex;align-items:center;gap:22px;padding:20px 24px;border-radius:var(--radius);border:1px solid var(--panel-border);background:var(--bg-1)}.result-card.good{border-color:var(--ok);background:#4ade8014}.result-card.ok{border-color:var(--amber);background:#f5b94214}.result-card.low{border-color:var(--danger);background:#f0556b14}.result-num{font-family:var(--mono);font-size:48px;font-weight:700;color:var(--accent)}.result-card.good .result-num{color:var(--ok)}.result-card.ok .result-num{color:var(--amber)}.result-card.low .result-num{color:var(--danger)}.result-text{color:var(--text-1);font-size:14px;line-height:1.6}.result-sub{margin-top:6px;font-size:12px;color:var(--text-2);font-family:var(--mono)}.life-stat{color:var(--accent)}.dashboard{display:flex;flex-direction:column;gap:16px;max-width:860px;margin:0 auto}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-card{background:var(--bg-1);border:1px solid var(--panel-border);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:6px}.stat-ic{color:var(--accent)}.stat-ic.amber{color:var(--amber)}.stat-val{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--text-0)}.stat-lbl{font-size:12px;color:var(--text-2)}.day-bars{display:flex;align-items:flex-end;gap:8px;height:120px}.day-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.day-bar-track{flex:1;width:100%;display:flex;align-items:flex-end}.day-bar-fill{width:100%;min-height:2px;background:linear-gradient(180deg,var(--accent),var(--accent-dim));border-radius:4px 4px 0 0;transition:height .3s}.day-bar-lbl{font-size:9px;color:var(--text-2);font-family:var(--mono)}.prog-rows{display:flex;flex-direction:column;gap:12px}.prog-row{display:flex;align-items:center;gap:14px}.prog-name{width:130px;font-size:13px;color:var(--text-1);flex-shrink:0}.prog-bar{flex:1;height:10px;background:var(--bg-0);border-radius:5px;overflow:hidden}.prog-fill{height:100%;background:var(--accent);border-radius:5px;transition:width .3s}.prog-fill.amber{background:var(--amber)}.prog-meta{width:150px;text-align:right;font-size:11px;color:var(--text-2);font-family:var(--mono);flex-shrink:0}.mistake-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.mistake-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-0);border-radius:8px;font-size:13px}.mk-type{font-size:11px;color:var(--accent);background:#2dd4bf1f;padding:2px 8px;border-radius:4px;flex-shrink:0}.mk-prompt{font-family:var(--mono);color:var(--text-1);flex-shrink:0}.mk-detail{color:var(--text-2);margin-left:auto}.mk-detail .wrong{color:var(--danger)}.mk-detail .right{color:var(--ok)}.mk-clear{display:inline-flex;align-items:center;gap:5px;background:var(--bg-3);border:1px solid var(--panel-border);color:var(--text-1);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;flex-shrink:0}.mk-clear:hover{border-color:var(--accent);color:var(--accent)}.danger-btn{align-self:flex-start;color:var(--text-2);border-color:var(--panel-border)}.danger-btn:hover{border-color:var(--danger);color:var(--danger)}@media(max-width:640px){.stat-grid{grid-template-columns:repeat(2,1fr)}.prog-name{width:90px}.prog-meta{width:auto}}
