*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--bg2:#111;--bg3:#1a1a1a;--border:#2a2a2a;--text:#ccc;--text-dim:#666;--accent:#cf0;--accent-dim:#8aaa00;--danger:#f33;--font:"Inter", system-ui, -apple-system, sans-serif;--mono:ui-monospace, Consolas, monospace;font-size:13px}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow:hidden}.auth-screen{background:linear-gradient(120deg, #ccff0014, transparent 30%), radial-gradient(circle at 50% 0%, #ffffff14, transparent 34%), var(--bg);place-items:center;width:100%;height:100vh;min-height:420px;padding:24px;display:grid}.auth-panel{border:1px solid var(--border);background:#111111eb;border-radius:8px;flex-direction:column;align-items:flex-start;gap:18px;width:min(100%,360px);padding:28px;display:flex;box-shadow:0 24px 80px #0000008c}.auth-brand{flex-direction:column;gap:2px;display:flex}.auth-logo{color:var(--accent);letter-spacing:.12em;font-size:26px;font-weight:800}.auth-sub{color:var(--text-dim);letter-spacing:.18em;font-size:11px;font-weight:700}.auth-copy{color:var(--text);font-size:13px;line-height:1.5}.auth-button{justify-content:center;width:100%}.auth-user{z-index:1000;position:fixed;top:7px;right:10px}.editor-root{flex-direction:column;width:100%;height:100vh;display:flex}.topbar{background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;height:44px;padding:0 16px;display:flex}.topbar-logo{letter-spacing:.08em;color:var(--accent);text-transform:uppercase;white-space:nowrap;font-size:14px;font-weight:700}.topbar-sub{color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-left:4px;font-size:11px;font-weight:400}.engine-picker-wrap{flex:1;align-items:center;gap:8px;display:flex;position:relative}.engine-current-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text);cursor:pointer;letter-spacing:.04em;white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;transition:border-color .15s;display:flex}.engine-current-btn:hover{border-color:var(--accent)}.engine-current-btn .chevron{color:var(--text-dim);font-size:10px}.engine-category-badge{background:var(--bg);color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--border);border-radius:2px;padding:1px 5px;font-size:9px}.engine-dropdown{z-index:100;background:var(--bg2);border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;gap:8px;max-width:680px;padding:8px;display:flex;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 32px #0009}.engine-cat-group{min-width:130px}.engine-cat-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border);margin-bottom:4px;padding:2px 6px 6px;font-size:9px;font-weight:700;display:block}.engine-pick-btn{text-align:left;width:100%;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:5px 8px;font-size:12px;transition:background .1s,color .1s;display:block}.engine-pick-btn:hover{background:var(--bg3);color:var(--text)}.engine-pick-btn.active{color:var(--accent);background:#ccff000f}.topbar-actions{gap:6px;display:flex}.fps-counter{font-size:11px;font-family:var(--mono);color:#ccff0080;pointer-events:none;z-index:10;letter-spacing:.05em;background:#0000004d;border-radius:3px;padding:2px 6px;position:absolute;top:8px;left:8px}.editor-body{flex:1;display:flex;overflow:hidden}.canvas-area{background:#000;flex:1;min-width:0;min-height:0;position:relative;overflow:hidden}.vj-stage{background:#000;position:absolute;inset:0;overflow:hidden}.vj-deck-layer{will-change:opacity, clip-path;transition:opacity .16s linear,clip-path .16s linear;position:absolute;inset:0}.vj-composite-canvas{z-index:2;width:100%;height:100%;display:block;position:absolute;inset:0}.vj-source-layer{z-index:1;pointer-events:none;opacity:0!important}.vj-deck-label{z-index:8;color:#ffffffb3;max-width:40%;font-family:var(--mono);pointer-events:none;text-overflow:ellipsis;white-space:nowrap;background:#00000073;border:1px solid #ffffff1f;border-radius:3px;padding:3px 7px;font-size:10px;position:absolute;bottom:8px;overflow:hidden}.vj-deck-label.left{left:8px}.vj-deck-label.right{text-align:right;right:8px}.side-panel{background:var(--bg2);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:min(360px,34vw);min-width:300px;display:flex;overflow:hidden}.side-tabs{border-bottom:1px solid var(--border);display:flex}.side-tab{color:var(--text-dim);cursor:pointer;letter-spacing:.06em;text-transform:uppercase;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 4px;font-size:11px;transition:color .15s}.side-tab:hover{color:var(--text)}.side-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.side-content{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:12px;overflow-y:auto}.live-panel{flex-direction:column;gap:12px;display:flex}.live-sticky{z-index:20;background:linear-gradient(180deg, var(--bg2) 0%, var(--bg2) 78%, #1110 100%);flex-direction:column;gap:8px;padding-bottom:8px;display:flex;position:sticky;top:-12px}.live-hero{background:#10120c;border:1px solid #ccff0047;border-radius:6px;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;display:flex}.live-kicker{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:800;display:block}.live-hero h2{color:#f2f2f2;letter-spacing:0;font-size:18px;line-height:1.15}.live-meter{border:1px solid var(--border);min-width:58px;color:var(--text-dim);font-family:var(--mono);text-align:center;border-radius:4px;flex-shrink:0;padding:5px 7px;font-size:11px}.live-meter.on{border-color:var(--accent);color:var(--accent);background:#ccff0014}.live-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.live-actions.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.live-actions-primary{border:1px solid var(--border);background:#1a1a1af0;border-radius:6px;padding:8px;box-shadow:0 10px 24px #00000047}.live-action{text-align:center;justify-content:center;align-items:center;width:100%;min-height:36px;display:inline-flex}.live-card{border:1px solid var(--border);background:var(--bg3);border-radius:6px;flex-direction:column;gap:9px;padding:10px;display:flex}.live-card-head{color:var(--text);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.live-subhead{color:var(--accent-dim);letter-spacing:.16em;text-transform:uppercase;margin-top:2px;font-size:9px;font-weight:900;display:block}.live-deck-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.live-deck{border:1px solid var(--border);background:var(--bg);border-radius:5px;flex-direction:column;gap:7px;min-width:0;padding:8px;display:flex}.live-deck.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px #ccff002e}.live-deck strong{color:var(--accent);font-family:var(--mono);font-size:16px}.live-deck span{min-height:28px;color:var(--text-dim);font-size:10px;line-height:1.35;overflow:hidden}.live-deck div{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;display:grid}.vj-jump-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.cue-list{flex-direction:column;gap:5px;max-height:230px;display:flex;overflow:auto}.cue-row{grid-template-columns:minmax(0,1fr) auto 28px 28px 28px;align-items:stretch;gap:5px;display:grid}.cue-row>.engine-category-badge{white-space:nowrap;align-self:center}.cue-row>button:first-child{border:1px solid var(--border);background:var(--bg);min-width:0;color:var(--text);cursor:pointer;text-align:left;border-radius:4px;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:6px;padding:6px;display:grid}.cue-row.active>button:first-child,.cue-row>button:first-child:hover{border-color:var(--accent)}.cue-row strong{color:var(--accent);font-family:var(--mono);font-size:11px}.cue-row span{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-dim);font-size:10px;overflow:hidden}.cue-edit-row{grid-column:1/-1;grid-template-columns:minmax(0,1fr) 58px 86px;gap:5px;display:grid}.live-wide{width:100%;min-height:36px}.live-note{color:var(--text-dim);font-size:11px;line-height:1.45}.live-readout{color:var(--text-dim);font-family:var(--mono);font-size:10px;font-weight:500}.live-status-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;display:grid}.live-preset-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.live-band-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;display:grid}.live-band{border:1px solid var(--border);background:var(--bg);border-radius:4px;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:6px;min-width:0;padding:5px;display:grid}.live-band span{color:var(--text-dim);font-family:var(--mono);text-transform:uppercase;font-size:9px}.live-band i{background:var(--accent);border-radius:99px;height:4px;transition:width 80ms linear;display:block;box-shadow:0 0 10px #ccff0040}.live-band.hit{border-color:var(--accent)}.beat-band-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;margin-bottom:12px;display:grid}.beat-band{border:1px solid var(--border);background:var(--bg);border-radius:4px;min-width:0;height:46px;position:relative;overflow:hidden}.beat-band span{z-index:1;color:var(--text-dim);font-family:var(--mono);text-transform:uppercase;font-size:8px;position:absolute;bottom:4px;left:5px}.beat-band i{background:linear-gradient(#ccff002e,#ccff00d1);transition:height 70ms linear;position:absolute;bottom:0;left:0;right:0}.beat-band.hit{border-color:var(--accent)}.live-status{border:1px solid var(--border);background:var(--bg);text-align:center;border-radius:5px;min-width:0;padding:8px 5px}.live-status span{color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;font-size:9px;font-weight:800;display:block}.live-status strong{color:var(--text);font-family:var(--mono);margin-top:3px;font-size:15px;display:block}.live-status.active{background:#ccff000d;border-color:#ccff0080}.live-status.active strong{color:var(--accent)}.live-toggle-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;display:grid}.live-toggle{border:1px solid var(--border);background:var(--bg);min-height:38px;color:var(--text-dim);cursor:pointer;text-align:left;border-radius:5px;padding:6px 7px}.live-toggle span{text-overflow:ellipsis;white-space:nowrap;letter-spacing:.04em;font-size:10px;font-weight:800;display:block;overflow:hidden}.live-toggle strong{font-family:var(--mono);margin-top:3px;font-size:10px;font-weight:500;display:block}.live-toggle.active{color:var(--accent);background:#ccff000f;border-color:#ccff008c}.live-source-meter{color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;grid-template-columns:70px minmax(0,1fr);align-items:center;gap:8px;font-size:10px;font-weight:800;display:grid}.live-source-meter div{background:var(--bg);border:1px solid var(--border);border-radius:999px;height:7px;overflow:hidden}.live-source-meter i{background:var(--accent);height:100%;display:block;box-shadow:0 0 12px #ccff006b}.live-scene-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;display:grid}.live-scene-pad{border:1px solid var(--border);background:var(--bg);min-height:58px;color:var(--text-dim);cursor:pointer;border-radius:5px;padding:6px 4px;overflow:hidden}.live-scene-pad:disabled{cursor:default;opacity:.45}.live-scene-pad.ready{color:var(--text);border-color:#ccff0059}.live-scene-pad.ready:hover{border-color:var(--accent);background:#ccff0012}.live-scene-pad.queued{outline-offset:2px;outline:2px solid #ccff00b8}.live-scene-pad span{color:var(--accent);font-family:var(--mono);font-size:15px;font-weight:800;display:block}.live-scene-pad small{text-overflow:ellipsis;color:inherit;margin-top:3px;font-size:10px;line-height:1.15;display:block;overflow:hidden}.live-macro-list{flex-direction:column;gap:8px;display:flex}.live-macro{color:var(--text-dim);grid-template-columns:76px minmax(0,1fr);align-items:center;gap:8px;font-size:11px;display:grid}.live-macro span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.live-macro input{width:100%;accent-color:var(--accent)}.live-next-row,.live-control-row{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:7px;display:grid}.live-next{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.live-duration-row{gap:6px;display:flex}.live-chip{border:1px solid var(--border);background:var(--bg);min-height:26px;color:var(--text-dim);cursor:pointer;font-family:var(--mono);border-radius:4px;flex:1;font-size:10px}.live-chip:hover,.live-chip.active{border-color:var(--accent);color:var(--accent);background:#ccff000f}.blackout-overlay{z-index:12;pointer-events:none;background:#000;position:absolute;inset:0}.output-root{background:#000}.output-canvas{width:100vw;height:100vh}.param-section{flex-direction:column;gap:8px;display:flex}.param-label{color:var(--text-dim);letter-spacing:.04em;align-items:center;gap:6px;font-size:11px;display:flex}.param-range{width:100%;accent-color:var(--accent);cursor:pointer}.param-select{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;border-radius:3px;padding:4px 6px;font-size:12px}.param-file{color:var(--text-dim);width:100%;font-size:11px}.param-color{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;width:36px;height:24px;padding:0}.param-row{gap:12px;display:flex}.param-input{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:3px;outline:none;flex:1;padding:4px 8px;font-size:12px}.param-input:focus{border-color:var(--accent)}.btn{background:var(--bg3);border:1px solid var(--border);color:var(--text);cursor:pointer;letter-spacing:.04em;border-radius:3px;padding:6px 12px;font-size:12px;transition:background .15s,border-color .15s}.btn:hover{background:#222;border-color:#444}.btn-primary{border-color:var(--accent);color:var(--accent)}.btn-primary:hover{background:#ccff0014}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:#ff333314}.btn-recording{border-color:var(--danger);color:var(--danger);opacity:.7;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:11px}.btn-icon{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 6px;font-size:14px;transition:color .15s}.btn-icon:hover{color:var(--text)}.btn-icon-danger:hover{color:var(--danger)}.export-row{gap:10px;display:flex}.export-row>div{flex-direction:column;flex:1;gap:4px;display:flex}.progress-bar{background:var(--bg3);border-radius:2px;width:100%;height:3px;overflow:hidden}.progress-fill{background:var(--danger);height:100%;transition:width .1s linear}.preset-save{gap:6px;display:flex}.preset-list{flex-direction:column;gap:2px;list-style:none;display:flex}.preset-item{background:var(--bg3);border-radius:3px;justify-content:space-between;align-items:center;padding:4px 6px;display:flex}.preset-name{color:var(--text);cursor:pointer;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;flex:1;font-size:12px;overflow:hidden}.preset-name:hover{color:var(--accent)}.preset-actions{gap:2px;display:flex}.fx-row{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;padding-bottom:8px;display:flex}.fx-row:last-child{border-bottom:none}.btn.active{border-color:var(--accent);color:var(--accent);background:#ccff000f}.lfo-row{background:var(--bg3);border:1px solid var(--border);border-radius:4px;flex-wrap:wrap;align-items:center;gap:5px;padding:6px;display:flex}.midi-device-list{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.midi-chip{border:1px solid var(--border);max-width:100%;color:var(--accent);text-overflow:ellipsis;white-space:nowrap;background:#ccff000d;border-radius:3px;padding:3px 6px;font-size:10px;overflow:hidden}.midi-monitor{border:1px solid var(--border);background:var(--bg);min-height:20px;color:var(--text-dim);font-family:var(--mono);border-radius:3px;padding:5px 6px;font-size:10px}.midi-learn-box{border:1px solid var(--border);background:var(--bg3);border-radius:4px;flex-direction:column;gap:5px;padding:7px;display:flex}.midi-learning{color:var(--accent);background:#ccff0014;border:1px solid #ccff0059;border-radius:4px;justify-content:space-between;align-items:center;gap:8px;padding:6px 8px;display:flex}.midi-map-row{background:var(--bg3);border-radius:3px;align-items:center;gap:6px;margin-bottom:3px;padding:4px 6px;display:flex}.performance-list{flex-direction:column;gap:4px;margin-top:8px;display:flex}.performance-row{border:1px solid var(--border);background:var(--bg3);border-radius:4px;align-items:center;gap:5px;min-height:28px;padding:4px 6px;display:flex}.macro-grid{flex-direction:column;gap:8px;display:flex}.macro-card{border:1px solid var(--border);background:var(--bg3);border-radius:5px;flex-direction:column;gap:6px;padding:8px;display:flex}.macro-head{align-items:center;gap:6px;display:flex}.macro-name{min-width:0;color:var(--accent);font-weight:700}.macro-value{min-width:36px;color:var(--text-dim);font-family:var(--mono);text-align:right;font-size:10px}.macro-bindings{flex-direction:column;gap:6px;display:flex}.macro-binding{background:var(--bg);border-radius:4px;flex-direction:column;gap:5px;padding:6px;display:flex}.macro-binding-title{color:var(--text);justify-content:space-between;align-items:center;font-size:11px;font-weight:700;display:flex}.input-route-builder{grid-template-columns:1fr 1fr auto;align-items:center;gap:5px;display:grid}.input-route-card{border:1px solid var(--border);background:var(--bg3);border-radius:4px;flex-direction:column;gap:6px;padding:7px;display:flex}.crossfade-overlay{object-fit:cover;pointer-events:none;z-index:5;opacity:1;width:100%;height:100%;transition:opacity .65s ease-out;position:absolute;inset:0}.glsl-editor{border:1px solid var(--border);color:#cf0;width:100%;height:240px;font-family:var(--mono);resize:vertical;box-sizing:border-box;white-space:pre;overflow-wrap:normal;tab-size:2;caret-color:#fff;background:#0a0a0a;border-radius:4px;padding:8px;font-size:10px;line-height:1.5;overflow:auto}.glsl-editor:focus{border-color:var(--accent);outline:none}.glsl-error{border:1px solid var(--danger);color:var(--danger);font-size:9px;font-family:var(--mono);white-space:pre-wrap;word-break:break-all;background:#ff33331f;border-radius:3px;max-height:80px;margin:0;padding:6px 8px;overflow-y:auto}.drop-overlay{border:2px dashed var(--accent);color:var(--accent);pointer-events:none;z-index:20;background:#ccff0014;border-radius:4px;justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;inset:0}.tl-header{align-items:center;gap:6px;margin-bottom:8px;display:flex}.tl-keyframes{margin-top:8px}.tl-track{background:var(--bg3);border-radius:3px;height:20px;position:relative;overflow:visible}.tl-kf{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:10px;height:10px;padding:0;transition:background .15s;position:absolute;top:50%;transform:translate(-50%,-50%)}.tl-kf:hover{background:var(--danger)}.tl-playhead{pointer-events:none;background:#fff4;width:2px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.help-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.help-modal{background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-width:280px;max-width:360px;padding:20px 24px;box-shadow:0 8px 40px #000c}.rec-badge{color:#fff;letter-spacing:.06em;pointer-events:none;z-index:10;background:#dc1414e6;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:700;animation:1s ease-in-out infinite recPulse;position:absolute;top:12px;left:12px}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.4}}
