*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cyan: #00d4ff;--cyan-dim: #0088aa;--magenta: #cc44ff;--blue-lit: #4488ff;--teal: #00ffcc;--orange: #ff8800;--bg-root: #06091a;--bg-panel: #080c1e;--bg-item: #0b1028;--bg-hover: #101830;--bg-active: #0d1f38;--border: #1a3a5a;--border-lit:#2a5a8a;--border-glow: #00d4ff;--text: #c8e8ff;--text-dim: #4a7a9a;--text-head: #e8f4ff;--panel-left: 240px;--panel-right: 268px;--bar-top: 42px;--bar-audio: 225px;--radius: 3px}html,body,#root{width:100%;height:100%;overflow:hidden;background:var(--bg-root);color:var(--text);font-family:Rajdhani,Share Tech Mono,sans-serif;font-size:13px;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none}input{font-family:inherit}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg-panel)}::-webkit-scrollbar-thumb{background:var(--border-lit);border-radius:2px}.app{display:grid;grid-template-rows:var(--bar-top) 1fr var(--bar-audio);width:100vw;height:100vh;overflow:hidden;outline:1px solid var(--border-lit);outline-offset:-1px}.app__body{display:grid;grid-template-columns:var(--panel-left) 1fr var(--panel-right);overflow:hidden;min-height:0;position:relative}.surf-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;background:#01010a}.app__left{background:var(--bg-panel);border-right:1px solid var(--border-lit);overflow-y:auto;overflow-x:hidden;position:relative}.app__center{position:relative;overflow:hidden;background:#020510;border:1px solid var(--cyan);box-shadow:inset 0 0 30px #00d4ff14,0 0 20px #00d4ff26}.app__right{background:var(--bg-panel);border-left:1px solid var(--border-lit);overflow-y:auto;overflow-x:hidden}.app__bottom{background:var(--bg-panel);border-top:2px solid var(--border-lit);position:relative;display:flex;flex-direction:row;align-items:stretch;overflow:hidden}.app__left:before,.app__right:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.6}.app__bottom:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--cyan),var(--magenta),var(--cyan));opacity:.5}.status-bar{display:flex;align-items:center;padding:0 14px;gap:12px;background:#050819;border-bottom:1px solid var(--border-lit);position:relative;overflow:hidden}.status-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,212,255,.03) 3px,rgba(0,212,255,.03) 4px)}.status-bar:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}.status-bar__brand{display:flex;flex-direction:row;align-items:center;gap:12px;line-height:1}.file-menu{position:relative;display:flex;align-items:center;gap:8px}.file-menu__btn{background:none;border:1px solid #0ff4;color:#0ff;font-family:inherit;font-size:10px;letter-spacing:.12em;padding:3px 10px;cursor:pointer;border-radius:2px;transition:background .15s,border-color .15s}.file-menu__btn:hover,.file-menu__btn--active{background:#0ff2;border-color:#0ff}.file-menu__name{font-size:10px;color:#0ff9;letter-spacing:.05em;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-menu__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.file-menu__dropdown{position:fixed;z-index:99999;background:#060d1a;border:1px solid #0ff5;border-radius:4px;min-width:180px;padding:4px 0;list-style:none;margin:0;box-shadow:0 8px 24px #000a}.file-menu__item{display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:11px;color:#cde;cursor:pointer;letter-spacing:.05em;transition:background .1s,color .1s}.file-menu__item:hover{background:#0ff1;color:#0ff}.file-menu__item--danger{color:#f46}.file-menu__item--danger:hover{background:#f461;color:#f66}.file-menu__icon{font-size:10px;opacity:.7}.file-menu__sep{border:none;border-top:1px solid #0ff2;margin:4px 0}.brand-text{font-size:17px;font-weight:700;color:var(--text-head);letter-spacing:2px;text-shadow:0 0 14px rgba(0,212,255,.7)}.brand-plus{color:var(--cyan);text-shadow:0 0 10px var(--cyan)}.brand-sub{font-size:7px;letter-spacing:3px;color:var(--text-dim);text-transform:uppercase;font-family:Share Tech Mono,monospace}.status-bar__center{flex:1;display:flex;justify-content:center}.status-tabs{display:flex;gap:1px}.status-tab{padding:5px 18px;background:transparent;border:1px solid var(--border);color:var(--text-dim);letter-spacing:1.5px;font-size:11px;font-weight:600;transition:all .15s}.status-tab--active{background:#00d4ff14;border-color:var(--cyan);color:var(--cyan);text-shadow:0 0 8px var(--cyan);box-shadow:inset 0 0 16px #00d4ff12}.status-tab:hover:not(.status-tab--active){border-color:var(--border-lit);color:var(--text)}.status-bar__right{display:flex;align-items:center;gap:10px}.connection-badge{display:flex;align-items:center;gap:5px;font-size:10px;letter-spacing:1px;color:var(--text-dim);font-family:Share Tech Mono,monospace}.connection-dot{width:6px;height:6px;border-radius:50%;background:var(--dot-color, #444);box-shadow:0 0 6px var(--dot-color, #444)}.panel-title{padding:8px 12px;font-size:11px;font-weight:700;letter-spacing:2.5px;color:var(--cyan);text-transform:uppercase;font-family:Share Tech Mono,monospace;border-bottom:1px solid var(--border-lit);background:#00d4ff0a;text-shadow:0 0 10px rgba(0,212,255,.4);position:relative}.panel-title:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}.panel-section-title{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px}.panel-close-btn{margin-left:auto;background:none;color:var(--text-dim);font-size:14px;line-height:1;padding:0 2px;transition:color .15s}.panel-close-btn:hover{color:var(--text)}.icon-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:none;color:var(--text-dim);border-radius:3px;transition:all .15s;flex-shrink:0}.icon-btn:hover{color:var(--cyan);background:#00d4ff14}.icon-btn--add:hover{color:var(--teal)}.icon-btn--close:hover{color:#f46}.layers-panel{display:flex;flex-direction:column;height:100%}.layer-section{border-bottom:1px solid var(--border)}.layer-section__header{display:flex;align-items:center;padding:6px 10px;background:#00d4ff08;border-bottom:1px solid var(--border);border-left:2px solid var(--accent, var(--cyan));gap:4px}.section-collapse{flex:1;display:flex;align-items:center;gap:6px;background:none;color:var(--text);font-size:12px;font-weight:600;letter-spacing:.5px;text-align:left;padding:0}.section-title{flex:1}.chevron{font-size:16px;color:var(--text-dim);display:inline-block;transition:transform .15s;line-height:1}.chevron--down{transform:rotate(90deg)}.chevron--right{transform:rotate(0)}.section-actions{display:flex;gap:2px}.layer-section__body{padding:4px 0}.layer-row{display:flex;align-items:center;padding:5px 10px 5px 14px;cursor:pointer;border-left:2px solid transparent;gap:7px;transition:background .1s}.layer-row:hover{background:var(--bg-hover)}.layer-row--selected{background:var(--bg-active);border-left-color:var(--cyan)}.layer-row--selected .layer-row__name{color:var(--text-head)}.layer-row__accent{width:3px;height:16px;border-radius:2px;flex-shrink:0;box-shadow:0 0 4px currentColor}.layer-row__name{flex:1;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layer-row__name-input{flex:1;background:#0006;border:1px solid var(--cyan);color:var(--text-head);padding:1px 4px;font-size:12px;border-radius:2px;outline:none}.layer-row__actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity .15s}.layer-row:hover .layer-row__actions{opacity:1}.layer-order-input{width:28px;background:#0a1525;border:1px solid #1a3050;border-radius:3px;color:var(--cyan);font-size:10px;text-align:center;padding:1px 2px;-moz-appearance:textfield}.layer-order-input::-webkit-inner-spin-button,.layer-order-input::-webkit-outer-spin-button{-webkit-appearance:none}.layer-empty{padding:8px 14px;font-size:11px;color:var(--text-dim);font-style:italic}.rec-menu{position:relative;display:flex;align-items:center;gap:6px}.rec-menu__btn{background:none;border:1px solid #f446;color:#f44;font-family:inherit;font-size:10px;letter-spacing:.12em;padding:3px 10px;cursor:pointer;border-radius:2px;display:flex;align-items:center;gap:5px;transition:background .15s,border-color .15s}.rec-menu__btn:hover,.rec-menu__btn--active{background:#f441;border-color:#f44}.rec-menu__btn--rec{border-color:#f44;color:#f66;animation:rec-pulse-border 1.2s ease-in-out infinite}@keyframes rec-pulse-border{0%,to{border-color:#f44;box-shadow:0 0 4px #f446}50%{border-color:#f448;box-shadow:0 0 10px #f446}}.rec-menu__dot{width:7px;height:7px;border-radius:50%;background:#f44;display:inline-block;flex-shrink:0;animation:rec-blink 1s step-start infinite}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:0}}.rec-menu__saved{font-size:9px;color:#0f8;letter-spacing:.08em;opacity:.8}.proj-btn{background:none;border:1px solid #44aaff66;color:#4af;font-family:inherit;font-size:10px;letter-spacing:.12em;padding:3px 10px;border-radius:3px;cursor:pointer;transition:background .15s,border-color .15s}.proj-btn:hover{background:#44aaff18;border-color:#4af}.proj-btn--active{border-color:#4af;color:#8cf;background:#4af2;animation:proj-pulse 2s ease-in-out infinite}.web-btn{background:none;border:1px solid #00d4ff66;color:#00d4ff;font-family:inherit;font-size:10px;letter-spacing:.12em;padding:3px 10px;border-radius:3px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.web-btn:hover{background:#00d4ff18;border-color:#00d4ff}.web-btn--active{border-color:#00d4ff;color:#7fefff;background:#00d4ff22}.web-btn:disabled{opacity:.8;cursor:wait}@keyframes proj-pulse{0%,to{box-shadow:0 0 4px #4af5}50%{box-shadow:0 0 10px #4af9}}.rec-menu__dropdown{position:fixed;z-index:99999;background:#060d1a;border:1px solid #f445;border-radius:4px;min-width:210px;padding:10px 0 8px;box-shadow:0 8px 24px #000a}.rec-menu__section{font-size:9px;color:#f449;letter-spacing:.15em;padding:0 14px 5px;font-weight:700}.rec-menu__options{display:flex;gap:5px;padding:0 14px 8px}.rec-menu__opt{background:#0a111f;border:1px solid #f443;color:#cde;font-family:inherit;font-size:10px;letter-spacing:.07em;padding:4px 10px;cursor:pointer;border-radius:2px;display:flex;flex-direction:column;align-items:center;gap:1px;transition:background .12s,border-color .12s}.rec-menu__opt:hover{background:#f441;border-color:#f44;color:#fff}.rec-menu__opt--active{background:#f442;border-color:#f44;color:#f88}.rec-menu__opt-sub{font-size:8px;opacity:.6}.rec-menu__sep{border:none;border-top:1px solid #f442;margin:4px 0 8px}.gizmo-eye-btn{position:absolute;bottom:10px;right:10px;width:26px;height:26px;padding:4px;background:#060d1a99;border:1px solid #0ff3;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s;z-index:10}.gizmo-eye-btn svg{width:100%;height:100%;display:block}.gizmo-eye-btn--on{color:#0ff9}.gizmo-eye-btn--off{color:#0ff3;border-color:#0ff1}.gizmo-eye-btn:hover{background:#0ff2;border-color:#0ff;color:#0ff}.rec-menu__audio-row{padding:0 14px 8px}.rec-menu__audio-btn{background:#0a111f;border:1px solid #f443;color:#88a;font-family:inherit;font-size:10px;letter-spacing:.07em;padding:4px 10px;cursor:pointer;border-radius:2px;width:100%;transition:background .12s}.rec-menu__audio-btn--on{border-color:#f44;color:#f88;background:#f441}.rec-menu__audio-btn:hover{background:#f441;color:#fff}.rec-menu__codec{font-size:9px;color:#667;letter-spacing:.06em;padding:0 14px 8px;font-style:italic}.rec-menu__start{display:flex;align-items:center;gap:7px;width:calc(100% - 28px);margin:0 14px;background:#1a0505;border:1px solid #f44;color:#f44;font-family:inherit;font-size:11px;letter-spacing:.1em;padding:7px 14px;cursor:pointer;border-radius:3px;transition:background .15s}.rec-menu__start:hover{background:#f441;color:#fff}.groups-section{padding:2px 0 4px}.groups-section__header{display:flex;align-items:center;justify-content:space-between;padding:3px 8px 3px 14px}.groups-section__label{font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text-dim);opacity:.6}.groups-section__add{font-size:10px;padding:2px 7px;border-radius:3px;background:#ff44cc26;color:#f4c;border:1px solid rgba(255,68,204,.3);cursor:pointer;transition:background .15s}.groups-section__add:hover{background:#ff44cc47}.group-block{border-left:2px solid transparent;margin-bottom:1px}.group-block--selected{background:#ffffff0a}.group-block__header{display:flex;align-items:center;gap:4px;padding:4px 6px 4px 8px;cursor:pointer;border-radius:3px}.group-block__header:hover{background:var(--bg-hover)}.group-block__chevron{font-size:11px;width:14px;color:var(--text-dim)}.group-block__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.group-block__name{flex:1;font-size:11px;color:var(--text-head);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-block__name-input{flex:1;font-size:11px;background:var(--bg-input);border:1px solid rgba(255,255,255,.15);border-radius:2px;color:var(--text-head);padding:1px 4px}.group-block__count{font-size:10px;color:var(--text-dim);min-width:16px;text-align:right}.group-block__mute{font-size:9px}.group-block__members{padding:2px 0 2px 18px}.group-block__empty{font-size:10px;color:var(--text-dim);padding:4px 8px;font-style:italic}.group-member-row{display:flex;align-items:center;gap:4px;padding:3px 6px;border-radius:3px;font-size:10px;color:var(--text-dim);cursor:pointer}.group-member-row:hover{background:var(--bg-hover)}.group-member-row--selected{background:var(--bg-active);color:var(--text-head)}.group-member-row__accent{width:3px;height:14px;border-radius:2px;flex-shrink:0}.group-member-row__name{flex:1}.group-member-row__actions{display:flex;gap:1px;opacity:0;transition:opacity .15s}.group-member-row:hover .group-member-row__actions{opacity:1}.group-member-row__remove{font-size:9px}.ungrouped-label{font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--text-dim);opacity:.5;padding:5px 14px 2px}.fixture-group-tag{width:8px;height:8px;border-radius:50%!important;padding:0!important;flex-shrink:0;cursor:pointer}.group-assign-dropdown{position:absolute;z-index:200;left:30px;background:var(--bg-panel);border:1px solid rgba(255,255,255,.12);border-radius:5px;padding:4px;box-shadow:0 4px 16px #00000080;min-width:120px}.group-assign-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:3px;cursor:pointer;font-size:11px;color:var(--text-body)}.group-assign-item:hover{background:var(--bg-hover)}.group-assign-item--active{color:var(--text-head)}.group-assign-dot{width:8px;height:8px;border-radius:50%}.pb-section--group{border-left:2px solid var(--gx-color, #ff44cc)}.pb-tri-row{display:flex;align-items:center;gap:6px;padding:3px 0}.pb-tri-btns{display:flex;gap:2px}.pb-tri-btn{font-size:10px;padding:2px 6px;border-radius:3px;cursor:pointer;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-dim);transition:all .12s}.pb-tri-btn--active{background:#ff44cc40;border-color:#ff44cc80;color:#f4c}.pb-header--group{gap:8px}.pb-group-name-input{flex:1;min-width:80px;max-width:140px;font-size:11px;padding:2px 7px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:3px;color:var(--text-head);transition:border-color .15s}.pb-group-name-input:focus{outline:none;border-color:var(--gx-color, #ff44cc)}.pb-group-count{font-size:9px;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.pb-mute-label{display:flex;align-items:center;gap:5px;cursor:pointer;flex-shrink:0}.pb-mute-text{font-size:9px;color:var(--text-dim);letter-spacing:.06em}.pb-feature-rows{display:flex;flex-direction:column;border-bottom:1px solid rgba(255,255,255,.06)}.pb-feature-row{display:flex;align-items:center;gap:10px;padding:5px 12px;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}.pb-feature-row:last-child{border-bottom:none}.pb-feature-row--on{background:#ff44cc0f}.pb-feature-row--sync.pb-feature-row--on{background:#32b4ff0f}.pb-feature-toggle{display:flex;align-items:center;gap:7px;cursor:pointer;flex-shrink:0;-webkit-user-select:none;user-select:none}.pb-feature-toggle input[type=checkbox]{display:none}.pb-feature-pip{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,68,204,.4);background:transparent;transition:all .15s;flex-shrink:0}.pb-feature-toggle input:checked+.pb-feature-pip{background:#f4c;border-color:#f4c;box-shadow:0 0 6px #f4c8}.pb-feature-row--sync .pb-feature-pip{border-color:#32b4ff66}.pb-feature-row--sync .pb-feature-toggle input:checked+.pb-feature-pip{background:#32b4ff;border-color:#32b4ff;box-shadow:0 0 6px #32b4ff88}.pb-feature-name{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--text-head);white-space:nowrap}.pb-feature-row--on .pb-feature-name{color:#f4c}.pb-feature-row--sync.pb-feature-row--on .pb-feature-name{color:#32b4ff}.pb-feature-slider{flex:1;height:4px;cursor:pointer;accent-color:#ff44cc;min-width:60px}.pb-feature-row--sync .pb-feature-slider{accent-color:#32b4ff}.pb-feature-val{font-size:10px;color:#f4c;min-width:36px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.pb-feature-row--sync .pb-feature-val{color:#32b4ff}.pb-feature-hint{font-size:9px;color:var(--text-dim);opacity:.7;white-space:nowrap;flex-shrink:0;font-style:italic}.pb-group-props{display:flex;padding:6px 0 4px}.pb-gprop{flex:1;padding:4px 12px;border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;gap:5px}.pb-gprop:last-child{border-right:none}.pb-gprop-label{font-size:8px;font-weight:700;letter-spacing:.1em;color:var(--text-dim);opacity:.6;margin-bottom:2px}.pb-gprop-check{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:10px;color:var(--text-dim)}.pb-gprop-check input[type=checkbox]{margin:0;accent-color:var(--gx-color, #ff44cc)}.cp-group-badge{display:flex;align-items:center;gap:6px;padding:5px 10px;margin:4px 0;border-radius:4px;border:1px solid;font-size:10px;font-weight:700;letter-spacing:.07em;background:#ffffff0a}.cp-group-badge__dot{width:7px;height:7px;border-radius:50%}.fixture-picker{margin:6px 8px;background:#000814f2;border:1px solid var(--border-lit);border-radius:var(--radius);padding:8px}.fixture-picker__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:11px;letter-spacing:1px;color:var(--text-dim)}.fixture-picker__grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.fixture-picker__item{display:flex;align-items:center;gap:6px;padding:4px 6px;background:transparent;border:1px solid var(--border);color:var(--text);font-size:11px;border-radius:3px;transition:all .12s}.fixture-picker__item:hover{border-color:var(--type-color);background:#ffffff05}.fixture-picker__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.import-btn{display:block;width:calc(100% - 16px);margin:8px 8px 4px;padding:5px 8px;background:#00d4ff0d;border:1px dashed var(--border-lit);color:var(--cyan);font-size:11px;letter-spacing:1px;border-radius:var(--radius);transition:all .15s}.import-btn:hover{background:#00d4ff1a;border-color:var(--cyan);box-shadow:0 0 12px #00d4ff26}.attach-panel{margin:8px;padding:8px;background:#001020e6;border:1px solid var(--magenta);border-radius:var(--radius);box-shadow:0 0 12px #cc44ff1f}.attach-panel__title{font-size:10px;letter-spacing:2px;color:var(--magenta);margin-bottom:4px;text-shadow:0 0 8px var(--magenta);display:flex;align-items:center;justify-content:space-between}.attach-panel__close{background:none;border:none;color:var(--text-dim);font-size:12px;cursor:pointer;padding:0 2px;line-height:1}.attach-panel__close:hover{color:var(--magenta)}.attach-panel__info{font-size:11px;color:var(--text-dim);margin-bottom:8px}.attach-panel__info strong{color:var(--text)}.attach-panel__anchors{display:flex;flex-wrap:wrap;gap:4px}.anchor-btn{padding:3px 8px;background:#cc44ff0f;border:1px solid rgba(204,68,255,.3);color:var(--magenta);font-size:10px;letter-spacing:.5px;border-radius:3px;transition:all .12s}.anchor-btn:hover{background:#cc44ff26;border-color:var(--magenta);box-shadow:0 0 8px #c4f3}.attach-trigger-btn{display:block;width:calc(100% - 16px);margin:6px 8px;padding:5px 8px;font-size:10px;letter-spacing:1px;background:#cc44ff0f;border:1px dashed rgba(204,68,255,.4);color:var(--magenta);border-radius:var(--radius);cursor:pointer;transition:all .15s}.attach-trigger-btn:hover{background:#cc44ff1f;border-color:var(--magenta);box-shadow:0 0 8px #c4f3}.stage-view{background:#020510;width:100%;height:100%;position:relative}.drop-zone{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:100}.drop-zone--active{background:#00d4ff0d;border:2px dashed var(--cyan)}.drop-zone__label{padding:16px 32px;background:#001020f2;border:1px solid var(--cyan);border-radius:8px;font-size:18px;font-weight:700;color:var(--cyan);letter-spacing:4px;text-shadow:0 0 16px var(--cyan);box-shadow:0 0 32px #00d4ff33}.stage-view:before,.stage-view:after{content:"";position:absolute;width:20px;height:20px;z-index:10;pointer-events:none}.stage-view:before{top:4px;left:4px;border-top:2px solid var(--cyan);border-left:2px solid var(--cyan);box-shadow:-2px -2px 8px #00d4ff66}.stage-view:after{top:4px;right:4px;border-top:2px solid var(--cyan);border-right:2px solid var(--cyan);box-shadow:2px -2px 8px #00d4ff66}.stage-hud{position:absolute;bottom:8px;left:50%;transform:translate(-50%);pointer-events:none}.stage-hud__hint{font-size:10px;color:#64a0c859;letter-spacing:.5px;font-family:Share Tech Mono,monospace;white-space:nowrap}.stage-hud__hint strong{color:#00d4ff66}.control-panel{display:flex;flex-direction:column}.control-panel>*+*{border-top:1px solid var(--border)}.bpm-block{padding:12px 14px 8px;display:flex;flex-direction:column;align-items:center;background:#00d4ff05}.bpm-ring{display:flex;justify-content:center;align-items:center;margin-top:6px;position:relative;transition:filter .12s;width:100%}.bpm-ring--pulse{filter:drop-shadow(0 0 20px var(--cyan))}.bpm-ring svg{width:140px;height:140px;filter:drop-shadow(0 0 12px rgba(0,212,255,.5))}.bpm-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:34px;font-weight:700;color:var(--text-head);text-shadow:0 0 16px rgba(0,212,255,.7);letter-spacing:-1px;pointer-events:none}.neon-slider{padding:8px 14px}.neon-slider__header{display:flex;justify-content:space-between;margin-bottom:5px}.neon-slider__label{font-size:11px;letter-spacing:1px;color:var(--text-dim);text-transform:uppercase}.neon-slider__value{font-size:11px;color:var(--cyan);font-family:Share Tech Mono,monospace}.neon-slider__track{position:relative;height:5px;background:var(--bg-item);border-radius:3px;border:1px solid var(--border)}.neon-slider__fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(90deg,var(--cyan),var(--magenta));border-radius:3px;box-shadow:0 0 8px #00d4ff80;pointer-events:none}.neon-slider__input{position:absolute;top:-6px;right:0;bottom:-6px;left:0;width:100%;opacity:0;cursor:pointer;height:18px}.color-palette{padding:10px 14px}.color-palette__swatches{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.auto-toggles{display:flex;gap:6px;margin-top:8px}.auto-toggle{display:flex;align-items:center;gap:5px;flex:1;padding:5px 8px;border:1px solid rgba(255,255,255,.1);border-radius:4px;cursor:pointer;background:#00000040;font-size:9px;font-family:Share Tech Mono,monospace;letter-spacing:.6px;color:#556;transition:all .15s;-webkit-user-select:none;user-select:none}.auto-toggle input[type=checkbox]{display:none}.auto-toggle__dot{width:7px;height:7px;border-radius:50%;background:#334;border:1px solid #445;flex-shrink:0;transition:background .15s,box-shadow .15s}.auto-toggle--on{border-color:#00dcff80;background:#00b4ff14;color:#00d4ff}.auto-toggle--on .auto-toggle__dot{background:#00d4ff;box-shadow:0 0 6px #00d4ff}.auto-toggle--strobe.auto-toggle--on{border-color:#ff50c880;background:#ff3cb414;color:#f4c}.auto-toggle--strobe.auto-toggle--on .auto-toggle__dot{background:#f4c;box-shadow:0 0 6px #f4c}.color-swatch{width:38px;height:32px;border-radius:4px;border:1px solid rgba(255,255,255,.12);cursor:pointer;transition:transform .1s,box-shadow .1s}.color-swatch:hover{transform:scale(1.1)}.color-swatch--active{transform:scale(1.1);border:2px solid white}.effects-grid{padding:10px 14px}.effects-grid__buttons{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-top:6px}.fx-btn{padding:5px 4px;background:#000814e6;border:1px solid var(--border);color:var(--text-dim);font-size:11px;letter-spacing:.5px;border-radius:3px;transition:all .12s}.fx-btn:hover{border-color:var(--cyan);color:var(--text);background:#00d4ff0d}.fx-btn--active{background:#00d4ff1a;border-color:var(--cyan);color:var(--cyan);text-shadow:0 0 6px var(--cyan);box-shadow:inset 0 0 8px #00d4ff1f}.fixture-props{padding:10px 14px;background:#00040c80}.effect-params{padding:8px 14px 4px;border-top:1px solid var(--border)}.effect-params__title{font-size:10px;letter-spacing:1.5px;color:var(--cyan);font-family:Share Tech Mono,monospace;margin-bottom:8px;text-transform:uppercase}.effect-activate{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:10px}.effect-activate input{accent-color:var(--cyan);width:14px;height:14px;cursor:pointer}.effect-activate__label{font-size:11px;letter-spacing:1.5px;color:var(--text-dim);font-family:Share Tech Mono,monospace;transition:color .15s}.effect-activate__label--on{color:#f4c;text-shadow:0 0 8px #ff44cc;animation:pulse-border 1s ease-in-out infinite}.strobe-hint{font-size:10px;color:#f84;letter-spacing:.5px;font-family:Share Tech Mono,monospace;padding:4px 0 2px;opacity:.8}.fixture-props__title{font-size:11px;font-weight:600;letter-spacing:1px;margin-bottom:8px;font-family:Share Tech Mono,monospace}.fixture-props__toggles{margin-top:8px}.toggle-label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim);cursor:pointer}.toggle-label input[type=checkbox]{accent-color:var(--cyan);width:12px;height:12px}.surf-panel{padding:10px 14px}.surf-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:6px}.surf-mode-btn{padding:4px 6px;background:#000814e6;border:1px solid var(--border);color:var(--text-dim);font-size:10px;border-radius:3px;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all .12s}.surf-mode-btn:hover{border-color:var(--magenta);color:var(--text)}.surf-mode-btn--active{background:#cc44ff1a;border-color:var(--magenta);color:var(--magenta);text-shadow:0 0 6px var(--magenta)}.audio-panel{display:flex;flex-direction:column;padding:8px 12px 6px;gap:6px;height:100%;min-width:0}.ap-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}.ap-header__label{font-size:10px;letter-spacing:3px;font-weight:700;color:var(--cyan);font-family:Share Tech Mono,monospace;text-shadow:0 0 8px rgba(0,212,255,.6);display:flex;align-items:center;gap:6px}.ap-live-dot{width:6px;height:6px;border-radius:50%;background:#f34;display:inline-block;animation:pulse-border 1s ease-in-out infinite;box-shadow:0 0 6px #f34}.ap-sensitivity{display:flex;align-items:center;gap:5px;flex:1;max-width:180px}.ap-sensitivity__label{font-size:9px;letter-spacing:1.5px;color:var(--text-dim);font-family:Share Tech Mono,monospace;white-space:nowrap}.ap-sensitivity__slider{flex:1;height:3px;accent-color:#00ff9f;cursor:pointer}.ap-sensitivity__val{font-size:10px;color:#00ff9f;font-family:Share Tech Mono,monospace;white-space:nowrap;min-width:28px;text-align:right}.ap-source-row{display:flex;align-items:center;gap:6px}.ap-src-btn{padding:3px 10px;border-radius:3px;font-size:10px;letter-spacing:1px;cursor:pointer;border:1px solid var(--border-lit);background:transparent;color:var(--text-dim);transition:all .15s;white-space:nowrap;font-family:Share Tech Mono,monospace}.ap-src-btn--mic:hover{border-color:var(--cyan);color:var(--cyan);background:#00d4ff0f}.ap-src-btn--loop:hover{border-color:#00ff9f;color:#00ff9f;background:#00ff9f0f}.ap-src-btn--stop{border-color:#f34;color:#f34}.ap-src-btn--stop:hover{background:#ff33441f}.ap-src-live{font-size:10px;letter-spacing:1px;color:#f34;font-family:Share Tech Mono,monospace;animation:pulse-border 1.5s ease-in-out infinite}.dev-sel{position:relative;display:flex;align-items:center;gap:6px}.dev-sel__toggle{padding:3px 10px;border-radius:3px;font-size:10px;letter-spacing:1px;cursor:pointer;border:1px solid var(--border-lit);background:transparent;color:var(--cyan);transition:all .15s;white-space:nowrap;font-family:Share Tech Mono,monospace}.dev-sel__toggle:hover{border-color:var(--cyan);background:#00d4ff0f}.dev-sel__live{font-size:10px;letter-spacing:1px;color:#f34;font-family:Share Tech Mono,monospace;animation:pulse-border 1.5s ease-in-out infinite;white-space:nowrap}.dev-sel__stop{padding:3px 10px;border-radius:3px;font-size:10px;letter-spacing:1px;cursor:pointer;border:1px solid #ff3344;background:transparent;color:#f34;font-family:Share Tech Mono,monospace;transition:all .15s}.dev-sel__stop:hover{background:#ff33441f}.dev-sel__menu{position:absolute;top:calc(100% + 4px);right:0;z-index:200;background:#06091a;border:1px solid var(--border-lit);border-radius:4px;min-width:300px;max-width:480px;width:max-content;box-shadow:0 4px 20px #0009,0 0 12px #00d4ff1a;overflow:hidden}.dev-sel__item{display:block;width:100%;padding:4px 10px;text-align:left;font-size:10px;letter-spacing:.4px;font-family:Share Tech Mono,monospace;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all .12s;white-space:nowrap}.dev-sel__item:last-child{border-bottom:none}.dev-sel__item:hover{background:var(--bg-hover);color:var(--cyan)}.dev-sel__item--loopback{color:#00ff9f;border-top:1px solid var(--border-lit);margin-top:2px}.dev-sel__item--loopback:hover{color:#00ff9f;background:#00ff9f12}.dev-sel__empty{display:block;padding:5px 10px;font-size:10px;color:var(--text-dim);font-family:Share Tech Mono,monospace}.eq-canvas{border:1px solid var(--border);border-radius:var(--radius);background:#000410f2;flex-shrink:0}.ap-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}.ap-knobs{display:flex;align-items:center;gap:4px;position:relative;border-right:1px solid var(--border);padding-right:12px}.ap-knobs__badge{position:absolute;top:-13px;left:0;font-size:9px;letter-spacing:2px;color:var(--cyan);font-family:Share Tech Mono,monospace;white-space:nowrap}.ap-transport{flex:1;min-width:0}.band-monitor-widget{display:flex;flex-direction:column;align-items:center;gap:4px;margin-left:4px;flex-shrink:0;position:relative}.band-monitor{border:1px solid #0a2535;border-radius:3px;background:#030810}.predictor-chip{display:flex;align-items:center;gap:4px;margin-left:auto;cursor:pointer;font-size:9px;font-family:Share Tech Mono,monospace;color:#f4c;letter-spacing:.5px;white-space:nowrap;opacity:.75}.predictor-chip:hover{opacity:1}.predictor-chip input[type=checkbox]{accent-color:#ff44cc;cursor:pointer}.audio-eq,.audio-label,.audio-knobs,.audio-transport-col{display:none}.knob{display:flex;flex-direction:column;align-items:center;gap:3px}.knob__label{font-size:10px;letter-spacing:1px;color:var(--text-dim);text-transform:uppercase;font-family:Share Tech Mono,monospace;white-space:nowrap}.knob__svg{cursor:ns-resize;display:block}.knob__value{font-size:11px;color:var(--text);font-family:Share Tech Mono,monospace}.mic-btn{padding:4px 10px;background:#00d4ff0d;border:1px solid var(--border-lit);color:var(--text-dim);font-size:10px;letter-spacing:1px;border-radius:3px;transition:all .15s;text-align:center}.mic-btn:hover{border-color:var(--cyan);color:var(--cyan)}.mic-btn--active{border-color:#f34;color:#f34;background:#ff334414;animation:pulse-border 1.5s ease-in-out infinite}.audio-source-selector{display:flex;gap:4px;align-items:center;justify-content:center;flex-wrap:wrap;padding:4px 0}.source-btn{padding:4px 10px;border-radius:3px;font-size:10px;letter-spacing:1px;cursor:pointer;border:1px solid var(--border-lit);background:transparent;color:var(--text-dim);transition:all .15s;white-space:nowrap}.source-btn--mic:hover{border-color:var(--cyan);color:var(--cyan)}.source-btn--loopback:hover{border-color:#00ff9f;color:#00ff9f}.source-btn--stop{border-color:#f34;color:#f34}.source-btn--stop:hover{background:#ff33441f}.source-active{display:flex;align-items:center;gap:6px}.source-badge{font-size:10px;letter-spacing:1px}.source-badge--live{color:#f34;animation:pulse-border 1.5s ease-in-out infinite}.audio-knobs{position:relative}.audio-knobs__context{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:9px;letter-spacing:2px;color:var(--cyan);white-space:nowrap;pointer-events:none}.transport{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.transport-btn{padding:4px 8px;background:#000814e6;border:1px solid var(--border);color:var(--text);font-size:13px;border-radius:3px;transition:all .12s;min-width:28px}.transport-btn:hover,.transport-btn--active{border-color:var(--cyan);color:var(--cyan)}.transport-seek{flex:1;min-width:80px;display:flex;flex-direction:column;justify-content:center}.seek-bar{width:100%;height:4px;accent-color:var(--cyan);cursor:pointer}.transport-time{font-size:12px;color:var(--text);font-family:Share Tech Mono,monospace;white-space:nowrap}.transport-btn--import{font-size:14px}.transport-btn--import:hover{border-color:#00ff9f}.transport-songname{font-size:9px;letter-spacing:1px;color:var(--cyan);font-family:Share Tech Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px;margin-bottom:2px}.transport-sync-btn{padding:4px 10px;background:#00d4ff0f;border:1px solid var(--border-lit);color:var(--cyan);font-size:10px;letter-spacing:1px;border-radius:3px;transition:all .15s;white-space:nowrap}.transport-sync-btn:hover{background:#00d4ff1f;border-color:var(--cyan);box-shadow:0 0 10px #00d4ff33}@keyframes pulse-border{0%,to{box-shadow:0 0 4px #ff33444d}50%{box-shadow:0 0 12px #f349}}.app{position:relative}.import-btn-row{display:flex;gap:4px;padding:6px 0 2px}.import-btn--lib{flex:1;background:#00ccff12!important;border-color:var(--cyan-dim)!important;color:var(--cyan)!important}.import-btn--file{flex:1}.stage-library{background:#040816f7;border:1px solid var(--cyan-dim);border-radius:4px;margin-bottom:6px;overflow:hidden}.stage-library__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#00d4ff0f;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--cyan);border-bottom:1px solid rgba(0,212,255,.15)}.stage-library__msg{padding:10px;font-size:10px;color:var(--text-dim);text-align:center}.stage-library__msg--err{color:#f46}.stage-library__list{max-height:200px;overflow-y:auto}.stage-library__item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text);font-size:11px;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s}.stage-library__item:hover{background:#00d4ff14}.stage-library__item--active{background:#00d4ff26;color:var(--cyan)}.stage-library__icon{color:var(--cyan-dim);font-size:12px;flex-shrink:0}.stage-library__name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fixture-props-panel{position:absolute;bottom:12px;left:12px;width:280px;background:#040816f0;border:1px solid var(--accent, var(--cyan));box-shadow:0 0 20px #00d4ff26,inset 0 0 30px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:4px;padding:0;z-index:50;font-family:inherit;font-size:11px}.fpp-header{display:flex;align-items:center;gap:6px;padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.06);background:#0000004d}.fpp-title{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;flex:1}.fpp-id{color:var(--text-dim);font-size:9px;font-family:monospace}.fpp-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;transition:color .15s}.fpp-close:hover{color:#f46}.fpp-row{display:flex;align-items:center;gap:6px;padding:5px 10px}.fpp-label{width:72px;flex-shrink:0;color:var(--text-dim);font-size:10px;text-transform:uppercase;letter-spacing:.05em}.fpp-track{flex:1;height:4px;background:#ffffff0f;border-radius:2px;position:relative}.fpp-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--cyan-dim),var(--cyan));border-radius:2px;pointer-events:none}.fpp-range{position:absolute;top:-6px;right:0;bottom:-6px;left:0;width:100%;opacity:0;cursor:pointer;margin:0}.fpp-val{width:36px;text-align:right;color:var(--text);font-size:10px;font-family:monospace}.fpp-color-row .fpp-val{flex:1;font-size:9px}.fpp-color-input{width:30px;height:20px;border:1px solid var(--border-lit);border-radius:3px;padding:0;cursor:pointer;background:none}.fpp-color-input::-webkit-color-swatch-wrapper{padding:2px}.fpp-color-input::-webkit-color-swatch{border-radius:2px;border:none}.fpp-toggle-row{justify-content:space-between}.fpp-toggle{position:relative;cursor:pointer}.fpp-toggle input{display:none}.fpp-toggle-track{display:block;width:32px;height:16px;background:#ffffff14;border:1px solid var(--border);border-radius:8px;transition:background .2s}.fpp-toggle input:checked+.fpp-toggle-track{background:var(--cyan-dim);border-color:var(--cyan)}.fpp-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:10px;height:10px;background:var(--text-dim);border-radius:50%;transition:transform .2s,background .2s}.fpp-toggle input:checked+.fpp-toggle-track:after{transform:translate(16px);background:var(--cyan)}.fpp-section-label{padding:6px 10px 2px;color:var(--text-dim);font-size:9px;text-transform:uppercase;letter-spacing:.08em;border-top:1px solid rgba(255,255,255,.04);margin-top:2px}.fpp-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;padding:4px 10px 6px}.fpp-type-btn{background:#ffffff0a;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-size:9px;padding:3px 2px;cursor:pointer;text-align:center;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fpp-type-btn:hover{background:#ffffff17;color:var(--text);border-color:var(--border-lit)}.fpp-type-btn--active{background:#00d4ff1f;border-color:var(--type-color, var(--cyan));color:var(--type-color, var(--cyan));box-shadow:0 0 6px #00d4ff33}.fpp-actions{display:flex;gap:6px;padding:6px 10px;border-top:1px solid rgba(255,255,255,.05)}.fpp-action-btn{flex:1;padding:5px;background:#ffffff0d;border:1px solid var(--border-lit);border-radius:3px;color:var(--text);font-size:10px;font-family:inherit;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:all .15s}.fpp-action-btn:hover{background:#00d4ff1a;border-color:var(--cyan)}.fpp-action-btn--danger{border-color:#a23;color:#f46}.fpp-action-btn--danger:hover{background:#ff325026;border-color:#f46}.fpp-hint{padding:4px 10px 6px;color:var(--text-dim);font-size:8px;text-align:center;opacity:.6}.obj-props-panel{position:absolute;bottom:12px;right:12px;width:300px;background:#040816f0;border:1px solid rgba(0,200,120,.5);box-shadow:0 0 20px #00c8781f,inset 0 0 30px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:4px;z-index:50;font-family:inherit;font-size:11px;color:var(--text)}.opp-header{display:flex;align-items:center;gap:6px;padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.06);background:#0000004d}.opp-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#00dc8ce6}.opp-name{flex:1;color:var(--text);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.opp-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;line-height:1;padding:0 2px}.opp-close:hover{color:var(--text)}.opp-row{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04)}.opp-label{width:46px;color:var(--accent, var(--text-dim));font-size:9px;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;opacity:.75}.opp-slider-wrap{flex:1;position:relative;height:16px;display:flex;align-items:center}.opp-slider{width:100%;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:color-mix(in srgb,var(--accent, #00cc88) 22%,transparent);border-radius:2px;outline:none;cursor:pointer}.opp-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent, rgba(0,220,140,.9));box-shadow:0 0 6px color-mix(in srgb,var(--accent, #00dc8c) 60%,transparent);cursor:pointer}.opp-step-btn{background:#00c8781f;border:1px solid rgba(0,200,120,.3);color:#00dc8ce6;border-radius:3px;width:22px;height:22px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;transition:background .15s}.opp-step-btn:hover{background:#00c87840}.opp-val{width:44px;text-align:right;font-size:11px;font-variant-numeric:tabular-nums;color:#00dc8ce6;flex-shrink:0}.opp-actions{display:flex;gap:6px;padding:8px 10px}.opp-action-btn{flex:1;padding:6px 8px;background:#00c87814;border:1px solid rgba(0,200,120,.3);border-radius:3px;color:#00dc8ce6;font-size:11px;font-family:inherit;cursor:pointer;transition:background .15s;letter-spacing:.04em}.opp-action-btn:hover{background:#00c87833}.properties-bar{display:flex;flex-direction:row;align-items:stretch;border-right:1px solid var(--border-lit);flex-shrink:0;max-width:560px;min-width:260px;overflow:hidden;min-height:0}.audio-panel{flex:1;min-width:0}.pb-section{display:flex;flex-direction:column;padding:0;width:100%;background:#04081680;min-height:0;flex:1}.pb-section--glb{border-left:2px solid #00dc8c}.pb-section--fixture{border-left:2px solid var(--fx-color, var(--cyan))}.pb-header{display:flex;align-items:center;gap:6px;padding:5px 8px;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.pb-type-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.pb-title{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0}.pb-name{flex:1;font-size:10px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pb-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:15px;line-height:1;padding:0 2px}.pb-close:hover{color:var(--text)}.pb-glb-body{display:flex;flex-direction:column;gap:4px;padding:6px 8px;flex:1;justify-content:center}.pb-glb-actions{display:flex;gap:6px;margin-top:2px}.pb-fx-body{display:flex;flex-direction:row;flex:1;overflow:hidden;min-height:0}.pb-col{display:flex;flex-direction:column;padding:5px 7px;gap:3px;overflow-y:auto;overflow-x:hidden;min-height:0}.pb-col--left{width:130px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.04)}.pb-col--sliders{flex:1;min-width:0}.pb-col--right{width:110px;flex-shrink:0;border-left:1px solid rgba(255,255,255,.04)}.pb-slider{display:flex;align-items:center;gap:5px;height:18px}.pb-slider__label{width:52px;font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);flex-shrink:0}.pb-slider__input{flex:1;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#00b4ff33;border-radius:2px;outline:none;cursor:pointer;min-width:0}.pb-slider__input::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--cyan);box-shadow:0 0 5px #00d4ffb3;cursor:pointer}.pb-section--glb .pb-slider__input{background:#00c87833}.pb-section--glb .pb-slider__input::-webkit-slider-thumb{background:#00dc8c;box-shadow:0 0 5px #00dc8cb3}.pb-slider__val{width:36px;text-align:right;font-size:10px;font-variant-numeric:tabular-nums;color:var(--text);flex-shrink:0}.pb-color-row{display:flex;align-items:center;gap:5px;height:22px}.pb-color-input{width:28px;height:20px;border:1px solid var(--border);border-radius:3px;padding:1px;background:none;cursor:pointer;flex-shrink:0}.pb-color-hex{font-size:9px;font-variant-numeric:tabular-nums;letter-spacing:.04em}.pb-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;flex:1;align-content:start}.pb-type-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:2px;color:var(--text-dim);font-size:8px;font-family:inherit;cursor:pointer;padding:2px 1px;transition:background .12s,color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pb-type-btn:hover{background:#ffffff1a;color:var(--text)}.pb-type-btn--active{background:color-mix(in srgb,var(--tc) 20%,transparent);border-color:var(--tc);color:var(--tc)}.pb-toggle-row{display:flex;align-items:center;gap:6px;cursor:pointer}.pb-toggle{position:relative;width:30px;height:16px;flex-shrink:0}.pb-toggle input{opacity:0;width:0;height:0}.pb-toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;background:#1a2a3a;transition:background .2s}.pb-toggle input:checked+.pb-toggle-track{background:var(--cyan)}.pb-toggle input:checked+.pb-toggle-track--strobe{background:#f4c}.pb-toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .2s}.pb-toggle input:checked+.pb-toggle-track:after{transform:translate(14px)}.pb-btn{flex:1;padding:4px 6px;background:#00b4ff14;border:1px solid rgba(0,180,255,.25);border-radius:3px;color:var(--cyan);font-size:10px;font-family:inherit;cursor:pointer;transition:background .15s;letter-spacing:.03em}.pb-btn:hover{background:#00b4ff2e}.pb-btn--danger{border-color:#ff32504d;color:#f46;background:#ff32500f}.pb-btn--danger:hover{background:#ff32502e}.pb-glb-actions .pb-btn{border-color:#00c8784d;color:#00dc8c;background:#00c8780f}.pb-glb-actions .pb-btn:hover{background:#00c87829}.pb-fx-actions{display:flex;gap:4px}.pb-hint{font-size:8px;color:var(--text-dim);opacity:.5;text-align:center}.ptg-overlay{pointer-events:none;z-index:50}.ptg-handle--resize,.ptg-handle--rot{position:absolute;width:10px;height:10px;background:#fff;border:1.5px solid #00cfff;border-radius:2px;box-shadow:0 0 4px #00c8ff99;pointer-events:all;-webkit-user-select:none;user-select:none}.ptg-handle--rot{border-radius:50%;background:#00cfff;border-color:#fff;width:9px;height:9px}.ptg-label{position:absolute;bottom:48px;left:50%;transform:translate(-50%);background:#000000a6;border:1px solid rgba(0,200,255,.3);border-radius:4px;padding:3px 10px;font-size:10px;color:#00cfff;white-space:nowrap;pointer-events:none}.pb-panel-tabs{display:flex;gap:3px;margin-bottom:4px}.pb-tab{flex:1;padding:3px 4px;font-size:9px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:3px;color:var(--text-dim);cursor:pointer;transition:background .15s}.pb-tab:hover{background:#00b4ff1f;color:#fff}.pb-tab--active{background:#00c8ff2e;border-color:var(--cyan);color:var(--cyan)}.pb-media-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.pb-media-order{display:flex;gap:3px;margin-bottom:4px}.pb-btn--file{cursor:pointer}.pb-media-ok{font-size:11px;color:#0f8}.pb-shader-editor{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.pb-shader-textarea{width:100%;min-height:110px;background:#0009;border:1px solid rgba(255,255,255,.1);border-radius:3px;color:#b0e0ff;font-family:Consolas,Fira Code,monospace;font-size:9.5px;line-height:1.45;padding:5px 7px;resize:vertical;outline:none;box-sizing:border-box}.pb-shader-textarea:focus{border-color:var(--cyan)}.pb-btn--compile{align-self:flex-end;font-size:9px;padding:3px 10px;border-color:#00ff8c59;color:#00ff8c;background:#00ff8c12}.pb-btn--compile:hover{background:#00ff8c2e}.pb-text-row{display:flex;align-items:center;gap:6px;margin-bottom:3px}.pb-text-input{flex:1;background:#0000008c;border:1px solid rgba(0,255,255,.25);border-radius:3px;color:#0ff;font-family:inherit;font-size:11px;padding:3px 7px;outline:none;min-width:0}.pb-text-input:focus{border-color:#0ff}.pb-text-select{flex:1;background:#0000008c;border:1px solid rgba(0,255,255,.25);border-radius:3px;color:#adf;font-family:inherit;font-size:10px;padding:3px 5px;outline:none;cursor:pointer}.pb-text-select:focus{border-color:#0ff}.app__body--shaderstudio{display:block;background:radial-gradient(circle at top,rgba(0,212,255,.09),transparent 40%),linear-gradient(180deg,#030716,#02040f)}.app__bottom--shaderstudio{display:block}.shaderstudio{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;height:100%;min-height:0;gap:0}.shaderstudio--projector{display:block;width:100%;height:100%;background:#000}.shaderstudio--projector .shaderstudio__preview-frame{width:100%;height:100%;padding:0;gap:0;border:none;grid-template-rows:minmax(0,1fr);background:#000;box-shadow:none}.shaderstudio--projector .shaderstudio__viewport-shell{width:100%;height:100%}.shaderstudio--projector .shaderstudio__viewport{border:none;box-shadow:none}.shaderstudio__panel{background:linear-gradient(180deg,#060c1cf5,#030712fa);min-height:0;overflow:hidden}.shaderstudio__panel--left{border-right:1px solid rgba(0,212,255,.22)}.shaderstudio__panel--right{border-left:1px solid rgba(0,212,255,.22)}.shaderstudio__panel-body{height:calc(100% - 36px);overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px}.shaderstudio__center{min-width:0;min-height:0;display:grid;gap:12px;padding:14px;background:radial-gradient(circle at 50% 0%,rgba(0,212,255,.1),transparent 35%),linear-gradient(180deg,#040a18f0,#02050efa)}.shaderstudio__center--editor-open{grid-template-rows:auto minmax(0,1fr) minmax(180px,32%)}.shaderstudio__center--editor-closed{grid-template-rows:auto minmax(0,1fr) auto}.shaderstudio__center-header,.shaderstudio__editor,.shaderstudio__section,.shaderstudio__import{border:1px solid rgba(0,212,255,.18);background:#070e1ec7;box-shadow:inset 0 0 16px #00d4ff0a}.shaderstudio__center-header{display:flex;justify-content:space-between;gap:16px;padding:14px 16px}.shaderstudio__kicker,.shaderstudio__section-heading{font-family:Share Tech Mono,monospace;text-transform:uppercase;letter-spacing:.16em;color:#61dfff}.shaderstudio__kicker{font-size:10px;margin-bottom:6px}.shaderstudio__headline{font-size:28px;font-weight:700;color:#ecf8ff;letter-spacing:.04em}.shaderstudio__subline,.shaderstudio__editor-hint,.shaderstudio__hint,.shaderstudio__shader-card-meta,.shaderstudio__message,.shaderstudio__empty{color:#8eb3ce;line-height:1.4}.shaderstudio__subline{margin-top:6px;max-width:720px}.shaderstudio__stats{display:grid;grid-template-columns:repeat(3,minmax(76px,1fr));gap:10px}.shaderstudio__center-top-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.shaderstudio__center-top-right--compact{flex-direction:row;align-items:center}.shaderstudio__header-actions{display:flex;align-items:center;justify-content:flex-end}.shaderstudio__stat{padding:10px 12px;border:1px solid rgba(255,196,0,.26);background:#ffc4000f;text-align:center}.shaderstudio__stat span{display:block;font-size:10px;letter-spacing:.16em;color:#ffcf61;text-transform:uppercase}.shaderstudio__stat strong{display:block;margin-top:4px;font-size:22px;color:#fff7de}.shaderstudio__preview-frame{position:relative;min-height:0;overflow:hidden;display:grid;grid-template-rows:minmax(0,1fr) auto auto;gap:10px;padding:12px;border:1px solid rgba(0,212,255,.34);background:radial-gradient(circle at center,rgba(0,212,255,.08),transparent 55%),#01040d;box-shadow:inset 0 0 24px #00d4ff0f,0 0 24px #00d4ff14}.shaderstudio__preview-frame--compact{grid-template-rows:minmax(0,1fr) auto;gap:6px;padding:8px}.shaderstudio__viewport-shell{min-height:0;display:grid;place-items:center}.shaderstudio__viewport{position:relative;overflow:hidden;border:1px solid rgba(255,207,97,.22);background:linear-gradient(180deg,#01040d66,#01040d1a),#000;box-shadow:inset 0 0 0 1px #ffcf6114,0 10px 26px #00000059}.shaderstudio__surface{position:absolute;left:50%;top:50%;transform:translate(calc(-50% + var(--sb-shake-x, 0px)),calc(-50% + var(--sb-shake-y, 0px))) scale(var(--sb-scale, 1)) rotate(var(--sb-shake-rot, 0deg));transform-origin:center center;will-change:transform,filter}.shaderstudio__canvas{width:100%;height:100%;display:block}.shaderstudio__canvas--epilepsy{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;mix-blend-mode:screen}.shaderstudio__canvas--glitch{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0}.shaderstudio__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden}.shaderstudio__blackout{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;opacity:0;pointer-events:none}.shaderstudio__autocolor{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;mix-blend-mode:color;opacity:0;will-change:opacity,background}.shaderstudio__text{position:absolute;max-width:88%;white-space:pre-wrap;line-height:.92;text-transform:inherit;will-change:transform,filter,opacity}.shaderstudio__text--main{color:transparent;-webkit-background-clip:text;background-clip:text}.shaderstudio__text--glow{opacity:.35}.shaderstudio__viewport-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#ffcf61}.shaderstudio__viewport-hint{font-size:11px;color:#d7eeffb8}.shaderstudio__preview-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:#d7eeffc7;font-family:Share Tech Mono,monospace}.shaderstudio__editor{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.shaderstudio__editor--closed{grid-template-rows:auto}.shaderstudio__import,.shaderstudio__section{display:flex;flex-direction:column;gap:10px}.shaderstudio__editor-header{padding:12px 14px 0;display:flex;justify-content:space-between;gap:12px}.shaderstudio__import,.shaderstudio__section{padding:12px}.shaderstudio__section--selected{margin-top:auto}.shaderstudio__shader-list{display:flex;flex-direction:column;gap:8px}.shaderstudio__shader-card{width:100%;text-align:left;padding:10px 12px;background:#09142ae0;border:1px solid rgba(63,111,151,.35);color:#d9efff;transition:border-color .16s,transform .16s,background .16s}.shaderstudio__shader-card:hover{border-color:#00d4ff7a;background:#0b1c36f0;transform:translateY(-1px)}.shaderstudio__shader-card--active{border-color:#ffd057;background:linear-gradient(135deg,#ffc4001f,#08152ef5);box-shadow:inset 0 0 14px #ffc40014}.shaderstudio__shader-card-top,.shaderstudio__button-row,.shaderstudio__toggle,.shaderstudio__color-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.shaderstudio__shader-card-top{font-weight:700;letter-spacing:.03em}.shaderstudio__badge{padding:2px 7px;border:1px solid rgba(255,196,0,.4);color:#ffd057;font-size:10px;letter-spacing:.16em}.shaderstudio__shader-card-meta{display:flex;justify-content:space-between;gap:8px;margin-top:6px;font-size:11px}.shaderstudio__text-input,.shaderstudio__select,.shaderstudio__textarea{width:100%;background:#020812eb;border:1px solid rgba(0,212,255,.22);color:#d7eeff;font-family:inherit;outline:none}.shaderstudio__text-input,.shaderstudio__select{padding:9px 10px}.shaderstudio__textarea{resize:vertical;min-height:120px;padding:12px;font-family:Share Tech Mono,monospace;line-height:1.45}.shaderstudio__textarea--compact{min-height:88px}.shaderstudio__text-input:focus,.shaderstudio__select:focus,.shaderstudio__textarea:focus{border-color:#00d4ff9e;box-shadow:0 0 0 1px #00d4ff2e}.shaderstudio__action{padding:9px 11px;background:#050f20f5;border:1px solid rgba(0,212,255,.24);color:#bfefff;letter-spacing:.12em;text-transform:uppercase}.shaderstudio__action:hover{border-color:#00d4ff99;color:#fff}.shaderstudio__action--primary{border-color:#ffc40057;background:#ffc40014;color:#ffd861}.shaderstudio__action--danger{border-color:#ff52785c;color:#ff7c9a}.shaderstudio__action:disabled{opacity:.5;cursor:not-allowed}.shaderstudio__control{display:grid;grid-template-columns:76px 1fr 56px;align-items:center;gap:10px}.shaderstudio__control-label,.shaderstudio__toggle span,.shaderstudio__color-row span{color:#d4ebff}.shaderstudio__control-value{text-align:right;color:#72dfff;font-variant-numeric:tabular-nums}.shaderstudio__slider{width:100%;accent-color:#00d4ff}.shaderstudio__toggle-btn{width:48px;height:24px;padding:2px;border:1px solid rgba(0,212,255,.24);background:#040a16e6}.shaderstudio__toggle-btn span{display:block;width:18px;height:18px;background:#3a6f8f;transition:transform .16s,background .16s}.shaderstudio__toggle-btn--on span{transform:translate(22px);background:#ffd057}.shaderstudio__link{color:#ffd861;text-decoration:none;letter-spacing:.08em}.shaderstudio__message--done{color:#67f0ab}.shaderstudio__message--warn{color:#ffd861}.shaderstudio__message--error,.shaderstudio__compile-error{color:#ff8ba3}.shaderstudio__compile-error{padding:10px 14px 14px;font-family:Share Tech Mono,monospace;white-space:pre-wrap;line-height:1.35}.shaderstudio__editor-collapsed{padding:10px 14px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:#8eb3ce;min-height:56px}.shaderstudio__editor--compact{border:1px solid rgba(0,212,255,.18);background:#070e1ec7;box-shadow:inset 0 0 16px #00d4ff0a}.shaderstudio__editor-header--compact{padding:10px 12px 0}.shaderstudio--web-lite .shaderstudio__center--editor-closed{grid-template-rows:auto minmax(0,1fr)}.shaderstudio--web-lite .shaderstudio__center-header--compact{padding:10px 12px;gap:12px;align-items:center}.shaderstudio--web-lite .shaderstudio__center--web-lite{gap:8px;padding:10px}.shaderstudio--web-lite .shaderstudio__headline{font-size:30px}.shaderstudio--web-lite .shaderstudio__stats{grid-template-columns:repeat(3,minmax(62px,1fr));gap:8px}.shaderstudio--web-lite .shaderstudio__center-header--compact .shaderstudio__action{padding:8px 10px;white-space:nowrap}.shaderstudio--web-lite .shaderstudio__stat{padding:8px 10px}.shaderstudio--web-lite .shaderstudio__stat strong{font-size:26px}@media (max-width: 1200px){.shaderstudio{grid-template-columns:240px minmax(0,1fr) 280px}}@media (max-width: 960px){.shaderstudio{grid-template-columns:1fr;grid-template-rows:auto minmax(320px,48vh) auto;overflow-y:auto}.shaderstudio__panel--left,.shaderstudio__panel--right{border:none}.shaderstudio__center{grid-template-rows:auto minmax(320px,50vh) minmax(220px,auto)}}.shaderstudio-web-lite{display:grid;grid-template-rows:auto auto minmax(0,1fr) minmax(190px,var(--bar-audio));width:100vw;height:100vh;background:radial-gradient(circle at top,rgba(0,212,255,.08),transparent 38%),linear-gradient(180deg,#02050f,#01030b)}.shaderstudio-web-lite__header{padding:16px 20px 12px;border-bottom:1px solid rgba(0,212,255,.2);background:#040a17e6}.shaderstudio-web-lite__kicker{font-family:Share Tech Mono,monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#61dfff}.shaderstudio-web-lite__title{margin-top:4px;font-size:30px;line-height:1.1;letter-spacing:.03em;color:#eff8ff}.shaderstudio-web-lite__subtitle{margin-top:8px;max-width:920px;color:#8eb3ce}.shaderstudio-web-lite__tools{min-height:42px;border-bottom:1px solid rgba(0,212,255,.2);background:#040a17d1;display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:0 20px}.shaderstudio-web-lite__tools-label{color:#61dfff;font-family:Share Tech Mono,monospace;text-transform:uppercase;letter-spacing:.2em;font-size:10px;margin-right:auto}.shaderstudio-web-lite__tools-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-left:auto}.shaderstudio-web-lite__main{min-height:0;overflow:hidden}.shaderstudio-web-lite__audio{min-height:0;border-top:2px solid var(--border-lit);background:var(--bg-panel);overflow:hidden}.shaderstudio-web-lite__audio .audio-panel{height:100%}@media (max-width: 960px){.shaderstudio-web-lite{grid-template-rows:auto auto minmax(0,1fr) minmax(250px,46vh)}.shaderstudio-web-lite__title{font-size:24px}.shaderstudio-web-lite__subtitle{font-size:12px}.shaderstudio-web-lite__header,.shaderstudio-web-lite__tools{padding:6px 10px}.shaderstudio-web-lite__tools-actions{gap:6px}.shaderstudio-web-lite__audio{overflow:auto}}.web-lite-admin{width:100vw;height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top,rgba(0,212,255,.16),transparent 40%),linear-gradient(180deg,#020510,#01020a)}.web-lite-admin__card{width:min(460px,100%);border:1px solid rgba(0,212,255,.25);background:#050c1cf0;box-shadow:0 24px 60px #00000073;padding:20px}.web-lite-admin__kicker{color:#61dfff;font-family:Share Tech Mono,monospace;text-transform:uppercase;letter-spacing:.2em;font-size:10px}.web-lite-admin__title{margin-top:6px;color:#ecf8ff;font-size:30px;line-height:1.1}.web-lite-admin__hint{margin-top:8px;color:#8eb3ce}.web-lite-admin__form{margin-top:16px;display:grid;gap:12px}.web-lite-admin__field{display:grid;gap:6px}.web-lite-admin__field span{color:#d7ebff;font-size:12px}.web-lite-admin__field input{width:100%;border:1px solid rgba(0,212,255,.28);background:#020711eb;color:#d8efff;padding:10px;outline:none}.web-lite-admin__field input:focus{border-color:#00d4ffad;box-shadow:0 0 0 1px #00d4ff33}.web-lite-admin__error{color:#ff93ac;font-size:12px}.web-lite-admin__submit{border:1px solid rgba(255,196,0,.45);background:#ffc4001a;color:#ffe08d;padding:10px 12px;text-transform:uppercase;letter-spacing:.14em}.web-lite-admin__submit:hover{background:#ffc40033}.web-lite-admin__shell{width:100%;height:100%}.web-lite-admin__shell .shaderstudio-web-lite{height:calc(100% - 36px)}.web-lite-admin__toolbar{height:36px;border-bottom:1px solid rgba(0,212,255,.22);background:#020813f2;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;color:#7fbed7;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.web-lite-admin__toolbar button{border:1px solid rgba(255,124,154,.4);background:#ff7c9a1f;color:#ff9db5;padding:4px 8px;font-size:10px;letter-spacing:.08em}.web-lite-admin__toolbar button:hover{background:#ff7c9a38}
