.exercise-selector.svelte-1oc1oib{display:flex;flex-direction:column;gap:var(--space-sm)}.start-practice-btn.svelte-1oc1oib{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);border:none;background:none;color:var(--text-primary);cursor:pointer;transition:all .2s ease;width:100%;min-height:120px}.play-icon.svelte-1oc1oib{display:flex;align-items:center;justify-content:center;width:125px;height:125px;border-radius:50%;border:3px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.start-text.svelte-1oc1oib{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.start-practice-btn.svelte-1oc1oib:hover .play-icon:where(.svelte-1oc1oib){border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.start-practice-btn.svelte-1oc1oib:focus{outline:none}.start-practice-btn.svelte-1oc1oib:focus .play-icon:where(.svelte-1oc1oib){box-shadow:0 0 0 3px rgba(var(--accent-primary-rgb),.3)}.practice-mode-selector.svelte-1oc1oib{display:flex;flex-direction:column;gap:var(--space-xs)}.exercise-select.svelte-1oc1oib{padding:var(--space-sm);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.9375rem;cursor:pointer;transition:border-color .2s ease}.exercise-select.svelte-1oc1oib:hover{border-color:var(--accent-primary)}.exercise-select.svelte-1oc1oib:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.1)}@media (max-width: 500px){.start-practice-btn.svelte-1oc1oib{font-size:.9rem;padding:var(--space-sm)}.exercise-select.svelte-1oc1oib{font-size:.875rem;padding:var(--space-xs) var(--space-sm)}}.exercise-display.svelte-1xvcyni{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg);max-width:600px;margin:0 auto}.instruction-text.svelte-1xvcyni{color:var(--text-secondary);font-size:1.125rem;text-align:center;margin:0;font-weight:500}.main-content.svelte-1xvcyni{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.primary-display.svelte-1xvcyni{font-size:7.2rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.action-controls.svelte-1xvcyni{display:flex;flex-direction:row;align-items:center;gap:var(--space-md)}.action-btn.svelte-1xvcyni{padding:var(--space-sm) var(--space-lg);background-color:var(--accent-primary);color:#fff;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #673ab74d;min-width:120px}.action-btn.svelte-1xvcyni:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #673ab766}.settings-link.svelte-1xvcyni{color:var(--accent-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.settings-link.svelte-1xvcyni:hover{color:var(--accent-primary-dark);text-decoration:underline}@media (max-width: 600px){.exercise-display.svelte-1xvcyni{padding:var(--space-md)}.primary-display.svelte-1xvcyni{font-size:6rem}.action-btn.svelte-1xvcyni{padding:var(--space-xs) var(--space-md);font-size:.8125rem}}@media (max-width: 480px){.primary-display.svelte-1xvcyni{font-size:4.5rem}}.colorized-notes.svelte-1shf94b{font-family:inherit;font-size:inherit;line-height:inherit}.note.svelte-1shf94b{font-weight:inherit;transition:color .2s ease}.exercise-display.svelte-1roce8e{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg);max-width:600px;margin:0 auto}.instruction-text.svelte-1roce8e{color:var(--text-secondary);font-size:1.125rem;text-align:center;margin:0;font-weight:500}.main-content.svelte-1roce8e{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.primary-display.svelte-1roce8e{font-size:5.4rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.compact-info.svelte-1roce8e{display:flex;align-items:center;justify-content:center;text-align:center}.notes.svelte-1roce8e{font-size:1rem;font-weight:500;color:var(--text-muted);font-family:monospace;letter-spacing:.05em}.action-controls.svelte-1roce8e{display:flex;flex-direction:row;align-items:center;gap:var(--space-md)}.action-btn.svelte-1roce8e{padding:var(--space-sm) var(--space-lg);background-color:var(--accent-primary);color:#fff;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #673ab74d;min-width:120px}.action-btn.svelte-1roce8e:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #673ab766}.settings-link.svelte-1roce8e{color:var(--accent-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.settings-link.svelte-1roce8e:hover{color:var(--accent-primary-dark);text-decoration:underline}@media (max-width: 600px){.exercise-display.svelte-1roce8e{padding:var(--space-md)}.primary-display.svelte-1roce8e{font-size:4rem}.notes.svelte-1roce8e{font-size:.9375rem}.action-btn.svelte-1roce8e{padding:var(--space-xs) var(--space-md);font-size:.8125rem}}@media (max-width: 480px){.primary-display.svelte-1roce8e{font-size:3.2rem}.notes.svelte-1roce8e{font-size:.875rem}}.exercise-display.svelte-mtzxj3{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg);max-width:600px;margin:0 auto}.instruction-text.svelte-mtzxj3{color:var(--text-secondary);font-size:1.125rem;text-align:center;margin:0;font-weight:500}.main-content.svelte-mtzxj3{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.primary-display.svelte-mtzxj3{font-size:7.2rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.compact-info.svelte-mtzxj3{display:flex;align-items:center;justify-content:center;gap:var(--space-md);flex-wrap:wrap;text-align:center}.scale-name.svelte-mtzxj3{font-size:1.25rem;font-weight:600;color:var(--text-secondary)}.separator.svelte-mtzxj3{font-size:1rem;color:var(--text-muted);font-weight:700}.notes.svelte-mtzxj3{font-size:1rem;font-weight:500;color:var(--text-muted);font-family:monospace;letter-spacing:.05em}.action-controls.svelte-mtzxj3{display:flex;flex-direction:row;align-items:center;gap:var(--space-md)}.action-btn.svelte-mtzxj3{padding:var(--space-sm) var(--space-lg);background-color:var(--accent-primary);color:#fff;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #673ab74d;min-width:120px}.action-btn.svelte-mtzxj3:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #673ab766}.settings-link.svelte-mtzxj3{color:var(--accent-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.settings-link.svelte-mtzxj3:hover{color:var(--accent-primary-dark);text-decoration:underline}@media (max-width: 600px){.exercise-display.svelte-mtzxj3{padding:var(--space-md)}.primary-display.svelte-mtzxj3{font-size:6rem}.scale-name.svelte-mtzxj3{font-size:1.125rem}.notes.svelte-mtzxj3{font-size:.9375rem}.action-btn.svelte-mtzxj3{padding:var(--space-xs) var(--space-md);font-size:.8125rem}}@media (max-width: 480px){.primary-display.svelte-mtzxj3{font-size:4.5rem}.compact-info.svelte-mtzxj3{flex-direction:column;gap:var(--space-sm)}.separator.svelte-mtzxj3{display:none}.scale-name.svelte-mtzxj3{font-size:1.125rem}.notes.svelte-mtzxj3{font-size:.875rem}}.exercise-display.svelte-1t4cwdk{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg);max-width:600px;margin:0 auto}.instruction-text.svelte-1t4cwdk{color:var(--text-secondary);font-size:1.125rem;text-align:center;margin:0;font-weight:500}.main-content.svelte-1t4cwdk{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.primary-display.svelte-1t4cwdk{font-size:7.2rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.compact-info.svelte-1t4cwdk{display:flex;align-items:center;justify-content:center;gap:var(--space-md);flex-wrap:wrap;text-align:center}.arpeggio-type.svelte-1t4cwdk{font-size:1.25rem;font-weight:600;color:var(--text-secondary)}.separator.svelte-1t4cwdk{font-size:1rem;color:var(--text-muted);font-weight:700}.notes.svelte-1t4cwdk{font-size:1rem;font-weight:500;color:var(--text-muted);font-family:monospace;letter-spacing:.05em}.action-controls.svelte-1t4cwdk{display:flex;flex-direction:row;align-items:center;gap:var(--space-md)}.action-btn.svelte-1t4cwdk{padding:var(--space-sm) var(--space-lg);background-color:var(--accent-primary);color:#fff;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #673ab74d;min-width:120px}.action-btn.svelte-1t4cwdk:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #673ab766}.settings-link.svelte-1t4cwdk{color:var(--accent-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.settings-link.svelte-1t4cwdk:hover{color:var(--accent-primary-dark);text-decoration:underline}@media (max-width: 600px){.exercise-display.svelte-1t4cwdk{padding:var(--space-md)}.primary-display.svelte-1t4cwdk{font-size:6rem}.arpeggio-type.svelte-1t4cwdk{font-size:1.125rem}.notes.svelte-1t4cwdk{font-size:.9375rem}.action-btn.svelte-1t4cwdk{padding:var(--space-xs) var(--space-md);font-size:.8125rem}}@media (max-width: 480px){.primary-display.svelte-1t4cwdk{font-size:4.5rem}.compact-info.svelte-1t4cwdk{flex-direction:column;gap:var(--space-sm)}.separator.svelte-1t4cwdk{display:none}.arpeggio-type.svelte-1t4cwdk{font-size:1.125rem}.notes.svelte-1t4cwdk{font-size:.875rem}}.exercise-display.svelte-1bnbdxx{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg);max-width:600px;margin:0 auto}.instruction-text.svelte-1bnbdxx{color:var(--text-secondary);font-size:1.125rem;text-align:center;margin:0;font-weight:500}.main-content.svelte-1bnbdxx{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);flex:1;justify-content:center}.primary-display.svelte-1bnbdxx{font-size:7.2rem;font-weight:700;color:var(--text-primary);text-align:center;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.compact-info.svelte-1bnbdxx{display:flex;align-items:center;justify-content:center;gap:var(--space-md);flex-wrap:wrap;text-align:center}.triad-type.svelte-1bnbdxx{font-size:1.25rem;font-weight:600;color:var(--text-secondary)}.separator.svelte-1bnbdxx{font-size:1rem;color:var(--text-muted);font-weight:700}.notes.svelte-1bnbdxx{font-size:1rem;font-weight:500;color:var(--text-muted);font-family:monospace;letter-spacing:.05em}.string-set.svelte-1bnbdxx{font-size:.875rem;font-weight:500;color:#3b82f6;padding:var(--space-xs) var(--space-sm);background-color:#3b82f61a;border-radius:var(--radius-sm);border:1px solid rgba(59,130,246,.2)}.action-controls.svelte-1bnbdxx{display:flex;flex-direction:row;align-items:center;gap:var(--space-md)}.action-btn.svelte-1bnbdxx{padding:var(--space-sm) var(--space-lg);background-color:var(--accent-primary);color:#fff;border:1px solid var(--accent-primary);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #673ab74d;min-width:120px}.action-btn.svelte-1bnbdxx:hover{background-color:var(--accent-primary-hover);border-color:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #673ab766}.settings-link.svelte-1bnbdxx{color:var(--accent-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.settings-link.svelte-1bnbdxx:hover{color:var(--accent-primary-dark);text-decoration:underline}@media (max-width: 600px){.exercise-display.svelte-1bnbdxx{padding:var(--space-md)}.primary-display.svelte-1bnbdxx{font-size:6rem}.triad-type.svelte-1bnbdxx{font-size:1.125rem}.notes.svelte-1bnbdxx{font-size:.9375rem}.string-set.svelte-1bnbdxx{font-size:.8125rem}.action-btn.svelte-1bnbdxx{padding:var(--space-xs) var(--space-md);font-size:.8125rem}}@media (max-width: 480px){.primary-display.svelte-1bnbdxx{font-size:4.5rem}.compact-info.svelte-1bnbdxx{flex-direction:column;gap:var(--space-sm)}.separator.svelte-1bnbdxx{display:none}.triad-type.svelte-1bnbdxx{font-size:1.125rem}.notes.svelte-1bnbdxx{font-size:.875rem}.string-set.svelte-1bnbdxx{font-size:.75rem}}.exercise-content.svelte-1w0hows{display:flex;flex:1;align-items:center;justify-content:center;min-height:300px;height:100%;position:relative}.no-content.svelte-1w0hows{color:var(--text-secondary);text-align:center;font-style:italic}@media (max-width: 500px){.exercise-content.svelte-1w0hows{min-height:200px}}.metronome-controls.svelte-1caeaob{display:flex;flex-direction:column;gap:var(--space-md)}.controls-row.svelte-1caeaob{display:flex;gap:var(--space-md);align-items:flex-end;justify-content:space-between}.control-group.svelte-1caeaob{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0}.control-label.svelte-1caeaob{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.bpm-control.svelte-1caeaob{display:flex;align-items:center;gap:var(--space-xs)}.bpm-btn.svelte-1caeaob{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-family:monospace}.bpm-btn.svelte-1caeaob:hover:not(:disabled){background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.bpm-btn.svelte-1caeaob:disabled{opacity:.5;cursor:not-allowed}.bpm-input.svelte-1caeaob{flex:1;padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:600;text-align:center;min-width:60px;height:32px;-moz-appearance:textfield}.bpm-input.svelte-1caeaob::-webkit-outer-spin-button,.bpm-input.svelte-1caeaob::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.bpm-input.svelte-1caeaob:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.1)}.time-signature-select.svelte-1caeaob{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:border-color .2s ease;height:32px}.time-signature-select.svelte-1caeaob:hover{border-color:var(--accent-primary)}.time-signature-select.svelte-1caeaob:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px rgba(var(--accent-primary-rgb),.1)}.accent-btn.svelte-1caeaob{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s ease;width:100%;height:32px}.accent-btn.svelte-1caeaob:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.accent-btn.active.svelte-1caeaob{background-color:var(--accent-primary);border-color:var(--accent-primary);color:#fff}@media (max-width: 500px){.metronome-controls.svelte-1caeaob,.controls-row.svelte-1caeaob{gap:var(--space-sm)}.bpm-btn.svelte-1caeaob{width:24px;height:24px;font-size:.875rem}.bpm-input.svelte-1caeaob{min-width:45px;font-size:.8125rem;height:28px}.accent-btn.svelte-1caeaob{font-size:.6875rem;padding:var(--space-xs);height:28px}.time-signature-select.svelte-1caeaob{font-size:.8125rem;height:28px}}.metronome-card.svelte-120oj2l{display:flex;flex-direction:column;gap:var(--space-lg);height:100%;padding:var(--space-xs)}.metronome-header.svelte-120oj2l{display:flex;justify-content:flex-start;align-items:center}.metronome-title.svelte-120oj2l{margin:0 0 0 var(--space-sm);font-size:1.25rem;font-weight:600;color:var(--text-primary)}.metronome-main.svelte-120oj2l{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);flex:1}.control-buttons-row.svelte-120oj2l{display:flex;gap:var(--space-md);align-items:center}.beat-indicator-container.svelte-120oj2l{display:flex;justify-content:center;align-items:center;height:140px}.beat-indicator.svelte-120oj2l{width:120px;height:120px;border-radius:50%;background-color:var(--bg-secondary);border:3px solid var(--border-secondary);display:flex;align-items:center;justify-content:center;transition:all .1s ease;position:relative}.beat-indicator.playing.svelte-120oj2l{border-color:var(--accent-primary);background-color:var(--bg-primary)}.bpm-display.svelte-120oj2l{display:flex;flex-direction:column;align-items:center;gap:1px;font-family:monospace}.bpm-number.svelte-120oj2l{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.bpm-label.svelte-120oj2l{font-size:.75rem;color:var(--text-muted);line-height:1;text-transform:uppercase;letter-spacing:.5px}.play-button.svelte-120oj2l{width:64px;height:64px;border-radius:50%;border:3px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.play-button.svelte-120oj2l:hover{border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.play-button.playing.svelte-120oj2l{border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff}.play-button.playing.svelte-120oj2l:hover{background-color:#dc2626;border-color:#dc2626}.tap-button.svelte-120oj2l{width:64px;height:64px;border-radius:50%;border:3px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.tap-button.svelte-120oj2l:hover{border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}@media (max-width: 500px){.beat-indicator-container.svelte-120oj2l{height:110px}.beat-indicator.svelte-120oj2l{width:90px;height:90px}.bpm-number.svelte-120oj2l{font-size:1.5rem}.play-button.svelte-120oj2l,.tap-button.svelte-120oj2l{width:50px;height:50px}}@media (prefers-color-scheme: dark){.play-button.svelte-120oj2l{box-shadow:0 2px 8px #0000004d}.play-button.svelte-120oj2l:hover{box-shadow:0 4px 12px #0006}.tap-button.svelte-120oj2l{box-shadow:0 2px 8px #0000004d}.tap-button.svelte-120oj2l:hover{box-shadow:0 4px 12px #0006}}.circle-of-fifths-container.svelte-1p3d1yi{display:flex;flex-direction:column;gap:var(--space-sm);height:100%;padding:var(--space-sm)}.svg-container.svelte-1p3d1yi{flex:1;display:flex;align-items:center;justify-content:center;max-width:100%;aspect-ratio:1}svg.svelte-1p3d1yi{width:100%;height:100%;min-width:450px;min-height:450px}@media (max-width: 640px){svg.svelte-1p3d1yi{min-width:380px;min-height:380px}}.roman-numeral.svelte-1p3d1yi{font-size:26px;fill:#fff;font-weight:900}.key-segment.svelte-1p3d1yi{cursor:pointer}.key-path.svelte-1p3d1yi{transition:all .2s ease}.key-segment.svelte-1p3d1yi:hover .key-path:where(.svelte-1p3d1yi){fill:var(--bg-secondary);stroke:var(--bg-secondary);stroke-width:4}.key-path.selected.svelte-1p3d1yi{fill:var(--bg-secondary);stroke:var(--bg-secondary);stroke-width:4}.key-label.svelte-1p3d1yi{pointer-events:none;font-weight:600;fill:var(--text-primary);transition:all .2s ease}.key-label.major.svelte-1p3d1yi{font-size:22px}.key-label.minor.svelte-1p3d1yi{font-size:20px}.key-label.selected-text.svelte-1p3d1yi{fill:#22c55e;font-weight:700}.key-segment.svelte-1p3d1yi:focus{outline:none}.key-segment.svelte-1p3d1yi:focus .key-path:where(.svelte-1p3d1yi){stroke:var(--bg-secondary);stroke-width:4}.center-toggle.svelte-1p3d1yi{cursor:pointer;transition:all .2s ease}.toggle-circle.svelte-1p3d1yi{transition:all .2s ease}.center-toggle.svelte-1p3d1yi:hover .toggle-circle:where(.svelte-1p3d1yi){fill:var(--bg-secondary);stroke:var(--accent-primary);stroke-width:4}.center-toggle.svelte-1p3d1yi:focus{outline:none}.center-toggle.svelte-1p3d1yi:focus .toggle-circle:where(.svelte-1p3d1yi){stroke:var(--accent-primary);stroke-width:6}.toggle-symbol.svelte-1p3d1yi{font-size:72px;font-weight:600;pointer-events:none;transition:fill .2s ease;-webkit-user-select:none;user-select:none}.center-toggle.svelte-1p3d1yi:hover .toggle-symbol:where(.svelte-1p3d1yi){fill:var(--text-primary)}@media (max-width: 500px){.roman-numeral.svelte-1p3d1yi{font-size:36px}.key-label.major.svelte-1p3d1yi{font-size:32px}.key-label.minor.svelte-1p3d1yi{font-size:26px}svg.svelte-1p3d1yi{min-width:100%;min-height:100%}.toggle-symbol.svelte-1p3d1yi{font-size:68px}}.circle-of-thirds-container.svelte-b1shy7{display:flex;flex-direction:column;height:100%;padding:var(--space-sm)}.svg-container.svelte-b1shy7{flex:1;display:flex;align-items:center;justify-content:center;max-width:100%;aspect-ratio:1}svg.svelte-b1shy7{width:100%;height:100%;min-width:300px;min-height:300px;max-width:500px;max-height:500px}@media (max-width: 640px){svg.svelte-b1shy7{min-width:250px;min-height:250px}}.note-group.svelte-b1shy7{cursor:pointer;transition:all .2s ease}.note-circle.svelte-b1shy7{transition:all .2s ease}.note-group.svelte-b1shy7:hover .note-circle:where(.svelte-b1shy7){fill:var(--bg-tertiary);stroke:var(--accent-primary);stroke-width:4}.note-circle.selected.svelte-b1shy7{fill:var(--accent-primary);stroke:var(--accent-primary);stroke-width:4}.note-label.svelte-b1shy7{pointer-events:none;font-weight:600;font-size:18px;fill:var(--text-primary);transition:all .2s ease}.note-label.selected-text.svelte-b1shy7{fill:#fff;font-weight:700}.interval-symbol.svelte-b1shy7{pointer-events:none;font-weight:700;font-size:16px;fill:var(--text-secondary);-webkit-user-select:none;user-select:none}.interval-symbol.major.svelte-b1shy7{fill:#22c55e}.interval-symbol.minor.svelte-b1shy7{fill:#3b82f6}.treble-clef-center.svelte-b1shy7{pointer-events:none}.treble-clef-center.svelte-b1shy7 image:where(.svelte-b1shy7){filter:brightness(0) invert(.5);opacity:.7}.note-group.svelte-b1shy7:focus{outline:none}.note-group.svelte-b1shy7:focus .note-circle:where(.svelte-b1shy7){stroke:var(--accent-primary);stroke-width:4}@media (max-width: 500px){.note-label.svelte-b1shy7{font-size:22px}.interval-symbol.svelte-b1shy7{font-size:20px}}.triads-container.svelte-11nrf6y{display:flex;flex-direction:column;height:100%;padding:var(--space-md);align-items:center;justify-content:center}.key-selector.svelte-11nrf6y{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.key-selector.svelte-11nrf6y label:where(.svelte-11nrf6y){font-weight:600;color:var(--text-primary);font-size:.9rem}.key-selector.svelte-11nrf6y select:where(.svelte-11nrf6y){padding:var(--space-xs) var(--space-sm);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.key-selector.svelte-11nrf6y select:where(.svelte-11nrf6y):hover{border-color:var(--accent-primary)}.key-selector.svelte-11nrf6y select:where(.svelte-11nrf6y):focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #22c55e33}.triads-grid.svelte-11nrf6y{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center;align-items:center;max-width:100%}.triad-rectangle.svelte-11nrf6y{display:flex;flex-direction:column;align-items:center;justify-content:space-between;background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm);width:90px;height:200px;cursor:pointer;transition:all .2s ease;position:relative}.triad-rectangle.svelte-11nrf6y:hover{background:var(--bg-tertiary);border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.roman-numeral.svelte-11nrf6y{font-size:18px;font-weight:700;text-align:center;margin-bottom:var(--space-xs)}.note-circles.svelte-11nrf6y{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;justify-content:center;align-items:center}.note-circle.svelte-11nrf6y{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--bg-primary);border:2px solid var(--border-primary);transition:all .2s ease}.triad-rectangle.svelte-11nrf6y:hover .note-circle:where(.svelte-11nrf6y){background:var(--bg-secondary);border-width:3px}.note-label.svelte-11nrf6y{font-size:14px;font-weight:600;color:var(--text-primary);pointer-events:none}.quality-label.svelte-11nrf6y{font-size:12px;font-weight:500;text-align:center;margin-top:var(--space-xs);opacity:.8}.triad-rectangle.svelte-11nrf6y:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #22c55e33}@media (max-width: 768px){.triads-grid.svelte-11nrf6y{gap:var(--space-xs)}.triad-rectangle.svelte-11nrf6y{width:75px;height:170px;padding:var(--space-xs)}.note-circle.svelte-11nrf6y{width:30px;height:30px}.note-label.svelte-11nrf6y{font-size:12px}.roman-numeral.svelte-11nrf6y{font-size:16px}.quality-label.svelte-11nrf6y{font-size:10px}}@media (max-width: 640px){.triads-grid.svelte-11nrf6y{flex-wrap:wrap;justify-content:center;max-width:100%}.triad-rectangle.svelte-11nrf6y{width:70px;height:150px}.note-circle.svelte-11nrf6y{width:28px;height:28px}.note-label.svelte-11nrf6y{font-size:13px}.roman-numeral.svelte-11nrf6y{font-size:14px}}.circle-visualization-container.svelte-he6hyr{display:flex;flex-direction:column;height:100%}.tab-header.svelte-he6hyr{flex-shrink:0;display:flex;border-bottom:1px solid var(--border-primary)}.tab-button.svelte-he6hyr{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:1rem;font-weight:500;font-family:inherit;border-bottom:2px solid transparent}.tab-button.svelte-he6hyr:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab-button.active.svelte-he6hyr{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-secondary)}.tab-title.svelte-he6hyr{font-weight:600}.tab-content.svelte-he6hyr{flex:1;display:flex;flex-direction:column;min-height:0}@media (max-width: 640px){.tab-button.svelte-he6hyr{padding:var(--space-xs) var(--space-sm);font-size:.8125rem}.tab-title.svelte-he6hyr{display:none}}@media (max-width: 480px){.tab-button.svelte-he6hyr{padding:var(--space-xs)}}.storage-usage-display.svelte-2jyvm0{background-color:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md)}.loading-state.svelte-2jyvm0,.error-state.svelte-2jyvm0{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md);text-align:center}.loading-spinner.svelte-2jyvm0{width:20px;height:20px;border:2px solid var(--bg-tertiary);border-top:2px solid var(--accent-primary);border-radius:50%;animation:svelte-2jyvm0-spin 1s linear infinite}@keyframes svelte-2jyvm0-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message.svelte-2jyvm0{color:var(--danger, #ef4444);margin:0}.retry-button.svelte-2jyvm0{background-color:var(--accent-primary);color:#fff;border:none;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:background-color .2s ease}.retry-button.svelte-2jyvm0:hover{background-color:var(--accent-primary-hover, #5e35b1)}.usage-content.svelte-2jyvm0{display:flex;flex-direction:column;gap:var(--space-md)}.usage-header.svelte-2jyvm0{display:flex;justify-content:space-between;align-items:center}.usage-header.svelte-2jyvm0 h3:where(.svelte-2jyvm0){margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.tier-badge.svelte-2jyvm0{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.tier-badge.premium.svelte-2jyvm0{background-color:var(--accent-primary);color:#fff}.tier-badge.practice.svelte-2jyvm0{background-color:var(--success, #10b981);color:#fff}.usage-section.svelte-2jyvm0{display:flex;flex-direction:column;gap:var(--space-xs)}.usage-label.svelte-2jyvm0{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--text-primary)}.usage-numbers.svelte-2jyvm0{font-weight:600;color:var(--text-secondary)}.progress-bar.svelte-2jyvm0{height:8px;background-color:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.progress-fill.svelte-2jyvm0{height:100%;transition:width .3s ease;border-radius:var(--radius-sm)}.usage-percentage.svelte-2jyvm0{font-size:.75rem;color:var(--text-secondary);text-align:right}.upgrade-prompt.svelte-2jyvm0{background-color:var(--bg-primary);border:1px solid var(--accent-primary);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;margin-top:var(--space-sm)}.upgrade-prompt.svelte-2jyvm0 p:where(.svelte-2jyvm0){margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:.875rem}.upgrade-button.svelte-2jyvm0{display:inline-block;background-color:var(--accent-primary);color:#fff;text-decoration:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:600;font-size:.875rem;transition:background-color .2s ease}.upgrade-button.svelte-2jyvm0:hover{background-color:var(--accent-primary-hover, #5e35b1)}@media (max-width: 640px){.usage-header.svelte-2jyvm0,.usage-label.svelte-2jyvm0{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.usage-percentage.svelte-2jyvm0{text-align:left}}.file-search.svelte-1v1u1f9{flex:1;min-width:200px}.search-input-container.svelte-1v1u1f9{position:relative;display:flex;align-items:center;width:100%}.search-icon.svelte-1v1u1f9{position:absolute;left:var(--space-sm);color:var(--text-secondary);pointer-events:none;z-index:1;display:flex;align-items:center}.search-input.svelte-1v1u1f9{width:100%;padding:var(--space-sm) var(--space-lg);padding-left:calc(var(--space-lg) + 20px);border:1px solid var(--border-secondary);border-radius:var(--radius-md);background-color:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:all .2s ease;box-sizing:border-box}.search-input.svelte-1v1u1f9:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #673ab71a}.search-input.svelte-1v1u1f9::placeholder{color:var(--text-secondary)}.clear-button.svelte-1v1u1f9{position:absolute;right:var(--space-sm);display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:50%;background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;z-index:1}.clear-button.svelte-1v1u1f9:hover{background-color:var(--danger, #ef4444);color:#fff;transform:scale(1.05)}.clear-button.svelte-1v1u1f9:focus{outline:none;box-shadow:0 0 0 2px #673ab74d}.search-input.svelte-1v1u1f9:not(:placeholder-shown){padding-right:calc(var(--space-lg) + 28px)}@media (max-width: 640px){.search-input.svelte-1v1u1f9{font-size:.8125rem;padding:var(--space-xs) var(--space-md);padding-left:calc(var(--space-md) + 20px)}.search-input.svelte-1v1u1f9:not(:placeholder-shown){padding-right:calc(var(--space-md) + 28px)}.clear-button.svelte-1v1u1f9{width:20px;height:20px}}.sound-file-list.svelte-1qdlsjx{display:flex;flex-direction:column;gap:var(--space-lg)}.controls-row.svelte-1qdlsjx{display:flex;align-items:center;gap:var(--space-md)}.toggle-button.svelte-1qdlsjx{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500}.toggle-button.svelte-1qdlsjx:hover{background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.toggle-button.svelte-1qdlsjx:focus{outline:none}.upload-section.svelte-1qdlsjx{animation:svelte-1qdlsjx-slideDown .3s ease-out}@keyframes svelte-1qdlsjx-slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-state.svelte-1qdlsjx,.empty-state.svelte-1qdlsjx{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.error-message.svelte-1qdlsjx{color:var(--danger, #ef4444);margin-bottom:var(--space-md)}.retry-button.svelte-1qdlsjx{background-color:var(--accent-primary);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;transition:background-color .2s ease}.retry-button.svelte-1qdlsjx:hover{background-color:var(--accent-primary-hover, #5e35b1)}.hint.svelte-1qdlsjx{font-style:italic;font-size:.875rem;margin-top:var(--space-sm)}.files-container.svelte-1qdlsjx{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:100%;overflow:hidden}.search-results-info.svelte-1qdlsjx{text-align:center;padding:var(--space-xs) 0}.results-count.svelte-1qdlsjx{font-size:.8125rem;color:var(--text-secondary);margin:0;font-style:italic}.files-grid.svelte-1qdlsjx{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:100%;overflow:hidden}.file-card.svelte-1qdlsjx{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);transition:all .3s ease;min-width:0;max-width:100%;overflow:hidden;width:100%;box-sizing:border-box;gap:var(--space-sm);contain:layout}.file-card.transitioning.svelte-1qdlsjx{opacity:.3;transform:translate(10px)}.file-card.svelte-1qdlsjx:hover{background-color:var(--bg-primary);border-color:var(--border-primary)}.file-info-section.svelte-1qdlsjx{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;overflow:hidden}.file-name-section.svelte-1qdlsjx{display:flex;align-items:center;gap:var(--space-xs);min-width:0;max-width:350px;overflow:hidden;flex-shrink:1}.file-name.svelte-1qdlsjx{font-weight:500;color:var(--text-primary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;word-break:break-all;flex:1;min-width:0;max-width:350px;font-size:.875rem}.file-type.svelte-1qdlsjx{background-color:var(--accent-primary);color:#fff;padding:1px 4px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;flex-shrink:0;line-height:1.2}.file-meta.svelte-1qdlsjx{display:flex;gap:var(--space-sm);font-size:.7rem;color:var(--text-muted)}.file-actions.svelte-1qdlsjx{display:flex;gap:var(--space-xs);flex-shrink:0;align-items:center}.action-button.svelte-1qdlsjx{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;background-color:var(--bg-tertiary);color:var(--text-secondary)}.action-button.svelte-1qdlsjx:hover{transform:scale(1.05)}.play-button.svelte-1qdlsjx:hover{background-color:var(--success, #10b981);color:#fff}.download-button.svelte-1qdlsjx:hover{background-color:var(--accent-primary);color:#fff}.delete-button.svelte-1qdlsjx:hover{background-color:var(--danger, #ef4444);color:#fff}.pagination.svelte-1qdlsjx{display:flex;justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;margin-top:var(--space-sm)}.pagination-button.svelte-1qdlsjx{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-secondary);border-radius:var(--radius-md);background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.pagination-button.svelte-1qdlsjx:hover:not(:disabled){background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.pagination-button.svelte-1qdlsjx:disabled{opacity:.5;cursor:not-allowed}.pagination-info.svelte-1qdlsjx{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.loading-placeholder.svelte-1qdlsjx{opacity:.6;pointer-events:none}.loading-bar.svelte-1qdlsjx{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:svelte-1qdlsjx-loading-shimmer 1.5s infinite;border-radius:var(--radius-sm)}.filename-loading.svelte-1qdlsjx{height:1rem;width:60%}.type-loading.svelte-1qdlsjx{height:.75rem;width:2rem}.meta-loading.svelte-1qdlsjx{height:.75rem;width:80%}.action-loading.svelte-1qdlsjx{height:24px;width:24px;border-radius:var(--radius-sm)}@keyframes svelte-1qdlsjx-loading-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 640px){.controls-row.svelte-1qdlsjx{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.file-meta.svelte-1qdlsjx{flex-wrap:wrap;gap:var(--space-sm)}.file-name.svelte-1qdlsjx{font-size:.875rem}.pagination.svelte-1qdlsjx{gap:var(--space-sm)}.pagination-info.svelte-1qdlsjx{font-size:.7rem}}.file-upload.svelte-1ch0h6k{display:flex;flex-direction:column;gap:var(--space-lg)}.drop-zone.svelte-1ch0h6k{border:2px dashed var(--border-secondary);border-radius:var(--radius-md);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all .2s ease;background-color:var(--bg-secondary);color:var(--text-secondary)}.drop-zone.svelte-1ch0h6k:hover,.drop-zone.svelte-1ch0h6k:focus{border-color:var(--accent-primary);background-color:var(--bg-primary);color:var(--text-primary);outline:none}.drop-zone.drag-over.svelte-1ch0h6k{border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff;transform:scale(1.02)}.drop-zone.svelte-1ch0h6k h3:where(.svelte-1ch0h6k){margin:var(--space-sm) 0 var(--space-xs) 0;font-size:1.125rem;font-weight:600}.drop-zone.svelte-1ch0h6k p:where(.svelte-1ch0h6k){margin:var(--space-xs) 0;font-size:.875rem}.file-types.svelte-1ch0h6k{color:var(--text-muted);font-size:.75rem!important}.upload-progress.svelte-1ch0h6k{display:flex;flex-direction:column;gap:var(--space-md)}.upload-item.svelte-1ch0h6k{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.upload-info.svelte-1ch0h6k{display:flex;justify-content:space-between;align-items:center}.file-name.svelte-1ch0h6k{font-weight:500;color:var(--text-primary);flex:1;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.file-size.svelte-1ch0h6k{color:var(--text-secondary);font-size:.875rem;margin-left:var(--space-md)}.progress-bar.svelte-1ch0h6k{width:100%;height:6px;background-color:var(--bg-tertiary);border-radius:3px;overflow:hidden}.progress-fill.svelte-1ch0h6k{height:100%;transition:width .3s ease;border-radius:3px}.progress-text.svelte-1ch0h6k{font-size:.875rem;color:var(--text-secondary);text-align:center}.upload-error.svelte-1ch0h6k{display:flex;align-items:center;gap:var(--space-sm);color:var(--danger, #ef4444);font-size:.875rem}.practice-file-list.svelte-441lx4{display:flex;flex-direction:column;gap:var(--space-md)}.upload-section.svelte-441lx4{animation:svelte-441lx4-slideDown .3s ease-out;margin-top:var(--space-md)}@keyframes svelte-441lx4-slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-state.svelte-441lx4,.empty-state.svelte-441lx4{text-align:center;padding:var(--space-md);color:var(--text-secondary)}.error-message.svelte-441lx4{color:var(--danger, #ef4444);margin-bottom:var(--space-md)}.retry-button.svelte-441lx4{background-color:var(--accent-primary);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;transition:background-color .2s ease}.retry-button.svelte-441lx4:hover{background-color:var(--accent-primary-hover, #5e35b1)}.hint.svelte-441lx4{font-style:italic;font-size:.875rem;margin-top:var(--space-sm)}.files-container.svelte-441lx4{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:100%;overflow:hidden;margin-top:var(--space-md)}.files-grid.svelte-441lx4{display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:100%;overflow:hidden}.file-card.svelte-441lx4{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) var(--space-sm);background-color:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);transition:all .3s ease;min-width:0;max-width:100%;overflow:hidden;width:100%;box-sizing:border-box;gap:var(--space-sm);contain:layout}.file-card.transitioning.svelte-441lx4{opacity:.3;transform:translate(10px)}.file-card.svelte-441lx4:hover{background-color:var(--bg-primary);border-color:var(--border-primary)}.file-info-section.svelte-441lx4{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;overflow:hidden}.file-name-section.svelte-441lx4{display:flex;align-items:center;gap:var(--space-xs);min-width:0;max-width:350px;overflow:hidden;flex-shrink:1}.file-name.svelte-441lx4{font-weight:500;color:var(--text-primary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;word-break:break-all;flex:1;min-width:0;max-width:350px;font-size:.875rem}.file-type.svelte-441lx4{background-color:var(--accent-primary);color:#fff;padding:1px 4px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;flex-shrink:0;line-height:1.2}.file-meta.svelte-441lx4{display:flex;gap:var(--space-sm);font-size:.7rem;color:var(--text-muted)}.file-actions.svelte-441lx4{display:flex;gap:var(--space-xs);flex-shrink:0;align-items:center}.action-button.svelte-441lx4{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;background-color:var(--bg-tertiary);color:var(--text-secondary)}.action-button.svelte-441lx4:hover{transform:scale(1.05)}.view-button.svelte-441lx4:hover{background-color:var(--accent-primary);color:#fff}.download-button.svelte-441lx4:hover{background-color:var(--success, #10b981);color:#fff}.delete-button.svelte-441lx4:hover{background-color:var(--danger, #ef4444);color:#fff}.pagination.svelte-441lx4{display:flex;justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;margin-top:var(--space-sm)}.pagination-button.svelte-441lx4{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-secondary);border-radius:var(--radius-md);background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.pagination-button.svelte-441lx4:hover:not(:disabled){background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.pagination-button.svelte-441lx4:disabled{opacity:.5;cursor:not-allowed}.pagination-info.svelte-441lx4{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.loading-placeholder.svelte-441lx4{opacity:.6;pointer-events:none}.loading-bar.svelte-441lx4{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:svelte-441lx4-loading-shimmer 1.5s infinite;border-radius:var(--radius-sm)}.filename-loading.svelte-441lx4{height:1rem;width:60%}.type-loading.svelte-441lx4{height:.75rem;width:2rem}.meta-loading.svelte-441lx4{height:.75rem;width:80%}.action-loading.svelte-441lx4{height:24px;width:24px;border-radius:var(--radius-sm)}@keyframes svelte-441lx4-loading-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.modal-overlay.svelte-441lx4{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content.svelte-441lx4{background-color:var(--bg-primary);border-radius:var(--radius-lg);width:90vw;height:80vh;max-width:800px;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a}.modal-header.svelte-441lx4{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-secondary);gap:var(--space-md)}.modal-controls.svelte-441lx4{display:flex;align-items:center;gap:var(--space-md);flex-shrink:0}.modal-header.svelte-441lx4 h3:where(.svelte-441lx4){margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;flex:1;margin-right:var(--space-md)}.close-button.svelte-441lx4{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.close-button.svelte-441lx4:hover{background-color:var(--danger, #ef4444);color:#fff}.modal-body.svelte-441lx4{flex:1;padding:var(--space-lg);overflow:auto}.pdf-viewer.svelte-441lx4{width:100%;height:100%;border:none;border-radius:var(--radius-md)}.text-viewer.svelte-441lx4{height:100%;overflow:auto}.text-viewer.svelte-441lx4 pre:where(.svelte-441lx4){margin:0;padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);white-space:pre-wrap;word-wrap:break-word;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;color:var(--text-primary)}@media (max-width: 640px){.file-meta.svelte-441lx4{flex-wrap:wrap;gap:var(--space-sm)}.file-name.svelte-441lx4{font-size:.875rem}.pagination.svelte-441lx4{gap:var(--space-sm)}.pagination-info.svelte-441lx4{font-size:.7rem}.modal-content.svelte-441lx4{width:95vw;height:85vh}.modal-header.svelte-441lx4{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.modal-controls.svelte-441lx4{align-self:stretch;justify-content:space-between}}.lock-container.svelte-177caf6{display:flex;flex:1;align-items:center;justify-content:center;height:100%}.lock-icon-circle.svelte-177caf6{display:flex;align-items:center;justify-content:center;width:125px;height:125px;border-radius:50%;border:3px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-muted);opacity:.6;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;cursor:pointer;font-family:inherit}.lock-icon-circle.svelte-177caf6:hover{opacity:.8;border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.lock-icon-circle.svelte-177caf6:focus{outline:none;box-shadow:0 0 0 3px #673ab74d}.expired-notice.svelte-5qxm3k{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-lg);display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000001a}.notice-content.svelte-5qxm3k{display:flex;align-items:center;gap:var(--space-md)}.notice-icon.svelte-5qxm3k{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:#f59e0b;color:#fff;border-radius:50%;flex-shrink:0}.notice-text.svelte-5qxm3k h3:where(.svelte-5qxm3k){margin:0 0 var(--space-xs) 0;font-size:1rem;font-weight:600;color:#92400e}.notice-text.svelte-5qxm3k p:where(.svelte-5qxm3k){margin:0;font-size:.875rem;color:#a16207;line-height:1.4}.notice-actions.svelte-5qxm3k{display:flex;gap:var(--space-sm);flex-shrink:0}.upgrade-btn.svelte-5qxm3k{background-color:#f59e0b;color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.upgrade-btn.svelte-5qxm3k:hover{background-color:#d97706;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.dismiss-btn.svelte-5qxm3k{background-color:transparent;color:#a16207;border:1px solid #d6d3d1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.dismiss-btn.svelte-5qxm3k:hover{background-color:#fef3c7;border-color:#a16207}@media (max-width: 768px){.expired-notice.svelte-5qxm3k{flex-direction:column;gap:var(--space-md);margin:var(--space-md)}.notice-actions.svelte-5qxm3k{width:100%;justify-content:center}.upgrade-btn.svelte-5qxm3k,.dismiss-btn.svelte-5qxm3k{flex:1}}.practice-badges.svelte-smr3rn{width:100%;max-width:600px;margin:0 auto;padding:1rem;background:transparent}.badges-loading.svelte-smr3rn,.badges-error.svelte-smr3rn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-2, #64748b)}.loading-spinner.svelte-smr3rn{width:1rem;height:1rem;border:2px solid var(--surface-3, #e2e8f0);border-top:2px solid var(--accent, #3b82f6);border-radius:50%;animation:svelte-smr3rn-spin 1s linear infinite}.badges-error.svelte-smr3rn{color:var(--error, #ef4444)}.badges-grid.svelte-smr3rn{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap}.badge-day.svelte-smr3rn{display:flex;flex-direction:column;align-items:center;gap:.5rem}.day-label.svelte-smr3rn{font-size:.75rem;font-weight:600;color:var(--text-2, #64748b);text-transform:uppercase;letter-spacing:.05em}.badge-pick.svelte-smr3rn{width:3rem;height:3rem;border:none;background:transparent;border-radius:.5rem;cursor:default;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.badge-pick.clickable.svelte-smr3rn{cursor:pointer}.badge-pick.clickable.svelte-smr3rn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.badge-pick.current-day.svelte-smr3rn{box-shadow:0 0 0 2px var(--accent, #3b82f6);background:var(--accent-1, #dbeafe)}.badge-pick.current-day.clickable.svelte-smr3rn:hover{box-shadow:0 0 0 2px var(--accent, #3b82f6),0 4px 12px #3b82f64d}.pick-image.svelte-smr3rn{width:2rem;height:2rem;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));background:#fff;border-radius:.25rem;padding:.125rem}.pick-placeholder.svelte-smr3rn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.pick-outline.svelte-smr3rn{width:1.5rem;height:1.5rem;border:2px dashed var(--surface-3, #e2e8f0);border-radius:.25rem;background:var(--surface-2, #f1f5f9)}.badge-pick.current-day.svelte-smr3rn .pick-outline:where(.svelte-smr3rn){border-color:var(--accent, #3b82f6);background:var(--accent-1, #dbeafe)}@keyframes svelte-smr3rn-spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.practice-badges.svelte-smr3rn{padding:.75rem}.badges-grid.svelte-smr3rn{gap:.25rem}.badge-pick.svelte-smr3rn{width:2.5rem;height:2.5rem}.pick-image.svelte-smr3rn{width:1.5rem;height:1.5rem}.pick-outline.svelte-smr3rn{width:1.25rem;height:1.25rem}}.practice-summary-card.svelte-u9nbpw{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-primary);display:flex;flex-direction:column;gap:var(--space-lg)}.summary-header.svelte-u9nbpw{display:flex;justify-content:space-between;align-items:center}.header-content.svelte-u9nbpw{display:flex;align-items:center;gap:var(--space-sm)}.header-content.svelte-u9nbpw h3:where(.svelte-u9nbpw){margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.total-time.svelte-u9nbpw{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs)}.time-value.svelte-u9nbpw{font-size:1.25rem;font-weight:700;color:var(--accent-primary);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.time-label.svelte-u9nbpw{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.weekly-chart.svelte-u9nbpw{display:flex;flex-direction:column;gap:var(--space-md)}.chart-title.svelte-u9nbpw{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;font-weight:600;color:var(--text-secondary)}.chart-bars.svelte-u9nbpw{display:flex;align-items:end;gap:var(--space-sm);height:80px;padding:var(--space-sm);background:#0003;border-radius:var(--radius-md)}.bar-container.svelte-u9nbpw{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex:1}.bar-wrapper.svelte-u9nbpw{height:60px;width:100%;display:flex;align-items:end;position:relative}.bar.svelte-u9nbpw{width:100%;background:#ffffff1a;border-radius:var(--radius-sm);transition:all .3s ease;position:relative;min-height:2px}.bar.active.svelte-u9nbpw{background:linear-gradient(to top,var(--accent-primary),var(--accent-secondary))}.bar.svelte-u9nbpw:hover{transform:scaleY(1.05)}.bar-tooltip.svelte-u9nbpw{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:var(--space-xs);border-radius:var(--radius-sm);font-size:.7rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:10}.bar.svelte-u9nbpw:hover .bar-tooltip:where(.svelte-u9nbpw){opacity:1;visibility:visible}.bar-label.svelte-u9nbpw{font-size:.7rem;color:var(--text-secondary);font-weight:500}.quick-stats.svelte-u9nbpw{display:flex;gap:var(--space-lg);justify-content:space-between}.stat-item.svelte-u9nbpw{display:flex;align-items:center;gap:var(--space-sm);flex:1}.stat-icon.svelte-u9nbpw{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#673ab71a;border-radius:50%;color:var(--accent-primary)}.stat-content.svelte-u9nbpw{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-value.svelte-u9nbpw{font-size:1.1rem;font-weight:700;color:var(--text-primary);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.stat-label.svelte-u9nbpw{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.recent-sessions.svelte-u9nbpw{display:flex;flex-direction:column;gap:var(--space-md)}.section-title.svelte-u9nbpw{margin:0;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.sessions-list.svelte-u9nbpw{display:flex;flex-direction:column;gap:var(--space-sm)}.session-item.svelte-u9nbpw{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm);background:#ffffff05;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.05)}.session-info.svelte-u9nbpw{display:flex;justify-content:space-between;align-items:center}.session-date.svelte-u9nbpw{font-size:.875rem;font-weight:500;color:var(--text-primary)}.session-duration.svelte-u9nbpw{font-size:.875rem;font-weight:600;color:var(--accent-primary);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.session-exercises.svelte-u9nbpw{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.exercise-tag.svelte-u9nbpw{font-size:.75rem;color:var(--text-secondary);background:#ffffff0d;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1)}.exercise-separator.svelte-u9nbpw{font-size:.75rem;color:var(--text-muted);opacity:.5}.loading-placeholder.svelte-u9nbpw{display:flex;align-items:center;justify-content:center;min-height:2rem}.loading-bar.svelte-u9nbpw{width:60px;height:4px;background:linear-gradient(90deg,#673ab733,#673ab799,#673ab733);border-radius:2px;animation:svelte-u9nbpw-loading-pulse 1.5s ease-in-out infinite}@keyframes svelte-u9nbpw-loading-pulse{0%{background-position:-200% 0}to{background-position:200% 0}}.error-text.svelte-u9nbpw{color:#ef4444;font-size:.875rem;font-weight:500}@media (max-width: 640px){.quick-stats.svelte-u9nbpw{flex-direction:column;gap:var(--space-md)}.stat-item.svelte-u9nbpw{justify-content:center}.session-info.svelte-u9nbpw{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}}.practice-controls.svelte-1uf5f48{margin-bottom:var(--space-md);padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-secondary)}@media (max-width: 640px){.practice-controls.svelte-1uf5f48{padding:var(--space-md);margin-left:calc(-1 * var(--space-md));margin-right:calc(-1 * var(--space-md));margin-top:var(--space-lg);border-radius:0;border-left:none;border-right:none;border:1px solid var(--border-secondary)}}.controls-row.svelte-1uf5f48{display:flex;align-items:center;gap:var(--space-sm);justify-content:center}.control-button.svelte-1uf5f48{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:none;border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:500;font-family:inherit;min-height:32px}.control-button.svelte-1uf5f48:hover{background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--text-primary)}.session-button.svelte-1uf5f48{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);font-weight:600}.session-button.svelte-1uf5f48:hover{background:var(--accent-primary-hover);transform:translateY(-1px);box-shadow:0 2px 8px #673ab74d}.button-text.svelte-1uf5f48{font-size:.75rem}.caret-icon.svelte-1uf5f48{color:var(--text-secondary);transition:transform .2s ease;display:flex;align-items:center}.exercise-select.svelte-1uf5f48{padding:var(--space-sm) var(--space-md);border:1px solid var(--border-secondary);border-radius:var(--radius-md);background:none;color:var(--text-secondary);font-size:.75rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;min-height:32px;min-width:140px}.exercise-select.svelte-1uf5f48:hover{background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--text-primary)}.exercise-select.svelte-1uf5f48:focus{outline:none;background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--text-primary);box-shadow:0 0 0 2px #673ab71a}@media (max-width: 640px){.controls-row.svelte-1uf5f48{flex-direction:column;gap:var(--space-sm);width:100%}.control-button.svelte-1uf5f48,.exercise-select.svelte-1uf5f48{width:100%;justify-content:center}.exercise-select.svelte-1uf5f48{min-width:100%;text-align:center;font-size:1rem}.exercise-select.svelte-1uf5f48 option:where(.svelte-1uf5f48){font-size:1.25rem}.control-button.svelte-1uf5f48{padding:var(--space-sm) var(--space-md);min-height:40px}.button-text.svelte-1uf5f48{display:inline;font-size:.875rem}}.session-status.svelte-1uf5f48{background:#673ab71a;border-color:var(--accent-primary);color:var(--accent-primary);padding:var(--space-xs) var(--space-md);gap:var(--space-sm)}.session-status.paused.svelte-1uf5f48{background:#f59e0b1a;border-color:#f59e0b;color:#f59e0b}.session-status.svelte-1uf5f48:hover{background:#673ab733;border-color:var(--accent-primary)}.session-status.paused.svelte-1uf5f48:hover{background:#f59e0b33;border-color:#f59e0b}.session-indicator.svelte-1uf5f48{display:flex;align-items:center;justify-content:center}.status-dot.svelte-1uf5f48{width:8px;height:8px;border-radius:50%;animation:svelte-1uf5f48-pulse 2s infinite}.status-dot.active.svelte-1uf5f48{background-color:var(--accent-primary)}.status-dot.paused.svelte-1uf5f48{background-color:#f59e0b;animation:none}@keyframes svelte-1uf5f48-pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.session-info.svelte-1uf5f48{display:flex;flex-direction:column;align-items:flex-start;gap:1px}.session-time.svelte-1uf5f48{font-size:.875rem;font-weight:700;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;line-height:1}.session-label.svelte-1uf5f48{font-size:.6rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;opacity:.8;line-height:1}@media (max-width: 640px){.session-status.svelte-1uf5f48{justify-content:center;width:100%;padding:var(--space-sm) var(--space-md);min-height:40px}.session-info.svelte-1uf5f48{align-items:center}}.notification-overlay.svelte-1eehub5{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:center;padding:var(--space-md);pointer-events:none}.notification.svelte-1eehub5{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 32px #0003;max-width:400px;width:100%;pointer-events:all;animation:svelte-1eehub5-slideDown .3s ease-out}.notification-content.svelte-1eehub5{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);padding-bottom:var(--space-sm)}.notification-icon.svelte-1eehub5{color:var(--accent-color);flex-shrink:0;margin-top:2px}.notification-text.svelte-1eehub5{flex:1}.notification-text.svelte-1eehub5 h3:where(.svelte-1eehub5){margin:0 0 var(--space-xs) 0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.notification-text.svelte-1eehub5 p:where(.svelte-1eehub5){margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.4}.close-button.svelte-1eehub5{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);flex-shrink:0;transition:all .2s ease}.close-button.svelte-1eehub5:hover{background:var(--bg-hover);color:var(--text-primary)}.notification-actions.svelte-1eehub5{display:flex;gap:var(--space-sm);padding:0 var(--space-md) var(--space-md)}.compatibility-button.svelte-1eehub5{background:var(--accent-color);color:#fff;border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1}.compatibility-button.svelte-1eehub5:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.compatibility-button.svelte-1eehub5:disabled{opacity:.7;cursor:not-allowed;transform:none}.dismiss-button.svelte-1eehub5{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s ease}.dismiss-button.svelte-1eehub5:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}@keyframes svelte-1eehub5-slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.notification-overlay.svelte-1eehub5{padding:var(--space-sm)}.notification.svelte-1eehub5{max-width:none}.notification-actions.svelte-1eehub5{flex-direction:column}}.dashboard.svelte-1xxowa6{margin-top:var(--space-lg)}.badges-section.svelte-1xxowa6{margin-bottom:var(--space-xl, 2rem);width:100%}.practice-summary-section.svelte-1xxowa6{margin-top:var(--space-lg);margin-bottom:var(--space-xl, 2rem);width:100%}.grid.svelte-1xxowa6{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media (max-width: 768px){.grid.svelte-1xxowa6{grid-template-columns:1fr}}@media (max-width: 640px){.practice-controls-container.svelte-1xxowa6{flex-direction:column;align-items:stretch}.stop-button.svelte-1xxowa6{width:32px;height:32px}.stop-button-row.svelte-1xxowa6{margin:0}.exercise-header.svelte-1xxowa6{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.practice-search-container.svelte-1xxowa6{min-width:unset;width:100%}.upload-files-button.svelte-1xxowa6{width:100%;justify-content:center}}.exercise-card.svelte-1xxowa6{height:580px;display:flex;flex-direction:column;position:relative}.practice-files-container.svelte-1xxowa6{flex:1;overflow-y:auto}.practice-controls-container.svelte-1xxowa6{margin-bottom:var(--space-md)}.stop-button-row.svelte-1xxowa6{display:flex;justify-content:flex-end;align-items:center;gap:var(--space-sm);margin-bottom:15px}.stop-button.svelte-1xxowa6{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.stop-button.svelte-1xxowa6:hover{background-color:var(--accent-primary);color:#fff;transform:scale(1.05)}.stop-button.svelte-1xxowa6:focus{outline:none;box-shadow:0 0 0 3px #673ab74d}.drone-button.svelte-1xxowa6{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background-color:var(--accent-primary);color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.drone-button.svelte-1xxowa6:hover{background-color:var(--accent-primary-hover);transform:scale(1.05)}.drone-button.playing.svelte-1xxowa6{background-color:#dc2626}.drone-button.playing.svelte-1xxowa6:hover{background-color:#b91c1c}.drone-button.svelte-1xxowa6:focus{outline:none;box-shadow:0 0 0 3px #673ab74d}.upload-files-button.svelte-1xxowa6{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;font-family:inherit;white-space:nowrap}.upload-files-button.svelte-1xxowa6:hover{background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.upload-files-button.svelte-1xxowa6:focus{outline:none}.exercise-header.svelte-1xxowa6{flex-shrink:0;align-self:flex-start;display:flex;align-items:center;gap:var(--space-md);width:100%}.practice-search-container.svelte-1xxowa6{flex:1;min-width:200px}.full-card-selector.svelte-1xxowa6{display:flex;flex:1;align-items:center;justify-content:center;height:100%}.metronome-card.svelte-1xxowa6,.circle-of-fifths-card.svelte-1xxowa6{min-height:400px;display:flex;flex-direction:column}.sound-files-card.svelte-1xxowa6{min-height:400px;display:flex;flex-direction:column;overflow:hidden;max-width:100%}.changes-content.svelte-1xxowa6{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-style:italic}.start-playing-btn.svelte-1xxowa6{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);background:none;border:none;cursor:pointer;transition:all .2s ease}.vinyl-icon.svelte-1xxowa6{display:flex;align-items:center;justify-content:center;width:125px;height:125px;border-radius:50%;border:3px solid var(--border-secondary);background-color:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.start-playing-text.svelte-1xxowa6{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.start-playing-btn.svelte-1xxowa6:hover .vinyl-icon:where(.svelte-1xxowa6){border-color:var(--accent-primary);background-color:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.start-playing-btn.svelte-1xxowa6:focus{outline:none}.start-playing-btn.svelte-1xxowa6:focus .vinyl-icon:where(.svelte-1xxowa6){box-shadow:0 0 0 3px #673ab74d}.sound-files-content.svelte-1xxowa6{flex:1;display:flex;flex-direction:column;gap:var(--space-lg);overflow:hidden;max-width:100%}.sound-files-header.svelte-1xxowa6{display:flex;justify-content:space-between;align-items:center}.sound-files-header.svelte-1xxowa6 h2:where(.svelte-1xxowa6){margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.back-button.svelte-1xxowa6{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.back-button.svelte-1xxowa6:hover{background-color:var(--accent-primary);color:#fff;transform:scale(1.05)}.back-button.svelte-1xxowa6:focus{outline:none;box-shadow:0 0 0 3px #673ab74d}.sound-files-body.svelte-1xxowa6{flex:1;display:flex;flex-direction:column;gap:var(--space-lg);overflow-y:auto;overflow-x:hidden;max-width:100%}
