@import url(https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:wght@400;700&family=Inter:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap);*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.\!grid{display:grid!important}.grid{display:grid}.hidden{display:none}.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rounded{border-radius:.25rem}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--surface-base:#0b0805;--surface-raised:#181614;--surface-sunken:#000;--surface-canvas:#1f1f1f;--content-primary:#edeae5;--content-secondary:#c9c9c9;--content-muted:#8a8a8a;--content-disabled:#4f4f4f;--border-subtle:#1f1f1f;--border-default:#3d3d3d;--border-focus:#fa9c33;--brand:#f98a1b;--brand-hover:#fa9c33;--brand-pressed:#e27713;--brand-tint:#5a2b03;--state-danger:#e24b3d;--state-success:#3eb572;--state-warning:#e6a72c;--state-info:#3a74e8;--radius-sm:2px;--radius-md:4px;--radius-lg:6px}*,:after,:before{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;color:#edeae5;color:var(--content-primary);font-family:Inter,system-ui,sans-serif;font-size:14px;margin:0;padding:0}.app,body{background:#0b0805;background:var(--surface-base)}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{align-items:center;border-bottom:1px solid #3d3d3d;border-bottom:1px solid var(--border-default);display:flex;flex-shrink:0;gap:14px;padding:14px 24px}.header-logo{height:28px;opacity:.95}.header-divider{background:#3d3d3d;background:var(--border-default);flex-shrink:0;height:28px;width:1px}.header-title{display:flex;flex-direction:column;gap:2px}.header-main{color:#edeae5;color:var(--content-primary);font-family:Atkinson Hyperlegible,Inter,sans-serif;font-size:20px;font-weight:700;letter-spacing:-.03em;line-height:1}.header-sub{color:#8a8a8a;color:var(--content-muted);font-size:10px;letter-spacing:.01em;line-height:1}.header-now-playing{align-items:center;background:#ffffff08;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:999px;color:#c9c9c9;color:var(--content-secondary);display:inline-flex;font-size:11px;gap:8px;margin-left:14px;padding:4px 10px;white-space:nowrap}.header-now-effect{color:#edeae5;color:var(--content-primary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:-.01em}.header-now-divider{color:#8a8a8a;color:var(--content-muted);opacity:.7}.header-now-swatch{border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:3px;flex-shrink:0;height:12px;width:22px}.header-now-palette{color:#c9c9c9;color:var(--content-secondary);font-size:11px}.app-body{align-items:flex-start;display:flex;flex:1 1;flex-direction:row;gap:18px;padding:18px 24px 24px}.layout-left{display:flex;flex:1 1;flex-direction:column;gap:14px;min-width:0}.layout-right,.layout-weather{display:flex;flex-direction:column;flex-shrink:0;gap:10px;width:280px}.accumulator-card .acc-section{border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);margin-top:10px;padding-top:8px}.accumulator-card .acc-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.accumulator-card .acc-section-title{color:#f98a1b;color:var(--brand);font-size:10px;font-weight:700;letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase}.accumulator-card .stat-grid{grid-gap:4px 14px;display:grid;gap:4px 14px;grid-template-columns:1fr 1fr}.accumulator-card .stat-label{color:#8a8a8a;color:var(--content-muted);font-size:10px;letter-spacing:.08em;text-transform:uppercase}.accumulator-card .stat-value{color:#edeae5;color:var(--content-primary);font-family:Space Mono,monospace;font-size:12px}.accumulator-card .pos-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.accumulator-card .pos-chip{background:#5a2b03;background:var(--brand-tint);border-radius:2px;border-radius:var(--radius-sm);color:#f98a1b;color:var(--brand);font-family:Space Mono,monospace;font-size:10px;padding:2px 6px}.accumulator-card .acc-weather-section .collapsible-header .nl-section-title{color:#f98a1b;color:var(--brand);font-size:10px;font-weight:700;letter-spacing:.08em;margin-bottom:0;opacity:1;text-transform:uppercase}.acc-weather-chip{color:#c9c9c9;color:var(--content-secondary);font-family:Space Mono,monospace;font-size:10px;text-transform:capitalize}.acc-weather-head{margin-bottom:6px}.acc-weather-location{color:#8a8a8a;color:var(--content-muted);display:block;font-size:10px;letter-spacing:.08em;text-transform:uppercase}.acc-weather-condition{color:#edeae5;color:var(--content-primary);display:block;font-family:Atkinson Hyperlegible,sans-serif;font-size:13px;margin-top:2px;text-transform:capitalize}.acc-weather-fetched{color:#8a8a8a;color:var(--content-muted);font-size:10px;font-style:italic;margin-top:6px}.sensors-panel .sensors-divider{background:#3d3d3d;background:var(--border-default);height:1px;margin:10px 0;opacity:.6}.sensors-summary{align-items:center;display:inline-flex;gap:4px}.sensors-summary-pill{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:9px;letter-spacing:.05em;padding:1px 5px}.sensors-summary-pill.src-live{border-color:#3eb572;border-color:var(--state-success);color:#3eb572;color:var(--state-success)}.sensors-summary-pill.src-synth,.sensors-summary-pill.src-synthetic{border-color:#f98a1b;border-color:var(--brand);color:#f98a1b;color:var(--brand)}.sensors-summary-pill.src-null,.sensors-summary-pill.src-off{color:#8a8a8a;color:var(--content-muted)}.app.demo-mode .app-header,.app.demo-mode .app-rules-bar,.app.demo-mode .canvas-hint,.app.demo-mode .header-now-playing,.app.demo-mode .layout-left .accumulator-card,.app.demo-mode .layout-right,.app.demo-mode .layout-weather,.app.demo-mode .stage-cta{display:none!important}.app.demo-mode .app-body{gap:0;padding:0}.app.demo-mode .panel-canvas{border:none;border-radius:0;padding:0}.sensors-panel .audio-view,.sensors-panel .sensor-view{background:#0000;border:none;border-radius:0;gap:8px;padding:0}.audio-view-compact .sensor-body,.sensor-view-compact .sensor-body{display:flex;flex-direction:column;gap:8px}.audio-view-compact .sensor-primary,.sensor-view-compact .sensor-primary{padding:8px}.sensor-view-compact .sensor-heatmap{height:auto;max-width:100%}.audio-view-compact .sensor-side,.sensor-view-compact .sensor-side{gap:8px}.audio-view-compact .audio-empty .empty{font-size:11px;max-width:none}.demo-exit-pill{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0b0805b3;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:999px;color:#edeae5;color:var(--content-primary);cursor:pointer;font-family:Inter,sans-serif;font-size:11px;font-weight:600;padding:6px 12px;position:fixed;right:16px;top:14px;transition:border-color .12s ease,background .12s ease;z-index:100}.demo-exit-pill:hover{background:#0b0805d9;border-color:#f98a1b;border-color:var(--brand);color:#f98a1b;color:var(--brand)}.brush-library .brush-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.brush-chip{align-items:center;background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-md);color:#c9c9c9;color:var(--content-secondary);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;font-size:10px;gap:4px;padding:6px 4px;transition:border-color .12s ease,transform .12s ease,box-shadow .12s ease}.brush-chip:hover{border-color:#fa9c33;border-color:var(--brand-hover);transform:translateY(-1px)}.brush-chip.active{border-color:#f98a1b;border-color:var(--brand);box-shadow:0 0 0 1px #f98a1b,0 0 12px #f98a1b40;box-shadow:0 0 0 1px var(--brand),0 0 12px #f98a1b40;color:#edeae5;color:var(--content-primary)}.brush-preview-canvas{background:#0006;border-radius:2px;border-radius:var(--radius-sm);display:block}.brush-chip-label{font-family:Inter,sans-serif;font-size:10px;font-weight:600;letter-spacing:.02em;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.brush-active-meta{border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);margin-top:10px;min-height:28px;padding-top:8px}.brush-active-name{color:#f98a1b;color:var(--brand);font-family:Atkinson Hyperlegible,sans-serif;font-size:12px;font-weight:700;margin-bottom:2px}.brush-active-spec{font-family:Space Mono,monospace;font-size:10px}.brush-active-spec,.brush-empty-hint{color:#8a8a8a;color:var(--content-muted);line-height:1.35}.brush-empty-hint{font-size:11px;font-style:italic}.btn-paint-toggle{align-items:center;background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-md);color:#edeae5;color:var(--content-primary);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:11px;font-weight:600;gap:6px;justify-content:center;letter-spacing:.02em;margin-top:8px;padding:6px 10px;transition:border-color .12s ease,background .12s ease,box-shadow .12s ease;width:100%}.btn-paint-toggle:hover:not(:disabled){border-color:#fa9c33;border-color:var(--brand-hover);color:#fa9c33;color:var(--brand-hover)}.btn-paint-toggle:disabled{cursor:not-allowed;opacity:.4}.btn-paint-toggle.active{background:#f98a1b;background:var(--brand);border-color:#f98a1b;border-color:var(--brand);box-shadow:0 0 12px #f98a1b59;color:#0b0805;color:var(--surface-base)}.btn-paint-toggle.active:hover{background:#fa9c33;background:var(--brand-hover)}.panel-canvas.paint-active{border-color:#f98a1b;border-color:var(--brand);box-shadow:0 0 0 1px #f98a1b,0 0 18px #f98a1b40;box-shadow:0 0 0 1px var(--brand),0 0 18px #f98a1b40;position:relative}.panel-canvas.paint-active .canvas-container,.panel-canvas.paint-active .canvas-container canvas{cursor:crosshair}.paint-hud{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0b0805c7;border:1px solid #f98a1b;border:1px solid var(--brand);border-radius:999px;color:#edeae5;color:var(--content-primary);display:inline-flex;font-family:Inter,sans-serif;font-size:11px;gap:8px;left:14px;padding:5px 10px 5px 8px;pointer-events:auto;position:absolute;top:10px;z-index:5}.paint-hud-dot{animation:paint-hud-pulse 1.6s ease-in-out infinite;background:#f98a1b;background:var(--brand);border-radius:50%;box-shadow:0 0 8px #f98a1b;box-shadow:0 0 8px var(--brand);height:8px;width:8px}@keyframes paint-hud-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.paint-hud-label{font-weight:600;letter-spacing:.04em}.paint-hud-brush{border:1px solid #f98a1b;border:1px solid var(--brand);border-radius:999px;color:#f98a1b;color:var(--brand);font-family:Space Mono,monospace;font-size:10px;padding:1px 6px}.paint-hud-exit{background:#0000;border:none;border-radius:50%;color:#8a8a8a;color:var(--content-muted);cursor:pointer;font-size:14px;height:16px;line-height:1;margin-left:4px;padding:0;width:16px}.paint-hud-exit:hover{color:#e24b3d;color:var(--state-danger)}.app-footer{align-items:center;border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);color:#8a8a8a;color:var(--content-muted);display:flex;font-family:Inter,sans-serif;font-size:11px;gap:8px;margin-top:6px;padding:14px 24px 18px}.app-footer-brand{color:#f98a1b;color:var(--brand);font-family:Atkinson Hyperlegible,sans-serif;font-weight:700;letter-spacing:.04em}.app-footer-sep{opacity:.5}.app-footer-tag{letter-spacing:.02em}.app-footer-spacer{flex:1 1}.app-footer-meta{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.06em;opacity:.7;text-transform:uppercase}.app.demo-mode .app-footer{display:none!important}.accumulator-card .empty,.rules-card .empty{color:#8a8a8a;color:var(--content-muted);font-size:12px;font-style:italic}.rules-card .rule-row{border-left:2px solid #3d3d3d;border-left:2px solid var(--border-default);border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);margin-left:-8px;margin-top:10px;padding-left:8px;padding-top:8px;transition:border-left-color .15s ease}.rules-card .rule-row:first-of-type{border-top:none;margin-top:0;padding-top:0}.rules-card .rule-row.state-applied{border-left-color:#3eb572;border-left-color:var(--state-success)}.rules-card .rule-row.state-pending{border-left-color:#e6a72c;border-left-color:var(--state-warning)}.rules-card .rule-row.state-fired{border-left-color:#f98a1b;border-left-color:var(--brand)}.rules-card .rule-row.state-inactive{border-left-color:#1f1f1f;border-left-color:var(--border-subtle)}.rules-card .rule-head{align-items:baseline;display:flex;gap:6px;margin-bottom:6px}.rules-card .rule-name{color:#edeae5;color:var(--content-primary);flex:1 1;font-family:Space Mono,monospace;font-size:12px;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis}.rules-card .rule-kind{border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--content-muted);padding:1px 4px}.rules-card .rule-kind,.rules-card .rule-state{font-size:9px;letter-spacing:.08em;text-transform:uppercase}.rules-card .state-applied .rule-state{color:#3eb572;color:var(--state-success)}.rules-card .state-pending .rule-state{color:#e6a72c;color:var(--state-warning)}.rules-card .state-fired .rule-state{color:#f98a1b;color:var(--brand)}.rules-card .state-inactive .rule-state{color:#8a8a8a;color:var(--content-muted)}.rules-card .rule-condition{color:#c9c9c9;color:var(--content-secondary);font-family:Space Mono,monospace;font-size:11px;margin-bottom:4px;word-break:break-word}.rules-card .rule-action{display:flex;font-family:Space Mono,monospace;font-size:11px;gap:8px}.rules-card .rule-arrow{color:#f98a1b;color:var(--brand);font-weight:700;min-width:44px}.rules-card .rule-action-body{color:#edeae5;color:var(--content-primary);word-break:break-word}.rules-card .rule-hold{color:#8a8a8a;color:var(--content-muted);font-size:10px;margin-top:4px}.rules-card .panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.rules-card .panel-header .panel-title{margin:0}.rules-card .rule-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.rules-card .btn{background:#181614;background:var(--surface-raised);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#edeae5;color:var(--content-primary);cursor:pointer;font-family:Inter,sans-serif;font-size:11px;font-weight:600;padding:4px 10px;transition:background .12s ease,border-color .12s ease}.rules-card .btn:hover{border-color:#fa9c33;border-color:var(--brand-hover)}.rules-card .btn:disabled{cursor:not-allowed;opacity:.5}.rules-card .btn-small{font-size:10px;padding:3px 8px}.rules-card .btn-primary{background:#f98a1b;background:var(--brand);border-color:#f98a1b;border-color:var(--brand);color:#0b0805;color:var(--surface-base)}.rules-card .btn-primary:hover{background:#fa9c33;background:var(--brand-hover)}.rules-card .btn-danger{background:#0000;border-color:#e24b3d;border-color:var(--state-danger);color:#e24b3d;color:var(--state-danger)}.rules-card .btn-danger:hover{background:#e24b3d1f}.rules-card .btn-secondary{background:#0000}.rules-card .rule-editor{display:flex;flex-direction:column;gap:6px;margin-top:8px}.rules-card .rule-form-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.rules-card .rule-form-label{color:#8a8a8a;color:var(--content-muted);font-size:10px;letter-spacing:.08em;min-width:44px;text-transform:uppercase}.rules-card .rule-input{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#edeae5;color:var(--content-primary);flex:1 1;font-family:Space Mono,monospace;font-size:11px;min-width:0;padding:3px 6px}.rules-card .rule-input:focus{border-color:#fa9c33;border-color:var(--border-focus);outline:none}.rules-card .rule-unit{color:#8a8a8a;color:var(--content-muted);font-size:10px}.rules-card .rule-enabled-toggle{align-items:center;color:#c9c9c9;color:var(--content-secondary);cursor:pointer;display:flex;font-size:11px;gap:4px}.rules-card .rule-form-buttons{display:flex;gap:6px;margin-top:4px}.app-rules-bar{padding:0 24px 28px}.app-rules-bar .rules-card{margin:0}.rules-summary{align-items:center;color:#8a8a8a;color:var(--content-muted);display:inline-flex;font-family:Space Mono,monospace;font-size:10px;gap:6px}.rules-summary-sep{opacity:.5}.rules-summary-active{color:#f98a1b;color:var(--brand)}.rules-summary-idle{color:#8a8a8a;color:var(--content-muted)}.rules-add-btn{align-items:center;display:inline-flex;gap:3px}.rule-disabled-badge{background:#000;background:var(--surface-sunken);border-radius:2px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--content-muted);font-size:9px;letter-spacing:.08em;padding:1px 5px;text-transform:uppercase}.rule-input-stack{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.rule-input-hint{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:10px;line-height:1.3}.rules-card .rule-input-op{flex:0 0 110px}.rules-card .rule-input-kind{flex:0 0 96px}.rules-card .rule-form-meta{border-bottom:1px dashed #1f1f1f;border-bottom:1px dashed var(--border-subtle);margin-bottom:2px;padding-bottom:6px}.rules-body{display:flex;flex-direction:column}.rules-body.rules-layout-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.rules-body.rules-layout-grid>.rule-row{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border-left:3px solid #3d3d3d;border:1px solid var(--border-default);border-left-width:3px;border-radius:4px;border-radius:var(--radius-md);margin:0;padding:10px 12px}.rules-body.rules-layout-grid>.rule-row.editing{background:#181614;background:var(--surface-raised);border-left-color:#f98a1b;border-left-color:var(--brand);grid-column:1/-1}.rules-body.rules-layout-grid>.rule-row:first-of-type{border-top:1px solid #3d3d3d;border-top:1px solid var(--border-default);margin-top:0;padding-top:10px}.rules-body.rules-layout-grid>.rule-row.state-applied{border-left-color:#3eb572;border-left-color:var(--state-success)}.rules-body.rules-layout-grid>.rule-row.state-pending{border-left-color:#e6a72c;border-left-color:var(--state-warning)}.rules-body.rules-layout-grid>.rule-row.state-fired{border-left-color:#f98a1b;border-left-color:var(--brand)}.rules-body.rules-layout-grid>.rule-row.state-inactive{border-left-color:#1f1f1f;border-left-color:var(--border-subtle)}.panel{background:#181614;background:var(--surface-raised);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:6px;border-radius:var(--radius-lg);padding:14px}.panel-sm{padding:10px 12px}.panel-title{color:#8a8a8a;color:var(--content-muted);display:block;font-size:10px;font-weight:700;letter-spacing:.1em;margin:0 0 10px;text-transform:uppercase}.panel-canvas{background:#1f1f1f;background:var(--surface-canvas);box-shadow:0 0 0 1px #f98a1b14,0 4px 18px #00000059}.figures-overlay{inset:0;pointer-events:none;position:absolute}.figure{background:#0000;border-radius:50%;cursor:grab;pointer-events:auto;position:absolute;transform:translate(-50%,-50%);user-select:none;-webkit-user-select:none}.figure:active{cursor:grabbing}.figure-bank-stack{pointer-events:auto;position:absolute;right:6px;top:6px;width:-webkit-fit-content;width:fit-content;z-index:5}.bank-slot{align-items:center;background:#181614;background:var(--surface-raised);border:1px dashed #1f1f1f;border:1px dashed var(--border-subtle);border-radius:2px;border-radius:var(--radius-sm);color:#edeae5;color:var(--content-primary);cursor:grab;display:flex;height:56px;justify-content:center;touch-action:none;transition:border-color .12s ease,background .12s ease;user-select:none;-webkit-user-select:none;width:44px}.bank-slot:hover:not(.empty){border-color:#f98a1b;border-color:var(--brand)}.bank-slot:active:not(.empty){cursor:grabbing}.bank-slot.empty{background:#0000;border-style:solid;color:#8a8a8a;color:var(--content-muted);cursor:default;font-family:Space Mono,monospace;font-size:10px}.canvas-container{display:block;max-height:920px;overflow-x:auto;overflow-y:hidden;text-align:center;width:100%}.canvas-container>*{display:inline-block;text-align:left}canvas{border:1px solid #3d3d3d;border:1px solid var(--border-default);cursor:crosshair;display:block}.canvas-hint{color:#8a8a8a;color:var(--content-muted);font-size:11px;line-height:1.4;margin:8px 0 0}.msg-error,.msg-info{align-items:flex-start;border-radius:4px;border-radius:var(--radius-md);display:flex;font-size:12px;gap:8px;line-height:1.4;margin-top:10px;padding:9px 11px}.msg-info{background:#3a74e81a;border:1px solid #3a74e838;color:#7ba8f0}.msg-error{background:#e24b3d1a;border:1px solid #e24b3d38;color:#f08a82}.edit-panels{align-items:flex-start;display:flex;flex-direction:row;gap:12px}.edit-panel-modules{flex-shrink:0;width:200px}.edit-panel-language{flex:1 1;min-width:0}.module-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(3,1fr);margin-bottom:10px}.module-btn{align-items:center;background:#3b82f6;border:2px solid #0000;border-radius:4px;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:3px;justify-content:center;padding:6px 3px;transition:all .12s ease}.module-btn:hover{filter:brightness(1.18);transform:scale(1.04)}.module-btn.active{border-color:#f98a1b;border-color:var(--brand);box-shadow:0 0 0 1px #f98a1b;box-shadow:0 0 0 1px var(--brand)}.module-label{color:#fff;font-size:8px;font-weight:700;line-height:1}button{border:none;font-family:inherit}.btn,button{cursor:pointer;transition:all .12s ease}.btn{align-items:center;border:none;border-radius:4px;border-radius:var(--radius-md);display:flex;font-size:11px;font-weight:600;gap:5px;justify-content:center;letter-spacing:.01em;padding:7px 12px;width:100%}.btn:disabled{cursor:not-allowed;opacity:.35}.btn-primary{background:#f98a1b;background:var(--brand);color:#000}.btn-primary:hover:not(:disabled){background:#fa9c33;background:var(--brand-hover)}.btn-primary:active:not(:disabled){background:#e27713;background:var(--brand-pressed)}.btn-ghost{background:#ffffff0d;border:1px solid #3d3d3d;border:1px solid var(--border-default);color:#c9c9c9;color:var(--content-secondary)}.btn-ghost:hover:not(:disabled){background:#ffffff17}.btn-success{background:#3eb572;background:var(--state-success);color:#000}.btn-success:hover:not(:disabled){filter:brightness(1.12)}.btn-danger{background:#e24b3d;background:var(--state-danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-blue{background:#3a74e8;background:var(--state-info);color:#fff}.btn-blue:hover:not(:disabled){filter:brightness(1.1)}.btn-effect{background:#0b0805;background:var(--surface-base);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#c9c9c9;color:var(--content-secondary);cursor:pointer;font-size:11px;font-weight:600;padding:6px 8px;text-align:center;transition:all .12s;width:100%}.btn-effect:hover:not(:disabled){background:#ffffff0f;color:#edeae5;color:var(--content-primary)}.btn-effect.active{background:#f98a1b;background:var(--brand);border-color:#f98a1b;border-color:var(--brand);color:#000;font-weight:700}.btn-effect:disabled{cursor:not-allowed;opacity:.35}.btn-expand{align-items:center;border:none;color:#edeae5;color:var(--content-primary);cursor:pointer;display:flex;justify-content:space-between;padding:0;width:100%}.btn-expand,.btn-expand:hover{background:none}.btn-row{display:flex;gap:6px}.btn-row .btn{flex:1 1}.stack-2>*+*{margin-top:6px}.stack-3>*+*{margin-top:10px}.input-text{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-md);color:#edeae5;color:var(--content-primary);font-family:Space Mono,monospace;font-size:11px;outline:none;padding:7px 10px;transition:border-color .12s;width:100%}.input-text:focus{border-color:#fa9c33;border-color:var(--border-focus)}.input-text::placeholder{color:#4f4f4f;color:var(--content-disabled)}textarea.input-text{font-size:11px;height:128px;line-height:1.5;max-height:320px;min-height:64px;resize:vertical}select.input-text{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='m0 0 5 6 5-6z' fill='%238a8a8a'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;cursor:pointer;padding-right:28px}select.input-text option{background:#181614;background:var(--surface-raised);color:#edeae5;color:var(--content-primary)}input[type=range]{accent-color:#f98a1b;accent-color:var(--brand);cursor:pointer;display:block;height:4px;width:100%}input[type=range]:disabled{cursor:not-allowed;opacity:.35}.slider-row{align-items:center;display:flex;gap:8px;min-width:0}.slider-label{color:#8a8a8a;color:var(--content-muted);flex-shrink:0;font-family:Space Mono,monospace;font-size:10px;width:34px}.slider-track{flex:1 1;min-width:0;width:0}.slider-track input[type=range]{width:100%}.slider-val{color:#8a8a8a;color:var(--content-muted);flex-shrink:0;font-family:Space Mono,monospace;font-size:10px;text-align:right;width:26px}.status-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.status-dot.connected{background:#3eb572;background:var(--state-success)}.status-dot.disconnected{background:#e24b3d;background:var(--state-danger)}.palette-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(4,1fr)}.palette-swatch{border:1px solid #ffffff26;border-radius:3px;cursor:pointer;height:22px;padding:0;transition:transform .1s ease,border-color .1s ease}.palette-swatch:hover{border-color:#ffffff80;transform:scale(1.04)}.palette-swatch.active{border-color:#3b82f6;border-color:var(--accent-primary,#3b82f6);box-shadow:0 0 0 1px #3b82f6;box-shadow:0 0 0 1px var(--accent-primary,#3b82f6)}.palette-swatch-wrap{height:22px;position:relative}.palette-swatch-wrap .palette-swatch{height:100%;width:100%}.palette-edit-btn{align-items:center;background:#0000008c;border:0;border-radius:2px;color:#ffffffd9;cursor:pointer;display:none;height:14px;justify-content:center;padding:0;position:absolute;right:1px;top:1px;width:14px}.palette-swatch-wrap:hover .palette-edit-btn{display:flex}.palette-edit-btn:hover{background:#000c;color:#fff}.nl-palette-footer{align-items:center;display:flex;gap:6px;margin-top:4px}.nl-palette-footer .nl-slider-hint{flex:1 1;margin-top:0}.nl-save-defaults{align-items:center;display:inline-flex;font-size:9px;gap:3px;padding:2px 6px}.palette-swatch.palette-new{align-items:center;background:#ffffff0a;border-style:dashed;color:#fff9;display:flex;justify-content:center}.palette-swatch.palette-new:hover{background:#ffffff14;border-style:dashed;color:#fff}.pe-backdrop{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.pe-modal{background:#181614;background:var(--surface-raised);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:8px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;gap:8px;max-height:85vh;overflow-y:auto;padding:16px;width:480px}.pe-header{align-items:center;display:flex;gap:6px}.pe-title{color:var(--content-default);flex:1 1;font-size:12px;font-weight:600}.pe-close{align-items:center;background:#0000;border:0;color:#8a8a8a;color:var(--content-muted);cursor:pointer;display:flex;padding:4px}.pe-close:hover{color:#fff}.pe-preview{background:#222;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;height:30px}.pe-row{align-items:center;display:flex;gap:6px}.pe-label{color:#8a8a8a;color:var(--content-muted);font-size:10px;width:50px}.pe-name{flex:1 1}.pe-warn{color:#f59e0b;font-size:10px;padding:2px 0}.pe-section-title{color:#8a8a8a;color:var(--content-muted);font-size:9px;font-weight:700;letter-spacing:.12em;margin-top:4px;text-transform:uppercase}.pe-stops{display:flex;flex-direction:column;gap:3px;max-height:280px;overflow-y:auto;padding-right:2px}.pe-stop{align-items:center;display:flex;gap:6px}.pe-stop-color{background:#0000;border:1px solid #3d3d3d;border:1px solid var(--border-default)}.pe-stop-color,.pe-stop-swatch{border-radius:3px;cursor:pointer;height:22px;padding:0;width:28px}.pe-stop-swatch{border:1px solid #3d3d3d;border:1px solid var(--border-default);transition:transform .1s ease,border-color .1s ease}.pe-stop-swatch:hover{border-color:#ffffff80;transform:scale(1.06)}.pe-stop.active .pe-stop-swatch{border-color:#3b82f6;border-color:var(--accent-primary,#3b82f6);box-shadow:0 0 0 1px #3b82f6;box-shadow:0 0 0 1px var(--accent-primary,#3b82f6)}.hwp{background:#ffffff08;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:8px}.hwp-row{align-items:center;display:flex;gap:10px;justify-content:center}.hwp-wheel{border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:50%;cursor:crosshair;flex-shrink:0;height:140px;position:relative;touch-action:none;width:140px}.hwp-wheel-shade{inset:0;mix-blend-mode:multiply}.hwp-wheel-marker,.hwp-wheel-shade{border-radius:50%;pointer-events:none;position:absolute}.hwp-wheel-marker{border:2px solid #fff;box-shadow:0 0 0 1px #0009;height:10px;transform:translate(-50%,-50%);width:10px}.hwp-value{-webkit-appearance:slider-vertical;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;height:140px;margin:0;padding:0;width:18px;writing-mode:bt-lr}.hwp-inputs{grid-gap:4px;align-items:center;display:grid;gap:4px;grid-template-columns:auto 1fr auto 1fr auto 1fr auto 2fr}.hwp-label{color:#8a8a8a;color:var(--content-muted)}.hwp-hex,.hwp-label,.hwp-num{font-family:ui-monospace,SFMono-Regular,monospace;font-size:10px}.hwp-hex,.hwp-num{background:#0000004d;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:3px;box-sizing:border-box;color:var(--content-default);min-width:0;padding:2px 4px;width:100%}.hwp-num::-webkit-inner-spin-button,.hwp-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.hwp-num{-moz-appearance:textfield}.pe-stop-pos{flex:1 1}.pe-stop-pos-val{font-feature-settings:"tnum";font-size:10px;font-variant-numeric:tabular-nums;text-align:right;width:26px}.pe-stop-del,.pe-stop-pos-val{color:#8a8a8a;color:var(--content-muted)}.pe-stop-del{align-items:center;background:#0000;border:0;cursor:pointer;display:flex;padding:2px 4px}.pe-stop-del:hover{color:#ef4444}.pe-stop-del:disabled{cursor:not-allowed;opacity:.3}.pe-add{align-self:flex-start}.pe-hint{color:#8a8a8a;color:var(--content-muted);font-size:10px;font-style:italic;opacity:.85;padding:4px 0}.pe-footer{align-items:center;border-top:1px solid #3d3d3d;border-top:1px solid var(--border-default);display:flex;gap:6px;margin-top:4px;padding-top:8px}.pe-autosave-hint{color:#8a8a8a;color:var(--content-muted);font-size:10px;font-style:italic}.noise-lab .panel-title{margin-bottom:10px}.nl-section{border-top:1px solid #3d3d3d;border-top:1px solid var(--border-default);margin-top:6px;padding-top:6px}.nl-section:first-of-type{border-top:0;margin-top:0;padding-top:0}.nl-section-title{color:#8a8a8a;color:var(--content-muted);font-size:9px;font-weight:700;letter-spacing:.12em;margin-bottom:4px;opacity:.75;text-transform:uppercase}.collapsible-header{align-items:center;background:none;border:none;color:#edeae5;color:var(--content-primary);cursor:pointer;display:flex;gap:4px;padding:0;text-align:left;width:100%}.collapsible-header:hover{background:none}.collapsible-header:focus-visible{outline:1px solid #f98a1b;outline:1px solid var(--brand);outline-offset:2px}.collapsible-section .collapsible-header .nl-section-title{margin-bottom:0}.collapsible-section.is-open .collapsible-header{margin-bottom:4px}.collapsible-panel .collapsible-header .panel-title{margin:0}.collapsible-panel.is-open .collapsible-header{margin-bottom:8px}.collapsible-chevron{flex-shrink:0;opacity:.7}.collapsible-header:hover .collapsible-chevron{opacity:1}.collapsible-right{align-items:center;display:flex;gap:6px;margin-left:auto}.collapsible-count{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:10px;opacity:.75}.collapsible-panel-wrap.is-closed{padding-bottom:8px}.acc-summary{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:10px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nl-slider{margin-bottom:3px}.nl-slider-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:1px}.nl-slider input[type=range]{display:block;margin:0}.nl-slider-hint{color:#8a8a8a;color:var(--content-muted);font-size:9px;line-height:1.2;margin-top:1px;opacity:.65}.nl-preset-row{align-items:stretch;display:flex;gap:4px}.nl-preset-input{flex:1 1;font-size:11px;min-width:0;padding:4px 6px}.nl-preset-save{align-items:center;display:flex;font-size:11px;justify-content:center;padding:4px 8px}.nl-preset-grid{display:flex;flex-wrap:wrap;gap:3px;margin-top:6px}.nl-preset-chip{align-items:stretch;background:#ffffff05;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:3px;display:inline-flex;font-size:10px;overflow:hidden}.nl-preset-chip:hover{border-color:#fff6}.nl-preset-load{background:#0000;border:0;color:var(--content-default);cursor:pointer;font-size:10px;padding:2px 6px}.nl-preset-load:hover{background:#ffffff0f}.nl-preset-del{align-items:center;background:#0000;border:0;border-left:1px solid #3d3d3d;border-left:1px solid var(--border-default);color:#8a8a8a;color:var(--content-muted);cursor:pointer;display:flex;padding:2px 4px}.nl-preset-del:hover{background:#ef444426;color:#ef4444}.view-toggle{border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:6px;display:flex;gap:0;overflow:hidden}.view-toggle-btn{background:#0000;border:0;color:#8a8a8a;color:var(--content-muted);cursor:pointer;flex:1 1;font-size:11px;font-weight:600;letter-spacing:.08em;padding:8px 14px;text-transform:uppercase;transition:background .12s ease,color .12s ease}.view-toggle-btn:hover{background:#ffffff08;color:var(--content-default)}.view-toggle-btn.active{background:#3b82f6;background:var(--accent-primary,#3b82f6);color:#fff}.workspace-pills{align-items:center;background:#0b0805;background:var(--surface-base);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:999px;display:inline-flex;padding:4px}.workspace-pill{background:#0000;border:0;border-radius:999px;color:#8a8a8a;color:var(--content-muted);cursor:pointer;font-family:Inter,sans-serif;font-size:11px;font-weight:500;letter-spacing:.06em;padding:6px 14px;text-transform:uppercase;transition:background .12s ease,color .12s ease}.workspace-pill:hover{background:#ffffff08;color:#edeae5;color:var(--content-primary)}.workspace-pill.active{background:#f98a1b;background:var(--brand);color:#fff;font-weight:600}.workspace-pill.active:hover{background:#fa9c33;background:var(--brand-hover,var(--brand))}.stage-cta{align-items:center;background:#5a2b03;background:var(--brand-tint);border:1px solid #f98a1b;border:1px solid var(--brand);border-radius:999px;bottom:14px;box-shadow:0 4px 14px #f98a1b2e;color:#edeae5;color:var(--content-primary);cursor:pointer;display:inline-flex;font-size:11px;gap:8px;left:50%;padding:7px 16px;position:absolute;transform:translateX(-50%);transition:transform .1s ease,box-shadow .1s ease,background .1s ease;z-index:6}.stage-cta:hover{background:#f98a1b2e;box-shadow:0 6px 18px #f98a1b47;transform:translateX(-50%) translateY(-1px)}.stage-cta-tag{color:#edeae5;color:var(--content-primary)}.stage-cta-sep{color:#8a8a8a;color:var(--content-muted);opacity:.6}.stage-cta-action{color:#f98a1b;color:var(--brand);font-weight:600}.parts-panel-pinned{bottom:24px;position:fixed;right:24px;width:280px;z-index:20}.parts-palette{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(2,1fr);margin:8px 0}.parts-tile{background:#0b0805;background:var(--surface-base);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:4px;display:flex;flex-direction:column;gap:2px;padding:8px 10px;transition:border-color .12s ease,background .12s ease}.parts-tile.next{background:#5a2b03;background:var(--brand-tint);border-color:#f98a1b;border-color:var(--brand)}.parts-tile-label{color:#c9c9c9;color:var(--content-secondary);font-size:11px;font-weight:500}.parts-tile.next .parts-tile-label{color:#f98a1b;color:var(--brand);font-weight:600}.parts-tile-hint{color:#8a8a8a;color:var(--content-muted);font-size:9px}.parts-counts{margin:4px 0 8px}.btn-clear-all{align-items:center;align-self:flex-start;display:inline-flex;font-size:10px;gap:4px;padding:4px 8px}.parts-inventory-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.parts-inventory-total{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:10px}.parts-inventory{display:flex;flex-direction:column;margin-bottom:8px}.parts-inventory-row{align-items:center;border-bottom:1px solid #1f1f1f;border-bottom:1px solid var(--border-subtle);color:#edeae5;color:var(--content-primary);display:flex;font-size:11px;padding:4px 0}.parts-inventory-row:last-child{border-bottom:0}.parts-inventory-spacer{flex:1 1}.parts-inventory-x{color:#8a8a8a;color:var(--content-muted);margin-right:4px}.parts-inventory-count{color:#f98a1b;color:var(--brand);font-family:Space Mono,monospace;font-weight:700}.discovery-stages{display:flex;flex-direction:column;gap:8px}.discovery-stage{align-items:center;display:flex;font-size:11px;gap:10px}.discovery-stage-ind{align-items:center;border-radius:999px;display:inline-flex;flex-shrink:0;font-family:Inter,sans-serif;font-size:10px;font-weight:700;height:20px;justify-content:center;width:20px}.stage-disabled .discovery-stage-ind{background:#0000;border:1px solid #3d3d3d;border:1px solid var(--border-default);color:#8a8a8a;color:var(--content-muted)}.stage-active .discovery-stage-ind{background:#f98a1b;background:var(--brand);color:#edeae5;color:var(--content-primary)}.stage-completed .discovery-stage-ind{background:#0000;border:1px solid #3eb572;border:1px solid var(--state-success);color:#3eb572;color:var(--state-success)}.discovery-stage-label{color:#8a8a8a;color:var(--content-muted);flex:1 1}.stage-active .discovery-stage-label{color:#edeae5;color:var(--content-primary);font-weight:600}.stage-completed .discovery-stage-label{color:#c9c9c9;color:var(--content-secondary)}.discovery-stage-run{align-items:center;display:inline-flex;font-size:10px;gap:4px;padding:4px 10px}@keyframes spin{to{transform:rotate(1turn)}}.walk-overlay{overflow:visible}@property --walk-n-end{syntax:"<length>";inherits:true;initial-value:0}@property --walk-s-end{syntax:"<length>";inherits:true;initial-value:0}@property --walk-w-end{syntax:"<length>";inherits:true;initial-value:0}@property --walk-e-end{syntax:"<length>";inherits:true;initial-value:0}@property --walk-up-end{syntax:"<length>";inherits:true;initial-value:0}.walk-ray{background:#f98a1b;background:var(--brand);border-radius:2px;box-shadow:0 0 6px #f98a1b,0 0 14px #f98a1b8c;box-shadow:0 0 6px var(--brand),0 0 14px #f98a1b8c;position:absolute;will-change:transform}.walk-ray-traverse{animation:walk-traverse 1.8s linear forwards;border-radius:50%;height:14px;left:0;margin:-7px 0 0 -7px;offset-rotate:0deg;position:absolute;top:0;width:14px}@keyframes walk-traverse{0%{offset-distance:0;opacity:1}85%{offset-distance:100%;opacity:1}to{offset-distance:100%;opacity:0}}.walk-axis-tick{animation:walk-axis-tick .32s ease-out forwards;background:#f98a1b;background:var(--brand);border-radius:50%;box-shadow:0 0 6px #f98a1b,0 0 14px #f98a1b8c;box-shadow:0 0 6px var(--brand),0 0 14px #f98a1b8c;height:12px;margin:-6px 0 0 -6px;opacity:0;position:absolute;transform:scale(0);width:12px}@keyframes walk-axis-tick{0%{opacity:0;transform:scale(0)}30%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.4)}}.env-panel{display:flex;flex-direction:column;gap:10px}.env-panel-title{margin:0}.env-card{background:#181614;background:var(--surface-raised);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:6px;color:inherit;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:8px;padding:12px;text-align:left;transition:border-color .12s ease,background .12s ease}.env-card:hover{border-color:#ffffff4d}.env-card.selected{background:#5a2b03;background:var(--brand-tint);border-color:#f98a1b;border-color:var(--brand);border-width:2px;padding:11px}.env-card-head{align-items:center;display:flex;justify-content:space-between}.env-card-title{font-family:Inter,sans-serif;font-size:13px;font-weight:600}.env-card-check,.env-card-title{color:#edeae5;color:var(--content-primary)}.env-card-check{align-items:center;background:#f98a1b;background:var(--brand);border-radius:999px;display:inline-flex;font-size:9px;font-weight:700;height:16px;justify-content:center;width:16px}.env-card-sub{font-size:10px}.env-card-sub,.env-card-thumb{color:#8a8a8a;color:var(--content-muted)}.env-card-thumb{align-items:center;background:#0b0805;background:var(--surface-base);border-radius:4px;display:flex;height:80px;justify-content:center}.env-card.selected .env-card-thumb{color:#f98a1b;color:var(--brand)}.env-card-thumb svg{height:100%;width:100%}.env-hint{color:#8a8a8a;color:var(--content-muted);font-size:10px;line-height:1.4;margin-top:4px}.header-right{align-items:center;display:flex;gap:12px;margin-left:auto}.header-view-toggle .view-toggle-btn{font-size:10px;padding:6px 14px}.header-conn-chip{align-items:center;background:#181614;background:var(--surface-raised);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:999px;color:#8a8a8a;color:var(--content-muted);cursor:pointer;display:inline-flex;font-family:inherit;font-size:10px;gap:6px;letter-spacing:.06em;padding:4px 10px 4px 8px;text-transform:uppercase;transition:background .12s ease,border-color .12s ease,color .12s ease;-webkit-user-select:none;user-select:none}.header-conn-chip:hover{background:#0b0805;background:var(--surface-base);color:#edeae5;color:var(--content-primary)}.header-conn-chip:focus-visible{outline:2px solid #fa9c33;outline:2px solid var(--border-focus);outline-offset:2px}.header-conn-chip.connected{border-color:#3eb572;border-color:var(--state-success);color:#edeae5;color:var(--content-primary)}.header-conn-label{line-height:1}.ws-header{align-items:center;display:flex;gap:6px;margin-bottom:10px}.ws-status-text{color:#8a8a8a;color:var(--content-muted);font-size:10px;margin-left:auto}.param-label-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:3px}.param-label,.param-val{color:#8a8a8a;color:var(--content-muted);font-size:10px}.param-val{font-family:Space Mono,monospace}.divider{border:none;border-top:1px solid #3d3d3d;border-top:1px solid var(--border-default);margin:8px 0}.effect-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(2,1fr)}.textarea-wrapper{position:relative}.textarea-copy-btn{background:#ffffff0f;border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--content-muted);cursor:pointer;line-height:1;padding:3px 5px;position:absolute;right:5px;top:5px;transition:all .12s}.textarea-copy-btn:hover:not(:disabled){background:#ffffff1f;color:#edeae5;color:var(--content-primary)}.textarea-copy-btn:disabled{cursor:not-allowed;opacity:.3}.lang-hint{background:#ffffff05;border:1px solid #1f1f1f;border:1px solid var(--border-subtle);border-radius:2px;border-radius:var(--radius-sm);color:#4f4f4f;color:var(--content-disabled);font-size:9px;line-height:1.7;padding:6px 8px}.lang-hint strong{color:#8a8a8a;color:var(--content-muted)}.checkbox-row{align-items:center;display:flex;gap:6px}.checkbox-row label{color:#c9c9c9;color:var(--content-secondary);cursor:pointer;font-size:11px;line-height:1}input[type=checkbox]{accent-color:#f98a1b;accent-color:var(--brand);cursor:pointer;flex-shrink:0;height:13px;width:13px}.sensor-view{display:flex;flex-direction:column;gap:12px}.sensor-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.sensor-header .panel-title{margin:0}.sensor-source{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:9px;font-weight:700;letter-spacing:.12em;padding:2px 6px}.sensor-source-live{border-color:#3eb572;border-color:var(--state-success);color:#3eb572;color:var(--state-success)}.sensor-source-synth{border-color:#3a74e8;border-color:var(--state-info);color:#3a74e8;color:var(--state-info)}.sensor-source-none{color:#8a8a8a;color:var(--content-muted)}.sensor-body{grid-gap:14px;align-items:stretch;display:grid;gap:14px;grid-template-columns:auto 1fr}.sensor-primary{background:#000;background:var(--surface-sunken);border:1px solid #1f1f1f;border:1px solid var(--border-subtle);border-radius:4px;border-radius:var(--radius-md);gap:6px;padding:10px}.sensor-primary,.sensor-primary-meta{align-items:center;display:flex;flex-direction:column}.sensor-primary-meta{gap:2px;width:100%}.sensor-side{display:flex;flex-direction:column;gap:12px;min-width:0}.sensor-axis-label{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:9px;letter-spacing:.05em}.sensor-heatmap{border-radius:2px;border-radius:var(--radius-sm);display:block;image-rendering:pixelated}.sensor-readout{padding:0 2px}.sensor-view .stat-grid{grid-gap:4px 14px;align-items:baseline;display:grid;gap:4px 14px;grid-template-columns:auto 1fr}.sensor-view .stat-label{color:#8a8a8a;color:var(--content-muted);font-size:10px;letter-spacing:.08em;text-transform:uppercase}.sensor-view .stat-value{color:#edeae5;color:var(--content-primary);font-family:Space Mono,monospace;font-size:12px}.sensor-channels{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,minmax(0,1fr))}.sensor-channel{background:#000;background:var(--surface-sunken);border:1px solid #1f1f1f;border:1px solid var(--border-subtle);border-radius:2px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:4px;padding:6px}.sensor-channel-label{align-items:baseline;color:#c9c9c9;color:var(--content-secondary);display:flex;font-size:10px;justify-content:space-between}.sensor-channel-empty,.sensor-channel-range{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:9px}.sensor-channel-empty{font-style:italic}.sensor-status-hist{display:flex;flex-direction:column;gap:4px}.status-bar-row{display:flex;flex-wrap:wrap;gap:4px}.status-chip{align-items:center;background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);display:flex;flex-direction:column;font-family:Space Mono,monospace;font-size:10px;gap:1px;min-width:28px;padding:3px 6px}.status-chip.ok{border-color:#3eb572;border-color:var(--state-success);color:#3eb572;color:var(--state-success)}.status-chip.bad{border-color:#e6a72c;border-color:var(--state-warning);color:#e6a72c;color:var(--state-warning)}.status-chip-code{font-weight:700}.status-chip-count{font-size:9px;opacity:.7}.audio-empty{align-items:flex-start;display:flex;flex-direction:column;gap:10px}.audio-empty .empty{margin:0;max-width:480px}.audio-error{color:#e24b3d;color:var(--state-danger);font-family:Space Mono,monospace;font-size:11px;margin:0}.audio-primary{align-items:stretch}.audio-bands,.audio-history{border-radius:2px;border-radius:var(--radius-sm);display:block;height:auto;width:100%}.audio-history{background:#0b0805;background:var(--surface-base);margin-top:6px}.audio-view-compact .audio-bands{height:120px;width:100%}.audio-view-compact .audio-history{height:40px;width:100%}.audio-header-right{align-items:center;display:flex;gap:8px}.audio-onset-pulse{background:#f98a1b;background:var(--brand);border-radius:50%;box-shadow:0 0 8px #f98a1b;box-shadow:0 0 8px var(--brand);height:10px;pointer-events:none;transition:opacity 80ms linear,transform 80ms linear;width:10px}.parts-keymap{color:#c9c9c9;color:var(--content-secondary);display:flex;flex-direction:column;font-size:11px;gap:4px;margin-bottom:10px}.parts-keymap kbd{background:#000;background:var(--surface-sunken);border:1px solid #3d3d3d;border:1px solid var(--border-default);border-radius:2px;border-radius:var(--radius-sm);color:#f98a1b;color:var(--brand);display:inline-block;font-family:Space Mono,monospace;font-size:10px;font-weight:700;margin-right:4px;min-width:16px;padding:1px 5px;text-align:center}.keymap-row-muted{font-style:italic}.keymap-row-muted,.parts-counts{color:#8a8a8a;color:var(--content-muted)}.parts-counts{font-family:Space Mono,monospace;font-size:10px;margin-bottom:8px}.discovery-summary{background:#000;background:var(--surface-sunken);border-radius:2px;border-radius:var(--radius-sm);display:flex;flex-direction:column;font-family:Space Mono,monospace;font-size:11px;gap:4px;padding:8px}.discovery-stat{color:#c9c9c9;color:var(--content-secondary);display:flex;justify-content:space-between}.discovery-current-step{font-size:10px;letter-spacing:.05em}.discovery-events{border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:2px;margin-top:4px;padding-top:4px}.discovery-event{color:#e6a72c;color:var(--state-warning);font-family:Inter,sans-serif;font-size:11px;padding:2px 0}.discovery-chain{border-top:1px solid #1f1f1f;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:4px;padding-top:4px}.discovery-chain-label{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase}.discovery-chain-list{display:flex;flex-direction:column;gap:2px;list-style:none;margin:0;max-height:220px;overflow-y:auto;padding:0}.discovery-chain-step{align-items:baseline;color:#c9c9c9;color:var(--content-secondary);display:flex;font-family:Inter,sans-serif;font-size:11px;gap:8px}.discovery-chain-idx{font-size:10px;min-width:18px}.discovery-chain-arm,.discovery-chain-idx{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace}.discovery-chain-arm{font-size:9px;margin-left:auto}.discovery-current-step{background:#5a2b03;background:var(--brand-tint);border-radius:2px;border-radius:var(--radius-sm);color:#f98a1b;color:var(--brand);font-family:Inter,sans-serif;font-size:11px;letter-spacing:normal;padding:4px 6px}.routing-summary{border-top:1px solid #3d3d3d;border-top:1px solid var(--border-default);gap:6px;margin-top:4px;padding-top:8px}.routing-arm,.routing-summary{display:flex;flex-direction:column}.routing-arm{background:#000;background:var(--surface-sunken);border-radius:2px;border-radius:var(--radius-sm);gap:4px;padding:6px 8px}.routing-arm-header{color:#f98a1b;color:var(--brand);display:flex;font-family:Space Mono,monospace;font-size:10px;font-weight:700;justify-content:space-between;letter-spacing:.06em}.routing-arm-meta{color:#8a8a8a;color:var(--content-muted);font-weight:400}.routing-chain-list{display:flex;flex-direction:column;gap:2px;list-style:none;margin:0;max-height:260px;overflow-y:auto;padding:0}.routing-chain-step{align-items:baseline;color:#c9c9c9;color:var(--content-secondary);display:flex;font-family:Inter,sans-serif;font-size:11px;gap:8px}.routing-chain-step .discovery-chain-idx{font-size:10px;min-width:30px;text-align:right}.routing-chain-state,.routing-chain-step .discovery-chain-idx{color:#8a8a8a;color:var(--content-muted);font-family:Space Mono,monospace}.routing-chain-state{font-size:9px;margin-left:auto}.routing-chain-controller_origin{color:#3a74e8;color:var(--state-info)}.routing-chain-lightbar{color:#3eb572;color:var(--state-success)}.routing-chain-node_pass{color:#edeae5;color:var(--content-primary)}.routing-chain-node_return{color:#8a8a8a;color:var(--content-muted)}.routing-chain-node_end{color:#e24b3d;color:var(--state-danger)}.routing-chain-spotlight_inline{color:#e6a72c;color:var(--state-warning)}.discovery-warnings{display:flex;flex-direction:column;gap:4px;margin-top:4px}.discovery-warning{border-radius:2px;border-radius:var(--radius-sm);display:flex;flex-direction:column;font-size:11px;gap:2px;padding:6px 8px}.discovery-warning.sev-error{background:color-mix(in srgb,#e24b3d 12%,#0000);background:color-mix(in srgb,var(--state-danger) 12%,#0000);color:#e24b3d;color:var(--state-danger)}.discovery-warning.sev-warn{background:color-mix(in srgb,#e6a72c 12%,#0000);background:color-mix(in srgb,var(--state-warning) 12%,#0000);color:#e6a72c;color:var(--state-warning)}.discovery-warning-code{font-family:Space Mono,monospace;font-size:9px;letter-spacing:.06em;opacity:.75;text-transform:uppercase}.audio-vibe{border:1px solid;border-radius:2px;border-radius:var(--radius-sm);font-family:Atkinson Hyperlegible,Inter,sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;padding:3px 10px;text-transform:uppercase;transition:color .2s ease,border-color .2s ease}.vibe-quiet{color:#8a8a8a;color:var(--content-muted)}.vibe-ambient{color:#3a74e8;color:var(--state-info)}.vibe-crowd{color:#e6a72c;color:var(--state-warning)}.vibe-music{box-shadow:0 0 12px #5a2b03;box-shadow:0 0 12px var(--brand-tint);color:#f98a1b;color:var(--brand)}.acc-section-title{color:#8a8a8a;color:var(--content-muted);font-size:9px;font-weight:700;letter-spacing:.14em;margin:0 0 6px;text-transform:uppercase}
/*# sourceMappingURL=main.811a2e20.css.map*/