@import "https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Inter:wght@300;400;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#070709;--bg-panel:#0e0e12;--bg-control:#141418;--bg-input:#1a1a20;--bg-raised:#222228;--border:#2a2a32;--border-light:#3a3a44;--text:#ccc;--text-dim:#666;--text-bright:#fff;--accent-a:#00c8ff;--accent-b:#ff2952;--accent-green:#00ff7f;--accent-orange:#f80;--accent-red:#ff1a3a;--accent-yellow:#ffd000;--accent-purple:#84f;--glow-a:#00c8ff40;--glow-b:#ff295240}body{background:var(--bg-dark);color:var(--text);-webkit-user-select:none;user-select:none;min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}#app{max-width:1700px;margin:0 auto;padding:6px}#app.fullscreen-mode{max-width:100%;padding:0}#app.fullscreen-mode .controls-area,#app.fullscreen-mode .library-panel,#app.fullscreen-mode .shortcuts-bar,#app.fullscreen-mode .key-compat{display:none}#app.fullscreen-mode .waveforms-main{height:50vh}#app.fullscreen-mode .waveform-display{height:100%}#app.fullscreen-mode .spectrum-bar{height:80px}.top-bar{border-bottom:1px solid var(--border);background:linear-gradient(#18181e,#101014);border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;padding:5px 14px;display:flex}.logo{letter-spacing:3px;background:linear-gradient(135deg,var(--accent-a),#fff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Orbitron,sans-serif;font-size:15px;font-weight:900}.model{letter-spacing:1px;font-size:9px;font-weight:400}.master-clock{align-items:center;gap:8px;display:flex}.master-clock .label{color:var(--text-dim);letter-spacing:2px;font-size:8px}.bpm-display{color:var(--accent-green);text-shadow:0 0 12px #00ff7f66;font-family:Orbitron,sans-serif;font-size:20px;font-weight:700}.top-right{align-items:center;gap:8px;display:flex}.top-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:1px;cursor:pointer;border-radius:3px;padding:3px 10px;font-size:9px;font-weight:700;transition:all .15s}.top-btn:hover{border-color:var(--accent-a);color:var(--accent-a)}.top-btn.active{background:var(--accent-a);color:#000;border-color:var(--accent-a)}.midi-status{color:var(--text-dim);letter-spacing:1px;align-items:center;gap:4px;font-size:9px;display:flex}.midi-dot{background:#333;border-radius:50%;width:6px;height:6px;display:inline-block}.midi-dot.connected{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.tap-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:2px;cursor:pointer;border-radius:3px;padding:3px 10px;font-size:9px;font-weight:700}.tap-btn:active{background:var(--accent-purple);color:#fff}.rec-btn{color:var(--accent-red);border:1px solid var(--accent-red);cursor:pointer;letter-spacing:2px;background:#2a0008;border-radius:3px;padding:3px 10px;font-size:9px;font-weight:700}.rec-btn.active{background:var(--accent-red);color:#fff;animation:1s infinite pulse-red}.rec-time{color:var(--text-dim);font-family:Orbitron,sans-serif;font-size:10px}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.4}}.phase-meter-bar{background:#0a0a0e;align-items:center;gap:8px;padding:3px 14px;display:flex;position:relative}.phase-label{color:var(--text-dim);letter-spacing:2px;font-size:8px}.phase-track{background:#111116;border-radius:3px;flex:1;height:6px;position:relative;overflow:hidden}.phase-center{background:#ffffff40;width:2px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.phase-indicator{background:var(--accent-green);border-radius:3px;width:10px;height:100%;transition:left 60ms;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 0 6px #00ff7f80}.phase-beats{color:var(--text-dim);font-family:Orbitron,sans-serif;font-size:9px}.beat-flash{opacity:0;pointer-events:none;background:linear-gradient(90deg,transparent,var(--glow-a));width:50%;height:100%;transition:opacity 50ms;position:absolute;top:0;left:0}.beat-flash.b{background:linear-gradient(270deg,transparent,var(--glow-b));left:50%}.beat-flash.flash{opacity:1}.spectrum-bar{background:#060609;gap:2px;height:50px;padding:2px 8px;display:flex}.spectrum-canvas{border-radius:3px;flex:1;height:100%}.waveform-overview{background:#080810;gap:2px;padding:2px 8px;display:flex}.deck-waveform{cursor:pointer;background:#06060a;border:1px solid #1a1a22;border-radius:3px;flex:1;height:32px;position:relative;overflow:hidden}.deck-waveform canvas{width:100%;height:100%;display:block}.playhead{z-index:2;pointer-events:none;background:#fff;width:2px;height:100%;position:absolute;top:0;left:0;box-shadow:0 0 8px #fffc}.waveforms-main{background:#080810;align-items:stretch;gap:2px;padding:2px 8px;display:flex}.waveform-display{background:#04040a;border:1px solid #1a1a22;border-radius:3px;flex:1;height:95px;position:relative;overflow:hidden}.waveform-display canvas{width:100%;height:100%;display:block}.wave-info{z-index:3;background:linear-gradient(#000000e6,#0000);flex-wrap:nowrap;align-items:center;gap:5px;padding:2px 6px;display:flex;position:absolute;top:0;left:0;right:0}.deck-label{border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-family:Orbitron,sans-serif;font-size:11px;font-weight:900;display:flex}.deck-label.a{background:var(--accent-a);color:#000}.deck-label.b{background:var(--accent-b);color:#fff}.track-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:9px;overflow:hidden}.key-display{color:var(--accent-purple);background:#8844ff1a;border-radius:2px;flex-shrink:0;padding:1px 5px;font-family:Orbitron,sans-serif;font-size:9px;font-weight:700}.key-controls{flex-shrink:0;gap:2px;display:flex}.key-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:1px 5px;font-size:8px;font-weight:700}.key-btn:hover{border-color:var(--accent-purple);color:var(--accent-purple)}.key-btn.active{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple)}.time-display{color:var(--accent-green);flex-shrink:0;font-family:Orbitron,sans-serif;font-size:9px}.beat-grid-line{z-index:2;pointer-events:none;background:#ffffff80;width:2px;height:100%;position:absolute;top:0;left:50%;box-shadow:0 0 6px #ffffff4d}.drop-overlay{border:2px dashed var(--accent-a);letter-spacing:3px;color:var(--accent-a);z-index:10;background:#00c8ff1a;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:none;position:absolute;inset:0}#deck-b .drop-overlay,#wave-drop-b .drop-overlay{border-color:var(--accent-b);color:var(--accent-b);background:#ff29521a}.drop-overlay.visible{display:flex}.waveform-zoom-controls{flex-direction:column;justify-content:center;gap:2px;padding:2px;display:flex}.zoom-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:3px 5px;font-size:8px;font-weight:700}.zoom-btn:hover{border-color:var(--border-light);color:var(--text)}.zoom-btn.active{color:var(--accent-a);border-color:var(--accent-a)}.key-compat{background:#0a0a0e;justify-content:center;align-items:center;gap:8px;padding:2px;font-size:9px;display:flex}.key-compat-label{color:var(--text-dim);letter-spacing:2px}.key-compat-value{color:var(--text-dim);font-weight:700}.key-compat-value.match{color:var(--accent-green)}.key-compat-value.close{color:var(--accent-yellow)}.key-compat-value.clash{color:var(--accent-red)}.controls-area{background:var(--bg-panel);border-radius:0 0 8px 8px;gap:4px;padding:6px;display:flex}.deck{background:var(--bg-control);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex:1;gap:5px;padding:8px;display:flex;overflow:hidden}#deck-a{border-top:2px solid var(--accent-a)}#deck-b{border-top:2px solid var(--accent-b)}.mixer-center{background:var(--bg-control);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:6px;width:210px;min-width:210px;max-height:calc(100vh - 300px);padding:8px 6px;display:flex;overflow-y:auto}.deck-header{justify-content:space-between;align-items:center;display:flex}.deck-id{letter-spacing:2px;color:var(--text-dim);font-family:Orbitron,sans-serif;font-size:10px;font-weight:700}.bpm-section{align-items:baseline;gap:3px;display:flex}.bpm-value{color:#fff;font-family:Orbitron,sans-serif;font-size:16px;font-weight:700}.bpm-label{color:var(--text-dim);letter-spacing:1px;font-size:8px}.load-btn{background:var(--bg-input);border:1px dashed var(--border);width:100%;color:var(--text-dim);letter-spacing:2px;text-align:center;cursor:pointer;border-radius:4px;padding:6px;font-size:9px;font-weight:600;transition:all .2s;display:block}.load-btn:hover{border-color:var(--accent-a);color:var(--accent-a)}#deck-b .load-btn:hover{border-color:var(--accent-b);color:var(--accent-b)}.jog-wheel-container{flex-direction:column;align-items:center;display:flex}.jog-wheel{cursor:grab;perspective:200px;background:radial-gradient(circle at 35% 35%,#252530,#111116 55%,#08080c);border:3px solid #2a2a32;border-radius:50%;width:160px;height:160px;position:relative;overflow:hidden;box-shadow:0 4px 24px #0009,inset 0 0 30px #0006}.jog-platter{width:100%;height:100%;transform-style:preserve-3d;border-radius:50%;transition:transform 50ms;position:relative}.jog-art{opacity:.2;pointer-events:none;border-radius:50%;width:150px;height:150px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#deck-a .jog-wheel:hover{box-shadow:0 4px 30px var(--glow-a),inset 0 0 30px #0006}#deck-b .jog-wheel:hover{box-shadow:0 4px 30px var(--glow-b),inset 0 0 30px #0006}.jog-wheel:active{cursor:grabbing}.jog-inner{z-index:2;background:radial-gradient(circle at 35% 35%,#1e1e28,#0e0e14);border:2px solid #222230;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.jog-label{color:#2a2a36;font-family:Orbitron,sans-serif;font-size:20px;font-weight:900}.jog-dot{z-index:3;border-radius:50%;width:5px;height:5px;position:absolute;top:8px;left:50%;transform:translate(-50%)}#deck-a .jog-dot{background:var(--accent-a);box-shadow:0 0 8px var(--accent-a)}#deck-b .jog-dot{background:var(--accent-b);box-shadow:0 0 8px var(--accent-b)}.jog-modes{gap:3px;margin-top:4px;display:flex}.vinyl-btn,.slip-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:1px;cursor:pointer;border-radius:2px;padding:2px 8px;font-size:8px;font-weight:700}.vinyl-btn.active{border-color:var(--accent-green);color:var(--accent-green);background:#0a1a10}.slip-btn.active{border-color:var(--accent-purple);color:var(--accent-purple);background:#1a0a2a}.transport{gap:5px;display:flex}.transport-btn{cursor:pointer;border:2px solid;border-radius:4px;flex:1;padding:8px;font-size:12px;font-weight:700;transition:all .1s}.cue-btn{border-color:var(--accent-orange);color:var(--accent-orange);background:#1e1200}.cue-btn:hover{background:var(--accent-orange);color:#000}.play-btn{border-color:var(--accent-green);color:var(--accent-green);background:#001a0a;font-size:15px}.play-btn:hover,.play-btn.active{background:var(--accent-green);color:#000}.play-btn.active{box-shadow:0 0 10px #00ff7f4d}.tempo-section{text-align:center}.tempo-header{justify-content:space-between;align-items:center;margin-bottom:3px;display:flex}.tempo-label{color:var(--text-dim);letter-spacing:2px;font-size:8px}.tempo-range-btns{gap:2px;display:flex}.range-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:1px 4px;font-size:7px;font-weight:700}.range-btn.active{border-color:var(--accent-a);color:var(--accent-a)}#deck-b .range-btn.active{border-color:var(--accent-b);color:var(--accent-b)}.tempo-slider{-webkit-appearance:none;background:var(--bg-input);border-radius:3px;outline:none;width:100%;height:7px}.tempo-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:linear-gradient(#fff,#bbb);border-radius:2px;width:12px;height:20px;box-shadow:0 2px 6px #00000080}.tempo-value{color:var(--accent-green);margin-top:2px;font-family:Orbitron,sans-serif;font-size:10px}.sync-row{justify-content:center;gap:3px;margin-top:3px;display:flex}.sync-btn,.master-btn{letter-spacing:1px;cursor:pointer;border:1px solid;border-radius:3px;padding:4px 12px;font-size:9px;font-weight:700;transition:all .15s}.sync-btn{border-color:var(--accent-purple);color:var(--accent-purple);background:#0a0a1e}.sync-btn:hover,.sync-btn.active{background:var(--accent-purple);color:#fff;box-shadow:0 0 8px #8844ff4d}.master-btn{background:var(--bg-input);border-color:var(--border);color:var(--text-dim)}.master-btn.active{border-color:var(--accent-yellow);color:var(--accent-yellow);background:#ffd00014}.eq-section{background:var(--bg-dark);border-radius:4px;justify-content:center;gap:5px;padding:5px;display:flex}.eq-knob-group{flex-direction:column;align-items:center;gap:2px;display:flex}.eq-knob-group label{color:var(--text-dim);letter-spacing:1px;font-size:7px;font-weight:700}.knob-wrapper{width:32px;height:32px;position:relative}.knob-wrapper.small{width:26px;height:26px}.rotary-knob{cursor:pointer;background:radial-gradient(circle at 35% 35%,#333340,#1a1a24);border:2px solid #3a3a44;border-radius:50%;width:100%;height:100%;position:relative}.rotary-knob:after{content:"";transform-origin:bottom;width:2px;height:8px;transform:translateX(-50%) rotate(var(--knob-angle,0deg));background:#fff;border-radius:1px;position:absolute;top:3px;left:50%}.knob-wrapper.small .rotary-knob:after{height:6px;top:2px}.eq-val{color:var(--text-dim);font-family:Orbitron,sans-serif;font-size:7px}.eq-kill{color:#500;letter-spacing:1px;cursor:pointer;background:0 0;border:1px solid #2a0000;border-radius:2px;padding:1px 5px;font-size:6px;font-weight:700;transition:all .1s}.eq-kill.active{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.eq-kill:hover{border-color:var(--accent-red);color:var(--accent-red)}.color-fx-section{background:var(--bg-dark);border-radius:4px;padding:5px}.section-label{color:var(--text-dim);letter-spacing:2px;margin-bottom:3px;font-size:8px;font-weight:700}.color-fx-select{gap:2px;margin-bottom:3px;display:flex}.cfx-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;flex:1;padding:3px 0;font-size:7px;font-weight:700}.cfx-btn.active{border-color:var(--accent-orange);color:var(--accent-orange);background:#ff88001f}.color-fx-knob{-webkit-appearance:none;background:var(--bg-input);border-radius:3px;outline:none;width:100%;height:5px}.color-fx-knob::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-orange);cursor:pointer;border-radius:50%;width:12px;height:12px}.channel-strip{background:var(--bg-dark);border-radius:4px;align-items:center;gap:5px;padding:5px;display:flex}.gain-section{flex-direction:column;align-items:center;gap:2px;display:flex}.gain-section label{color:var(--text-dim);letter-spacing:1px;font-size:7px}.volume-fader{-webkit-appearance:slider-vertical;background:var(--bg-input);cursor:pointer;outline:none;width:16px;height:90px}.vu-meter{background:#0a0a0e;border:1px solid #1a1a22;border-radius:3px;width:20px;height:130px;position:relative;overflow:hidden}.vu-canvas{width:100%;height:100%;display:block}.vu-clip{z-index:2;background:#300;border-radius:2px 2px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.vu-clip.active{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.vu-peak-hold{background:var(--accent-green);z-index:2;height:2px;position:absolute;bottom:0;left:2px;right:2px}.pad-section{background:var(--bg-dark);border-radius:4px;padding:5px}.pad-mode-tabs{gap:2px;margin-bottom:4px;display:flex}.pad-mode-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:.3px;cursor:pointer;border-radius:2px;flex:1;padding:3px 0;font-size:7px;font-weight:700;transition:all .1s}.pad-mode-btn.active{border-color:var(--accent-purple);color:var(--accent-purple);background:#8844ff1f}.pad-grid{grid-template-columns:repeat(4,1fr);gap:3px;display:none}.pad-grid.active{display:grid}.pad{background:var(--bg-input);color:var(--text-dim);cursor:pointer;text-align:center;border:1px solid #2a2a34;border-radius:3px;padding:8px 0;font-size:9px;font-weight:700;transition:all 60ms}.pad:active{brightness:1.2;transform:scale(.93)}.pad.set{border-color:var(--accent-a);color:var(--accent-a);background:#00c8ff1a}#deck-b .pad.set{border-color:var(--accent-b);color:var(--accent-b);background:#ff29521a}.pad.roll-active{border-color:var(--accent-green);color:var(--accent-green);background:#00ff7f1f}.pad.slicer-active{border-color:var(--accent-yellow);color:var(--accent-yellow);background:#ffd0001f}.pad.sampler-loaded{border-color:var(--accent-purple);color:var(--accent-purple);background:#8844ff1a}.pad.sampler-playing{background:var(--accent-purple);color:#fff}.pad.padfx-active{border-color:var(--accent-orange);color:var(--accent-orange);background:#ff880026}.loop-buttons{grid-template-columns:repeat(4,1fr);gap:2px;display:grid}.loop-btn,.loop-in-out{background:var(--bg-input);color:var(--text-dim);cursor:pointer;border:1px solid #2a2a34;border-radius:2px;padding:5px 0;font-size:8px;font-weight:700}.loop-btn:hover,.loop-in-out:hover{border-color:#444}.loop-btn.active,.loop-in-out.set{border-color:var(--accent-green);color:var(--accent-green);background:#00ff7f1a}.loop-adjust{gap:2px;margin-top:2px;display:flex}.loop-adj-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;flex:1;padding:3px 0;font-size:8px;font-weight:700}.loop-adj-btn:hover{border-color:var(--border-light);color:var(--text)}.loop-exit-btn{color:var(--accent-orange);border-color:#320}.saved-loops{flex-wrap:wrap;gap:2px;margin-top:3px;display:flex}.saved-loop-btn{color:var(--accent-green);cursor:pointer;background:#00ff7f0d;border:1px solid #00ff7f33;border-radius:2px;padding:2px 6px;font-size:7px;font-weight:700}.saved-loop-btn:hover{background:#00ff7f26}.beat-fx-panel{background:var(--bg-dark);border-radius:4px;padding:5px}.beat-fx-select{gap:3px;margin-bottom:4px;display:flex}.fx-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:2px;outline:none;flex:1;padding:3px;font-size:8px;font-weight:600}.fx-select option{background:var(--bg-input);color:var(--text)}.beat-fx-controls{gap:5px;display:flex}.fx-channel{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.fx-channel label{color:var(--text-dim);letter-spacing:1px;font-size:8px;font-weight:700}.fx-depth-slider{-webkit-appearance:none;background:var(--bg-input);border-radius:3px;outline:none;width:100%;height:5px}.fx-depth-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-purple);cursor:pointer;border-radius:50%;width:10px;height:10px}.fx-beat-select{gap:2px;display:flex}.fx-beat-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:1px 3px;font-size:7px;font-weight:700}.fx-beat-btn.active{border-color:var(--accent-purple);color:var(--accent-purple)}.fx-on-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:1px;cursor:pointer;border-radius:2px;padding:3px 14px;font-size:8px;font-weight:700}.fx-on-btn.active{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple);box-shadow:0 0 8px #8844ff4d}.fx-chain-section{flex-wrap:wrap;align-items:center;gap:3px;margin-top:4px;display:flex}.chain-label{color:var(--text-dim);letter-spacing:1px;font-size:7px}.fx-chain-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;flex:1;padding:2px 4px;font-size:7px;font-weight:700}.fx-chain-btn.active{border-color:var(--accent-purple);color:var(--accent-purple)}.xy-pad-section{text-align:center}.xy-pad-deck-select{justify-content:center;gap:3px;margin-bottom:3px;display:flex}.xy-deck-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:2px 10px;font-size:8px;font-weight:700}.xy-deck-btn.active{border-color:var(--accent-a);color:var(--accent-a)}.xy-pad{background:var(--bg-dark);border:1px solid var(--border);cursor:crosshair;border-radius:4px;width:100%;height:110px;position:relative;overflow:hidden}.xy-pad canvas{width:100%;height:100%;display:block}.xy-cursor{border:2px solid var(--accent-a);pointer-events:none;width:12px;height:12px;box-shadow:0 0 8px var(--glow-a);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.xy-label-x{color:var(--text-dim);letter-spacing:1px;pointer-events:none;font-size:7px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.xy-label-y{color:var(--text-dim);letter-spacing:1px;pointer-events:none;font-size:7px;position:absolute;top:50%;left:2px;transform:translateY(-50%)rotate(-90deg)}.crossfader-section{text-align:center}.cf-label{color:var(--text-dim);letter-spacing:2px;margin-bottom:2px;font-size:7px}.cf-curve-btns{justify-content:center;gap:2px;margin-bottom:3px;display:flex}.cf-curve{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:1px 6px;font-size:8px}.cf-curve.active{border-color:var(--accent-a);color:var(--accent-a)}.crossfader{-webkit-appearance:none;background:linear-gradient(90deg,var(--accent-a),#333 35%,#333 65%,var(--accent-b));border-radius:4px;outline:none;width:100%;height:8px}.crossfader::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:linear-gradient(#eee,#aaa);border-radius:3px;width:26px;height:16px;box-shadow:0 2px 6px #00000080}.cf-indicators{color:var(--text-dim);justify-content:space-between;margin-top:2px;font-size:8px;display:flex}.master-hp-row{justify-content:center;gap:8px;display:flex}.master-section,.booth-section{flex-direction:column;align-items:center;gap:3px;display:flex}.master-section label,.booth-section label{color:var(--text-dim);letter-spacing:1px;font-size:8px}.master-fader{-webkit-appearance:slider-vertical;background:var(--bg-input);cursor:pointer;outline:none;width:16px;height:60px}.master-vu{width:22px;height:60px}.headphone-section{text-align:center}.hp-buttons{gap:2px;margin-bottom:3px;display:flex}.hp-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;flex:1;padding:3px;font-size:8px;font-weight:700}.hp-btn.active{border-color:var(--accent-yellow);color:var(--accent-yellow);background:#ffd0001a}.hp-mix,.hp-vol{align-items:center;gap:3px;margin-top:2px;display:flex}.hp-mix label,.hp-vol label{color:var(--text-dim);min-width:28px;font-size:7px}.hp-mix input,.hp-vol input{-webkit-appearance:none;background:var(--bg-input);border-radius:2px;outline:none;flex:1;height:4px}.hp-mix input::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-yellow);cursor:pointer;border-radius:50%;width:8px;height:8px}.hp-vol input::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-yellow);cursor:pointer;border-radius:50%;width:8px;height:8px}.beat-jump-section{text-align:center}.beat-jump-deck-select{justify-content:center;gap:2px;margin-bottom:3px;display:flex}.bj-deck-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:2px 8px;font-size:8px;font-weight:700}.bj-deck-btn.active{border-color:var(--accent-a);color:var(--accent-a)}.beat-jump-row{grid-template-columns:repeat(4,1fr);gap:2px;margin-bottom:2px;display:grid}.bj-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:4px 0;font-size:8px;font-weight:700}.bj-btn:hover{border-color:var(--border-light);color:var(--text)}.mic-section{text-align:center}.mic-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);letter-spacing:1px;cursor:pointer;border-radius:3px;margin-bottom:3px;padding:3px 12px;font-size:8px;font-weight:700}.mic-btn.active{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.mic-section input[type=range]{-webkit-appearance:none;background:var(--bg-input);border-radius:2px;outline:none;width:100%;height:4px}.mic-section input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-red);cursor:pointer;border-radius:50%;width:8px;height:8px}.talkover-label{color:var(--text-dim);cursor:pointer;justify-content:center;align-items:center;gap:3px;margin-top:2px;font-size:7px;display:flex}.talkover-label input{cursor:pointer;width:10px;height:10px}.setlist-section{flex:1;overflow:hidden}.setlist{max-height:50px;color:var(--text-dim);font-size:8px;overflow-y:auto}.setlist-entry{border-bottom:1px solid #1a1a22;padding:1px 3px}.setlist-entry .time{color:var(--accent-green);margin-right:4px;font-family:Orbitron,sans-serif;font-size:7px}.library-panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:5px;max-height:220px;margin-top:4px;transition:max-height .3s;overflow:hidden}.library-panel.collapsed{max-height:28px}.library-header{background:var(--bg-control);justify-content:space-between;align-items:center;padding:5px 10px;display:flex}.library-actions{align-items:center;gap:3px;display:flex}.lib-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:2px 6px;font-size:8px;font-weight:700}.lib-btn:hover{border-color:var(--border-light);color:var(--text)}.lib-toggle{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:1px 6px;font-size:10px}.library-panel.collapsed .lib-toggle{transform:rotate(180deg)}.library-search{gap:4px;padding:3px 10px;display:flex}.library-search input{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:3px;outline:none;flex:1;padding:4px 6px;font-size:10px}.library-search input:focus{border-color:var(--accent-a)}.lib-sort{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:2px;outline:none;padding:3px;font-size:8px}.library-table-wrap{max-height:140px;padding:0 10px;overflow-y:auto}.library-table{border-collapse:collapse;width:100%}.library-table th{text-align:left;color:var(--text-dim);letter-spacing:1px;border-bottom:1px solid var(--border);background:var(--bg-panel);cursor:pointer;padding:3px 5px;font-size:8px;position:sticky;top:0}.library-table th:hover{color:var(--text)}.library-table td{color:var(--text);border-bottom:1px solid #1a1a22;padding:3px 5px;font-size:9px}.library-table tr:hover td{background:#ffffff08}.lib-load-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:2px;padding:1px 6px;font-size:8px;font-weight:700}.lib-load-btn:hover{border-color:var(--accent-a);color:var(--accent-a)}.lib-load-btn.b:hover{border-color:var(--accent-b);color:var(--accent-b)}.star-rating{gap:1px;display:inline-flex}.star{cursor:pointer;color:#333;font-size:10px;transition:color .1s}.star.filled,.star:hover{color:var(--accent-yellow)}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.visible{display:flex}.modal{background:var(--bg-control);border:1px solid var(--border);border-radius:8px;width:320px;max-height:80vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);letter-spacing:2px;color:var(--text);justify-content:space-between;align-items:center;padding:10px 14px;font-family:Orbitron,sans-serif;font-size:12px;font-weight:700;display:flex}.modal-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:20px}.modal-body{flex-direction:column;gap:10px;padding:12px 14px;display:flex}.pref-group{justify-content:space-between;align-items:center;gap:10px;display:flex}.pref-group label{color:var(--text);font-size:11px}.pref-group select,.pref-group input[type=color]{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:3px;padding:3px;font-size:10px}.pref-group input[type=color]{cursor:pointer;border:none;width:40px;height:24px;padding:0}.toggle{cursor:pointer;width:36px;height:20px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-input);border:1px solid var(--border);border-radius:10px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-dim);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-slider{border-color:var(--accent-green);background:#00ff7f33}.toggle input:checked+.toggle-slider:before{background:var(--accent-green);transform:translate(16px)}[data-tooltip]{position:relative}[data-tooltip]:hover:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;z-index:100;pointer-events:none;background:#222;border-radius:3px;padding:3px 8px;font-size:9px;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.welcome-overlay{background:var(--bg-dark);z-index:2000;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.welcome-overlay.hidden{opacity:0;pointer-events:none}.welcome-card{background:var(--bg-control);border:1px solid var(--border);text-align:center;border-radius:16px;width:400px;max-width:90vw;padding:40px 36px;box-shadow:0 20px 60px #0009}.welcome-logo{letter-spacing:4px;background:linear-gradient(135deg,var(--accent-a),#fff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:4px;font-family:Orbitron,sans-serif;font-size:28px;font-weight:900}.welcome-sub{color:var(--text-dim);letter-spacing:2px;margin-bottom:28px;font-size:11px}.welcome-form{text-align:left;flex-direction:column;gap:14px;display:flex}.welcome-field{flex-direction:column;gap:4px;display:flex}.welcome-field label{color:var(--text);letter-spacing:.5px;font-size:11px;font-weight:600}.welcome-field .optional{color:var(--text-dim);font-size:9px;font-weight:400}.welcome-field input,.welcome-field select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-bright);border-radius:6px;outline:none;padding:10px 12px;font-family:Inter,sans-serif;font-size:13px;transition:border-color .2s}.welcome-field input:focus,.welcome-field select:focus{border-color:var(--accent-a)}.welcome-field input::placeholder{color:#444}.welcome-field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23666'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.welcome-field select option{background:var(--bg-input);color:var(--text)}.welcome-start{background:linear-gradient(135deg,var(--accent-a),var(--accent-purple));color:#fff;letter-spacing:2px;cursor:pointer;border:none;border-radius:6px;margin-top:4px;padding:12px;font-size:13px;font-weight:700;transition:all .2s}.welcome-start:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #00c8ff4d}.welcome-start:disabled{opacity:.35;cursor:not-allowed}.welcome-footer{color:#444;letter-spacing:.5px;margin-top:16px;font-size:9px}.user-badge{background:var(--bg-input);border:1px solid var(--border);cursor:pointer;border-radius:20px;align-items:center;gap:6px;margin:0 8px;padding:3px 10px;transition:all .2s;display:none}.user-badge:hover{border-color:var(--accent-a);background:var(--bg-raised)}.user-badge.visible{display:flex}.user-avatar{background:linear-gradient(135deg,var(--accent-a),var(--accent-purple));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:900;display:flex}.user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:10px;font-weight:600;overflow:hidden}.user-level-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:8px;padding:2px 6px;font-size:7px;font-weight:700}.user-level-badge.professional{color:var(--accent-purple);background:#8844ff26;border:1px solid #8844ff4d}.user-level-badge.hobbyist{color:var(--accent-a);background:#00c8ff1f;border:1px solid #00c8ff40}.user-level-badge.newbie{color:var(--accent-green);background:#00ff7f1a;border:1px solid #00ff7f33}.modal-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-bright);border-radius:4px;outline:none;width:100%;max-width:180px;padding:6px 10px;font-family:Inter,sans-serif;font-size:12px}.modal-input:focus{border-color:var(--accent-a)}.shortcuts-bar{text-align:center;color:#333;letter-spacing:.3px;background:#06060a;border-top:1px solid #111118;padding:4px 14px;font-size:8px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:#2a2a34;border-radius:2px}@media (width<=1200px){.jog-wheel{width:130px;height:130px}.jog-inner{width:55px;height:55px}.mixer-center{width:180px;min-width:180px}}@media (width<=900px){.controls-area{flex-direction:column}.mixer-center{width:100%;min-width:unset;max-height:unset;flex-flow:wrap;justify-content:center}}
