@font-face{font-family:iAWriterDuoS;src:url(./iAWriterDuoS-Regular-CW_LHp8r.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:iAWriterDuoS;src:url(./iAWriterDuoS-Bold-BR5v5URg.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:iAWriterMonoS;src:url(./iAWriterMonoS-Regular-B8put20p.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:iAWriterMonoS;src:url(./iAWriterMonoS-Bold-DHbjDDRm.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}:root{color-scheme:light;--bg: #f3f4f6;--panel: rgba(255, 255, 255, .78);--panel-solid: #ffffff;--ink: #101316;--accent: #245a8d;--map-mode: #2ea44f;--node: #2d7aa6;--node-active: #c94b3d;--border: rgba(16, 19, 22, .15);--canvas: #fdfbf7;--muted-ink: rgba(16, 19, 22, .65);--edge: rgba(0, 0, 0, .18);--node-stroke: rgba(0, 0, 0, .35);--text-primary: #1e1e1e;--text-secondary: #2a2a2a;--font-title: "Noto Serif";--font-ratio: "Noto Serif";--font-note: "Lexend";--font-triangle-label: "Noto Serif";--font-custom-label: "Noto Serif";--font-key-mapping: "Lexend";--page: #ffffff;--page-border: rgba(16, 19, 22, .15);--page-shadow: rgba(16, 19, 22, .18);--lfo: #2f6df6;--play-fill: #f3d64d;--looper-fill: #f0bf3a;--wheel-line: #000000;--wheel-ring: #000000;--wheel-text: #000000;--left-panel-width: 180px;--left-panel-left: 16px;--left-panel-inner: 86%}@font-face{font-family:HEJI2Text;src:url(./HEJI2Text-B5Fkx4lF.otf) format("opentype");font-display:swap}*{box-sizing:border-box}body{margin:0;font-family:Lexend,Helvetica Neue,sans-serif;background:radial-gradient(circle at top left,#ffffff,var(--bg));color:var(--muted-ink);transition:background .3s ease,color .3s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;pointer-events:none;transition:background .3s ease;z-index:1}body.theme-dark{color-scheme:dark;--bg: #0c1117;--panel: rgba(18, 24, 33, .8);--panel-solid: #121821;--ink: #e8edf2;--accent: #4aa3df;--map-mode: #33c46b;--node: #59b0dd;--node-active: #f5a15b;--border: rgba(231, 237, 244, .18);--canvas: #0a0f14;--muted-ink: rgba(232, 237, 242, .72);--edge: rgba(230, 238, 246, .16);--node-stroke: rgba(230, 238, 246, .35);--text-primary: #e8edf2;--text-secondary: #b8c1cb;--page: #f9fafb;--page-border: rgba(231, 237, 244, .2);--page-shadow: rgba(0, 0, 0, .45);--lfo: #6cb7ff;--play-fill: #f3d64d;--looper-fill: #f0bf3a;--wheel-line: #f5f7fb;--wheel-ring: #f5f7fb;--wheel-text: #f5f7fb;background:var(--bg)}.app{position:relative;z-index:2;padding:0}.top-bar{display:flex;align-items:center;gap:14px;padding:0;position:relative}.title h1{margin:15px 0 5px 15px;font-size:26px;letter-spacing:.4px;font-weight:200}.title p{margin:0 0 0 18px;color:var(--muted-ink);font-size:12px;line-height:1.4}.ui-hint{margin:0;color:var(--muted-ink);font-size:12px;line-height:1.4;white-space:pre-line;cursor:pointer;display:inline-block;width:fit-content;max-width:80vw;position:relative;z-index:0;pointer-events:auto;background:#ffffffa6;border-radius:12px;padding:10px 14px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 24px #00000026}.creator{margin:0 0 6px 15px;font-size:12px;color:var(--muted-ink);opacity:.75}.creator a,.creator a:visited{color:inherit}.panel{background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:12px 16px;border-radius:14px;border:1px solid var(--border);opacity:.25;transition:opacity .2s ease}.panel:hover,.panel:focus-within{opacity:1}.panel.panel-open{opacity:1;transition:none}.panel.panel-open:hover,.panel.panel-open:focus-within{opacity:1}.panel.controls{position:relative}.help-toggle{position:absolute;bottom:-20px;left:16px;display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted-ink);pointer-events:auto}.help-toggle-right{position:fixed;top:75;right:18px;left:auto;bottom:auto;z-index:9;border:none;padding:6px 10px}.help-toggle input{width:14px;height:14px;margin:0}.help-toggle label{font-size:11px;letter-spacing:.2px;margin:0}body.performance-mode .panel,body.performance-mode .title,body.performance-mode .help-toggle,body.performance-mode .ui-hint,body.performance-mode .keyboard-help,body.performance-mode .preset-overlay,body.performance-mode .interval-chart-overlay,body.performance-mode .layout-overlay,body.performance-mode .layout-font-popover,body.performance-mode .layout-space-popover,body.performance-mode .layout-key-mapping-popover,body.performance-mode .file-share-popover,body.performance-mode dialog,body.performance-mode [role=dialog]{display:none!important}.controls{flex:1;display:flex;flex-wrap:wrap;gap:10px 12px;align-items:center}.controls-wrap{display:inline-flex;flex-direction:column;align-items:flex-start;gap:6px;flex:1}.hint-row{position:fixed;right:18px;top:105px;width:auto;max-width:min(320px,45vw);display:inline-flex;align-items:flex-start;justify-content:flex-end;z-index:0;min-height:18px;pointer-events:none}.banner-message{position:fixed;top:10%;left:50%;transform:translate(-50%);z-index:10;width:auto;max-width:min(92vw,860px);padding:3px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.24);text-align:center;pointer-events:none;font-size:13px;line-height:1.35;display:none;background:transparent;color:var(--text-primary);box-shadow:none;opacity:1;transition:opacity .5s ease}.banner-message button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;text-decoration:underline;padding:0}.banner-message button:hover{color:var(--ink)}.panel-subtext{margin-top:6px;font-size:11px;color:var(--text-secondary);line-height:1.4}.custom-ratio-dialog textarea{width:100%;min-height:120px;resize:vertical;padding:8px 10px;border-radius:12px;border:1px solid rgba(0,0,0,.12);font-family:Lexend,sans-serif;font-size:13px;line-height:1.4;background:#fffffff2;color:var(--text-primary)}body.theme-dark .custom-ratio-dialog textarea{border-color:#ffffff24;background:#0f1216e6;color:#f5f5f5}.banner-message:not([hidden]){display:block;pointer-events:auto;background:transparent;color:var(--text-primary);box-shadow:none}.banner-message.is-fading{opacity:0}body.theme-dark .banner-message:not([hidden]){background:transparent;color:#f5f5f5;border-color:#ffffff4d;box-shadow:none}.layout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#78829138;pointer-events:none;z-index:5}.control-actions,.control-actions-group{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center}.control-actions-panel{background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 10px;border-radius:14px;border:1px solid var(--border);opacity:.25;transition:opacity .2s ease}.control-actions-panel:hover,.control-actions-panel:focus-within{opacity:1}.control-actions-panel.panel-open{opacity:1;transition:none}.control-actions-divider{width:1px;height:22px;background:var(--border);opacity:.7}.control-group{display:grid;gap:6px}.export-check-status{font-size:11px;line-height:1.35;color:var(--text-secondary);min-height:14px}.control-group-inline{grid-template-columns:auto 1fr;align-items:center;column-gap:10px;row-gap:0}.ratios-inline{display:inline-flex;align-items:center;width:318px;gap:6px;padding:0;border-radius:0;border:none;background:transparent;box-sizing:border-box}.ratios-label{display:block;width:69px;font-size:12px;letter-spacing:.2px}.ratio-axis-label{font-size:10px;letter-spacing:.8px;text-transform:uppercase;opacity:.75}.ratios-inline select{height:24px;padding:2px 8px;font-size:12px;border-radius:8px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.control-inline{display:flex;gap:8px;align-items:center}.subordinate-control{margin-left:0}.subordinate-control.is-disabled{opacity:.45}.fundamental-inline{gap:6px}.fundamental-inline select,.fundamental-inline input{height:24px;padding:2px 8px;border-radius:8px;font-size:12px;line-height:1.2}.fundamental-inline input{width:94.3px;min-width:92px;box-sizing:border-box}.fundamental-inline input::-webkit-outer-spin-button,.fundamental-inline input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.fundamental-inline input[type=number]{-moz-appearance:textfield}.hz-suffix{font-size:10px;letter-spacing:.2px;color:var(--muted-ink);margin-left:4px}.tiny-button{height:22px;min-width:30px;padding:0 6px;border-radius:8px;font-size:11px;line-height:1}.inline-label{font-size:12px;letter-spacing:.2px;color:var(--muted-ink)}.synth-mode-label{font-size:12px;font-weight:600}.synth-mode-toggle{display:flex;gap:8px;flex-wrap:wrap}.synth-mode-option{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink)}.fundamental-spelling-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.control-readout{font-size:11px;color:var(--muted-ink)}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink)}.arrow-sep{font-size:12px;color:var(--muted-ink)}.radio-row{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;font-size:13px}.radio-row label{display:flex;gap:6px;align-items:center}.radio-option{display:inline-flex;align-items:center;gap:6px;font-size:12px}label{font-size:13px;letter-spacing:.2px}input[type=number],select{flex:1;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:#fff;font-size:14px}body.theme-dark input[type=number],body.theme-dark select{background:#0f151d;color:#fff;border-color:#fff}body.theme-dark .ratios-inline{background:transparent}body.theme-dark .banner-message{background:transparent;color:#f5f5f5;border-color:#ffffff4d}body.theme-dark .ui-hint{background:#06080bd9;color:#f5f5f0;box-shadow:0 12px 24px #000000bf}.button-ghost{background:transparent;border:1px solid var(--border);color:var(--ink)}.button-ghost:hover,.button-ghost:focus{border-color:var(--accent);color:var(--accent)}.narrow-select{max-width:110px}input[type=range]{width:100%}#ratio-wheel-mini{width:36px;height:36px}#volume-readout{font-size:12px;opacity:.75}button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--accent);color:#fff;padding:10px 16px;border-radius:999px;font-size:14px;cursor:pointer}button:active{transform:translateY(1px)}.button-on{background:#f2c94c;color:#1a1a1a}.button-on:active{transform:translateY(1px)}.nav-3d{position:fixed;top:100px;left:var(--left-panel-left);width:var(--left-panel-width);z-index:9}.nav-3d[hidden],#nav-3d[data-mode="2d"] [data-nav-mode="3d"],#nav-3d[data-mode="3d"] [data-nav-mode="2d"]{display:none}.nav-3d-panel{display:grid;gap:12px;max-height:calc(100vh - 140px);overflow:auto;--panel-inner-width: var(--left-panel-inner)}.nav-3d-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;border:1px solid rgba(0,0,0,.15);border-radius:12px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;cursor:pointer}.nav-3d-chevron{font-size:12px;transition:transform .2s ease}.nav-3d-content{display:grid;gap:12px}.nav-3d-content>*{width:var(--panel-inner-width);justify-self:center}.nav-3d-content .control-group,.nav-3d-content .control-inline,.nav-3d-content .nav-3d-buttons{width:100%;min-width:0}.nav-3d-panel.is-collapsed .nav-3d-content{display:none}.nav-3d-panel.is-collapsed .nav-3d-chevron{transform:rotate(-90deg)}.nav-3d-section{display:grid;gap:8px}.nav-3d-title{font-size:11px;letter-spacing:.5px;text-transform:uppercase;opacity:.7}.nav-3d-accordion-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:0;background:none;border:0;font-size:11px;letter-spacing:.5px;text-transform:uppercase;opacity:.7;cursor:pointer}.nav-3d-accordion-chevron{transition:transform .2s ease}.nav-3d-accordion-toggle.is-collapsed .nav-3d-accordion-chevron{transform:rotate(-90deg)}.nav-3d-accordion-body[hidden]{display:none}.nav-3d-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.nav-3d-subsection{display:grid;gap:6px}.nav-3d-subtitle{font-size:10px;letter-spacing:.2px;text-transform:uppercase;opacity:.55}.nav-3d-inline-slider{gap:6px}.nav-3d-inline-slider label{font-size:11px;color:var(--muted-ink);min-width:62px}.nav-3d-inline-slider input[type=range]{flex:1;min-width:0;height:14px}.nav-3d button{background:transparent;color:var(--ink);border:1px solid var(--border);padding:6px 8px;border-radius:10px;font-size:12px}.nav-3d-view-modes{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.nav-3d-toggle-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:0}.nav-3d-toggle-buttons-3{grid-template-columns:repeat(3,1fr)}.nav-3d-view-modes button,.nav-3d-toggle-buttons button{background:transparent;color:var(--ink);border:1px solid var(--border);padding:6px 8px;font-size:12px;border-radius:0}.nav-3d-view-modes button:first-child{border-top-left-radius:10px;border-bottom-left-radius:10px}.nav-3d-view-modes button:last-child{border-top-right-radius:10px;border-bottom-right-radius:10px}.nav-3d-view-modes button+button{margin-left:-1px}.nav-3d-toggle-buttons button:first-child{border-top-left-radius:10px;border-bottom-left-radius:10px}.nav-3d-toggle-buttons button:last-child{border-top-right-radius:10px;border-bottom-right-radius:10px}.nav-3d-toggle-buttons button+button{margin-left:-1px}.nav-3d-view-modes button.is-active,.nav-3d-toggle-buttons button.is-active{background:var(--accent);color:#fff;border-color:var(--accent);position:relative;z-index:1}.nav-3d-toggle{display:flex;gap:6px;align-items:center;font-size:13px}.nav-3d-toggle-small{font-size:12px}.ratio-wheel-button{padding:6px;border-radius:999px;background:transparent;border:1px solid var(--border)}.ratio-wheel-toggle{position:relative;display:inline-flex}.ratio-wheel-panel{position:fixed;left:var(--ratio-wheel-left, 24px);top:var(--ratio-wheel-top, 120px);width:min(420px,90vw);display:grid;gap:12px;z-index:3}.ratio-wheel-panel[hidden]{display:none}.ratio-wheel-panel-header{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}.ratio-wheel-panel canvas{width:min(420px,100%);height:auto;max-height:min(70vh,560px);margin:0 auto}.options-toggle{position:relative}.options-toggle button{display:inline-flex;align-items:center;gap:8px}.options-panel{position:absolute;top:calc(100% + 8px);left:-120px;min-width:220px;padding:18px;display:grid;gap:12px;z-index:3}.options-panel[hidden]{display:none}.options-panel .control-group{display:grid;gap:6px}.options-panel button{justify-self:start}.inline-link{background:none;border:none!important;color:var(--accent);font-size:11px;text-decoration:underline;cursor:pointer;padding:0!important;border-radius:0!important;flex:0 0 auto}.inline-link:hover{color:var(--ink)}.options-panel .button-full{justify-self:stretch;width:100%;display:flex;align-items:center;justify-content:center}#tilt{width:120px;min-width:120px;max-width:120px}#tilt-readout{width:60px;min-width:60px;max-width:60px;text-align:right;font-variant-numeric:tabular-nums}.file-panel .button-full{justify-self:stretch;width:100%;display:flex;align-items:center;justify-content:center}.layout-float{position:fixed;top:100px;left:var(--left-panel-left);width:min(var(--left-panel-width),100%);--panel-inner-width: var(--left-panel-inner);z-index:3;display:grid;gap:10px;max-height:calc(100vh - 140px);overflow:auto;overflow-x:hidden}.layout-float[hidden]{display:none}.layout-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;color:var(--ink);border:1px solid rgba(0,0,0,.15);border-radius:12px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;cursor:pointer}.layout-chevron{font-size:12px;transition:transform .2s ease}.layout-content{display:grid;gap:8px}.layout-content>*{width:var(--panel-inner-width);justify-self:center}.layout-float.is-collapsed .layout-content{display:none}.layout-float.is-collapsed .layout-chevron{transform:rotate(-90deg)}.layout-header{font-weight:600}.layout-float .button-full{width:100%;display:flex;align-items:center;justify-content:center}.layout-float label{font-size:11px;letter-spacing:.5px;opacity:.7}.layout-float label[for=layout-unify-size]{font-size:12px;letter-spacing:.4px;text-transform:uppercase;opacity:.7}.layout-float .control-inline,.layout-float .control-inline span,.layout-float .control-inline label{font-size:11px;letter-spacing:0;text-transform:none;opacity:1}.layout-float .control-inline{flex-wrap:wrap}.layout-float input[type=checkbox]:disabled+span{opacity:.45;cursor:not-allowed}.layout-float .layout-align-row{width:100%;flex-wrap:nowrap}.layout-float .layout-align-row+.layout-align-row{margin-top:6px}.layout-float .layout-align-row button{flex:1 1 0}.layout-float input[type=number],.layout-float select{width:100%;padding:6px 8px;font-size:12px}.layout-float input[type=range]{width:100%}.layout-float button{padding:6px 8px;font-size:12px}.layout-float .nav-3d-accordion-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:0;background:none;border:0;color:var(--ink);font-size:12px;font-weight:400;letter-spacing:.4px;text-transform:uppercase;opacity:.7;cursor:pointer}.layout-float .control-inline button{flex:1 1 72px}.layout-float .control-inline .inline-link{flex:0 0 auto;padding:0}.layout-float .control-readout{font-size:10px}.layout-float input,.layout-float select,.layout-float button{max-width:100%;box-sizing:border-box}.layout-space-group{position:relative}.layout-space-trigger{cursor:pointer}.layout-space-trigger:hover,.layout-space-trigger:focus-visible{opacity:1}.layout-space-popover{position:absolute;top:calc(100% + 6px);left:0;width:100%;display:grid;gap:6px;padding:8px;border-radius:10px;background:var(--panel);border:1px solid var(--border);box-shadow:0 10px 24px #00000026;z-index:5}.layout-space-popover[hidden]{display:none}.layout-font-popover{position:fixed;top:100px;right:var(--left-panel-left);width:280px;max-height:calc(100vh - 48px);overflow:auto;padding:12px;border-radius:12px;background:var(--panel-solid);border:1px solid var(--border);box-shadow:0 14px 30px #0000002e;z-index:12}.layout-font-popover[hidden]{display:none}.layout-font-form{display:grid;gap:12px}.layout-font-form label{display:grid;gap:8px;font-size:12px}.layout-font-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.layout-font-popover select{padding:4px 6px;border-radius:8px}.layout-font-size{display:grid;grid-template-columns:88px 1fr;gap:8px;align-items:center;font-size:11px;letter-spacing:.2px;opacity:.85}.layout-font-actions{display:flex;justify-content:flex-end;gap:8px}.layout-key-mapping-group{position:relative}.layout-key-mapping-trigger{cursor:pointer}.layout-key-mapping-trigger:hover,.layout-key-mapping-trigger:focus-visible{opacity:1}.layout-key-mapping-popover{background:var(--panel-solid)}.layout-key-mapping-popover .layout-space-row{grid-template-columns:60px 1fr}.layout-space-row{display:grid;grid-template-columns:16px 1fr;gap:6px;align-items:center}.layout-space-row label{font-size:11px;letter-spacing:.2px;opacity:.8}.preset-toggle{position:relative}.preset-toggle button{display:inline-flex;align-items:center;gap:8px}.file-toggle,.calculate-toggle{position:relative}.file-toggle button{display:inline-flex;align-items:center;gap:8px}.preset-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:340px;max-width:420px;z-index:3;display:grid;gap:8px;white-space:normal;word-wrap:break-word}.preset-panel[hidden]{display:none}.file-panel{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;z-index:3;display:grid;gap:8px;overflow:visible}.file-panel[hidden]{display:none}.file-panel .file-share-popover{position:absolute;top:0;left:calc(100% + 8px);min-width:220px;padding:10px 12px;font-size:12px;line-height:1.3;opacity:1;background:var(--panel-solid);box-shadow:0 12px 24px #0000001f;pointer-events:none}.calculate-panel{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;z-index:3;display:grid;gap:8px;padding:12px 14px}.calculate-panel[hidden],.file-share-popover[hidden]{display:none}.preset-list{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:13px}.preset-list a{display:grid;grid-template-columns:1fr auto;gap:10px;padding:6px 10px;border-radius:8px;background:#fff6;color:inherit;text-decoration:none;align-items:center}.preset-list a:focus-visible,.preset-list a:hover{color:var(--accent);background:#ffffffb3}.preset-label{font-weight:500;min-width:0}.preset-meta{font-size:12px;color:var(--muted-ink);opacity:.7}.preset-empty{color:var(--muted-ink)}.chevron{display:inline-block;transition:transform .2s ease}.options-toggle button[aria-expanded=true] .chevron,.preset-toggle button[aria-expanded=true] .chevron,.file-toggle button[aria-expanded=true] .chevron{transform:rotate(180deg)}.synth-panel{position:fixed;left:24px;right:24px;bottom:24px;z-index:2;display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 14px;border-radius:999px}.synth-panel[hidden]{display:none}.synth-group{display:grid;gap:6px}.synth-group:has(#keyboard-help){position:relative}.synth-group:has(#keyboard-map-popover){position:relative}.synth-panel .synth-group{display:flex;gap:8px;align-items:center;min-width:0}.synth-panel .synth-slider-group{display:grid;grid-template-columns:auto 110px auto;column-gap:6px;row-gap:2px;align-items:center;min-width:0}.synth-panel .synth-slider-group label{white-space:nowrap;margin:0}.synth-panel .synth-slider-group input[type=range]{min-width:80px;width:100%}.synth-panel .synth-slider-group .control-readout,.synth-panel .synth-slider-group #volume-readout,.synth-panel .synth-slider-group #lfo-depth-readout{justify-self:end;min-width:48px;text-align:right}.snapshot-group{flex-direction:column;align-items:flex-start;gap:4px;min-width:160px;position:relative;margin-left:auto;margin-right:auto}.snapshot-keyboard{display:grid;gap:4px;align-self:center;min-width:0}.snapshot-keyboard[hidden]{display:none}.snapshot-keyboard-row{display:grid;grid-auto-flow:column;grid-auto-columns:18px;gap:3px}.snapshot-keyboard-row-head{grid-auto-columns:auto 1fr;align-items:center;column-gap:6px}.snapshot-key{border:1px solid var(--line);border-radius:5px;background:transparent;color:var(--muted-ink);font-size:8px;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.snapshot-key.is-filled{background:#3f5efb26;border-color:#3f5efb66;color:var(--text-primary)}.snapshot-key.is-active{border-color:#3f5efbe6;box-shadow:0 0 0 1px #3f5efb80}.snapshot-keyboard.is-inactive .snapshot-key{opacity:.35;filter:grayscale(.4);pointer-events:none}.snapshot-keyboard.is-inactive .snapshot-key.is-filled,.snapshot-keyboard.is-inactive .snapshot-key.is-active{background:#8c8c8c1f;border-color:#8c8c8c59;color:#8c8c8cbf;box-shadow:none}.snapshot-header{width:100%;display:flex;align-items:center;gap:6px;font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted-ink)}.snapshot-header button{font-size:10px;padding:2px 6px;border-radius:6px}.snapshot-toggle{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--muted-ink);text-transform:uppercase;letter-spacing:.3px}.snapshot-toggle input{margin:0}.snapshot-subtoggle{margin-left:14px;font-size:9px}.snapshot-options{display:flex;flex-direction:column;gap:4px;padding:6px 8px;border-radius:8px;background:#14171f;border:1px solid rgba(255,255,255,.08);color:#e6e9f2;box-shadow:0 6px 16px #00000047;position:absolute;bottom:calc(100% + 6px);margin-top:0;z-index:20}.snapshot-options[hidden]{display:none}.snapshot-options .snapshot-toggle{color:inherit}.snapshot-options input[type=checkbox]{accent-color:#6f86ff}.snapshot-options .snapshot-subtoggle{color:#e6e9f2bf}.snapshot-grid{display:grid;grid-template-columns:repeat(10,16px);grid-auto-rows:16px;gap:4px}.snapshot-slot{border:1px solid var(--line);border-radius:5px;background:transparent;color:var(--muted-ink);font-size:9px;padding:0;line-height:1;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.snapshot-slot.is-filled{background:#3f5efb26;border-color:#3f5efb66;color:var(--text-primary)}.snapshot-slot.is-active{border-color:#3f5efbe6;box-shadow:0 0 0 1px #3f5efb80}.synth-panel label{font-size:11px;letter-spacing:.3px;text-transform:uppercase;color:var(--muted-ink)}.synth-panel #volume-readout,.synth-panel #lfo-depth-readout,.synth-panel .control-readout{font-size:10px;opacity:.8}.synth-panel select,.synth-panel input[type=number]{padding:4px 8px;border-radius:999px;font-size:12px}.synth-panel input[type=range]{height:14px}.synth-panel input[type=range]{min-width:140px}.synth-panel button{padding:6px 12px;font-size:12px}.keyboard-mode-row{display:grid;grid-template-columns:minmax(160px,1fr) auto auto;gap:8px;align-items:center}.keyboard-mode-row select{min-width:180px}.keyboard-mode-row button{white-space:nowrap}.midi-menu{position:relative}.midi-menu-panel{position:absolute;bottom:calc(100% + 8px);top:auto;left:50%;transform:translate(-50%);min-width:220px;padding:14px;display:grid;gap:12px;z-index:4}.midi-menu-panel[hidden]{display:none}.midi-menu-panel .control-group{display:grid;gap:6px}.keyboard-map-button{height:28px;padding:0 10px;font-size:12px;font-weight:600}.keyboard-mode-row button.is-active{border-color:var(--button-active-border);background:var(--button-active-bg);color:var(--button-active-text)}.keyboard-map-button.is-active{border-color:var(--map-mode);background:color-mix(in srgb,var(--map-mode) 22%,transparent);color:var(--map-mode)}body.map-mode-active #lattice{box-shadow:inset 0 0 0 6px color-mix(in srgb,var(--map-mode) 55%,transparent)}body.map-mode-active .keyboard-mode-row{background:color-mix(in srgb,var(--map-mode) 12%,transparent);border-radius:8px;padding:2px}body.map-mode-active:before{background:color-mix(in srgb,var(--map-mode) 8%,transparent)}.keyboard-help{position:absolute;left:0;bottom:calc(100% + 6px);max-width:220px;padding:6px 8px;border-radius:8px;border:1px solid var(--border);background:var(--panel);font-size:11px;line-height:1.2;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}.keyboard-help.is-visible{opacity:1;transform:translateY(0)}.keyboard-map-popover{position:absolute;left:0;bottom:calc(100% + 8px);width:240px;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--panel);box-shadow:0 12px 24px #0000001f;z-index:3}.keyboard-map-clear-link{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:0;border:0;background:transparent;color:var(--text-secondary);font-size:11px;text-transform:lowercase;cursor:pointer}.keyboard-map-clear-link:hover{color:var(--text-primary)}.keyboard-map-popover[hidden]{display:none}.piano-keys{position:relative;display:block;height:86px;margin-bottom:10px}.piano-keys-white{display:flex;height:100%;gap:4px}.piano-keys-black{position:absolute;top:0;left:0;height:52px;width:100%;pointer-events:none}.piano-key{border:1px solid var(--border);border-radius:6px;padding:0;font-size:10px;font-family:Lexend,sans-serif;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.piano-key.white{flex:1;background:#fff;color:var(--text-primary);box-shadow:inset 0 -2px #0000001f}.piano-key.black{position:absolute;top:0;left:calc(var(--key-pos) * 100% / 7 - 10px);width:20px;height:52px;background:#1b1b1b;color:#f5f5f5;border-color:#0009;border-radius:4px;pointer-events:auto;box-shadow:inset 0 -2px #ffffff1f}.piano-key.is-unmapped{background:#fff;border-color:var(--border)}.piano-key.black.is-unmapped{background:#1b1b1b;border-color:#0009;color:#f5f5f5}.piano-key.is-mapped{background:color-mix(in srgb,var(--map-mode) 18%,#ffffff);border-color:var(--border)}.piano-key.black.is-mapped{background:color-mix(in srgb,var(--map-mode) 22%,#1b1b1b);border-color:#0009}.piano-key.is-selected{background:color-mix(in srgb,var(--map-mode) 45%,#ffffff);border-color:var(--map-mode);box-shadow:0 0 0 2px color-mix(in srgb,var(--map-mode) 70%,transparent)}.piano-key.black.is-selected{background:color-mix(in srgb,var(--map-mode) 55%,#1b1b1b);border-color:var(--map-mode);color:#fff}.piano-key:active{transform:translateY(1px)}.synth-group.is-disabled{opacity:.45}.synth-group.is-disabled input,.synth-group.is-disabled select,.synth-group.is-disabled button{pointer-events:none}.control-note{font-size:10px;color:var(--muted-ink);letter-spacing:.2px}.looper-label{display:inline-flex;align-items:center;gap:8px}.looper-clear{background:none;border:none;padding:0;font-size:12px;color:var(--muted-ink);text-decoration:underline;cursor:pointer}.looper-clear:hover,.looper-clear:focus{color:var(--accent)}.looper-quantize-row{align-items:center;gap:8px}.looper-quantize-row label{margin-right:auto}.looper-quantize-menu{margin-top:8px;padding:10px 12px;border-radius:10px}.looper-quantize-menu .control-group{margin-bottom:10px}.looper-quantize-menu .control-group:last-child{margin-bottom:0}.lfo-label{display:inline-flex;align-items:center;gap:8px}.lfo-stop{background:none;border:none;padding:0;font-size:12px;color:var(--muted-ink);text-decoration:underline;cursor:pointer}.lfo-stop:hover,.lfo-stop:focus{color:var(--accent)}.all-notes-off{background:none;border:none;padding:0;font-size:12px;color:var(--muted-ink);text-decoration:underline;cursor:pointer;justify-self:start}.all-notes-off:hover,.all-notes-off:focus{color:var(--accent)}.animation-toggle,.envelope-toggle{justify-self:end;align-self:center}.synth-actions{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.animation-panel{position:fixed;right:24px;bottom:140px;width:min(240px,80vw);display:grid;gap:12px;z-index:3}.animation-section{display:grid;gap:10px}.animation-section-title{display:flex;align-items:center;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted-ink)}.envelope-panel{position:fixed;right:24px;bottom:140px;width:min(260px,80vw);display:grid;gap:12px;z-index:3}.envelope-slider{display:grid;grid-template-columns:72px 1fr;gap:6px;align-items:center}.envelope-slider label{margin:0;white-space:nowrap}.envelope-slider-row{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}.envelope-slider-row input[type=range]{min-width:0}.envelope-slider-row span{font-size:10px;opacity:.8}.envelope-panel-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted-ink);margin-top:4px}.envelope-panel .envelope-panel-section-title{font-size:12px}.animation-panel[hidden],.envelope-panel[hidden]{display:none}.animation-panel-header{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}.custom-ratio-dialog{border:none;border-radius:16px;padding:18px 20px;width:min(320px,90vw);background:var(--panel);color:var(--ink)}.custom-ratio-dialog.interval-dialog{width:min(420px,90vw)}.credits-dialog{width:min(420px,92vw)}.credits-content{display:grid;gap:10px;font-size:12px;line-height:1.5}.credits-content a,.credits-content a:visited{color:inherit}.credits-contact{margin-top:6px;font-size:11px;color:var(--ink-muted)}.credits-close{margin-top:4px;font-size:11px;color:var(--ink-muted)}.custom-ratio-dialog::backdrop{background:#0a0f1473}.custom-ratio-form{display:grid;gap:12px}.custom-ratio-form label{display:grid;gap:6px;font-size:12px}.custom-ratio-form input{width:100%}.dialog-title{font-size:14px;font-weight:600}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin:0;padding:0}.dialog-help{font-size:11px;color:var(--ink-muted)}.dialog-actions button{font-size:12px}.interval-chart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0a0a0e99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;padding:24px}.interval-chart-overlay[hidden]{display:none}.interval-chart-window{width:min(1200px,96vw);height:min(720px,90vh);background:var(--panel-bg, #f4f4f6);color:var(--text-color, #1b1b1f);border-radius:18px;border:1px solid rgba(0,0,0,.08);box-shadow:0 24px 80px #00000047;display:flex;flex-direction:column;overflow:hidden}body.theme-dark .interval-chart-window{background:#141418;color:#f5f5f7;border-color:#ffffff14}.interval-chart-header{padding:18px 24px 10px;border-bottom:1px solid rgba(0,0,0,.08)}body.theme-dark .interval-chart-header{border-bottom-color:#ffffff14}.interval-chart-subheader{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 24px;border-bottom:1px solid rgba(0,0,0,.08);font-size:13px}body.theme-dark .interval-chart-subheader{border-bottom-color:#ffffff14}.interval-chart-subheader select{margin:0 6px}.interval-chart-title{font-size:20px;font-weight:600;letter-spacing:.01em}.interval-chart-body{flex:1;display:grid;grid-template-columns:220px 1fr;gap:16px;padding:16px 24px;overflow:hidden}.interval-chart-filters{border-right:1px solid rgba(0,0,0,.08);padding-right:16px;overflow:auto}body.theme-dark .interval-chart-filters{border-right-color:#ffffff14}.interval-chart-filter-title{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:#00000080;margin-bottom:12px}body.theme-dark .interval-chart-filter-title{color:#ffffff8c}.interval-chart-filter-actions{display:flex;gap:8px;margin-bottom:12px}.interval-chart-filter-actions button{font-size:11px;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.15);background:#ffffffe6;cursor:pointer;color:#000}body.theme-dark .interval-chart-filter-actions button{border-color:#fff3;background:#18181ef2;color:#000}.interval-chart-type-list{display:flex;flex-direction:column;gap:8px}.interval-chart-filter-extra{margin-bottom:12px}.interval-chart-type-group{display:flex;flex-direction:column;gap:6px}.interval-chart-type-group-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.interval-chart-type{display:flex;align-items:center;gap:8px;font-size:14px}.interval-chart-type.is-child{margin-left:18px}.interval-chart-type-divider{margin:6px 0 2px;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#0006}body.theme-dark .interval-chart-type-divider{color:#ffffff73}.interval-chart-table-wrap{overflow:auto;border-radius:12px;border:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;flex:1;min-height:0}.interval-chart-table-column{display:flex;flex-direction:column;gap:12px;min-height:0}body.theme-dark .interval-chart-table-wrap{border-color:#ffffff14}.interval-chart-toolbar{position:sticky;top:0;z-index:1;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08);background:#fafafcf2;display:flex;align-items:center;gap:12px;flex-wrap:wrap}body.theme-dark .interval-chart-toolbar{background:#18181ef2;border-bottom-color:#ffffff14}.interval-chart-toolbar:empty{display:none}.interval-chart-toolbar-search{position:static;border-bottom:1px solid rgba(0,0,0,.08);border-radius:12px;margin-bottom:12px}body.theme-dark .interval-chart-toolbar-search{border-bottom-color:#ffffff14}.interval-chart-toolbar input{flex:1;padding:8px 10px;border-radius:10px;border:1px solid rgba(0,0,0,.15);background:#ffffffe6;color:inherit;font-size:13px}body.theme-dark .interval-chart-toolbar input{border-color:#fff3;background:#14141af2}.interval-chart-custom{display:inline-flex;gap:8px;align-items:center;flex:1 1 320px;padding:12px 12px 14px;border-top:1px solid rgba(0,0,0,.08);position:sticky;bottom:0;background:#fafafcf2;z-index:2}body.theme-dark .interval-chart-custom{border-top-color:#ffffff14;background:#18181ef2}.interval-chart-custom-label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:#0009}body.theme-dark .interval-chart-custom-label{color:#fff9}.interval-chart-custom input{flex:1 1 auto}.interval-chart-listen{display:inline-flex;align-items:center;gap:6px;font-size:12px;white-space:nowrap}.interval-chart-custom-active{position:sticky;top:52px;z-index:1;padding:8px 12px;font-size:12px;color:#000;background:#ffecb3e6;border-bottom:1px solid rgba(0,0,0,.1)}body.theme-dark .interval-chart-custom-active{background:#ffecb3d9;color:#000}.interval-chart-table tbody tr{transition:background-color .12s ease}.interval-chart-row-selected{background:#ffe26b59}.interval-chart-table{width:100%;border-collapse:collapse;min-width:720px;font-size:13px}.interval-chart-table thead th{position:sticky;top:0;background:#fafafcf2;text-align:left;font-weight:600;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.08)}body.theme-dark .interval-chart-table thead th{background:#18181ef2;border-bottom-color:#ffffff14}.interval-chart-table tbody td{padding:8px 12px;border-bottom:1px solid rgba(0,0,0,.06);vertical-align:top}.interval-chart-factor-line{font-size:12px}.interval-chart-factor-line.is-muted{font-size:11px;color:#00000080}body.theme-dark .interval-chart-factor-line.is-muted{color:#ffffff8c}body.theme-dark .interval-chart-table tbody td{border-bottom-color:#ffffff14}.interval-chart-table.is-disabled{pointer-events:none;opacity:.45}.interval-chart-actions{padding:12px 24px 18px;border-top:1px solid rgba(0,0,0,.08);display:flex;justify-content:flex-end;gap:12px}.interval-chart-actions #interval-chart-close{color:#000;background:#fff;border:1px solid rgba(0,0,0,.2)}body.theme-dark .interval-chart-actions{border-top-color:#ffffff14}body.interval-chart-open{overflow:hidden}.preset-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121652;z-index:4;display:flex;align-items:center;justify-content:center;padding:32px}.preset-overlay[hidden]{display:none}.preset-window{width:min(860px,92vw);max-height:86vh;background:var(--panel-solid);color:inherit;border-radius:18px;box-shadow:0 28px 60px #0f121640;display:flex;flex-direction:column;overflow:hidden}body.theme-dark .preset-window{background:#1e2128f5;box-shadow:0 28px 60px #00000073}.preset-header{padding:18px 24px 10px;border-bottom:1px solid rgba(31,35,40,.08)}body.theme-dark .preset-header{border-color:#ffffff1a}.preset-title{font-size:18px;font-weight:600;letter-spacing:.2px}.preset-body{display:flex;flex-direction:column;gap:14px;padding:18px 24px 20px;overflow:hidden}.preset-body-single{display:flex}.preset-main{display:flex;flex-direction:column;gap:14px;min-width:0}.preset-toolbar{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.preset-toolbar input{width:100%;border-radius:12px;padding:10px 14px;border:1px solid rgba(31,35,40,.12);background:#ffffffb3;font-size:13px;color:inherit}body.theme-dark .preset-toolbar input{background:#0a0c1073;border-color:#ffffff14}.preset-sort{display:grid;gap:4px;font-size:11px;color:var(--muted-ink)}.preset-sort select{min-width:160px;border-radius:10px;padding:8px 10px;border:1px solid rgba(31,35,40,.12);background:#ffffffb3;color:inherit;font-size:12px}body.theme-dark .preset-sort select{background:#0a0c1073;border-color:#ffffff14}.preset-list{display:grid;gap:12px;padding:4px;margin:0;overflow:auto;max-height:58vh}.preset-card{display:grid;grid-template-columns:1fr;gap:6px;padding:12px 14px;border-radius:14px;border:1px solid rgba(31,35,40,.1);background:#ffffffbf;color:inherit;text-decoration:none}body.theme-dark .preset-card{background:#12141ae6;border-color:#ffffff14}.preset-card:hover,.preset-card:focus-visible{border-color:#1f232833;color:var(--accent)}body.theme-dark .preset-card:hover,body.theme-dark .preset-card:focus-visible{border-color:#ffffff2e}.preset-card-title{font-weight:600;font-size:15px}.preset-card-creator{font-size:12px;color:var(--muted-ink)}.preset-card-tags{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:var(--muted-ink)}.preset-card-tag{padding:2px 8px;border-radius:999px;background:#1f232814}body.theme-dark .preset-card-tag{background:#ffffff14}.preset-empty{color:var(--muted-ink);font-size:13px}.preset-actions{display:flex;justify-content:flex-end;gap:12px;padding:12px 20px 18px;border-top:1px solid rgba(31,35,40,.08)}body.theme-dark .preset-actions{border-color:#ffffff1a}body.preset-open{overflow:hidden}@media (max-width: 720px){.preset-toolbar{grid-template-columns:1fr}}.build-intervals-preview{display:grid;gap:8px;width:100%;margin-top:6px;padding:10px 12px;border-radius:12px;border:1px solid rgba(31,35,40,.12);background:#ffffff80}.build-intervals-preview.is-over{background:#d65a5a24;border-color:#d65a5a59}.build-intervals-line{position:relative;height:22px}.build-intervals-line:before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:#1f232859;transform:translateY(-50%)}.build-intervals-endpoint{position:absolute;width:2px;height:12px;background:#1f232899;top:50%;transform:translateY(-50%)}.build-intervals-endpoint.start{left:0}.build-intervals-endpoint.end{right:0}.build-intervals-ticks{position:absolute;top:0;right:0;bottom:0;left:0}.build-intervals-tick{position:absolute;width:2px;height:10px;background:#1f232899;top:50%;transform:translate(-50%,-50%)}.build-intervals-warning{font-size:12px;color:#8b2f2f}body.theme-dark .build-intervals-preview{background:#0a0c1073;border-color:#ffffff14}body.theme-dark .build-intervals-preview.is-over{background:#78282859;border-color:#b45a5a80}body.theme-dark .build-intervals-line:before,body.theme-dark .build-intervals-endpoint,body.theme-dark .build-intervals-tick{background:#ffffffa6}.envelope-panel-header{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}#lattice{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:var(--canvas);z-index:0}@media (max-width: 720px){.top-bar{flex-direction:column;padding-top:12px}.title{max-width:none}.title h1{font-size:22px}.control-actions-divider{display:none}}.snapshot-keyboard-keys{display:grid;gap:4px}
