/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\@container{container-type:inline-size}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{--bg:#080810;--surface:#0f0f1a;--surface2:#14141f;--border:#ffffff12;--border2:#ffffff1f;--green:#4ade80;--green-dim:#4ade801f;--green-glow:#4ade8040;--yellow:#fbbf24;--orange:#fb923c;--red:#f87171;--blue:#60a5fa;--purple:#a78bfa;--text:#f0f0f8;--text-dim:#f0f0f880;--text-muted:#f0f0f840;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--role-chord:var(--green);--role-scale:var(--yellow);--role-tension:var(--orange);--role-avoid:var(--red)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#app{background:var(--bg);min-height:100%;color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif}button{cursor:pointer;color:inherit;font:inherit;background:0 0;border:none;padding:0}input,select{font:inherit}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}*{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent}.section-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;font-size:10px;font-weight:700}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}.tab-bar.svelte-1nx8sae{display:flex;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;position:relative}.tab.svelte-1nx8sae{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:9px 4px 7px;gap:2px;color:var(--text-dim);transition:color .15s;position:relative}.tab.svelte-1nx8sae:hover{color:var(--text)}.tab.active.svelte-1nx8sae{color:var(--green)}.tab-main.svelte-1nx8sae{font-size:10px;font-weight:800;letter-spacing:.08em}.tab-sub.svelte-1nx8sae{font-size:9px;font-weight:500;letter-spacing:.04em;opacity:.7}.tab-indicator.svelte-1nx8sae{position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--green);border-radius:0 0 2px 2px}@media (min-width: 768px){.tab-bar.svelte-1nx8sae{height:100%;flex-direction:column;align-items:stretch;justify-content:flex-start;border-top:0;background:transparent;padding:12px 10px;gap:6px}.tab.svelte-1nx8sae{flex:0 0 auto;min-height:58px;align-items:flex-start;padding:11px 12px;border-radius:var(--radius-md);background:#ffffff06;border:1px solid transparent}.tab.svelte-1nx8sae:hover{background:#ffffff0f}.tab.active.svelte-1nx8sae{background:var(--green-dim);border-color:#4ade8047}.tab-main.svelte-1nx8sae{font-size:11px}.tab-sub.svelte-1nx8sae{font-size:10px}.tab-indicator.svelte-1nx8sae{top:12px;left:0;width:3px;height:calc(100% - 24px);transform:none;border-radius:0 3px 3px 0}}.header.svelte-1t4q57h{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.brand.svelte-1t4q57h{display:flex;flex-direction:column;flex-shrink:0;line-height:1;gap:2px}.brand-name.svelte-1t4q57h{font-size:15px;font-weight:900;letter-spacing:-.01em;background:linear-gradient(90deg,#4ade80,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-sub.svelte-1t4q57h{font-size:8px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.inst-row.svelte-1t4q57h{display:flex;gap:3px;flex:1;overflow-x:auto;scrollbar-width:none}.inst-row.svelte-1t4q57h::-webkit-scrollbar{display:none}.inst-btn.svelte-1t4q57h{flex-shrink:0;padding:5px 8px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid transparent;font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);transition:all .15s}.inst-btn.svelte-1t4q57h:hover{background:#ffffff1a;color:var(--text)}.inst-btn.active.svelte-1t4q57h{background:var(--green-dim);border-color:#4ade8066;color:var(--green)}.note-toggle.svelte-1t4q57h{flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid transparent;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s}.note-toggle.svelte-1t4q57h:hover{background:#ffffff1a;color:var(--text)}.note-toggle.svelte-1t4q57h span.active:where(.svelte-1t4q57h){color:var(--green)}.mode-toggle.svelte-1t4q57h{flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-sm);background:#60a5fa1a;border:1px solid rgba(96,165,250,.28);color:var(--blue);font-size:13px;font-weight:900;transition:all .15s}.mode-toggle.svelte-1t4q57h:hover{background:#60a5fa2e;border-color:#60a5fa70}@media (min-width: 768px){.header.svelte-1t4q57h{width:min(100%,1440px);margin:0 auto;padding:12px 18px;border-left:1px solid var(--border);border-right:1px solid var(--border)}.brand.svelte-1t4q57h{min-width:146px}.brand-name.svelte-1t4q57h{font-size:18px}.brand-sub.svelte-1t4q57h{font-size:9px}.inst-row.svelte-1t4q57h{gap:5px;overflow:visible}.inst-btn.svelte-1t4q57h{padding:7px 10px}.note-toggle.svelte-1t4q57h,.mode-toggle.svelte-1t4q57h{width:36px;height:36px}}.ksp.svelte-203rc3{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.ksp-row.svelte-203rc3{display:flex;align-items:center;gap:8px}.note-grid.svelte-203rc3{display:flex;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}.note-grid.svelte-203rc3::-webkit-scrollbar{display:none}.note-btn.svelte-203rc3{flex-shrink:0;min-width:28px;padding:5px 4px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid transparent;font-size:11px;font-weight:700;color:var(--text-muted);transition:all .12s;text-align:center}.note-btn.svelte-203rc3:hover{background:#ffffff1a;color:var(--text)}.note-btn.active.svelte-203rc3{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.scale-toggle.svelte-203rc3{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid var(--border2);white-space:nowrap;flex-shrink:0;transition:all .12s}.scale-toggle.svelte-203rc3:hover{background:#ffffff1a}.scale-name.svelte-203rc3{font-size:11px;font-weight:600;color:var(--text-dim)}.chevron.svelte-203rc3{font-size:14px;color:var(--text-muted);display:inline-block;transform:rotate(90deg);transition:transform .2s}.chevron.up.svelte-203rc3{transform:rotate(-90deg)}.scale-grid.svelte-203rc3{display:grid;grid-template-columns:1fr 1fr;gap:4px}.scale-btn.svelte-203rc3{padding:7px 10px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid transparent;font-size:12px;color:var(--text-dim);text-align:left;transition:all .12s}.scale-btn.svelte-203rc3:hover{background:#ffffff17;color:var(--text)}.scale-btn.active.svelte-203rc3{background:var(--green-dim);border-color:#4ade8059;color:var(--green);font-weight:600}@media (min-width: 768px){.ksp.svelte-203rc3{padding:14px;gap:10px}.ksp-row.svelte-203rc3{align-items:stretch;flex-direction:column}.note-grid.svelte-203rc3{display:grid;grid-template-columns:repeat(6,1fr);gap:5px;overflow:visible}.note-btn.svelte-203rc3{min-width:0;padding:8px 4px}.scale-toggle.svelte-203rc3{justify-content:space-between;padding:9px 10px}.scale-grid.svelte-203rc3{grid-template-columns:1fr}}.cpi.svelte-ef985n{padding:8px 12px;display:flex;flex-direction:column;gap:6px}.cpi-top.svelte-ef985n{display:flex;align-items:center;justify-content:space-between;gap:8px}.cpi-label.svelte-ef985n{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.edit-btn.svelte-ef985n{font-size:11px;padding:3px 10px;border-radius:var(--radius-sm);background:#ffffff0f;color:var(--text-dim);border:1px solid var(--border2);transition:all .12s}.edit-btn.svelte-ef985n:hover{background:#ffffff1f;color:var(--text)}.top-actions.svelte-ef985n{display:flex;gap:5px;align-items:center}.mode-btn.svelte-ef985n{font-size:11px;padding:3px 8px;border-radius:var(--radius-sm);background:#60a5fa1a;color:var(--blue);border:1px solid rgba(96,165,250,.25);font-weight:800;transition:all .12s}.mode-btn.svelte-ef985n:hover{background:#60a5fa2b;border-color:#60a5fa6b}.raw-input.svelte-ef985n{width:100%;padding:8px 10px;background:#ffffff0d;border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-weight:600;outline:none;transition:border-color .15s}.raw-input.svelte-ef985n:focus{border-color:var(--green)}.chord-strip.svelte-ef985n{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;align-items:center}.chord-strip.svelte-ef985n::-webkit-scrollbar{display:none}.roman-strip.svelte-ef985n{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none}.roman-strip.svelte-ef985n::-webkit-scrollbar{display:none}.roman-pill.svelte-ef985n{flex-shrink:0;min-width:34px;padding:3px 7px;border-radius:4px;background:#ffffff09;border:1px solid var(--border);color:var(--text-muted);font-size:10px;font-weight:900;text-align:center}.roman-pill.active.svelte-ef985n{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.chord-pill.svelte-ef985n{flex-shrink:0;display:flex;align-items:center;gap:4px;padding:6px 9px;border-radius:var(--radius-sm);background:#ffffff0f;border:1px solid transparent;font-size:14px;font-weight:700;color:var(--text-dim);transition:all .12s;-webkit-user-select:none;user-select:none;cursor:pointer}.chord-pill.svelte-ef985n:hover{background:#ffffff1a;color:var(--text)}.chord-pill.active.svelte-ef985n{background:var(--green-dim);border-color:#4ade8066;color:var(--green)}.chord-pill.tonic.svelte-ef985n{background:#60a5fa1f;border-color:#60a5fa6b;color:var(--blue)}.chord-pill.tonic.svelte-ef985n:before{content:"KEY";font-size:8px;font-weight:900;letter-spacing:.04em;color:#60a5facc}.chord-pill.tension-light.svelte-ef985n{background:#fb923c1a;border-color:#fb923c80;color:#fb923c}.chord-pill.tension-strong.svelte-ef985n{background:#f871711f;border-color:#f8717194;color:#f87171}.chord-pill.tension-light.active.svelte-ef985n{background:#fb923c29;border-color:#fb923c;color:#fb923c}.chord-pill.tension-strong.active.svelte-ef985n{background:#f871712e;border-color:#f87171;color:#f87171}.remove-x.svelte-ef985n{font-size:14px;line-height:1;color:#fff3;transition:color .12s;padding:0 1px}.remove-x.svelte-ef985n:hover{color:var(--red)}.add-btn.svelte-ef985n{flex-shrink:0;width:28px;height:28px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px dashed rgba(255,255,255,.15);font-size:18px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .12s;line-height:1}.add-btn.svelte-ef985n:hover{background:var(--green-dim);border-color:#4ade8066;color:var(--green)}.add-btn.active.svelte-ef985n{background:var(--green-dim);border-color:#4ade8073;color:var(--green)}.note-picker.svelte-ef985n{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:5px;padding:8px;border-radius:var(--radius-md);background:#ffffff06;border:1px solid var(--border)}.note-picker.svelte-ef985n .diatonic-label:where(.svelte-ef985n){grid-column:1 / -1}.note-chip.svelte-ef985n{min-width:0;padding:6px 4px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid var(--border);color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .12s}.note-chip.svelte-ef985n:hover{background:#ffffff14;color:var(--text)}.note-chip-root.svelte-ef985n{font-size:13px;font-weight:900;line-height:1}.note-chip-chord.svelte-ef985n{font-size:9px;font-weight:700;color:#ffffff61;line-height:1}.note-chip.in-scale.svelte-ef985n{background:#4ade8014;border-color:#4ade803d;color:var(--green)}.note-chip.tonic.svelte-ef985n{background:#60a5fa1f;border-color:#60a5fa6b;color:var(--blue)}.note-chip.tonic.svelte-ef985n .note-chip-chord:where(.svelte-ef985n),.note-chip.in-scale.svelte-ef985n .note-chip-chord:where(.svelte-ef985n){color:#ffffff94}.note-chip.tension-light.svelte-ef985n{background:#fb923c14;border-color:#fb923c4d;color:#fb923c}.note-chip.tension-strong.svelte-ef985n{background:#f871711a;border-color:#f8717157;color:#f87171}.diatonic.svelte-ef985n,.suggestions.svelte-ef985n{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.suggestions.svelte-ef985n{padding-top:2px}.diatonic-label.svelte-ef985n{font-size:10px;color:var(--text-muted);flex-shrink:0}.d-chip.svelte-ef985n{padding:3px 7px;border-radius:4px;background:#ffffff0a;border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-muted);transition:all .12s}.d-chip.svelte-ef985n:hover{background:var(--green-dim);border-color:#4ade804d;color:var(--green)}.d-chip.suggested.svelte-ef985n{order:-2;gap:5px;display:inline-flex;align-items:center;padding-inline:8px;border-width:1.5px}.d-chip.suggested.resolve.svelte-ef985n{background:#60a5fa1a;border-color:#60a5fa47;color:var(--blue)}.suggested-label.svelte-ef985n{font-size:8px;font-weight:900;letter-spacing:.05em;text-transform:uppercase;color:#ffffff80}.suggestion-help.svelte-ef985n{flex-basis:100%;color:var(--text-muted);font-size:10px;line-height:1.35}.d-chip.in-scale.svelte-ef985n{background:#4ade8012;border-color:#4ade8038;color:var(--green)}.d-chip.in-scale.svelte-ef985n:hover{background:#4ade8024;border-color:#4ade8066;color:var(--green)}.d-chip.tonic.svelte-ef985n{background:#60a5fa1a;border-color:#60a5fa4d;color:var(--blue)}.d-chip.tonic.svelte-ef985n:before{content:"KEY ";font-size:8px;font-weight:900;color:#60a5fab8}.d-chip.tonic.svelte-ef985n:hover{background:#60a5fa2e;border-color:#60a5fa85;color:var(--blue)}.d-chip.tension-light.svelte-ef985n{background:#fb923c14;border-color:#fb923c42;color:#fb923c}.d-chip.tension-light.svelte-ef985n:hover{background:#fb923c29;border-color:#fb923c75;color:#fb923c}.d-chip.tension-strong.svelte-ef985n{background:#f871711a;border-color:#f871714d;color:#f87171}.d-chip.tension-strong.svelte-ef985n:hover{background:#f871712e;border-color:#f8717180;color:#f87171}@media (min-width: 768px){.cpi.svelte-ef985n{padding:14px;gap:10px}.chord-strip.svelte-ef985n,.roman-strip.svelte-ef985n{flex-wrap:wrap;overflow:visible}.chord-pill.svelte-ef985n{flex-shrink:1}.diatonic.svelte-ef985n{gap:5px}.note-picker.svelte-ef985n{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:10px}.d-chip.svelte-ef985n{padding:5px 8px}}.preset-library.svelte-1yqym0k{padding:0 12px 10px;border-bottom:1px solid var(--border)}.preset-head.svelte-1yqym0k{display:flex;gap:6px;align-items:center}.preset-toggle.svelte-1yqym0k,.save-btn.svelte-1yqym0k{border-radius:var(--radius-sm);border:1px solid var(--border2);background:#ffffff0d;color:var(--text-dim);font-size:11px;font-weight:800;transition:all .12s}.preset-toggle.svelte-1yqym0k{flex:1;padding:7px 9px;display:flex;align-items:center;justify-content:space-between;text-transform:uppercase;letter-spacing:.06em}.save-btn.svelte-1yqym0k{padding:7px 10px}.preset-toggle.svelte-1yqym0k:hover,.save-btn.svelte-1yqym0k:hover{background:#ffffff1a;color:var(--text)}.count.svelte-1yqym0k{color:var(--green)}.preset-list.svelte-1yqym0k{display:flex;flex-direction:column;gap:6px;margin-top:8px}.preset-card.svelte-1yqym0k{position:relative;border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff09;transition:all .12s}.preset-card.svelte-1yqym0k:hover{background:#ffffff13;border-color:#4ade8047}.preset-card.user.svelte-1yqym0k{border-color:#60a5fa3d}.preset-load.svelte-1yqym0k{width:100%;padding:9px 10px;text-align:left}.preset-title.svelte-1yqym0k{display:flex;justify-content:space-between;gap:8px;color:var(--text);font-size:12px;font-weight:900}.preset-key.svelte-1yqym0k{flex-shrink:0;color:var(--yellow);font-size:10px;text-transform:capitalize}.preset-prog.svelte-1yqym0k{margin-top:5px;color:var(--green);font-size:12px;font-weight:800;word-spacing:4px}.preset-desc.svelte-1yqym0k,.preset-meta.svelte-1yqym0k{margin-top:5px;color:var(--text-muted);font-size:10px;line-height:1.35}.preset-meta.svelte-1yqym0k{display:flex;gap:8px;text-transform:uppercase;letter-spacing:.05em}.delete-btn.svelte-1yqym0k{position:absolute;right:6px;bottom:5px;color:#ffffff3d;font-size:15px;line-height:1}.delete-btn.svelte-1yqym0k:hover{color:var(--red)}@media (min-width: 768px){.preset-library.svelte-1yqym0k{padding:0 14px 14px}}.note-groups.svelte-c5aamj{display:flex;flex-direction:column;gap:10px}.group.svelte-c5aamj{display:flex;flex-direction:column;gap:6px}.group-head.svelte-c5aamj{display:flex;align-items:center;gap:7px}.dot.svelte-c5aamj{width:7px;height:7px;border-radius:50%;flex-shrink:0}.glabel.svelte-c5aamj{font-size:11px;font-weight:700;color:var(--text)}.gtip.svelte-c5aamj{font-size:10px;color:var(--text-muted);margin-left:auto}.chips.svelte-c5aamj{display:flex;flex-wrap:wrap;gap:5px}.chip.svelte-c5aamj{padding:4px 10px;border-radius:5px;background:color-mix(in srgb,var(--c) 14%,transparent);border:1px solid color-mix(in srgb,var(--c) 30%,transparent);color:var(--c);font-size:13px;font-weight:800;letter-spacing:.02em}.chord-diagram.svelte-ck39gz{padding:0;background:none;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:border-color .15s,transform .1s;display:block;line-height:0}.chord-diagram.svelte-ck39gz:hover{border-color:#fff3;transform:scale(1.02)}.chord-diagram.active.svelte-ck39gz{border-color:#4ade80}.dgrid-wrap.svelte-jonw6c{display:flex;flex-direction:column;gap:8px}.scroll-row.svelte-jonw6c{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}.hint-msg.svelte-jonw6c{margin:0;padding:18px;text-align:center;color:var(--text-muted);font-size:13px;background:#ffffff05;border-radius:var(--radius-md);border:1px dashed var(--border)}.scroll-hint.svelte-jonw6c{font-size:10px;color:var(--text-muted);text-align:center;margin:0}@container panel (min-width: 720px){.scroll-row.svelte-jonw6c{display:grid;grid-template-columns:repeat(auto-fit,minmax(124px,1fr));overflow:visible}.scroll-row.svelte-jonw6c svg{justify-self:center}.scroll-hint.svelte-jonw6c{display:none}}.main-visual.svelte-k1ijrm{border-bottom:1px solid var(--border)}.expanded-visual.svelte-k1ijrm{padding:12px 16px 6px;background:var(--bg);overflow-x:auto;display:flex;flex-direction:column;align-items:center;gap:6px}.collapsed-visual.svelte-k1ijrm{padding:10px 16px;background:var(--surface2);display:flex;align-items:center;justify-content:space-between;gap:12px}.collapsed-copy.svelte-k1ijrm{min-width:0;display:flex;flex-direction:column;gap:2px}.collapsed-title.svelte-k1ijrm{font-size:12px;font-weight:800;color:var(--text)}.collapsed-sub.svelte-k1ijrm,.visual-sub.svelte-k1ijrm{font-size:11px;color:var(--text-muted)}.collapsed-sub.svelte-k1ijrm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.visual-sub.svelte-k1ijrm{text-align:center;margin:0}.visual-sub.svelte-k1ijrm strong{color:var(--text-dim)}.show-btn.svelte-k1ijrm{flex-shrink:0;padding:6px 12px;border-radius:var(--radius-sm);background:#4ade801a;border:1px solid rgba(74,222,128,.3);color:var(--green);font-size:11px;font-weight:800}@container panel (min-width: 720px){.expanded-visual.svelte-k1ijrm{padding:20px 24px 12px}.expanded-visual.svelte-k1ijrm svg{display:block;width:100%;height:auto;max-width:100%}.collapsed-visual.svelte-k1ijrm{padding:12px 24px}}.panel.svelte-cr0cz1{display:flex;flex-direction:column;flex:1}.chord-hdr.svelte-cr0cz1{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px;background:var(--surface2);border-bottom:1px solid var(--border);gap:12px}.chord-left.svelte-cr0cz1{display:flex;flex-direction:column;gap:3px}.chord-name.svelte-cr0cz1{margin:0;font-size:40px;font-weight:900;letter-spacing:-.02em;line-height:1;color:var(--text)}.chord-sub.svelte-cr0cz1{font-size:12px;color:var(--text-muted)}.scale-suggestions.svelte-cr0cz1{display:flex;flex-direction:column;align-items:flex-end;gap:5px}.sc-label.svelte-cr0cz1{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.sc-chips.svelte-cr0cz1{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.sc-chip.svelte-cr0cz1{padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;background:#ffffff0d;border:1px solid transparent;color:var(--text-muted);transition:all .12s}.sc-chip.svelte-cr0cz1:hover{background:#ffffff1a;color:var(--text)}.sc-chip.active.svelte-cr0cz1{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.section.svelte-cr0cz1{padding:14px 16px;border-bottom:1px solid var(--border)}@container panel (min-width: 720px){.panel.svelte-cr0cz1{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);grid-template-rows:auto auto auto}.chord-hdr.svelte-cr0cz1{grid-column:1 / -1;grid-row:1;padding:22px 28px}.chord-name.svelte-cr0cz1{font-size:56px}.main-visual{grid-column:1 / -1;grid-row:2}.section.svelte-cr0cz1{padding:20px 24px;border-bottom:0}.section.svelte-cr0cz1+.section:where(.svelte-cr0cz1){border-left:1px solid var(--border)}}.chord-card.svelte-t61xvr{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;padding:10px 12px;border-radius:8px;background:#ffffff0d;border:1.5px solid transparent;min-width:90px;transition:all .12s;text-align:left}.chord-card.svelte-t61xvr:hover{background:#ffffff17}.chord-card.active.svelte-t61xvr{background:#4ade801a;border-color:#4ade80}.chord-card.tonic.svelte-t61xvr{box-shadow:inset 0 0 0 1px #60a5fa80}.chord-card.tension-light.svelte-t61xvr{background:#fb923c1a;border-color:#fb923ca6}.chord-card.tension-strong.svelte-t61xvr{background:#f871711f;border-color:#f87171bf}.chord-card.tension-light.active.svelte-t61xvr{border-color:#fb923c}.chord-card.tension-strong.active.svelte-t61xvr{border-color:#f87171}.card-fn.svelte-t61xvr{font-size:10px;font-weight:700;color:#ffffff59;letter-spacing:.05em;margin-bottom:2px}.root-badge.svelte-t61xvr{margin-bottom:4px;padding:2px 6px;border-radius:4px;background:#60a5fa24;border:1px solid rgba(96,165,250,.34);color:var(--blue);font-size:9px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;line-height:1}.card-name.svelte-t61xvr{font-size:18px;font-weight:900;color:#fff;line-height:1;margin-bottom:6px}.chord-card.active.svelte-t61xvr .card-name:where(.svelte-t61xvr){color:#4ade80}.chord-card.tension-light.svelte-t61xvr .card-name:where(.svelte-t61xvr),.chord-card.tension-light.active.svelte-t61xvr .card-name:where(.svelte-t61xvr){color:#fb923c}.chord-card.tension-strong.svelte-t61xvr .card-name:where(.svelte-t61xvr),.chord-card.tension-strong.active.svelte-t61xvr .card-name:where(.svelte-t61xvr){color:#f87171}.tension-hint.svelte-t61xvr{display:flex;gap:4px;align-items:center;margin:-2px 0 6px;font-size:10px;font-weight:800;color:#ffffffb8;white-space:nowrap}.card-notes.svelte-t61xvr{display:flex;flex-wrap:wrap;gap:3px}.dot.svelte-t61xvr{display:inline-block;width:20px;height:20px;line-height:20px;border-radius:50%;text-align:center;font-size:9px;font-weight:900;color:#000}.timing-panel.svelte-a5zrhw{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface2);display:flex;flex-direction:column;gap:12px}.timing-head.svelte-a5zrhw{display:flex;align-items:center;justify-content:space-between;gap:12px}.timing-kicker.svelte-a5zrhw{display:block;color:var(--text-muted);font-size:9px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}h2.svelte-a5zrhw{margin:2px 0 0;font-size:15px;font-weight:900}.transport.svelte-a5zrhw{padding:7px 13px;border-radius:var(--radius-sm);background:#4ade801a;border:1px solid rgba(74,222,128,.32);color:var(--green);font-size:12px;font-weight:900}.transport.playing.svelte-a5zrhw{background:#f871711f;border-color:#f8717166;color:var(--red)}.transport-controls.svelte-a5zrhw{display:grid;grid-template-columns:72px minmax(0,1fr);gap:8px;align-items:center}.tempo-control.svelte-a5zrhw{display:flex;flex-direction:column;gap:3px}.tempo-control.svelte-a5zrhw span:where(.svelte-a5zrhw),.row-controls.svelte-a5zrhw span:where(.svelte-a5zrhw){color:var(--text-muted);font-size:9px;font-weight:800;text-transform:uppercase}.tempo-control.svelte-a5zrhw input:where(.svelte-a5zrhw),.row-controls.svelte-a5zrhw input:where(.svelte-a5zrhw){width:100%;border-radius:var(--radius-sm);border:1px solid var(--border2);background:#ffffff0d;color:var(--text);padding:5px 6px;font-size:12px;font-weight:800}.tempo-slider.svelte-a5zrhw{accent-color:var(--green)}.meter-row.svelte-a5zrhw{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.meter-btn.svelte-a5zrhw{padding:6px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:11px;font-weight:900}.meter-btn.active.svelte-a5zrhw{background:var(--green-dim);border-color:#4ade8061;color:var(--green)}.timing-list.svelte-a5zrhw{display:flex;flex-direction:column;gap:8px}.timing-row.svelte-a5zrhw{padding:10px;border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffff08;display:flex;flex-direction:column;gap:9px}.timing-row.active.svelte-a5zrhw{border-color:#4ade8061;background:#4ade800e}.row-top.svelte-a5zrhw{display:flex;align-items:center;justify-content:space-between;gap:10px}.chord-name.svelte-a5zrhw{color:var(--text);font-size:16px;font-weight:900}.row-controls.svelte-a5zrhw{display:flex;align-items:end;gap:6px}.row-controls.svelte-a5zrhw label:where(.svelte-a5zrhw){width:58px;display:flex;flex-direction:column;gap:3px}.rest-btn.svelte-a5zrhw{padding:6px 8px;border-radius:var(--radius-sm);border:1px solid rgba(251,146,60,.28);background:#fb923c14;color:#fb923c;font-size:11px;font-weight:800}.grid-wrap.svelte-a5zrhw{overflow-x:auto;scrollbar-width:none}.grid-wrap.svelte-a5zrhw::-webkit-scrollbar{display:none}.step-grid.svelte-a5zrhw{display:grid;grid-template-columns:repeat(var(--steps),11px);grid-auto-rows:18px;grid-auto-flow:row;gap:3px;width:max-content}.step-cell.svelte-a5zrhw{width:11px;height:18px;border-radius:3px;background:#ffffff0e;border:1px solid rgba(255,255,255,.06)}.step-cell.beat.svelte-a5zrhw{border-left-color:#ffffff3d}.step-cell.bar.svelte-a5zrhw{border-left-color:var(--blue)}.step-cell.on.svelte-a5zrhw{background:var(--green);border-color:#4ade80e6}.row-meta.svelte-a5zrhw{display:flex;justify-content:space-between;gap:10px;color:var(--text-muted);font-size:10px;line-height:1.35}@media (min-width: 768px){.timing-panel.svelte-a5zrhw{padding:18px 24px}.timing-list.svelte-a5zrhw{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}}.voice-map.svelte-1c9c8sm{padding:12px 16px;border-bottom:1px solid var(--border);background:#ffffff05}.vm-head.svelte-1c9c8sm{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.vm-title.svelte-1c9c8sm{display:block;color:var(--text-muted);font-size:9px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.vm-route.svelte-1c9c8sm{display:block;margin-top:3px;color:var(--text);font-size:15px;font-weight:900}.resolve.svelte-1c9c8sm{flex-shrink:0;padding:4px 7px;border-radius:4px;background:#fb923c1f;border:1px solid rgba(251,146,60,.26);color:#fb923c;font-size:10px;font-weight:800}.vm-summary.svelte-1c9c8sm{margin:8px 0 0;color:var(--text-dim);font-size:11px;line-height:1.4}.common-row.svelte-1c9c8sm,.move-list.svelte-1c9c8sm{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}.common-label.svelte-1c9c8sm{color:var(--text-muted);font-size:10px;font-weight:800;align-self:center}.common-note.svelte-1c9c8sm,.move.svelte-1c9c8sm{border-radius:4px;border:1px solid var(--border);background:#ffffff0a}.common-note.svelte-1c9c8sm{padding:3px 7px;color:var(--blue);font-size:11px;font-weight:900}.move.svelte-1c9c8sm{display:inline-flex;align-items:center;gap:4px;padding:5px 7px;color:var(--text-dim);font-size:11px;font-weight:800}.move.common.svelte-1c9c8sm{border-color:#60a5fa42;color:var(--blue)}.move.step.svelte-1c9c8sm{border-color:#4ade803d;color:var(--green)}.move.leap.svelte-1c9c8sm{border-color:#fbbf2438;color:var(--yellow)}.move-arrow.svelte-1c9c8sm,.move-size.svelte-1c9c8sm{color:#ffffff6b}@media (min-width: 768px){.voice-map.svelte-1c9c8sm{padding:18px 20px;border-left:1px solid var(--border);border-bottom:0;overflow-y:auto}}.prog-panel.svelte-1w65cid{display:flex;flex-direction:column;flex:1}.scale-set.svelte-1w65cid{padding:10px 12px 9px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.scale-set-head.svelte-1w65cid{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.scale-set-title.svelte-1w65cid{font-size:12px;font-weight:800;color:var(--text);text-transform:capitalize}.scale-set-sub.svelte-1w65cid{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.scale-note-row.svelte-1w65cid{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}.scale-note-row.svelte-1w65cid::-webkit-scrollbar{display:none}.scale-note.svelte-1w65cid{flex-shrink:0;min-width:40px;padding:6px 8px;border-radius:var(--radius-sm);background:#fbbf2414;border:1px solid rgba(251,191,36,.18);display:flex;flex-direction:column;align-items:center;gap:2px}.scale-degree.svelte-1w65cid{font-size:9px;font-weight:800;color:#fbbf24a6;line-height:1}.scale-pitch.svelte-1w65cid{font-size:14px;font-weight:900;color:var(--yellow);line-height:1}.chord-strip-wrap.svelte-1w65cid{padding:10px 12px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:9px}.chord-strip.svelte-1w65cid{display:flex;gap:7px;overflow-x:auto;scrollbar-width:none}.chord-strip.svelte-1w65cid::-webkit-scrollbar{display:none}.roman-summary.svelte-1w65cid{display:flex;align-items:center;gap:7px}.roman-label.svelte-1w65cid{color:var(--text-muted);font-size:9px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.roman-row.svelte-1w65cid{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none}.roman-row.svelte-1w65cid::-webkit-scrollbar{display:none}.roman-token.svelte-1w65cid{flex-shrink:0;min-width:36px;padding:4px 8px;border-radius:4px;background:#ffffff0a;border:1px solid var(--border);color:var(--text-muted);font-size:11px;font-weight:900}.roman-token.active.svelte-1w65cid{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.active-ctx.svelte-1w65cid{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);gap:10px}.active-lbl.svelte-1w65cid{font-size:12px;color:var(--text-dim)}.active-lbl.svelte-1w65cid strong:where(.svelte-1w65cid){color:var(--text)}.sc-row.svelte-1w65cid{display:flex;gap:4px}.sc-chip.svelte-1w65cid{padding:3px 7px;border-radius:4px;font-size:10px;font-weight:600;background:#ffffff0d;border:1px solid transparent;color:var(--text-muted);transition:all .12s}.sc-chip.svelte-1w65cid:hover{background:#ffffff1a;color:var(--text)}.sc-chip.active.svelte-1w65cid{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.legend.svelte-1w65cid{padding:10px 16px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border);background:var(--surface2)}.legend-row.svelte-1w65cid{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-muted)}.ldot.svelte-1w65cid{width:8px;height:8px;border-radius:50%;flex-shrink:0}.breakdown.svelte-1w65cid{display:flex;flex-direction:column}.bd-row.svelte-1w65cid{display:flex;align-items:center;gap:14px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .12s;width:100%;text-align:left}.bd-row.svelte-1w65cid:hover{background:#ffffff08}.bd-row.active.svelte-1w65cid{background:#4ade800a}.bd-row.tonic.svelte-1w65cid{box-shadow:inset 3px 0 #60a5facc}.bd-row.tension-light.svelte-1w65cid{background:#fb923c0b}.bd-row.tension-strong.svelte-1w65cid{background:#f871710e}.bd-row.tension-light.active.svelte-1w65cid{background:#fb923c1a}.bd-row.tension-strong.active.svelte-1w65cid{background:#f871711f}.bd-left.svelte-1w65cid{display:flex;flex-direction:column;min-width:52px}.bd-fn.svelte-1w65cid{font-size:10px;color:var(--text-muted)}.bd-name.svelte-1w65cid{font-size:16px;font-weight:900;color:var(--text)}.bd-row.active.svelte-1w65cid .bd-name:where(.svelte-1w65cid){color:var(--green)}.bd-row.tonic.svelte-1w65cid .bd-name:where(.svelte-1w65cid),.bd-row.tonic.active.svelte-1w65cid .bd-name:where(.svelte-1w65cid){color:var(--blue)}.bd-row.tension-light.svelte-1w65cid .bd-name:where(.svelte-1w65cid),.bd-row.tension-light.active.svelte-1w65cid .bd-name:where(.svelte-1w65cid){color:#fb923c}.bd-row.tension-strong.svelte-1w65cid .bd-name:where(.svelte-1w65cid),.bd-row.tension-strong.active.svelte-1w65cid .bd-name:where(.svelte-1w65cid){color:#f87171}.bd-notes.svelte-1w65cid{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.bd-root.svelte-1w65cid{margin-top:2px;font-size:9px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#60a5fabf}.ct.svelte-1w65cid{font-size:11px;font-weight:700;color:#4ade80}.st.svelte-1w65cid{font-size:10px;color:#fbbf248c}.resolve-hint.svelte-1w65cid{padding:2px 7px;border-radius:4px;background:#fb923c1f;border:1px solid rgba(251,146,60,.24);font-size:10px;font-weight:700;color:#ffffffb8}@container panel (min-width: 720px){.prog-panel.svelte-1w65cid{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,340px);grid-template-rows:auto auto auto auto auto auto auto}.scale-set.svelte-1w65cid,.chord-strip-wrap.svelte-1w65cid,.active-ctx.svelte-1w65cid,.timing-panel,.main-visual{grid-column:1 / -1}.scale-set.svelte-1w65cid{padding:16px 24px 14px}.scale-note-row.svelte-1w65cid{flex-wrap:wrap;overflow:visible}.scale-note.svelte-1w65cid{min-width:48px}.chord-strip-wrap.svelte-1w65cid{padding:16px 24px}.chord-strip.svelte-1w65cid{flex-wrap:wrap;overflow:visible}.active-ctx.svelte-1w65cid{padding:12px 24px}.main-visual{grid-row:5}.legend.svelte-1w65cid{grid-column:2;grid-row:7;align-self:stretch;padding:18px 20px;border-left:1px solid var(--border);border-bottom:0}.voice-map{grid-column:2;grid-row:6;align-self:start;max-height:100%}.breakdown.svelte-1w65cid{grid-column:1;grid-row:6 / 8}.bd-row.svelte-1w65cid{padding:14px 24px}}.card.svelte-zba2wk{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:9px;transition:border-color .15s}.card.svelte-zba2wk:hover{border-color:var(--border2)}.card-meta.svelte-zba2wk{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.exp-badge.svelte-zba2wk{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--exp-clr)}.exp-dot.svelte-zba2wk{width:6px;height:6px;border-radius:50%;background:var(--exp-clr)}.style-tag.svelte-zba2wk{font-size:10px;padding:2px 7px;border-radius:4px;background:var(--style-bg);color:var(--text-dim)}.scale-tag.svelte-zba2wk{margin-left:auto;font-size:10px;padding:2px 7px;border-radius:4px;background:#ffffff0d;color:var(--text-muted);white-space:nowrap}.card-name.svelte-zba2wk{margin:0;font-size:16px;font-weight:800;color:var(--text);line-height:1.25}.card-desc.svelte-zba2wk{margin:0;font-size:13px;color:var(--text-dim);line-height:1.55}.tip-block.svelte-zba2wk{display:flex;gap:8px;align-items:flex-start;background:#4ade800f;border-left:2px solid rgba(74,222,128,.4);border-radius:0 6px 6px 0;padding:8px 10px}.tip-icon.svelte-zba2wk{font-size:13px;flex-shrink:0}.tip-text.svelte-zba2wk{margin:0;font-size:12px;color:var(--text-dim);line-height:1.5}.context.svelte-zba2wk{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.ctx-label.svelte-zba2wk{font-size:10px;color:var(--text-muted)}.ctx-tag.svelte-zba2wk{font-size:10px;padding:2px 6px;border-radius:4px;background:#ffffff0d;color:var(--text-muted)}.card-actions.svelte-zba2wk{display:flex;gap:6px}.action-btn.svelte-zba2wk{flex:1;padding:7px 12px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;transition:all .12s;border:1px solid transparent}.play-btn.svelte-zba2wk{background:#4ade801a;border-color:#4ade8040;color:var(--green)}.play-btn.svelte-zba2wk:hover:not(:disabled){background:#4ade8033;border-color:#4ade8080}.play-btn.svelte-zba2wk:disabled{opacity:.6;cursor:default}.play-btn.is-playing.svelte-zba2wk{background:#4ade802e;animation:svelte-zba2wk-pulse 1s ease-in-out infinite}@keyframes svelte-zba2wk-pulse{0%,to{opacity:1}50%{opacity:.65}}.show-btn.svelte-zba2wk{background:#ffffff0d;border-color:var(--border);color:var(--text-muted)}.show-btn.svelte-zba2wk:hover{background:#ffffff1a;color:var(--text-dim)}.show-btn.active.svelte-zba2wk{background:#ffffff17;color:var(--text-dim)}.fretboard-wrap.svelte-zba2wk{margin-top:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 8px 6px;display:flex;flex-direction:column;align-items:center;gap:6px;overflow-x:auto}.fb-legend.svelte-zba2wk{margin:0;font-size:10px;color:var(--text-muted);display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}.fb-dot.svelte-zba2wk{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.fb-dot.root.svelte-zba2wk{background:#4ade80}.fb-dot.scale.svelte-zba2wk{background:#fbbf24}.box-panel.svelte-bsqn3w{display:flex;flex-direction:column;background:var(--surface2);border-bottom:1px solid var(--border)}.box-header.svelte-bsqn3w{padding:12px 16px 10px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.box-title-row.svelte-bsqn3w{display:flex;align-items:center;gap:8px}.box-title.svelte-bsqn3w{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.scale-badge.svelte-bsqn3w{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--green-dim);color:var(--green)}.no-positions.svelte-bsqn3w{margin:0;font-size:12px;color:var(--text-muted)}.pos-tabs.svelte-bsqn3w{display:flex;gap:5px;align-items:center}.pos-tab.svelte-bsqn3w{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid transparent;font-size:12px;font-weight:700;color:var(--text-muted);transition:all .12s;white-space:nowrap}.pos-tab.svelte-bsqn3w:hover{background:#ffffff17;color:var(--text)}.pos-tab.active.svelte-bsqn3w{background:var(--green-dim);border-color:#4ade8059;color:var(--green)}.pos-num.svelte-bsqn3w{font-size:13px}.pos-deg.svelte-bsqn3w{font-size:10px;font-weight:600;opacity:.8}.play-btn.svelte-bsqn3w{margin-left:auto;padding:5px 12px;border-radius:var(--radius-sm);background:#4ade801f;border:1px solid rgba(74,222,128,.3);color:var(--green);font-size:11px;font-weight:700;transition:all .12s}.play-btn.svelte-bsqn3w:hover{background:#4ade8038}.fretboard-wrap.svelte-bsqn3w{padding:10px 16px 6px;background:var(--bg);overflow-x:auto;display:flex;justify-content:center}.pos-info.svelte-bsqn3w{padding:10px 16px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--border);background:var(--surface)}.info-row.svelte-bsqn3w{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-muted)}.legend-dot.svelte-bsqn3w{width:9px;height:9px;border-radius:50%;flex-shrink:0}.legend-dot.root.svelte-bsqn3w{background:#4ade80}.legend-dot.scale.svelte-bsqn3w{background:#fbbf24}.fret-range.svelte-bsqn3w{margin-top:2px}.fret-tag.svelte-bsqn3w{font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;background:#4ade801f;color:var(--green)}.pos-nav.svelte-bsqn3w{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border)}.nav-btn.svelte-bsqn3w{padding:6px 14px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-dim);transition:all .12s}.nav-btn.svelte-bsqn3w:hover:not(:disabled){background:#ffffff1a;color:var(--text)}.nav-btn.svelte-bsqn3w:disabled{opacity:.3;cursor:default}.nav-pips.svelte-bsqn3w{display:flex;gap:6px;align-items:center}.pip.svelte-bsqn3w{width:8px;height:8px;border-radius:50%;background:#ffffff26;border:1px solid transparent;transition:all .15s;padding:0}.pip.active.svelte-bsqn3w{background:var(--green);width:20px;border-radius:4px}.pip.svelte-bsqn3w:hover:not(.active){background:#ffffff4d}.tips-block.svelte-bsqn3w{display:flex;gap:8px;align-items:flex-start;padding:10px 16px 14px;border-top:1px solid var(--border)}.tip-icon.svelte-bsqn3w{font-size:13px;flex-shrink:0}.tips-text.svelte-bsqn3w{display:flex;flex-direction:column;gap:3px}.tips-text.svelte-bsqn3w p:where(.svelte-bsqn3w){margin:0;font-size:11px;color:var(--text-muted);line-height:1.5}.tips-text.svelte-bsqn3w strong:where(.svelte-bsqn3w){color:var(--text-dim)}@media (min-width: 768px){.box-panel.svelte-bsqn3w{min-width:0;border-right:1px solid var(--border)}.box-header.svelte-bsqn3w{padding:14px 24px 12px}.fretboard-wrap.svelte-bsqn3w{padding:14px 24px 8px;overflow:hidden}.fretboard-wrap.svelte-bsqn3w svg{width:min(100%,720px);height:auto}.pos-info.svelte-bsqn3w,.pos-nav.svelte-bsqn3w,.tips-block.svelte-bsqn3w{padding-left:24px;padding-right:24px}}.solo-panel.svelte-1gffc8t{display:flex;flex-direction:column;flex:1}.scale-set.svelte-1gffc8t{padding:10px 12px 9px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.scale-set-head.svelte-1gffc8t{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.scale-set-title.svelte-1gffc8t{font-size:12px;font-weight:800;color:var(--text);text-transform:capitalize}.scale-set-sub.svelte-1gffc8t{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.scale-note-row.svelte-1gffc8t{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}.scale-note-row.svelte-1gffc8t::-webkit-scrollbar{display:none}.scale-note.svelte-1gffc8t{flex-shrink:0;min-width:40px;padding:6px 8px;border-radius:var(--radius-sm);background:#fbbf2414;border:1px solid rgba(251,191,36,.18);display:flex;flex-direction:column;align-items:center;gap:2px}.scale-degree.svelte-1gffc8t{font-size:9px;font-weight:800;color:#fbbf24a6;line-height:1}.scale-pitch.svelte-1gffc8t{font-size:14px;font-weight:900;color:var(--yellow);line-height:1}.sliders.svelte-1gffc8t{padding:14px 16px;display:flex;flex-direction:column;gap:14px;background:var(--surface2);border-bottom:1px solid var(--border)}.slider-row.svelte-1gffc8t{display:flex;flex-direction:column;gap:5px}.slider-info.svelte-1gffc8t{display:flex;justify-content:space-between}.sl-name.svelte-1gffc8t{font-size:11px;font-weight:600;color:var(--text-dim)}.sl-val.svelte-1gffc8t{font-size:11px;font-weight:700}.slider.svelte-1gffc8t{width:100%;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none;cursor:pointer}.slider.svelte-1gffc8t::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;cursor:pointer;box-shadow:0 0 0 3px #0006}.green-thumb.svelte-1gffc8t::-webkit-slider-thumb{background:#4ade80}.yellow-thumb.svelte-1gffc8t::-webkit-slider-thumb{background:#fbbf24}.sl-ends.svelte-1gffc8t{display:flex;justify-content:space-between;font-size:9px;color:var(--text-muted)}.pattern-count.svelte-1gffc8t{padding:7px 16px;font-size:10px;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface)}.cards.svelte-1gffc8t{display:flex;flex-direction:column;gap:8px;padding:12px 16px}.empty.svelte-1gffc8t{text-align:center;padding:32px;color:var(--text-muted);font-size:13px}@container panel (min-width: 720px){.solo-panel.svelte-1gffc8t{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,380px);grid-template-rows:auto auto auto auto auto}.scale-set.svelte-1gffc8t{grid-column:1 / -1;padding:16px 24px 14px}.scale-note-row.svelte-1gffc8t{flex-wrap:wrap;overflow:visible}.scale-note.svelte-1gffc8t{min-width:48px}.main-visual{grid-column:1 / -1;grid-row:2}.sliders.svelte-1gffc8t{grid-column:2;grid-row:3 / span 2;padding:18px 20px;border-left:1px solid var(--border)}.pattern-count.svelte-1gffc8t{grid-column:1;grid-row:4;padding:10px 24px}.cards.svelte-1gffc8t{grid-column:1 / -1;grid-row:5;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));align-content:start;padding:18px 24px}}.melody-panel.svelte-u38aef{display:flex;flex-direction:column;flex:1}.scale-set.svelte-u38aef{padding:10px 12px 9px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.scale-set-head.svelte-u38aef{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.scale-set-title.svelte-u38aef{font-size:12px;font-weight:800;color:var(--text);text-transform:capitalize}.scale-set-sub.svelte-u38aef{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.scale-note-row.svelte-u38aef{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}.scale-note-row.svelte-u38aef::-webkit-scrollbar{display:none}.scale-note.svelte-u38aef{flex-shrink:0;min-width:40px;padding:6px 8px;border-radius:var(--radius-sm);background:#fbbf2414;border:1px solid rgba(251,191,36,.18);display:flex;flex-direction:column;align-items:center;gap:2px}.scale-degree.svelte-u38aef{font-size:9px;font-weight:800;color:#fbbf24a6;line-height:1}.scale-pitch.svelte-u38aef{font-size:14px;font-weight:900;color:var(--yellow);line-height:1}.phrase-list.svelte-u38aef{display:flex;flex-direction:column;gap:10px;padding:12px 16px}.phrase-card.svelte-u38aef{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:12px}.phrase-head.svelte-u38aef{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.phrase-head.svelte-u38aef h2:where(.svelte-u38aef){margin:0 0 4px;font-size:16px;font-weight:900}.phrase-head.svelte-u38aef p:where(.svelte-u38aef){margin:0;font-size:12px;color:var(--text-muted);line-height:1.45}.play-btn.svelte-u38aef{flex-shrink:0;padding:7px 12px;border-radius:var(--radius-sm);background:#4ade801a;border:1px solid rgba(74,222,128,.3);color:var(--green);font-size:11px;font-weight:800}.play-btn.svelte-u38aef:disabled{opacity:.55;cursor:default}.play-btn.playing.svelte-u38aef{background:#4ade802e}.phrase-bars.svelte-u38aef{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.phrase-bar.svelte-u38aef{min-width:132px;flex-shrink:0;padding:10px;border-radius:var(--radius-md);background:#ffffff09;border:1px solid var(--border)}.bar-chord.svelte-u38aef{display:block;margin-bottom:8px;font-size:14px;font-weight:900;color:var(--text-dim)}.bar-notes.svelte-u38aef{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.mel-note.svelte-u38aef{min-width:0;aspect-ratio:1;border-radius:50%;background:var(--note-color);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#070710}.note-degree.svelte-u38aef{font-size:7px;font-weight:800;line-height:1;opacity:.72}.note-pitch.svelte-u38aef{font-size:10px;font-weight:900;line-height:1.1}.phrase-tip.svelte-u38aef{margin:0;padding:8px 10px;border-left:2px solid rgba(74,222,128,.45);background:#4ade800e;border-radius:0 6px 6px 0;color:var(--text-dim);font-size:12px;line-height:1.45}.legend.svelte-u38aef{padding:12px 16px;display:grid;grid-template-columns:1fr;gap:7px;border-top:1px solid var(--border)}.lg-row.svelte-u38aef{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-muted)}.lg-dot.svelte-u38aef{width:9px;height:9px;border-radius:50%;flex-shrink:0}@container panel (min-width: 720px){.melody-panel.svelte-u38aef{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:auto auto auto auto}.scale-set.svelte-u38aef{grid-row:1;padding:16px 24px 14px}.main-visual{grid-row:2}.scale-note-row.svelte-u38aef{flex-wrap:wrap;overflow:visible}.scale-note.svelte-u38aef{min-width:48px}.phrase-list.svelte-u38aef{grid-row:3;padding:18px 24px}.phrase-bars.svelte-u38aef{overflow:visible;flex-wrap:wrap}.legend.svelte-u38aef{grid-row:4;grid-template-columns:repeat(3,max-content);justify-content:center;gap:14px;padding:14px 20px;background:var(--surface2);border-top:1px solid var(--border)}}@container panel (min-width: 1100px){.phrase-list.svelte-u38aef{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:12px;align-content:start}}.bass-line-card.svelte-1wsuskn{display:flex;gap:6px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none}.bass-line-card.svelte-1wsuskn::-webkit-scrollbar{display:none}.bar.svelte-1wsuskn{flex-shrink:0;background:#ffffff0a;border-radius:8px;padding:10px;min-width:140px}.bar-chord.svelte-1wsuskn{font-size:14px;font-weight:900;color:#fff9;margin-bottom:8px;letter-spacing:.02em}.bar-notes.svelte-1wsuskn{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.beat.svelte-1wsuskn{display:flex;flex-direction:column;align-items:center;gap:3px}.note-dot.svelte-1wsuskn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.note-pitch.svelte-1wsuskn{font-size:11px;font-weight:900;color:#000}.note-fret.svelte-1wsuskn{font-size:10px;font-weight:700;color:#ffffffa6}.rest-dot.svelte-1wsuskn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:#ffffff1f;font-size:14px}.beat-label.svelte-1wsuskn{font-size:9px;color:#fff3}@container panel (min-width: 720px){.bass-line-card.svelte-1wsuskn{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));overflow:visible;gap:10px}.bar.svelte-1wsuskn{min-width:0}}.bass-panel.svelte-1mintql{display:flex;flex-direction:column;flex:1}.style-section.svelte-1mintql{padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface2)}.style-list.svelte-1mintql{display:flex;flex-direction:column;gap:5px}.style-btn.svelte-1mintql{display:flex;flex-direction:column;gap:3px;padding:10px 12px;border-radius:var(--radius-md);background:#ffffff0a;border:1px solid transparent;text-align:left;transition:all .12s}.style-btn.svelte-1mintql:hover{background:#ffffff12}.style-btn.active.svelte-1mintql{background:var(--green-dim);border-color:#4ade804d}.sb-top.svelte-1mintql{display:flex;align-items:center;gap:8px}.sb-label.svelte-1mintql{font-size:13px;font-weight:700;color:var(--text)}.style-btn.active.svelte-1mintql .sb-label:where(.svelte-1mintql){color:var(--green)}.sb-active-dot.svelte-1mintql{width:6px;height:6px;border-radius:50%;background:var(--green)}.sb-desc.svelte-1mintql{font-size:12px;color:var(--text-muted)}.line-section.svelte-1mintql{padding:14px 16px;border-bottom:1px solid var(--border)}.line-head.svelte-1mintql{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.line-head.svelte-1mintql .section-title:where(.svelte-1mintql){margin-bottom:0}.play-btn.svelte-1mintql{flex-shrink:0;padding:7px 12px;border-radius:var(--radius-sm);background:#4ade801a;border:1px solid rgba(74,222,128,.3);color:var(--green);font-size:11px;font-weight:800}.play-btn.playing.svelte-1mintql{background:#4ade802e}.line-hint.svelte-1mintql{font-size:10px;color:var(--text-muted);text-align:center;margin:5px 0 0}.legend.svelte-1mintql{padding:12px 16px;display:grid;grid-template-columns:1fr 1fr;gap:7px}.lg-row.svelte-1mintql{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-muted)}.lg-dot.svelte-1mintql{width:9px;height:9px;border-radius:50%;flex-shrink:0}@container panel (min-width: 720px){.bass-panel.svelte-1mintql{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);grid-template-rows:auto auto auto}.main-visual{grid-column:1 / -1;grid-row:1}.style-section.svelte-1mintql{grid-column:1;grid-row:2;padding:18px 20px;border-right:1px solid var(--border);border-bottom:0}.line-section.svelte-1mintql{grid-column:2;grid-row:2;padding:18px 24px}.legend.svelte-1mintql{grid-column:1 / -1;grid-row:3;grid-template-columns:repeat(6,max-content);justify-content:center;gap:14px;border-top:1px solid var(--border)}}.app.svelte-1n46o8q{display:flex;flex-direction:column;max-width:480px;margin:0 auto;background:var(--bg);padding-bottom:calc(56px + env(safe-area-inset-bottom))}.workspace.svelte-1n46o8q{display:flex;flex-direction:column}.desktop-nav.svelte-1n46o8q{display:none}.controls.svelte-1n46o8q{flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border)}.app-main.svelte-1n46o8q{display:flex;flex-direction:column}.mobile-tabs.svelte-1n46o8q{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;z-index:20;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}@media (min-width: 768px){.app.svelte-1n46o8q{width:100%;max-width:none;height:100vh;height:100dvh;overflow:hidden;padding-bottom:0;background:linear-gradient(180deg,var(--surface) 0,var(--bg) 72px)}.workspace.svelte-1n46o8q{display:grid;grid-template-columns:164px minmax(280px,336px) minmax(0,1fr);gap:0;width:min(100%,1440px);margin:0 auto;flex:1;min-height:0;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--bg)}.desktop-nav.svelte-1n46o8q{display:block;min-height:0;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}.controls.svelte-1n46o8q{min-height:0;overflow-y:auto;border-right:1px solid var(--border);border-bottom:0}.app-main.svelte-1n46o8q{min-width:0;overflow-y:auto;background:var(--bg);container-type:inline-size;container-name:panel}.mobile-tabs.svelte-1n46o8q{display:none}}
