.instrument-surface[data-v-2af0b0c4]{width:100%;display:flex;overflow:hidden}.lane-row[data-v-7b18b099]{display:flex;width:100%;height:40px;align-items:center;border-bottom:1px solid var(--border-dim)}.lane-viewport[data-v-7b18b099]{flex:1;min-width:0;position:relative;height:100%;background:#0000000d}.controls-row[data-v-7b18b099]{display:flex;flex-direction:row;gap:6px;flex-wrap:wrap}@media(max-width:600px){.song-select[data-v-7b18b099]{flex:1 0 100%;margin-bottom:4px}}.btn-group[data-v-7b18b099]{display:flex;width:80px;flex-direction:row}.instrument-controls[data-v-a9f5df82]{margin-bottom:6px}.btns[data-v-a9f5df82]{display:flex;flex-direction:row;gap:6px}.instrument-content[data-v-a9f5df82]{display:flex;flex-direction:row}.keysig-select[data-v-71309868]{padding:2px 6px;font-size:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px}.staff-surface[data-v-71309868]{width:100%;min-height:200px;display:block;background:#f8fafc;border:2px solid #cbd5e1;overflow:hidden;touch-action:none}[data-v-71309868] .vf-stavenote{transition:opacity .2s,filter .2s}[data-v-71309868] .vf-stavenote:hover{filter:brightness(.8)}[data-v-71309868] svg{width:100%;height:auto;display:block}.piano-viewport[data-v-116416b0]{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-116416b0]{cursor:grab;touch-action:pan-x}.grab-strip[data-v-116416b0]:active{cursor:grabbing}.piano-content-wrapper[data-v-116416b0]{position:relative}.piano-surface[data-v-116416b0]{position:relative;height:150px;display:flex;padding:0;margin:0;gap:0;align-items:flex-start}.white-key[data-v-116416b0]{flex-shrink:0;border:none;border-right:1px solid #ccc;border-bottom:1px solid #ccc;box-sizing:border-box}.white-key[data-v-116416b0]:first-child{border-left:1px solid #ccc}.black-key[data-v-116416b0]{position:absolute;top:0;z-index:10;box-sizing:border-box;border:1px solid #000}.piano-key[data-v-116416b0]{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-116416b0],.piano-key.sys-active[data-v-116416b0]{filter:brightness(1.3)}.white-key[data-v-116416b0]{background:#fff;border:1px solid #ccc;height:100%;z-index:1}.black-key[data-v-116416b0]{background:#222;height:65%;position:absolute;z-index:2;color:#fff}.gap-note[data-v-116416b0]{opacity:.6;filter:grayscale(.5)}.out-of-scale[data-v-116416b0]{opacity:.3;filter:grayscale(1)}.piano-label[data-v-116416b0]{pointer-events:none;font-size:.7em;text-align:center}.pad[data-v-150f4173]{flex-direction:column;gap:2px;font-size:.9em}.chord-notes[data-v-150f4173]{display:flex;flex-direction:row;gap:4px}.pads-row-wrapper[data-v-f79b5717]{display:flex;width:100%;flex-wrap:nowrap}.pads-row-wrapper.mobile-rows[data-v-f79b5717]{flex-wrap:wrap;row-gap:5px}.pad[data-v-f79b5717]{flex:1 1 0;min-width:0;box-sizing:border-box;transition:transform .05s ease,filter .1s ease}.mobile-rows .pad[data-v-f79b5717]{flex:0 0 14.285%;height:60px}.dummy-spacer[data-v-f79b5717]{visibility:hidden;pointer-events:none}.gap-note[data-v-f79b5717]{opacity:.6;filter:grayscale(.5)}.out-of-scale[data-v-f79b5717]{opacity:.3;filter:grayscale(1)}.spiral-svg[data-v-e001379d]{width:100%;max-width:600px;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-e001379d]{cursor:pointer;stroke:#0f172a;stroke-width:.5;transition:filter .2s,transform .1s;touch-action:none;-webkit-tap-highlight-color:transparent}.out-of-scale[data-v-e001379d]{opacity:.3}.solfege-label[data-v-e001379d]{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)}.user-active[data-v-e001379d]{filter:brightness(1.4) saturate(1.2);transform-origin:center}.main-app[data-v-582a5155]{display:flex;flex-direction:column;width:100%;align-items:center}.app-container[data-v-582a5155]{width:100%;max-width:1000px;display:flex;flex-direction:column;align-items:center}html,body{overscroll-behavior-x:none}#app{height:100%;padding:12px}.logo-container{position:relative;width:80px;height:80px;transition:transform .8s cubic-bezier(.22,1,.36,1);will-change:transform}.logo-container{position:relative;width:80px;height:80px;top:0;margin-bottom:0;z-index:500;display:flex;align-items:center;justify-content:center;overflow:visible!important}#main-logo.hit-pulse{animation:logo-hit-pulse .4s ease-out;z-index:10}@keyframes logo-hit-pulse{0%{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}20%{transform:scale(1.1);filter:drop-shadow(0 0 20px var(--pulse-color, #2ecc71))}to{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}}.note-indicator{position:relative;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}.note-indicator span{display:flex;flex-direction:column;align-items:center}:deep(.solfege-label){font-size:1.8rem;line-height:1}:deep(.degree-label){font-size:.9rem;opacity:.8}.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-top:40px;margin-bottom: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}@media(max-width:600px){.footer-content{flex-direction:column;text-align:center}}:root{--bg: #0f172a;--panel: #1e293b;--accent: #38bdf8;--playing: #22c55e;--system: #a855f7;--harmony: #f43f5e;--hover: #f59e0b;--success: #10b981;--error: #ef4444;--muted: #475569;--blue-note: #38bdf8}*,*:before,*:after{box-sizing:border-box}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:#fff;margin:0;padding:10px;display:flex;flex-direction:column;align-items:center}.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-x;-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)}#unlock-overlay .subtitle{position:absolute;top:60%;opacity:.7;animation:pulseText 2s infinite}#unlock-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg);z-index:1000;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:65%;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}.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:1001;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{display:flex;flex-wrap:wrap;gap:10px;background:var(--panel);padding:12px;border-radius:12px;width:100%;max-width:1000px;margin-bottom:5px;align-items:center;box-shadow:0 4px 20px #0000004d;flex-direction:row;justify-content:space-between;text-align:left;position:sticky;top:0;z-index:200;transition:all .3s cubic-bezier(.4,0,.2,1)}.header-left{display:flex;align-items:center;gap:16px}.header-controls{display:flex;flex-direction:row;gap:4px}.logo-container{position:relative;width:80px;height:80px;top:0;margin-bottom:0;z-index:500;display:flex;align-items:center;justify-content:center}.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.pulse{animation:logo-pulse 2s forwards;filter:drop-shadow(0 0 12px var(--pulse-color, red))}#main-logo.hit-pulse{animation:logo-hit-pulse .4s ease-out;box-sizing:border-box}@keyframes logo-pulse{0%{transform:scale(1);box-shadow:0 4px 12px #00000026}50%{transform:scale(1.05);box-shadow:0 8px 24px var(--pulse-color, rgba(46, 204, 113, .4))}to{transform:scale(1);box-shadow:0 0 12px #00000026}}@keyframes logo-hit-pulse{0%{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}20%{transform:scale(1.1);filter:drop-shadow(0 0 25px var(--pulse-color, #2ecc71))}to{transform:scale(1);filter:drop-shadow(0 0 0px transparent)}}.logo-container #main-logo .logo-container .note-indicator{grid-area:1 / 1;border-radius:50%}.note-indicator{transform:scale(105%) translate(2%);font-weight:900;font-size:1.8rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;background:#0006;border-radius:50%;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;z-index:600}.note-indicator.show{animation:note-heard-felt 3.5s cubic-bezier(.19,1,.22,1) forwards}@keyframes note-heard-felt{0%{opacity:0;transform:scale(1);filter:blur(4px)}5%{opacity:1;transform:scale(1.1);filter:blur(0)}10%{transform:scale(1)}30%{transform:scale(1)}80%{opacity:0;transform:scale(.4);filter:blur(2px)}to{opacity:0;transform:scale(.2);filter:blur(2px)}}@keyframes note-fade-out{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}10%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-50%) scale(.8)}}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}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}.sequencer-container{display:flex;flex-direction:column;gap:4px;position:relative}.lane-row{display:flex;height:45px;border-bottom:1px solid #1e293b}.lane-controls{padding:5px;background:#0f172a;display:flex;align-items:center;justify-content:center;gap:4px;border-right:1px solid #334155;z-index:10}.ms-btn{width:22px;height:22px;padding:0;font-size:9px;border-radius:4px;background:#1e293b;border:1px solid #334155;color:#94a3b8}.btn-mute-active{color:var(--error)!important;border-color:var(--error)!important;background:#ef444433!important}.btn-solo-active{color:var(--hover)!important;border-color:var(--hover)!important;background:#f59e0b33!important}.lane-viewport{flex-grow:1;position:relative;overflow:hidden}.lane-viewport.muted{opacity:.25;filter:grayscale(1)}.playhead{position:absolute;top:0;left:60px;width:2px;height:100%;background:#fff;box-shadow:0 0 10px #fff;z-index:20;pointer-events:none}.note-block{position:absolute;height:80%;top:10%;border-radius:3px;background:var(--system);opacity:.35;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;transition:all .1s;border:1px solid rgba(255,255,255,.1);font-weight:700;cursor:pointer}.note-block.chord{background:var(--harmony)}.note-block.active,.note-block.user-active,.note-block.sys-active{opacity:1!important;transform:scaleY(1.1);box-shadow:0 0 15px #fff;z-index:5;border-color:#fff}.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}.pad{padding:5px 5px 15px}.pad.user-active{background:var(--playing);color:#fff!important}.pad.sys-active{background:var(--system);color:#fff!important}.pad.chord-active{background:var(--harmony);color:#fff!important}.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 #d3d3d3!important}.visualizer-container{width:100%;max-width:1000px;height:80px;display:flex;justify-content:center;align-items:center;gap:10px;margin-top:5px}.visualizer-card{width:40px;height:40px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;text-shadow:0 2px 4px rgba(0,0,0,.5);transition:opacity 1s ease,transform .3s cubic-bezier(.175,.885,.32,1.275);transform:scale(.6);opacity:0;color:#fff;pointer-events:none}.visualizer-card.show{transform:scale(1.1);opacity:1;box-shadow:0 0 20px currentColor;transition:opacity .1s;animation:fadeCard 2s forwards}@keyframes fadeCard{0%{opacity:0}10%{opacity:1}50%{opacity:1}to{opacity:0}}[v-cloak]{display:none}#vue-note-pads{width:100%;display:contents}.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}
