:root{--accent: #d8453a;--accent-2: #8f7ce0;--r-lg: 6px;--r-md: 5px;--r-sm: 3px;--font-ui: "Archivo", "Helvetica Neue", system-ui, sans-serif;--font-label: "Archivo", "Helvetica Neue", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}[data-theme=dark]{--bg: #181818;--surface: #242424;--surface-2: #2c2c2c;--header: #2a2a2a;--recess: #141414;--ink: #d2d2d2;--ink-2: #8f8f8f;--ink-3: #5f5f5f;--line: rgba(255,255,255,.07);--line-2: rgba(255,255,255,.13);--knob-track:#3a3a3a;--shadow: none}[data-theme=light]{--bg: #c9c9c9;--surface: #dedede;--surface-2: #e9e9e9;--header: #d4d4d4;--recess: #bdbdbd;--ink: #232323;--ink-2: #555555;--ink-3: #828282;--line: rgba(0,0,0,.13);--line-2: rgba(0,0,0,.24);--knob-track:#b1b1b1;--shadow: none}*{box-sizing:border-box}html,body{margin:0;height:100%}body{font-family:var(--font-ui);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;overflow:hidden;font-size:13px}.metal{background:var(--surface)}.crt-screen:after{display:none!important}.screw{display:none!important}#root{height:100%}.shell{height:100%;display:grid;grid-template-columns:320px 1fr;grid-template-rows:auto 1fr;grid-template-areas:"brand top" "rail main";gap:8px;padding:8px}.brand{grid-area:brand;position:relative;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface);padding:14px 16px;display:flex;align-items:center}.brand-row{display:flex;align-items:center;gap:11px}.logo-mark{width:30px;height:30px;border-radius:6px;flex:none;display:grid;place-items:center;position:relative;background:var(--surface-2);border:1px solid var(--line-2)}.logo-mark:before{content:"";width:13px;height:13px;border-radius:50%;border:2px solid var(--accent)}.logo-mark:after{content:"";position:absolute;width:2px;height:7px;border-radius:2px;background:var(--accent);top:6px}.brand-name{font-family:var(--font-label);font-weight:700;letter-spacing:.01em;font-size:16px;line-height:1}.brand-sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);margin-top:4px}.top{grid-area:top;position:relative;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface);padding:10px 12px;display:flex;align-items:center;gap:10px}.eyebrow{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.1em;font-size:9.5px;color:var(--ink-3);font-weight:600}.rail{grid-area:rail;overflow-y:auto;padding-right:3px;display:flex;flex-direction:column;gap:8px}.main{grid-area:main;overflow-y:auto;padding:2px 6px 40px 2px}.rail::-webkit-scrollbar,.main::-webkit-scrollbar{width:9px}.rail::-webkit-scrollbar-thumb,.main::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px;border:2px solid transparent;background-clip:padding-box}.panel{position:relative;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface);padding:13px 14px}.panel-h{display:flex;align-items:center;gap:7px;margin-bottom:11px}.panel-h h3{margin:0;font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.09em;font-size:10.5px;color:var(--ink-2)}.panel-h .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex:none}.field{margin-top:10px}.field.spaced{margin-top:14px}.field>label{display:block;font-size:10.5px;letter-spacing:.02em;color:var(--ink-3);margin-bottom:5px;text-transform:uppercase;font-family:var(--font-mono)}.inp,.sel{width:100%;font-family:var(--font-ui);font-size:13px;color:var(--ink);background:var(--recess);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:8px 10px;outline:none}.inp::placeholder{color:var(--ink-3)}.inp:focus,.sel:focus{border-color:var(--accent)}.sel{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--ink-3) 50%),linear-gradient(135deg,var(--ink-3) 50%,transparent 50%);background-position:calc(100% - 15px) center,calc(100% - 10px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:28px}textarea.inp{resize:vertical;min-height:82px;font-family:var(--font-mono);font-size:11.5px;line-height:1.55}.status{display:flex;align-items:flex-start;gap:8px;font-size:12px;line-height:1.4;border-radius:var(--r-md);padding:9px 10px;border:1px solid;background:var(--recess)}.status .led-pip{width:7px;height:7px;border-radius:50%;margin-top:4px;flex:none}.status.off{color:#d9a55a;border-color:color-mix(in oklch,#d8a33a 45%,transparent)}.status.off .led-pip{background:#d9a55a}.status.on{color:#62b97f;border-color:color-mix(in oklch,#4fbf6a 42%,transparent)}.status.on .led-pip{background:#62b97f}[data-theme=light] .status.off{color:#8a5d08}[data-theme=light] .status.off .led-pip{background:#b07a10}[data-theme=light] .status.on{color:#1f7a3e}[data-theme=light] .status.on .led-pip{background:#2f9a54}.btn{font-family:var(--font-label);letter-spacing:.01em;font-weight:500;font-size:12px;color:var(--ink);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:var(--surface-2);display:inline-flex;align-items:center;justify-content:center;transition:background .1s,border-color .1s,color .1s}.btn:hover{border-color:var(--ink-3);background:color-mix(in oklch,var(--surface-2) 80%,var(--ink))}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.42;cursor:not-allowed}.btn.full{width:100%}.btn.primary{color:#18120a;border-color:transparent;background:var(--accent);font-weight:600}.btn.primary:hover{filter:brightness(1.08);background:var(--accent)}[data-theme=light] .btn.primary{color:#18120a}.btn.ghost{background:transparent}.check{display:flex;align-items:flex-start;gap:8px;cursor:pointer;font-size:12px;color:var(--ink-2);padding:3px 0;line-height:1.4}.check+.check{margin-top:5px}.check input{display:none}.check .box{width:15px;height:15px;border-radius:3px;flex:none;margin-top:1px;border:1px solid var(--line-2);background:var(--recess);display:grid;place-items:center;transition:.1s}.check input:checked+.box{background:var(--accent);border-color:var(--accent)}.check .box svg{opacity:0;color:#fff}[data-theme=light] .check input:checked+.box svg{color:#1a1208}.check input:checked+.box svg{opacity:1}.check.danger input:checked+.box{background:#cf4d3a;border-color:#cf4d3a}.hint{font-size:11px;color:var(--ink-3);line-height:1.45;margin-top:4px}.sub-h{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.08em;font-size:10px;color:var(--ink-2);font-weight:600;margin:13px 0 2px}.filebtn{display:flex;align-items:center;gap:8px}.filebtn .fake{flex:1;font-size:11px;color:var(--ink-3);font-family:var(--font-mono);border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 9px;background:var(--recess);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vfd{border-radius:var(--r-md);padding:6px;background:#050505;border:1px solid #000;box-shadow:inset 0 1px 2px #000000e6,0 1px 0 var(--line-2)}.vfd-glass{position:relative;overflow:hidden;border-radius:3px;padding:11px 13px 13px;background:radial-gradient(120% 90% at 50% 0%,#1e0604,#0a0100 70%,#050000);color:#ff3b2e;text-shadow:0 0 5px rgba(255,52,32,.65),0 0 12px rgba(255,40,20,.4);font-family:"VT323",var(--font-mono)}.vfd-glass:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(rgba(0,0,0,.55) 38%,transparent 39%);background-size:3px 3px;mix-blend-mode:multiply;opacity:.55}.vfd-line1{display:flex;align-items:baseline;gap:10px;font-size:19px;line-height:1;letter-spacing:.04em;white-space:nowrap}.vfd-line1>span{flex:none;white-space:nowrap}.vfd-line1 .vfd-cat{margin-left:auto;color:#ff9079;text-shadow:0 0 6px rgba(255,70,45,.6)}.vfd-line2{font-size:33px;line-height:1;letter-spacing:.02em;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitor-screen{border-radius:var(--r-md);padding:6px;background:#050505;border:1px solid #000;box-shadow:inset 0 1px 2px #000000e6,0 1px 0 var(--line-2)}.monitor-glass{position:relative;overflow:hidden;border-radius:3px;height:116px;background:radial-gradient(130% 120% at 50% 0%,#0e130c,#080b06 68%,#050603)}.monitor-canvas{display:block;width:100%;height:100%}.monitor-glass:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(0deg,#0000 0,#0000 2px,#00000042 2px,#00000042 3px);mix-blend-mode:multiply}.monitor-tag{position:absolute;top:6px;left:8px;z-index:2;pointer-events:none;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.14em;color:#96b48c80}.monitor-readout{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-variant-numeric:tabular-nums}.monitor-readout .mon-stat{color:var(--ink-3)}.monitor-readout .mon-stat.on{color:#62b97f}.pselect{display:flex;align-items:center;gap:10px;margin-top:12px}.pselect-grp{display:flex;align-items:center;gap:6px;flex:1}.pselect-lbl{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;font-size:10px;color:var(--ink-3);flex:none;margin-right:1px}.navbtn{flex:1;display:inline-grid;place-items:center;height:34px;border-radius:var(--r-sm);border:1px solid var(--line-2);cursor:pointer;color:var(--ink-2);background:var(--surface-2);transition:.1s}.navbtn:hover{border-color:var(--ink-3);color:var(--ink);background:color-mix(in oklch,var(--surface-2) 80%,var(--ink))}.navbtn:active{transform:translateY(.5px)}.navbtn:disabled{opacity:.42;cursor:not-allowed}.searchwrap{position:relative;flex:1}.searchwrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-3);pointer-events:none}.search{width:100%;padding-left:34px}.patchname{font-family:var(--font-ui);font-size:13px;min-width:190px}.toolbtn{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--line-2);cursor:pointer;color:var(--ink-2);background:var(--surface-2);transition:.1s}.toolbtn:hover{border-color:var(--ink-3);color:var(--ink)}.toolbtn.active{color:#fff;border-color:transparent;background:var(--accent)}[data-theme=light] .toolbtn.active{color:#1a1208}.group{margin-bottom:18px}.group-h{display:flex;align-items:center;gap:10px;padding:4px 2px 9px;position:sticky;top:0;z-index:3;background:var(--bg)}.group-h h2{margin:0;font-family:var(--font-label);font-weight:600;letter-spacing:.01em;font-size:14px}.group-h .count{font-family:var(--font-mono);font-size:11px;color:var(--ink-2);background:var(--surface);border:1px solid var(--line-2);border-radius:4px;padding:1px 7px}.group-h .blurb{font-size:11px;color:var(--ink-3);margin-left:auto;font-family:var(--font-ui);letter-spacing:0}.group-rule{flex:0 0 auto;width:1px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:6px}.cell{position:relative;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);padding:11px 11px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .1s,background .1s}.cell:hover{border-color:var(--line-2);background:var(--surface-2)}.cell.edited{border-color:color-mix(in oklch,var(--accent) 60%,var(--line-2))}.cell-top{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:6px}.cell-name{font-family:var(--font-ui);font-weight:500;letter-spacing:0;font-size:12px;line-height:1.15;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2em}.cell-foot{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px}.rack{display:flex;flex-direction:column;gap:3px}.prow{position:relative;display:grid;grid-template-columns:220px 84px 1fr 70px auto;align-items:center;gap:14px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);padding:7px 12px;transition:border-color .1s,background .1s}.prow:hover{border-color:var(--line-2);background:var(--surface-2)}.prow.edited{border-color:color-mix(in oklch,var(--accent) 50%,var(--line))}.prow-name{font-family:var(--font-ui);font-weight:500;letter-spacing:0;font-size:13px}.prow-badges{display:flex;gap:4px;flex-wrap:wrap}.badge{font-family:var(--font-mono);font-size:9.5px;font-weight:500;letter-spacing:.01em;padding:1px 5px;border-radius:3px;line-height:1.5;border:1px solid var(--line-2);white-space:nowrap;color:var(--ink-2);background:var(--recess)}.b-addr,.b-cc{color:var(--ink-2)}.b-tag{color:var(--ink-3)}.b-conf{font-size:9px;text-transform:uppercase;letter-spacing:.06em;border-color:transparent}.b-conf.high{color:#62b97f;background:color-mix(in oklch,#62b97f 16%,transparent)}.b-conf.med{color:#cf9a3a;background:color-mix(in oklch,#cf9a3a 16%,transparent)}.b-conf.low{color:#c97a5a;background:color-mix(in oklch,#c97a5a 16%,transparent)}.led{font-family:var(--font-mono);font-weight:500;font-size:12px;letter-spacing:.02em;color:var(--ink);padding:3px 7px;border-radius:var(--r-sm);min-width:42px;text-align:center;background:var(--recess);border:1px solid var(--line-2);position:relative;overflow:hidden;font-variant-numeric:tabular-nums}.led .ghost{display:none}.led span{position:relative;z-index:1}.prow .led{font-size:12.5px;min-width:52px}.knob{position:relative;cursor:ns-resize;touch-action:none}.knob svg{display:block}.knob:active{cursor:grabbing}.knob .track{stroke:var(--knob-track)}.knob .fill{stroke:var(--accent)}.knob .ind{stroke:var(--ink)}.knob:hover .fill{stroke:color-mix(in oklch,var(--accent) 80%,var(--ink))}.fader{position:relative;height:22px;display:flex;align-items:center}.fader .track2{position:absolute;left:0;right:0;height:4px;border-radius:4px;background:var(--recess);border:1px solid var(--line)}.fader .fill2{position:absolute;left:0;height:4px;border-radius:4px;background:var(--accent)}.fader input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;margin:0;opacity:0;cursor:pointer}.fader .cap2{position:absolute;width:6px;height:16px;border-radius:2px;transform:translate(-50%);top:3px;pointer-events:none;background:var(--ink-2);border:1px solid var(--surface)}.fader:hover .cap2{background:var(--ink)}.cell-ctl{width:100%;min-height:56px;display:flex;align-items:center;justify-content:center}.fader .fill2.bip{background:color-mix(in oklch,var(--accent) 72%,var(--ink))}.toggle,.segmented{display:flex;gap:3px;width:100%;flex-wrap:wrap}.toggle-opt,.seg-opt{flex:1 1 0;min-width:0;padding:5px 6px;border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-2);border-radius:var(--r-sm);font-family:var(--font-ui);font-size:11px;line-height:1.15;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:.1s}.toggle-opt:hover,.seg-opt:hover{border-color:var(--ink-3);color:var(--ink)}.toggle-opt.on,.seg-opt.on{background:color-mix(in oklch,var(--accent) 20%,var(--surface-2));border-color:var(--accent);color:var(--ink)}.toggle.disabled,.segmented.disabled{opacity:.42;pointer-events:none}.pdrop{width:100%;padding:6px 8px;border:1px solid var(--line-2);border-radius:var(--r-sm);background:var(--surface-2);color:var(--ink);font-family:var(--font-ui);font-size:12px;cursor:pointer;transition:.1s}.pdrop:hover{border-color:var(--ink-3)}.pdrop.disabled,.pdrop:disabled{opacity:.42;pointer-events:none}.log{font-family:var(--font-mono);font-size:11px;line-height:1.65;max-height:176px;overflow-y:auto}.log-line{display:flex;gap:7px;color:var(--ink-2);white-space:nowrap}.log-line .t{color:var(--ink-3)}.log-line.dry .tag{color:#cf9a3a}.log-line.live .tag{color:#62b97f}.log-line .tag{font-weight:700}.log-empty{color:var(--ink-3);font-style:italic}.empty{text-align:center;padding:56px 20px;color:var(--ink-3);font-family:var(--font-mono);font-size:12px}@media (max-width: 1080px){.shell{grid-template-columns:290px 1fr}.prow{grid-template-columns:170px 78px 1fr 60px auto;gap:10px}}.knob.disabled{opacity:.38;pointer-events:none}.fader.disabled{opacity:.42}.fader.disabled input{pointer-events:none}.banner{padding:8px 10px;border-radius:var(--r-md);margin-top:8px;font-size:11.5px;line-height:1.45;border:1px solid}.banner.warn{color:#cf9a3a;border-color:color-mix(in oklch,#cf9a3a 42%,transparent);background:color-mix(in oklch,#cf9a3a 9%,transparent)}.banner.danger{color:#d2705a;border-color:color-mix(in oklch,#cf4d3a 48%,transparent);background:color-mix(in oklch,#cf4d3a 9%,transparent)}.banner.ok{color:#62b97f;border-color:color-mix(in oklch,#62b97f 42%,transparent);background:color-mix(in oklch,#62b97f 9%,transparent)}.main{overflow:hidden;padding:0;display:grid;grid-template-rows:1fr auto;gap:8px;min-height:0}.main-scroll{overflow-y:auto;padding:2px 6px 24px 2px;min-height:0}.main-scroll::-webkit-scrollbar{width:9px}.main-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px;border:2px solid transparent;background-clip:padding-box}.console-dock{display:flex;flex-direction:column;min-height:0;max-height:240px}.console-dock .panel-h{margin-bottom:8px;justify-content:space-between}.console-log{font-family:var(--font-mono);font-size:11px;line-height:1.6;overflow-y:auto;flex:1}.console-log .empty-line{color:var(--ink-3);font-style:italic}.console-log .entry{padding:3px 0;border-bottom:1px solid var(--line)}.console-log .entry:last-child{border-bottom:none}.console-log .time{color:var(--ink-3)}.console-log .lvl-ok{color:#62b97f;font-weight:700}.console-log .lvl-info{color:var(--ink-2);font-weight:700}.console-log .lvl-warn{color:#cf9a3a;font-weight:700}.console-log .lvl-error{color:#cf4d3a;font-weight:700}.hex{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);background:var(--recess);border:1px solid var(--line);border-radius:var(--r-sm);padding:6px 8px;margin-top:4px;white-space:pre-wrap;word-break:break-all}.ok{color:#62b97f}.warn{color:#cf9a3a}.play-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}.chan-btn{--h: 30;position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-height:56px;padding:8px 9px 7px;text-align:left;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:border-color .1s,background .1s,box-shadow .1s}.chan-btn:hover{border-color:var(--ink-3)}.chan-dot{position:absolute;top:9px;right:9px;width:7px;height:7px;border-radius:50%;background:hsl(var(--h) 55% 52%);opacity:.35;transition:.12s}.chan-num{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.07em;color:var(--ink-3);line-height:1}.chan-name{font-size:11.5px;font-weight:600;color:var(--ink);line-height:1;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chan-count{font-family:var(--font-mono);font-size:9px;letter-spacing:.03em;color:var(--ink-3);line-height:1;margin-top:1px}.chan-latch{font-family:var(--font-mono);font-size:9px;letter-spacing:.04em;color:hsl(var(--h) 80% 66%);line-height:1;margin-top:1px;font-weight:600}.chan-btn.active{border-color:var(--accent);background:color-mix(in oklch,var(--surface-2) 84%,var(--accent))}.chan-btn.active .chan-num{color:var(--accent)}.chan-btn.active .chan-dot{opacity:1;box-shadow:0 0 7px hsl(var(--h) 85% 58%)}.chan-btn.held{border-color:hsl(var(--h) 68% 50%);box-shadow:inset 0 0 0 1px hsl(var(--h) 70% 48% / .55),0 0 10px hsl(var(--h) 75% 45% / .22)}.chan-btn.held .chan-dot{opacity:1;box-shadow:0 0 8px hsl(var(--h) 88% 58%);background:hsl(var(--h) 85% 58%)}.play-meta{display:flex;align-items:flex-end;gap:14px;margin-top:13px;flex-wrap:wrap}.octrow{display:flex;align-items:center;gap:6px}.octbtn{width:31px;height:31px;display:grid;place-items:center;cursor:pointer;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-2);transition:.1s}.octbtn:hover{border-color:var(--ink-3);color:var(--ink)}.octval{font-family:var(--font-mono);font-size:13px;min-width:22px;text-align:center;color:var(--ink);font-variant-numeric:tabular-nums}.play-meta .field input[type=number]{width:100%}.play-active{--h: 30;display:flex;align-items:center;gap:7px;margin-left:auto;align-self:flex-end;padding-bottom:1px}.pa-dot{width:8px;height:8px;border-radius:50%;background:hsl(var(--h) 80% 58%);box-shadow:0 0 7px hsl(var(--h) 85% 55%);flex:none}.pa-txt{font-family:var(--font-mono);font-size:11px;color:var(--ink-2);white-space:nowrap}.pa-mode{font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:.08em;color:hsl(var(--h) 75% 66%);border:1px solid hsl(var(--h) 60% 45% / .5);border-radius:3px;padding:1px 4px;line-height:1.3}.keys{position:relative;display:flex;gap:2px;height:118px;margin-top:14px;padding:5px;border-radius:6px;background:var(--recess);border:1px solid var(--line);touch-action:none}.keys.disabled{opacity:.6;pointer-events:none;filter:grayscale(.3)}.key{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none}.key.white{flex:1;min-width:0;border-radius:0 0 4px 4px;background:linear-gradient(#f6f6f4,#e4e4e1);border:1px solid #c4c4c0;border-top:none;display:flex;align-items:flex-end;justify-content:center;padding-bottom:7px;box-shadow:inset 0 -3px 4px #0000000f}.key.white:active{background:linear-gradient(#eee,#dcdcd9)}.key.white.lit{box-shadow:inset 0 -3px 6px #0000001f}.key-lbl{font-family:var(--font-mono);font-size:8.5px;color:#9a9a96;pointer-events:none}.key.white.lit .key-lbl{color:#0000008c}.key.black{position:absolute;top:5px;width:7.6%;height:60%;transform:translate(-50%);z-index:2;border-radius:0 0 3px 3px;background:linear-gradient(#34343a,#0b0b0d);border:1px solid #000;box-shadow:0 2px 4px #0000008c}.key.black:active{background:linear-gradient(#222,#000)}.play-actions{display:flex;gap:8px;margin-top:11px}.play-actions .btn{flex:1}.btn.hold-on{border-color:var(--accent);color:var(--accent);background:color-mix(in oklch,var(--surface-2) 82%,var(--accent))}.play-hint{margin:11px 0 0;font-size:11px;line-height:1.55;color:var(--ink-3);text-wrap:pretty}.play-hint b{color:var(--ink-2);font-weight:600}.panel-expand{position:absolute;top:9px;right:12px;z-index:5;width:22px;height:22px;padding:0;display:grid;place-items:center;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-3);cursor:pointer;transition:.1s}.panel-expand svg{display:block}.panel-expand:hover{color:var(--ink);border-color:var(--ink-3)}.name-input{width:100%;text-align:center;font-family:var(--font-mono);font-weight:700;letter-spacing:.04em}.live-note{font-size:10.5px;line-height:1.5;color:var(--ink-3);margin-bottom:8px}.live-group{margin-top:8px}.live-group-h{font-size:11px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.live-group-h .muted{font-weight:400;text-transform:none;letter-spacing:0;color:var(--ink-3)}.live-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.live-list li{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11.5px;color:var(--ink-2);padding:2px 0}.live-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:100%;max-width:560px;max-height:calc(100vh - 48px);overflow:auto;border:1px solid var(--line-2);border-radius:var(--r-lg);padding:16px 18px 18px;box-shadow:0 18px 48px #00000080;outline:none}.modal-wide{max-width:920px}.modal-h{display:flex;align-items:center;gap:8px;margin-bottom:14px}.modal-h h3{flex:1;margin:0;font-family:var(--font-label);font-size:14px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink)}.modal-x{padding:4px 10px;line-height:1}.modal-body{display:block}.perf-table-wrap{overflow-x:auto;border:1px solid var(--line-2);border-radius:var(--r-md)}.perf-table{width:100%;border-collapse:collapse;font-size:12px}.perf-table th,.perf-table td{padding:5px 7px;text-align:center;border-bottom:1px solid var(--line)}.perf-table thead th{position:sticky;top:0;background:var(--surface-2);color:var(--ink-2);font-family:var(--font-label);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.perf-table tbody tr{opacity:.5}.perf-table tbody tr.on{opacity:1}.perf-table tbody tr:hover{background:color-mix(in oklch,var(--surface-2) 60%,transparent)}.perf-idx{font-family:var(--font-mono);color:var(--ink-3)}.perf-num{width:56px;padding:5px 6px;text-align:center}.perf-sel{width:56px;padding:5px 20px 5px 6px}.perf-name{width:110px;padding:5px 8px;text-align:left}.panel-h-action{margin-left:auto}.perf-edit-link{display:block;margin:9px 0 0;padding:0;background:none;border:none;font-family:var(--font-mono);font-size:10px;letter-spacing:.03em;color:var(--ink-3);cursor:pointer;text-align:left}.perf-edit-link:hover{color:var(--ink-2)}.play-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0000009e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:pm-fade .14s ease both}@keyframes pm-fade{0%{opacity:0}to{opacity:1}}.play-modal{width:min(1120px,96vw);max-height:92vh;overflow-y:auto;background:var(--bg);border:1px solid var(--line-2);border-radius:16px;box-shadow:0 30px 90px #0000008c;padding:22px 26px 26px;display:flex;flex-direction:column;gap:18px;animation:pm-rise .16s cubic-bezier(.2,.7,.3,1) both}@keyframes pm-rise{0%{transform:translateY(10px) scale(.99);opacity:0}to{transform:none;opacity:1}}.pm-head{display:flex;align-items:center;gap:11px}.pm-head .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 7px var(--accent);flex:none}.pm-head h2{margin:0;font-family:var(--font-label);font-weight:700;font-size:16px;letter-spacing:.01em;color:var(--ink)}.pm-sub{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:.03em}.pm-close{margin-left:auto;width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-2);cursor:pointer;transition:.1s}.pm-close:hover{color:var(--ink);border-color:var(--ink-3)}.pm-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}@media (max-width: 720px){.pm-strip{grid-template-columns:repeat(3,1fr)}}.chan-card{--h: 30;position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:11px 12px;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--r-md);border:1px solid var(--line-2);background:var(--surface);transition:border-color .1s,background .1s,box-shadow .1s}.chan-card:hover{border-color:var(--ink-3)}.chan-card.active{border-color:var(--accent);background:color-mix(in oklch,var(--surface) 82%,var(--accent))}.chan-card.active .chan-num{color:var(--accent)}.chan-card.active .chan-dot{opacity:1;box-shadow:0 0 7px hsl(var(--h) 85% 58%)}.chan-card.held{border-color:hsl(var(--h) 68% 50%);box-shadow:inset 0 0 0 1px hsl(var(--h) 70% 48% / .5),0 0 12px hsl(var(--h) 75% 45% / .22)}.chan-card.held .chan-dot{opacity:1;background:hsl(var(--h) 85% 58%);box-shadow:0 0 8px hsl(var(--h) 88% 58%)}.chan-card .chan-name{font-size:13px}.chan-notes{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.02em;color:hsl(var(--h) 70% 66%);line-height:1.3;min-height:1.3em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.chan-notes.dim{color:var(--ink-3)}.chan-card-btns{display:flex;gap:6px;margin-top:4px;width:100%}.chan-mini{flex:1;font-family:var(--font-mono);font-size:10px;letter-spacing:.03em;padding:5px 6px;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--surface-2);color:var(--ink-2);cursor:pointer;transition:.1s}.chan-mini:hover{border-color:var(--ink-3);color:var(--ink)}.chan-mini.on{border-color:hsl(var(--h) 68% 52%);color:hsl(var(--h) 80% 68%);background:hsl(var(--h) 60% 45% / .18)}.pm-settings{display:flex;align-items:flex-end;gap:22px;flex-wrap:wrap;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.pm-range{width:100%;accent-color:var(--accent);cursor:pointer}.pm-master{display:flex;gap:8px;margin-left:auto}.seg{display:flex;gap:4px;padding:3px;border-radius:var(--r-sm);background:var(--recess);border:1px solid var(--line)}.seg-btn{font-family:var(--font-mono);font-size:11px;padding:5px 10px;border:none;border-radius:5px;background:transparent;color:var(--ink-3);cursor:pointer;transition:.1s}.seg-btn:hover{color:var(--ink-2)}.seg-btn.on{background:var(--surface-2);color:var(--ink);box-shadow:0 1px 2px #0000004d}.pm-active{--h: 30;display:flex;align-items:center;gap:9px}.pm-active .pa-txt{font-size:12px}.keys-big{height:220px;padding:6px}.keys-big .key.white{border-radius:0 0 5px 5px;padding-bottom:10px}.keys-big .key-lbl{font-size:10px}.keys-big .key.black{top:6px;height:62%;border-radius:0 0 4px 4px}.rec-row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}.rec-row .rec-btn{display:inline-flex;align-items:center;gap:6px}.rec-glyph{font-size:11px;line-height:1}.rec-btn.rec-armed{color:var(--accent);border-color:color-mix(in oklch,var(--accent) 55%,transparent)}.rec-btn.rec-armed .rec-glyph{animation:rec-pulse 1s ease-in-out infinite}@keyframes rec-pulse{0%,to{opacity:1}50%{opacity:.25}}.rec-bpm{display:flex;flex-direction:column;gap:4px;font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2)}.rec-bpm .inp{width:64px}.rec-status{display:flex;align-items:center;gap:8px;margin:10px 0 0;font-size:12px;color:var(--ink-2)}.rec-status-txt{font-family:var(--font-mono)}.rec-pip{width:8px;height:8px;border-radius:50%;flex:none;background:var(--ink-3)}.rec-pip.armed,.rec-pip.recording{background:var(--accent)}.rec-pip.recording{animation:rec-pulse 1s ease-in-out infinite}.rec-pip.playing{background:#57b87a}
