.metronome-container.svelte-1fuw5eh{display:flex;justify-content:center;align-items:center;padding:2rem;background:#77d2ff1a;border:1px solid rgba(119,210,255,.3);border-radius:12px;animation:svelte-1fuw5eh-pulse 2s ease-in-out infinite;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease,border-radius .3s ease;z-index:10}.metronome-container.playing.svelte-1fuw5eh{position:sticky;top:0}.metronome-container.stuck.svelte-1fuw5eh{border-radius:0 0 12px 12px;background:#272d30fa;border-color:#77d2ff33;box-shadow:0 4px 12px #0000004d;animation:none}.metronome-content.svelte-1fuw5eh{text-align:center;width:100%}.metronome-display.svelte-1fuw5eh{display:flex;flex-direction:column;align-items:center}.bpm-display.svelte-1fuw5eh{display:flex;flex-direction:row;align-items:baseline;gap:.2rem}.bpm-value.svelte-1fuw5eh{font-size:5rem;font-weight:700;color:#fffffff2;line-height:1;text-shadow:0 0 20px rgba(119,210,255,.3)}.bpm-label.svelte-1fuw5eh{font-size:1.2rem;color:#fff9;text-transform:uppercase;letter-spacing:.1em}.time-signature-display.svelte-1fuw5eh{font-size:.8rem;color:#ffffffb3;font-weight:500;padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;max-width:50%;margin:0 auto}.beat-indicator.svelte-1fuw5eh{display:flex;justify-content:center;gap:1rem;margin-bottom:1rem}.beat-dot.svelte-1fuw5eh{width:16px;height:16px;border-radius:50%;background:#fff3;border:2px solid rgba(255,255,255,.3);transition:all .2s ease}.beat-dot.active.svelte-1fuw5eh{background:#77d2ffcc;border-color:#77d2ff;transform:scale(1.3);box-shadow:0 0 15px #77d2ff99}.beat-dot.accent.active.svelte-1fuw5eh{background:#fde72de6;border-color:#fde72d;box-shadow:0 0 20px #fde72db3}.beat-dot.countdown.active.svelte-1fuw5eh{background:#ffa500cc;border-color:orange;box-shadow:0 0 15px #ffa50099}.beat-dot.countdown.accent.active.svelte-1fuw5eh{background:#ff8c00e6;border-color:#ff8c00;box-shadow:0 0 20px #ff8c00b3}.countdown-indicator.svelte-1fuw5eh{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem}.countdown-label.svelte-1fuw5eh{font-size:.9rem;color:#ffa500e6;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.countdown-progress.svelte-1fuw5eh{font-size:.85rem;color:#ffffffb3;font-weight:500}.controls.svelte-1fuw5eh{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.speed-progression-indicator.svelte-1fuw5eh{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem;width:100%}@keyframes svelte-1fuw5eh-pulse{0%,to{opacity:1}50%{opacity:.8}}.upcoming-speed.svelte-1fuw5eh{display:flex;flex-direction:column;align-items:center;gap:.25rem}.upcoming-label.svelte-1fuw5eh{font-size:1rem;color:#77d2ffe6;font-weight:600}.countdown.svelte-1fuw5eh{font-size:.85rem;color:#ffffffb3;font-weight:500}.progress-container.svelte-1fuw5eh{display:flex;flex-direction:column;gap:.5rem;width:100%}.progress-label.svelte-1fuw5eh{font-size:.85rem;color:#fffc;font-weight:500;text-align:center}.progress-bar-wrapper.svelte-1fuw5eh{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;position:relative}.progress-bar.svelte-1fuw5eh{height:100%;background:linear-gradient(90deg,#77d2ffcc,#77d2ff);border-radius:4px;transition:width .3s ease;box-shadow:0 0 10px #77d2ff80}.dialog-overlay.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem;animation:svelte-187oiqn-fadeIn .2s ease}@keyframes svelte-187oiqn-fadeIn{0%{opacity:0}to{opacity:1}}.dialog-content.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{background:#141419f2;border:1px solid rgba(255,255,255,.1);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:svelte-187oiqn-slideUp .3s ease}@keyframes svelte-187oiqn-slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.dialog-header.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.dialog-header.svelte-187oiqn h2.svelte-187oiqn.svelte-187oiqn{margin:0;font-size:1.5rem;color:#ffffffe6;font-weight:600}.dialog-body.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{padding:1.5rem;display:flex;flex-direction:column;gap:2rem}.setting-group.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;flex-direction:column;gap:.75rem}.setting-group.svelte-187oiqn label.svelte-187oiqn.svelte-187oiqn{font-size:.95rem;color:#ffffffb3;font-weight:500}.bpm-control.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;align-items:center;gap:1rem}.bpm-slider.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{flex:1;height:6px;background:#ffffff1a;border-radius:3px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.bpm-slider.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:#77d2ffe6;border-radius:50%;cursor:pointer;transition:all .2s ease}.bpm-slider.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn::-webkit-slider-thumb:hover{background:#77d2ff;transform:scale(1.2)}.bpm-slider.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn::-moz-range-thumb{width:18px;height:18px;background:#77d2ffe6;border-radius:50%;cursor:pointer;border:none;transition:all .2s ease}.bpm-slider.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn::-moz-range-thumb:hover{background:#77d2ff;transform:scale(1.2)}.bpm-input.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{width:80px;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:1rem;text-align:center;font-weight:600}.bpm-input.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:focus{outline:none;border-color:#77d2ff80;background:#ffffff14}.bpm-range.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;justify-content:space-between;font-size:.75rem;color:#ffffff80}.time-signature-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:1rem;cursor:pointer;transition:all .2s ease}.time-signature-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:focus{outline:none;border-color:#77d2ff80;background:#ffffff14}.time-signature-select.svelte-187oiqn option.svelte-187oiqn.svelte-187oiqn{background:#141419f2;color:#ffffffe6}.sound-options.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.sound-option.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease}.sound-option.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:hover{background:#ffffff14;border-color:#fff3}.sound-option.svelte-187oiqn input[type=radio].svelte-187oiqn.svelte-187oiqn{width:18px;height:18px;cursor:pointer;accent-color:rgba(119,210,255,.9)}.sound-option.svelte-187oiqn span.svelte-187oiqn.svelte-187oiqn{color:#ffffffe6;font-size:.95rem}.sound-option.svelte-187oiqn input[type=radio].svelte-187oiqn:checked+span.svelte-187oiqn{color:#77d2ff;font-weight:600}.countdown-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:1rem;cursor:pointer;transition:all .2s ease}.countdown-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:focus{outline:none;border-color:#77d2ff80;background:#ffffff14}.countdown-select.svelte-187oiqn option.svelte-187oiqn.svelte-187oiqn{background:#141419f2;color:#ffffffe6}.dialog-footer.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{padding:1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:1rem}.speed-progression-group.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;margin-top:.5rem}.tab-container.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#ffffff0d;border-radius:8px;padding:.25rem}.tab-button.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{flex:1;padding:.75rem 1rem;background:transparent;border:none;border-radius:6px;color:#ffffffb3;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.tab-button.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:hover{background:#ffffff0d;color:#ffffffe6}.tab-button.active.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{background:#77d2ff33;color:#77d2ff;font-weight:600}.tab-content.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{margin-top:0}.speed-progression-settings.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{margin-top:1rem;display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.speed-progression-row.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{display:flex;justify-content:space-between;align-items:center;gap:1rem}.speed-progression-row.svelte-187oiqn label.svelte-187oiqn.svelte-187oiqn{font-size:.9rem;color:#ffffffb3;font-weight:500;flex:1}.speed-input.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{width:100px;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:.95rem;text-align:center;font-weight:600}.speed-input.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:focus{outline:none;border-color:#77d2ff80;background:#ffffff14}.end-behavior-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn{width:100px;padding:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffe6;font-size:.9rem;cursor:pointer;transition:all .2s ease}.end-behavior-select.svelte-187oiqn.svelte-187oiqn.svelte-187oiqn:focus{outline:none;border-color:#77d2ff80;background:#ffffff14}.end-behavior-select.svelte-187oiqn option.svelte-187oiqn.svelte-187oiqn{background:#141419f2;color:#ffffffe6}.scale-practice.svelte-18qfp79.svelte-18qfp79{padding:2rem;max-width:1200px;margin:0 auto}.header.svelte-18qfp79.svelte-18qfp79{margin-bottom:2rem}.header.svelte-18qfp79 h2.svelte-18qfp79{font-size:2rem;color:#ffffffe6;font-weight:600;margin-bottom:1rem}.progress-summary.svelte-18qfp79.svelte-18qfp79{display:flex;align-items:center;gap:1rem}.progress-bar-container.svelte-18qfp79.svelte-18qfp79{flex:1;height:24px;background:#ffffff1a;border-radius:12px;overflow:hidden;position:relative}.progress-bar-container.small.svelte-18qfp79.svelte-18qfp79{width:150px;height:16px}.progress-bar.svelte-18qfp79.svelte-18qfp79{height:100%;background:linear-gradient(90deg,#77d2ffcc,#fde72dcc);transition:width .3s ease;border-radius:12px}.progress-text.svelte-18qfp79.svelte-18qfp79{font-size:.95rem;color:#ffffffb3;white-space:nowrap}.controls.svelte-18qfp79.svelte-18qfp79{display:flex;justify-content:flex-start;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.view-toggle.svelte-18qfp79.svelte-18qfp79{display:flex;gap:.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.25rem}.toggle-btn.svelte-18qfp79.svelte-18qfp79{padding:.5rem 1rem;background:transparent;border:none;border-radius:6px;color:#ffffffb3;cursor:pointer;transition:all .2s ease;font-size:.95rem;font-weight:500}.toggle-btn.svelte-18qfp79.svelte-18qfp79:hover{background:#ffffff0d;color:#ffffffe6}.toggle-btn.active.svelte-18qfp79.svelte-18qfp79{background:#77d2ff33;color:#77d2ff}.keys-view.svelte-18qfp79.svelte-18qfp79{display:flex;flex-direction:column;gap:2rem}.key-section.svelte-18qfp79.svelte-18qfp79{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.key-header.svelte-18qfp79.svelte-18qfp79{width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;background:transparent;border:none;cursor:pointer;padding:.5rem;margin:-.5rem;text-align:left;font-family:inherit;transition:all .2s ease}.key-header.svelte-18qfp79.svelte-18qfp79:hover{opacity:.8}.key-header.expanded.svelte-18qfp79.svelte-18qfp79{margin-bottom:1rem}.key-header.expanded.svelte-18qfp79 .chevron-icon.svelte-18qfp79{transform:rotate(90deg)}.key-header.svelte-18qfp79 .svelte-18qfp79{pointer-events:none}.key-name.svelte-18qfp79.svelte-18qfp79{font-size:1.5rem;font-weight:600;color:#ffffffe6;margin:0;flex:1}.key-progress.svelte-18qfp79.svelte-18qfp79{display:flex;align-items:center;gap:.75rem}.chevron-icon.svelte-18qfp79.svelte-18qfp79{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;transition:transform .2s ease;color:#ffffffb3;flex-shrink:0}.chevron-icon.svelte-18qfp79 svg{width:100%;height:100%}.scales-grid.svelte-18qfp79.svelte-18qfp79{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;animation:svelte-18qfp79-slideDown .2s ease}@keyframes svelte-18qfp79-slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scale-item.svelte-18qfp79.svelte-18qfp79{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem;border:none;width:100%;text-align:left;font-family:inherit}.scale-item.svelte-18qfp79.svelte-18qfp79:hover{background:#ffffff14;border-color:#fff3}.scale-item.completed.svelte-18qfp79.svelte-18qfp79{background:#77d2ff26;border-color:#77d2ff66}.scale-item.completed.svelte-18qfp79 .scale-name.svelte-18qfp79{color:#77d2ff;text-decoration:line-through}.scale-item.selected.svelte-18qfp79.svelte-18qfp79{background:#fde72d26;border-color:#fde72d66;box-shadow:0 0 0 2px #fde72d33}.scale-item.disabled.svelte-18qfp79.svelte-18qfp79{opacity:.4;cursor:not-allowed;pointer-events:none}.scale-item.disabled.svelte-18qfp79.svelte-18qfp79:hover{background:#ffffff0d;border-color:#ffffff1a}.checkmark.svelte-18qfp79.svelte-18qfp79{color:#77d2ff;font-weight:700;font-size:1.1rem}.scale-name.svelte-18qfp79.svelte-18qfp79{color:#ffffffe6;font-weight:500;flex:1}.alternate-names.svelte-18qfp79.svelte-18qfp79{color:#ffffff80;font-size:.85em}.scales-view.svelte-18qfp79.svelte-18qfp79{display:flex;flex-direction:column;gap:2rem}.scale-section.svelte-18qfp79.svelte-18qfp79{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.scale-section.disabled.svelte-18qfp79.svelte-18qfp79{opacity:.4}.scale-header.svelte-18qfp79.svelte-18qfp79{width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;background:transparent;border:none;cursor:pointer;padding:.5rem;margin:-.5rem;text-align:left;font-family:inherit;transition:all .2s ease}.scale-header.svelte-18qfp79.svelte-18qfp79:hover{opacity:.8}.scale-header.expanded.svelte-18qfp79.svelte-18qfp79{margin-bottom:.75rem}.scale-header.expanded.svelte-18qfp79 .chevron-icon.svelte-18qfp79{transform:rotate(90deg)}.scale-header.disabled.svelte-18qfp79.svelte-18qfp79{cursor:not-allowed}.scale-header.disabled.svelte-18qfp79.svelte-18qfp79:hover{opacity:1}.scale-header.svelte-18qfp79 .svelte-18qfp79{pointer-events:none}.scale-content.svelte-18qfp79.svelte-18qfp79{animation:svelte-18qfp79-slideDown .2s ease}.scale-name-title.svelte-18qfp79.svelte-18qfp79{font-size:1.5rem;font-weight:600;color:#ffffffe6;margin:0;flex:1}.scale-progress.svelte-18qfp79.svelte-18qfp79{display:flex;align-items:center;gap:.75rem}.scale-description.svelte-18qfp79.svelte-18qfp79{color:#fff9;font-size:.9rem;margin:0 0 1rem;font-style:italic}.keys-grid.svelte-18qfp79.svelte-18qfp79{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.key-item.svelte-18qfp79.svelte-18qfp79{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem;border:none;width:100%;font-family:inherit}.key-item.svelte-18qfp79.svelte-18qfp79:hover{background:#ffffff14;border-color:#fff3}.key-item.completed.svelte-18qfp79.svelte-18qfp79{background:#77d2ff26;border-color:#77d2ff66}.key-item.completed.svelte-18qfp79 .key-name.svelte-18qfp79{color:#77d2ff;text-decoration:line-through}.key-item.selected.svelte-18qfp79.svelte-18qfp79{background:#fde72d26;border-color:#fde72d66;box-shadow:0 0 0 2px #fde72d33}.key-item.svelte-18qfp79 .key-name.svelte-18qfp79{color:#ffffffe6;font-weight:500}.selected-scale.svelte-1oldpdf.svelte-1oldpdf{min-height:300px;display:flex;flex-direction:column}.selected-scale.empty.svelte-1oldpdf.svelte-1oldpdf{justify-content:center;align-items:center}.scale-info.svelte-1oldpdf.svelte-1oldpdf{flex:1}.scale-title.svelte-1oldpdf.svelte-1oldpdf{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.key-name.svelte-1oldpdf.svelte-1oldpdf{font-size:2rem;font-weight:700;color:#77d2ff}.scale-name.svelte-1oldpdf.svelte-1oldpdf{font-size:1.5rem;font-weight:600;color:#ffffffe6}.alternate-names.svelte-1oldpdf.svelte-1oldpdf{font-size:1rem;color:#fff9;font-weight:400}.description.svelte-1oldpdf.svelte-1oldpdf{color:#ffffffb3;font-size:.95rem;margin-bottom:1.5rem;font-style:italic}.piano-section.svelte-1oldpdf.svelte-1oldpdf,.notes-section.svelte-1oldpdf.svelte-1oldpdf{margin-bottom:1.5rem}.sampler-loading.svelte-1oldpdf.svelte-1oldpdf{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem;margin-bottom:.5rem;color:#fff9;font-size:.85rem}.loading-indicator.svelte-1oldpdf.svelte-1oldpdf{width:16px;height:16px;border:2px solid rgba(119,210,255,.3);border-top-color:#77d2ff;border-radius:50%;animation:svelte-1oldpdf-spin 1s linear infinite}@keyframes svelte-1oldpdf-spin{to{transform:rotate(360deg)}}.notes-list.svelte-1oldpdf.svelte-1oldpdf{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.note.svelte-1oldpdf.svelte-1oldpdf{padding:.5rem 1rem;background:#77d2ff26;border:1px solid rgba(119,210,255,.3);border-radius:8px;color:#77d2ff;font-weight:600;font-size:1rem}.piano-keyboard.svelte-1oldpdf.svelte-1oldpdf{display:flex;position:relative;height:200px;background:#ffffff0d;border-radius:8px;padding:.5rem;overflow-x:auto;overflow-y:hidden;align-items:flex-start;width:564px;margin:0 auto;transition:opacity .3s ease}.piano-keyboard.loading.svelte-1oldpdf.svelte-1oldpdf{opacity:.5;pointer-events:none}.piano-key.svelte-1oldpdf.svelte-1oldpdf{position:relative;border:none;cursor:pointer;transition:all .08s ease;display:flex;align-items:flex-end;justify-content:center;padding-bottom:.5rem;font-family:inherit;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.piano-key.white.svelte-1oldpdf.svelte-1oldpdf{width:40px;min-width:40px;height:100%;background:#ffffff4d;border:1px solid rgba(0,0,0,.1);border-radius:0 0 4px 4px;z-index:1;margin-right:-1px;transition:background .08s ease,border-color .08s ease,opacity .08s ease,transform .08s ease,box-shadow .08s ease}.piano-key.white.svelte-1oldpdf.svelte-1oldpdf:hover{background:#ffffff80}.piano-key.white.svelte-1oldpdf.svelte-1oldpdf:active,.piano-key.white.pressed.svelte-1oldpdf.svelte-1oldpdf{background:#77d2ff99!important;transform:translateY(2px);box-shadow:inset 0 2px 8px #0003}.piano-key.white.active.svelte-1oldpdf.svelte-1oldpdf{background:#fff!important;border-color:#0003!important;opacity:1!important}.piano-key.white.active.svelte-1oldpdf.svelte-1oldpdf:hover{background:#f0f8ff!important}.piano-key.white.active.svelte-1oldpdf.svelte-1oldpdf:active,.piano-key.white.active.pressed.svelte-1oldpdf.svelte-1oldpdf{background:#77d2ffe6!important;transform:translateY(2px);box-shadow:inset 0 2px 8px #0000004d}.piano-key.white.active.svelte-1oldpdf .key-label.svelte-1oldpdf{color:#000000e6!important;font-weight:700}.piano-key.black.svelte-1oldpdf.svelte-1oldpdf{width:28px;min-width:28px;height:60%;background:#1a1a1a4d;border:1px solid rgba(0,0,0,.3);border-radius:0 0 3px 3px;z-index:2;position:absolute;top:0;transition:background .08s ease,border-color .08s ease,opacity .08s ease,transform .08s ease,box-shadow .08s ease}.piano-key.black.svelte-1oldpdf.svelte-1oldpdf:hover{background:#28282880}.piano-key.black.svelte-1oldpdf.svelte-1oldpdf:active,.piano-key.black.pressed.svelte-1oldpdf.svelte-1oldpdf{background:#77d2ff66!important;transform:translateY(2px);box-shadow:inset 0 2px 6px #0006}.piano-key.black.active.svelte-1oldpdf.svelte-1oldpdf{background:#1a1a1a!important;border-color:#00000080!important;opacity:1!important}.piano-key.black.active.svelte-1oldpdf .key-label.svelte-1oldpdf{color:#fff!important;font-weight:700}.piano-key.black.active.svelte-1oldpdf.svelte-1oldpdf:hover{background:#2a2a2a!important}.piano-key.black.active.svelte-1oldpdf.svelte-1oldpdf:active,.piano-key.black.active.pressed.svelte-1oldpdf.svelte-1oldpdf{background:#77d2ff99!important;transform:translateY(2px);box-shadow:inset 0 2px 6px #00000080}.piano-key.svelte-1oldpdf .key-label.svelte-1oldpdf{font-size:.65rem;font-weight:600;color:#0000004d;pointer-events:none}.piano-key.svelte-1oldpdf .piano-key.black .key-label.svelte-1oldpdf{color:#ffffff4d;font-size:.6rem}.intervals-list.svelte-1oldpdf.svelte-1oldpdf{display:flex;flex-wrap:wrap;gap:.5rem}.interval.svelte-1oldpdf.svelte-1oldpdf{padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fffc;font-weight:500;font-size:.9rem}.completion-label.svelte-1oldpdf.svelte-1oldpdf{color:#ffffffe6;font-size:1rem;font-weight:500}.empty-state.svelte-1oldpdf.svelte-1oldpdf{text-align:center;color:#ffffff80;font-size:.95rem;padding:2rem}.drill-notation.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{margin-top:2rem;padding:1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px}.notation-header.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.controls.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.select-wrapper.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:.5rem}.select-wrapper.svelte-1g74z2t label.svelte-1g74z2t.svelte-1g74z2t{font-size:.9rem;color:#ffffffb3}.select-wrapper.svelte-1g74z2t select.svelte-1g74z2t.svelte-1g74z2t{padding:.4rem .75rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffe6;font-size:.9rem;cursor:pointer;min-width:150px}.select-wrapper.svelte-1g74z2t select.svelte-1g74z2t.svelte-1g74z2t:hover{background:#ffffff1f;border-color:#ffffff40}.select-wrapper.svelte-1g74z2t select.svelte-1g74z2t.svelte-1g74z2t:focus{outline:none;border-color:#77d2ff80}.select-wrapper.svelte-1g74z2t select.svelte-1g74z2t.svelte-1g74z2t:disabled{opacity:.5;cursor:not-allowed}.select-wrapper.svelte-1g74z2t select.svelte-1g74z2t option.svelte-1g74z2t{background:#1a1a2e;color:#ffffffe6}.view-options.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:1rem}.checkbox-label.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#ffffffb3;cursor:pointer}.checkbox-label.svelte-1g74z2t input[type=checkbox].svelte-1g74z2t.svelte-1g74z2t{width:16px;height:16px;accent-color:#77d2ff}.bars-control.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:.4rem}.bars-control.svelte-1g74z2t label.svelte-1g74z2t.svelte-1g74z2t{font-size:.85rem;color:#ffffffb3}.bars-control.svelte-1g74z2t select.svelte-1g74z2t.svelte-1g74z2t{padding:.3rem .5rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#ffffffe6;font-size:.85rem;cursor:pointer}.bars-control.svelte-1g74z2t select.svelte-1g74z2t option.svelte-1g74z2t{background:#1a1a2e}.action-buttons.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:.75rem}.tempo-display.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{font-size:.85rem;color:#77d2ffe6;font-weight:600;padding:.25rem .5rem;background:#77d2ff1a;border-radius:4px}.no-selection.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{font-size:.9rem;color:#ffffff80;font-style:italic;margin:0;padding:2rem;text-align:center}.pattern-preview.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;background:#77d2ff14;border-radius:8px}.pattern-preview.svelte-1g74z2t .chord-progression-info.svelte-1g74z2t.svelte-1g74z2t{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.pattern-preview.svelte-1g74z2t .label.svelte-1g74z2t.svelte-1g74z2t{font-size:.85rem;color:#fff9}.pattern-preview.svelte-1g74z2t .numerals.svelte-1g74z2t.svelte-1g74z2t{font-size:1rem;font-weight:600;color:#fde72d}.pattern-preview.svelte-1g74z2t .separator.svelte-1g74z2t.svelte-1g74z2t{color:#ffffff4d}.pattern-preview.svelte-1g74z2t .notes.svelte-1g74z2t.svelte-1g74z2t{font-family:SF Mono,Fira Code,monospace;font-size:.95rem;color:#77d2ff;letter-spacing:.5px}.pattern-preview.svelte-1g74z2t .drill-description.svelte-1g74z2t.svelte-1g74z2t{font-size:.85rem;color:#fff9;font-style:italic;margin:0}.notation-wrapper.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{background:#fffffff2;border-radius:8px;padding:1rem;overflow-x:auto}.notation-display.svelte-1g74z2t.svelte-1g74z2t.svelte-1g74z2t{min-height:120px}.notation-display.svelte-1g74z2t svg{max-width:100%;height:auto}.notation-display.svelte-1g74z2t .abcjs-note{fill:#1a1a2e}.notation-display.svelte-1g74z2t .abcjs-staff{stroke:#333}.page-container.svelte-16c4qlt.svelte-16c4qlt{padding:2rem;max-width:1600px;margin:0 auto;position:relative}.header.svelte-16c4qlt.svelte-16c4qlt{margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:2rem}.header.svelte-16c4qlt .header-content.svelte-16c4qlt{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.header.svelte-16c4qlt .title-wrapper.svelte-16c4qlt{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.header.svelte-16c4qlt .title-icon.svelte-16c4qlt{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;flex-shrink:0;color:#77d2ff;transition:transform .25s ease}.header.svelte-16c4qlt .title-icon.svelte-16c4qlt svg{width:100%;height:100%}.header.svelte-16c4qlt .title-icon.svelte-16c4qlt:hover{transform:scale(1.1);color:#fde72d}.header.svelte-16c4qlt .title.svelte-16c4qlt{font-size:3rem;font-weight:700;margin:0;background:linear-gradient(45deg,#77d2ff,#fde72d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.header.svelte-16c4qlt .subtitle.svelte-16c4qlt{font-size:1.2rem;color:#ffffffb3}
