:root{--bg-color: #1a1a1a;--text-color: #f0f0f0;--card-bg: #2d2d2d;--border-color: #444;--keyboard-bg: #333;--white-key-bg: #f0f0f0;--black-key-bg: #2d2d2d;--white-key-text: #333;--black-key-text: #fff;--active-white-key: #d0d0d0;--active-black-key: #222;--button-bg: #4a90e2;--button-text: #fff;--button-hover: #357abd;--error-color: #e74c3c;--success-color: #2ecc71;--shadow-color: rgba(0,0,0,.5);--transition-speed: .3s;--section-bg: #2d2d2d;--input-bg: #333;--select-bg: #333;--launchpad-layout-tooltip: #aaa;--sound-generator-bg: #333;--grid-bg: #1a1a1a;--midi-note-map-bg: #333;--table-row-bg: #333;--color-settings-bg: #2d2d2d;--json-editor-bg: #2d2d2d;--json-editor-textarea-bg: #333;--json-error-bg: #3a1a1a;--key-border-color: #666;--color-picker-bg: #2d2d2d;--color-picker-border: #444;--color-picker-shadow: rgba(0, 0, 0, .3)}[data-theme=light]{--bg-color: #f5f5f5;--text-color: #333;--card-bg: #fff;--border-color: #ddd;--keyboard-bg: #f0f0f0;--white-key-bg: #fff;--black-key-bg: #ebebeb;--white-key-text: #333;--black-key-text: #fff;--active-white-key: #e0e0e0;--active-black-key: #555;--button-bg: #4a90e2;--button-text: #fff;--button-hover: #357abd;--section-bg: #f9f9f9;--input-bg: #fff;--select-bg: #fff;--launchpad-layout-tooltip: #666;--sound-generator-bg: #f5f5f5;--grid-bg: #1a1a1a;--midi-note-map-bg: #f5f5f5;--shadow-color: rgba(223, 223, 223, .5);--table-row-bg: #f5f5f5;--color-settings-bg: #fff;--json-editor-bg: #fff;--json-editor-textarea-bg: #fff;--json-error-bg: #ffebee;--key-border-color: #999;--color-picker-bg: #fff;--color-picker-border: #ddd;--color-picker-shadow: rgba(0, 0, 0, .1)}html{height:100%;margin:0;padding:0;background-color:var(--bg-color)}body{margin:0;padding:0;min-height:100vh;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color);transition:background-color var(--transition-speed),color var(--transition-speed);display:flex;justify-content:center}button,.btn{font:inherit;font-size:.85rem;line-height:1.1;cursor:pointer;background:var(--button-bg);color:var(--button-text);border:1px solid var(--button-bg);border-radius:4px;padding:.5rem .9rem;display:inline-flex;align-items:center;gap:.4rem}button.small,.btn.small{padding:.35rem .55rem;font-size:.7rem}h1,h2,h3,h4{margin:0 0 .5rem;font-weight:600;line-height:1.2}h1{font-size:1.4rem}h2,h3,h4{font-size:1rem}.panel{padding:15px;background:var(--section-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px var(--shadow-color)}.action{all:unset}button:hover{background-color:var(--button-hover)}button:disabled{background-color:#ccc;cursor:not-allowed}label{display:block;margin-bottom:8px;color:var(--text-color)}input{background:var(--input-bg);height:18px;color:var(--text-color);border:1px solid var(--border-color);border-radius:4px;padding:4px 10px;font-size:12px}select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--select-bg);color:var(--text-color);font-size:14px}input[type=radio]{cursor:pointer}input[type=range]{padding:0}label>input[type=radio]{cursor:pointer}.json-editor.svelte-faw06k{margin-top:10px}.json-editor.svelte-faw06k textarea:where(.svelte-faw06k){width:100%;height:300px;padding:10px;font-family:monospace;font-size:14px;background-color:var(--json-editor-textarea-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:4px;resize:vertical}.json-error.svelte-faw06k{margin-top:10px;padding:10px;background-color:var(--json-error-bg);color:var(--error-color);border-radius:4px}.sound-generator.svelte-z1o6l1{background:var(--section-bg);padding:20px;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color)}.control-grid.svelte-z1o6l1{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.sound-control-group.svelte-z1o6l1{display:flex;flex-direction:column;gap:8px}.value-display.svelte-z1o6l1{font-size:14px;color:var(--launchpad-layout-tooltip)}.note-input.svelte-qf2vfi{width:32px;height:18px;padding:4px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--input-bg);color:var(--text-color);font-family:monospace;font-size:14px;text-align:right}.note-button.svelte-qf2vfi{font-size:12px;color:var(--text-color);text-shadow:0 1px 2px var(--shadow-color);font-weight:500;background:none;border:none;padding:0;margin:0;cursor:pointer}.note-input.invalid-input.svelte-qf2vfi{border-color:#ff6b6b;background-color:#ff6b6b1a}.note-stepper.svelte-qf2vfi{display:flex;flex-direction:row}.steppers.svelte-qf2vfi{display:flex;flex-direction:column;margin-left:3px}.note-stepper.svelte-qf2vfi button:where(.svelte-qf2vfi){padding:0;width:16px;height:14px;font-size:10px;display:flex;align-items:center;justify-content:center;background:var(--button-bg);border:none;cursor:pointer;color:#fff}.note-stepper.svelte-qf2vfi button:where(.svelte-qf2vfi):first-child{border-radius:2px 2px 0 0}.note-stepper.svelte-qf2vfi button:where(.svelte-qf2vfi):last-child{border-radius:0 0 2px 2px}.note-stepper.svelte-qf2vfi button:where(.svelte-qf2vfi):hover{background:var(--button-hover)}.transposer.svelte-bgplju{background:var(--section-bg);border:1px solid var(--border-color);border-radius:8px;padding:12px}.column.svelte-bgplju{display:flex;flex-direction:column;gap:16px}.group.svelte-bgplju{display:flex;flex-direction:column;gap:6px;min-width:240px}.label.svelte-bgplju{font-size:.8rem}.transpose-compact.svelte-bgplju{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px}.transpose-input.svelte-bgplju{display:flex;align-items:center;gap:6px}.offset.svelte-bgplju{font-size:.85rem;opacity:.8;min-width:32px;text-align:right}.bend.svelte-bgplju{width:100%}.transpose-note{font-size:16px}.value-display.svelte-bgplju{font-size:14px;color:var(--launchpad-layout-tooltip)}.octave-controls.svelte-bgplju{display:flex;gap:6px}.inline.svelte-bgplju{display:flex;align-items:center;gap:6px;font-size:.8rem}.floating-color-picker.svelte-6kpwqe{background:var(--color-picker-bg);border:1px solid var(--color-picker-border);border-radius:8px;padding:15px;box-shadow:0 4px 12px var(--color-picker-shadow);z-index:9999;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.color-search.svelte-6kpwqe{width:100%;box-sizing:border-box;padding:15px 12px;border:1px solid var(--border-color);border-radius:4px;outline:none;background-color:var(--input-bg);color:var(--text-color);margin-bottom:10px;font-size:14px}.color-grid.svelte-6kpwqe{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin:10px 0;background:var(--card-bg);border-radius:4px}.inner.svelte-6kpwqe{padding:5px}.color-option.svelte-6kpwqe:hover{transform:scale(1.1);z-index:1}.color-option.selected.svelte-6kpwqe{border:2px solid var(--text-color);box-shadow:0 0 0 1px var(--border-color)}.color-option.svelte-6kpwqe{width:40px;height:40px;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;font-family:monospace;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8);transition:transform .1s ease}.color-button-container.svelte-1jry7k6{display:inline-block}.color-preview.svelte-1jry7k6{width:24px;height:24px;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color);font-size:12px}.color-settings.svelte-1tw9hbl{display:flex;justify-content:center;width:100%}.panel.svelte-1tw9hbl{background:var(--section-bg);border:1px solid var(--border-color);border-radius:8px;padding:15px;display:flex;flex-direction:column;align-items:center;gap:15px;width:100%}.table-container.svelte-1tw9hbl{width:100%;max-width:300px;margin:0 auto}.color-settings-table.svelte-1tw9hbl{width:100%;border-collapse:collapse}.color-settings-table.svelte-1tw9hbl th:where(.svelte-1tw9hbl),.color-settings-table.svelte-1tw9hbl td:where(.svelte-1tw9hbl){padding:8px;text-align:center;border-bottom:1px solid var(--border-color)}.color-settings-table.svelte-1tw9hbl th:where(.svelte-1tw9hbl){font-weight:500;color:var(--text-color)}.color-settings-table.svelte-1tw9hbl td:where(.svelte-1tw9hbl):first-child{text-align:right;padding-right:15px}.single-color-toggle.svelte-1tw9hbl{margin-top:5px}.single-color-toggle.svelte-1tw9hbl label:where(.svelte-1tw9hbl){display:flex;align-items:center;gap:8px;cursor:pointer}.theme-toggle.svelte-rp2z9x{position:absolute;top:20px;right:20px;background:none;border:none;cursor:pointer;font-size:24px;color:var(--text-color);display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;transition:background-color var(--transition-speed);z-index:1000;padding:0;line-height:1;box-shadow:0 2px 5px #0003}.theme-toggle.svelte-rp2z9x:hover{background-color:#0000001a;transform:scale(1.1)}.grid-keyboard-container.svelte-1kgguhk{display:flex;flex-direction:column;align-items:center;width:100%;margin:20px 0}.grid-keyboard.svelte-1kgguhk{display:flex;flex-direction:column;gap:8px;padding:24px;background-color:var(--grid-bg);border:1px solid var(--border-color);border-radius:12px;max-width:600px;margin:0 auto;box-shadow:0 4px 12px var(--shadow-color)}.grid-keyboard-container.svelte-1kgguhk{overflow-x:auto}.below-grid.svelte-1kgguhk{max-width:600px;width:100%;margin:8px auto 0;display:flex;flex-direction:column;gap:8px;align-items:stretch}.below-controls.svelte-1kgguhk{display:flex;justify-content:center}.grid-container.svelte-1kgguhk{display:flex;flex-direction:column;gap:8px}.grid-row.svelte-1kgguhk{display:flex;gap:8px;justify-content:center}.grid-cell.svelte-1kgguhk{width:56px;height:56px;border:none;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;position:relative;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0003}.grid-cell.special.svelte-1kgguhk{outline:2px dashed var(--border-color)}.grid-cell.disabled.svelte-1kgguhk{pointer-events:none;opacity:.5}.grid-cell.svelte-1kgguhk:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.grid-cell.active.svelte-1kgguhk{transform:translateY(2px);box-shadow:0 1px 2px #0000004d}.cell-content.svelte-1kgguhk{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.mapping-label.svelte-1kgguhk{font-size:.7rem;font-weight:500;max-width:52px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:none}.mapping-label.unmapped.svelte-1kgguhk{opacity:.4}.grid-editor.svelte-1kgguhk{padding:.6rem .7rem;border:1px solid var(--border-color);border-radius:8px;background:var(--card-bg);display:flex;flex-direction:column;gap:.5rem}.editor-row.svelte-1kgguhk{display:flex;align-items:center;gap:.5rem}.editor-row.svelte-1kgguhk>label:where(.svelte-1kgguhk){min-width:90px;text-align:right}.editor-actions.svelte-1kgguhk{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.editor-buttons.svelte-1kgguhk{display:flex;gap:.5rem}.pb-readout.svelte-1kgguhk{font-size:.8rem;opacity:.8;min-width:60px;text-align:right}.layout-generator.svelte-k94v3o{padding:.75rem .85rem}.row.svelte-k94v3o{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.panel-element.svelte-k94v3o{display:flex;gap:6px;align-items:center}.panel-element.svelte-k94v3o input:where(.svelte-k94v3o){width:70px}.btn.svelte-k94v3o{white-space:nowrap}.advanced-row.svelte-k94v3o{margin-top:.6rem;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.subtitle.svelte-k94v3o{font-size:.8rem;opacity:.8;margin-right:4px}.layout-manager.svelte-e4lt8n{display:flex;flex-direction:column;gap:10px}.save-row.svelte-e4lt8n{display:flex;gap:8px;align-items:center}.chip-list.svelte-e4lt8n{display:flex;gap:8px;flex-wrap:wrap}.chip.svelte-e4lt8n{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-color);cursor:pointer}.chip.svelte-e4lt8n{border:1px solid var(--border-color);background:var(--card-bg)}.chip.svelte-e4lt8n,.chip.svelte-e4lt8n :where(.svelte-e4lt8n){font:inherit}.chip.svelte-e4lt8n button:where(.svelte-e4lt8n){background:transparent;border:none;color:inherit;cursor:pointer}.chip.svelte-e4lt8n .name:where(.svelte-e4lt8n){font-weight:500}.chip.svelte-e4lt8n .close:where(.svelte-e4lt8n){margin-left:6px;opacity:.8}.chip.svelte-e4lt8n .close:where(.svelte-e4lt8n):hover{opacity:1}.small.svelte-e4lt8n{padding:2px 6px;font-size:.7rem}.editing.svelte-e4lt8n{display:inline-flex;gap:6px;align-items:center;padding:4px 8px;border-radius:6px;border:1px solid var(--border-color);background:var(--card-bg)}.rename.svelte-e4lt8n{padding:2px 6px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color)}input[type=text].svelte-e4lt8n{padding:4px 8px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-color);border-radius:4px}.empty.svelte-e4lt8n{color:var(--text-color);opacity:.7;font-size:.9em}.error.svelte-e4lt8n{color:#ff6b6b;font-size:.9em}.App.svelte-i34dpe{width:100%;max-width:1000px;margin:0 auto 3rem;padding:0 1rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.App-header.svelte-i34dpe{background:var(--card-bg);padding:1rem;display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border-color);border-radius:0 0 8px 8px}.section.svelte-i34dpe{background:var(--section-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1rem 1.15rem;display:flex;flex-direction:column;gap:1rem;max-width:100%}label.svelte-i34dpe{font-size:.8rem;font-weight:500;margin:0;display:flex;align-items:center;gap:.4rem}input.svelte-i34dpe,select.svelte-i34dpe{font-size:.8rem}input[type=number].svelte-i34dpe{width:90px}.device-selector.svelte-i34dpe{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));align-items:end}.device-group.svelte-i34dpe{display:flex;flex-direction:column;gap:.4rem}.device-brightness.svelte-i34dpe{display:flex;align-items:center;gap:.75rem}#brightness.svelte-i34dpe{flex:1}.brightness-value.svelte-i34dpe{font-size:.7rem;min-width:28px;text-align:right;opacity:.75}.device-controls.svelte-i34dpe{display:flex;gap:.6rem;flex-wrap:wrap}.settings-grid.svelte-i34dpe{display:grid;gap:1rem;grid-template-columns:1fr;width:100%}.settings-card.svelte-i34dpe{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;padding:.85rem .95rem .95rem;display:flex;flex-direction:column;gap:.55rem}.radio-group.svelte-i34dpe{display:flex;flex-direction:column;gap:.35rem}.sax-ignore.svelte-i34dpe{display:flex;flex-direction:column;gap:.45rem}.sax-ignore.svelte-i34dpe .inline-label:where(.svelte-i34dpe){font-size:.7rem}.layouts-flex-column.svelte-i34dpe{display:flex;flex-direction:column;gap:1rem}.layouts-tools.svelte-i34dpe{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.tool-card.svelte-i34dpe{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;padding:.85rem}.json-editor textarea{max-width:100%;box-sizing:border-box;font-size:.8rem;line-height:1.2rem}@media (max-width:600px){.json-editor textarea{height:220px}}.color-settings-table{font-size:.7rem}.color-settings-table th,.color-settings-table td{padding:6px}input[type=range].svelte-i34dpe{width:100%}.svelte-i34dpe:focus-visible{outline:2px solid var(--button-bg);outline-offset:2px}.no-devices-detected.svelte-i34dpe{font-size:.75rem;opacity:.8;margin:0}@media (min-width: 640px){.settings-grid.svelte-i34dpe{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}}
