:root{color-scheme:dark;--bg: #0e0f13;--panel: #161821;--panel-2: #1d2030;--border: #242838;--text: #e7e9ee;--muted: #8a90a0;--accent: #2a64ff;--ok: #3ddc84;--err: #ff5468}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font:16px/1.45 system-ui,-apple-system,sans-serif;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}.app{display:flex;flex-direction:column;height:100dvh;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.app-header{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border)}.brand{font-weight:700;font-size:16px;letter-spacing:.01em}.midi-status{display:flex;align-items:center;gap:8px;margin-left:auto;font-size:12.5px;color:var(--muted);min-width:0}.midi-status .dot{width:9px;height:9px;border-radius:50%;background:var(--muted);flex:none}.midi-status.ok .dot{background:var(--ok);box-shadow:0 0 8px var(--ok)}.midi-status.ok{color:var(--ok)}.midi-status.err .dot{background:var(--err)}.midi-status.err{color:var(--err)}.midi-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.midi-connect{flex:none;background:var(--accent);color:#fff;border:0;border-radius:7px;padding:6px 10px;font-size:12px;font-weight:600}.app-main{flex:1;min-height:0;display:flex;flex-direction:column}.mode{flex:1;display:flex;flex-direction:column;min-height:0}.stage{position:relative;flex:1;min-height:0;margin:10px 12px 0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:linear-gradient(180deg,#0c0d12,#12131b)}.falling-canvas{display:block;width:100%;height:100%}.countin{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:96px;font-weight:800;color:var(--accent);text-shadow:0 0 40px rgba(42,100,255,.5)}.stage-hint{position:absolute;left:0;right:0;top:44%;text-align:center;color:var(--muted);font-size:12.5px;padding:0 28px}.stage-hint b{color:var(--text)}.controls{display:flex;flex-wrap:wrap;align-items:end;gap:12px;padding:14px 12px}.field{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted)}.field span{font-weight:600}.field select,.field input[type=range]{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:9px;padding:9px 10px;font-size:14px;min-width:120px}.field input[type=range]{padding:6px 0;min-width:160px;accent-color:var(--accent)}.field-check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text)}.field-check input{width:20px;height:20px;accent-color:var(--accent)}button.primary{margin-left:auto;background:var(--accent);color:#fff;border:0;border-radius:11px;padding:13px 22px;font-size:16px;font-weight:700}button.ghost{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:11px;padding:12px 18px;font-size:15px;font-weight:600}button:active{transform:translateY(1px)}.results{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0b10eb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;justify-content:center;gap:18px;padding:22px}.results h2{margin:0;font-size:22px;text-align:center}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px}.metric-value{font-size:26px;font-weight:800}.metric-label{font-size:12.5px;color:var(--muted);margin-top:2px}.metric-hint{font-size:11px;color:#6a7080;margin-top:4px}.results-actions{display:flex;gap:12px}.results-actions .primary{margin:0;flex:1;text-align:center}.tabbar{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--border)}.tab{flex:1;min-width:0;background:transparent;color:var(--muted);border:0;border-radius:10px;padding:7px 1px;display:flex;flex-direction:column;align-items:center;gap:2px}.tab-icon{font-size:18px;line-height:1}.tab-label{font-size:10px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.tab.active{background:var(--panel-2);color:var(--text)}.home{flex:1;overflow-y:auto;padding:16px 14px 22px}.home-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.home-greet{font-size:24px;font-weight:800}.home-sub{color:var(--muted);font-size:14px;margin-top:2px}.home-stats{display:flex;gap:10px;margin-bottom:16px}.hstat{flex:1;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:12px}.hstat.center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.hstat-top{display:flex;align-items:center;margin-bottom:7px}.hstat-lv{font-weight:800;color:var(--accent);font-size:14px}.hstat-label{font-size:11px;color:var(--muted);margin-top:5px}.hstat.center .hstat-label{margin-top:0}.streak-big{font-size:22px;font-weight:800}.home-ring .dr-track{fill:none;stroke:#ffffff1a;stroke-width:5}.home-ring .dr-fill{fill:none;stroke:var(--accent);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .4s}.home-ring.done .dr-fill{stroke:var(--ok)}.home-ring .dr-text{fill:var(--text);font-size:12px;font-weight:800;text-anchor:middle}.home-ring.done .dr-text{fill:var(--ok)}.continue-card{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#2a64ff,#1b3fb0);color:#fff;border:0;border-radius:16px;padding:16px 18px;margin-bottom:18px;text-align:left}.continue-card:active{transform:scale(.99)}.cc-label{font-size:12px;opacity:.85;font-weight:600}.cc-title{font-size:19px;font-weight:800;margin-top:2px}.cc-go{font-weight:700;white-space:nowrap}.home-section-title{font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:10px}.home-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mode-card{display:flex;flex-direction:column;gap:4px;text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px;color:var(--text)}.mode-card:active{transform:scale(.98)}.mc-icon{font-size:26px}.mc-title{font-size:16px;font-weight:700}.mc-sub{font-size:12px;color:var(--muted)}.theory{overflow:hidden}.segmented{display:flex;gap:4px;margin:12px 12px 0;background:var(--panel);border:1px solid var(--border);border-radius:11px;padding:4px}.seg{flex:1;background:transparent;color:var(--muted);border:0;border-radius:8px;padding:9px 0;font-size:14px;font-weight:600}.seg.active{background:var(--accent);color:#fff}.theory-scroll{flex:1;overflow-y:auto;padding:14px 12px 20px}.circle5{width:100%;max-width:360px;margin:0 auto 14px;display:block}.circle5 .c5-ring{fill:none;stroke:#ffffff0f}.circle5 .c5-major{fill:var(--panel-2);stroke:var(--border);stroke-width:1}.circle5 .c5-minor{fill:#12131b;stroke:var(--border);stroke-width:1}.circle5 .selected .c5-major{fill:var(--accent);stroke:var(--accent)}.circle5 .selected .c5-minor{fill:#2a3358;stroke:var(--accent)}.circle5 text{fill:var(--text);text-anchor:middle;dominant-baseline:middle}.circle5 .c5-major-label{font-size:14px;font-weight:700}.circle5 .c5-sig{font-size:8px;fill:var(--muted)}.circle5 .selected .c5-sig{fill:#fffc}.circle5 .c5-minor-label{font-size:11px;fill:var(--muted)}.circle5 .c5-center-top,.circle5 .c5-center-bot{fill:#4a5063;font-size:13px;font-weight:700}.key-detail{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:12px}.kd-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.kd-name{font-size:22px;font-weight:800}.kd-sig{color:var(--muted);font-size:13px}.kd-row{display:flex;gap:10px;padding:5px 0;border-top:1px solid var(--border)}.kd-label{color:var(--muted);font-size:13px;width:116px;flex:none}.kd-value{font-size:15px}.kd-scale{letter-spacing:.02em}.mnemonic{display:flex;flex-direction:column;gap:6px}.mn-row{display:flex;gap:10px;font-size:13px}.mn-label{color:var(--muted);width:116px;flex:none}.quiz-ready,.quiz-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:24px;color:var(--muted)}.qr-level{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.04em}.quiz-done h2{color:var(--text);margin:0}.quiz-ready .primary,.quiz-done .primary{margin:0}.quiz{flex:1;display:flex;flex-direction:column;padding:16px 14px;gap:14px;overflow-y:auto}.quiz-bar{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}.quiz-prompt{font-size:19px;font-weight:700;line-height:1.3}.quiz-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px}.choice{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:11px;padding:16px 10px;font-size:17px;font-weight:600;min-height:56px}.choice.correct{background:#11331f;border-color:var(--ok);color:var(--ok)}.choice.wrong{background:#3a1518;border-color:var(--err);color:var(--err)}.choice.dim{opacity:.5}.quiz-explain{display:flex;flex-direction:column;gap:12px}.quiz-explain p{margin:0;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:14px;color:var(--text)}.quiz-explain .primary{margin:0}.seg3 .seg{font-size:13px}.path-tools{display:flex;justify-content:flex-end;padding:0 2px 8px}.mute-btn{background:var(--panel-2);border:1px solid var(--border);border-radius:9px;padding:6px 10px;font-size:15px}.pathmap{padding-bottom:12px}.path-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.ph-left{display:flex;align-items:center;gap:10px}.ph-title{font-size:18px;font-weight:800}.ph-sub{font-size:12.5px;color:var(--muted)}.ph-stars{background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-weight:700;font-size:14px;white-space:nowrap}.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.badge{display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:5px 11px;font-size:13px}.badge-label{color:var(--muted)}.path{display:flex;flex-direction:column;gap:20px;padding:6px 0}.path-step{display:flex;align-items:center;gap:14px;width:78%}.path-step.left{margin-right:auto}.path-step.right{margin-left:auto;flex-direction:row-reverse;text-align:right}.node{width:66px;height:66px;flex:none;border-radius:50%;border:2px solid var(--border);background:var(--panel-2);color:var(--text);font-size:26px;display:grid;place-items:center;position:relative;transition:transform .12s}.node:active{transform:scale(.94)}.node.locked{opacity:.45}.node.open{border-color:var(--accent)}.node.done{background:linear-gradient(160deg,#15351f,#112b1a);border-color:var(--ok)}.node.next{border-color:var(--accent);box-shadow:0 0 #2a64ff80;animation:nodePulse 1.8s infinite}@keyframes nodePulse{0%{box-shadow:0 0 #2a64ff73}70%{box-shadow:0 0 0 14px #2a64ff00}to{box-shadow:0 0 #2a64ff00}}.node-meta{min-width:0}.node-title{font-size:14px;font-weight:600}.node-cta{font-size:12.5px;color:var(--accent);font-weight:700}.lesson{display:flex;flex-direction:column;min-height:60vh}.lesson-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}.lesson-x{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;color:var(--muted);font-size:14px;flex:none}.lesson-progress-wrap{flex:1}.lesson-title{font-weight:700;font-size:15px}.lesson-progress{height:8px;background:var(--panel-2);border-radius:999px;overflow:hidden}.lp-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s}.lesson-step{color:var(--muted);font-size:12.5px;font-variant-numeric:tabular-nums}.lesson-body{flex:1}.lesson-foot{margin-top:18px}.primary.wide{width:100%;margin:0;text-align:center}.guide-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.speech{background:var(--panel);border:1px solid var(--border);border-radius:4px 14px 14px;padding:13px 15px;font-size:15px;line-height:1.45}.lesson-visual{display:flex;justify-content:center}.chip-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.chip{display:inline-grid;place-items:center;min-width:40px;padding:9px 11px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;font-size:17px;font-weight:700}.chip.sharp{color:#7fa8ff;border-color:#2f3f6b}.chip.flat{color:#c8b4ff;border-color:#463a6b}.chip.emph{box-shadow:0 0 0 2px var(--accent)}.visual-accidentals{text-align:center}.big-acc{font-size:72px;font-weight:700;line-height:1}.big-acc.sharp{color:#7fa8ff}.big-acc.flat{color:#c8b4ff}.acc-caption{color:var(--muted);font-size:13px;margin-top:6px}.visual-scale{text-align:center}.vs-key{font-weight:800;font-size:18px;margin-bottom:10px}.visual-relminor{display:flex;align-items:center;gap:14px;font-size:24px;font-weight:800}.rm-arrow{color:var(--muted)}.rm-minor{color:#c8b4ff}.lesson-result{align-items:center;text-align:center;justify-content:center;gap:12px}.lesson-result h2{margin:4px 0 0}.result-burst{position:relative}.result-acc{color:var(--muted);font-size:14px}.lesson-result .lesson-foot{width:100%}.stars{display:inline-flex;gap:3px;line-height:1}.star.on{color:#ffd23f}.star.off{color:#2b2f3c}.star.pop{animation:starPop .4s backwards}@keyframes starPop{0%{transform:scale(0)}60%{transform:scale(1.35)}to{transform:scale(1)}}.mascot .m-body{fill:var(--accent)}.mascot .m-stem{stroke:var(--accent);stroke-width:4;fill:none;stroke-linecap:round}.mascot .m-flag{fill:var(--accent)}.mascot .m-eye{fill:#0c0d12}.mascot .m-eye-line,.mascot .m-smile,.mascot .m-mouth-line{stroke:#0c0d12;stroke-width:2.6;fill:none;stroke-linecap:round}.mascot .m-mouth-open{fill:#0c0d12}.mascot .m-cheek{fill:#ff9aa9;opacity:.85}.mascot.mood-cheer{animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}30%{transform:translateY(-8px)}60%{transform:translateY(-2px)}}.explain-row{display:flex;gap:10px;align-items:flex-start}.explain-row p{margin:0;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:11px 13px;font-size:14px;flex:1}.confetti{position:absolute;top:-20px;right:-60px;bottom:-20px;left:-60px;pointer-events:none;overflow:visible}.confetti-bit{position:absolute;top:0;width:8px;height:8px;border-radius:2px;background:hsl(calc(var(--i) * 47),80%,60%);animation:confFall 1.1s ease-in forwards;animation-delay:calc(var(--i) * .04s)}@keyframes confFall{0%{transform:translateY(-10px) rotate(0);opacity:1}to{transform:translateY(120px) rotate(360deg);opacity:0}}.circle5 .c5-node.dimmed{opacity:.32}.game-bar{display:flex;align-items:center;gap:12px;margin-bottom:14px}.level-chip{flex:1;display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:9px 12px}.lv-num{font-weight:800;font-size:13px;color:var(--accent);white-space:nowrap}.xp-bar{flex:1;height:8px;background:var(--panel-2);border-radius:999px;overflow:hidden}.xp-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .4s}.xp-text{font-size:11px;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}.daily-ring{display:flex;flex-direction:column;align-items:center;flex:none}.dr-track{fill:none;stroke:#ffffff1a;stroke-width:5}.dr-fill{fill:none;stroke:var(--accent);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .4s}.daily-ring.done .dr-fill{stroke:var(--ok)}.dr-text{fill:var(--text);font-size:13px;font-weight:800;text-anchor:middle}.daily-ring.done .dr-text{fill:var(--ok)}.dr-label{font-size:10px;color:var(--muted);margin-top:1px}.hearts{display:inline-flex;gap:3px}.heart{color:#ff5468;font-size:16px}.heart.lost{color:#2b2f3c}.quiz-topline{min-height:22px;display:flex;justify-content:center}.combo{color:#ffd23f;font-weight:800;font-size:14px;animation:pop .3s}@keyframes pop{0%{transform:scale(.6)}60%{transform:scale(1.2)}to{transform:scale(1)}}.xp-gain{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;font-weight:800;color:var(--accent);font-size:18px}.xp-tag{font-size:12px;font-weight:700;background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:3px 9px;color:var(--text)}.xp-tag.goal{color:var(--ok)}.ghost.wide{width:100%;margin-top:8px;text-align:center}.gentle-tag{font-size:12px;color:var(--ok);font-weight:700;background:#3ddc841f;border-radius:999px;padding:4px 10px;white-space:nowrap}.step-say{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:30px 10px}.say-text{font-size:18px;line-height:1.5;font-weight:600}.tf-statement{font-size:20px;font-weight:700;line-height:1.4;text-align:center;padding:22px 6px 14px}.tf-choices{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tf-btn{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;padding:20px;font-size:18px;font-weight:700;color:var(--text);min-height:64px;transition:transform .1s}.tf-btn:active{transform:scale(.97)}.tf-btn.correct{background:#11331f;border-color:var(--ok);color:var(--ok)}.tf-btn.wrong{background:#3a1518;border-color:var(--err);color:var(--err)}.tf-btn.dim{opacity:.5}.q-visual{margin-bottom:14px}.kbd{width:100%;max-width:340px;display:block;margin:0 auto}.kbd .wk{fill:#eef0f4;stroke:#b9bfcb;stroke-width:1}.kbd .wk.on{fill:var(--accent);stroke:var(--accent)}.kbd .wk-label{fill:#5a6172;font-size:11px;font-weight:700;text-anchor:middle}.kbd .wk-label.on{fill:#fff}.kbd .bk{fill:#1a1d26;stroke:#05060a;stroke-width:1}.kbd .bk.on{fill:var(--accent);stroke:var(--accent)}.kbd .step-lab{text-anchor:middle;font-size:12px;font-weight:800}.kbd .step-lab.half{fill:#ff5468}.kbd .step-lab.whole{fill:#8a90a0}.quiz-explain.ok p{border-color:#3ddc8473}.quiz-explain.no p{border-color:#ff546873}.reading-head{display:flex;align-items:center;gap:10px;padding:12px 14px 0}.level-badge{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.level-label{color:var(--muted);font-size:13px}.reading-stage{background:#f4f5f8;display:flex;align-items:center;justify-content:center}.notation{width:100%;overflow-x:auto;display:flex;justify-content:center}.notation svg{max-width:none}.reading-hint{position:absolute;left:0;right:0;bottom:12px;text-align:center;color:#5a6172;font-size:12px;padding:0 22px}.reading-hint b{color:#20242e}.reading-progress{font-variant-numeric:tabular-nums;font-weight:700;color:var(--muted)}.error-patterns{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 14px}.ep-title{font-size:12px;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.ep-row{display:flex;justify-content:space-between;font-size:14px;padding:2px 0}.ep-count{color:var(--err);font-weight:700}.history{flex:1;overflow-y:auto;padding:14px 12px 20px}.streak-card{background:linear-gradient(135deg,#1a1d2b,#14161f);border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:16px}.streak-main{display:flex;align-items:baseline;gap:10px}.streak-flame{font-size:26px}.streak-num{font-size:34px;font-weight:800}.streak-unit{color:var(--muted);font-size:14px}.streak-sub{display:flex;gap:8px;color:var(--muted);font-size:13px;margin-top:6px}.hist-section{margin-bottom:18px}.hist-section h3{font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0 0 10px}.chart-grid{display:grid;grid-template-columns:1fr;gap:12px}@media (min-width: 560px){.chart-grid{grid-template-columns:1fr 1fr}}.chart-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 12px 6px}.chart-title{font-size:14px;font-weight:600}.chart-hint{font-size:11.5px;color:var(--muted);margin:1px 0 6px}.chart-empty{color:#6a7080;font-size:13px;padding:16px 4px}.line-chart{width:100%;height:auto;display:block}.line-chart .grid{stroke:#ffffff12;stroke-width:1}.line-chart .axis{fill:#6a7080;font-size:9px}.line-chart .last-val{font-size:11px;font-weight:700}.coming-soon{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;color:var(--muted);padding:24px}.coming-soon h2{color:var(--text);margin:4px 0}.cs-phase{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700}
