@font-face{font-family:Vulf Mono;src:url(/patchNet/assets/VulfMono-Regular-DVMvfemx.woff2) format("woff2");font-weight:400;font-style:normal}@font-face{font-family:Vulf Mono;src:url(/patchNet/assets/VulfMono-Bold-DY4GHCcr.otf) format("opentype");font-weight:700;font-style:normal}@font-face{font-family:Vulf Sans;src:url(/patchNet/assets/VulfSans-Regular-B6r_8rLc.woff2) format("woff2");font-weight:400;font-style:normal}@font-face{font-family:Vulf Sans;src:url(/patchNet/assets/VulfSans-Bold-D6KgGF1i.otf) format("opentype");font-weight:700;font-style:normal}:root{--pn-bg-deep: #000000;--pn-bg: #000000;--pn-surface: #000000;--pn-surface-raised: #000000;--pn-surface-glow: rgba(0, 255, 0, .35);--pn-border: rgba(0, 255, 0, .42);--pn-border-subtle: rgba(0, 255, 0, .35);--pn-border-accent: rgba(0, 255, 0, .7);--pn-border-accent-soft: rgba(0, 255, 0, .48);--pn-text: #00ff00;--pn-text-dim: rgba(0, 255, 0, .8);--pn-muted: rgba(0, 255, 0, .6);--pn-muted-deep: rgba(0, 255, 0, .45);--pn-accent: #00ff00;--pn-accent-dim: #008000;--pn-accent-glow: rgba(0, 255, 0, .48);--pn-secondary: #00ff00;--pn-secondary-soft: rgba(0, 255, 0, .45);--pn-group: #00ff00;--pn-group-soft: rgba(0, 255, 0, .42);--pn-cyan: #00ff00;--pn-cyan-soft: rgba(0, 255, 0, .38);--pn-danger: #00ff00;--pn-warning: #00ff00;--pn-info: #00ff00;--pn-cable: #00ff00;--pn-cable-audio: #00ff00;--pn-cable-selected: #00ff00;--pn-object-bg: #000000;--pn-object-border: rgba(0, 255, 0, .48);--pn-object-border-active: #00ff00;--pn-port-in: rgba(0, 255, 0, .65);--pn-port-out: #00ff00;--pn-canvas-grid: rgba(0, 255, 0, .22);--pn-shadow-inset: inset 0 1px 0 rgba(0, 255, 0, .35);--pn-shadow-panel: 0 18px 56px rgba(0, 0, 0, .7);--pn-shadow-soft: 0 4px 24px rgba(0, 0, 0, .5);--pn-shadow-halo: inset 0 1px 0 rgba(0, 255, 0, .35), inset 0 -1px 0 rgba(0, 0, 0, .3);--pn-hover: rgba(0, 255, 0, .2);--pn-hover-accent: rgba(0, 255, 0, .3);--pn-active: rgba(0, 255, 0, .25);--pn-active-accent: rgba(0, 255, 0, .38);--pn-focus-ring: 0 0 0 2px var(--pn-accent);--pn-font-mono: "Vulf Mono", monospace;--pn-font-sans: "Vulf Sans", sans-serif;--pn-type-display: 2rem;--pn-type-title: 1.25rem;--pn-type-heading: 1.0625rem;--pn-type-body: .9375rem;--pn-type-ui: .875rem;--pn-type-helper: .8125rem;--pn-type-chip: .75rem;--pn-type-micro: .6875rem;--pn-type-object-label: .6875rem;--pn-type-object-name: .75rem;--pn-space-1: 2px;--pn-space-2: 4px;--pn-space-3: 6px;--pn-space-4: 8px;--pn-space-5: 12px;--pn-space-6: 16px;--pn-space-7: 20px;--pn-space-8: 24px;--pn-space-9: 32px;--pn-space-10: 48px;--pn-radius-xs: 3px;--pn-radius-sm: 6px;--pn-radius-md: 10px;--pn-radius-lg: 14px;--pn-radius-pill: 9999px;--pn-object-radius: 4px;--pn-port-size: 8px;--pn-port-radius: 50%;--pn-attrui-header-h: 22px;--pn-attrui-row-h: 24px}:root{--pn-cursor-default: url(/patchNet/assets/normal-select-D6mr-EY6.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M4 3L4 19L8 15L11 21L13 20L10 14L16 14Z' fill='%236aff91' stroke='%23020402' stroke-width='1.5' stroke-linejoin='miter' paint-order='stroke fill'/%3E%3C/svg%3E") 4 3, auto;--pn-cursor-pointer: url(/patchNet/assets/link-select-CSYFDzEA.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cpath d='M10 1 Q13 1 13 4 L13 12 C13 8.5 17 8.5 17 12 C17 8.5 21 8.5 21 12 C21 8.5 25 9 25 12.5 L25 31 L4 31 L4 22 Q2 22 1 20 Q0.5 17 1 14 Q1.5 12 3.5 12 L7 12 Q8 12 8 11 L8 4 Q8 1 10 1 Z' fill='%23ffffff' stroke='%23020402' stroke-width='1.8' stroke-linejoin='round' stroke-linecap='round' paint-order='stroke fill'/%3E%3Cpath d='M4 22 Q5.5 18 7.5 13' fill='none' stroke='%23020402' stroke-width='1.3' stroke-linecap='round'/%3E%3C/svg%3E") 10 1, pointer;--pn-cursor-finger: var(--pn-cursor-pointer);--pn-cursor-text: url(/patchNet/assets/text-select-BHrrYCXN.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Crect x='10' y='4' width='4' height='16' fill='%236aff91' fill-opacity='.18'/%3E%3Cpath d='M8 4H16M12 4V20M8 20H16' fill='none' stroke='%236aff91' stroke-width='2' stroke-linecap='square'/%3E%3C/svg%3E") 12 12, text;--pn-cursor-crosshair: url(/patchNet/assets/precision-select-CNKlBwPH.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Ccircle cx='12' cy='12' r='4' fill='none' stroke='%236aff91' stroke-width='1.7'/%3E%3Cpath d='M12 2V7M12 17V22M2 12H7M17 12H22' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square'/%3E%3C/svg%3E") 12 12, crosshair;--pn-cursor-grab: url(/patchNet/assets/move-CwcgPSzo.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M12 3V21M3 12H21M12 3L9 6M12 3L15 6M12 21L9 18M12 21L15 18M3 12L6 9M3 12L6 15M21 12L18 9M21 12L18 15' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E") 12 12, grab;--pn-cursor-grabbing: url(/patchNet/assets/move-CwcgPSzo.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Crect x='9' y='9' width='6' height='6' fill='%236aff91' fill-opacity='.24' stroke='%236aff91' stroke-width='1.4'/%3E%3Cpath d='M12 3V8M12 16V21M3 12H8M16 12H21M12 3L9 6M12 3L15 6M12 21L9 18M12 21L15 18M3 12L6 9M3 12L6 15M21 12L18 9M21 12L18 15' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E") 12 12, grabbing;--pn-cursor-resize: url(/patchNet/assets/diagonal-resize-1-DTpxLx0x.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M6 6L18 18M6 6H12M6 6V12M18 18H12M18 18V12' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E") 12 12, nwse-resize;--pn-cursor-col-resize: url(/patchNet/assets/horizontal-resize-Dd21_or4.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M4 12H20M4 12L8 8M4 12L8 16M20 12L16 8M20 12L16 16M12 6V18' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E") 12 12, col-resize;--pn-cursor-row-resize: url(/patchNet/assets/vertical-resize-BsOjLOqn.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M12 4V20M12 4L8 8M12 4L16 8M12 20L8 16M12 20L16 16' fill='none' stroke='%236aff91' stroke-width='1.7' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E") 12 12, ns-resize;--pn-cursor-cable: url(/patchNet/assets/handwriting-DHx3LfHo.cur), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Ccircle cx='12' cy='5.5' r='3' fill='%236aff91' stroke='%23020402' stroke-width='1.2'/%3E%3Ccircle cx='12' cy='18.5' r='3' fill='%236aff91' stroke='%23020402' stroke-width='1.2'/%3E%3Cpath d='M12 8.5 L12 15.5' stroke='%236aff91' stroke-width='2.2' stroke-linecap='round'/%3E%3C/svg%3E") 12 12, pointer;--pn-cursor-not-allowed: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Ccircle cx='12' cy='12' r='8' fill='none' stroke='%23ff5577' stroke-width='2'/%3E%3Cpath d='M6.3 17.7 L17.7 6.3' stroke='%23ff5577' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") 12 12, not-allowed}*{cursor:var(--pn-cursor-default)!important}body.pn-state-panning *{cursor:var(--pn-cursor-grabbing)!important}body.pn-state-pan-ready *{cursor:var(--pn-cursor-grab)!important}body.pn-state-slider-drag *{cursor:var(--pn-cursor-pointer)!important}body.pn-state-numbox-drag *{cursor:var(--pn-cursor-row-resize)!important}input:not([type=range]),textarea,[contenteditable],.pn-object-entry-input{cursor:var(--pn-cursor-text)!important;caret-color:var(--pn-accent);caret-shape:block}input[type=range]{cursor:var(--pn-cursor-pointer)!important}.text-panel,.text-panel *{cursor:var(--pn-cursor-default)!important}.text-panel textarea{cursor:var(--pn-cursor-text)!important}body{background:radial-gradient(circle at top,rgba(0,255,0,.38),transparent 32%),radial-gradient(circle at center,rgba(0,255,0,.35),transparent 60%),linear-gradient(180deg,#000000,var(--pn-bg-deep));color:var(--pn-text);font-family:var(--pn-font-sans);margin:0;height:100vh;display:flex;flex-direction:column;overflow:hidden;overscroll-behavior-x:none}html{overscroll-behavior-x:none}#app{flex:1;display:flex;flex-direction:column;min-height:0}.toolbar{background:var(--pn-surface-raised);border-bottom:1px solid var(--pn-border);box-shadow:0 1px 20px #00ff0073;display:flex;flex-direction:row;align-items:center;padding:0 20px;gap:10px;font-family:"Vulf Sans",var(--pn-font-sans);font-size:var(--pn-type-body)}.toolbar--logo{height:80px}.toolbar--controls{height:56px;overflow:hidden;transition:height .15s ease,border-color .15s ease,box-shadow .15s ease}.toolbar--controls.toolbar--collapsed{height:0;padding-top:0;padding-bottom:0;border-bottom-color:transparent;box-shadow:none}.toolbar-collapse-btn{background:none;border:1px solid var(--pn-border);color:var(--pn-muted);font-family:"Vulf Mono",var(--pn-font-mono);font-size:14px;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:var(--pn-cursor-pointer);transition:color .1s,transform .15s,border-color .1s}.toolbar-collapse-btn:hover{color:var(--pn-accent);border-color:var(--pn-accent)}.toolbar-collapse-btn[aria-expanded=true]{transform:rotate(180deg)}.toolbar .app-title{display:block;height:75px;width:auto;filter:brightness(1.4) drop-shadow(0 0 10px var(--pn-accent));-webkit-user-select:none;user-select:none;-webkit-user-drag:none;transform-origin:center center;transform:translate(41px) scale(1.85,1.15)}.pn-tab-row{display:flex;flex-direction:row;align-items:stretch;background:var(--pn-surface);border-bottom:1px solid var(--pn-border);flex-shrink:0}.pn-tab-row>#pn-tab-bar{flex:1;border-bottom:none}.patch-name-wrap{flex-shrink:0;align-self:stretch;display:inline-flex;align-items:center;margin:0 8px;padding:0 8px;border:1px solid transparent;border-radius:2px;background:transparent;max-width:360px;min-width:200px;transition:border-color .12s,background .12s}.patch-name-wrap:hover{border-color:var(--pn-border)}.patch-name-wrap:focus-within{border-color:var(--pn-accent);background:#00ff000a}.patch-name-input{flex:1;min-width:0;outline:none;color:var(--pn-accent);font-family:"Vulf Mono",var(--pn-font-mono);font-size:var(--pn-type-body);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;text-shadow:0 0 6px rgba(0,255,0,.55);caret-color:transparent}.patch-name-input:empty:before{content:attr(data-placeholder);color:var(--pn-muted);opacity:.6;text-shadow:none;pointer-events:none}.patch-name-caret{flex-shrink:0;width:.55em;height:1.05em;margin-left:1px;background:var(--pn-accent);box-shadow:0 0 6px #00ff008c;visibility:hidden}.patch-name-wrap:focus-within .patch-name-caret{visibility:visible;animation:pn-patch-name-blink 1.05s steps(2,jump-none) infinite}@keyframes pn-patch-name-blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.patch-name-input::placeholder{color:var(--pn-muted);opacity:.6;text-shadow:none}.patch-name-input:hover{border-color:var(--pn-border)}.patch-name-input:focus{border-color:var(--pn-accent);background:#00ff000a}.toolbar-separator{width:1px;height:40px;background:var(--pn-border);flex-shrink:0;margin:0 4px}.toolbar-audio-btn{display:flex;align-items:center;gap:6px;height:36px;padding:0 14px;background:var(--pn-object-bg);border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);letter-spacing:.06em;cursor:var(--pn-cursor-pointer);transition:color .1s,border-color .1s,box-shadow .1s}.toolbar-audio-btn:hover{color:var(--pn-accent);border-color:var(--pn-border-accent);box-shadow:0 0 8px #00ff0085}.toolbar-audio-btn--on{color:var(--pn-accent);border-color:var(--pn-border-accent);box-shadow:0 0 8px #0f06,0 0 16px #00ff006b;text-shadow:0 0 6px var(--pn-accent)}.toolbar-audio-icon{font-size:11px;line-height:1}.toolbar-audio-device{height:36px;padding:0 8px;background:var(--pn-object-bg);border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);max-width:160px;cursor:var(--pn-cursor-pointer);outline:none;transition:border-color .1s,color .1s}.toolbar-audio-device:hover,.toolbar-audio-device:focus{border-color:var(--pn-border-accent);color:var(--pn-text)}.toolbar-audio-device option{background:var(--pn-surface-raised);color:var(--pn-text)}.toolbar-vol-wrap{display:flex;align-items:center;gap:5px}.toolbar-vol-label{font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);color:var(--pn-muted);letter-spacing:.06em}.toolbar-vol-readout{font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);color:var(--pn-muted);min-width:24px;text-align:right}.toolbar-vol-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:4px;background:var(--pn-border);border-radius:2px;outline:none;cursor:var(--pn-cursor-pointer)}.toolbar-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent);cursor:var(--pn-cursor-pointer)}.toolbar-vol-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent);border:none;cursor:var(--pn-cursor-pointer)}.workspace{flex:1;display:flex;flex-direction:row;overflow:hidden;min-height:0}.pn-terminal{position:fixed;left:0;right:0;bottom:0;z-index:280;height:min(190px,36vh);display:flex;flex-direction:column;background:var(--pn-surface-raised);border-top:1px solid var(--pn-border-accent);box-shadow:0 -1px 22px #00ff006b;color:var(--pn-text);font-family:var(--pn-font-mono);transform:translateY(100%);transition:transform .14s ease}.pn-terminal.is-open{transform:translateY(0)}.pn-terminal__header,.pn-terminal__prompt{display:flex;align-items:center;gap:10px;padding:8px 14px}.pn-terminal__header{border-bottom:1px solid var(--pn-border);background:var(--pn-surface);min-height:34px}.pn-terminal__title{color:var(--pn-accent);font-size:var(--pn-type-micro);letter-spacing:.08em;text-transform:uppercase}.pn-terminal__spacer{flex:1}.pn-terminal__shortcut{color:var(--pn-muted);font-size:var(--pn-type-micro)}.pn-terminal__close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--pn-border);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:13px;line-height:1;cursor:var(--pn-cursor-pointer)}.pn-terminal__close:hover,.pn-terminal__close:focus-visible{border-color:var(--pn-accent);color:var(--pn-accent);outline:none}.pn-terminal__log{flex:1;min-height:0;overflow:auto;padding:8px 14px;background:#00000047;scrollbar-width:thin;scrollbar-color:rgba(0,255,0,.42) transparent}.pn-terminal__log-row{min-height:18px;color:var(--pn-text-dim);font-size:var(--pn-type-micro);line-height:1.35;white-space:pre-wrap;word-break:break-word}.pn-terminal__log-row--input{color:var(--pn-text)}.pn-terminal__log-row--ok{color:var(--pn-accent)}.pn-terminal__log-row--error,.pn-terminal__status.is-error{color:var(--pn-danger)}.pn-terminal__prompt{border-top:1px solid var(--pn-border);background:var(--pn-surface-raised);padding-top:7px;padding-bottom:7px}.pn-terminal__prompt-mark{color:var(--pn-accent)}.pn-terminal__input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--pn-text);caret-color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:13px}.pn-terminal__input::placeholder{color:var(--pn-muted)}.pn-terminal__status{min-height:22px;padding:3px 14px 6px;color:var(--pn-muted);font-size:var(--pn-type-micro);border-top:1px solid rgba(0,255,0,.1)}.canvas-area{flex:1;position:relative;background-color:var(--pn-surface);overflow:scroll;min-width:0;overscroll-behavior-x:contain;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .25s}.canvas-area:hover{scrollbar-color:rgba(0,255,0,.5) transparent}.canvas-area::-webkit-scrollbar{width:6px;height:6px}.canvas-area::-webkit-scrollbar-track{background:transparent}.canvas-area::-webkit-scrollbar-corner{background:transparent}.canvas-area::-webkit-scrollbar-thumb{background:transparent;border-radius:3px;transition:background .25s}.canvas-area:hover::-webkit-scrollbar-thumb{background:#00ff0080}.canvas-grid{display:none}.pn-rulers{position:absolute;pointer-events:none;z-index:90}.pn-rulers-corner{background:var(--pn-surface-raised);border-right:1px solid color-mix(in srgb,var(--pn-accent) 40%,transparent);border-bottom:1px solid color-mix(in srgb,var(--pn-accent) 40%,transparent)}.pn-rulers-x,.pn-rulers-y{background:var(--pn-surface-raised)}.patch-object{position:absolute;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--pn-object-border);border-radius:var(--pn-object-radius);background:var(--pn-object-bg);box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c;color:var(--pn-text);font-family:var(--pn-font-mono);container-type:size}.patch-object-body{position:relative;z-index:1;display:flex;flex:1;min-height:0;overflow:hidden;flex-direction:column;align-items:center;justify-content:center;gap:var(--pn-space-2);padding:var(--pn-space-3)}.patch-object-title{font-size:clamp(8px,min(24cqw,48cqh),24px);line-height:1;text-align:center;color:var(--pn-text);letter-spacing:.04em;text-shadow:0 0 8px rgba(0,255,0,.55);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.patch-object-body--args-inline{justify-content:flex-start;padding-top:10px}.patch-object-meta{font-size:clamp(7px,min(16cqw,34cqh),18px);line-height:1;color:var(--pn-text-dim);text-shadow:0 0 6px rgba(0,255,0,.35)}.patch-object-glyph{color:var(--pn-secondary);text-shadow:0 0 8px rgba(0,255,0,.6)}.patch-object-sr{display:flex;align-items:baseline;gap:5px;line-height:1}.patch-object-sr-type{font-size:clamp(8px,min(24cqw,48cqh),22px);color:var(--pn-secondary);text-shadow:0 0 8px rgba(0,255,0,.55);font-family:var(--pn-font-mono)}.patch-object-sr-channel{font-size:clamp(7px,min(18cqw,38cqh),16px);color:var(--pn-text);font-family:var(--pn-font-mono);opacity:.85}.patch-object--scripting .patch-object-body{padding:0}.patch-object-body .patch-object-slider-track,.patch-object-body .patch-object-slider-track *{cursor:var(--pn-cursor-col-resize)!important}.patch-object-face{pointer-events:none}.patch-object-face-button{width:72%;aspect-ratio:1;max-height:calc(100% - 12px);border:1.5px solid var(--pn-border-accent);border-radius:50%;background:#00ff0059;box-shadow:inset 0 1px #00ff0059,0 0 10px #00ff0085,0 0 22px #0f06;transition:background 60ms ease,box-shadow 60ms ease;pointer-events:auto;cursor:var(--pn-cursor-pointer)!important}.patch-object-codebox{display:flex;flex-direction:column;width:100%;height:100%}.patch-object-codebox-header{display:flex;align-items:center;justify-content:space-between;padding:2px 6px;border-bottom:1px solid var(--pn-border);flex-shrink:0}.patch-object-codebox-name{font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);color:var(--pn-text-dim);letter-spacing:.06em}.patch-object-codebox-badge{font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-accent);border:1px solid var(--pn-accent);border-radius:2px;padding:0 3px;opacity:.8}.patch-object-codebox-host{display:flex;flex:1;flex-direction:column;overflow:hidden;min-height:0}.patch-object-codebox-host .cm-editor{height:100%;background:transparent;font-family:var(--pn-font-mono);font-size:11px;color:var(--pn-text)}.patch-object-codebox-host .cm-scroller{overflow:auto}.patch-object-codebox-host .cm-content{padding:4px 6px}.patch-object-codebox-host .cm-focused{outline:none}.patch-object-codebox-host .cm-cursor,.patch-object-codebox-host .cm-dropCursor{border-left-color:var(--pn-accent)!important}.patch-object-codebox-host,.patch-object-codebox-host *{cursor:var(--pn-cursor-text)!important}.patch-object-codebox-host[data-error=true] .cm-editor{outline:1px solid var(--pn-danger)}.patch-object-codebox-host .pn-codebox-error-msg{font-family:var(--pn-font-mono);font-size:10px;color:var(--pn-danger);padding:2px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patch-object--active .patch-object-face-button{background:var(--pn-accent);box-shadow:0 0 14px var(--pn-accent),0 0 32px #00ff008c,inset 0 1px #00ff007a}.patch-object-toggle{border:none!important;background:transparent!important;box-shadow:none!important}.patch-object-toggle-plate{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:4px 0;border:1.5px solid var(--pn-border-accent);border-radius:4px;background:#00ff000f;box-shadow:0 0 8px #00ff0038,0 0 18px #00ff001a;pointer-events:none;-webkit-user-select:none;user-select:none}.patch-object-toggle-screw{font-size:clamp(6px,min(14cqw,28cqh),14px);line-height:1;color:var(--pn-border-accent);opacity:.6}.patch-object-toggle-rocker{flex:1;width:52%;min-height:0;display:flex;flex-direction:column;border:1px solid var(--pn-border-accent);border-radius:2px;overflow:hidden;margin:2px 0;pointer-events:auto}.patch-object-toggle-rocker,.patch-object-toggle-rocker *{cursor:var(--pn-cursor-pointer)!important}.patch-object-toggle-half{flex:1;display:flex;align-items:center;justify-content:center;font-size:clamp(7px,min(18cqw,38cqh),18px);line-height:1;font-family:var(--pn-font-mono);color:var(--pn-text-dim);background:#00ff000d;transition:background 80ms ease,color 80ms ease,text-shadow 80ms ease}.patch-object-toggle-half-on{border-bottom:1px solid var(--pn-border-accent)}.patch-object-toggle-half--active{color:var(--pn-accent);background:#0f03;text-shadow:0 0 6px var(--pn-accent),0 0 16px rgba(0,255,0,.5)}.patch-object-slider-track{position:relative;width:100%;height:100%;background:transparent;border-radius:0;cursor:var(--pn-cursor-col-resize)!important}.patch-object-slider-thumb{position:absolute;top:0;width:4px;height:100%;background:var(--pn-accent);box-shadow:0 0 8px var(--pn-accent),0 0 20px #00ff0073;transform:translate(-50%);border-radius:1px;transition:box-shadow .1s}.patch-object-integer .patch-object-body,.patch-object-float .patch-object-body{padding:0;overflow:hidden}.patch-object-integer,.patch-object-float{min-width:52px;min-height:36px;border-color:var(--pn-accent)}.pn-odometer{display:flex;align-items:stretch;width:100%;height:100%;box-sizing:border-box;padding:0;background:transparent;position:relative;-webkit-user-select:none;user-select:none;gap:0}.pn-odo-inner{display:flex;align-items:stretch;flex:1;min-width:0;background:color-mix(in srgb,var(--pn-object-bg) 20%,#000 80%);position:relative;overflow:hidden;border-radius:2px;box-shadow:inset 0 0 0 1px #000c,inset 0 2px 6px #00000080;padding:0 2px;gap:0}.pn-odo-inner:before{content:"";position:absolute;top:0;left:0;right:0;height:32%;background:linear-gradient(to bottom,color-mix(in srgb,var(--pn-object-bg) 20%,#000 80%) 0%,transparent 100%);pointer-events:none;z-index:4}.pn-odo-inner:after{content:"";position:absolute;bottom:0;left:0;right:0;height:32%;background:linear-gradient(to top,color-mix(in srgb,var(--pn-object-bg) 20%,#000 80%) 0%,transparent 100%);pointer-events:none;z-index:4}.pn-odo-sign{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0 2px 0 0;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:clamp(5px,calc(35cqh - 8px),14px);pointer-events:none;opacity:.55}.pn-odo-dot{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:clamp(5px,calc(35cqh - 8px),14px);font-weight:700;pointer-events:none}.pn-odo-col{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-width:0;border-left:1px solid rgba(0,255,0,.35);position:relative;z-index:1}.pn-odo-col:first-of-type{border-left:none}.patch-object-body .pn-odo-col,.patch-object-body .pn-odo-col *{cursor:var(--pn-cursor-row-resize)!important}.pn-odo-above,.pn-odo-below{flex:1;display:flex;align-items:center;justify-content:center;width:100%;font-family:var(--pn-font-mono);font-variant-numeric:tabular-nums;line-height:1;color:#00ff0085;font-size:clamp(4px,calc(20cqh - 4px),10px)}.pn-odo-curr{flex:2;display:flex;align-items:center;justify-content:center;width:100%;font-family:var(--pn-font-mono);font-variant-numeric:tabular-nums;line-height:1;font-weight:600;color:var(--pn-accent);font-size:clamp(6px,calc(40cqh - 9px),18px);text-shadow:0 0 6px currentColor;box-shadow:0 1px #00ff0061,0 -1px #00ff0061}.pn-odometer-input{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;background:color-mix(in srgb,var(--pn-object-bg) 92%,transparent);border:none;outline:1px solid var(--pn-accent);outline-offset:-1px;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:clamp(9px,44cqh,20px);font-weight:600;text-align:center;padding:0 6px;letter-spacing:.06em;caret-color:var(--pn-accent)}.pn-odo-col--active{background:#00ff0059}.pn-odo-col--active .pn-odo-curr{text-shadow:0 0 8px currentColor,0 0 22px currentColor}.patch-object-integer .patch-object-body,.patch-object-float .patch-object-body{padding:0}.patch-object-ports{position:absolute;left:0;width:100%;height:var(--pn-port-size);pointer-events:none;z-index:7}.patch-object-ports-inlet{top:0;transform:translateY(-50%)}.patch-object-ports-outlet{bottom:0;transform:translateY(50%)}.patch-port{position:absolute;top:50%;width:var(--pn-port-size);height:var(--pn-port-size);border:1px solid var(--pn-border);border-radius:var(--pn-port-radius);transform:translate(-50%,-50%);box-sizing:border-box}.patch-port:before{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:50%;background:#0000}.patch-port-inlet{background:color-mix(in srgb,var(--pn-port-in) 40%,transparent);box-shadow:0 0 6px #00ff0059}.patch-port-inlet.patch-port-hot{background:var(--pn-accent)!important;border-color:var(--pn-accent)!important;box-shadow:0 0 6px var(--pn-accent),0 0 12px #00ff0073!important}.patch-port-cold{background:transparent!important;border:2px solid var(--pn-secondary)!important;box-shadow:0 0 4px #00ff0073!important;opacity:1}.pn-port--endpoint{background:color-mix(in srgb,var(--pn-accent) 55%,transparent)!important;border-color:var(--pn-accent)!important;box-shadow:0 0 0 2px #00ff0080,0 0 10px var(--pn-accent),0 0 22px #00ff0073!important;width:18px!important;height:18px!important;transform:translate(-50%,-50%)!important;transition:width .1s ease,height .1s ease,box-shadow .1s ease;z-index:20}.pn-port--snap{background:color-mix(in srgb,var(--pn-accent) 70%,transparent)!important;box-shadow:0 0 10px var(--pn-accent),0 0 22px #00ff008c!important;transform:translate(-50%,-50%) scale(1.6)!important;transition:transform .08s ease,box-shadow .08s ease}.patch-port-outlet{background:color-mix(in srgb,var(--pn-port-out) 40%,transparent);box-shadow:0 0 8px var(--pn-accent),0 0 18px #0f06}.patch-port-type-signal{box-shadow:0 0 0 1px var(--pn-secondary-soft)}.patch-port{pointer-events:all;cursor:var(--pn-cursor-crosshair)!important;overflow:visible;z-index:6}.patch-port:hover{cursor:var(--pn-cursor-crosshair)!important;transform:translate(-50%,-50%) scale(1.55)!important;box-shadow:0 0 10px var(--pn-accent),0 0 24px #00ff008c!important;transition:transform .07s ease,box-shadow .07s ease}.pn-port-tooltip{position:fixed;white-space:nowrap;font-family:var(--pn-font-mono);font-size:11px;line-height:1.3;color:var(--pn-text);background:var(--pn-surface);border:1px solid var(--pn-border);border-radius:4px;padding:4px 8px;box-shadow:0 0 12px #00000059,0 0 18px #0f06;pointer-events:none;z-index:1000;opacity:0}.pn-port-tooltip--visible{opacity:1}.patch-object--selected{border-color:var(--pn-object-border-active)!important;box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 0 2px var(--pn-accent),0 0 24px #0f06,0 0 6px #00ff00b3!important}.patch-object-toggle.patch-object--selected{border:1px solid var(--pn-object-border-active)!important;box-shadow:0 0 0 2px var(--pn-accent),0 0 24px #0f06,0 0 6px #00ff00b3!important}.patch-object--dragging{opacity:.85;cursor:var(--pn-cursor-grabbing)!important;z-index:10}.patch-object--drop-blocked{outline:1px dashed var(--pn-danger);outline-offset:2px}.patch-object--drop-blocked,.patch-object--drop-blocked *{cursor:var(--pn-cursor-not-allowed)!important}.patch-object--grouped{outline:1px dashed var(--pn-group);outline-offset:4px}.patch-object--grouped.patch-object--selected{outline-color:var(--pn-group)}.pn-group-badge{position:absolute;top:-5px;right:-5px;width:8px;height:8px;border-radius:50%;background:var(--pn-group);box-shadow:0 0 6px var(--pn-group);pointer-events:none;z-index:5}.pn-pan-group{position:absolute;top:0;left:0;background-color:var(--pn-surface);background-image:linear-gradient(to right,color-mix(in srgb,var(--pn-accent) 18%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--pn-accent) 18%,transparent) 1px,transparent 1px),linear-gradient(to right,color-mix(in srgb,var(--pn-accent) 8%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--pn-accent) 8%,transparent) 1px,transparent 1px),linear-gradient(to right,color-mix(in srgb,var(--pn-accent) 4%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--pn-accent) 4%,transparent) 1px,transparent 1px);background-size:250px 250px,250px 250px,50px 50px,50px 50px,25px 25px,25px 25px;background-position:0 0;box-shadow:0 0 0 1px color-mix(in srgb,var(--pn-accent) 40%,transparent);-webkit-user-select:none;user-select:none}.pn-pan-group input:not([type=range]),.pn-pan-group textarea,.pn-pan-group [contenteditable],.pn-pan-group .patch-object-codebox-host,.pn-pan-group .patch-object-codebox-host *{-webkit-user-select:text;user-select:text}.pn-cable-hit{cursor:var(--pn-cursor-cable)!important}.pn-cable-seg.pn-cable--hover .pn-cable-vis{stroke-width:2.75px!important;filter:drop-shadow(0 0 6px var(--pn-accent))}.pn-cable-snap-hint{pointer-events:none}.pn-snap-radius-ring{stroke:color-mix(in srgb,var(--pn-accent) 50%,transparent);stroke-width:1px;stroke-dasharray:5 7;opacity:.9;filter:drop-shadow(0 0 4px color-mix(in srgb,var(--pn-accent) 35%,transparent))}[data-canvas-root].pn-drag-over{outline:2px dashed var(--pn-accent);outline-offset:-3px}.patch-object-visual-label{font-family:var(--pn-font-mono);font-size:clamp(8px,min(20cqw,34cqh),18px);color:var(--pn-text);line-height:1.3;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.patch-object-visual-sub{font-family:var(--pn-font-mono);font-size:clamp(7px,min(14cqw,24cqh),14px);color:var(--pn-muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;opacity:.8}.patch-object[data-node-type$="~"]{--pn-meter: 0;border-color:var(--pn-accent);box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 10px #00ff0085,0 0 calc(6px + var(--pn-meter) * 22px) rgba(0,255,0,calc(.35 + var(--pn-meter) * .45)),0 0 calc(var(--pn-meter) * 18px) rgba(0,255,0,calc(var(--pn-meter) * .75));transition:box-shadow .04s linear,border-color .04s linear}.pn-meters{display:flex;flex-direction:row;align-items:flex-end;justify-content:center;gap:4px;width:100%;height:100%;padding:4px 6px 3px;box-sizing:border-box}.pn-meter-col{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;height:100%}.pn-meter-track{position:relative;flex:1;width:100%;max-width:12px;border-radius:1px;overflow:hidden;background:repeating-linear-gradient(to top,rgba(0,0,0,.55) 0px,rgba(0,0,0,.55) 1px,transparent 1px,transparent 4px),#000}.pn-meter-fill{position:absolute;bottom:0;left:0;width:100%;height:0%;background:repeating-linear-gradient(to top,rgba(0,0,0,.55) 0px,rgba(0,0,0,.55) 1px,transparent 1px,transparent 4px),linear-gradient(to top,green,#00b300 55%,#00b300 55%,#0f0 80%,#0f0 80%,#0f0)}.pn-meter-label{font-family:var(--pn-font-mono);font-size:6px;line-height:1;color:#00ff0059;letter-spacing:.05em;text-align:center}.pn-meter-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#00ff0080;margin-bottom:2px}.patch-object[data-node-type="visualizer*"]{border-color:var(--pn-border-accent);box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c}.patch-object[data-node-type="layer*"]{border-color:color-mix(in srgb,var(--pn-accent) 35%,var(--pn-border))}.pn-rubber-band{position:absolute;border:1px dashed var(--pn-accent);background:color-mix(in srgb,var(--pn-accent) 8%,transparent);pointer-events:none;z-index:10}.toolbar-icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;background:none;border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);cursor:var(--pn-cursor-pointer);line-height:1;transition:color .1s,border-color .1s}.toolbar-icon-btn:hover{color:var(--pn-accent);border-color:var(--pn-border-accent);box-shadow:0 0 8px #00ff0059;text-shadow:0 0 8px var(--pn-accent)}.toolbar-icon-btn--toggle[aria-pressed=true]{color:var(--pn-accent);border-color:var(--pn-border-accent);box-shadow:0 0 8px #0f06,0 0 16px #00ff006b;text-shadow:0 0 6px var(--pn-accent)}[data-canvas-root].is-patch-locked .pn-cable-svg{z-index:-1!important;pointer-events:none;opacity:.6}[data-canvas-root].is-patch-locked .pn-cable-hit{pointer-events:none}.pn-resize-handle{position:absolute;bottom:-10px;right:-10px;width:14px;height:14px;cursor:var(--pn-cursor-resize)!important;z-index:5;opacity:0;transition:opacity .15s}.pn-resize-handle:before{content:"";position:absolute;right:10px;bottom:10px;width:10px;height:10px;background:linear-gradient(135deg,transparent 50%,var(--pn-border-accent) 50%);border-bottom-right-radius:var(--pn-object-radius);transition:transform .12s ease,filter .12s ease}.patch-object:hover .pn-resize-handle,.patch-object--selected .pn-resize-handle,.pn-resize-handle:hover,.patch-object--resizing .pn-resize-handle{opacity:1}.pn-resize-handle:hover:before,.patch-object--resizing .pn-resize-handle:before{transform:scale(1.18);filter:drop-shadow(0 0 4px var(--pn-accent)) drop-shadow(0 0 10px rgba(0,255,0,.45))}.patch-object--resizing{opacity:.9;z-index:10}.pn-move-handle{position:absolute;cursor:var(--pn-cursor-grab)!important;z-index:4;background:transparent}.pn-move-handle--top{top:-4px;left:14px;right:14px;height:8px}.pn-move-handle--bottom{bottom:-4px;left:14px;right:18px;height:8px}.pn-move-handle--left{left:-4px;top:14px;bottom:14px;width:8px}.pn-move-handle--right{right:-4px;top:14px;bottom:18px;width:8px}.pn-move-handle--tl{top:-6px;left:-6px;width:14px;height:14px}.pn-move-handle--tr{top:-6px;right:-6px;width:14px;height:14px}.pn-move-handle--bl{bottom:-6px;left:-6px;width:14px;height:14px}.patch-object-slider .patch-object-body,.patch-object-body:has(.patch-object-slider-track){padding:6px 4px}.patch-object-body:has(.pn-ezslider){padding:4px 6px 6px}.pn-ezslider{display:flex;flex-direction:column;gap:4px;width:100%;height:100%;font-family:var(--pn-font-mono)}.pn-ezslider__fields{display:flex;justify-content:space-between;gap:4px}.pn-ezslider__field{width:48%;min-width:0;background:var(--pn-object-bg);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-object-radius);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-object-name);padding:1px 4px;outline:none;cursor:var(--pn-cursor-text)!important;caret-color:var(--pn-accent)}.pn-ezslider__field:focus{border-color:var(--pn-accent);box-shadow:0 0 0 1px var(--pn-accent-glow)}.pn-ezslider__track{position:relative;flex:1 1 auto;min-height:12px;background:transparent;cursor:var(--pn-cursor-col-resize)!important}.pn-ezslider__track--inert{opacity:.4;cursor:var(--pn-cursor-grab)!important}.pn-ezslider__thumb{position:absolute;top:0;width:4px;height:100%;background:var(--pn-accent);box-shadow:0 0 8px var(--pn-accent),0 0 20px #00ff0073;transform:translate(-50%);border-radius:1px;pointer-events:none}.patch-object-body:has(.pn-ezscale){padding:4px 6px 6px}.pn-ezscale{display:flex;flex-direction:column;gap:6px;width:100%;height:100%;font-family:var(--pn-font-mono)}.pn-ezscale__toolbar{display:flex;justify-content:flex-end;align-items:center;gap:4px;height:14px;margin-bottom:-2px}.pn-ezscale__auto-btn,.pn-ezscale__invert-btn,.pn-ezscale__collapse-btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--pn-font-mono);font-size:var(--pn-type-object-label);line-height:1;padding:1px 6px;background:transparent;color:var(--pn-muted);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-object-radius);cursor:var(--pn-cursor-pointer)!important;-webkit-user-select:none;user-select:none;outline:none;text-align:center}.pn-ezscale__invert-btn,.pn-ezscale__collapse-btn{min-width:16px;padding:1px 4px}.pn-ezscale__auto-btn[aria-pressed=true],.pn-ezscale__invert-btn[aria-pressed=true]{color:var(--pn-bg);background:var(--pn-accent);border-color:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent-glow)}.pn-ezscale__auto-btn:hover,.pn-ezscale__invert-btn:hover,.pn-ezscale__collapse-btn:hover{color:var(--pn-text)}.pn-ezscale__auto-btn[aria-pressed=true]:hover,.pn-ezscale__invert-btn[aria-pressed=true]:hover{color:var(--pn-bg)}.pn-ezscale__fields{display:grid;grid-template-columns:1fr 1fr;gap:3px 6px}.pn-ezscale__mult-row{display:flex;margin-bottom:10px}.pn-ezscale__mult-row .pn-ezscale__cell{flex:1 1 0}.pn-ezscale__cell{display:flex;align-items:center;gap:4px;font-size:var(--pn-type-object-label);color:var(--pn-text-dim);min-width:0}.pn-ezscale__label{flex:0 0 auto;font-family:var(--pn-font-sans);font-size:var(--pn-type-object-label);color:var(--pn-muted);-webkit-user-select:none;user-select:none}.pn-ezscale__field{flex:1 1 0;min-width:0;background:var(--pn-object-bg);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-object-radius);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-object-name);padding:1px 4px;outline:none;cursor:var(--pn-cursor-text)!important;caret-color:var(--pn-accent)}.pn-ezscale__field:focus{border-color:var(--pn-accent);box-shadow:0 0 0 1px var(--pn-accent-glow)}.pn-ezscale__range{position:relative;width:100%;height:14px;margin-top:auto;padding:0 6px;box-sizing:border-box}.patch-object-body .pn-ezscale__track{position:relative;width:100%;height:100%;background:color-mix(in srgb,var(--pn-accent) 8%,transparent);border:1px solid var(--pn-border-subtle);border-radius:2px;cursor:var(--pn-cursor-col-resize)!important}.patch-object-body .pn-ezscale__range--inert .pn-ezscale__track{opacity:.5;cursor:var(--pn-cursor-grab)!important}.patch-object-body .pn-ezscale__fill{position:absolute;top:0;bottom:0;background:color-mix(in srgb,var(--pn-accent) 32%,transparent);cursor:var(--pn-cursor-grab)!important}.patch-object-body .pn-ezscale__thumb{position:absolute;top:-2px;bottom:-2px;width:6px;background:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent-glow);border-radius:2px;transform:translate(-50%);cursor:var(--pn-cursor-col-resize)!important}.patch-object-body .pn-ezscale__edge-label{position:absolute;bottom:calc(100% + 2px);font-family:var(--pn-font-mono);font-size:var(--pn-type-object-label);line-height:1;color:var(--pn-accent);background:var(--pn-bg);padding:1px 3px;border-radius:2px;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.patch-object-body .pn-ezscale__edge-label--lo{left:0}.patch-object-body .pn-ezscale__edge-label--hi{right:0}.patch-object--message{border-left:2px solid var(--pn-border-accent)!important;border-radius:0 var(--pn-object-radius) var(--pn-object-radius) 0}.patch-object--message .patch-object-body{align-items:flex-start;padding:0 6px}.patch-object-message-content{width:100%;font-size:clamp(8px,min(22cqw,56cqh),24px);color:var(--pn-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 0 8px rgba(0,255,0,.5);-webkit-user-select:none;user-select:none;line-height:1;cursor:var(--pn-cursor-pointer)!important}.patch-object--active.patch-object--message{border-color:var(--pn-accent)!important;box-shadow:0 0 14px var(--pn-accent),0 0 32px #00ff0073,var(--pn-shadow-inset)!important}.patch-object--active .patch-object-message-content{color:var(--pn-accent);text-shadow:0 0 8px var(--pn-accent),0 0 20px rgba(0,255,0,.5)}.patch-object-message-input{width:100%;background:transparent;border:none;outline:none;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:clamp(8px,min(22cqw,56cqh),24px);padding:0;caret-color:var(--pn-accent);caret-shape:block;text-shadow:0 0 6px var(--pn-accent)}.patch-object-title-input{width:100%;background:transparent;border:none;outline:none;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:clamp(8px,min(24cqw,48cqh),24px);letter-spacing:.04em;text-align:center;padding:0;caret-color:var(--pn-accent);caret-shape:block;text-shadow:0 0 6px var(--pn-accent)}.patch-object--editing{outline:1px solid var(--pn-accent);outline-offset:2px}.pn-object-entry{position:absolute;z-index:50;min-width:80px;height:24px;box-sizing:border-box;border:1px solid var(--pn-object-border-active);border-radius:var(--pn-object-radius);background:var(--pn-object-bg);box-shadow:0 0 0 1px var(--pn-border-accent),0 0 18px #00ff00a6,0 0 56px #00ff0073;display:flex;align-items:center;padding:0 6px;transform-origin:center center;animation:pn-object-entry-pop .16s cubic-bezier(.2,.9,.3,1.3) both,pn-object-entry-pulse 1.3s ease-in-out .16s infinite}.pn-object-entry:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(0,255,0,.8);border-radius:calc(var(--pn-object-radius) + 2px);pointer-events:none;animation:pn-object-entry-halo 1.3s ease-out infinite}@keyframes pn-object-entry-pop{0%{transform:scale(.55);opacity:0}65%{transform:scale(1.18);opacity:1}to{transform:scale(1);opacity:1}}@keyframes pn-object-entry-pulse{0%,to{box-shadow:0 0 0 1px var(--pn-border-accent),0 0 18px #00ff008c,0 0 56px #0f06}50%{box-shadow:0 0 0 1px var(--pn-border-accent),0 0 30px #00ff00e6,0 0 88px #00ff00a6}}@keyframes pn-object-entry-halo{0%{top:0;right:0;bottom:0;left:0;opacity:.85}to{top:-28px;right:-28px;bottom:-28px;left:-28px;opacity:0}}.patch-object--just-placed{animation:pn-object-entry-pop .16s cubic-bezier(.2,.9,.3,1.3) both,pn-object-just-placed-glow 1.1s ease-out both}.patch-object--just-placed:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid rgba(0,255,0,.85);border-radius:calc(var(--pn-object-radius) + 2px);pointer-events:none;animation:pn-object-entry-halo 1.1s ease-out both;z-index:2}@keyframes pn-object-just-placed-glow{0%{box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 30px #00ff00f2,0 0 88px #00ff00b3}to{box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c}}.pn-object-entry--error{border-color:var(--pn-danger);box-shadow:0 0 0 1px #0f06;animation:pn-object-entry-pop .16s cubic-bezier(.2,.9,.3,1.3) both}.pn-object-entry--error:before{animation:none;opacity:0}.pn-object-entry-input{background:transparent;border:none;outline:none;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-object-name);width:100%;min-width:72px;caret-color:var(--pn-accent);text-shadow:0 0 8px rgba(0,255,0,.5)}.pn-object-entry-input::placeholder{color:var(--pn-muted-deep)}.pn-object-entry{overflow:visible}.pn-object-ac{display:none;position:absolute;top:100%;left:0;min-width:100%;z-index:60;background:var(--pn-surface-raised);border:1px solid var(--pn-border-accent);border-top:none;border-radius:0 0 var(--pn-radius-xs) var(--pn-radius-xs);box-shadow:0 4px 16px #00000080,0 0 12px #00ff006b;overflow:hidden}.pn-object-ac--visible{display:block}.pn-object-ac-item{padding:4px 10px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);color:var(--pn-text-dim);cursor:var(--pn-cursor-pointer);letter-spacing:.04em;white-space:nowrap;transition:background .06s,color .06s}.pn-object-ac-item:hover,.pn-object-ac-item--active{background:#00ff0061;color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent)}.divider{width:4px;flex-shrink:0;background:var(--pn-border);cursor:var(--pn-cursor-col-resize)}.divider:hover{background:var(--pn-accent)}.text-panel{width:280px;min-width:180px;max-width:480px;flex-shrink:0;background:var(--pn-bg);border-left:1px solid var(--pn-border);box-shadow:-2px 0 28px #00ff006b;display:flex;flex-direction:column}.text-panel-header{height:32px;background:var(--pn-surface-raised);border-bottom:1px solid var(--pn-border);display:flex;align-items:center;justify-content:space-between;padding:0 8px 0 12px;font-family:"Vulf Mono",var(--pn-font-mono);font-size:var(--pn-type-chip);color:var(--pn-muted);text-transform:uppercase;letter-spacing:.08em;text-shadow:0 0 6px rgba(0,255,0,.35);flex-shrink:0}.console-collapse-btn{background:none;border:none;color:var(--pn-muted);font-family:"Vulf Mono",var(--pn-font-mono);font-size:16px;line-height:1;padding:0 4px;cursor:var(--pn-cursor-pointer);transition:color .1s,transform .15s;display:flex;align-items:center}.console-collapse-btn:hover{color:var(--pn-accent)}.text-panel--collapsed{width:32px!important;min-width:32px!important;max-width:32px!important}.text-panel--collapsed .text-panel-header{writing-mode:vertical-rl;text-orientation:mixed;justify-content:flex-end;padding:12px 0 8px;height:100%;border-bottom:none;border-right:1px solid var(--pn-border);flex-direction:column-reverse;align-items:center;cursor:var(--pn-cursor-pointer)}.text-panel--collapsed textarea{display:none}.text-panel--collapsed .console-collapse-btn{transform:rotate(180deg);writing-mode:horizontal-tb;margin-bottom:4px}.text-panel textarea{flex:1;min-height:0;background:transparent;color:var(--pn-text-dim);font-family:var(--pn-font-mono);font-size:var(--pn-type-helper);border:none;outline:none;resize:none;padding:12px;line-height:1.6;text-shadow:0 0 6px rgba(0,255,0,.52);transition:box-shadow .15s;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:box-shadow .15s,scrollbar-color .25s}.text-panel textarea:hover,.text-panel textarea:focus{scrollbar-color:rgba(0,255,0,.5) transparent}.text-panel textarea::-webkit-scrollbar{width:6px}.text-panel textarea::-webkit-scrollbar-track{background:transparent}.text-panel textarea::-webkit-scrollbar-thumb{background:transparent;border-radius:3px;transition:background .25s}.text-panel textarea:hover::-webkit-scrollbar-thumb,.text-panel textarea:focus::-webkit-scrollbar-thumb{background:#00ff0080}.patch-object--unavailable{opacity:.5;outline:1px dashed var(--pn-warn, #f5a623)!important;cursor:default;pointer-events:none}.pn-unavailable-body{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:4px 8px;gap:2px;height:100%}.pn-unavailable-type{font-family:"Vulf Mono",var(--pn-font-mono);font-size:var(--pn-type-body);color:var(--pn-fg);opacity:.7}.pn-unavailable-badge{font-family:"Vulf Sans",var(--pn-font-sans);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--pn-warn, #f5a623);opacity:.9}.patch-object--comment{background:transparent!important;border:none!important;box-shadow:none!important;outline:1px dashed var(--pn-border)!important}.patch-object--comment .patch-object-body{background:transparent;border:none;padding:4px 6px;display:flex;align-items:flex-start}.patch-object--comment.patch-object--selected{outline:1px dashed var(--pn-accent)!important}.patch-object-comment-text{font-family:"Vulf Mono",var(--pn-font-mono);font-style:italic;font-size:var(--pn-type-helper);color:var(--pn-muted);line-height:1.4;white-space:pre-wrap;word-break:break-word;pointer-events:none;-webkit-user-select:none;user-select:none}.patch-object-comment-input{font-family:"Vulf Mono",var(--pn-font-mono);font-style:italic;font-size:var(--pn-type-helper);color:var(--pn-muted);background:transparent;border:none;outline:none;width:100%;resize:none;line-height:1.4;padding:0;caret-color:var(--pn-accent)}.text-panel textarea.text-panel--error{box-shadow:inset 0 0 0 1px #00ff0073;color:var(--pn-danger)}.status-bar{height:24px;flex-shrink:0;background:var(--pn-bg-deep);border-top:1px solid var(--pn-border);box-shadow:0 -1px 18px #00ff006b;display:flex;align-items:center;padding:0 12px;gap:16px;font-family:"Vulf Mono",var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-muted);text-shadow:0 0 5px rgba(0,255,0,.52)}.status-bar .status-mode{color:var(--pn-accent);text-shadow:0 0 8px var(--pn-accent),0 0 20px rgba(0,255,0,.45)}.status-bar span:last-child{cursor:var(--pn-cursor-pointer);transition:color .15s,text-shadow .15s}.status-bar span:last-child:hover{color:var(--pn-accent);text-shadow:0 0 8px var(--pn-accent)}.patch-object--attribute .patch-object-body{padding:0;overflow:hidden}.pn-attrui{display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden;box-sizing:border-box}.pn-attrui__header{flex-shrink:0;height:var(--pn-attrui-header-h);box-sizing:border-box;font-family:var(--pn-font-sans);font-size:var(--pn-type-micro);font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--pn-accent);padding:4px 7px 3px;border-bottom:1px solid var(--pn-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none}.pn-attrui__hint{font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-muted);padding:10px 8px;text-align:center;opacity:.6;-webkit-user-select:none;user-select:none}.pn-attrui__scroll{flex:1 1 auto;overflow-y:scroll;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .2s}.patch-object--attribute:hover .pn-attrui__scroll{scrollbar-color:var(--pn-accent-dim) transparent}.pn-attrui__scroll::-webkit-scrollbar{width:3px}.pn-attrui__scroll::-webkit-scrollbar-track{background:transparent}.pn-attrui__scroll::-webkit-scrollbar-thumb{background:transparent;border-radius:2px;transition:background .2s}.patch-object--attribute:hover .pn-attrui__scroll::-webkit-scrollbar-thumb{background:var(--pn-accent-dim)}.pn-attrui__row{display:flex;align-items:center;gap:5px;padding:2px 6px;height:var(--pn-attrui-row-h);min-height:var(--pn-attrui-row-h);box-sizing:border-box}.pn-attrui__row:hover{background:var(--pn-hover-accent)}.pn-attrui__label{flex:0 0 54px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;-webkit-user-select:none;user-select:none}.pn-attrui__slider{flex:1 1 auto;min-width:0;height:12px;accent-color:var(--pn-accent);cursor:var(--pn-cursor-pointer);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;margin:0}.pn-attrui__slider::-webkit-slider-runnable-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-attrui__slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--pn-accent);margin-top:-4px;box-shadow:0 0 5px var(--pn-accent-glow);transition:box-shadow .1s}.pn-attrui__slider:hover::-webkit-slider-thumb,.pn-attrui__slider:focus::-webkit-slider-thumb{box-shadow:0 0 10px var(--pn-accent),0 0 4px var(--pn-accent)}.pn-attrui__slider::-moz-range-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-attrui__slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--pn-accent);border:none;box-shadow:0 0 5px var(--pn-accent-glow)}.pn-attrui__readout{flex:0 0 40px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text);text-align:right;white-space:nowrap;-webkit-user-select:none;user-select:none}.pn-attrui__text{flex:1 1 auto;min-width:0;font-family:var(--pn-font-mono);font-size:9px;background:transparent;border:1px solid var(--pn-border);border-radius:2px;color:var(--pn-text);padding:1px 4px;outline:none}.pn-attrui__text:focus{border-color:var(--pn-border-accent);box-shadow:0 0 0 1px var(--pn-accent-glow)}.patch-port-side-left,.patch-port-side-right{width:6px;height:6px;z-index:3}.patch-object--attribute{border-color:color-mix(in srgb,var(--pn-accent) 28%,var(--pn-border))}.patch-object--attribute:hover{box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 14px #0f06}.pn-imgfx-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:500;display:flex;align-items:center;justify-content:center}.pn-imgfx-modal{background:var(--pn-surface-raised);border:1px solid var(--pn-border-accent);border-radius:var(--pn-radius-sm);box-shadow:0 0 40px #00ff0073,0 0 80px #000c;display:flex;flex-direction:column;width:640px;max-width:95vw;max-height:90vh;overflow:hidden}.pn-imgfx-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--pn-border);font-family:var(--pn-font-mono);font-size:var(--pn-type-ui);color:var(--pn-accent);text-shadow:0 0 8px var(--pn-accent);letter-spacing:.08em;flex-shrink:0}.pn-imgfx-close{background:none;border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);padding:2px 7px;line-height:1}.pn-imgfx-close:hover{color:var(--pn-accent);border-color:var(--pn-border-accent)}.pn-imgfx-content{display:flex;flex:1;min-height:0}.pn-imgfx-preview-col{flex:0 0 240px;display:flex;flex-direction:column;padding:12px;gap:8px;border-right:1px solid var(--pn-border)}.pn-imgfx-preview-label{font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-muted);letter-spacing:.04em}.pn-imgfx-preview-wrap{flex:1;min-height:0;border:1px solid var(--pn-border);border-radius:2px;overflow:hidden;background-color:#000;background-image:linear-gradient(45deg,rgba(0,255,0,.35) 25%,transparent 25%),linear-gradient(-45deg,rgba(0,255,0,.35) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(0,255,0,.35) 75%),linear-gradient(-45deg,transparent 75%,rgba(0,255,0,.35) 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0;display:flex;align-items:center;justify-content:center}.pn-imgfx-preview{max-width:100%;max-height:100%;display:block;object-fit:contain;image-rendering:auto}.pn-imgfx-bg-status{font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent);min-height:14px}.pn-imgfx-zoom-row{display:flex;align-items:center;gap:4px;padding:4px 0 0}.pn-imgfx-zoom-btn{padding:1px 6px;min-width:22px}.pn-imgfx-zoom-readout{font-family:var(--pn-font-mono);font-size:10px;color:var(--pn-fg);min-width:28px;text-align:center}.pn-imgfx-controls-col{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:rgba(0,255,0,.48) transparent}.pn-imgfx-section-title{font-family:var(--pn-font-mono);font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--pn-accent);margin-bottom:6px;padding-bottom:3px;border-bottom:1px solid rgba(0,255,0,.48)}.pn-imgfx-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.pn-imgfx-label{flex:0 0 54px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text-dim);text-align:right;-webkit-user-select:none;user-select:none}.pn-imgfx-slider{flex:1;height:12px;accent-color:var(--pn-accent);cursor:var(--pn-cursor-pointer);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;margin:0}.pn-imgfx-slider::-webkit-slider-runnable-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-imgfx-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--pn-accent);margin-top:-4px;box-shadow:0 0 5px var(--pn-accent)}.pn-imgfx-slider::-moz-range-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-imgfx-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--pn-accent);border:none;box-shadow:0 0 5px var(--pn-accent)}.pn-imgfx-readout{flex:0 0 38px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text);text-align:right;-webkit-user-select:none;user-select:none}.pn-imgfx-swatch-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.pn-imgfx-swatch{width:22px;height:22px;border:1px solid var(--pn-border);border-radius:2px;flex-shrink:0}.pn-imgfx-swatch-hint{font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-muted)}.pn-imgfx-btn-row{display:flex;gap:6px;margin-top:4px}.pn-imgfx-footer{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--pn-border);justify-content:flex-end;flex-shrink:0}.pn-imgfx-btn{padding:5px 12px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);background:var(--pn-object-bg);border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-text);letter-spacing:.04em;transition:border-color .1s,color .1s,box-shadow .1s}.pn-imgfx-btn:hover{border-color:var(--pn-border-accent);color:var(--pn-accent)}.pn-imgfx-btn--accent{border-color:var(--pn-border-accent);color:var(--pn-accent);box-shadow:0 0 8px #00ff007a}.pn-imgfx-btn--active{border-color:var(--pn-accent);color:var(--pn-accent);box-shadow:0 0 6px #00ff0059}.patch-object[data-node-type="imageFX*"]{border-color:var(--pn-border-accent);box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff006b,0 0 2px #00ff0073}.pn-fft-body{padding:0!important;overflow:hidden}.pn-fft-device{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;padding:6px 7px 5px;gap:4px;background:var(--pn-surface-raised);border-radius:3px 3px 14px}.pn-fft-top-label{font-family:var(--pn-font-mono);font-size:5.5px;letter-spacing:.18em;color:var(--pn-border-accent-soft);align-self:flex-start;padding-left:1px}.pn-fft-screen-bezel{width:100%;flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:4px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-fft-screen{flex:1;min-height:0;position:relative;background:var(--pn-bg-deep);border-radius:1px;overflow:hidden;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-fft-mount{position:absolute;top:0;right:0;bottom:0;left:0}.pn-fft-mount canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;image-rendering:pixelated}.pn-fft-bands{display:grid;grid-template-columns:repeat(4,1fr);width:100%;gap:2px}.pn-fft-band{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--pn-surface);border:1px solid var(--pn-border-subtle);border-radius:2px;padding:2px 0;min-width:0;overflow:hidden}.pn-fft-band-label{font-family:var(--pn-font-mono);font-size:5px;color:var(--pn-border-accent-soft);letter-spacing:.05em}.pn-fft-band-val{font-family:var(--pn-font-mono);font-size:7px;color:var(--pn-accent);letter-spacing:.02em}.pn-fft-bands[data-band-count="8"] .pn-fft-band-val{font-size:5px}.pn-fft-bands[data-band-count="8"] .pn-fft-band-label{font-size:4px}.pn-fft-bands[data-band-count="16"]{gap:1px}.pn-fft-bands[data-band-count="16"] .pn-fft-band{padding:1px 0}.pn-fft-bands[data-band-count="16"] .pn-fft-band-val{font-size:4px}.pn-fft-bands[data-band-count="16"] .pn-fft-band-label{display:none}.pn-fft-controls{display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;padding:0 2px}.pn-fft-dpad{position:relative;width:26px;height:26px;flex-shrink:0}.pn-fft-dpad-h,.pn-fft-dpad-v{position:absolute;background:var(--pn-border);border-radius:1px}.pn-fft-dpad-h{top:33%;left:0;width:100%;height:33%}.pn-fft-dpad-v{left:33%;top:0;width:33%;height:100%}.pn-fft-power-led{width:5px;height:5px;border-radius:50%;background:var(--pn-surface);box-shadow:0 0 0 1px var(--pn-border-subtle);flex-shrink:0}.patch-object[data-node-type="fft~"][data-dsp-active=true] .pn-fft-power-led{background:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent-glow),0 0 0 1px var(--pn-border-accent)}.pn-fft-buttons{display:flex;flex-direction:row;align-items:center;gap:5px;flex-shrink:0}.pn-fft-btn{width:12px;height:12px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--pn-font-mono);font-size:5px;color:var(--pn-border-accent-soft);background:var(--pn-surface);border:1px solid var(--pn-border)}.pn-fft-btn-b{margin-top:4px}.patch-object-patchviz-body{padding:0!important;overflow:hidden;position:relative;background:#000}.pn-patchviz-mount{width:100%;height:100%;overflow:hidden;background:#000}.pn-patchviz-canvas{display:block;width:100%;height:100%;image-rendering:pixelated}.pn-patchviz-label{position:absolute;bottom:4px;left:6px;font-family:var(--pn-font-mono);font-size:9px;color:#00ff0080;pointer-events:none;-webkit-user-select:none;user-select:none}.pn-wave-body{padding:0!important;overflow:hidden}.pn-wave-panel{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:6px 7px 5px;gap:5px;background:var(--pn-surface-raised);border-radius:3px}.pn-wave-scope-bezel{flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:3px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-wave-scope,.pn-wave-scope-live{flex:1;width:100%;height:100%;display:block;border-radius:1px;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-wave-knobs{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:100%}.pn-wave-knob{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--pn-surface);border:1px solid var(--pn-border-subtle);border-radius:3px;padding:3px 0 2px;cursor:ns-resize;user-select:none;-webkit-user-select:none}.pn-wave-knob:hover{border-color:var(--pn-border-accent-soft)}.pn-wave-knob__dial{width:32px;height:32px;display:block;filter:drop-shadow(0 0 3px var(--pn-accent-glow))}.pn-wave-knob__dial svg{display:block}.pn-wave-knob__ring{fill:var(--pn-bg-deep);stroke:var(--pn-border-accent-soft);stroke-width:1.25}.pn-wave-knob__pointer{stroke:var(--pn-accent);stroke-width:2;stroke-linecap:round}.pn-wave-knob__label{font-family:var(--pn-font-mono);font-size:6px;letter-spacing:.12em;color:var(--pn-border-accent-soft);margin-top:1px}.pn-wave-knob__value{font-family:var(--pn-font-mono);font-size:8px;color:var(--pn-accent);letter-spacing:.02em;line-height:1.1}.pn-wave-body[data-wave-locked="1"] .pn-wave-knob{cursor:inherit;pointer-events:none}.pn-noise-body{padding:0!important;overflow:hidden}.pn-noise-panel{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:6px 7px 5px;gap:5px;background:var(--pn-surface-raised);border-radius:3px}.pn-noise-scope-bezel{flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:3px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-noise-scope-live{flex:1;width:100%;height:100%;display:block;border-radius:1px;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-noise-readouts{display:flex;justify-content:space-between;gap:6px;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-accent)}.pn-noise-readouts span:first-child{color:var(--pn-border-accent-soft);text-transform:uppercase;letter-spacing:.08em}.pn-lfo-body{padding:0!important;overflow:hidden}.pn-lfo-panel{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:6px 7px 5px;gap:5px;background:var(--pn-surface-raised);border-radius:3px}.pn-lfo-scope-bezel{flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:3px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-lfo-scope,.pn-lfo-scope-live{flex:1;width:100%;height:100%;display:block;border-radius:1px;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-lfo-knobs{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:100%}.pn-lfo-knob{display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--pn-surface);border:1px solid var(--pn-border-subtle);border-radius:3px;padding:3px 0 2px;cursor:ns-resize;user-select:none;-webkit-user-select:none}.pn-lfo-knob:hover{border-color:var(--pn-border-accent-soft)}.pn-lfo-knob__dial{width:32px;height:32px;display:block;filter:drop-shadow(0 0 3px var(--pn-accent-glow))}.pn-lfo-knob__dial svg{display:block}.pn-lfo-knob__ring{fill:var(--pn-bg-deep);stroke:var(--pn-border-accent-soft);stroke-width:1.25}.pn-lfo-knob__pointer{stroke:var(--pn-accent);stroke-width:2;stroke-linecap:round}.pn-lfo-knob__label{font-family:var(--pn-font-mono);font-size:6px;letter-spacing:.12em;color:var(--pn-border-accent-soft);margin-top:1px}.pn-lfo-knob__value{font-family:var(--pn-font-mono);font-size:8px;color:var(--pn-accent);letter-spacing:.02em;line-height:1.1}.pn-lfo-body[data-lfo-locked="1"] .pn-lfo-knob{cursor:inherit;pointer-events:none}.pn-tf-body{padding:0!important;overflow:hidden}.pn-tf-panel{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:6px 7px 5px;gap:4px;background:var(--pn-surface-raised);border-radius:3px}.pn-tf-scope-bezel{flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:3px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-tf-scope-live{flex:1;width:100%;height:100%;display:block;border-radius:1px;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-adsr-body{padding:0!important;overflow:hidden}.pn-adsr-panel{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:6px 7px 5px;gap:4px;background:var(--pn-surface-raised);border-radius:3px}.pn-adsr-editor-bezel{flex:1;min-height:0;display:flex;background:var(--pn-bg-deep);border-radius:2px;padding:3px;box-shadow:inset 0 1px 4px #000c,inset 0 0 0 1px var(--pn-border-subtle)}.pn-adsr-svg{flex:1;width:100%;height:100%;display:block;border-radius:1px;box-shadow:inset 0 0 10px var(--pn-surface-glow)}.pn-adsr-line{stroke:var(--pn-accent);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 2px var(--pn-accent-glow))}.pn-adsr-handle{fill:var(--pn-accent);stroke:none;cursor:grab;transition:r .08s ease-out}.pn-adsr-handle:hover{r:5;filter:drop-shadow(0 0 3px var(--pn-accent-glow))}.pn-adsr-handle:active{cursor:grabbing}.pn-adsr-readouts{display:flex;justify-content:space-between;gap:4px;font-family:var(--pn-font-mono);font-size:8px;color:var(--pn-accent);letter-spacing:.02em;line-height:1.1}.pn-adsr-readouts span{white-space:nowrap}.pn-adsr-body[data-adsr-locked="1"] .pn-adsr-handle{pointer-events:none;cursor:inherit}.patch-object-mediaimage-body{padding:0!important;overflow:hidden;position:relative}.pn-polaroid{width:100%;height:100%;box-sizing:border-box;display:flex;flex-direction:column;padding:7px 7px 0;border:1.5px solid rgba(0,255,0,.55);border-radius:2px;box-shadow:inset 0 0 0 1px #00ff0059,0 0 10px #0f06;position:relative}.pn-polaroid:before,.pn-polaroid:after{content:"";position:absolute;width:8px;height:8px;pointer-events:none}.pn-polaroid:before{top:3px;left:3px;border-top:1px solid rgba(0,255,0,.35);border-left:1px solid rgba(0,255,0,.35)}.pn-polaroid:after{top:3px;right:3px;border-top:1px solid rgba(0,255,0,.35);border-right:1px solid rgba(0,255,0,.35)}.pn-polaroid__photo{flex:1;min-height:0;overflow:hidden;border:1px solid rgba(0,255,0,.52);position:relative}.pn-polaroid__photo:before,.pn-polaroid__photo:after{content:"";position:absolute;bottom:-1px;width:8px;height:8px;pointer-events:none}.pn-polaroid__photo:before{left:-1px;border-bottom:1px solid rgba(0,255,0,.35);border-left:1px solid rgba(0,255,0,.35)}.pn-polaroid__photo:after{right:-1px;border-bottom:1px solid rgba(0,255,0,.35);border-right:1px solid rgba(0,255,0,.35)}.pn-polaroid__img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;-webkit-user-select:none;user-select:none}.pn-polaroid__placeholder{width:100%;height:100%;background:linear-gradient(to bottom right,transparent calc(50% - .5px),rgba(0,255,0,.4) calc(50% - .5px),rgba(0,255,0,.4) calc(50% + .5px),transparent calc(50% + .5px)),linear-gradient(to bottom left,transparent calc(50% - .5px),rgba(0,255,0,.4) calc(50% - .5px),rgba(0,255,0,.4) calc(50% + .5px),transparent calc(50% + .5px))}.pn-polaroid__base{height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0 6px;border-top:1px solid rgba(0,255,0,.48);position:relative}.pn-polaroid__base:before,.pn-polaroid__base:after{content:"";position:absolute;bottom:3px;width:6px;height:6px;pointer-events:none}.pn-polaroid__base:before{left:3px;border-bottom:1px solid rgba(0,255,0,.52);border-left:1px solid rgba(0,255,0,.52)}.pn-polaroid__base:after{right:3px;border-bottom:1px solid rgba(0,255,0,.52);border-right:1px solid rgba(0,255,0,.52)}.pn-polaroid__label{font-family:var(--pn-font-mono);font-size:8px;color:#00ff0059;letter-spacing:.05em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s}.patch-object:hover .pn-polaroid__label{color:#00ff00a6}.crt-overlay{--crt-sx: 0;--crt-sy: 0;position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:150;box-shadow:inset 0 0 min(180px,22vw) color-mix(in srgb,var(--pn-bg-deep) 90%,black),inset 0 0 56px color-mix(in srgb,var(--pn-accent) 14%,transparent),inset 0 0 12px color-mix(in srgb,var(--pn-text) 6%,transparent)}.crt-overlay:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;mix-blend-mode:screen;opacity:.34;background:linear-gradient(90deg,color-mix(in srgb,var(--pn-secondary) 14%,transparent) 0%,transparent 38%,color-mix(in srgb,var(--pn-accent) 8%,transparent) 100%)}.crt-overlay:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;mix-blend-mode:screen;opacity:.52;background:repeating-linear-gradient(to bottom,color-mix(in srgb,var(--pn-text) 14%,transparent) 0,color-mix(in srgb,var(--pn-text) 14%,transparent) 1px,transparent 1px,transparent 3px),repeating-linear-gradient(to right,transparent 0,transparent 2px,color-mix(in srgb,var(--pn-bg-deep) 35%,transparent) 2px,color-mix(in srgb,var(--pn-bg-deep) 35%,transparent) 3px);background-position:calc(-1px * var(--crt-sx)) calc(-1px * var(--crt-sy)),calc(-1px * var(--crt-sx)) calc(-1px * var(--crt-sy));will-change:background-position}@media (prefers-reduced-motion: reduce){.crt-overlay:after{background-position:0 0,0 0!important;will-change:auto}.crt-overlay:before{opacity:.22}.crt-overlay:after{opacity:.32}}#pn-tab-bar{display:flex;flex-direction:row;align-items:stretch;height:28px;background:var(--pn-surface);border-bottom:1px solid var(--pn-border);overflow-x:auto;overflow-y:hidden;flex-shrink:0;scrollbar-width:none}#pn-tab-bar::-webkit-scrollbar{display:none}.pn-tab{display:flex;align-items:center;gap:6px;padding:0 12px;background:none;border:none;border-right:1px solid var(--pn-border);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);letter-spacing:.04em;cursor:pointer;white-space:nowrap;flex-shrink:0}.pn-tab:hover{color:var(--pn-text);background:var(--pn-hover-accent)}.pn-tab--active{color:var(--pn-accent);background:var(--pn-surface-raised);border-bottom:2px solid var(--pn-accent)}.pn-tab-close{opacity:.5;font-size:14px;line-height:1;padding:0 2px;border-radius:2px}.pn-tab-close:hover{opacity:1;background:var(--pn-border)}.pn-tab-add{display:flex;align-items:center;justify-content:center;width:28px;background:none;border:none;border-right:1px solid var(--pn-border);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:16px;line-height:1;cursor:pointer;flex-shrink:0}.pn-tab-add:hover{color:var(--pn-accent);background:var(--pn-hover-accent)}.pn-tab-context-menu{position:fixed;z-index:9999;background:var(--pn-surface-raised);border:1px solid var(--pn-border);border-radius:3px;padding:3px 0;min-width:100px;box-shadow:0 4px 12px #0006}.pn-tab-context-item{display:block;width:100%;background:none;border:none;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);letter-spacing:.04em;text-align:left;padding:5px 12px;cursor:var(--pn-cursor-pointer)}.pn-tab-context-item:hover{background:var(--pn-hover-accent);color:var(--pn-accent)}.pn-tab-rename-input{background:var(--pn-surface-raised);border:1px solid var(--pn-accent);border-radius:2px;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);letter-spacing:.04em;padding:0 3px;outline:none;min-width:2ch;cursor:var(--pn-cursor-text)}.patch-object-subpatch .patch-object-body{padding:0;overflow:hidden}.pn-subpatch-panel-mount{flex:1 1 0;position:relative;overflow:hidden;width:100%}.pn-subpatch-panel{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--pn-object-bg)}.pn-subpatch-panel .patch-object{box-shadow:var(--pn-shadow-soft),var(--pn-shadow-inset)!important}.pn-subpatch-panel .patch-object-toggle-plate{box-shadow:none!important}.pn-subpatch-panel-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;pointer-events:none}.pn-subpatch-hint-name{font-family:var(--pn-font-mono);font-size:11px;color:var(--pn-text)}.pn-subpatch-hint-sub{font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-secondary)}.pn-subpatch-panel[data-locked="0"] .patch-object-body,.pn-subpatch-panel[data-locked="0"] .patch-object-body *{cursor:var(--pn-cursor-grab)!important}.pn-subpatch-lock{position:absolute;bottom:5px;left:5px;z-index:20;width:20px;height:20px;padding:0;border:1px solid var(--pn-border);border-radius:4px;background:var(--pn-object-bg);color:var(--pn-secondary);cursor:var(--pn-cursor-pointer)!important;display:flex;align-items:center;justify-content:center;transition:color .1s,background .1s,border-color .1s}.pn-subpatch-lock:hover{color:var(--pn-text);background:var(--pn-hover-accent);border-color:var(--pn-accent)}.pn-subpatch-lock[data-locked="0"]{color:var(--pn-accent);border-color:var(--pn-accent)}.pn-lock-open{display:none}.pn-lock-closed,.pn-subpatch-lock[data-locked="0"] .pn-lock-open{display:block}.pn-subpatch-lock[data-locked="0"] .pn-lock-closed{display:none}.pn-subpatch-panel[data-locked="0"]{outline:1px dashed color-mix(in srgb,var(--pn-accent) 50%,transparent);outline-offset:-1px}.patch-object-sequencer-body{padding:0;display:flex;flex-direction:column;position:relative;box-sizing:border-box}.pn-seq-grid{flex:1;display:grid;gap:1px;padding:1px;background:var(--pn-border);width:100%;height:100%;box-sizing:border-box;min-height:0}.pn-seq-cell{background:var(--pn-object-bg);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);display:flex;align-items:center;justify-content:center;text-align:center;padding:2px 4px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;min-height:0;outline:none;-webkit-user-select:none;user-select:none;transition:background .05s linear}.pn-seq-cell--active{background:color-mix(in srgb,var(--pn-accent) 28%,var(--pn-object-bg));box-shadow:inset 0 0 0 1px var(--pn-accent)}.pn-seq-grid[data-locked="1"] .pn-seq-cell{cursor:var(--pn-cursor-grab)!important;caret-color:transparent}.pn-seq-grid[data-locked="0"] .pn-seq-cell{cursor:var(--pn-cursor-text)!important;-webkit-user-select:text;user-select:text}.pn-seq-grid[data-locked="0"] .pn-seq-cell:hover{background:var(--pn-hover-accent)}.pn-seq-grid[data-locked="0"] .pn-seq-cell:focus{background:var(--pn-object-bg);box-shadow:inset 0 0 0 1px var(--pn-accent);color:var(--pn-accent)}.pn-seq-grid[data-locked="0"] .pn-seq-cell--active:focus{background:color-mix(in srgb,var(--pn-accent) 18%,var(--pn-object-bg))}.pn-sequencer-lock{top:4px;left:auto;right:4px;bottom:auto}.pn-iolet-label{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);color:var(--pn-muted);letter-spacing:.06em}.patch-object-dmx-body{padding:0;display:flex;flex-direction:column;align-items:stretch}.pn-dmx-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.patch-object-dmx-body[data-locked="0"] .pn-dmx-panel-host,.patch-object-dmx-body[data-locked="0"] .pn-dmx-panel-host *{cursor:var(--pn-cursor-pointer)!important}.patch-object-dmx-body[data-locked="1"] .pn-dmx-panel-host{pointer-events:none}.patch-object-dmx-body .pn-subpatch-lock{pointer-events:auto!important;cursor:var(--pn-cursor-pointer)!important}.patch-object-dmx-body[data-locked="1"] .pn-dmx-panel{outline:1px dashed color-mix(in srgb,var(--pn-accent) 50%,transparent);outline-offset:-1px}.pn-dmx-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);overflow:hidden}@keyframes pn-dmx-pulse{0%,to{opacity:.45}50%{opacity:1}}@keyframes pn-dmx-blink{0%{opacity:1}50%{opacity:.2}to{opacity:1}}.pn-dmx-banner{padding:8px 14px;border-bottom:1px solid var(--pn-border);font-size:var(--pn-type-chip);color:var(--pn-accent);background:#00ff0014}.pn-dmx-banner[hidden]{display:none}.pn-dmx-status-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--pn-border-subtle)}.pn-dmx-status-dot{width:10px;height:10px;border-radius:50%;background:var(--pn-muted-deep);flex-shrink:0}.pn-dmx-status-dot[data-state=connecting],.pn-dmx-status-dot[data-state=reconnecting]{background:var(--pn-secondary-soft);animation:pn-dmx-pulse 1s ease-in-out infinite}.pn-dmx-status-dot[data-state=connected]{background:var(--pn-accent);box-shadow:0 0 8px var(--pn-accent)}.pn-dmx-status-dot[data-state=error]{background:var(--pn-accent);animation:pn-dmx-blink .6s steps(2) infinite}.pn-dmx-status-text{display:flex;flex-direction:column;gap:2px}.pn-dmx-status-label{font-size:var(--pn-type-ui);color:var(--pn-accent);letter-spacing:.04em}.pn-dmx-status-device{font-size:var(--pn-type-chip);color:var(--pn-muted)}.pn-dmx-actions{display:flex;gap:8px;padding:12px 14px;border-bottom:1px solid var(--pn-border-subtle)}.pn-dmx-btn{flex:1;background:transparent;border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);padding:6px 10px;letter-spacing:.04em;cursor:pointer}.pn-dmx-btn:hover{border-color:var(--pn-border-accent);color:var(--pn-accent)}.pn-dmx-btn-primary{border-color:var(--pn-border-accent);color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent)}.pn-dmx-rate-row{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--pn-border-subtle)}.pn-dmx-label{font-size:var(--pn-type-chip);color:var(--pn-muted);letter-spacing:.06em;min-width:36px}.pn-dmx-slider{flex:1;accent-color:var(--pn-accent)}.pn-dmx-readout{font-size:var(--pn-type-chip);color:var(--pn-text-dim);min-width:50px;text-align:right}.pn-dmx-log-section{display:flex;flex-direction:column;padding:10px 14px 14px;gap:6px;min-height:120px;max-height:240px}.pn-dmx-log-label{font-size:var(--pn-type-chip);color:var(--pn-muted);letter-spacing:.08em;text-transform:lowercase}.pn-dmx-log-list{flex:1;overflow-y:auto;border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs);padding:6px 8px;background:#0000004d;display:flex;flex-direction:column;gap:2px}.pn-dmx-log-row{display:flex;gap:8px;font-size:var(--pn-type-chip);line-height:1.4}.pn-dmx-log-row[data-level=error] .pn-dmx-log-msg{color:var(--pn-accent)}.pn-dmx-log-time{color:var(--pn-muted-deep);flex-shrink:0}.pn-dmx-log-msg{color:var(--pn-text-dim);word-break:break-word}.pn-dmx-tab-strip{display:flex;border-bottom:1px solid var(--pn-border)}.pn-dmx-tab{flex:1;background:transparent;border:0;border-right:1px solid var(--pn-border-subtle);color:var(--pn-muted);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);padding:8px 10px;letter-spacing:.08em;text-transform:lowercase;cursor:pointer}.pn-dmx-tab:last-child{border-right:0}.pn-dmx-tab:hover{color:var(--pn-text-dim)}.pn-dmx-tab[data-active=true]{color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent);background:#00ff000d}.pn-dmx-tab-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.pn-dmx-tab-panel{display:flex;flex-direction:column;overflow:auto;min-height:0;scrollbar-gutter:stable}.pn-dmx-tab-panel[hidden]{display:none}.pn-dmx-empty{padding:10px 14px;font-size:var(--pn-type-chip);color:var(--pn-muted-deep);font-style:italic}.pn-dmx-cell{font-size:var(--pn-type-chip);color:var(--pn-text-dim);padding:0 6px}.pn-dmx-input,.pn-dmx-select{background:#0006;border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);padding:4px 6px;outline:none}.pn-dmx-input:focus,.pn-dmx-select:focus{border-color:var(--pn-border-accent)}.pn-dmx-btn-small{flex:none;padding:3px 8px;font-size:var(--pn-type-micro)}.pn-dmx-import-status{font-size:var(--pn-type-chip);min-height:1em;padding:0 14px 8px;color:var(--pn-muted)}.pn-dmx-import-status[data-kind=error]{color:var(--pn-accent)}.pn-dmx-import-status[data-kind=ok]{color:var(--pn-text-dim)}.pn-dmx-profiles-panel{gap:0}.pn-dmx-profiles-split{display:flex;border-bottom:1px solid var(--pn-border-subtle);min-height:220px;max-height:320px}.pn-dmx-profiles-list{flex:0 0 180px;overflow-y:auto;border-right:1px solid var(--pn-border-subtle);display:flex;flex-direction:column}.pn-dmx-profile-row{display:grid;grid-template-columns:1fr auto;gap:2px 8px;padding:6px 10px;background:transparent;border:0;border-bottom:1px solid var(--pn-border-subtle);color:var(--pn-text-dim);font-family:var(--pn-font-mono);text-align:left;cursor:pointer}.pn-dmx-profile-row:hover{background:var(--pn-hover)}.pn-dmx-profile-row[data-selected=true]{background:#00ff0014;color:var(--pn-accent)}.pn-dmx-profile-name{font-size:var(--pn-type-chip);grid-column:1}.pn-dmx-profile-badge{font-size:var(--pn-type-micro);color:var(--pn-muted-deep);grid-column:2;align-self:start}.pn-dmx-profile-meta{font-size:var(--pn-type-micro);color:var(--pn-muted);grid-column:1 / -1}.pn-dmx-profiles-detail{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px}.pn-dmx-profile-detail-header{display:flex;flex-direction:column;gap:2px}.pn-dmx-profile-detail-name{color:var(--pn-accent);font-size:var(--pn-type-ui)}.pn-dmx-profile-detail-id{color:var(--pn-muted);font-size:var(--pn-type-micro)}.pn-dmx-profile-channels{display:flex;flex-direction:column;border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs)}.pn-dmx-profile-channel-row{display:grid;grid-template-columns:48px 1fr 1fr 60px;gap:0;padding:4px 6px;font-size:var(--pn-type-chip);border-bottom:1px solid var(--pn-border-subtle);color:var(--pn-text-dim)}.pn-dmx-profile-channel-row:last-child{border-bottom:0}.pn-dmx-profile-channel-head{background:#00ff000d;color:var(--pn-muted)}.pn-dmx-profile-import{display:flex;flex-direction:column;padding:10px 14px;gap:6px}.pn-dmx-profile-import-box{background:#0006;border:1px solid var(--pn-border);border-radius:var(--pn-radius-xs);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);padding:6px 8px;resize:vertical;outline:none}.pn-dmx-profile-import-box:focus{border-color:var(--pn-border-accent)}.pn-dmx-patch-panel{gap:0}.pn-dmx-patch-table{display:flex;flex-direction:column;padding:10px 14px;gap:2px;border-bottom:1px solid var(--pn-border-subtle);max-height:220px;overflow-y:auto}.pn-dmx-patch-row{display:grid;grid-template-columns:1fr 1fr 50px 50px auto;gap:6px;align-items:center;padding:4px 0;font-size:var(--pn-type-chip);border-bottom:1px solid var(--pn-border-subtle);color:var(--pn-text-dim)}.pn-dmx-patch-row[data-muted=true]{color:var(--pn-muted-deep)}.pn-dmx-patch-row:last-child{border-bottom:0}.pn-dmx-patch-row-head{color:var(--pn-muted)}.pn-dmx-patch-row-actions{display:flex;gap:4px;justify-self:end}.pn-dmx-occ-section{padding:10px 14px;border-bottom:1px solid var(--pn-border-subtle)}.pn-dmx-occ-strip{margin-top:4px;display:grid;grid-template-columns:repeat(64,1fr);gap:1px}.pn-dmx-occ-cell{aspect-ratio:1;background:#00ff000d;min-height:4px}.pn-dmx-occ-cell[data-claimed=true]{background:var(--pn-accent);box-shadow:0 0 2px var(--pn-accent-glow)}.pn-dmx-patch-add{display:flex;flex-direction:column;padding:10px 14px;gap:6px}.pn-dmx-patch-add-form{display:grid;grid-template-columns:1fr 1.3fr 60px auto;gap:6px}.pn-dmx-patch-row[data-orphan=true]{color:var(--pn-accent);background:#00ff000f}.pn-dmx-patch-shortcuts{padding:6px 14px 0;gap:6px}.pn-dmx-patch-shortcuts .pn-dmx-btn{flex:0 1 auto}.pn-dmx-patch-row-actions .pn-dmx-select.pn-dmx-btn-small{padding:3px 6px;font-size:var(--pn-type-micro)}.pn-dmx-monitor-panel{padding:10px 14px;gap:6px}.pn-dmx-monitor-grid{display:grid;grid-template-columns:repeat(64,1fr);gap:1px;padding:4px;border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs);background:#0006}.pn-dmx-monitor-cell{aspect-ratio:1;background:rgba(0,255,0,calc(.06 + .8 * var(--pn-mon-v, 0)));min-height:4px}.pn-dmx-monitor-cell[data-claimed=true]{outline:1px solid rgba(0,255,0,.25);outline-offset:-1px}.pn-dmx-profile-editor-heading{display:flex;align-items:baseline;gap:8px}.pn-dmx-profile-editor-name{flex:1;font-size:var(--pn-type-ui);color:var(--pn-accent)}.pn-dmx-profile-editor-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px}.pn-dmx-profile-editor-count{width:60px}.pn-dmx-profile-editor-table .pn-dmx-profile-editor-row{display:grid;grid-template-columns:1fr 70px 48px 48px 64px 1fr 22px;gap:3px;padding:3px 4px;align-items:center}.pn-dmx-profile-editor-head{display:grid;grid-template-columns:1fr 70px 48px 48px 64px 1fr 22px;background:#00ff000d;color:var(--pn-muted);padding:4px}.pn-dmx-profile-editor-row .pn-dmx-input,.pn-dmx-profile-editor-row .pn-dmx-select{padding:2px 4px;font-size:var(--pn-type-micro);width:100%;box-sizing:border-box}.pn-dmx-profile-editor-row .pn-dmx-input:disabled{opacity:.4}.patch-object-rvideo-body{padding:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start}.pn-rvideo-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-rvideo-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);overflow:hidden;background:var(--pn-surface)}.pn-rvideo-header{padding:4px 8px;border-bottom:1px solid var(--pn-border);font-size:var(--pn-type-chip);color:var(--pn-accent);letter-spacing:.05em;flex:0 0 auto;display:flex;align-items:center;gap:4px}.pn-rvideo-title{font-family:var(--pn-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}.pn-rvideo-title-btn{flex:1 1 auto;display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);letter-spacing:.05em;padding:2px 6px;min-width:0;text-align:left;cursor:var(--pn-cursor-pointer)}.pn-rvideo-title-btn:hover{border-color:color-mix(in srgb,var(--pn-accent) 40%,transparent);background:color-mix(in srgb,var(--pn-accent) 8%,transparent)}.pn-rvideo-caret{flex:0 0 auto;font-size:10px;opacity:.7}.pn-rvideo-hdr-btn{flex:0 0 auto;background:transparent;border:1px solid color-mix(in srgb,var(--pn-border) 80%,transparent);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);padding:2px 8px;cursor:var(--pn-cursor-pointer)}.pn-rvideo-hdr-btn:hover{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-rvideo-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--pn-bg-deep);border:1px solid var(--pn-border);box-shadow:0 8px 24px #0009;max-height:300px;overflow-y:auto;padding:6px 0}.pn-rvideo-dd-empty{padding:10px 14px;font-family:var(--pn-font-sans);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 55%,transparent);font-style:italic}.pn-rvideo-dd-section+.pn-rvideo-dd-section{margin-top:6px}.pn-rvideo-dd-heading{padding:4px 14px;font-family:var(--pn-font-sans);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 60%,transparent);letter-spacing:.04em;text-transform:lowercase}.pn-rvideo-dd-row{display:flex;align-items:stretch;gap:0}.pn-rvideo-dd-row:hover{background:color-mix(in srgb,var(--pn-accent) 10%,transparent)}.pn-rvideo-dd-name{flex:1 1 auto;min-width:0;text-align:left;padding:4px 14px;background:transparent;border:none;font-family:var(--pn-font-mono);font-size:var(--pn-type-body);color:var(--pn-text);cursor:var(--pn-cursor-pointer);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pn-rvideo-dd-del{flex:0 0 auto;background:transparent;border:none;color:color-mix(in srgb,var(--pn-text) 40%,transparent);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);padding:4px 10px;cursor:var(--pn-cursor-pointer)}.pn-rvideo-dd-del:hover{color:var(--pn-error, #ff6464)}.pn-rvideo-dd-actions{display:flex;flex-direction:column;gap:1px;border-top:1px solid var(--pn-border);margin-top:6px;padding-top:4px}.pn-rvideo-dd-action{text-align:left;padding:4px 14px;background:transparent;border:none;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 75%,transparent);cursor:var(--pn-cursor-pointer)}.pn-rvideo-dd-action:hover{color:var(--pn-accent);background:color-mix(in srgb,var(--pn-accent) 10%,transparent)}.pn-rvideo-save-prompt{position:absolute;top:32px;right:12px;z-index:60;background:var(--pn-bg-deep);border:1px solid var(--pn-accent);box-shadow:0 8px 24px #000000b3;padding:10px 12px;display:flex;flex-direction:column;gap:8px;min-width:240px}.pn-rvideo-save-label{font-family:var(--pn-font-sans);font-size:var(--pn-type-micro);color:var(--pn-accent);letter-spacing:.04em}.pn-rvideo-save-name{width:100%;font-family:var(--pn-font-mono);font-size:var(--pn-type-body);background:var(--pn-surface);border:1px solid var(--pn-border);color:var(--pn-text);padding:4px 6px;box-sizing:border-box}.pn-rvideo-save-name:focus{outline:none;border-color:var(--pn-accent)}.pn-rvideo-save-scope{display:flex;gap:12px;font-family:var(--pn-font-sans);font-size:var(--pn-type-micro);color:var(--pn-text)}.pn-rvideo-save-radio{display:inline-flex;align-items:center;gap:4px;cursor:var(--pn-cursor-pointer)}.pn-rvideo-save-actions{display:flex;gap:6px;justify-content:flex-end}.pn-rvideo-lock{flex:0 0 auto;background:transparent;border:1px solid color-mix(in srgb,var(--pn-border) 80%,transparent);color:var(--pn-text);padding:2px 6px;display:inline-flex;align-items:center;justify-content:center;cursor:var(--pn-cursor-pointer)!important}.pn-rvideo-lock:hover,.pn-rvideo-lock[data-locked="1"]{border-color:var(--pn-accent);color:var(--pn-accent)}.patch-object-rvideo-body[data-locked="1"] .pn-rvideo-code,.patch-object-rvideo-body[data-locked="1"] .pn-rvideo-title-btn,.patch-object-rvideo-body[data-locked="1"] .pn-rvideo-hdr-btn{pointer-events:none;opacity:.55}.patch-object-rvideo-body[data-locked="1"] .pn-rvideo-lock,.patch-object-rvideo-body[data-locked="1"] .pn-rvideo-knob-range{pointer-events:auto!important;opacity:1}.pn-rvideo-body{flex:1;display:flex;flex-direction:row;min-height:0;min-width:0}.pn-rvideo-knob-col{display:flex;flex-direction:column;flex:1 1 0;min-width:180px;background:var(--pn-bg-deep);border-right:1px solid var(--pn-border)}.pn-rvideo-knob-header{position:relative;height:var(--pn-attrui-header-h);min-height:var(--pn-attrui-header-h);display:flex;align-items:center;gap:4px;padding:0 6px;border-bottom:1px solid var(--pn-border);background:var(--pn-surface)}.pn-rvideo-knobs{flex:1 1 0;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.pn-rvideo-code-col{display:flex;flex-direction:column;flex:2 1 0;min-width:220px;min-height:0}.pn-rvideo-code{flex:1 1 0;min-height:0;min-width:0;overflow:auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-body)}.pn-rvideo-code .cm-editor{height:100%;background:var(--pn-bg-deep);color:var(--pn-text)}.pn-rvideo-code .cm-scroller{font-family:var(--pn-font-mono)}.pn-rvideo-code .cm-content{caret-color:var(--pn-accent)}.pn-rvideo-code .cm-cursor{border-left-color:var(--pn-accent)}.pn-rvideo-code .cm-gutters{background:var(--pn-surface);border-right:1px solid var(--pn-border);color:color-mix(in srgb,var(--pn-text) 50%,transparent)}.pn-rvideo-code .cm-placeholder{color:color-mix(in srgb,var(--pn-text) 45%,transparent);font-style:italic}.pn-rvideo-knob-row{display:flex;align-items:center;gap:5px;padding:2px 6px;height:var(--pn-attrui-row-h);min-height:var(--pn-attrui-row-h);box-sizing:border-box}.pn-rvideo-knob-label{flex:0 0 72px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;-webkit-user-select:none;user-select:none}.pn-rvideo-knob-readout{flex:0 0 40px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-accent);text-align:right;white-space:nowrap;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums}.pn-rvideo-knob-range{flex:1 1 auto;min-width:0;height:12px;accent-color:var(--pn-accent);cursor:var(--pn-cursor-pointer);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;margin:0}.pn-rvideo-knob-range::-webkit-slider-runnable-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-rvideo-knob-range::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--pn-accent);margin-top:-4px;box-shadow:0 0 5px var(--pn-accent-glow)}.pn-rvideo-knob-range:hover::-webkit-slider-thumb,.pn-rvideo-knob-range:focus::-webkit-slider-thumb{box-shadow:0 0 10px var(--pn-accent),0 0 4px var(--pn-accent)}.pn-rvideo-knob-range::-moz-range-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-rvideo-knob-range::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--pn-accent);border:none;box-shadow:0 0 5px var(--pn-accent-glow)}.pn-rvideo-empty{font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 50%,transparent);font-style:italic;padding:4px 0}.pn-rvideo-status{padding:3px 8px;border-top:1px solid var(--pn-border);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-text);opacity:.7;min-height:16px;flex:0 0 auto}.pn-rvideo-status[data-kind=ok]{color:var(--pn-accent);opacity:1}.pn-rvideo-status[data-kind=error]{color:var(--pn-error, #ff6464);opacity:1}.patch-object-jseffect-body{padding:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start}.pn-jseffect-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-jseffect-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);overflow:hidden;background:var(--pn-surface)}.pn-jseffect-header{position:relative;padding:4px 8px;border-bottom:1px solid var(--pn-border);font-size:var(--pn-type-chip);color:var(--pn-accent);letter-spacing:.05em;flex:0 0 auto;display:flex;align-items:center;gap:4px}.pn-jseffect-title-btn{flex:1 1 auto;display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;color:var(--pn-accent);font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);letter-spacing:.05em;padding:2px 6px;min-width:0;text-align:left;cursor:var(--pn-cursor-pointer)}.pn-jseffect-title-btn:hover{border-color:color-mix(in srgb,var(--pn-accent) 40%,transparent);background:color-mix(in srgb,var(--pn-accent) 8%,transparent)}.pn-jseffect-caret{flex:0 0 auto;font-size:10px;opacity:.7}.pn-jseffect-title{font-family:var(--pn-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}.pn-jseffect-hdr-btn{flex:0 0 auto;background:transparent;border:1px solid color-mix(in srgb,var(--pn-border) 80%,transparent);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);padding:2px 8px;cursor:var(--pn-cursor-pointer)}.pn-jseffect-hdr-btn:hover{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-jseffect-lock{flex:0 0 auto;background:transparent;border:1px solid color-mix(in srgb,var(--pn-border) 80%,transparent);color:var(--pn-text);padding:2px 6px;display:inline-flex;align-items:center;justify-content:center;cursor:var(--pn-cursor-pointer)!important}.pn-jseffect-lock:hover{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-jseffect-lock[data-locked="1"]{color:var(--pn-accent);border-color:var(--pn-accent)}.pn-jseffect-dropdown{position:absolute;top:100%;left:6px;z-index:50;background:var(--pn-bg-deep);border:1px solid var(--pn-border);min-width:320px;max-width:480px;max-height:360px;overflow-y:auto;font-family:var(--pn-font-mono);color:var(--pn-text);box-shadow:0 4px 16px #0006}.pn-jseffect-dd-empty{padding:10px 12px;font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 55%,transparent);font-style:italic}.pn-jseffect-dd-section+.pn-jseffect-dd-section{border-top:1px solid var(--pn-border)}.pn-jseffect-dd-heading{padding:6px 10px 4px;font-size:var(--pn-type-micro);letter-spacing:.08em;color:var(--pn-accent);text-transform:lowercase}.pn-jseffect-dd-row{display:flex;align-items:center}.pn-jseffect-dd-row:hover{background:color-mix(in srgb,var(--pn-accent) 10%,transparent)}.pn-jseffect-dd-name{flex:1 1 auto;background:transparent;border:none;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);text-align:left;padding:4px 10px;cursor:var(--pn-cursor-pointer);white-space:normal;word-break:break-word;line-height:1.3}.pn-jseffect-dd-del{flex:0 0 auto;background:transparent;border:none;color:color-mix(in srgb,var(--pn-text) 60%,transparent);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);padding:4px 8px;cursor:var(--pn-cursor-pointer)}.pn-jseffect-dd-del:hover{color:var(--pn-error, #ff6464)}.pn-jseffect-dd-actions{border-top:1px solid var(--pn-border);display:flex;flex-direction:column}.pn-jseffect-dd-action{background:transparent;border:none;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);text-align:left;padding:5px 10px;cursor:var(--pn-cursor-pointer)}.pn-jseffect-dd-action:hover{background:color-mix(in srgb,var(--pn-accent) 14%,transparent);color:var(--pn-accent)}.pn-jseffect-save-prompt{position:absolute;top:36px;left:6px;right:6px;z-index:60;background:var(--pn-surface);border:1px solid var(--pn-accent);padding:10px 12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 6px 20px #00000080}.pn-jseffect-save-label{font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-accent);letter-spacing:.05em}.pn-jseffect-save-name{background:var(--pn-bg-deep);border:1px solid var(--pn-border);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);padding:4px 6px}.pn-jseffect-save-name:focus{border-color:var(--pn-accent);outline:none}.pn-jseffect-save-scope{display:flex;gap:16px;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:var(--pn-text)}.pn-jseffect-save-radio{display:inline-flex;align-items:center;gap:4px;cursor:var(--pn-cursor-pointer)}.pn-jseffect-save-actions{display:flex;gap:6px;justify-content:flex-end}.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-code,.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-title-btn,.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-hdr-btn{pointer-events:none;opacity:.55}.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-lock,.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-slider-range{pointer-events:auto!important;opacity:1}.patch-object-jseffect-body[data-locked="1"] .pn-jseffect-panel{outline:1px dashed color-mix(in srgb,var(--pn-accent) 40%,transparent);outline-offset:-1px}.pn-jslib-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1000;display:flex;align-items:center;justify-content:center;font-family:var(--pn-font-mono);color:var(--pn-text)}.pn-jslib-modal{background:var(--pn-surface);border:1px solid var(--pn-accent);width:min(800px,90vw);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 12px 40px #000000b3}.pn-jslib-modal-header{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--pn-border)}.pn-jslib-modal-header .pn-jslib-modal-title{margin-right:auto}.pn-jslib-modal-header .pn-jslib-close{margin-left:auto}.pn-jslib-import-btn{background:transparent;border:1px solid var(--pn-border);border-radius:var(--pn-radius-sm);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);padding:4px 10px;cursor:var(--pn-cursor-pointer);white-space:nowrap}.pn-jslib-import-btn:hover{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-jslib-import-btn:disabled{opacity:.5;cursor:not-allowed}.pn-jslib-import-status{font-size:var(--pn-type-micro);color:var(--pn-muted);font-family:var(--pn-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 auto}.pn-jslib-import-status.is-error{color:var(--pn-secondary, #ff7a3c)}.pn-jslib-modal-title{font-size:var(--pn-type-chip);color:var(--pn-accent);letter-spacing:.05em}.pn-jslib-close{background:transparent;border:none;color:var(--pn-text);font-size:18px;cursor:var(--pn-cursor-pointer);line-height:1;padding:0 4px}.pn-jslib-close:hover{color:var(--pn-accent)}.pn-jslib-body{display:flex;flex-direction:column;background:var(--pn-bg-deep);overflow:hidden;flex:1 1 auto;min-height:0}.pn-jslib-col{background:var(--pn-bg-deep);padding:10px 12px;overflow-y:auto;flex:1 1 auto;min-height:0}.pn-jslib-section+.pn-jslib-section{margin-top:4px}.pn-jslib-section-header{display:flex;align-items:center;gap:6px;width:100%;background:transparent;border:1px solid transparent;color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);text-align:left;padding:4px 6px;cursor:var(--pn-cursor-pointer)}.pn-jslib-section-header:hover{border-color:var(--pn-border);background:color-mix(in srgb,var(--pn-accent) 6%,transparent)}.pn-jslib-section-caret{flex:0 0 auto;color:var(--pn-accent);width:12px;display:inline-block}.pn-jslib-section-label{flex:1 1 auto;text-transform:lowercase}.pn-jslib-section-count{flex:0 0 auto;font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 55%,transparent)}.pn-jslib-empty{font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 50%,transparent);font-style:italic}.pn-jslib-list{display:flex;flex-direction:column;gap:4px}.pn-jslib-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border:1px solid transparent}.pn-jslib-row:hover{border-color:var(--pn-border);background:color-mix(in srgb,var(--pn-accent) 6%,transparent)}.pn-jslib-name{flex:1 1 auto;font-size:var(--pn-type-body);white-space:normal;word-break:break-word;line-height:1.3}.pn-jslib-name-input{flex:1 1 auto;background:var(--pn-surface);border:1px solid var(--pn-accent);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-body);padding:2px 4px}.pn-jslib-actions{display:flex;gap:4px;flex:0 0 auto}.pn-jslib-btn{background:transparent;border:1px solid var(--pn-border);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);padding:2px 8px;cursor:var(--pn-cursor-pointer)}.pn-jslib-btn:hover{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-jslib-btn-danger:hover{border-color:var(--pn-error, #ff6464);color:var(--pn-error, #ff6464)}.pn-jslib-btn-primary{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-jslib-btn-primary:hover{background:color-mix(in srgb,var(--pn-accent) 12%,transparent)}.pn-jseffect-body{flex:1;display:flex;flex-direction:row;min-height:0;min-width:0}.pn-jseffect-slider-col{display:flex;flex-direction:column;flex:2 1 0;min-width:180px;background:var(--pn-bg-deep);border-right:1px solid var(--pn-border)}.pn-jseffect-slider-header{position:relative;height:var(--pn-attrui-header-h);min-height:var(--pn-attrui-header-h);display:flex;align-items:center;gap:4px;padding:0 6px;border-bottom:1px solid var(--pn-border);background:var(--pn-surface)}.pn-jseffect-sliders{flex:1 1 0;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.pn-jseffect-code-col{display:flex;flex-direction:column;flex:1 1 0;min-width:180px;min-height:0}.pn-jseffect-code{flex:1 1 0;min-height:0;min-width:0;overflow:auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-body)}.pn-jseffect-code .cm-editor{height:100%;background:var(--pn-bg-deep);color:var(--pn-text)}.pn-jseffect-code .cm-content{caret-color:var(--pn-accent)}.pn-jseffect-code .cm-cursor{border-left-color:var(--pn-accent)}.pn-jseffect-code .cm-gutters{background:var(--pn-surface);border-right:1px solid var(--pn-border);color:color-mix(in srgb,var(--pn-text) 50%,transparent)}.pn-jseffect-empty{font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 50%,transparent);font-style:italic;padding:4px 10px}.pn-jseffect-slider-row{display:flex;align-items:center;gap:5px;padding:2px 6px;height:var(--pn-attrui-row-h);min-height:var(--pn-attrui-row-h);box-sizing:border-box}.pn-jseffect-slider-label{flex:0 0 72px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right;-webkit-user-select:none;user-select:none}.pn-jseffect-slider-readout{flex:0 0 40px;font-family:var(--pn-font-mono);font-size:9px;color:var(--pn-accent);text-align:right;white-space:nowrap;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums}.pn-jseffect-slider-range{flex:1 1 auto;min-width:0;height:12px;accent-color:var(--pn-accent);cursor:var(--pn-cursor-pointer);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;margin:0}.pn-jseffect-slider-range::-webkit-slider-runnable-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-jseffect-slider-range::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--pn-accent);margin-top:-4px;box-shadow:0 0 5px var(--pn-accent-glow)}.pn-jseffect-slider-range:hover::-webkit-slider-thumb,.pn-jseffect-slider-range:focus::-webkit-slider-thumb{box-shadow:0 0 10px var(--pn-accent),0 0 4px var(--pn-accent)}.pn-jseffect-slider-range::-moz-range-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-jseffect-slider-range::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--pn-accent);border:none;box-shadow:0 0 5px var(--pn-accent-glow)}.pn-jseffect-status{padding:4px 10px;border-top:1px solid var(--pn-border);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 65%,transparent);min-height:18px;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pn-jseffect-status[data-kind=error]{color:var(--pn-error, #ff6464)}.pn-jseffect-status[data-kind=ok]{color:var(--pn-accent)}[data-node-type="browser~*"]{border:1px solid var(--pn-border-accent);border-radius:14px;padding:28px 22px 34px;background:radial-gradient(ellipse at 50% -20%,rgba(0,255,0,.1),transparent 55%),radial-gradient(ellipse at 50% 120%,rgba(0,255,0,.05),transparent 55%),linear-gradient(180deg,#00300059,#001200d9 18%,#000,#001200d9 82%,#00300059);box-shadow:inset 0 2px #00ff008c,inset 2px 0 #00ff0047,inset -2px 0 #000000d9,inset 0 -3px #000000e6,inset 0 0 0 4px #000000c7,inset 0 0 0 5px #00ff0042,0 0 0 1px #000000f2,0 3px #00ff001f,0 14px 40px #000c;cursor:move}[data-node-type="browser~*"]:before,[data-node-type="browser~*"]:after{content:"";position:absolute;width:8px;height:8px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#00ff00bf,#005000 55%,#000);box-shadow:inset 0 0 0 1px #000000d9,0 0 4px #00ff0073;pointer-events:none}[data-node-type="browser~*"]:before{top:10px;left:10px}[data-node-type="browser~*"]:after{top:10px;right:10px}.patch-object-browser-body{display:flex;flex-direction:column;min-height:0;min-width:0;padding:0;border-radius:5px;background:#000;box-shadow:inset 0 0 0 1px #0f06,inset 0 0 14px #000000e6,inset 0 0 28px #00ff000d;overflow:hidden}.pn-browser-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-browser-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);background:var(--pn-surface);overflow:hidden}.pn-browser-btn{background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:3px 10px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);cursor:pointer}.pn-browser-btn:hover:not(:disabled){border-color:var(--pn-accent);color:var(--pn-accent)}.pn-browser-btn:disabled{opacity:.4;cursor:default}.pn-browser-btn-primary{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-browser-preview{flex:1;position:relative;min-height:0;background:var(--pn-bg)}.pn-browser-mirror{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#000}.pn-browser-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px;padding:14px 18px;overflow:auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);line-height:1.45;color:color-mix(in srgb,var(--pn-text) 78%,transparent);background:var(--pn-bg)}.pn-browser-help-title{color:var(--pn-accent);font-size:var(--pn-type-chip);letter-spacing:.05em;text-transform:uppercase}.pn-browser-help-steps{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:3px}.pn-browser-help-steps code,.pn-browser-help-rules code{background:color-mix(in srgb,var(--pn-accent) 15%,transparent);color:var(--pn-accent);padding:0 3px;border-radius:2px}.pn-browser-help-rules{display:flex;flex-direction:column;gap:5px;padding:8px 10px;border:1px solid var(--pn-border);background:color-mix(in srgb,var(--pn-surface) 60%,transparent);color:color-mix(in srgb,var(--pn-text) 85%,transparent)}.pn-browser-help-rules b{color:var(--pn-text)}.pn-browser-controls{display:flex;gap:6px;align-items:center;padding:4px 8px;border-top:1px solid var(--pn-border);flex:0 0 auto}.pn-browser-status{margin-left:auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 65%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pn-browser-status[data-state=on]{color:var(--pn-accent)}.pn-browser-status[data-state=err]{color:var(--pn-error, #ff6464)}.patch-object-youtube-body{display:flex;flex-direction:column;min-height:0;min-width:0;padding:0;border-radius:5px;background:#000;overflow:hidden}.pn-youtube-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-youtube-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);background:var(--pn-surface);overflow:hidden}.pn-youtube-url-row{display:flex;gap:6px;padding:6px 8px;border-bottom:1px solid var(--pn-border);flex:0 0 auto}.pn-youtube-url-input{flex:1;min-width:0;background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:3px 8px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip)}.pn-youtube-url-input:focus{outline:none;border-color:var(--pn-accent)}.pn-youtube-error{flex:0 0 auto;padding:0 10px;color:var(--pn-error, #ff6464);font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);min-height:0;line-height:1.4}.pn-youtube-error:not(:empty){padding:4px 10px}.pn-youtube-preview{flex:1;position:relative;min-height:0;background:#000}.pn-youtube-iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;background:#000}.pn-youtube-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:10px;font-family:var(--pn-font-sans);font-size:var(--pn-type-chip);color:color-mix(in srgb,var(--pn-text) 65%,transparent);text-align:center;background:var(--pn-bg)}.pn-youtube-controls{display:flex;gap:6px;align-items:center;padding:4px 8px;border-top:1px solid var(--pn-border);flex:0 0 auto}.pn-youtube-btn{background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:3px 10px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);cursor:pointer}.pn-youtube-btn:hover:not(:disabled){border-color:var(--pn-accent);color:var(--pn-accent)}.pn-youtube-btn:disabled{opacity:.4;cursor:default}.pn-youtube-btn-primary{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-youtube-status{margin-left:auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 65%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pn-youtube-status[data-state=on]{color:var(--pn-accent)}.pn-youtube-status[data-state=err]{color:var(--pn-error, #ff6464)}.patch-object-youtube-body[data-locked="1"] .pn-youtube-panel-host,.patch-object-youtube-body[data-locked="1"] .pn-youtube-panel-host *{pointer-events:none}.patch-object-youtube-body .pn-subpatch-lock{pointer-events:auto!important;cursor:var(--pn-cursor-pointer)!important}.patch-object-youtube-body[data-locked="1"] .pn-youtube-panel{outline:1px dashed color-mix(in srgb,var(--pn-accent) 50%,transparent);outline-offset:-1px}.patch-object-mixer-body{padding:0;overflow:hidden}.pn-mixer-panel-host{width:100%;height:100%}.patch-object-mixer-body[data-locked="0"] .pn-mixer-panel-host,.patch-object-mixer-body[data-locked="0"] .pn-mixer-panel-host *{cursor:var(--pn-cursor-pointer)!important}.patch-object-mixer-body[data-locked="1"] .pn-mixer-panel-host{pointer-events:none}.patch-object-mixer-body[data-locked="1"] .pn-mixer-panel{outline:1px dashed color-mix(in srgb,var(--pn-accent) 50%,transparent);outline-offset:-1px}.patch-object-mixer-body .pn-subpatch-lock{pointer-events:auto!important;cursor:var(--pn-cursor-pointer)!important}.pn-mixer-panel{display:flex;flex-direction:row;align-items:stretch;width:100%;height:100%;padding:4px;gap:3px;box-sizing:border-box;overflow-x:auto;overflow-y:hidden}.pn-mixer-strip{display:flex;flex-direction:column;align-items:center;flex:1 1 0;min-width:22px;gap:2px;container-type:inline-size}.pn-mixer-pan-label{font-family:var(--pn-font-mono);font-size:clamp(5px,20cqi,11px);color:var(--pn-text-dim);letter-spacing:.04em;line-height:1;text-align:center;-webkit-user-select:none;user-select:none}.pn-mixer-pan{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:clamp(8px,25cqi,16px);background:transparent;outline:none}.pn-mixer-pan::-webkit-slider-runnable-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-mixer-pan::-moz-range-track{height:2px;background:var(--pn-border);border-radius:1px}.pn-mixer-pan::-webkit-slider-thumb{-webkit-appearance:none;width:clamp(5px,15cqi,10px);height:clamp(8px,25cqi,16px);background:var(--pn-accent);border-radius:1px;margin-top:calc(clamp(8px,25cqi,16px)/-2 + 1px)}.pn-mixer-pan::-moz-range-thumb{width:clamp(5px,15cqi,10px);height:clamp(8px,25cqi,16px);background:var(--pn-accent);border-radius:1px;border:none}.pn-mixer-fader-track{position:relative;flex:1 1 0;align-self:stretch;margin:0 2px;border:1px solid var(--pn-border);border-radius:2px;background:var(--pn-bg-deep);overflow:hidden;box-sizing:border-box}.pn-mixer-meter-fill{position:absolute;bottom:0;left:0;width:100%;height:0%;background:#00ff002e;transition:height 40ms linear;pointer-events:none}.pn-mixer-fader-fill{position:absolute;bottom:0;left:0;width:100%;height:75%;background:#00ff001a;pointer-events:none}.pn-mixer-fader-thumb{position:absolute;bottom:75%;left:0;width:100%;height:clamp(3px,8cqi,6px);background:var(--pn-accent);border-radius:1px;transform:translateY(50%);pointer-events:none;box-shadow:0 0 4px #0f09}.pn-mixer-readout{font-family:var(--pn-font-mono);font-size:clamp(5px,18cqi,10px);color:var(--pn-text-dim);text-align:center;line-height:1;white-space:nowrap;-webkit-user-select:none;user-select:none}.pn-mixer-ch-label{font-family:var(--pn-font-mono);font-size:clamp(6px,22cqi,12px);color:var(--pn-accent-dim);text-align:center;line-height:1;-webkit-user-select:none;user-select:none}.pn-mixer-strip--linked .pn-mixer-fader-track{border-color:var(--pn-accent)}.pn-mixer-strip--linked-right{border-right:2px solid var(--pn-accent);margin-right:-1px;z-index:1}.pn-mixer-strip--linked-left{border-left:2px solid var(--pn-accent);margin-left:-1px;z-index:1}.pn-mixer-strip--linked .pn-mixer-ch-label:after{content:"=";color:var(--pn-accent);opacity:.8}.patch-object-frame-body{display:block;position:relative;padding:0;background:transparent;border:none;outline:1px dashed var(--pn-accent, #f0c14b);outline-offset:-1px;overflow:visible}.pn-frame-panel-host,.pn-frame-panel{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.pn-frame-capture-rect{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;pointer-events:none}.pn-frame-toolbar{position:absolute;top:-28px;left:0;height:24px;display:flex;align-items:center;gap:6px;pointer-events:auto;font-family:var(--pn-font-mono, monospace);font-size:11px;color:var(--pn-fg, #ddd);background:var(--pn-bg, #111);padding:0 6px;border:1px solid var(--pn-accent, #f0c14b);border-radius:3px;white-space:nowrap}.pn-frame-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;color:var(--pn-fg, #ddd);border:1px solid var(--pn-accent, #f0c14b);font-family:inherit;font-size:11px;padding:1px 6px;cursor:pointer;border-radius:2px}.pn-frame-btn:hover{background:var(--pn-accent, #f0c14b);color:var(--pn-bg, #111)}.pn-frame-btn:disabled{opacity:.5;cursor:default}.pn-frame-btn-primary{font-weight:700}.pn-frame-status{opacity:.8}.pn-frame-status[data-state=on]{color:var(--pn-accent, #f0c14b);opacity:1}.pn-frame-status[data-state=err]{color:var(--pn-error, #ff6464);opacity:1}.patch-object--collide-flash{animation:pn-collide-flash .6s ease-out}@keyframes pn-collide-flash{0%{box-shadow:0 0 0 0 transparent,0 0 0 0 transparent,var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c}35%{box-shadow:0 0 28px 10px var(--pn-accent-glow),0 0 60px 24px #00ff004d,var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c}to{box-shadow:0 0 0 0 transparent,0 0 0 0 transparent,var(--pn-shadow-soft),var(--pn-shadow-inset),0 0 18px #00ff0073,0 0 2px #00ff008c}}.pn-stage-host{position:relative;padding:0;overflow:hidden;container-type:size;display:flex;align-items:center;justify-content:center}.pn-stage{min-width:var(--pn-stage-min-w, 0);min-height:var(--pn-stage-min-h, 0);width:max-content;height:max-content;padding:var(--pn-space-2) var(--pn-space-4);box-sizing:border-box;flex:0 0 auto;transform-origin:center;transform:scale(min(calc(100cqw / var(--pn-stage-w, 100px)),calc(100cqh / var(--pn-stage-h, 50px))))}.patch-object-buffer-body{position:relative;padding:0;overflow:hidden;container-type:size}.pn-buf-stage{position:absolute;top:0;left:0;width:280px;height:110px;box-sizing:border-box;display:flex;flex-direction:column;gap:4px;padding:6px 8px;font-family:var(--pn-font-mono);color:var(--pn-text);transform-origin:top left;transform:scale(min(calc(100cqw/280px),calc(100cqh/110px)))}.pn-buf-title{font-size:var(--pn-type-object-name);color:var(--pn-muted);letter-spacing:.04em}.pn-buf-transport{display:flex;gap:4px}.pn-buf-btn{flex:1;background:transparent;border:1px solid var(--pn-border);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-helper);padding:3px 0;border-radius:var(--pn-radius-xs);cursor:var(--pn-cursor-pointer)!important;line-height:1}.pn-buf-btn:hover{border-color:var(--pn-border-accent);background:var(--pn-hover)}.pn-buf-btn.pn-buf-active{background:var(--pn-active-accent);border-color:var(--pn-accent);color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent)}.pn-buf-wave{display:block;width:100%;height:36px;background:var(--pn-bg-deep);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs)}.pn-buf-info{display:flex;align-items:center;gap:6px;font-size:var(--pn-type-micro);color:var(--pn-muted);white-space:nowrap}.pn-buf-rate{min-width:40px}.pn-buf-loop-on{color:var(--pn-accent)}.pn-buf-maxlen{cursor:text;padding:1px 4px;border:1px dashed transparent;border-radius:var(--pn-radius-xs);-webkit-user-select:none;user-select:none}.pn-buf-maxlen:hover{border-color:var(--pn-border-subtle);color:var(--pn-accent)}.pn-buf-maxlen-input{width:3.2em;font:inherit;color:var(--pn-accent);background:var(--pn-bg-deep);border:1px solid var(--pn-accent);border-radius:var(--pn-radius-xs);padding:0 2px;outline:none}.pn-buf-mode{flex:0 0 auto;padding:1px 6px;font-size:var(--pn-type-micro)}.patch-object-vbuf-body{position:relative;padding:0;overflow:hidden;container-type:size}.pn-vbuf-stage{position:absolute;top:0;left:0;width:280px;height:220px;box-sizing:border-box;display:flex;flex-direction:column;gap:4px;padding:6px 8px;font-family:var(--pn-font-mono);color:var(--pn-text);transform-origin:top left;transform:scale(min(calc(100cqw/280px),calc(100cqh/220px)))}.pn-vbuf-title{font-size:var(--pn-type-object-name);color:var(--pn-muted);letter-spacing:.04em}.pn-vbuf-transport{display:flex;gap:4px}.pn-vbuf-btn{flex:1;background:transparent;border:1px solid var(--pn-border);color:var(--pn-text);font-family:var(--pn-font-mono);font-size:var(--pn-type-helper);padding:3px 0;border-radius:var(--pn-radius-xs);cursor:var(--pn-cursor-pointer)!important;line-height:1}.pn-vbuf-btn:hover{border-color:var(--pn-border-accent);background:var(--pn-hover)}.pn-vbuf-btn.pn-vbuf-active{background:var(--pn-active-accent);border-color:var(--pn-accent);color:var(--pn-accent);text-shadow:0 0 6px var(--pn-accent)}.pn-vbuf-preview{position:relative;width:100%;flex:1 1 auto;min-height:0;background:var(--pn-bg-deep);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs);overflow:hidden}.pn-vbuf-preview>video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#000}.pn-vbuf-strip{display:block;width:100%;height:28px;background:var(--pn-bg-deep);border:1px solid var(--pn-border-subtle);border-radius:var(--pn-radius-xs)}.pn-vbuf-info{display:flex;align-items:center;gap:6px;font-size:var(--pn-type-micro);color:var(--pn-muted);white-space:nowrap}.pn-vbuf-rate{min-width:40px}.pn-vbuf-loop-btn{font:inherit;color:var(--pn-muted);background:transparent;border:1px dashed var(--pn-border-subtle);border-radius:var(--pn-radius-xs);padding:1px 6px;cursor:pointer;-webkit-user-select:none;user-select:none}.pn-vbuf-loop-btn:hover{color:var(--pn-accent);border-color:var(--pn-accent)}.pn-vbuf-loop-btn.pn-vbuf-loop-on{color:var(--pn-accent);border-style:solid;border-color:var(--pn-accent)}.pn-vbuf-maxlen{cursor:text;padding:1px 4px;border:1px dashed transparent;border-radius:var(--pn-radius-xs);-webkit-user-select:none;user-select:none}.pn-vbuf-maxlen:hover{border-color:var(--pn-border-subtle);color:var(--pn-accent)}.pn-vbuf-maxlen-input{width:3.2em;font:inherit;color:var(--pn-accent);background:var(--pn-bg-deep);border:1px solid var(--pn-accent);border-radius:var(--pn-radius-xs);padding:0 2px;outline:none}.patch-object-cam-body{display:flex;flex-direction:column;min-height:0;min-width:0;padding:0;border-radius:5px;background:#000;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--pn-accent) 40%,transparent),inset 0 0 14px #000000e6;overflow:hidden}.pn-cam-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-cam-panel{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;font-family:var(--pn-font-mono);color:var(--pn-text);background:var(--pn-surface);overflow:hidden}.pn-cam-preview{flex:1;position:relative;min-height:0;background:var(--pn-bg)}.pn-cam-mirror{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#000}.pn-cam-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:12px;text-align:center;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 60%,transparent);background:var(--pn-bg)}.pn-cam-controls{display:flex;flex-direction:column;gap:4px;padding:4px 8px;border-top:1px solid var(--pn-border);flex:0 0 auto;min-width:0}.pn-cam-controls-row{display:flex;gap:6px;align-items:center;min-width:0}.pn-cam-btn{background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:3px 10px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);cursor:pointer}.pn-cam-btn:hover:not(:disabled){border-color:var(--pn-accent);color:var(--pn-accent)}.pn-cam-btn:disabled{opacity:.4;cursor:default}.pn-cam-btn-primary{border-color:var(--pn-accent);color:var(--pn-accent)}.pn-cam-device{width:100%;min-width:0;max-width:100%;background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:2px 6px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);outline:none;cursor:pointer;text-overflow:ellipsis}.pn-cam-device:hover:not(:disabled){border-color:var(--pn-accent)}.pn-cam-device:disabled{opacity:.4;cursor:default}.pn-cam-status{flex:0 1 auto;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 65%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:60%}.pn-cam-status:not([data-state]){display:none}.pn-cam-status[data-state=err]{color:var(--pn-error, #ff6464);flex:1 1 auto}.pn-cam-status[data-state=starting]{color:color-mix(in srgb,var(--pn-text) 80%,transparent)}.pn-cam-preview[data-state=on]:after{content:"";position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--pn-accent);box-shadow:0 0 6px var(--pn-accent);pointer-events:none}.pn-peer-panel-host{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.pn-peer-panel{flex:1;display:flex;flex-direction:column;gap:4px;padding:6px 8px;min-height:0;min-width:0;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);color:var(--pn-text);background:var(--pn-surface);overflow:hidden}.pn-peer-role{display:flex;gap:10px;align-items:center;flex:0 0 auto}.pn-peer-role label{display:inline-flex;align-items:center;gap:3px;cursor:pointer;-webkit-user-select:none;user-select:none}.pn-peer-role input[type=radio]{accent-color:var(--pn-accent);margin:0}.pn-peer-status{flex:0 0 auto;font-size:var(--pn-type-micro);color:color-mix(in srgb,var(--pn-text) 65%,transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pn-peer-status[data-status=connected]{color:var(--pn-accent)}.pn-peer-status[data-status=connecting],.pn-peer-status[data-status=creating-offer],.pn-peer-status[data-status=awaiting-answer],.pn-peer-status[data-status=accepting-offer]{color:color-mix(in srgb,var(--pn-text) 80%,transparent)}.pn-peer-status[data-status=failed]{color:var(--pn-error, #ff6464)}.pn-peer-sdp{flex:1 1 auto;min-height:0;width:100%;resize:none;background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:4px 6px;font-family:var(--pn-font-mono);font-size:var(--pn-type-micro);outline:none;word-break:break-all}.pn-peer-sdp:focus{border-color:var(--pn-accent)}.pn-peer-btnrow{display:flex;gap:4px;flex:0 0 auto}.pn-peer-btn{flex:1;background:var(--pn-bg);color:var(--pn-text);border:1px solid var(--pn-border);padding:3px 6px;font-family:var(--pn-font-mono);font-size:var(--pn-type-chip);cursor:pointer}.pn-peer-btn:hover{border-color:var(--pn-accent);color:var(--pn-accent)}
