@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8d697b304b401681-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba015fad6dcf6784-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/4cf2300e9c8272f7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Fallback;src:local("Arial");ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.00%;size-adjust:104.76%}.__className_188709{font-family:Geist,Geist Fallback;font-style:normal}.__variable_188709{--font-geist-sans:"Geist","Geist Fallback"}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/9610d9e46709d722-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/747892c23ea88013-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/93f479601ee12b01-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Mono Fallback;src:local("Arial");ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.00%;size-adjust:134.59%}.__className_9a8899{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.__variable_9a8899{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#080808;--bg-panel:#111111;--bg-panel-raised:#191919;--bg-input:#0a0a0a;--bg-section:#141414;--border-subtle:#1c1c1c;--border-panel:#282828;--border-light:#333;--text-primary:#d4d4d4;--text-secondary:#777;--text-dim:#444;--color-play:#00e676;--color-cue:#ff9100;--color-sync:#00b0ff;--color-stop:#ff1744;--color-effect:#aa00ff;--color-loop:#ffd600;--glow-play:0 0 12px rgba(0,230,118,0.6);--glow-cue:0 0 12px rgba(255,145,0,0.6);--glow-sync:0 0 12px rgba(0,176,255,0.6);--font-mono:"Geist Mono","Courier New",monospace;--font-sans:"Geist",-apple-system,BlinkMacSystemFont,sans-serif;--transition:0.15s ease}body,html{background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-sans);min-height:100vh;-webkit-font-smoothing:antialiased}.dj-app{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#0c0c0c,#080808);-webkit-user-select:none;user-select:none}.dj-header{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;background:#0a0a0a;border-bottom:1px solid var(--border-subtle);min-height:40px;flex-shrink:0}.dj-logo{font-size:1.1rem;font-weight:800;letter-spacing:5px;text-transform:uppercase;background:linear-gradient(135deg,#dfa968,#be7c2c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.audio-init-hint{font-size:.7rem;color:var(--color-cue);animation:pulse-hint 1.5s ease-in-out infinite}@keyframes pulse-hint{0%,to{opacity:.5}50%{opacity:1}}.header-right{display:flex;align-items:center;gap:12px}.header-info{font-size:.65rem;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase}.dj-main{padding:4px;min-height:0}.decks-side,.dj-main{display:flex;flex:1 1;gap:4px}.decks-side{flex-direction:column;min-width:0}.decks-side.four-decks .deck{flex:1 1}.dj-footer{padding:4px 16px;text-align:center;font-size:.6rem;color:var(--text-dim);border-top:1px solid var(--border-subtle);letter-spacing:1px;flex-shrink:0}.deck{flex:1 1;display:flex;flex-direction:column;gap:4px;background:var(--bg-panel);border-radius:6px;padding:6px;border:1px solid var(--border-panel);min-width:0;transition:border-color var(--transition)}.deck-dragover{border-color:var(--color-sync)!important;box-shadow:inset 0 0 20px rgba(0,176,255,.1)}.deck-header{display:flex;justify-content:space-between;align-items:center;padding:3px 8px;background:var(--bg-section);border-radius:4px;gap:8px}.deck-label{font-size:.65rem;font-weight:800;letter-spacing:3px;text-transform:uppercase}.track-name{font-size:.75rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1;text-align:center;font-weight:500}.bpm-display{font-family:var(--font-mono);font-size:1.1rem;font-weight:700;white-space:nowrap}.bpm-display small{font-size:.55rem;opacity:.6;letter-spacing:1px}.deck-time-display{display:flex;justify-content:space-between;padding:2px 8px;font-family:var(--font-mono);font-size:.9rem;font-weight:600}.time-elapsed{color:var(--text-primary)}.time-remaining{color:var(--color-stop)}.waveform-container{position:relative;background:var(--bg-input);border-radius:4px;border:1px solid var(--border-subtle);overflow:hidden;min-height:70px;cursor:pointer}.waveform{width:100%;height:70px}.zoom-controls{position:absolute;top:2px;right:2px;gap:2px;z-index:10;background:rgba(0,0,0,.65);border-radius:3px;padding:1px 3px}.zoom-btn,.zoom-controls{display:flex;align-items:center}.zoom-btn{width:18px;height:18px;border:1px solid var(--border-light);border-radius:2px;background:var(--bg-section);color:var(--text-secondary);font-size:.7rem;font-weight:700;cursor:pointer;justify-content:center;padding:0;line-height:1;font-family:var(--font-sans)}.zoom-btn:hover{background:var(--bg-panel-raised);color:var(--text-primary)}.zoom-label{font-size:.5rem;color:var(--text-dim);font-family:var(--font-mono);font-weight:600;min-width:24px;text-align:center}.waveform-placeholder{font-size:.75rem;color:var(--text-dim);pointer-events:none;border:2px dashed var(--border-light);border-radius:4px;margin:2px}.waveform-drop-overlay,.waveform-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.waveform-drop-overlay{background:rgba(0,176,255,.08);border:2px dashed;border-radius:4px;font-size:.85rem;font-weight:700;color:var(--color-sync);z-index:5}.deck-controls-row{display:flex;gap:8px;align-items:center}.vinyl-disc{width:86px;height:86px;border-radius:50%;background:radial-gradient(circle,#1a1a1a 0,#0d0d0d 20%,#151515 21%,#0d0d0d 40%,#151515 41%,#0d0d0d 60%,#151515 61%,#0d0d0d 80%,#1a1a1a 100%);position:relative;box-shadow:0 2px 12px rgba(0,0,0,.8),inset 0 0 20px rgba(0,0,0,.5);transition:transform .05s linear}.vinyl-grooves{position:absolute;inset:6px;border-radius:50%;border:1px solid rgba(255,255,255,.03);background:repeating-radial-gradient(circle,transparent 0,transparent 2px,rgba(255,255,255,.02) 0,rgba(255,255,255,.02) 3px)}.vinyl-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:rgba(255,255,255,.8)}.transport-controls{flex:1 1;display:flex;gap:8px;align-items:center}.transport-buttons{display:flex;gap:4px}.transport-btn{padding:6px 12px;border:1px solid var(--border-light);border-radius:4px;background:var(--bg-section);color:var(--text-secondary);font-size:.65rem;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans);min-width:44px;text-align:center}.transport-btn:hover{background:var(--bg-panel-raised)}.transport-btn:disabled{opacity:.3;cursor:not-allowed}.btn-play.active{background:var(--color-play);color:#000;border-color:var(--color-play);box-shadow:var(--glow-play)}.btn-cue.set,.btn-cue:active{background:var(--color-cue);color:#000;border-color:var(--color-cue);box-shadow:var(--glow-cue)}.btn-sync.active,.btn-sync:active{background:var(--color-sync);color:#000;border-color:var(--color-sync);box-shadow:var(--glow-sync)}.speed-control{display:flex;flex-direction:column;align-items:center;gap:2px;margin-left:auto}.speed-label{font-size:.5rem;color:var(--text-dim);letter-spacing:2px;font-weight:700}.speed-slider{appearance:none;writing-mode:vertical-lr;direction:rtl;width:6px;height:80px;background:linear-gradient(to top,var(--border-light),var(--border-panel));border-radius:3px;outline:none;cursor:pointer}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:8px;background:linear-gradient(180deg,#555,#333);border-radius:2px;border:1px solid #666;cursor:grab;box-shadow:0 1px 4px rgba(0,0,0,.5)}.speed-value{font-family:var(--font-mono);font-size:.65rem;color:var(--text-secondary);font-weight:600}.hotcue-section,.loop-section{display:flex;align-items:center;gap:6px;padding:2px 0}.section-label{font-size:.5rem;color:var(--text-dim);letter-spacing:2px;font-weight:700;width:48px;flex-shrink:0}.hotcue-pads{display:flex;gap:3px;flex:1 1}.hotcue-pad{flex:1 1;height:26px;width:3vw;border:1px solid var(--border-light);border-radius:3px;background:var(--bg-section);color:var(--text-dim);font-size:.6rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans)}.hotcue-pad:hover{background:var(--bg-panel-raised);border-color:#555}.hotcue-pad.active{color:#000!important;border-color:transparent;font-weight:800}.loop-controls{display:flex;gap:3px;align-items:center;flex:1 1}.loop-btn{padding:4px 8px;border:1px solid var(--border-light);border-radius:3px;background:var(--bg-section);color:var(--text-dim);font-size:.6rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans);min-width:30px;text-align:center}.loop-btn:hover{background:var(--bg-panel-raised)}.loop-btn.set{color:var(--color-loop);border-color:rgba(255,214,0,.3)}.loop-btn.active{background:var(--color-loop);color:#000;border-color:var(--color-loop)}.beat-jump{display:flex;gap:2px;margin-left:auto}.beat-btn{padding:4px 6px;border:1px solid var(--border-subtle);border-radius:3px;background:var(--bg-input);color:var(--text-dim);font-size:.55rem;cursor:pointer;transition:all var(--transition)}.beat-btn:hover{background:var(--bg-section);color:var(--text-secondary)}.effects-rack{display:flex;gap:6px;align-items:center;padding:3px 0}.effects-label{font-size:.5rem;color:var(--text-dim);letter-spacing:2px;font-weight:700;width:24px;flex-shrink:0}.effects-grid{display:flex;gap:4px;flex:1 1;flex-wrap:wrap}.effect-slot{display:flex;flex-direction:column;align-items:center;gap:2px}.effect-btn{padding:4px 8px;border:1px solid var(--border-light);border-radius:3px;background:var(--bg-section);color:var(--text-dim);font-size:.55rem;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans);min-width:50px;text-align:center}.effect-btn:hover{background:var(--bg-panel-raised);color:var(--text-secondary)}.effect-btn.active{font-weight:800}.mixer{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:4px;background:var(--bg-panel);border-radius:6px;padding:6px;border:1px solid var(--border-panel)}.mixer-header{display:flex;justify-content:space-between;align-items:center;padding:2px 6px}.mixer-title{font-size:.65rem;font-weight:800;letter-spacing:3px;color:var(--text-secondary)}.deck-count-toggle{display:flex;gap:2px}.count-btn{padding:2px 6px;border:1px solid var(--border-light);border-radius:3px;background:var(--bg-section);color:var(--text-dim);font-size:.55rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans)}.count-btn.active{background:var(--color-sync);color:#000;border-color:var(--color-sync)}.spectrum-container{height:50px;background:var(--bg-input);border-radius:4px;border:1px solid var(--border-subtle);overflow:hidden}.spectrum-canvas{width:100%;height:100%;display:block}.mixer-channels{display:flex;gap:4px;flex:1 1;justify-content:center}.mixer-channel{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--bg-section);border-radius:4px;padding:4px 2px;flex:1 1;min-width:0}.master-channel{border-left:1px solid var(--border-panel);padding-left:6px}.channel-label{font-size:.55rem;font-weight:800;letter-spacing:2px}.channel-fader-section{display:flex;gap:2px;align-items:center;flex:1 1}.master-vu-section{display:flex;gap:3px;flex:1 1}.volume-fader-wrapper{display:flex;align-items:center;justify-content:center}.volume-fader{appearance:none;writing-mode:vertical-lr;direction:rtl;width:6px;height:100px;background:linear-gradient(0deg,#222,#1a1a1a);border-radius:3px;outline:none;cursor:pointer}.volume-fader::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:6px;background:linear-gradient(180deg,#666,#444);border-radius:2px;border:1px solid #777;cursor:grab;box-shadow:0 1px 3px rgba(0,0,0,.6)}.crossfader-section{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--bg-section);border-radius:4px}.crossfader-label{font-size:.7rem;font-weight:800}.crossfader{appearance:none;flex:1 1;height:4px;background:linear-gradient(90deg,#222,#333,#222);border-radius:2px;outline:none;cursor:pointer}.crossfader::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:14px;background:linear-gradient(180deg,#666,#444);border-radius:3px;border:1px solid #777;cursor:grab;box-shadow:0 1px 4px rgba(0,0,0,.6)}.knob-container{display:flex;flex-direction:column;align-items:center;gap:1px}.knob-label{font-size:.5rem;color:var(--text-dim);letter-spacing:1px;font-weight:700;text-transform:uppercase}.knob-body{position:relative;cursor:grab;border-radius:50%}.knob-body:active{cursor:grabbing}.knob-svg{position:absolute;top:0;left:0;pointer-events:none}.knob-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle at 35% 35%,#3a3a3a,#1a1a1a 70%);box-shadow:inset 0 2px 4px rgba(255,255,255,.05),inset 0 -2px 4px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding-top:4px}.knob-indicator{width:2px;height:8px;border-radius:1px;transform-origin:center calc(100% + 5px)}.knob-value{font-family:var(--font-mono);font-size:.5rem;color:var(--text-dim)}.vu-meter{border-radius:2px;background:#0a0a0a}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}@media (max-width:1200px){.mixer{width:240px}.vinyl-container{width:70px;height:70px}.vinyl-disc{width:66px;height:66px}}@media (max-width:900px){.dj-main{flex-direction:column}.decks-side,.mixer{flex-direction:row}.mixer{width:100%}.mixer,.mixer-channels{flex-wrap:wrap}.crossfader-section{width:100%}}.waveform ::part(cursor){border-left:2px solid #fff!important}.song-queue{display:flex;flex-direction:column;gap:2px;min-height:0}.song-queue-header{display:flex;align-items:center;gap:4px;padding:1px 0}.song-queue-title{font-size:.5rem;font-weight:800;letter-spacing:2px}.song-queue-count{font-size:.5rem;color:var(--text-dim);font-family:var(--font-mono);margin-right:auto}.queue-autoplay-btn,.queue-view-btn{width:20px;height:16px;border:1px solid var(--border-light);border-radius:2px;background:var(--bg-section);color:var(--text-dim);font-size:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-family:var(--font-sans)}.queue-autoplay-btn:hover,.queue-view-btn:hover{background:var(--bg-panel-raised);color:var(--text-secondary)}.queue-autoplay-btn.active{background:var(--bg-panel-raised);font-weight:800}.song-queue-list{max-height:64px;overflow-y:auto;overflow-x:hidden;border:1px solid var(--border-subtle);border-radius:3px;background:var(--bg-input);min-height:28px;transition:border-color .15s}.song-queue-list.drag-over{border-color:var(--color-sync);background:rgba(0,176,255,.05)}.song-queue-list.grid-mode{display:flex;flex-wrap:wrap;gap:2px;padding:2px;align-content:flex-start}.song-queue-list.list-mode{display:flex;flex-direction:column}.queue-empty{display:flex;align-items:center;justify-content:center;font-size:.5rem;color:var(--text-dim);padding:6px;width:100%}.queue-item{cursor:pointer;transition:all .1s;border:1px solid transparent;border-radius:2px}.queue-item:hover{background:var(--bg-panel-raised)}.queue-item.playing{border-style:solid}.queue-item.drag-target{border-left:2px solid var(--color-sync)}.queue-item-art{width:28px;height:28px;border-radius:2px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-section)}.queue-item-art img{width:100%;height:100%;object-fit:cover}.queue-art-placeholder{font-size:.65rem;color:var(--text-dim)}.queue-item-name{font-size:.5rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:2px 4px;display:block}.song-library{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--border-panel);padding-top:4px}.library-header{display:flex;align-items:center;gap:4px;padding:0 2px}.library-title{font-size:.55rem;font-weight:800;letter-spacing:2px;color:var(--text-secondary)}.library-count{font-size:.45rem;color:var(--text-dim);font-family:var(--font-mono);margin-right:auto}.library-filters{display:flex;gap:2px;padding:0 2px}.lib-filter-btn{padding:1px 4px;border:1px solid var(--border-subtle);border-radius:2px;background:var(--bg-input);color:var(--text-dim);font-size:.45rem;font-weight:700;cursor:pointer;font-family:var(--font-sans);letter-spacing:.5px}.lib-filter-btn:hover{background:var(--bg-section);color:var(--text-secondary)}.lib-filter-btn.active{background:var(--bg-panel-raised);color:var(--text-primary);border-color:var(--border-light)}.library-list{overflow-y:auto;overflow-x:hidden;border:1px solid var(--border-subtle);border-radius:3px;background:var(--bg-input);min-height:32px;transition:border-color .15s}.library-list.drag-over{border-color:var(--color-sync);background:rgba(0,176,255,.05)}.library-list.grid-mode{display:flex;flex-wrap:wrap;gap:2px;padding:2px;align-content:flex-start}.library-list.list-mode{display:flex;flex-direction:column}.library-empty{display:flex;align-items:center;justify-content:center;font-size:.55rem;color:var(--text-dim);padding:10px;width:100%}.library-item{cursor:grab;transition:all .1s}.library-item:hover{background:var(--bg-panel-raised)}.library-item-art{width:36px;height:36px;border-radius:2px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-section);position:relative}.library-item-art img{width:100%;height:100%;object-fit:cover}.library-art-placeholder{font-size:.8rem;color:var(--text-dim)}.library-resize-handle{display:flex;align-items:center;justify-content:center;height:10px;cursor:ns-resize;background:var(--bg-section);border-bottom:1px solid var(--border-subtle);border-radius:3px 3px 0 0;-webkit-user-select:none;user-select:none;transition:background .15s}.library-resize-handle:hover{background:var(--bg-panel-raised)}.resize-grip{font-size:.5rem;color:var(--text-dim);letter-spacing:2px;line-height:1}.queue-view-btn.active{color:var(--color-sync);border-color:var(--color-sync)}.library-deck-badge{position:absolute;bottom:1px;right:1px;width:12px;height:12px;border-radius:50%;font-size:.4rem;font-weight:800;color:#000;display:flex;align-items:center;justify-content:center}.library-item-row{display:flex;align-items:center;gap:4px;padding:2px 4px}.library-item-mini-art{width:18px;height:18px;border-radius:2px;object-fit:cover;flex-shrink:0}.library-item-name{font-size:.5rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1}.library-item-deck{font-size:.45rem;font-weight:800;flex-shrink:0;letter-spacing:.5px}.dj-logo-img{width:40px;height:40px;margin-right:12px;box-shadow:0 0 5px #BE7C2C,0 0 0 #d4d4d4;border-radius:5px}.header-left{flex-shrink:0}.header-center,.header-left{display:flex;align-items:center}.header-center{gap:12px;flex:1 1;justify-content:center;min-width:0}.midi-monitor{gap:8px;font-size:.65rem;font-family:var(--font-mono)}.midi-monitor,.midi-status{display:flex;align-items:center}.midi-status{gap:4px}.midi-status-dot{width:6px;height:6px;border-radius:50%;background:#444;transition:all .3s ease}.midi-connected .midi-status-dot{background:#00e676;box-shadow:0 0 6px #00e676}.midi-status-label{color:var(--text-dim);font-weight:700;letter-spacing:1px;font-size:.6rem}.midi-connected .midi-status-label,.midi-device-name{color:var(--text-secondary)}.midi-device-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.55rem}.midi-activity{display:flex;align-items:center;gap:4px;background:var(--bg-section);padding:2px 8px;border-radius:3px;border:1px solid var(--border-subtle);animation:midi-flash .3s ease;max-width:280px;overflow:hidden}.midi-activity-mapped{border-color:var(--color-sync);background:rgba(0,176,255,.08)}.midi-activity-input{color:var(--text-secondary);font-size:.6rem;white-space:nowrap}.midi-activity-target{color:var(--color-sync);font-weight:700;font-size:.6rem;white-space:nowrap}@keyframes midi-flash{0%{opacity:.3;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.midi-controls{display:flex;align-items:center;gap:4px}.midi-map-btn{padding:3px 8px;border:1px solid var(--border-light);border-radius:3px;background:var(--bg-section);color:var(--text-secondary);font-size:.6rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font-sans);white-space:nowrap}.midi-map-btn:hover{background:var(--bg-panel-raised);color:var(--text-primary)}.midi-map-btn.active{background:var(--color-cue);color:#000;border-color:var(--color-cue);animation:pulse-mapping 1.5s ease-in-out infinite}@keyframes pulse-mapping{0%,to{box-shadow:0 0 4px rgba(255,145,0,.4)}50%{box-shadow:0 0 14px rgba(255,145,0,.9)}}.midi-mapping-count{color:var(--text-dim);font-size:.55rem;white-space:nowrap}.midi-learning-hint{color:#ffd600;font-size:.55rem;animation:pulse-hint 1s ease-in-out infinite;white-space:nowrap}.midi-action-btn{padding:2px 5px;border:1px solid var(--border-subtle);border-radius:3px;background:var(--bg-section);font-size:.65rem;cursor:pointer;transition:all var(--transition);line-height:1}.midi-action-btn:hover{background:var(--bg-panel-raised);border-color:var(--border-light)}.midi-wrap{position:relative;display:inline-flex}.midi-learn-overlay{position:absolute;inset:-2px;background:rgba(255,145,0,.12);border:1px dashed rgba(255,145,0,.5);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:20;gap:1px;padding:1px;transition:all .15s ease}.midi-learn-overlay:hover{background:rgba(255,145,0,.25);border-color:rgba(255,145,0,.8);box-shadow:0 0 8px rgba(255,145,0,.3)}.midi-learning .midi-learn-overlay{background:rgba(255,214,0,.2);border-color:#ffd600;border-style:solid;animation:pulse-learn 1s ease-in-out infinite}@keyframes pulse-learn{0%,to{box-shadow:0 0 6px rgba(255,214,0,.3)}50%{box-shadow:0 0 16px rgba(255,214,0,.7)}}.midi-learn-label{font-size:.4rem;color:rgba(255,145,0,.9);font-weight:700;text-align:center;line-height:1.1;text-transform:uppercase;letter-spacing:.3px;pointer-events:none;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.midi-learn-mapped{font-size:.38rem;color:var(--color-sync);font-family:var(--font-mono);pointer-events:none}.midi-learn-waiting{font-size:.75rem;pointer-events:none;animation:pulse-hint .8s ease-in-out infinite}.midi-dot-indicator{position:absolute;top:-2px;right:-2px;width:5px;height:5px;border-radius:50%;background:var(--color-sync);box-shadow:0 0 4px var(--color-sync);pointer-events:none;z-index:5}.knob-midi-active .knob-body{cursor:pointer}.knob-midi-active .knob-body:after{content:"";position:absolute;inset:-3px;border-radius:50%;border:1px dashed rgba(255,145,0,.4);pointer-events:none}.knob-body.knob-midi-learning{box-shadow:0 0 12px rgba(255,214,0,.5)}.knob-body.knob-midi-learning:after{border-color:#ffd600;border-style:solid;animation:pulse-learn 1s ease-in-out infinite}.knob-body.knob-midi-mapped:after{border-color:var(--color-sync);border-style:solid;opacity:.6}.knob-midi-overlay{font-size:.4rem;color:var(--color-cue);text-align:center;font-family:var(--font-mono);font-weight:600;line-height:1;margin-top:-1px}.knob-midi-overlay.learning{color:#ffd600;animation:pulse-hint .8s ease-in-out infinite}.midi-mapping-active .midi-learn-overlay{pointer-events:auto}.dj-app:has(.midi-map-btn.active) .deck{border-color:rgba(255,145,0,.15)}.dj-app:has(.midi-map-btn.active) .mixer{border-color:rgba(255,145,0,.15)}.dj-app:has(.midi-map-btn.active) .dj-header{border-bottom-color:rgba(255,145,0,.3)}.vinyl-container{flex-shrink:0;width:90px;height:90px;display:flex;align-items:center;justify-content:center;position:relative}.vinyl-disc.scratch-glow-fwd{box-shadow:0 2px 12px rgba(0,0,0,.8),inset 0 0 20px rgba(0,0,0,.5),0 0 18px rgba(0,230,118,.7),0 0 40px rgba(0,230,118,.3)}.vinyl-disc.scratch-glow-bwd{box-shadow:0 2px 12px rgba(0,0,0,.8),inset 0 0 20px rgba(0,0,0,.5),0 0 18px rgba(255,23,68,.7),0 0 40px rgba(255,23,68,.3)}.scratch-indicator{position:absolute;top:-6px;right:-6px;font-size:.45rem;font-weight:800;letter-spacing:.5px;padding:2px 4px;border-radius:3px;z-index:20;pointer-events:none;font-family:var(--font-mono)}.scratch-indicator.scratch-fwd{color:#00e676;background:rgba(0,230,118,.15);border:1px solid rgba(0,230,118,.4);text-shadow:0 0 8px #00e676}.scratch-indicator.scratch-bwd{color:#ff1744;background:rgba(255,23,68,.15);border:1px solid rgba(255,23,68,.4);text-shadow:0 0 8px #ff1744}.vinyl-midi-map-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(255,145,0,.15);border:2px dashed rgba(255,145,0,.55);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:30;gap:2px;transition:all .15s ease}.vinyl-midi-map-overlay:hover{background:rgba(255,145,0,.28);border-color:rgba(255,145,0,.9);box-shadow:0 0 16px rgba(255,145,0,.35)}.vinyl-midi-map-overlay.learning{background:rgba(255,214,0,.2);border-color:#ffd600;border-style:solid;animation:pulse-learn 1s ease-in-out infinite}.vinyl-midi-map-overlay.mapped{background:rgba(0,176,255,.1);border-color:rgba(0,176,255,.5);border-style:solid}.vinyl-midi-map-overlay.mapped:hover{background:rgba(255,145,0,.2);border-color:rgba(255,145,0,.8);border-style:dashed}.vinyl-midi-icon{font-size:1rem;line-height:1;pointer-events:none}.vinyl-midi-txt{font-size:.38rem;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;color:rgba(255,145,0,.95);text-align:center;pointer-events:none;letter-spacing:.3px}.vinyl-midi-map-overlay.learning .vinyl-midi-txt{color:#ffd600}.vinyl-midi-map-overlay.mapped .vinyl-midi-txt{color:var(--color-sync)}.vinyl-midi-dot{position:absolute;top:3px;right:3px;width:7px;height:7px;border-radius:50%;background:var(--color-sync);box-shadow:0 0 5px var(--color-sync);z-index:20;pointer-events:none}:root{--background:#080808;--foreground:#d4d4d4}html{height:100%;color-scheme:dark}body,html{max-width:100vw;overflow-x:hidden}body{min-height:100%;display:flex;flex-direction:column;color:var(--foreground);background:var(--background);font-family:var(--font-sans,Arial,Helvetica,sans-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}