@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&display=swap";:root{--panel-bg:#ffffff14;--panel-bg-strong:#ffffff21;--panel-border:#ffffff2e;--text-main:#f8fafc;--text-soft:#c7d2fe;--text-muted:#a5b4fc;--accent:#a855f7;--accent-2:#f59e0b;--go:#22c55e;--stop:#ef4444;--color-red:#ef4444;--color-blue:#3b82f6;--color-cyan:#06b6d4;--color-green:#22c55e;--color-yellow:#eab308;--radius:20px;--radius-sm:14px;--shadow:0 12px 32px #00000059}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:var(--text-main);-webkit-font-smoothing:antialiased;background-color:#0000;background-image:radial-gradient(1100px 720px at 50% -15%,#5b3aa3 0%,#0000 60%),linear-gradient(#2a1f5e 0%,#15102f 100%);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box;background-clip:border-box,border-box;min-height:100vh;font-family:Fredoka,sans-serif;font-weight:500}#app{width:100%;max-width:1100px;margin:0 auto}h1,h2,h3{font-weight:700;line-height:1.15}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--panel-border);border-radius:var(--radius);box-shadow:var(--shadow)}button{cursor:pointer;background:var(--accent);color:#fff;border-radius:var(--radius-sm);border:none;padding:.7rem 1.4rem;font-family:Fredoka,sans-serif;font-size:1rem;font-weight:600;transition:transform .12s,filter .15s,background .15s}button:hover{filter:brightness(1.08)}button:active{transform:translateY(1px)scale(.98)}button:disabled{opacity:.45;cursor:not-allowed;filter:none;transform:none}.module{flex-direction:column;align-items:center;gap:1.5rem;width:100%;display:flex}.module-head{text-align:center;flex-direction:column;gap:.35rem;display:flex}.module-head h2{font-size:1.7rem}.module-head .hint{color:var(--text-soft);font-size:1.05rem;font-weight:500}.picker-row{flex-wrap:wrap;justify-content:center;gap:.6rem;display:flex}.stage{flex-flow:wrap;justify-content:center;align-items:flex-start;gap:2.5rem;width:100%;display:flex}.stage-panel{flex-direction:column;align-items:center;gap:1.25rem;min-width:280px;margin-top:1.5rem;display:flex}.note-cue{text-shadow:0 0 24px #ffffff59;font-size:3.4rem;font-weight:700;line-height:1}.placeholder{color:var(--text-muted);text-align:center;font-style:italic}.pulse-add{z-index:10;animation:1s ease-in-out infinite pulse-scale;border-color:var(--color-green)!important;background-color:#22c55e66!important}.pulse-remove{z-index:10;animation:1s ease-in-out infinite pulse-scale;border-color:var(--color-red)!important;background-color:#ef444466!important}@keyframes pulse-scale{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}@media (width<=768px){.stage{flex-direction:column-reverse;gap:1.25rem}.stage-panel{width:100%;min-width:0}.module-head h2{font-size:1.45rem}}.recorder-wrapper[data-v-09f6ce29]{justify-content:center;align-items:flex-start;padding:1rem 4rem;display:flex}.recorder-body[data-v-09f6ce29]{background:linear-gradient(#eef2f7 0%,#cbd5e1 100%);border:1px solid #ffffff80;border-radius:75px 75px 24px 24px;flex-direction:column;align-items:center;width:150px;padding:22px 0;display:flex;position:relative;box-shadow:inset -10px 0 24px #0000001f,0 14px 34px #00000059}.mouthpiece[data-v-09f6ce29]{clip-path:polygon(20% 0%,80% 0%,100% 100%,0% 100%);background:linear-gradient(#9aa7b8 0%,#7c8aa0 100%);border-radius:12px;width:70px;height:88px;margin-bottom:34px;box-shadow:inset 0 -5px 10px #0003}.holes-container[data-v-09f6ce29]{flex-direction:column;align-items:center;gap:26px;width:100%;margin-bottom:44px;display:flex;position:relative}.hand-group[data-v-09f6ce29]{flex-direction:column;gap:26px;width:100%;display:flex;position:relative}.hand-header[data-v-09f6ce29]{text-align:center;letter-spacing:1px;text-transform:uppercase;color:#475569;margin-bottom:-6px;font-size:.72rem;font-weight:700}.hand-divider[data-v-09f6ce29]{background:#47556959;border-radius:3px;width:90px;height:3px;margin:2px 0}.hole-row[data-v-09f6ce29]{justify-content:center;width:100%;display:flex;position:relative}.finger-label[data-v-09f6ce29]{color:var(--text-main);text-align:left;width:52px;font-size:.8rem;font-weight:600;position:absolute;top:50%;right:-58px;transform:translateY(-50%)}.thumb-unit[data-v-09f6ce29]{flex-direction:column;align-items:center;gap:3px;width:46px;display:flex;position:absolute;top:50%;left:-52px;transform:translateY(-50%)}.thumb-label[data-v-09f6ce29]{color:#b45309;font-size:.72rem;font-weight:700}.split-wrapper[data-v-09f6ce29]{gap:14px;display:flex}.hole[data-v-09f6ce29]{z-index:2;background:#1e293b;border-radius:50%;width:28px;height:28px;transition:all .3s;box-shadow:inset 0 3px 6px #0009,0 1px 2px #ffffff4d}.hole.small[data-v-09f6ce29]{width:18px;height:18px}.hole.thumb[data-v-09f6ce29]{width:22px;height:22px}.hole.covered[data-v-09f6ce29]{background:var(--text-main);box-shadow:inset 0 0 5px #0003,0 2px 4px #0003}.hole.uncovered[data-v-09f6ce29]{background:#1e293b}.bell[data-v-09f6ce29]{background:linear-gradient(#cbd5e1 0%,#94a3b8 100%);border-radius:50% 50% 12px 12px;width:174px;height:46px;position:absolute;bottom:-23px;box-shadow:inset 0 -5px 10px #0003}@media (width<=768px){.recorder-wrapper[data-v-09f6ce29]{padding:.5rem 3.5rem}}.note-btn[data-v-851940af]{color:#fff;text-shadow:0 2px 4px #00000080;border:4px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:84px;height:84px;font-size:1.6rem;font-weight:700;display:flex;box-shadow:0 6px 14px #00000059}.note-btn.active[data-v-851940af]{border-color:#fff;transform:translateY(-3px)scale(1.05);box-shadow:0 0 0 4px #ffffff40,0 8px 18px #0006}.replay-btn[data-v-851940af]{background:var(--panel-bg-strong);border:2px solid var(--panel-border)}.big-placeholder[data-v-851940af]{padding:3rem 1rem;font-size:1.3rem}@media (width<=768px){.note-btn[data-v-851940af]{width:66px;height:66px;font-size:1.3rem}}.transition-btn[data-v-a5993c42]{background:var(--panel-bg);border:2px solid var(--panel-border);color:var(--text-main);padding:.55rem 1rem;font-size:1rem;font-weight:600}.transition-btn.active[data-v-a5993c42]{background:var(--accent);border-color:var(--accent)}.controls-panel[data-v-a5993c42]{gap:1.25rem;padding:1.75rem}.controls-panel h3[data-v-a5993c42]{font-size:1.5rem}.highlight[data-v-a5993c42]{color:var(--color-cyan);font-weight:800}.hint .add[data-v-a5993c42]{color:var(--color-green)}.hint .remove[data-v-a5993c42]{color:var(--color-red)}.status-text[data-v-a5993c42]{height:1.5rem;font-size:1.15rem;font-weight:600;transition:color .3s}.status-text.step-0[data-v-a5993c42]{color:var(--color-blue)}.status-text.step-1[data-v-a5993c42]{color:var(--color-yellow)}.status-text.step-2[data-v-a5993c42]{color:var(--color-green)}.toolbar[data-v-a5993c42]{border-radius:var(--radius-sm);background:#0003;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:.5rem;display:flex}.tool-btn[data-v-a5993c42]{border:2px solid var(--panel-border);background:0 0;min-width:96px;padding:.5rem .8rem;font-size:.95rem}.tool-btn[data-v-a5993c42]:hover:not(.disabled){background:#ffffff1a}.tool-btn.main-play-btn[data-v-a5993c42]{background:var(--go);border-color:var(--go)}.tool-btn.main-play-btn.playing[data-v-a5993c42]{background:var(--stop);border-color:var(--stop)}.tool-btn.disabled[data-v-a5993c42]{opacity:.3;cursor:not-allowed}.big-placeholder[data-v-a5993c42]{padding:3rem 1rem;font-size:1.3rem}@media (width<=768px){.controls-panel[data-v-a5993c42]{width:100%;padding:1.25rem}.tool-btn[data-v-a5993c42]{flex:40%;padding:.8rem;font-size:1rem}}.controls[data-v-cfb5cfb8]{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;padding:.8rem 1.5rem;display:flex}.separator[data-v-cfb5cfb8]{background:var(--panel-border);width:2px;height:24px}.speed-toggles[data-v-cfb5cfb8]{align-items:center;gap:.5rem;display:flex}.label[data-v-cfb5cfb8]{color:var(--text-soft);margin-right:.25rem;font-weight:600}.tool-btn[data-v-cfb5cfb8]{border:2px solid var(--panel-border);background:0 0;padding:.45rem .85rem;font-size:.95rem}.tool-btn.active[data-v-cfb5cfb8]{background:var(--accent);border-color:var(--accent)}.tool-btn.main-play-btn[data-v-cfb5cfb8]{background:var(--go);border-color:var(--go)}.tool-btn.main-play-btn.playing[data-v-cfb5cfb8]{background:var(--color-yellow);border-color:var(--color-yellow);color:#000}.scrubber-container[data-v-cfb5cfb8]{width:100%;padding:1rem 1.5rem}.scrubber-track[data-v-cfb5cfb8]{cursor:pointer;background:#00000040;border:1px solid #ffffff1a;border-radius:10px;width:100%;height:44px;display:flex;position:relative;overflow:hidden}.scrubber-block[data-v-cfb5cfb8]{opacity:.7;border-right:1px solid #0000004d;height:100%;transition:opacity .2s,filter .2s}.scrubber-block[data-v-cfb5cfb8]:hover{opacity:1;filter:brightness(1.2)}.scrubber-block.active[data-v-cfb5cfb8]{opacity:1;filter:brightness(1.5);box-shadow:inset 0 0 10px #ffffff80}.progress-line[data-v-cfb5cfb8]{pointer-events:none;z-index:10;background:#fff;width:3px;position:absolute;top:0;bottom:0;transform:translate(-50%);box-shadow:0 0 10px #fff}.song-cue[data-v-cfb5cfb8]{justify-content:center;gap:.5rem;min-height:180px}.cue-label[data-v-cfb5cfb8]{text-transform:uppercase;letter-spacing:1px;color:var(--text-soft);font-size:1rem;font-weight:600}.note-cue.done[data-v-cfb5cfb8]{font-size:2.4rem}.countdown[data-v-cfb5cfb8]{color:var(--accent-2);text-shadow:0 0 26px #f59e0b80;font-size:4.5rem;font-weight:700;line-height:1}.next-line[data-v-cfb5cfb8]{color:var(--text-soft);font-size:1.1rem}@media (width<=768px){.controls[data-v-cfb5cfb8]{flex-direction:column;gap:1rem;padding:1rem}.playback-controls[data-v-cfb5cfb8]{justify-content:center;gap:.5rem;width:100%;display:flex}.playback-controls .tool-btn[data-v-cfb5cfb8]{flex:1}.speed-toggles[data-v-cfb5cfb8]{flex-wrap:nowrap;justify-content:center;gap:.35rem;width:100%}.speed-toggles .tool-btn[data-v-cfb5cfb8]{flex:1;min-width:0;padding:.6rem .4rem;font-size:.85rem}.label[data-v-cfb5cfb8]{margin-right:0}.tool-btn[data-v-cfb5cfb8]{padding:.7rem 1rem}.separator[data-v-cfb5cfb8]{width:100%;height:2px}.song-cue[data-v-cfb5cfb8]{min-height:0}}.app-shell{flex-direction:column;gap:1.25rem;padding:1.25rem 1.5rem 3rem;display:flex}.top-bar{flex-direction:column;gap:1rem;padding:.75rem 0 1rem;display:flex}.app-header{justify-content:center;align-items:center;gap:.9rem;display:flex}.app-header .logo{font-size:2.4rem;line-height:1}.title-block{flex-direction:column;display:flex}.title-block h1{background:linear-gradient(90deg,#f9a8d4,#c4b5fd,#67e8f9);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.9rem}.title-block p{color:var(--text-soft);font-size:1rem;font-weight:500}.step-nav{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.step{background:var(--panel-bg);border:2px solid var(--panel-border);color:var(--text-soft);border-radius:999px;align-items:center;gap:.6rem;padding:.6rem 1.1rem .6rem .6rem;font-size:1.05rem;display:flex}.step .step-num{width:1.9rem;height:1.9rem;color:var(--text-main);background:#ffffff1f;border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.step:hover{color:var(--text-main);border-color:#ffffff59}.step.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 6px 20px #a855f773}.step.active .step-num{background:#ffffff47}.module-host{justify-content:center;padding:2rem;display:flex}.loading{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:2rem;display:flex}@media (width<=768px){.app-shell{gap:1rem;padding:.5rem .75rem 2.5rem}.app-header .logo{font-size:1.9rem}.title-block h1{font-size:1.45rem}.title-block p{font-size:.85rem}.step{flex:auto;justify-content:center;padding:.5rem .75rem;font-size:.95rem}.step .step-num{width:1.6rem;height:1.6rem}.module-host{padding:1.25rem .85rem}}@media (width<=480px){.step-nav{gap:.4rem}.step{flex:auto;gap:.4rem;padding:.45rem .6rem;font-size:.85rem}.step .step-num{width:1.45rem;height:1.45rem;font-size:.85rem}}
