:root{--color-bg: #0a0a0b;--color-bg-1: #111113;--color-bg-2: #16161a;--color-bg-3: #1d1d22;--color-edge: #2a2a31;--color-edge-strong: #3a3a42;--color-fg: #ece6d9;--color-fg-dim: #8a857a;--color-fg-mute: #5a564e;--color-accent: #b4001a;--color-accent-bright: #e00820;--color-accent-deep: #6e0010;--color-warn: #e06b00;--color-ok: #6b8f4a;--color-mod-lfo: #42c8ff;--color-mod-sh: #c484ff;--color-mod-velocity: #e08c28;--color-mod-keytrack: #72c25a;--color-mod-macro: #f0c050;--color-mod-generic: #8a857a;--font-display: "Playfair Display", "IM Fell English", "Times New Roman", serif;--font-ui: "Barlow Condensed", "Oswald", "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Menlo", "Consolas", monospace;--size-display: 2.25rem;--size-heading: 1.125rem;--size-label: .75rem;--size-body: .875rem;--size-micro: .6875rem;--weight-ui: 500;--weight-label: 600;--weight-display: 900;--radius: 0;--gap-xs: .25rem;--gap-s: .5rem;--gap-m: .75rem;--gap-l: 1rem;--gap-xl: 1.5rem;--glow-accent: 0 0 8px rgba(224, 8, 32, .55);--glow-accent-soft: 0 0 16px rgba(180, 0, 26, .25);--bevel-top: inset 0 1px 0 rgba(255, 255, 255, .04);--bevel-bottom: inset 0 -1px 0 rgba(0, 0, 0, .6);--grain-opacity: .05}*,*:before,*:after{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;padding:0;height:100%;background:var(--color-bg);color:var(--color-fg);font-family:var(--font-ui);font-size:var(--size-body);font-weight:var(--weight-ui);letter-spacing:.015em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:var(--grain-opacity);mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.9  0 0 0 0 0.85  0 0 0 0 0.75  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}@media(prefers-reduced-motion:reduce){body:before{display:none}}h1,h2,h3{font-family:var(--font-display);font-weight:var(--weight-display);letter-spacing:.02em;margin:0}.label{font-size:var(--size-label);font-weight:var(--weight-label);text-transform:uppercase;letter-spacing:.14em;color:var(--color-fg-dim)}.mono,.value{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.app{display:grid;grid-template-rows:auto 1fr auto;height:100vh;min-height:100vh}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--gap-l);padding:var(--gap-m) var(--gap-l);background:var(--color-bg-1);border-bottom:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom)}.topbar-left{justify-self:start;display:inline-flex;align-items:center;gap:var(--gap-l)}.topbar-center{justify-self:center;display:inline-flex;align-items:center;gap:var(--gap-l)}.topbar-right{justify-self:end;display:inline-flex;align-items:center;gap:var(--gap-s)}.topbar .title{font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-display);line-height:1;color:var(--color-fg);text-shadow:var(--glow-accent-soft)}.topbar .title .accent{color:var(--color-accent-bright)}.stage{position:relative;overflow:auto;padding:var(--gap-xl);background:radial-gradient(1200px 800px at 50% -20%,rgba(180,0,26,.08),transparent 60%),var(--color-bg)}.footer{padding:var(--gap-s) var(--gap-l);background:var(--color-bg-1);border-top:1px solid var(--color-edge);color:var(--color-fg-mute);font-size:var(--size-micro);letter-spacing:.2em;text-transform:uppercase}.btn{appearance:none;display:inline-flex;align-items:center;gap:var(--gap-s);padding:.65rem 1.25rem;border:1px solid var(--color-edge-strong);background:linear-gradient(180deg,var(--color-bg-2),var(--color-bg-3));color:var(--color-fg);font-family:var(--font-ui);font-size:var(--size-label);font-weight:var(--weight-label);letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:var(--radius);box-shadow:var(--bevel-top),var(--bevel-bottom);transition:background 80ms linear,color 80ms linear,box-shadow 80ms linear}.btn:hover{color:var(--color-accent-bright);border-color:var(--color-accent-deep)}.btn:active{background:var(--color-bg-3);box-shadow:inset 0 2px 6px #0009}.btn.armed,.btn.active{color:var(--color-accent-bright);border-color:var(--color-accent);background:linear-gradient(180deg,var(--color-bg-3),var(--color-bg-2));box-shadow:var(--bevel-top),var(--bevel-bottom),var(--glow-accent)}.btn-primary{color:var(--color-fg);border-color:var(--color-accent);background:linear-gradient(180deg,var(--color-accent-deep) 0%,var(--color-accent-deep) 60%,rgba(0,0,0,.25) 100%);box-shadow:var(--bevel-top),var(--bevel-bottom),var(--glow-accent-soft);font-weight:var(--weight-display);letter-spacing:.08em}.btn-primary:hover{color:var(--color-fg);border-color:var(--color-accent-bright);box-shadow:var(--bevel-top),var(--bevel-bottom),var(--glow-accent)}.btn-primary:active{box-shadow:inset 0 2px 6px #00000080}.synth-toolbar{display:flex;align-items:center;gap:var(--gap-s);padding:var(--gap-l) calc(var(--gap-xl) * 1.7) var(--gap-s);background:transparent;border:0;flex-wrap:wrap}.synth-toolbar+.stage{padding-top:0}.synth-toolbar-divider{width:1px;height:1.5rem;margin:0 var(--gap-s);background:var(--color-edge)}.synth-toolbar-active-preset{appearance:none;background:transparent;border:0;padding:.25rem .5rem;color:var(--color-accent-bright);font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-label);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;max-width:22ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.synth-toolbar-active-preset:hover,.synth-toolbar-active-preset:focus-visible{color:var(--color-fg);text-shadow:var(--glow-accent-soft);outline:none}.synth-toolbar-spacer{flex:1}.synth-toolbar-midi{display:inline-flex;align-items:center}.synth-toolbar-randomize{padding:.55rem 1.1rem}.synth-toolbar-undo,.synth-toolbar-redo{font-family:var(--font-display);letter-spacing:.08em;padding:.3rem .65rem}.synth-toolbar-undo+.synth-toolbar-redo{margin-left:calc(-1 * var(--gap-s) + var(--gap-xs))}.osc-capture{display:flex;align-items:center;gap:var(--gap-xs);flex-wrap:wrap}.osc-capture-source{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.2rem .4rem;font-family:var(--font-mono);font-size:var(--size-micro);border-radius:0}.osc-capture-btn{font-family:var(--font-display);letter-spacing:.08em;padding:.3rem .6rem}.knob.midi-bound:before{content:"";position:absolute;top:2px;right:calc(50% - var(--knob-size) / 2 + 2px);width:6px;height:6px;border-radius:50%;background:var(--color-accent-bright);box-shadow:0 0 4px #e00820cc}.knob.midi-learning{animation:knob-midi-learn 1s ease-in-out infinite}@keyframes knob-midi-learn{0%,to{box-shadow:0 0 #e0082000}50%{box-shadow:0 0 0 4px #e0082073}}.knob-midi-menu{position:fixed;z-index:80;display:flex;flex-direction:column;min-width:12rem;padding:.25rem;background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 12px 24px #0009}.knob-midi-menu-item{appearance:none;background:transparent;border:0;color:var(--color-fg);text-align:left;padding:.4rem .6rem;cursor:pointer;font-size:var(--size-label)}.knob-midi-menu-item:hover,.knob-midi-menu-item:focus-visible{background:var(--color-bg-3);color:var(--color-accent-bright);outline:none}.pwa-toast-host{position:fixed;right:var(--gap-l);bottom:var(--gap-l);z-index:100;pointer-events:none}.pwa-toast{pointer-events:auto;display:inline-flex;align-items:center;gap:var(--gap-s);padding:var(--gap-s) var(--gap-m);background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 12px 24px #0009;color:var(--color-fg);font-size:var(--size-label);animation:pwa-toast-in .18s ease-out}@keyframes pwa-toast-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-toast-message{letter-spacing:.02em}.pwa-toast-close{appearance:none;background:transparent;border:0;padding:0 .4rem;color:var(--color-fg-mute);font-size:.95rem;line-height:1;cursor:pointer}.pwa-toast-close:hover,.pwa-toast-close:focus-visible{color:var(--color-fg);outline:none}.led{width:.5rem;height:.5rem;background:var(--color-accent-deep);display:inline-block;border:1px solid rgba(0,0,0,.6)}.led.on{background:var(--color-accent-bright);box-shadow:var(--glow-accent)}.module-panel{display:flex;flex-direction:column;min-height:14rem;background:linear-gradient(180deg,#181820,#13131a 60%,#0f0f14);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 12px 24px #0009}.module-panel-content-grouped{flex-direction:column;align-items:stretch;gap:var(--gap-s)}.module-panel-subgroup{display:flex;flex-direction:column;gap:var(--gap-xs)}.source-osc-fold-row,.source-osc-fold-row.module-panel-content-grouped{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--gap-l);align-items:stretch}.module-panel-subgroup-noise,.module-panel-subgroup-sh,.module-panel-subgroup-macros,.module-panel-subgroup-fold,.module-panel-subgroup-voice,.module-panel-subgroup-wave{border-left:1px solid var(--color-edge);padding-left:var(--gap-m)}.module-panel-subgroup-body{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--gap-m) var(--gap-l);align-items:flex-start}.module-panel-subsection{padding-left:var(--gap-xs);color:var(--color-fg-dim);letter-spacing:.2em}.module-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--gap-m);padding:var(--gap-m) var(--gap-l);background:var(--color-bg-2);border-bottom:1px solid var(--color-edge);box-shadow:var(--bevel-bottom)}.module-panel-action{margin-left:auto}.module-panel-title{font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-heading);letter-spacing:.1em;text-transform:uppercase;color:var(--color-fg)}.module-panel-subtitle{color:var(--color-fg-mute)}.module-panel-content{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--gap-m) var(--gap-l);padding:var(--gap-l);align-items:flex-start;justify-content:flex-start}.effects-group{display:flex;flex-direction:column;width:100%;flex:1 1 100%;min-height:280px;background:linear-gradient(180deg,#181820,#13131a 60%,#0f0f14);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 12px 24px #0009}.effects-group-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--gap-m);padding:var(--gap-m) var(--gap-l);background:var(--color-bg-2);border-bottom:1px solid var(--color-edge);box-shadow:var(--bevel-bottom)}.effects-group-title{font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-heading);letter-spacing:.1em;text-transform:uppercase;color:var(--color-fg)}.effects-group-hint{color:var(--color-fg-mute)}.effects-group-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:var(--gap-s);padding:var(--gap-s);align-items:stretch;flex:1}.effects-group-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--gap-xs);flex:1;margin:var(--gap-s);padding:var(--gap-l);border:1px dashed var(--color-edge);border-radius:var(--radius);color:var(--color-fg-mute);text-align:center}.effects-group-empty-headline{font-family:var(--font-display);font-weight:var(--weight-display);letter-spacing:.08em;text-transform:uppercase;color:var(--color-fg);font-size:var(--size-heading)}.effects-group-empty-hint{color:var(--color-fg-mute);max-width:36ch}.effects-group-slot{box-shadow:none;cursor:grab}.effects-group-slot.effects-group-slot-dragging{opacity:.5;cursor:grabbing}.effects-group-slot-over{border-color:var(--color-accent);box-shadow:var(--glow-accent-soft)}.effects-group-palette{display:flex;flex-wrap:wrap;align-items:center;gap:var(--gap-xs);padding:var(--gap-s) var(--gap-l);border-bottom:1px solid var(--color-edge);background:var(--color-bg-2)}.effects-group-palette-label{color:var(--color-fg-mute);margin-right:var(--gap-xs);font-weight:var(--weight-display);letter-spacing:.08em;text-transform:uppercase}.effects-group-palette-btn{font-family:var(--font-display);letter-spacing:.05em}.effects-group-remove{appearance:none;background:transparent;border:none;color:var(--color-fg-mute);font-size:.95rem;line-height:1;cursor:pointer;padding:2px 6px;border-radius:var(--radius)}.effects-group-remove:hover,.effects-group-remove:focus-visible{color:#ff6b6b;background:#ff50501f;outline:none}.effects-group-bypass{margin-left:auto;appearance:none;background:transparent;border:1px solid var(--color-edge);color:var(--color-fg-dim);font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.1em;line-height:1;cursor:pointer;padding:3px 8px;border-radius:var(--radius);transition:color .12s ease-out,background .12s ease-out,border-color .12s ease-out}.effects-group-bypass.is-on{color:var(--color-accent-bright);border-color:var(--color-accent)}.effects-group-bypass.is-off{color:var(--color-fg-mute);border-color:var(--color-edge)}.effects-group-bypass:hover,.effects-group-bypass:focus-visible{background:var(--color-bg-3);outline:none}.effects-group-slot-bypassed .module-panel-content{opacity:.4;pointer-events:none}.effects-group-slot-bypassed .module-panel-title{color:var(--color-fg-mute)}.knob{--knob-size: 56px;position:relative;display:flex;flex-direction:column;align-items:center;gap:.375rem;user-select:none;outline:none;cursor:ns-resize;touch-action:none;padding:var(--gap-xs);border-radius:var(--radius)}.knob:focus-visible{box-shadow:0 0 0 1px var(--color-accent),var(--glow-accent-soft)}.knob.dragging{cursor:ns-resize}.knob-svg{width:var(--knob-size);height:var(--knob-size);overflow:visible;filter:drop-shadow(0 2px 3px rgba(0,0,0,.6))}.knob-body{fill:#1a1a20;stroke:#050507;stroke-width:1.5}.knob-arc-bg{fill:none;stroke:var(--color-edge);stroke-width:3;stroke-linecap:butt}.knob-arc-value{fill:none;stroke:var(--color-accent-bright);stroke-width:3;stroke-linecap:butt;filter:drop-shadow(0 0 3px rgba(224,8,32,.7))}.knob-mod-arcs{fill:none}.knob-mod-arc{fill:none;stroke-width:2;stroke-linecap:round;opacity:.85}.knob-mod-arc-lfo{stroke:var(--color-mod-lfo);filter:drop-shadow(0 0 2px rgba(66,200,255,.6))}.knob-mod-arc-sh{stroke:var(--color-mod-sh);filter:drop-shadow(0 0 2px rgba(196,132,255,.6))}.knob-mod-arc-velocity{stroke:var(--color-mod-velocity);filter:drop-shadow(0 0 2px rgba(224,140,40,.6))}.knob-mod-arc-keytrack{stroke:var(--color-mod-keytrack);filter:drop-shadow(0 0 2px rgba(114,194,90,.6))}.knob-mod-arc-macro{stroke:var(--color-mod-macro);filter:drop-shadow(0 0 2px rgba(240,192,80,.6))}.knob-mod-arc-generic{stroke:var(--color-mod-generic)}.knob-tick{stroke:var(--color-fg);stroke-width:2.5;stroke-linecap:round}.knob-label{font-size:var(--size-micro);color:var(--color-fg-dim)}.knob-value{font-size:var(--size-micro);color:var(--color-fg);min-height:1em;letter-spacing:.05em}.select-control{display:flex;flex-direction:column;gap:.375rem;align-items:center;min-width:100px}.select-control-input{appearance:none;-webkit-appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge-strong);padding:.45rem 1.5rem .45rem .6rem;font-family:var(--font-mono);font-size:var(--size-micro);font-weight:var(--weight-label);letter-spacing:.08em;text-transform:uppercase;border-radius:0;box-shadow:var(--bevel-top),var(--bevel-bottom);cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--color-fg-dim) 50%),linear-gradient(135deg,var(--color-fg-dim) 50%,transparent 50%);background-position:calc(100% - 12px) 55%,calc(100% - 7px) 55%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;transition:border-color 80ms linear,color 80ms linear}.select-control-input:hover{border-color:var(--color-accent-deep);color:var(--color-accent-bright)}.select-control-input:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.voice-glide{display:flex;align-items:center;gap:var(--gap-s)}.voice-glide input[type=range].range-themed{width:120px;accent-color:var(--color-accent)}.voice-glide-readout{font-size:var(--size-micro);color:var(--color-accent-bright);min-width:3rem;text-align:right}.wave-select{display:flex;flex-direction:column;gap:.375rem;align-items:center}.wave-select-group{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;border:1px solid var(--color-edge-strong);box-shadow:var(--bevel-top),var(--bevel-bottom)}.wave-select-btn{appearance:none;background:var(--color-bg-3);color:var(--color-fg-dim);border:none;border-right:1px solid var(--color-edge);padding:.4rem .6rem;font-family:var(--font-ui);font-size:var(--size-micro);font-weight:var(--weight-label);letter-spacing:.15em;cursor:pointer;transition:background 60ms linear,color 60ms linear}.wave-select-btn:last-child{border-right:none}.wave-select-btn:hover:not(.active){color:var(--color-fg);background:var(--color-bg-2)}.wave-select-btn.active{color:var(--color-accent-bright);background:linear-gradient(180deg,#1f0208,#110104);box-shadow:inset 0 0 8px #b4001a80,var(--glow-accent)}.wave-select-btn:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px;z-index:1}.trigger-btn{appearance:none;display:inline-flex;align-items:center;gap:var(--gap-s);padding:.9rem 1.75rem;border:1px solid var(--color-edge-strong);background:linear-gradient(180deg,var(--color-bg-2),var(--color-bg-3));color:var(--color-fg);font-family:var(--font-display);font-weight:var(--weight-display);font-size:1.25rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:var(--radius);box-shadow:var(--bevel-top),var(--bevel-bottom);transition:color 80ms linear,box-shadow 80ms linear;user-select:none;touch-action:none}.trigger-btn:hover{color:var(--color-accent-bright)}.trigger-btn.active{color:var(--color-accent-bright);box-shadow:var(--bevel-bottom),inset 0 2px 6px #000000b3,var(--glow-accent);background:linear-gradient(180deg,#200306,#0a0204)}.phase{display:flex;flex-direction:column;align-items:flex-start;gap:var(--gap-xl);padding:var(--gap-l)}.phase .controls{display:flex;align-items:center;gap:var(--gap-l)}.rack{display:flex;flex-direction:row;align-items:stretch;gap:var(--gap-l);flex-wrap:wrap}.phase1{display:flex;flex-direction:column;gap:var(--gap-xl)}.btn-sm{padding:.35rem .6rem;font-size:var(--size-micro);letter-spacing:.12em}.keyboard-root{display:contents}.keyboard-dock{display:flex;flex-direction:column;gap:var(--gap-s);padding:var(--gap-s) var(--gap-l) var(--gap-m);background:linear-gradient(180deg,var(--color-bg-1),var(--color-bg));border-top:1px solid var(--color-edge);box-shadow:var(--bevel-top);position:relative;z-index:5}.keyboard-controls{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--gap-m)}.keyboard-controls-left{justify-self:start;display:inline-flex;align-items:center;gap:var(--gap-m);flex-wrap:wrap}.keyboard-controls-center{justify-self:center;display:inline-flex;align-items:center;gap:var(--gap-l)}.keyboard-octave,.keyboard-velocity{display:flex;align-items:center;gap:.4rem}.keyboard-octave-val{color:var(--color-fg);min-width:2.2rem;text-align:center}.keyboard-velocity input[type=range].range-themed{width:120px;accent-color:var(--color-accent)}.keyboard-controls-right{justify-self:end;display:inline-flex;align-items:center;gap:var(--gap-m)}.keyboard-tab{display:flex;flex-direction:column;gap:var(--gap-s)}.keyboard-tab-header{display:flex;align-items:center;gap:var(--gap-m);flex-wrap:wrap}.keyboard-tab-body{display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-start;justify-content:flex-start;gap:var(--gap-l)}.keyboard-piano{position:relative;height:150px;background:var(--color-bg);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),inset 0 4px 12px #000000b3;user-select:none;touch-action:none}.keyboard-arp-badge{position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%;background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.6);box-shadow:var(--glow-accent);pointer-events:none;display:none}.keyboard-arp-badge.on{display:block}.keyboard-controls .btn-sm:has(.keyboard-arp-badge){position:relative;padding-right:1rem}.keyboard-arp-slot{min-height:150px}.keyboard-arp-panel{border:none;box-shadow:none;background:transparent;min-height:0}.seq-panel{position:relative;display:flex;flex-direction:column;gap:var(--gap-s);padding:var(--gap-xs) 0}.seq-transport{display:flex;align-items:center;gap:var(--gap-m);flex-wrap:wrap}.seq-labeled{display:inline-flex;align-items:center;gap:var(--gap-xs);font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.05em}.seq-select,.seq-number{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.25rem .45rem;font-family:var(--font-mono);font-size:var(--size-micro)}.seq-number{width:3.4rem}.seq-swing{width:80px}.seq-enable{font-family:var(--font-display);letter-spacing:.12em;padding:.35rem .8rem}.seq-random{font-family:var(--font-display);letter-spacing:.08em;padding:.3rem .65rem}.seq-patterns-btn{font-family:var(--font-display);letter-spacing:.08em}.pattern-modal-backdrop{position:fixed;inset:0;background:#0000008c;backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--gap-l)}.pattern-modal{display:flex;flex-direction:column;gap:var(--gap-s);width:min(560px,100%);max-height:min(80vh,720px);background:var(--color-bg-1);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 18px 48px #000000b3;padding:var(--gap-m);overflow:hidden}.pattern-modal-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-edge);padding-bottom:var(--gap-s)}.pattern-modal-title{font-family:var(--font-display);font-size:var(--size-heading);letter-spacing:.12em;text-transform:uppercase;margin:0}.pattern-modal-close{appearance:none;background:transparent;border:none;color:var(--color-fg-mute);font-size:1.1rem;cursor:pointer;padding:2px 8px;border-radius:var(--radius)}.pattern-modal-close:hover,.pattern-modal-close:focus-visible{color:var(--color-accent-bright);outline:none}.pattern-modal-search{padding:0}.pattern-modal-input{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.4rem .6rem;font-family:var(--font-mono);font-size:var(--size-body);border-radius:0;min-width:0}.pattern-modal-search .pattern-modal-input{width:100%}.pattern-modal-input:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.pattern-modal-form{display:grid;grid-template-columns:1fr auto auto auto;gap:var(--gap-xs);padding:var(--gap-s);border:1px solid var(--color-edge);background:var(--color-bg-2)}.pattern-modal-list{display:flex;flex-direction:column;gap:1px;overflow-y:auto;flex:1 1 auto}.pattern-modal-heading{padding:.4rem .6rem .2rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-fg-mute);border-bottom:1px solid var(--color-edge);margin-top:var(--gap-xs)}.pattern-modal-row{display:flex;align-items:center;gap:var(--gap-xs);padding:.25rem .4rem;background:var(--color-bg-2);border-bottom:1px solid var(--color-edge)}.pattern-modal-row.active{background:linear-gradient(180deg,rgba(180,0,26,.18),var(--color-bg-2))}.pattern-modal-load{appearance:none;background:transparent;border:none;color:var(--color-fg);text-align:left;flex:1 1 auto;padding:.35rem .5rem;font-family:var(--font-mono);font-size:var(--size-body);cursor:pointer;border-radius:var(--radius)}.pattern-modal-load:hover,.pattern-modal-load:focus-visible{background:var(--color-bg-3);outline:none}.pattern-modal-name{display:inline-block}.pattern-modal-action{appearance:none;background:transparent;border:none;color:var(--color-fg-mute);cursor:pointer;padding:2px 6px;font-size:.95rem;border-radius:var(--radius)}.pattern-modal-action:hover,.pattern-modal-action:focus-visible{color:var(--color-fg);background:var(--color-bg-3);outline:none}.pattern-modal-delete:hover,.pattern-modal-delete:focus-visible{color:#ff6b6b;background:#ff50501f}.pattern-modal-empty{padding:var(--gap-m);color:var(--color-fg-mute);font-style:italic;text-align:center}.seq-enable.is-on{border-color:var(--color-accent);color:var(--color-accent-bright);box-shadow:var(--glow-accent-soft)}.seq-row{display:flex;align-items:center;gap:var(--gap-s)}.seq-row-label{flex:0 0 auto;width:3rem;text-align:right;color:var(--color-fg-mute);letter-spacing:.12em;text-transform:uppercase;font-size:var(--size-micro)}.seq-grid{flex:1 1 auto;display:flex;gap:4px;align-items:stretch}.seq-grid-steps .seq-cell{position:relative;flex:1 1 0;min-width:28px;height:56px;appearance:none;background:var(--color-bg-3);border:1px solid var(--color-edge);color:var(--color-fg-mute);font-family:var(--font-mono);font-size:var(--size-micro);cursor:pointer;padding:0;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;user-select:none;touch-action:none}.seq-grid-steps .seq-cell.is-active{border-color:var(--color-accent-deep);background:linear-gradient(180deg,rgba(180,0,26,.25) 0%,var(--color-bg-3) 60%);color:var(--color-fg)}.seq-grid-steps .seq-cell.is-cursor,.seq-grid-mod .seq-mod-cell.is-cursor{border-color:var(--color-accent-bright);box-shadow:0 0 6px #ff474773}.seq-cell-note{margin-top:4px;pointer-events:none;z-index:1}.seq-cell-velocity{position:absolute;bottom:0;left:0;right:0;height:0;background:linear-gradient(180deg,transparent,rgba(180,0,26,.5));pointer-events:none}.seq-cell-tie{position:absolute;top:1px;right:2px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.04em;color:var(--color-accent-bright);pointer-events:none;z-index:1}.seq-grid-steps .seq-cell.is-carrier{background:repeating-linear-gradient(135deg,var(--color-bg-3) 0,var(--color-bg-3) 6px,rgba(180,0,26,.12) 6px,rgba(180,0,26,.12) 10px);color:var(--color-fg-dim);border-color:var(--color-edge);cursor:default}.seq-grid-mod .seq-mod-cell{position:relative;flex:1 1 0;min-width:28px;height:28px;appearance:none;background:var(--color-bg-3);border:1px solid var(--color-edge);cursor:ns-resize;padding:0;overflow:hidden;touch-action:none}.seq-mod-bar{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,var(--color-accent-bright),var(--color-accent-deep));pointer-events:none}.seq-editor{display:flex;flex-direction:column;gap:.4rem;background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:0 6px 18px #0000008c;padding:.55rem .7rem;z-index:60;min-width:200px}.seq-editor-title{letter-spacing:.12em;text-transform:uppercase;color:var(--color-fg-dim);border-bottom:1px solid var(--color-edge);padding-bottom:.2rem}.seq-editor-knobs{display:flex;align-items:flex-start;gap:.4rem}.seq-editor-knobs .knob{padding:2px}.keyboard-key{appearance:none;position:absolute;top:0;bottom:0;margin:0;padding:0;border:0;cursor:pointer;transition:background 30ms linear,box-shadow 30ms linear;border-radius:0}.keyboard-key.white{background:linear-gradient(180deg,#1e1e24,#0c0c11);border-right:1px solid #000;color:var(--color-fg-mute)}.keyboard-key.white:hover{background:linear-gradient(180deg,#242430,#0f0f14)}.keyboard-key.white.held,.keyboard-key.white.sounding{background:linear-gradient(180deg,#380104,#120004);box-shadow:inset 0 0 10px var(--color-accent-deep),0 0 10px #b4001a66;color:var(--color-accent-bright)}.keyboard-key.black{top:0;height:62%;background:linear-gradient(180deg,#070709,#141419);border-left:1px solid #000;border-right:1px solid #000;box-shadow:0 4px 6px #000000b3,inset 0 1px #ffffff0f;z-index:2;transform:translate(-50%)}.keyboard-key.black:hover{background:linear-gradient(180deg,#1c1c22,#131319)}.keyboard-key.black.held,.keyboard-key.black.sounding{background:linear-gradient(180deg,#30010a,#0a0002);box-shadow:inset 0 0 10px var(--color-accent-deep),0 0 12px #b4001a8c}.keyboard-key-label{position:absolute;bottom:.35rem;left:0;right:0;text-align:center;font-size:.625rem;font-family:var(--font-mono);letter-spacing:.05em;pointer-events:none}.app{grid-template-rows:auto 1fr auto auto}.mod-matrix{position:fixed;right:0;top:0;bottom:0;width:540px;max-width:90vw;z-index:40;background:linear-gradient(180deg,var(--color-bg-1),var(--color-bg));border-left:1px solid var(--color-edge);box-shadow:-12px 0 24px #0009;display:flex;flex-direction:column;gap:var(--gap-m);padding:var(--gap-l);overflow-y:auto;transform:translate(100%);transition:transform .16s ease-out}.mod-matrix.open{transform:translate(0)}.mod-matrix-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--gap-m)}.mod-matrix-title{font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-heading);letter-spacing:.12em;text-transform:uppercase}.mod-matrix-form{display:grid;grid-template-columns:1fr auto 1fr auto;gap:var(--gap-s);align-items:center;padding:var(--gap-m);border:1px solid var(--color-edge);background:var(--color-bg-2);box-shadow:var(--bevel-top)}.mod-matrix-select{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.4rem .5rem;font-family:var(--font-ui);font-size:var(--size-label);letter-spacing:.1em;text-transform:uppercase;border-radius:0;min-width:0}.mod-matrix-select-compact{padding:.25rem .35rem;font-size:var(--size-micro);max-width:100%;overflow:hidden;text-overflow:ellipsis}.mod-matrix-select:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.mod-matrix-arrow{color:var(--color-accent-bright);font-family:var(--font-mono)}.mod-matrix-list{display:flex;flex-direction:column;gap:var(--gap-xs)}.mod-matrix-row{display:grid;grid-template-columns:1fr auto auto auto auto;grid-template-rows:auto auto;row-gap:var(--gap-xs);column-gap:var(--gap-s);align-items:center;padding:var(--gap-s) var(--gap-m);border:1px solid var(--color-edge);background:var(--color-bg-2);box-shadow:var(--bevel-top)}.mod-matrix-range{appearance:none;background:var(--color-bg-3);color:var(--color-fg-dim);font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.05em;border:1px solid var(--color-edge);padding:.15rem .35rem;min-width:3rem;cursor:pointer}.mod-matrix-range:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.mod-matrix-row-label{display:flex;align-items:center;gap:var(--gap-xs);min-width:0;grid-column:1 / -1;grid-row:1}.mod-matrix-row-label .mod-matrix-select{flex:1 1 0;min-width:0}.mod-matrix-curve{appearance:none;background:var(--color-bg-3);color:var(--color-fg-dim);font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.05em;border:1px solid var(--color-edge);padding:.15rem .35rem;min-width:3rem;cursor:pointer}.mod-matrix-curve:disabled{opacity:.4;cursor:not-allowed}.mod-matrix-curve:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.mod-matrix-row-label .label{color:var(--color-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mod-matrix-depth{accent-color:var(--color-accent);min-width:100px}input[type=range].range-themed{--range-track-height: 6px;--range-thumb-width: 10px;--range-thumb-height: 18px;appearance:none;-webkit-appearance:none;width:100%;min-width:120px;height:var(--range-thumb-height);margin:0;background:transparent;cursor:pointer}input[type=range].range-themed:focus{outline:none}input[type=range].range-themed:focus-visible{outline:1px solid var(--color-accent);outline-offset:2px}input[type=range].range-themed::-webkit-slider-runnable-track{height:var(--range-track-height);background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 0 1px 3px #000000b3}input[type=range].range-themed::-moz-range-track{height:var(--range-track-height);background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 0 1px 3px #000000b3}input[type=range].range-themed::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:var(--range-thumb-width);height:var(--range-thumb-height);margin-top:calc((var(--range-track-height) - var(--range-thumb-height)) / 2);background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:grab}input[type=range].range-themed:active::-webkit-slider-thumb{cursor:grabbing}input[type=range].range-themed::-moz-range-thumb{width:var(--range-thumb-width);height:var(--range-thumb-height);background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:grab}input[type=range].range-themed:active::-moz-range-thumb{cursor:grabbing}.mod-matrix-depth-readout{min-width:3.5rem;text-align:right;color:var(--color-accent-bright);font-size:var(--size-micro)}.mod-matrix-delete{padding:.3rem .5rem}.mod-matrix-empty{padding:var(--gap-m);color:var(--color-fg-mute)}.midi-picker{display:inline-flex;align-items:center;gap:var(--gap-xs)}.midi-picker-select{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.3rem 1.3rem .3rem .5rem;font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.05em;border-radius:0;max-width:160px;background-image:linear-gradient(45deg,transparent 50%,var(--color-fg-dim) 50%),linear-gradient(135deg,var(--color-fg-dim) 50%,transparent 50%);background-position:calc(100% - 11px) 55%,calc(100% - 6px) 55%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.midi-picker-select:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.midi-picker-status{color:var(--color-fg-mute);font-size:var(--size-micro);letter-spacing:.05em;text-transform:lowercase}.midi-monitor{position:relative;display:inline-flex;align-items:center}.midi-monitor-button.is-open{background:var(--color-bg-3);border-color:var(--color-accent)}.midi-monitor-popover{position:absolute;top:calc(100% + 6px);right:0;min-width:260px;max-width:320px;background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:0 6px 18px #0000008c;padding:.5rem .6rem;z-index:50;font-size:var(--size-micro)}.midi-monitor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem;padding-bottom:.3rem;border-bottom:1px solid var(--color-edge)}.midi-monitor-title{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--color-fg-dim);font-size:var(--size-micro)}.midi-monitor-list{list-style:none;margin:0;padding:0;max-height:240px;overflow-y:auto}.midi-monitor-row{padding:.15rem .1rem;font-family:var(--font-mono);font-size:var(--size-micro);color:var(--color-fg);white-space:pre;border-bottom:1px dotted var(--color-edge)}.midi-monitor-row:last-child{border-bottom:none}.midi-monitor-empty{padding:.4rem .1rem;color:var(--color-fg-mute);font-style:italic}.topbar-volume-wrap{position:relative;display:inline-flex;align-items:center}.topbar-volume-button{font-family:var(--font-mono);letter-spacing:.1em;padding:.2rem .5rem}.topbar-volume-popover{position:absolute;top:100%;left:50%;transform:translate(-50%);padding:calc(var(--gap-s) + 6px) var(--gap-xs) var(--gap-s);background:var(--color-bg-2);border:1px solid var(--color-edge);background-clip:padding-box;box-shadow:var(--bevel-top),var(--bevel-bottom),0 10px 18px #0000008c;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease-out,visibility .12s ease-out;z-index:40}.topbar-volume-wrap:hover .topbar-volume-popover,.topbar-volume-wrap:focus-within .topbar-volume-popover,.topbar-volume-wrap.is-open .topbar-volume-popover{opacity:1;visibility:visible;pointer-events:auto}.topbar-volume-slider{appearance:none;-webkit-appearance:none;writing-mode:vertical-lr;direction:rtl;width:18px;min-width:0;height:96px;margin:0;background:transparent;cursor:ns-resize}.topbar-volume-slider:focus{outline:none}.topbar-volume-slider:focus-visible{outline:1px solid var(--color-accent);outline-offset:2px}.topbar-volume-slider::-webkit-slider-runnable-track{width:6px;background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 1px 0 3px #000000b3}.topbar-volume-slider::-moz-range-track{width:6px;background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 1px 0 3px #000000b3}.topbar-volume-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:18px;height:10px;margin-left:-6px;background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:ns-resize}.topbar-volume-slider::-moz-range-thumb{width:18px;height:10px;background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:ns-resize}.topbar-bpm{display:inline-flex;align-items:center;gap:var(--gap-xs)}.topbar-bpm-input{appearance:textfield;width:4.5rem;padding:.25rem .4rem;background:var(--color-bg-3);border:1px solid var(--color-edge);color:var(--color-fg);font-family:var(--font-mono);font-size:var(--size-label);text-align:center;border-radius:0}.topbar-bpm-input:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.topbar-tap{padding:.2rem .5rem;font-family:var(--font-mono);letter-spacing:.1em}.topbar-metronome-wrap{position:relative;display:inline-flex;align-items:center}.topbar-metronome{padding:.2rem .45rem;font-size:1rem;line-height:1}.topbar-metronome-icon{display:inline-block}.topbar-metronome.on{color:var(--color-accent-bright);border-color:var(--color-accent);background:linear-gradient(180deg,var(--color-bg-3),var(--color-bg-2));box-shadow:var(--bevel-top),var(--bevel-bottom),var(--glow-accent-soft)}.topbar-metronome-volume{position:absolute;top:100%;left:50%;transform:translate(-50%);padding:calc(var(--gap-s) + 6px) var(--gap-xs) var(--gap-s);background:var(--color-bg-2);border:1px solid var(--color-edge);background-clip:padding-box;box-shadow:var(--bevel-top),var(--bevel-bottom),0 10px 18px #0000008c;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease-out,visibility .12s ease-out;z-index:40}.topbar-metronome-wrap:hover .topbar-metronome-volume,.topbar-metronome-wrap:focus-within .topbar-metronome-volume,.topbar-metronome-wrap.is-open .topbar-metronome-volume{opacity:1;visibility:visible;pointer-events:auto}.topbar-metronome-volume-slider{appearance:none;-webkit-appearance:none;writing-mode:vertical-lr;direction:rtl;width:18px;min-width:0;height:96px;margin:0;background:transparent;cursor:ns-resize}.topbar-metronome-volume-slider:focus{outline:none}.topbar-metronome-volume-slider:focus-visible{outline:1px solid var(--color-accent);outline-offset:2px}.topbar-metronome-volume-slider::-webkit-slider-runnable-track{width:6px;background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 1px 0 3px #000000b3}.topbar-metronome-volume-slider::-moz-range-track{width:6px;background:var(--color-bg-3);border:1px solid var(--color-edge);box-shadow:inset 1px 0 3px #000000b3}.topbar-metronome-volume-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:18px;height:10px;margin-left:-6px;background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:ns-resize}.topbar-metronome-volume-slider::-moz-range-thumb{width:18px;height:10px;background:var(--color-accent-bright);border:1px solid rgba(0,0,0,.8);border-radius:2px;box-shadow:0 0 6px #e00820cc;cursor:ns-resize}.topbar-tap.tap-pulse{animation:topbar-tap-flash .18s ease-out}@keyframes topbar-tap-flash{0%{background:var(--color-accent-deep);border-color:var(--color-accent);color:var(--color-fg)}to{background:transparent}}.output-meter{display:inline-flex;align-items:center;gap:var(--gap-xs)}.output-meter-track{position:relative;width:200px;height:1.35rem;background:var(--color-bg-3);border:1px solid var(--color-edge);overflow:visible}.output-meter-fill{position:absolute;top:0;bottom:0;left:0;width:0%;background:linear-gradient(90deg,var(--color-ok) 0%,var(--color-ok) 60%,var(--color-warn) 80%,var(--color-accent-bright) 100%);transition:width 30ms linear}.output-meter-peak{position:absolute;top:-2px;bottom:-2px;width:2px;left:0%;background:var(--color-fg);transition:left 80ms linear;pointer-events:none}.output-meter-clip{width:.75rem;height:.75rem;background:var(--color-accent-deep);border:1px solid rgba(0,0,0,.6);flex-shrink:0}.output-meter-clip.active{background:var(--color-accent-bright);box-shadow:var(--glow-accent)}.scope-panel .module-panel-content{flex-direction:column;align-items:stretch}.visualizer{display:flex;flex-direction:column;align-items:stretch;gap:var(--gap-xs);padding:var(--gap-xs);margin:0;width:200px;background:var(--color-bg-3);border:1px solid var(--color-edge);cursor:pointer}.visualizer:hover{border-color:var(--color-accent)}.visualizer:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.visualizer-canvas{display:block;width:100%;height:110px;image-rendering:pixelated}.visualizer-mode{align-self:flex-end;color:var(--color-fg-mute);font-size:var(--size-micro);letter-spacing:.1em;text-transform:uppercase}.visualizer:hover .visualizer-mode{color:var(--color-fg-dim)}.topbar-panic{border-color:var(--color-accent-deep);color:var(--color-fg-dim)}.topbar-panic:hover{color:var(--color-accent-bright);border-color:var(--color-accent)}.topbar-record{appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:transparent;border:1px solid var(--color-edge);border-radius:50%;width:2.25rem;height:2.25rem;padding:0;cursor:pointer;--record-peak: 0;transition:border-color .15s ease-out,box-shadow .15s ease-out,background-color .15s ease-out,width .18s ease-out,border-radius .18s ease-out,padding .18s ease-out}.topbar-record:hover,.topbar-record:focus-visible{border-color:var(--color-accent);box-shadow:var(--glow-accent-soft);outline:none}.topbar-record-icon{display:block;width:1rem;height:1rem;border-radius:50%;background:#fff;transition:background-color .18s ease-out,border-radius .18s ease-out,width .18s ease-out,height .18s ease-out,box-shadow .18s ease-out}.topbar-record.recording{width:auto;min-width:4.6rem;border-radius:999px;padding:0 .65rem 0 .5rem;border-color:#ff4747;box-shadow:0 0 calc(8px + 14px * var(--record-peak)) rgba(255,71,71,calc(.35 + .5 * var(--record-peak)))}.topbar-record-timer{font-family:var(--font-mono);font-size:var(--size-micro);letter-spacing:.05em;color:var(--color-fg);white-space:nowrap;display:none}.topbar-record.recording .topbar-record-timer{display:inline}.topbar-record.recording .topbar-record-icon{width:.85rem;height:.85rem;border-radius:2px;background:#ff4747;box-shadow:0 0 8px #ff4747cc;animation:topbar-record-pulse 1.2s ease-in-out infinite}@keyframes topbar-record-pulse{0%,to{opacity:1}50%{opacity:.55}}.skip-link{position:absolute;top:0;left:0;transform:translateY(-100%);z-index:1000;padding:var(--gap-s) var(--gap-l);background:var(--color-accent-deep);color:var(--color-fg);font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border:1px solid var(--color-accent);transition:transform .12s ease-out}.skip-link:focus,.skip-link:focus-visible{transform:translateY(0);outline:none}@media(prefers-reduced-motion:reduce){.topbar-record.recording .topbar-record-icon,.knob.midi-learning,.topbar-tap.tap-pulse{animation:none!important}.pwa-toast{animation:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.topbar-user-slot{position:relative;margin-left:var(--gap-s);display:inline-flex;align-items:center}.user-menu{position:relative;display:inline-flex;align-items:center}.user-menu-avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--color-edge);background:var(--color-bg-2);color:var(--color-fg);font-family:var(--font-display);font-weight:var(--weight-display);font-size:.95rem;letter-spacing:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:border-color .15s ease-out,box-shadow .15s ease-out,background-color .15s ease-out}.user-menu-avatar:hover,.user-menu-avatar:focus-visible{border-color:var(--color-accent);box-shadow:var(--glow-accent-soft);outline:none}.user-menu.signed-in .user-menu-avatar{background:var(--color-accent-deep);color:var(--color-fg)}.user-menu.signed-out .user-menu-avatar,.user-menu.loading .user-menu-avatar{color:var(--color-fg-mute)}.user-menu-initial{pointer-events:none;line-height:1;text-transform:uppercase}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;padding:var(--gap-s);display:flex;flex-direction:column;gap:var(--gap-xs);background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom),0 12px 24px #0009;z-index:50}.user-menu-email{padding:var(--gap-xs) var(--gap-s);color:var(--color-fg);font-size:var(--size-micro);word-break:break-all}.user-menu-divider{height:1px;background:var(--color-edge);margin:0 calc(-1 * var(--gap-s))}.user-menu-action{width:100%;text-align:center}.preset-browser-auth{display:flex;flex-direction:column;gap:var(--gap-s);padding:var(--gap-l);border:1px solid var(--color-edge);background:var(--color-bg-2);box-shadow:var(--bevel-top)}.preset-browser-auth-intro{margin:0;color:var(--color-fg-dim)}.preset-browser-auth-actions{display:flex;gap:var(--gap-s);justify-content:flex-start}.preset-browser-auth-error{color:var(--color-accent-bright);min-height:1em}.preset-browser-message{padding:var(--gap-s) var(--gap-m);color:var(--color-accent-bright);border:1px solid var(--color-accent-deep);background:#b4001a14}.preset-browser{position:fixed;left:0;top:0;bottom:0;width:380px;max-width:90vw;z-index:40;background:linear-gradient(180deg,var(--color-bg-1),var(--color-bg));border-right:1px solid var(--color-edge);box-shadow:12px 0 24px #0009;display:flex;flex-direction:column;gap:var(--gap-m);padding:var(--gap-l);overflow-y:auto;transform:translate(-100%);transition:transform .16s ease-out}.preset-browser.open{transform:translate(0)}.preset-browser-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--gap-m)}.preset-browser-title{font-family:var(--font-display);font-weight:var(--weight-display);font-size:var(--size-heading);letter-spacing:.12em;text-transform:uppercase}.preset-browser-form{display:grid;grid-template-columns:1fr auto;gap:var(--gap-s);padding:var(--gap-m);border:1px solid var(--color-edge);background:var(--color-bg-2);box-shadow:var(--bevel-top)}.preset-browser-search{padding:var(--gap-s) var(--gap-m) 0}.preset-browser-search-input{width:100%}.preset-browser-search-input::-webkit-search-cancel-button{appearance:none;-webkit-appearance:none;width:14px;height:14px;background:var(--color-fg-mute);mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 14 14"><path d="M3 3 L11 11 M11 3 L3 11" stroke="black" stroke-width="2" fill="none"/></svg>') center / contain no-repeat;cursor:pointer}.preset-browser-input{appearance:none;background:var(--color-bg-3);color:var(--color-fg);border:1px solid var(--color-edge);padding:.4rem .6rem;font-family:var(--font-mono);font-size:var(--size-body);border-radius:0;min-width:0}.preset-browser-input:focus-visible{outline:1px solid var(--color-accent);outline-offset:-1px}.preset-browser-list{display:flex;flex-direction:column;gap:var(--gap-xs)}.preset-browser-factory{display:flex;flex-direction:column;gap:var(--gap-xs);margin-bottom:var(--gap-m);padding-bottom:var(--gap-m);border-bottom:1px solid var(--color-edge)}.preset-browser-section-heading{padding:var(--gap-xs) 0 var(--gap-xs) var(--gap-s);color:var(--color-fg-dim);letter-spacing:.2em}.preset-browser-row-factory{grid-template-columns:1fr auto;background:var(--color-bg-1)}.preset-browser-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:stretch;gap:var(--gap-xs);border:1px solid var(--color-edge);background:var(--color-bg-2);box-shadow:var(--bevel-top);transition:border-color 80ms linear}.preset-browser-row.active{border-color:var(--color-accent);box-shadow:var(--bevel-top),var(--glow-accent-soft)}.preset-browser-load{appearance:none;background:transparent;color:var(--color-fg);border:none;padding:var(--gap-s) var(--gap-m);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:baseline;gap:var(--gap-m);transition:color 80ms linear;font-family:inherit;min-width:0}.preset-browser-load:hover{color:var(--color-accent-bright)}.preset-browser-name{font-family:var(--font-ui);font-size:var(--size-body);font-weight:var(--weight-label);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-browser-time{font-size:var(--size-micro);color:var(--color-fg-mute);flex-shrink:0}.preset-browser-action{padding:.3rem .5rem;min-width:2rem}.preset-browser-update{font-size:var(--size-micro);letter-spacing:.15em}.preset-browser-update:hover{color:var(--color-accent-bright);border-color:var(--color-accent-deep)}.preset-browser-delete:hover{color:var(--color-warn)}.preset-browser-empty{padding:var(--gap-m);color:var(--color-fg-mute);text-align:center}.preset-browser-category-input{flex:0 0 7rem}.preset-dialog-backdrop{position:fixed;inset:0;background:#0000008c;display:grid;place-items:center;z-index:1000}.preset-dialog{background:var(--color-bg-2);border:1px solid var(--color-edge-strong);box-shadow:var(--bevel-top),0 6px 24px #00000080;padding:var(--gap-l);display:flex;flex-direction:column;gap:var(--gap-m);min-width:22rem;max-width:28rem}.preset-dialog-title{margin:0;font-family:var(--font-display);font-size:1.15rem;color:var(--color-fg);letter-spacing:.05em}.preset-dialog-desc{color:var(--color-fg-dim);line-height:1.35;margin:0}.preset-dialog-field{display:flex;flex-direction:column;gap:var(--gap-xs)}.preset-dialog-actions{display:flex;justify-content:flex-end;gap:var(--gap-s);margin-top:var(--gap-s)}.topbar .status{font-size:var(--size-micro);letter-spacing:.15em;text-transform:uppercase;color:var(--color-fg-mute)}.topbar .status.live{color:var(--color-accent-bright)}.test-panel{display:flex;flex-direction:column;align-items:flex-start;gap:var(--gap-l);max-width:520px;padding:var(--gap-xl);background:var(--color-bg-2);border:1px solid var(--color-edge);box-shadow:var(--bevel-top),var(--bevel-bottom)}.test-panel p{margin:0;color:var(--color-fg-dim);line-height:1.55}.test-panel .row{display:flex;align-items:center;gap:var(--gap-m)}.test-panel .status{font-size:var(--size-micro);letter-spacing:.2em;text-transform:uppercase;color:var(--color-fg-mute)}.test-panel .status.live{color:var(--color-accent-bright)}@media(max-width:720px){.topbar{display:flex;flex-wrap:wrap;gap:var(--gap-m);padding:var(--gap-s) var(--gap-m)}.topbar-left,.topbar-center,.topbar-right{justify-self:auto;flex-wrap:wrap;gap:var(--gap-m)}.topbar-right{margin-left:auto}.topbar .title{font-size:1.4rem}.synth-toolbar{flex-wrap:wrap;gap:var(--gap-s)}.stage{padding:var(--gap-m)}.topbar-volume-popover,.topbar-metronome-volume{left:auto;right:0;transform:none}.visualizer{width:100%}.midi-monitor-popover{max-width:calc(100vw - 2 * var(--gap-m))}}@media(max-width:480px){.rack{gap:var(--gap-m)}.module-panel{min-height:auto}}.fartstorm-modal-backdrop{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--gap-l);background:#000000a6;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fartstorm-fade-in .2s ease-out}@keyframes fartstorm-fade-in{0%{opacity:0}to{opacity:1}}.fartstorm-modal{display:flex;flex-direction:column;align-items:center;gap:var(--gap-m);max-width:460px;padding:var(--gap-xl) var(--gap-xl) var(--gap-l);background:linear-gradient(180deg,var(--color-bg-2),var(--color-bg-1));border:1px solid var(--color-edge-strong);box-shadow:var(--bevel-top),var(--bevel-bottom),0 16px 48px #000000b3;text-align:center;animation:fartstorm-pop-in .24s cubic-bezier(.2,.9,.3,1.4)}@keyframes fartstorm-pop-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.fartstorm-modal-art{position:relative;width:200px;height:160px}.fartstorm-modal-art svg{width:100%;height:100%;animation:fartstorm-spin 6s linear infinite;transform-origin:center}@keyframes fartstorm-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fartstorm-modal-emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.5rem;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(0,0,0,.7));animation:fartstorm-emoji-bob 1.6s ease-in-out infinite}@keyframes fartstorm-emoji-bob{0%,to{transform:translate(-2px,-4px) scale(1)}50%{transform:translate(2px,4px) scale(1.06)}}.fartstorm-modal-text{font-family:var(--font-display);font-weight:var(--weight-display);font-size:1.6rem;line-height:1.25;color:var(--color-fg);letter-spacing:.02em;margin:0;text-shadow:0 0 8px rgba(224,128,32,.3)}.fartstorm-modal-close{margin-top:var(--gap-s);padding:.6rem 1.4rem;font-family:var(--font-display);font-size:var(--size-heading);letter-spacing:.1em;text-transform:uppercase;background:var(--color-accent);color:var(--color-bg);border:1px solid var(--color-accent-bright);cursor:pointer}.fartstorm-modal-close:hover,.fartstorm-modal-close:focus-visible{background:var(--color-accent-bright);color:var(--color-bg);outline:none;box-shadow:0 0 12px #e008208c}@media(prefers-reduced-motion:reduce){.fartstorm-modal-backdrop,.fartstorm-modal,.fartstorm-modal-art svg,.fartstorm-modal-emoji{animation:none}}.song-panel{padding:12px 14px;display:flex;flex-direction:column;gap:12px;position:relative}.song-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.song-play.btn-primary{padding-inline:18px}.song-play.playing{background:var(--color-accent-bright, #c44);color:var(--color-bg, #0a0a0b)}.song-status{font-size:11px;color:var(--color-text-soft, #888);letter-spacing:.05em;margin-left:auto;font-variant-numeric:tabular-nums}.song-lane{display:flex;align-items:stretch;gap:6px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:thin}.song-empty{flex:0 1 auto;min-height:92px;max-width:380px;display:flex;align-items:center;justify-content:flex-start;font-size:12px;color:var(--color-text-soft, #888);font-style:italic;border:1px dashed var(--color-edge, #2a2a2d);border-radius:8px;padding:0 16px;text-align:left}.song-block{flex:0 0 auto;min-width:140px;background:var(--color-panel, #161618);border:1px solid var(--color-edge, #2a2a2d);border-radius:8px;padding:10px;cursor:grab;position:relative;transition:transform .1s ease,border-color .1s ease,box-shadow .1s ease;display:flex;flex-direction:column;gap:6px}.song-block:hover{border-color:var(--color-accent, #884)}.song-block.dragging{opacity:.45;cursor:grabbing}.song-block.drop-target{border-color:var(--color-accent-bright, #c44);box-shadow:0 0 0 2px var(--color-accent-bright, #c44)}.song-block.playing{border-color:var(--color-accent-bright, #c44);box-shadow:0 0 0 1px var(--color-accent-bright, #c44),0 4px 14px #c4444440}.song-block.orphan{opacity:.55;border-style:dashed}.song-block-header{display:flex;align-items:center;gap:6px}.song-block-name{flex:1;font-size:12px;font-weight:600;color:var(--color-text, #e0e0e0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-block-remove{width:18px;height:18px;border-radius:50%;background:transparent;color:var(--color-text-soft, #888);border:1px solid transparent;font-size:14px;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.song-block-remove:hover{color:var(--color-accent-bright, #c44);border-color:currentColor}.song-block-body{display:flex;align-items:center;justify-content:space-between;gap:8px}.song-block-meta{font-size:11px;color:var(--color-text-soft, #888);font-variant-numeric:tabular-nums}.song-block-repeats{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-soft, #888)}.song-block-repeats input{width:42px;padding:3px 4px;background:var(--color-bg, #0a0a0b);border:1px solid var(--color-edge, #2a2a2d);border-radius:4px;color:var(--color-text, #e0e0e0);font:inherit;font-size:12px;font-weight:600;text-align:center;font-variant-numeric:tabular-nums}.song-block-repeats input:focus{outline:none;border-color:var(--color-accent-bright, #c44)}.song-block-index{position:absolute;top:-6px;left:-6px;width:18px;height:18px;border-radius:50%;background:var(--color-bg, #0a0a0b);border:1px solid var(--color-edge, #2a2a2d);color:var(--color-text-soft, #888);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}.song-block.playing .song-block-index{background:var(--color-accent-bright, #c44);border-color:var(--color-accent-bright, #c44);color:var(--color-bg, #0a0a0b)}.song-arrow{color:var(--color-text-soft, #888);font-size:18px;font-weight:700;align-self:center;user-select:none}.song-block-add{flex:0 0 auto;background:transparent;border:1px dashed var(--color-edge, #2a2a2d);border-radius:8px;color:var(--color-text-soft, #888);font:inherit;font-weight:600;font-size:12px;padding:0 16px;cursor:pointer;display:flex;align-items:center;gap:6px;min-width:100px;transition:border-color .1s ease,color .1s ease}.song-block-add:hover{border-color:var(--color-accent, #884);color:var(--color-text, #e0e0e0)}.song-block-add .plus{font-size:18px;font-weight:700;line-height:1}.song-add-popover{position:fixed;z-index:1000;background:var(--color-panel, #161618);border:1px solid var(--color-edge, #2a2a2d);border-radius:8px;box-shadow:0 6px 20px #0006;min-width:220px;max-width:320px;max-height:260px;overflow-y:auto;padding:6px 0}.song-add-group{padding:4px 0}.song-add-group+.song-add-group{border-top:1px solid var(--color-edge, #2a2a2d);margin-top:4px;padding-top:6px}.song-add-group-header{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-soft, #888);padding:4px 12px;font-weight:700}.song-add-item{width:100%;background:transparent;border:none;font:inherit;font-size:12px;color:var(--color-text, #e0e0e0);text-align:left;padding:6px 12px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px}.song-add-item:hover{background:var(--color-edge, #2a2a2d)}.song-add-item-meta{font-size:10px;color:var(--color-text-soft, #888);font-variant-numeric:tabular-nums}.song-add-notice{position:fixed;z-index:1000;background:var(--color-panel, #161618);border:1px solid var(--color-edge, #2a2a2d);border-radius:8px;padding:12px 14px;font-size:12px;color:var(--color-text-soft, #888);box-shadow:0 6px 20px #0006}.atom-panel{padding:12px 14px;display:flex;flex-direction:column;gap:12px}.atom-header{display:flex;align-items:center;gap:12px}.atom-info{display:flex;align-items:center;gap:10px}.atom-symbol{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;font-size:22px;font-weight:700;color:var(--color-bg, #0a0a0b)}.atom-info-meta{line-height:1.2}.atom-info-name{font-size:14px;font-weight:600;color:var(--color-text, #e0e0e0);text-transform:capitalize}.atom-info-num{font-size:11px;color:var(--color-text-soft, #888);letter-spacing:.05em;text-transform:capitalize}.atom-body{display:grid;grid-template-columns:minmax(0,2fr) minmax(220px,1fr);gap:14px;align-items:start}@media(max-width:900px){.atom-body{grid-template-columns:1fr}}.atom-grid{display:grid;grid-template-columns:repeat(18,minmax(0,1fr));grid-auto-rows:1fr;gap:2px;aspect-ratio:18 / 9;font-variant-numeric:tabular-nums}.atom-cell{background:var(--color-panel, #161618);border:1px solid var(--color-edge, #2a2a2d);border-radius:4px;padding:0;font:inherit;color:var(--color-text, #e0e0e0);cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;transition:transform 80ms ease,box-shadow 80ms ease}.atom-cell:hover{transform:scale(1.05);box-shadow:0 4px 10px #0006;z-index:1}.atom-cell.selected{outline:2px solid var(--color-accent-bright, #c44);outline-offset:-2px;box-shadow:0 0 0 1px var(--color-accent-bright, #c44);z-index:2}.atom-cell-num{font-size:7px;position:absolute;top:2px;left:3px;color:#0000008c;font-weight:700}.atom-cell-symbol{font-size:11px;font-weight:700;color:var(--color-bg, #0a0a0b)}.cat-alkali-metal{background:#ff9f80}.cat-alkaline-earth{background:#ffd28c}.cat-transition-metal{background:#e8b3d6}.cat-post-transition-metal{background:#c5d3e3}.cat-metalloid{background:#d6c79a}.cat-nonmetal{background:#a3d8a3}.cat-halogen{background:#b8e3d8}.cat-noble-gas{background:#c8a8e3}.cat-lanthanide{background:#f4a8b8}.cat-actinide{background:#e8a3a3}.atom-side{display:flex;flex-direction:column;gap:12px}.atom-side-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-soft, #888);font-weight:700;margin-bottom:4px}.atom-shells{display:flex;flex-wrap:wrap;gap:4px}.atom-shell-cell{flex:0 0 auto;min-width:36px;padding:4px 6px;background:var(--color-panel, #161618);border:1px solid var(--color-edge, #2a2a2d);border-radius:6px;display:flex;align-items:center;justify-content:space-between;gap:6px;font-variant-numeric:tabular-nums;font-size:11px}.atom-shell-cell.playing{border-color:var(--color-accent-bright, #c44);box-shadow:0 0 0 1px var(--color-accent-bright, #c44),0 2px 8px #c444444d;background:#c444441f}.atom-shell-idx{font-size:9px;color:var(--color-text-soft, #888)}.atom-shell-count{font-weight:700;color:var(--color-text, #e0e0e0)}.atom-chord{display:flex;flex-wrap:wrap;gap:4px}.atom-chord-note{padding:3px 7px;background:var(--color-bg, #0a0a0b);border:1px solid var(--color-edge, #2a2a2d);border-radius:10px;font-size:11px;font-weight:600;color:var(--color-text, #e0e0e0);font-variant-numeric:tabular-nums}.atom-controls{display:grid;grid-template-columns:1fr 1fr;gap:8px}.atom-field{display:flex;flex-direction:column;gap:3px}.atom-field-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-soft, #888);font-weight:600}.atom-input,.atom-select{background:var(--color-bg, #0a0a0b);border:1px solid var(--color-edge, #2a2a2d);border-radius:4px;padding:5px 6px;font:inherit;font-size:12px;color:var(--color-text, #e0e0e0);font-variant-numeric:tabular-nums}.atom-input:focus,.atom-select:focus{outline:none;border-color:var(--color-accent-bright, #c44)}.atom-raw-btn{width:100%}.atom-raw-btn.active{background:var(--color-accent-bright, #c44);color:var(--color-bg, #0a0a0b)}.atom-play-btn{width:100%;padding:10px;font-weight:700}.atom-trigger-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;border:1px solid var(--color-edge, #2a2a2d);border-radius:4px;overflow:hidden;background:var(--color-edge, #2a2a2d)}.atom-trigger-btn{background:var(--color-bg, #0a0a0b);border:none;color:var(--color-text-soft, #888);font:inherit;font-size:11px;font-weight:600;text-transform:lowercase;padding:6px 4px;cursor:pointer;transition:background 80ms ease,color 80ms ease}.atom-trigger-btn:hover{background:var(--color-panel, #161618);color:var(--color-text, #e0e0e0)}.atom-trigger-btn.active{background:var(--color-accent-bright, #c44);color:var(--color-bg, #0a0a0b)}
