.instrument-surface[data-v-0311c22a]{width:100%;display:flex;overflow:hidden;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:none}[data-v-0311c22a] svg{pointer-events:none}[data-v-0311c22a] .instrument-key{pointer-events:auto!important;cursor:pointer}.procedural-debug[data-v-dea1a5af]{background:var(--bg);border:1px solid var(--border-dim);border-bottom:2px solid var(--border-dim);padding:15px;display:flex;flex-direction:column;gap:15px;width:100%;box-sizing:border-box}.debug-header[data-v-dea1a5af]{display:flex;justify-content:space-between;align-items:center}h3[data-v-dea1a5af]{margin:0;font-size:.8rem;color:var(--accent);text-transform:uppercase;letter-spacing:.05em;font-weight:900}.debug-grid[data-v-dea1a5af]{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px 25px}.control-group[data-v-dea1a5af]{display:flex;flex-direction:column;gap:5px}.control-header[data-v-dea1a5af]{display:flex;justify-content:space-between;align-items:baseline}label[data-v-dea1a5af]{font-size:.7rem;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.02em}.val[data-v-dea1a5af]{font-size:.75rem;font-weight:900;font-family:monospace;color:#fff}.dimmed-control[data-v-dea1a5af]{opacity:.4;filter:grayscale(.8);transition:all .3s}.dimmed-control[data-v-dea1a5af]:hover{opacity:.8;filter:grayscale(.3)}input[type=range][data-v-dea1a5af]{width:100%;accent-color:var(--accent);height:4px}.re-roll-btn[data-v-dea1a5af]{background:#ffffff0d;border:1px solid var(--border);color:#fff;padding:4px 12px;border-radius:12px;font-size:.7rem;font-weight:800;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.re-roll-btn[data-v-dea1a5af]:hover{background:var(--accent);border-color:#fff;color:var(--bg)}@media(max-width:600px){.debug-grid[data-v-dea1a5af]{grid-template-columns:1fr}}.controls-row[data-v-7f6a20ed]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.transport-btns[data-v-7f6a20ed]{display:flex;gap:4px;background:#0003;padding:4px;border-radius:8px}.transport-btn[data-v-7f6a20ed]{background:var(--surface);border:1px solid var(--border);color:#fff;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s}.transport-play-active[data-v-7f6a20ed]{background:var(--success);border-color:#fff;color:var(--bg)}.transport-pause-active[data-v-7f6a20ed]{background:var(--warning);border-color:#fff;color:var(--bg)}.song-select[data-v-7f6a20ed]{background:var(--bg);color:#fff;border:1px solid var(--border);padding:6px;border-radius:6px;font-size:.8rem}.sequencer-container.surface[data-v-7f6a20ed]{position:relative;background:#020617;border:1px solid var(--border-dim);border-radius:12px;padding:0;overflow:hidden}.ruler-row[data-v-7f6a20ed]{display:flex;height:24px;background:#ffffff08;border-bottom:1px solid var(--border-dim)}.ruler-content[data-v-7f6a20ed]{flex:1;position:relative}.measure-marker[data-v-7f6a20ed]{position:absolute;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.2);padding-left:4px;font-size:10px;font-weight:900;color:var(--text-dim);display:flex;align-items:center}.beat-marker[data-v-7f6a20ed]{position:absolute;top:12px;bottom:0;border-left:1px solid rgba(255,255,255,.05)}.playhead[data-v-7f6a20ed]{position:absolute;top:0;bottom:0;width:1px;background:var(--accent);z-index:20;pointer-events:none}.playhead-head[data-v-7f6a20ed]{position:absolute;top:0;left:-6px;width:13px;height:12px;background:var(--accent);clip-path:polygon(0% 0%,100% 0%,100% 60%,50% 100%,0% 60%)}.lane-row[data-v-7f6a20ed]{display:flex;height:70px;align-items:center;border-bottom:1px solid rgba(255,255,255,.05)}.lane-row[data-v-7f6a20ed]:last-child{border-bottom:none}.lane-controls[data-v-7f6a20ed]{width:55px;height:100%;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-dim);z-index:5;background:#020617}.lane-control-panel[data-v-7f6a20ed]{background:#ffffff08;padding:6px;border-radius:8px;display:flex;flex-direction:column;gap:6px;border:1px solid rgba(255,255,255,.05)}.mute-btn[data-v-7f6a20ed],.solo-btn[data-v-7f6a20ed]{width:28px;height:22px;font-size:11px;font-weight:900;border-radius:4px;cursor:pointer;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#ffffff4d;transition:all .2s}.mute-btn.active[data-v-7f6a20ed]{background:var(--error);color:#fff;border-color:#fff;box-shadow:0 0 8px var(--error)}.solo-btn.active[data-v-7f6a20ed]{background:var(--warning);color:var(--bg);border-color:#fff;box-shadow:0 0 8px var(--warning)}.mute-btn[data-v-7f6a20ed]:hover:not(.active),.solo-btn[data-v-7f6a20ed]:hover:not(.active){background:#ffffff1a;color:#fff}.lane-viewport[data-v-7f6a20ed]{flex:1;position:relative;height:100%;overflow:hidden;background-image:linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:6.25% 100%}.grid-subdivisions[data-v-7f6a20ed]{position:absolute;inset:0;pointer-events:none}.grid-line[data-v-7f6a20ed]{position:absolute;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.02)}.melody-note[data-v-7f6a20ed] .pad-hero{font-size:1.1em}.sequencer-note[data-v-7f6a20ed]{position:absolute;height:75%;top:12.5%;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.7rem;font-weight:900;border:1px solid rgba(255,255,255,.2);transition:all .1s;line-height:1.1}.melody-note[data-v-7f6a20ed]{background:#3b82f64d;color:#93c5fd}.harmony-note[data-v-7f6a20ed]{background:#a855f74d;color:#d8b4fe}.sys-active[data-v-7f6a20ed]{transform:scaleY(1.1);filter:brightness(1.4);border-color:#fff;box-shadow:0 0 12px currentColor;z-index:10}.user-active[data-v-7f6a20ed]{background:var(--success)!important;color:var(--bg)!important;border-color:#fff!important;box-shadow:0 0 15px var(--success);z-index:15;transform:scale(1.05)}.lane-muted .sequencer-note[data-v-7f6a20ed]{opacity:.2;filter:grayscale(1)}.instrument-controls[data-v-ab2ce2af]{margin-bottom:6px}.btns[data-v-ab2ce2af]{display:flex;flex-direction:row;gap:6px}.instrument-content[data-v-ab2ce2af]{display:flex;flex-direction:row}.instrument-header-right[data-v-ab2ce2af]{display:flex;flex-direction:row;gap:6px}.chord-button[data-v-ab2ce2af]{min-width:80px;height:32px;line-height:1;text-align:center;display:inline-flex;align-items:center;justify-content:center}.chord-button.no-chord[data-v-ab2ce2af]{font-size:.7em;color:#94a3b8;opacity:.6}.detected-chord[data-v-ab2ce2af]{font-size:.5em}.keysig-select[data-v-49a548d2]{padding:2px 6px;font-size:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px}.staff-surface[data-v-49a548d2]{width:100%;min-height:200px;display:block;background:#f8fafc;border:2px solid #cbd5e1;overflow:hidden;touch-action:none}[data-v-49a548d2] .vf-stavenote{transition:opacity .2s,filter .2s}[data-v-49a548d2] .vf-stavenote:hover{filter:brightness(.8)}[data-v-49a548d2] svg{width:100%;height:auto;display:block}.relative-container[data-v-938d2ae3]{position:relative;width:100%;overflow-x:auto;overflow-y:hidden}.tab-surface[data-v-938d2ae3]{width:100%;min-height:240px;background:#fff}.annotation-layer[data-v-938d2ae3]{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.floating-annotation[data-v-938d2ae3]{position:absolute;pointer-events:auto;display:flex;flex-direction:column;align-items:center;transform:translate(-50%,-100%);transition:all .2s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;z-index:10}.hero[data-v-938d2ae3],.note[data-v-938d2ae3]{font-size:.75rem;line-height:1.1;text-align:center;white-space:pre-line;font-weight:900;color:var(--note-color);padding:0 2px;border-radius:2px}.floating-annotation.active[data-v-938d2ae3]{transform:translate(-50%,-120%) scale(1.3);filter:drop-shadow(0 0 10px var(--note-color))}.piano-viewport[data-v-291a0885]{width:100%;position:relative;overflow-x:hidden;overflow-y:hidden;padding:0!important;margin:0!important;touch-action:none;cursor:default}.grab-strip[data-v-291a0885]{cursor:grab;touch-action:pan-x}.grab-strip[data-v-291a0885]:active{cursor:grabbing}.piano-content-wrapper[data-v-291a0885]{position:relative}.piano-surface[data-v-291a0885]{position:relative;height:150px;display:flex;padding:0;margin:0;gap:0;align-items:flex-start}.white-key[data-v-291a0885]{flex-shrink:0;border:1px solid #ccc}.white-key[data-v-291a0885]:first-child{border-left:1px solid #ccc}.black-key[data-v-291a0885]{position:absolute;top:0;z-index:10;box-sizing:border-box;border:1px solid #000}.piano-key[data-v-291a0885]{position:relative;flex-shrink:0;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;padding-bottom:10px;transition:filter .1s}.piano-key.user-active[data-v-291a0885],.piano-key.sys-active[data-v-291a0885]{border-right-width:4px;border-left-width:4px;border-right-color:var(--playing)!important;border-left-color:var(--playing)!important;filter:brightness(1.3)}.white-key .pad-sub[data-v-291a0885]{color:var(--text-dim)!important;opacity:.8}.piano-key.user-active[data-v-291a0885]{border-top-color:var(--playing)!important}.white-key[data-v-291a0885]{background:#fff;border:1px solid #ccc;height:100%;z-index:1}.black-key[data-v-291a0885]{background:#222;height:65%;position:absolute;z-index:2;color:#fff}.gap-note[data-v-291a0885]{opacity:.6;filter:grayscale(.5)}.out-of-scale[data-v-291a0885]{opacity:.3;filter:grayscale(1)}.white-key .piano-label[data-v-291a0885] .pad-hero{color:#1e293b;font-size:1.1em}.black-key .piano-label[data-v-291a0885] .pad-hero{color:#fff;font-size:1.1em}.piano-label[data-v-291a0885]{pointer-events:none;font-size:.7em;text-align:center}.mobile-rows .pad[data-v-622b9c1d]{flex:0 0 calc(100% / var(--pads-per-row))}.scheme-select[data-v-7c5512f3]{padding:2px 6px;font-size:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px}.pad[data-v-7c5512f3]{height:80px}.chord-notes[data-v-7c5512f3]{display:flex;flex-direction:row;gap:4px;margin-top:4px}.chord-note-name[data-v-7c5512f3]{font-size:.5em;color:var(--text-dim);opacity:.6}.mobile-rows .pad[data-v-6712ffbc]{flex:0 0 14.285%}.spiral-container[data-v-2c0b5b30]{display:flex;flex-direction:column;align-items:center;padding:20px;width:100%;box-sizing:border-box}.viz-container[data-v-2c0b5b30]{width:100%;background:#020617;border-radius:8px;border:2px solid #334155;box-sizing:border-box}.spiral-svg[data-v-2c0b5b30]{width:100%;max-width:400px;height:auto;overflow:visible;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.spiral-polygon[data-v-2c0b5b30]{cursor:pointer;stroke:#0f172a;stroke-width:.5;transition:filter .2s,transform .1s;touch-action:none;-webkit-tap-highlight-color:transparent}.spiral-polygon.active[data-v-2c0b5b30]{color:red}.out-of-scale[data-v-2c0b5b30]{opacity:.3}.solfege-label[data-v-2c0b5b30]{fill:#fff;font-size:9px;font-weight:800;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0px 1px 2px rgba(0,0,0,.8)}.active[data-v-2c0b5b30],.user-active[data-v-2c0b5b30]{filter:brightness(2.4) saturate(1.2);border-color:var(--playing)!important;fill:var(--playing)}.hovered-item[data-v-2c0b5b30]{border-color:var(--hover)!important;transform:translateY(-1px);box-shadow:0 4px 10px #d3d3d3!important}.circle-container[data-v-55b2f8b0]{display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;width:100%}.viz-container[data-v-55b2f8b0]{width:100%;background:#020617;border-radius:8px;border:2px solid #334155;box-sizing:border-box}.svg-wrapper[data-v-55b2f8b0]{filter:drop-shadow(0 10px 20px rgba(0,0,0,.4))}.wheel-svg[data-v-55b2f8b0]{display:block;max-width:100%;height:auto}.wheel-slice[data-v-55b2f8b0]{cursor:pointer;transition:filter .2s,fill .2s;stroke:#0003;stroke-width:1}.wheel-slice[data-v-55b2f8b0]:hover,.wheel-slice.hovered-item[data-v-55b2f8b0]{filter:brightness(1.4)}.wheel-slice.user-active[data-v-55b2f8b0]{fill:#fff!important;filter:brightness(1)}.note-slice.is-tonic[data-v-55b2f8b0]{stroke:#fff6;stroke-width:2}.slice-label[data-v-55b2f8b0]{pointer-events:none;fill:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.8)}.note-name[data-v-55b2f8b0]{font-size:.9rem}.chord-text[data-v-55b2f8b0]{font-size:.65rem}.chord-text .roman[data-v-55b2f8b0]{font-size:.8rem}.slice-sub[data-v-55b2f8b0]{font-size:.5rem;opacity:.6;font-weight:500}.chord-text .rel-m[data-v-55b2f8b0]{opacity:.7;font-weight:700}.hub-text[data-v-55b2f8b0]{pointer-events:none}.hub-tonic[data-v-55b2f8b0]{font-size:1.8rem;font-weight:900;fill:var(--system)}.hub-mode[data-v-55b2f8b0]{font-size:.7rem;fill:var(--text-dim);text-transform:uppercase;font-weight:700}.learner-legend[data-v-55b2f8b0]{text-align:center;max-width:450px;color:var(--text-dim);line-height:1.5}.main-app[data-v-e944a7ad]{display:flex;flex-direction:column;width:100%;align-items:center;padding-top:10px}.ear-trainer-panel[data-v-2e32092e]{width:100%;background:transparent;padding:16px;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.trainer-row[data-v-2e32092e]{display:flex;align-items:center;gap:12px;width:100%}.controls-row[data-v-2e32092e]{justify-content:space-between}.select-group[data-v-2e32092e]{display:flex;gap:8px;flex:1}.compact-select[data-v-2e32092e]{background:var(--surface);border:1px solid var(--border);color:#fff;padding:6px 8px;border-radius:6px;font-size:.75rem;font-weight:700;max-width:100px}.difficulty-select[data-v-2e32092e]{max-width:110px}.stats-group[data-v-2e32092e]{display:flex;gap:16px;font-weight:900;font-size:.9rem;color:#fff}.stat .label[data-v-2e32092e]{font-size:.6rem;color:var(--text-dim);margin-right:4px}.context-row[data-v-2e32092e]{justify-content:center}.toggle-btn[data-v-2e32092e]{flex:1;background:var(--surface);border:1px solid var(--border);padding:8px;border-radius:8px;font-size:.7rem;font-weight:800;color:var(--text-dim)}.toggle-btn.active[data-v-2e32092e]{background:var(--accent);color:var(--bg);border-color:#fff}.action-btn[data-v-2e32092e]{flex:1.2;background:#334155;border:1px solid #475569;padding:8px;border-radius:8px;font-size:.7rem;font-weight:800;color:#fff;box-shadow:0 2px 4px #0003}.action-btn[data-v-2e32092e]:active{transform:translateY(1px);box-shadow:none}.action-row[data-v-2e32092e]{justify-content:center}.play-btn[data-v-2e32092e]{width:100%;max-width:300px;background:var(--surface);border:2px solid var(--accent);color:var(--accent);padding:12px;border-radius:30px;font-weight:900;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s;z-index:10}.play-btn[data-v-2e32092e]:disabled{pointer-events:none;opacity:.6}.play-btn.is-pulsing[data-v-2e32092e]{background:var(--accent);color:#fff;transform:scale(1.05)}.progress-container[data-v-2e32092e]{width:24px;height:24px}.circular-chart[data-v-2e32092e]{display:block;width:100%;height:100%}.circle-bg[data-v-2e32092e]{fill:none;stroke:#fff3;stroke-width:3.8}.circle[data-v-2e32092e]{fill:none;stroke:#fff;stroke-width:3.8;stroke-linecap:round;transition:stroke-dasharray .1s linear}.rhythmic-pulse[data-v-2e32092e]{animation:rhythmic-glow-2e32092e 2s infinite ease-in-out}@keyframes rhythmic-glow-2e32092e{0%,to{box-shadow:0 0 0 var(--accent)}50%{box-shadow:0 0 15px var(--accent)}}.pads-row[data-v-2e32092e]{margin-top:8px;transition:all .3s;padding:4px;border-radius:12px}.pads-row.highlight-active[data-v-2e32092e]{background:#38bdf81a;box-shadow:0 0 20px #38bdf81a}.pad[data-v-2e32092e]{min-height:70px;gap:4px}.pad .note-name[data-v-2e32092e]{font-size:1.1rem;font-weight:700}.pad.is-target[data-v-2e32092e]{background:var(--success)!important;color:#fff!important;box-shadow:0 0 20px var(--success);border-color:#fff}.pad.is-wrong[data-v-2e32092e]{background:var(--error)!important;color:#fff!important;animation:shake-2e32092e .4s}.pad.is-correct-hint[data-v-2e32092e]{border:2px dashed var(--success);background:#10b9811a}@keyframes shake-2e32092e{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.confetti-overlay[data-v-2e32092e]{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9999;overflow:visible}.confetti-piece[data-v-2e32092e]{position:absolute;width:10px;height:10px;opacity:0;animation:confetti-premium-burst-2e32092e ease-out forwards}.confetti-piece.circle[data-v-2e32092e]{border-radius:50%}.confetti-piece.triangle[data-v-2e32092e]{width:0;height:0;background-color:transparent!important;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:12px solid}@keyframes confetti-premium-burst-2e32092e{0%{transform:translate(0) rotate(0) scale(0);opacity:1}15%{opacity:1;transform:translate(calc(var(--tx) * .5),calc(var(--ty) * .2)) rotate(calc(var(--rot) * .5)) scale(1.2)}to{transform:translate(var(--tx),var(--ty)) rotate(var(--rot)) scale(0);opacity:0}}@media(max-width:480px){.ear-trainer-panel[data-v-2e32092e]{padding:12px}.compact-select[data-v-2e32092e]{max-width:75px;font-size:.7rem}.difficulty-select[data-v-2e32092e]{max-width:90px}.stats-group[data-v-2e32092e]{font-size:.8rem;gap:10px}.toggle-btn[data-v-2e32092e],.action-btn[data-v-2e32092e]{font-size:.6rem;padding:6px}.pad .note-name[data-v-2e32092e]{font-size:.9rem}}.settings-panel-content[data-v-c70a89c8]{display:flex;flex-wrap:wrap;gap:24px;padding:16px;width:100%}.setting-group[data-v-c70a89c8]{display:flex;flex-direction:column;gap:8px;min-width:160px;align-items:flex-start}.setting-group label[data-v-c70a89c8]{font-size:.65rem;font-weight:900;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em}select[data-v-c70a89c8]{width:100%;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:#fff;font-weight:700;cursor:pointer;appearance:auto}@media(max-width:600px){.settings-panel-content[data-v-c70a89c8]{flex-direction:column;align-items:stretch}}:root{--safe-top: env(safe-area-inset-top, 0px)}html,body{overscroll-behavior:none;margin:0;padding:0;height:100%;width:100%;overflow-y:scroll;background:var(--bg)}#app{height:100%;width:100%;display:flex;flex-direction:column;overflow-y:scroll;overscroll-behavior-y:none;-webkit-overflow-scrolling:touch;padding:0}#instruments-and-footer{width:100%;display:flex;flex-direction:column;align-items:center;transition:filter .4s ease,opacity .4s ease}#instruments-and-footer.content-blur{filter:blur(5px);opacity:.4;pointer-events:none;-webkit-user-select:none;user-select:none}#unlock-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg);z-index:3000;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:opacity .5s ease,visibility .5s ease}#unlock-overlay:not(.locked){opacity:0;visibility:hidden}#unlock-overlay .subtitle{position:absolute;top:75%;opacity:.7;animation:pulseText 2s infinite}@keyframes pulseText{0%{opacity:.3}50%{opacity:1}to{opacity:.3}}.logo-container{display:grid;place-items:center;position:relative;width:80px;height:80px;transition:transform .8s cubic-bezier(.22,1,.36,1);will-change:transform;z-index:500;overflow:visible!important}#main-logo{grid-area:1 / 1;border-radius:50%;width:100%;height:100%;position:relative;z-index:500}.logo{width:100%;height:100%;object-fit:cover;border-radius:50%;box-shadow:0 4px 12px #00000026;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0}#main-logo.hit-pulse{animation:logo-hit-pulse 1.2s cubic-bezier(.22,1,.36,1);z-index:10;box-sizing:border-box}@keyframes logo-hit-pulse{0%{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}15%{transform:scale(1.15);filter:drop-shadow(0 0 30px var(--pulse-color, #2ecc71))}to{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}}.note-indicator{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000080;border-radius:50%;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);pointer-events:none;opacity:0;z-index:600;transform:scale(1.05) translate(2%);font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.8)}.note-indicator .pad-hero{font-size:1.45rem}.note-indicator .pad-sub{font-size:1.1rem}.note-indicator.show{animation:indicator-fade 1.2s ease-in-out forwards}@keyframes indicator-fade{0%{opacity:0}15%{opacity:1}60%{opacity:1}to{opacity:0}}.brand-text{transition:transform .8s cubic-bezier(.22,1,.36,1);transform-origin:left center;will-change:transform;white-space:nowrap}.brand-text p{transition:opacity .4s ease,max-height .4s ease;overflow:hidden}.top-bar:not(.locked-state) .brand-text p{opacity:0;max-height:0}.header-controls,.header-right{transition:opacity .6s ease .3s,transform .6s ease .3s;opacity:1;transform:translateY(0)}.top-bar.locked-state{background:transparent;box-shadow:none;z-index:3001;pointer-events:none}.top-bar.locked-state .header-controls,.top-bar.locked-state .header-right{opacity:0;transform:translateY(-10px);transition:opacity .2s,transform .2s}.top-bar.locked-state .logo-container{transform:translate(calc(min(50vw,500px) - 52px),calc(50vh - 180px)) scale(1.8)}.top-bar.locked-state .brand-text{transform:translate(calc(min(50vw,500px) - 108px),calc(50vh + 20px)) scale(1.5) translate(-50%);text-align:center}.top-bar.locked-state .brand-text p{opacity:.8;max-height:20px}.top-bar{width:100%;position:sticky;top:0;z-index:1000;background:linear-gradient(to bottom,#0f172a,#0f172abf 15px 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.top-bar-content{max-width:1000px;margin:0 auto;width:100%;padding:calc(12px + var(--safe-top)) 16px 12px 16px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;position:relative}@media(max-width:767px){.top-bar-content{padding:calc(10px + var(--safe-top)) 16px 10px 16px}}.header-left{display:flex;align-items:center;gap:16px}.header-controls{display:flex;flex-direction:row;gap:4px}.help-btn-wrapper{position:absolute;top:calc(12px + var(--safe-top));right:12px;display:flex;gap:8px}.header-btn{width:32px;height:32px;border-radius:50%;font-weight:700;font-size:1rem;line-height:1;background:var(--surface);color:var(--text-muted, #94a3b8);border:1px solid var(--border);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;padding:0}@media(hover:hover)and (pointer:fine){.header-btn:hover{background:var(--bg-hover);border-color:var(--accent);transform:translateY(-1px)}}.help-btn.active,.trainer-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 3px #38bdf84d}.control-highlight{animation:highlight-pulse 1.5s ease-out;box-sizing:border-box}@keyframes highlight-pulse{0%{outline:2px solid var(--accent);background-color:#38bdf84d;transform:scale(1.02)}to{outline:2px solid transparent;background-color:transparent;transform:scale(1)}}.app-footer{width:100%;max-width:1000px;margin:40px auto 20px;padding:20px;border-top:1px solid #334155;color:#94a3b8;font-size:.85rem}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.support-link{display:flex;align-items:center;gap:8px;background:#f43f5e1a;color:var(--harmony);padding:8px 16px;border-radius:8px;text-decoration:none;font-weight:700;border:1px solid var(--harmony);transition:all .2s ease}.support-link:hover{background:var(--harmony);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #f43f5e4d}.footer-btns{display:flex;align-items:center;gap:12px}.footer-tool-btn{background:#ffffff0d;border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.footer-tool-btn:hover{background:#ffffff1a;color:#fff}.diag-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.diag-dialog{background:var(--panel);border:1px solid var(--border);padding:24px;border-radius:16px;width:90%;max-width:400px;box-shadow:0 20px 50px #00000080}.diag-dialog h3{margin-top:0;color:#fff;font-size:1.1rem}.diag-info{background:#0003;padding:12px;border-radius:8px;margin:16px 0}.diag-info p{margin:4px 0;font-size:.9rem;color:var(--text-dim)}.diag-info span.running{color:var(--success);font-weight:700;text-transform:uppercase}.diag-info span.suspended{color:var(--warning);font-weight:700;text-transform:uppercase}.diag-help{font-size:.75rem!important;opacity:.7;font-style:italic}.diag-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px}.diag-btn{border:none;padding:12px;border-radius:8px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.diag-btn.primary{background:var(--system);color:#fff}.diag-btn.secondary{background:#334155;color:#fff;border:1px solid #475569}.close-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:8px;border-radius:8px;cursor:pointer}@media(max-width:600px){.footer-content{flex-direction:column;text-align:center}}:root{--bg: #0f172a;--panel: #1e293b;--surface: #1e293b;--bg-card: #1e293b;--accent: #38bdf8;--playing: #22c55e;--system: #a855f7;--harmony: #f43f5e;--hover: #f59e0b;--success: #10b981;--error: #ef4444;--muted: #475569;--text: white;--text-dim: #94a3b8;--border: rgba(255,255,255,.1);--border-dim: rgba(255,255,255,.05);--blue-note: #38bdf8;--warning: #f8d838}*,*:before,*:after{box-sizing:border-box}button:focus:not(:focus-visible){outline:none}@media(hover:none){*:hover{transition:none!important}}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:#fff;margin:0;display:flex;flex-direction:column;align-items:center;touch-action:pan-y}*{touch-action:manipulation;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.native-scroll{overflow-x:auto;overflow-y:hidden;width:100%;touch-action:pan-y;-webkit-overflow-scrolling:touch;scrollbar-width:none}.native-scroll::-webkit-scrollbar{display:none}.grab-strip{height:22px;background:#1a1a1a;border-top:1px solid #333;border-bottom:1px solid #111;display:flex;align-items:center;justify-content:center;cursor:grab;position:sticky;left:0;width:100%;z-index:10}.grab-strip:active{cursor:grabbing}.grab-strip span{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:800;letter-spacing:.15em;color:#555;text-transform:uppercase}.grab-strip span:before,.grab-strip span:after{content:"";width:40px;height:12px;background:repeating-linear-gradient(90deg,transparent,transparent 2px,#333 2px,#333 4px);opacity:.6}.grab-strip:hover span{color:var(--accent)}select,button{background:#0f172a;color:#fff;border:1px solid #334155;padding:6px 10px;border-radius:6px;cursor:pointer;font-weight:600;font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:6px}@media(hover:hover)and (pointer:fine){button:hover{background:#1e293b;border-color:var(--accent)}}.btn-toggle-active{color:var(--accent);border-color:var(--accent);background:#38bdf81a}.app-container{width:100%;max-width:1000px;display:flex;flex-direction:column;align-items:center}.instrument-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;border-bottom:1px solid #334155;padding-bottom:5px}.instrument-header h3{margin:0;font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.15em;font-weight:800}.surface{width:100%;background:#020617;border-radius:8px;border:2px solid #334155;position:relative;overflow:hidden;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.row-surface{display:flex}.note-item{flex:1;border-right:1px solid #334155;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:12px;font-weight:800;position:relative;cursor:crosshair;transition:all .1s}.note-item:last-child{border-right:none}.note-item.out-of-scale{background:#00000059;backdrop-filter:blur(6px) brightness(1.3);-webkit-backdrop-filter:blur(3px) brightness(1.3);border:1px solid rgba(255,255,255,.15);opacity:.6}.note-item.gap-note{opacity:.4;background:repeating-linear-gradient(45deg,#0003,#0003 5px,#0006 5px 10px);border-bottom:2px solid #64748b}.solfege-bar{position:absolute;bottom:0;width:100%;height:5px;pointer-events:none}.piano-surface{display:flex;height:160px;position:relative;background:#0f172a;padding:0}.white-key{background:linear-gradient(to bottom,#fff,#e2e8f0);position:relative;display:flex;align-items:flex-end;justify-content:center;padding-bottom:12px;z-index:1;border-radius:0 0 6px 6px;box-shadow:inset 0 -4px 6px #0000001a;transition:transform .05s,background .1s;margin-top:-4px}.white-key.user-active,.white-key.sys-active{transform:translateY(2px) scale(.98)}.black-key{background:#000!important;position:absolute;height:60%;z-index:10;border-radius:0 0 5px 5px;border:1px solid #334155;display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;box-shadow:2px 4px 8px #000c;transition:transform .05s;margin-top:-4px}.black-key.user-active,.black-key.sys-active{transform:translateY(2px) scale(.98);background:#111!important}.black-key.out-of-scale{background:#00000059;backdrop-filter:blur(3px) brightness(1.3);-webkit-backdrop-filter:blur(3px) brightness(1.3);border:1px solid rgba(255,255,255,.15);opacity:.6}.white-key.out-of-scale{background:#ffffff8c;backdrop-filter:blur(3px) brightness(.1);-webkit-backdrop-filter:blur(3px) brightness(.1);border:1px solid rgba(0,0,0,.12)}.white-key.gap-note{background:#94a3b8;opacity:.4}.black-key.gap-note{background:#334155!important;opacity:.4}.piano-label{font-size:9px;font-weight:900;pointer-events:none;text-align:center;color:#1e293b;display:flex;flex-direction:column;align-items:center;justify-content:center}.black-key .piano-label{color:#f8fafc}.staff-surface{min-height:200px;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:0;border:2px solid #cbd5e1;overflow:hidden}.staff-surface svg{color:#1e293b!important}.vf-clef{pointer-events:all}.vf-clef :hover,.vf-keysignature:has(:hover),.staff-surface g.vf-annotation.hovered-item{outline:none!important;transform:none!important;filter:drop-shadow(0 2px 4px var(--hover)) drop-shadow(0 -2px 4px var(--hover));background:transparent!important;box-shadow:none!important}.pads-row-wrapper{display:flex;width:100%;flex-wrap:nowrap}.pads-row-wrapper.mobile-rows{flex-wrap:wrap;row-gap:5px}.pad{flex:1 1 0;min-width:0;box-sizing:border-box;transition:transform .05s ease,filter .1s ease;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;border:1px solid var(--border-dim);background:#ffffff08;border-radius:8px;padding:8px 8px 14px}.mobile-rows .pad{flex:0 0 calc(100% / var(--pads-per-row, 7));height:70px}.pad-hero{font-size:1.1rem;font-weight:700;color:#fff;line-height:1.1;white-space:pre-line;text-align:center}.pad-sub{font-size:.7rem;font-weight:500;color:var(--text-dim);opacity:.6}.white-key .pad-hero,.white-key.user-active .pad-hero,.white-key.sys-active .pad-hero{color:#1e293b}.white-key .pad-sub,.white-key.user-active .pad-sub,.white-key.sys-active .pad-sub{color:#1e293b;opacity:.6}.pad.user-active .pad-sub,.pad.sys-active .pad-sub,.pad.chord-active .pad-sub{color:#fff;opacity:.8}.pad.user-active{background:var(--playing)!important;color:#fff!important}.pad.sys-active{background:var(--system)!important;color:#fff!important}.pad.chord-active{background:var(--harmony)!important;color:#fff!important}.pad.in-scale{background:#ffffff14;border-color:var(--muted)}.pad.gap-note{opacity:.6;filter:grayscale(.5)}.solfege-bar{position:absolute;bottom:0;width:100%;height:6px;border-radius:0 0 8px 8px;pointer-events:none}.dummy-spacer{visibility:hidden;pointer-events:none}.staff-surface .vf-stavenote.sys-active path,.staff-surface .vf-stavenote.sys-active text{fill:var(--system)!important;stroke:var(--system)!important}.staff-surface .vf-stavenote.user-active path,.staff-surface .vf-stavenote.user-active text{fill:var(--playing)!important;stroke:var(--playing)!important}.hovered-item{border-color:var(--hover)!important;transform:translateY(-1px);box-shadow:0 4px 10px #0000004d!important}[v-cloak]{display:none}.btns button.active{background:var(--accent);color:var(--bg);border-color:#fff;box-shadow:0 0 10px var(--accent)}.btns button{transition:all .2s ease}.instrument-section{width:100%;max-width:1000px;background:var(--panel);padding:12px;border-radius:16px;margin-bottom:12px;box-shadow:0 10px 15px -3px #0003}.instrument-surface{touch-action:none}.label-mode-toggle{display:flex;background:#0003;border-radius:6px;padding:2px;border:1px solid var(--border)}.label-mode-toggle button{background:transparent;border:none;padding:2px 8px;font-size:10px;font-weight:800;color:var(--text-dim);border-radius:4px;min-width:36px}.label-mode-toggle button.active{background:var(--accent);color:var(--bg)}.tippy-box[data-theme~=notefeel]{background:#1e293b;color:#e2e8f0;border:1px solid #334155;border-radius:6px;font-size:.78rem;box-shadow:0 8px 24px #00000080}.tippy-box[data-theme~=notefeel]>.tippy-arrow:before{color:#1e293b}.tippy-box[data-theme~=notefeel][data-placement^=top]>.tippy-arrow:before{border-top-color:#334155}.tippy-box[data-theme~=notefeel][data-placement^=bottom]>.tippy-arrow:before{border-bottom-color:#334155}.tippy-box[data-theme~=notefeel][data-placement^=left]>.tippy-arrow:before{border-left-color:#334155}.tippy-box[data-theme~=notefeel][data-placement^=right]>.tippy-arrow:before{border-right-color:#334155}.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}[data-tippy-root]{max-width:calc(100vw - 10px)}.tippy-box{position:relative;background-color:#333;color:#fff;border-radius:4px;font-size:14px;line-height:1.4;white-space:normal;outline:0;transition-property:transform,visibility,opacity}.tippy-box[data-placement^=top]>.tippy-arrow{bottom:0}.tippy-box[data-placement^=top]>.tippy-arrow:before{bottom:-7px;left:0;border-width:8px 8px 0;border-top-color:initial;transform-origin:center top}.tippy-box[data-placement^=bottom]>.tippy-arrow{top:0}.tippy-box[data-placement^=bottom]>.tippy-arrow:before{top:-7px;left:0;border-width:0 8px 8px;border-bottom-color:initial;transform-origin:center bottom}.tippy-box[data-placement^=left]>.tippy-arrow{right:0}.tippy-box[data-placement^=left]>.tippy-arrow:before{border-width:8px 0 8px 8px;border-left-color:initial;right:-7px;transform-origin:center left}.tippy-box[data-placement^=right]>.tippy-arrow{left:0}.tippy-box[data-placement^=right]>.tippy-arrow:before{left:-7px;border-width:8px 8px 8px 0;border-right-color:initial;transform-origin:center right}.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}.tippy-arrow{width:16px;height:16px;color:#333}.tippy-arrow:before{content:"";position:absolute;border-color:transparent;border-style:solid}.tippy-content{position:relative;padding:5px 9px;z-index:1}
