/*! 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-muted);transition:color .15s;position:relative}.tab.svelte-1nx8sae:hover{color:var(--text-dim)}.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}}.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}.panel-loading.svelte-1n46o8q{flex:1;min-height:120px}.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 (max-width: 767px) and (orientation: landscape){.app.svelte-1n46o8q{max-width:none;width:100%}.mobile-tabs.svelte-1n46o8q{max-width:none;width:100%;margin:0}}@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}}
