:root{--bg: #050507;--surface: #08080d;--panel: #0b0b11;--panel-2: #101019;--line: #1a1a28;--text: #ecedfb;--muted: #6b7082;--neon-cyan: #00e5ff;--neon-pink: #ff2d9c;--neon-lime: #5dff9e;--neon-yellow: #ffe24a;--neon-purple: #b06bff;--accent: var(--neon-cyan);--shift: #ffd250}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}.btn,.mini,.lib-nav,.lib-add{touch-action:manipulation}.app{height:100dvh;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;overflow:hidden;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}.app input,.app textarea,.app [contenteditable]{user-select:text;-webkit-user-select:text}.workspace{flex:1 1 0;min-height:0;min-width:0;display:flex;flex-direction:column}.stage{flex:1 1 0;min-width:0;min-height:0;display:flex;flex-direction:column;position:relative}*{scrollbar-width:thin;scrollbar-color:var(--line) transparent}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}*::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--accent, #36c2ff) 60%,var(--line))}*::-webkit-scrollbar-track,*::-webkit-scrollbar-corner{background:transparent}.lanes,.decks-row,.mix-row{scrollbar-width:none}.lanes::-webkit-scrollbar,.decks-row::-webkit-scrollbar,.mix-row::-webkit-scrollbar{display:none}.topbar{display:flex;align-items:baseline;gap:12px;padding:14px 20px;border-bottom:1px solid var(--line);background:#0006}.logo{font-size:22px;font-weight:800;letter-spacing:2px;margin:0;color:var(--neon-cyan);text-shadow:0 0 8px rgba(0,229,255,.7),0 0 20px rgba(0,229,255,.4)}.tagline{color:var(--muted);font-size:12px;letter-spacing:1px;text-transform:uppercase}.decks{flex:0 0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}.deck{background:var(--panel);padding:16px;display:flex;flex-direction:column;gap:12px;min-width:0}.deck-header{display:flex;align-items:baseline;gap:12px}.deck-id{font-weight:800;letter-spacing:1px;color:var(--accent)}.deck-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.deck-bpm{font-variant-numeric:tabular-nums;color:var(--muted)}.waveform{width:100%;height:110px;border-radius:6px;background:var(--panel);border:1px solid var(--line);cursor:pointer;display:block}.deck-time{font-variant-numeric:tabular-nums;font-size:13px;display:flex;gap:6px}.muted{color:var(--muted)}.deck-body{display:flex;gap:18px;align-items:center}.transport{display:flex;flex-direction:column;gap:8px}.btn{background:var(--panel-2);border:1px solid var(--btn-border, var(--line));color:var(--text);border-radius:6px;padding:10px 14px;font-size:15px;cursor:pointer;-webkit-user-select:none;user-select:none}.btn:hover{border-color:var(--accent)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.play{background:var(--accent);color:#06080c;font-weight:800}.btn.cue{color:var(--accent)}.btn.small{padding:6px 10px;font-size:12px}.eq-stack{display:flex;flex-direction:column;gap:10px}.knob{display:flex;align-items:center;gap:8px}.knob-dial{width:34px;height:34px;border-radius:50%;background:var(--panel);border:1px solid var(--line);position:relative;cursor:ns-resize;flex:none}.knob-pointer{position:absolute;left:50%;top:4px;width:2px;height:12px;background:var(--accent);transform-origin:50% 13px;border-radius:1px}.knob-label{width:28px;font-size:11px;color:var(--muted);letter-spacing:1px}.knob-value{width:26px;text-align:right;font-variant-numeric:tabular-nums;font-size:11px;color:var(--muted)}.pitch{display:flex;flex-direction:column;align-items:center;gap:8px;margin-left:auto}.pitch-fader{writing-mode:vertical-lr;direction:rtl;width:24px;height:120px;accent-color:var(--accent)}.pitch-label{font-variant-numeric:tabular-nums;font-size:12px;color:var(--muted)}.deck-load{display:flex;gap:8px;align-items:center;margin-top:auto}.yt-input{flex:1;background:var(--panel-2);border:1px solid var(--line);border-radius:6px;color:var(--text);padding:6px 10px;font-size:12px;min-width:0}.yt-input:focus{outline:none;border-color:var(--accent)}.deck-status{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.mixer{flex:0 0 auto;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--panel);padding:14px 20px;display:flex;justify-content:center}.crossfader{display:flex;align-items:center;gap:14px;width:min(560px,80%)}.sampler-strip{position:relative;display:flex;align-items:stretch;gap:4px;width:100%;margin:6px 0 2px}.smp-pad{flex:1 1 0;min-width:0;height:38px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:2px 3px;--smp-col: var(--smp-tint, var(--accent));border:1px solid color-mix(in srgb,var(--smp-col) 55%,var(--panel));border-radius:6px;background:var(--panel-2);color:var(--muted);cursor:pointer;overflow:hidden;transition:border-color .1s,background .1s,box-shadow .1s,color .1s}.smp-pad.smp-divide{margin-left:9px}.smp-pad.smp-master{--smp-col: var(--line);border-color:var(--line)}.smp-pad:not(:disabled):hover{border-color:var(--smp-col);color:var(--text)}.smp-pad:disabled{opacity:.3;border-color:var(--line);cursor:default}.smp-pad.empty{border-style:dashed}.smp-pad.set{color:var(--text);border-style:solid;border-color:color-mix(in srgb,var(--smp-col) 70%,var(--line));background:color-mix(in srgb,var(--smp-col) 12%,var(--panel-2))}.smp-pad.playing{box-shadow:0 0 12px color-mix(in srgb,var(--smp-col) 60%,transparent);border-color:var(--smp-col)}.smp-pad.drag-over{border-style:solid;border-color:var(--smp-col);background:color-mix(in srgb,var(--smp-col) 16%,var(--panel-2))}.smp-pad.uploading{animation:smp-pulse 1s ease-in-out infinite}@keyframes smp-pulse{50%{opacity:.55}}.smp-name{font-size:9.5px;font-weight:600;line-height:1.1;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.smp-mode{font-size:8px;opacity:.7}.smp-hint{font-size:11px;opacity:.7}.smp-error{position:absolute;top:100%;left:0;right:0;margin-top:4px;z-index:5;padding:6px 10px;font-size:11px;border-radius:6px;background:color-mix(in srgb,#c0334e 22%,var(--panel));border:1px solid #c0334e;color:var(--text);cursor:pointer}.smp-error-x{float:right;opacity:.7}.smp-menu .smp-modes{display:flex;gap:4px;padding:2px 4px 6px}.smp-menu .smp-modes button{flex:1;padding:5px 4px;font-size:11px;border:1px solid var(--line);border-radius:5px;background:var(--panel);color:var(--text);cursor:pointer}.smp-menu .smp-modes button.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,var(--panel))}.smp-menu .smp-gain{width:calc(100% - 16px);margin:2px 8px 8px;accent-color:var(--accent)}.crossfader input{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:22px;background:transparent;cursor:ew-resize}.crossfader input::-webkit-slider-runnable-track{height:5px;border-radius:999px;border:none;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-pink));box-shadow:0 0 8px color-mix(in srgb,var(--neon-cyan) 35%,transparent),0 0 8px color-mix(in srgb,var(--neon-pink) 35%,transparent)}.crossfader input::-moz-range-track{height:5px;border-radius:999px;border:none;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-pink))}.crossfader input::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:26px;margin-top:-10.5px;border-radius:3px;background:#fff;border:none;box-shadow:0 0 7px #ffffffd9,0 0 15px #fff6;cursor:ew-resize}.crossfader input::-moz-range-thumb{width:13px;height:26px;border-radius:3px;background:#fff;border:none;box-shadow:0 0 7px #ffffffd9,0 0 15px #fff6;cursor:ew-resize}.xf-end{font-weight:800;color:var(--accent, var(--muted))}.crossfader .xf-end:first-child{color:var(--neon-cyan);text-shadow:0 0 8px color-mix(in srgb,var(--neon-cyan) 60%,transparent)}.crossfader .xf-end:last-child{color:var(--neon-pink);text-shadow:0 0 8px color-mix(in srgb,var(--neon-pink) 60%,transparent)}.deck-artist{color:var(--muted);font-weight:400}.library{position:relative;flex:1 1 0;min-height:110px;overflow:hidden;display:flex;background:var(--bg);border-top:1px solid var(--line)}.lib-sidebar{width:var(--lib-side-w, 200px);flex:none;border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;padding:8px;gap:2px;overflow-y:auto}.lib-nav{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:none;color:var(--text);padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px}.lib-nav:hover{background:var(--panel-2)}.lib-nav.active{background:color-mix(in srgb,var(--accent, #36c2ff) 22%,transparent);color:#cfeaff}.lib-nav:focus{outline:none}.lib-nav:focus-visible{outline:2px solid var(--accent, #36c2ff);outline-offset:-2px}.lib-nav.small{font-size:12px;padding:6px 10px}.lib-nav-ico{font-size:13px;flex:none}.lib-pl-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-count{margin-left:auto;color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px}.lib-pl-src{margin-left:6px;color:var(--accent, #36c2ff);font-size:11px;opacity:.8}.lib-del{margin-left:6px;color:var(--muted);opacity:0;font-size:11px}.lib-nav:hover .lib-del{opacity:.7}.lib-del:hover{color:var(--text);opacity:1}.lib-section{display:flex;align-items:center;justify-content:space-between;margin:12px 6px 2px;font-size:10px;letter-spacing:1px;color:var(--muted)}.lib-section-toggle{flex:1 1 auto;display:flex;align-items:center;gap:5px;min-width:0;background:none;border:none;padding:2px 0;font:inherit;letter-spacing:inherit;color:inherit;cursor:pointer;text-align:left}.lib-section-toggle:hover{color:var(--text)}.lib-section-caret{font-size:8px;width:8px;flex:none}.lib-add{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:15px;line-height:1}.lib-add:hover{color:var(--text)}.lib-playlists{display:flex;flex-direction:column;gap:1px}.lib-import-msg{margin-top:auto;padding-top:10px;font-size:11px;color:var(--muted)}.lib-mine-msg{padding:4px 10px;font-size:11px;color:var(--muted)}.lib-mine-err{color:var(--neon-pink, #ff5c8a);word-break:break-word}.lib-shared{margin-top:2px}.lib-shared>summary{padding:4px 10px;font-size:11px;color:var(--muted);cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.lib-shared>summary::-webkit-details-marker{display:none}.lib-shared>summary:before{content:"▸ "}.lib-shared[open]>summary:before{content:"▾ "}.lib-shared-note{padding:2px 10px 6px;font-size:10.5px;line-height:1.4;color:var(--muted);opacity:.85}.lib-main{flex:1;min-width:0;overflow:auto;scrollbar-gutter:stable;display:flex;flex-direction:column;--tt-toolbar-h: 36px;container-type:inline-size}.lib-empty{padding:28px;color:var(--muted);font-size:13px}.lib-empty.error{color:#ff8a99}.explorer{display:flex;flex-direction:column;min-height:0}.search-bar{position:sticky;top:0;z-index:1;display:flex;gap:8px;padding:12px;background:var(--bg);border-bottom:1px solid var(--line)}.search-input{flex:1;background:var(--panel-2);border:1px solid var(--line);border-radius:6px;color:var(--text);padding:9px 12px;font-size:14px}.search-input:focus{outline:none;border-color:var(--accent, #36c2ff)}.result-list{display:flex;flex-direction:column}.result-row{display:grid;grid-template-columns:124px 1fr;gap:12px;align-items:center;padding:8px 12px;border-bottom:1px solid #1a1c24;cursor:pointer}.result-row:hover{background:var(--panel)}.thumb{position:relative;width:124px;height:70px;border-radius:5px;overflow:hidden;background:var(--panel);flex:none}.thumb img{width:100%;height:100%;object-fit:cover}.thumb-time{position:absolute;right:4px;bottom:4px;background:#000000d1;color:#fff;font-size:11px;font-variant-numeric:tabular-nums;padding:1px 4px;border-radius:3px}.result-meta{min-width:0}.result-title{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-sub{margin-top:3px;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-sub .dot{margin:0 6px}.result-actions{display:flex;gap:6px;flex:none}.mini{width:26px;height:26px;border-radius:5px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-size:12px;font-weight:700;cursor:pointer}.mini:hover{border-color:var(--text)}.mini:disabled{opacity:.5;cursor:default}.mini.a{color:var(--neon-cyan)}.mini.b{color:var(--neon-pink)}.mini.add{color:var(--neon-lime)}.mini.x:hover{color:#ff8a99;border-color:#ff8a99}.track-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.track-table thead th{position:sticky;top:var(--tt-toolbar-h, 30px);background:var(--panel);color:var(--muted);font-weight:600;text-align:left;font-size:11px;letter-spacing:.5px;padding:8px 10px;border-bottom:1px solid var(--line);z-index:1}.tt-toolbar{position:sticky;top:0;z-index:3;box-sizing:border-box;height:var(--tt-toolbar-h, 36px);display:flex;align-items:center;gap:8px;padding:0 10px;background:var(--bg);border-bottom:1px solid var(--line)}.tt-rows{flex:none;display:flex;align-items:center;gap:6px;margin-left:auto}.tt-filter{display:flex;align-items:center;gap:6px;flex:1 1 auto;min-width:0;height:26px;background:var(--panel-2);border:1px solid var(--line);border-radius:7px;padding:0 9px;transition:border-color .12s,box-shadow .12s}.tt-filter:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 22%,transparent)}.tt-filter-ico{font-size:11px;opacity:.6;flex:none}.tt-filter-input{flex:1;min-width:0;height:100%;background:transparent;border:none;color:var(--text);font-size:13px;padding:0}.tt-filter-input:focus{outline:none}.tt-filter-input::placeholder{color:var(--muted)}.tt-filter-input::-webkit-search-cancel-button{display:none}.tt-filter-clear{flex:none;background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:11px;line-height:1;padding:2px}.tt-filter-clear:hover{color:var(--text)}.tt-rows-label{flex:none}.tt-rows-label{font-size:10px;letter-spacing:.5px;color:var(--muted);margin-right:2px}.tt-step{width:22px;height:20px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--line);color:var(--text);border-radius:4px;cursor:pointer;font-size:13px;line-height:1}.tt-step:hover:not(:disabled){border-color:var(--accent)}.tt-step:disabled{opacity:.4;cursor:default}.tt-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.tt-sortable.sorted{color:var(--text)}.tt-th-label{display:inline-flex;align-items:center;gap:4px}.tt-caret{font-size:8px}.col-resize{position:absolute;top:0;right:0;width:9px;height:100%;cursor:col-resize;z-index:2;touch-action:none}.col-resize:after{content:"";position:absolute;top:0;bottom:0;right:0;width:2px;border-radius:2px;background:transparent;transition:background .12s}.col-resize:hover:after,.col-resize:active:after{background:color-mix(in srgb,var(--accent, #36c2ff) 70%,transparent)}.track-table th:not(:last-child),.track-table td:not(:last-child){border-right:1px solid var(--line)}.track-table tbody tr{border-bottom:1px solid #16181f;cursor:default}.track-table tbody tr:hover{background:var(--panel)}.track-table tbody tr.tt-spacer,.track-table tbody tr.tt-spacer:hover{border:0;background:transparent;cursor:default}.track-table tbody tr.tt-spacer td{padding:0;border:0}.track-table tbody tr.loaded{color:#6ee7a8}.track-table td{padding:var(--tt-row-pad, 7px) 10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-num{width:36px;color:var(--muted);font-variant-numeric:tabular-nums}.col-thumb{width:3.8em}.col-extra{width:84px}td.col-extra{text-align:right;overflow:hidden}td.col-extra .mixq-badge{max-width:100%;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.tt-search-btn{flex:0 0 auto;padding:3px 12px;font-size:12px}.tt-queue-label{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;color:var(--muted)}.track-table tr.reorder-over td{box-shadow:inset 0 2px 0 var(--accent)}.col-thumb img{width:100%;height:2.1em;object-fit:cover;border-radius:3px;display:block}td.col-thumb{text-align:center;padding:var(--tt-row-pad, 7px) 4px}th.col-thumb{position:relative}.col-title{width:auto}.cache-pips{display:inline-flex;gap:3px;align-items:center;vertical-align:middle;margin-right:6px}.cache-pips .pip{width:7px;height:7px;border-radius:50%;flex:0 0 auto}.cache-pips .pip-song{background:#3ddc84}.cache-pips .pip-stems{background:var(--accent, #36c2ff)}.col-artist{color:var(--muted)}.col-bpm,.col-key,.col-time{font-variant-numeric:tabular-nums;color:var(--muted)}.track-table tbody tr{cursor:pointer}.mini.plus{color:var(--neon-lime)}.track-table tbody tr.selected{background:#00e5ff1f}.track-table tbody tr.selected.loaded{background:#5dff9e24}.track-table tbody tr{-webkit-user-select:none;user-select:none}@container (max-width: 440px){.track-table .col-num,.track-table .col-thumb,.track-table .col-bpm,.track-table .col-key,.track-table .col-extra{display:none}.track-table .col-title{width:58%}.track-table .col-artist{width:30%}.track-table .col-resize,.tt-rows-label{display:none}}.lib-nav.drag-over{border-color:var(--neon-lime);background:#5dff9e24;box-shadow:inset 0 0 0 1px var(--neon-lime)}.ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60}.ctx-menu{position:fixed;z-index:61;min-width:190px;max-height:320px;overflow-y:auto;background:var(--panel-2);border:1px solid var(--accent);border-radius:8px;padding:4px;display:flex;flex-direction:column;gap:1px;box-shadow:0 10px 30px #000000b3}.ctx-menu>*{flex-shrink:0}.ctx-menu button{text-align:left;background:transparent;border:none;color:var(--text);font-size:13px;padding:8px 10px;border-radius:5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctx-menu button:hover{background:var(--panel-2)}.ctx-count{font-size:11px;color:var(--muted);padding:4px 10px 6px}.ctx-label{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:6px 10px 2px}.ctx-sep{height:1px;background:var(--line);margin:3px 0}.ctx-new{color:var(--neon-lime)!important}.ctx-danger{color:var(--neon-pink)!important}.dialog{width:min(400px,92vw);background:var(--panel);border:1px solid var(--accent);border-radius:12px;padding:20px;box-shadow:0 16px 50px #000000b3}.dialog-title{margin:0 0 12px;font-size:16px}.dialog-msg{margin:0 0 16px;font-size:13px;color:var(--muted);line-height:1.5}.dialog-input{width:100%;font-size:14px;padding:9px 11px;margin-bottom:16px}.dialog-actions{display:flex;justify-content:flex-end;gap:8px}.dialog-ok{background:var(--accent)!important;color:#06080c!important;border-color:var(--accent)!important;font-weight:700}.dialog-danger{background:var(--neon-pink)!important;color:#11030a!important;border-color:var(--neon-pink)!important;font-weight:700}@media(max-width:768px){html,body,#root{height:auto}.app{height:100dvh;min-height:0;overflow:hidden}.topbar{padding:12px 14px}.tagline{display:none}.decks{grid-template-columns:1fr}.deck{padding:14px;gap:10px}.waveform{height:88px}.btn.play,.btn.cue{padding:14px 18px;font-size:17px}.mini{width:34px;height:34px;font-size:13px}.knob-dial{width:40px;height:40px}.pitch-fader{height:140px;width:30px}.crossfader{width:100%}.library{flex-direction:row;min-height:0}.lib-sidebar{width:min(232px,70vw);flex:none}.lib-del{display:none}.lib-main{flex:1;min-width:0;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.tt-filter-input{font-size:16px}.sync-full{width:100vw;height:100dvh;max-height:none;border-radius:0;border:none;padding:14px}.sync-row{grid-template-columns:auto 1fr auto;grid-template-areas:"check src badge" "check dst change";gap:4px 8px;row-gap:2px}.sync-row>input[type=checkbox]{grid-area:check}.sync-src{grid-area:src}.sync-dst{grid-area:dst}.sync-badge{grid-area:badge;justify-self:end}.sync-change{grid-area:change;justify-self:end}.sync-arrow2{display:none}.sync-review-head{flex-wrap:wrap}.search-bar{position:static}.search-input,.yt-input{font-size:16px}.result-row{grid-template-columns:92px 1fr;gap:8px 10px}.thumb{width:92px;height:52px}}.btn.sync{background:var(--panel-2);color:var(--accent);font-weight:800;letter-spacing:1px;font-size:12px;padding:8px 12px}.btn.sync:hover{border-color:var(--accent)}.pads{display:flex;flex-direction:column;gap:8px}.hotcues{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));align-items:start;justify-items:center;gap:5px}.pad{position:relative;aspect-ratio:1 / 1;border:1px solid var(--btn-border, var(--line));background:var(--panel-2);color:var(--muted);border-radius:5px;font-size:13px;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.pad.set{background:color-mix(in srgb,var(--accent) 30%,var(--panel));border-color:var(--accent);color:#fff;box-shadow:inset 0 0 10px color-mix(in srgb,var(--accent) 35%,transparent)}.pad-clear{position:absolute;top:1px;right:3px;font-size:9px;color:#ffffffb3;line-height:1}.pad-clear:hover{color:#fff}.loops{display:flex;gap:5px}.loop-btn{flex:1;border:1px solid var(--btn-border, var(--line));background:var(--panel-2);color:var(--muted);border-radius:5px;padding:7px 0;font-size:12px;font-weight:700;cursor:pointer}.loop-btn:hover{border-color:var(--accent);color:var(--text)}.loop-btn.on{background:#6ee7a82e;border-color:#6ee7a8;color:#6ee7a8}.loop-btn.adjust{background:color-mix(in srgb,var(--shift) 22%,transparent);border-color:var(--shift);color:var(--shift);box-shadow:inset 0 0 9px color-mix(in srgb,var(--shift) 28%,transparent),0 0 8px color-mix(in srgb,var(--shift) 35%,transparent)}.loop-btn.toggle{flex:1.4;letter-spacing:1px}.loop-btn:disabled{opacity:.45;cursor:default}@media(max-width:768px){.pad,.loop-btn{font-size:12px}}.caption-bar{position:relative;flex:0 0 auto;height:19px;overflow:hidden;background:color-mix(in srgb,var(--surface) 80%,#000);border-top:1px solid var(--line)}.caption-bar:after{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;transform:translate(-50%);background:color-mix(in srgb,var(--accent) 45%,transparent);pointer-events:none}.caption-tools{position:absolute;right:4px;top:50%;transform:translateY(-50%);z-index:2;display:flex;align-items:center;gap:3px}.caption-source{font-size:10px;line-height:1;opacity:.5;pointer-events:none;background:color-mix(in srgb,var(--surface) 70%,#000);padding:1px 2px;border-radius:3px}.caption-reprocess{display:flex;gap:2px;opacity:0;transition:opacity .12s}.caption-bar:hover .caption-reprocess{opacity:1}.caption-redo{font-size:9px;line-height:1;padding:2px 4px;border-radius:3px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--surface) 80%,#000);color:var(--text);cursor:pointer;white-space:nowrap}.caption-redo:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 22%,var(--surface))}.caption-track{position:absolute;left:0;top:0;height:100%;will-change:transform}.caption-phrases,.caption-words{position:absolute;left:0;top:0;height:100%}.caption-word{position:absolute;top:0;height:100%;display:flex;align-items:center;gap:3px;margin:0;padding:0;border:0;background:none;font:inherit;font-size:11px;line-height:1;color:var(--text);cursor:pointer;white-space:nowrap;overflow:visible}.cw-tick{flex:0 0 auto;width:2px;align-self:stretch;margin:3px 0;border-radius:1px;background:color-mix(in srgb,var(--accent) 30%,transparent)}.cw-label{transition:color .1s}.cw-bar{position:absolute;left:0;bottom:1px;height:2px;width:0;border-radius:1px;background:color-mix(in srgb,var(--accent) 16%,transparent);pointer-events:none}.cw-fill{display:block;height:100%;width:0;border-radius:1px;background:var(--accent)}.caption-word.no-label .cw-label{display:none}.caption-word.cw-on .cw-tick{width:2px;background:var(--accent);box-shadow:0 0 6px color-mix(in srgb,var(--accent) 60%,transparent)}.caption-word.cw-on .cw-label{color:var(--accent);font-weight:700;text-shadow:0 0 8px color-mix(in srgb,var(--accent) 45%,transparent)}.caption-word.cw-on .cw-bar{background:color-mix(in srgb,var(--accent) 28%,transparent)}.caption-word.cw-on .cw-fill{box-shadow:0 0 6px color-mix(in srgb,var(--accent) 55%,transparent)}body.no-glow .caption-word.cw-on .cw-tick{box-shadow:none}body.no-glow .caption-word.cw-on .cw-label{text-shadow:none}.caption-phrase{position:absolute;top:0;height:100%;display:flex;align-items:center;margin:0;padding:0 4px;border:0;background:none;overflow:hidden;font:inherit;font-size:11px;line-height:1;color:var(--text);cursor:pointer}.cp-text{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.caption-track.has-words .caption-phrase:not(.on){display:none}.caption-phrase.on{z-index:5;max-width:none!important;overflow:visible;padding-right:7px;border-radius:4px;background:color-mix(in srgb,var(--surface) 80%,#000)}.caption-track:not(.has-words) .caption-phrase.on{color:var(--accent);font-weight:600}.caption-status{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:6;display:flex;align-items:center;gap:6px;max-width:80%;padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);background:color-mix(in srgb,var(--surface) 70%,#000);border:1px solid color-mix(in srgb,var(--accent) 50%,transparent);pointer-events:none}.caption-spin{flex:0 0 auto;width:9px;height:9px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--accent) 25%,transparent);border-top-color:var(--accent);animation:caption-spin .8s linear infinite}@keyframes caption-spin{to{transform:rotate(360deg)}}.wv-wrap{position:relative}.waveform{cursor:grab}.waveform:active{cursor:grabbing}.wv-zoom{position:absolute;bottom:5px;right:5px;display:flex;gap:4px;z-index:3}.wv-zoom button{width:24px;height:22px;border-radius:5px;border:1px solid var(--line);background:#08090d8c;color:var(--muted);font-size:15px;line-height:1;cursor:pointer}.wv-zoom button:hover{border-color:var(--accent);color:var(--text)}@media(max-width:768px){.wv-zoom{display:none}}.loops{flex-wrap:nowrap}.loop-btn{flex:1 1 auto;min-width:0}.loop-btn.armed{border-color:var(--shift);color:var(--shift)}.loop-sizes{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));align-items:start;justify-items:center;gap:5px}.loop-sizes .loop-btn{min-width:0;width:100%;max-width:64px;height:auto;aspect-ratio:1 / 1;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.deck-hint{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn.keylock{background:var(--panel-2);color:var(--muted);font-weight:800;letter-spacing:1px;font-size:12px;padding:8px 12px}.btn.keylock.on{background:color-mix(in srgb,var(--shift) 16%,transparent);border-color:var(--shift);color:var(--shift)}.jog{display:flex;gap:6px}.jog-btn{flex:1 1 0;min-width:0;height:34px;display:grid;place-items:center;border:1px solid var(--btn-border, var(--line));background:var(--panel-2);color:var(--muted);border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;transition:border-color .1s,background .1s,color .1s,transform .04s}.jog-btn:active{transform:translateY(1px);background:var(--panel)}.jog-btn:hover{border-color:var(--accent);color:var(--text)}.jog-btn.mag{letter-spacing:1px}.jog-btn.mag.on{background:color-mix(in srgb,var(--shift) 16%,transparent);border-color:var(--shift);color:var(--shift)}.jog-btn.mag.skip{font-size:11px;letter-spacing:0;overflow:hidden;white-space:nowrap}@media(max-width:768px){.jog-btn{padding:10px 0;font-size:13px}}.lanes{flex:1 1 0;min-height:140px;overflow:hidden;display:flex;flex-direction:column;gap:2px;background:var(--line)}.lane{position:relative;background:var(--surface);flex:1;min-height:0;display:flex;flex-direction:column}.lane.collapsed{display:none}.lanes .lane.drop-target:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:7;pointer-events:none;border:2px dashed var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);box-shadow:inset 0 0 24px color-mix(in srgb,var(--accent) 22%,transparent)}.lane.expanded{flex:1 1 0}.stem-busy{position:absolute;left:50%;bottom:34px;transform:translate(-50%);z-index:3;pointer-events:none;display:flex;align-items:center;gap:9px;padding:6px 13px;border-radius:999px;background:color-mix(in srgb,var(--bg) 80%,transparent);border:1px solid var(--accent);color:var(--text);font-size:12px;font-weight:700;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:stem-busy-pulse 1.5s ease-in-out infinite}.stem-busy.process{border-color:#ffd64a;box-shadow:0 0 16px color-mix(in srgb,#ffd64a 38%,transparent)}.stem-busy.fetch{border-color:#5dff9e;box-shadow:0 0 16px color-mix(in srgb,#5dff9e 38%,transparent)}.stem-busy-spin{width:13px;height:13px;border-radius:50%;border:2px solid color-mix(in srgb,currentColor 22%,transparent);animation:stem-busy-rot .8s linear infinite}.stem-busy.process .stem-busy-spin{color:#ffd64a;border-top-color:#ffd64a}.stem-busy.fetch .stem-busy-spin{color:#5dff9e;border-top-color:#5dff9e}.stem-busy-bar{width:84px;height:4px;border-radius:2px;background:color-mix(in srgb,var(--text) 16%,transparent);overflow:hidden}.stem-busy-bar>span{display:block;height:100%;transition:width .2s ease}.stem-busy.process .stem-busy-bar>span{background:#ffd64a}.stem-busy.fetch .stem-busy-bar>span{background:#5dff9e}@keyframes stem-busy-pulse{0%,to{opacity:.94}50%{opacity:.6}}@keyframes stem-busy-rot{to{transform:rotate(360deg)}}.lane.focused:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid color-mix(in srgb,var(--accent) 80%,transparent);box-shadow:inset 0 0 16px color-mix(in srgb,var(--accent) 26%,transparent);pointer-events:none;z-index:6}.lane .wv-wrap{flex:1;min-height:0;position:relative}.lane .waveform{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;border-radius:0;border:none}.lane-info{flex:0 0 auto;z-index:2;display:flex;align-items:center;gap:12px;padding:5px 12px;font-size:12px;pointer-events:none;background:var(--surface);border-bottom:1px solid var(--line)}.lane-id{font-weight:800;letter-spacing:1px;color:var(--accent);font-size:inherit;background:none;border:1px solid transparent;border-radius:5px;padding:1px 6px;cursor:pointer;pointer-events:auto;transition:background .1s,border-color .1s}.lane-id:hover{border-color:color-mix(in srgb,var(--accent) 45%,transparent)}.lane-id.on{background:color-mix(in srgb,var(--accent) 20%,transparent);border-color:var(--accent)}.lane-head{flex:1;min-width:0;display:flex;align-items:center;gap:12px}.lane-head.draggable{pointer-events:auto;cursor:grab}.lane-head.draggable:active{cursor:grabbing}.lane-drag{flex:none;pointer-events:auto;cursor:grab;color:var(--muted);font-size:13px;line-height:1;opacity:.55;transition:color .1s,opacity .1s}.lane-head.draggable:hover .lane-drag{opacity:1;color:var(--accent)}.lane-title{flex:1;min-width:0;overflow:hidden}.lane-title-inner{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}.lane-title.ticker .lane-title-inner{max-width:none;overflow:visible;text-overflow:clip;animation:lane-ticker var(--ticker-dur, 8s) linear infinite alternate}@keyframes lane-ticker{0%,12%{transform:translate(0)}88%,to{transform:translate(calc(-1 * var(--scroll, 0px)))}}.lane-id{white-space:nowrap}.lane-artist{color:var(--muted)}@media(max-width:768px){.lane-info{flex-wrap:wrap;row-gap:1px;column-gap:10px}.lane-head{flex-basis:100%}.lane-bpm{white-space:nowrap}}.lane-time{font-variant-numeric:tabular-nums}.lane-bpm{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent)}.lane-key{font-weight:700;font-size:11px;letter-spacing:.3px;color:var(--muted);white-space:nowrap}.lane-status{color:var(--shift);font-weight:600;letter-spacing:.02em}.lane-status.tone-fetch{color:#46e08a}.lane-status.tone-process{color:var(--shift)}.lane-status.tone-ok{color:#46e08a}.lane-status.tone-fail{color:#ff6b6b}.lane-status.tone-idle{color:var(--muted)}.lane-proc{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap;color:color-mix(in srgb,var(--accent) 80%,var(--text))}.lane-proc-dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--accent) 25%,transparent);border-top-color:var(--accent);animation:caption-spin .8s linear infinite}.lane-grid{pointer-events:auto;display:inline-flex;align-items:center;gap:4px}.grid-btn{width:18px;height:18px;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);border-radius:4px;color:var(--text);font-size:14px;line-height:1;cursor:pointer}.grid-btn:hover{border-color:var(--accent)}.grid-val{min-width:50px;text-align:center;color:var(--muted);font-weight:700;font-size:11px;font-variant-numeric:tabular-nums}.board{flex:0 0 auto;overflow:visible;display:flex;align-items:stretch;gap:1px;background:var(--line);border-top:1px solid var(--line)}.bank{flex:1;display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--panel);border-top:2px solid color-mix(in srgb,var(--accent) 55%,transparent);min-width:0;--btn-border: color-mix(in srgb, var(--accent) 55%, var(--panel))}.bank.mirror{flex-direction:row-reverse}.bank.focused{border-top-color:var(--accent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 45%,transparent),inset 0 0 22px color-mix(in srgb,var(--accent) 12%,transparent)}.decks-row .bank:not(.focused){opacity:.86}.decks-row .bank.expanded{flex:1 1 100%}.decks-row .bank.collapsed{display:none}.jog-btn,.loop-btn,.hw-btn,.stem-btn{position:relative}.kbd{position:absolute;right:3px;bottom:2px;font:700 8px/1 ui-monospace,monospace;color:var(--muted);opacity:.55;pointer-events:none;display:none}@media(min-width:769px){body.show-keys .kbd{display:block}}.bank-main{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.mixer-center{flex:0 0 auto;display:flex;flex-direction:column;gap:8px;padding:6px 14px 8px;background:var(--panel-2);border-top:2px solid var(--neon-purple)}.decks-row{flex:0 1 auto;min-height:0;display:flex;gap:1px;background:var(--line)}.decks-row .bank{align-items:stretch;overflow:hidden}.decks-row .bank-main{justify-content:flex-start}.decks-row .bank-main>.eq-row{flex:0 1 auto;min-height:0}.mix-row{flex:0 0 auto;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:10px 14px;background:var(--panel-2);border-top:1px solid var(--line);overflow-y:auto;--fader-h: clamp(140px, 21vh, 250px);--fader-sm: clamp(78px, 12vh, 138px);--fader-half: clamp(58px, 8.5vh, 100px)}.mixer-box{display:flex;flex-direction:column;align-items:stretch;gap:12px;width:100%}.mix-row .channels{flex:0 0 auto;width:100%}.mixer-box .crossfader{width:100%}@media(max-width:768px){html,body,#root{height:100dvh;overflow:hidden}.app{height:100dvh;min-height:0;overflow:hidden}.stage .lanes{flex:1 1 0;min-height:140px;overflow:hidden}.stage .decks-third{flex:0 1 auto;min-height:0}.stage .decks-row{flex:1 1 auto;min-height:0;overflow:hidden}.stage .decks-row .bank{align-items:stretch;overflow:hidden;padding:5px 8px;gap:8px}.stage .decks-row .bank-main{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;min-height:0}.decks-row .bank-main{gap:3px;justify-content:flex-start}.decks-row .bank-main>*{flex:0 0 auto;min-height:0}}.decks-third{flex:0 1 auto;min-height:0;display:flex;flex-direction:column}.xfader-bar{flex:0 0 auto;display:flex;align-items:center;padding:5px 0 0;background:var(--panel);border-bottom:1px solid var(--line)}.xbar-track{position:relative;flex:1;height:30px;background:color-mix(in srgb,var(--text) 6%,var(--bg));border-top:1px solid var(--line);overflow:hidden}.xbip{position:absolute;top:3px;right:3px;bottom:3px;left:3px;pointer-events:none}.xbip .smeter{position:absolute;inset:auto;top:0;bottom:0;width:50%}.xbip .smeter.xb-a{left:0}.xbip .smeter.xb-b{right:0}.xbip .smeter.xb-a .smeter-fill{right:0;left:auto}.xbip .smeter.xb-b .smeter-fill{left:0;right:auto}.xbar-track:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;transform:translate(-50%);background:color-mix(in srgb,var(--text) 32%,transparent);pointer-events:none}.xbar-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;z-index:2;cursor:ew-resize}.xbar-input::-webkit-slider-runnable-track{height:100%;background:transparent}.xbar-input::-moz-range-track{background:transparent}.xbar-input::-webkit-slider-thumb{-webkit-appearance:none;width:38px;height:24px;border-radius:4px;background:color-mix(in srgb,var(--xa, #fff),var(--xb, #fff) var(--xpct, 50%));border:1px solid color-mix(in srgb,#fff 35%,transparent);box-shadow:0 0 6px color-mix(in srgb,color-mix(in srgb,var(--xa, #fff),var(--xb, #fff) var(--xpct, 50%)) 75%,transparent);cursor:ew-resize}.xbar-input::-moz-range-thumb{width:38px;height:24px;border-radius:4px;background:color-mix(in srgb,var(--xa, #fff),var(--xb, #fff) var(--xpct, 50%));border:1px solid color-mix(in srgb,#fff 35%,transparent);box-shadow:0 0 6px color-mix(in srgb,color-mix(in srgb,var(--xa, #fff),var(--xb, #fff) var(--xpct, 50%)) 75%,transparent);cursor:ew-resize}.smeter{position:absolute;top:4px;right:3px;bottom:4px;left:3px;display:flex;gap:2px;z-index:0}.smeter.h{flex-direction:column}.smeter-bar{position:relative;flex:1;border-radius:2px;background:color-mix(in srgb,var(--accent) 11%,var(--bg));overflow:hidden}.smeter-fill{position:absolute;background:var(--accent);box-shadow:0 0 6px color-mix(in srgb,var(--accent) 55%,transparent)}.smeter.v .smeter-fill{left:0;right:0;height:0%}.smeter.v.up .smeter-fill{bottom:0}.smeter.v.down .smeter-fill{top:0}.smeter.h .smeter-fill{top:0;bottom:0;left:0;width:0%}.smeter-fill.hot{background:#ff5d5d;box-shadow:0 0 6px #ff5d5d}.lfader{display:flex;align-items:center;width:100%}.lfader.mirror{transform:scaleX(-1)}.lfader-track{position:relative;flex:1;height:26px;border-radius:6px;background:color-mix(in srgb,var(--accent) 6%,var(--bg));border:1px solid color-mix(in srgb,var(--accent) 18%,transparent)}.lfader-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;z-index:2;cursor:ew-resize}.lfader-input::-webkit-slider-runnable-track{height:100%;background:transparent}.lfader-input::-moz-range-track{background:transparent}.lfader-input::-webkit-slider-thumb{-webkit-appearance:none;width:38px;height:20px;border-radius:4px;background:var(--accent);border:1px solid color-mix(in srgb,#fff 35%,transparent);box-shadow:0 0 6px color-mix(in srgb,var(--accent) 75%,transparent);cursor:ew-resize}.lfader-input::-moz-range-thumb{width:38px;height:20px;border-radius:4px;background:var(--accent);border:1px solid color-mix(in srgb,#fff 35%,transparent);box-shadow:0 0 6px color-mix(in srgb,var(--accent) 75%,transparent);cursor:ew-resize}.lfader-val{position:absolute;top:50%;width:38px;height:20px;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:3;font-size:14px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.3px;color:var(--text);text-shadow:0 1px 3px color-mix(in srgb,var(--bg) 92%,transparent),0 0 2px var(--bg);white-space:nowrap}.lfader.mirror .lfader-val span{display:inline-block;transform:scaleX(-1)}.xbar-val{height:24px}.chin{flex:0 0 auto;display:flex;gap:1px;background:var(--line);border-bottom:1px solid var(--line);z-index:45}.chin-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--panel);border:none;color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.3px;padding:11px 4px;cursor:pointer;touch-action:manipulation;transition:color .12s,background .12s}.chin-btn:hover{color:var(--text)}.chin-btn.active{color:var(--text);background:var(--panel-2)}.chin-ico{font-size:17px;line-height:1}.chin-btn.chin-info{flex:0 0 auto;width:42px}.chin-info-i{display:grid;place-items:center;width:18px;height:18px;border:1.5px solid currentColor;border-radius:50%;font-size:11px;font-weight:800;font-style:italic;font-family:Georgia,Times New Roman,serif;line-height:1}.chin-gear{display:block;font-size:17px;line-height:1}.chin-btn.chin-settings{flex:0 0 auto;width:42px}.chin-btn.chin-settings .chin-label{display:none}:root{--dock-w: clamp(280px, 28vw, 520px)}@media(min-width:769px){.workspace{flex-direction:row;position:relative}.modal-backdrop.dock-left,.modal-backdrop.dock-right{position:relative;inset:auto;z-index:auto;flex:0 0 auto;min-height:0;padding:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none}.modal-backdrop.dock-left{flex-basis:var(--dock-w-left, var(--dock-w));max-width:min(var(--dock-w-left, var(--dock-w)),calc(100vw - 160px));min-width:0}.modal-backdrop.dock-right{flex-basis:var(--dock-w-right, var(--dock-w));max-width:min(var(--dock-w-right, var(--dock-w)),calc(100vw - 160px));min-width:0}.modal-backdrop.dock-left{order:-1}.modal-backdrop.dock-right,.app.dock-swapped .modal-backdrop.dock-left{order:1}.app.dock-swapped .modal-backdrop.dock-right{order:-1}.modal-backdrop.dock-left>.panel,.modal-backdrop.dock-right>.panel{width:100%;min-width:0;height:100%;max-height:none;border-radius:0;border-top:none;border-bottom:none;box-shadow:none}.modal-backdrop.dock-left>.panel{animation:dock-in-left .16s ease-out}.modal-backdrop.dock-right>.panel{animation:dock-in-right .16s ease-out}.lib-panel .settings-head .mini.x,.search-panel .settings-head .mini.x{display:none}.dock-resizer{z-index:6;touch-action:none}.dock-resizer-edge{position:absolute;top:0;bottom:0;width:9px;cursor:col-resize}.modal-backdrop.dock-left .dock-resizer-edge{right:-3px;left:auto}.modal-backdrop.dock-right .dock-resizer-edge{left:-3px;right:auto}.app.dock-swapped .modal-backdrop.dock-left .dock-resizer-edge{right:auto;left:-3px}.app.dock-swapped .modal-backdrop.dock-right .dock-resizer-edge{left:auto;right:-3px}.app.dock-swapped .modal-backdrop.dock-left .library{flex-direction:row-reverse}.app.dock-swapped .modal-backdrop.dock-left .lib-sidebar{border-right:none;border-left:1px solid var(--line)}.app.dock-swapped .modal-backdrop.dock-left .lib-burger{order:1;margin-right:0;margin-left:8px}.dock-resizer-edge:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translate(-50%);background:transparent;transition:background .12s}.dock-resizer-edge:hover:after{background:var(--accent, #36c2ff)}.dock-resizer-inline{flex:0 0 5px;align-self:stretch;cursor:col-resize;background:transparent;transition:background .12s}.dock-resizer-inline:hover{background:var(--accent, #36c2ff)}}@media(min-width:769px)and (max-width:980px){.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .stage{display:none}.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .modal-backdrop.dock-left,.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .modal-backdrop.dock-right{flex:1 1 50%;min-width:0}.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .dock-resizer-edge{display:none}}@media(min-width:981px)and (max-width:1366px)and (pointer:coarse){.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .stage{flex:1 1 50%;min-width:0}.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .modal-backdrop.dock-left,.workspace:has(.modal-backdrop.dock-left):has(.modal-backdrop.dock-right) .modal-backdrop.dock-right{flex:1 1 25%;min-width:0}}@media(min-width:769px)and (pointer:coarse){.result-row{grid-template-columns:92px 1fr;gap:10px;padding:7px 10px}.thumb{width:92px;height:52px}.result-title{font-size:13px}.decks-row .bank-main{gap:4px}.hw-btn{padding:6px 8px}.jog-btn{height:28px}.loops .loop-btn{padding:5px 0}.loop-sizes,.hotcues{gap:4px}.loop-sizes .loop-btn,.hotcues .pad{max-width:48px}.pitch-row,.stems-row{gap:4px}.vcell{height:34px}.fx-strip{--fx-body-h: 100px}.eq-curve{min-height:48px}.fx-delay .fx-knobs{grid-auto-rows:minmax(20px,28px);gap:6px 7px;padding-bottom:4px}.fx-foot{gap:3px}.fx-chip{padding:4px 3px;font-size:8.5px}.eq-tool{padding:3px 2px}}@media(max-width:768px){.dock-resizer{display:none}}.chin-btn.chin-swap{display:none}.chin-swap-i{font-size:16px;line-height:1}@media(min-width:769px){.chin-btn.chin-swap{display:flex;flex:0 0 auto;width:42px}.app.dock-swapped .chin{flex-direction:row-reverse}}@keyframes dock-in-left{0%{opacity:.4;transform:translate(-12px)}to{transform:none}}@keyframes dock-in-right{0%{opacity:.4;transform:translate(12px)}to{transform:none}}.lib-panel .library{flex:1;min-height:0;border-top:none;margin:0}.channels{display:flex;gap:18px;justify-content:center;align-items:center}.chan{flex:1 1 0;min-width:0;max-width:460px;display:flex;flex-direction:column;align-items:center;gap:3px}.chan-id{font-weight:800;color:var(--accent);font-size:12px;text-shadow:0 0 8px color-mix(in srgb,var(--accent) 60%,transparent)}.chan-grid{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:5px}.cbank{position:relative;width:100%;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:5px}.mixer-btns{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.chan-pitch{display:flex;flex-direction:column;align-items:center;gap:5px}.tempo-width.mini{width:32px;padding:2px 1px;font-size:9px;letter-spacing:0}.tempo-width.mini.ph{opacity:.4;cursor:default;pointer-events:none}.tempo-width{background:var(--panel);border:1px solid var(--line);color:var(--muted);border-radius:6px;width:96px;box-sizing:border-box;text-align:center;padding:4px;font-size:11px;font-weight:700;letter-spacing:.5px;font-variant-numeric:tabular-nums;cursor:pointer;white-space:nowrap;overflow:hidden}.tempo-width:hover{border-color:var(--neon-cyan);color:var(--text);box-shadow:0 0 8px color-mix(in srgb,var(--neon-cyan) 35%,transparent)}.mixer-foot{display:flex;flex-direction:column;align-items:center;gap:6px}.hw-btn{background:var(--panel);border:1px solid var(--btn-border, var(--line));color:var(--text);border-radius:6px;padding:9px 8px;font-size:13px;font-weight:700;letter-spacing:.5px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;transition:border-color .12s,box-shadow .12s,color .12s}.hw-btn:hover{border-color:var(--accent);color:#fff;box-shadow:0 0 10px color-mix(in srgb,var(--accent) 45%,transparent)}.hw-btn:active{transform:translateY(1px)}.hw-btn.play{background:var(--accent);border-color:var(--accent);color:#06080c;font-size:16px;box-shadow:none}.hw-btn.play:hover{color:#06080c;box-shadow:0 0 20px color-mix(in srgb,var(--accent) 80%,transparent)}.hw-btn.cue{color:var(--accent)}.hw-btn.sync,.hw-btn.key,.hw-btn.fx,.hw-btn.range{font-size:12px;letter-spacing:1px}.hw-btn.key,.hw-btn.fx{color:var(--muted)}.hw-btn.key.on{background:color-mix(in srgb,var(--shift) 18%,transparent);border-color:var(--shift);color:var(--shift)}.hw-btn.fx.on{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,var(--line))}.hw-btn.fx{overflow:visible}.hw-btn.fx .fx-label,.hw-btn.fx .kbd{position:relative;z-index:1}.hw-btn.range{color:var(--accent);font-variant-numeric:tabular-nums}.fx-wrap{position:relative;display:flex}.fx-wrap .hw-btn{flex:1}.fx-menu-catch{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.fx-menu{position:absolute;bottom:calc(100% + 5px);left:0;right:0;z-index:41;display:flex;flex-direction:column;gap:2px;padding:3px;background:var(--panel-2);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));border-radius:7px;box-shadow:0 8px 24px #0000008c}.fx-menu-item{background:transparent;border:none;border-radius:5px;color:var(--text);font-size:12px;font-weight:700;letter-spacing:.5px;padding:7px 8px;cursor:pointer;text-align:center}.fx-menu-item:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}.fx-menu-item.on{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.hw-btn.shift{font-size:12px;letter-spacing:2px;color:var(--muted);font-weight:800}.hw-btn.shift.on{background:color-mix(in srgb,var(--shift) 20%,transparent);border-color:var(--shift);color:var(--shift);box-shadow:0 0 22px color-mix(in srgb,var(--shift) 60%,transparent),0 0 7px color-mix(in srgb,var(--shift) 75%,transparent),inset 0 0 11px color-mix(in srgb,var(--shift) 24%,transparent);text-shadow:0 0 9px color-mix(in srgb,var(--shift) 75%,transparent)}body.no-glow .hw-btn.shift.on{box-shadow:0 0 6px color-mix(in srgb,var(--shift) 25%,transparent);text-shadow:none}.bank.shifted .jog-btn{border-color:color-mix(in srgb,var(--shift) 45%,var(--line));color:var(--shift)}.bank.adjusting .jog-btn{border-color:var(--shift);color:var(--shift);box-shadow:inset 0 0 9px color-mix(in srgb,var(--shift) 22%,transparent)}.bank.shifted .loop-sizes .loop-btn:not(.on){border-color:color-mix(in srgb,#36c2ff 65%,var(--line));color:#36c2ff;box-shadow:inset 0 0 9px color-mix(in srgb,#36c2ff 20%,transparent)}.bank.shifted .loop-sizes .loop-btn:not(.on):hover{background:color-mix(in srgb,#36c2ff 16%,transparent)}.bank.shifted .hotcues .pad:not(.set){border-color:color-mix(in srgb,#6ee7a8 65%,var(--line));color:#6ee7a8;box-shadow:inset 0 0 9px color-mix(in srgb,#6ee7a8 20%,transparent)}.bank.shifted .pitch-step,.bank.shifted .loops .loop-btn:not(.adjust):not(.armed):not(.on):not(:disabled){border-color:color-mix(in srgb,var(--shift) 55%,var(--line));color:var(--shift);box-shadow:inset 0 0 9px color-mix(in srgb,var(--shift) 18%,transparent)}.bank.shifted .pitch-step:hover,.bank.shifted .loops .loop-btn:not(.adjust):not(.armed):not(.on):not(:disabled):hover{background:color-mix(in srgb,var(--shift) 16%,transparent)}.hw-btn.small{padding:8px 12px;font-size:12px}.transport{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.transport>*{min-width:0}.bank-load{display:flex;gap:6px}.bank-load .hw-btn,.bank-load .skip-btn,.bank-load .vcell{flex:1;width:auto}.bank-load .vcell.play .vcell-value{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap}.bank-load .vcell.play.playing{background:color-mix(in srgb,var(--accent) 16%,var(--bg));box-shadow:inset 0 0 0 1px var(--accent),0 0 12px color-mix(in srgb,var(--accent) 60%,transparent)}.bank-load .vcell.play.playing .vcell-value{color:var(--accent)}.bank-load .vcell.cue-fader .vcell-value{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap}.bank-load .vcell.cue-fader.cue-on{background:color-mix(in srgb,var(--accent) 14%,var(--bg));box-shadow:inset 0 0 0 1px var(--accent),0 0 10px color-mix(in srgb,var(--accent) 50%,transparent)}.bank-load .vcell.cue-fader.cue-on .vcell-value{color:var(--accent)}.knob-dial{width:38px;height:38px;position:relative;background:var(--panel);box-shadow:0 0 0 1px var(--line);border:none}.chan .knob-dial{width:26px;height:26px}.chan{gap:3px}.knob-ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;width:calc(100% + 6px);height:calc(100% + 6px);fill:none}.knob-ring-track{stroke:#1d1d2b;stroke-width:3;stroke-linecap:round}.knob-ring-fill{stroke-width:3;stroke-linecap:round;filter:drop-shadow(0 0 3px var(--accent))}.knob-pointer{position:absolute;left:50%;top:5px;width:2px;height:11px;margin-left:-1px;border-radius:1px;background:var(--accent);transform-origin:50% 14px;box-shadow:0 0 5px var(--accent)}.chan .knob{flex-direction:column;gap:0}.chan .knob-label{width:auto;text-align:center;font-size:8px;line-height:1.1}.chan .knob-value{display:block;width:auto;text-align:center;font-size:8px;line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}.vcell{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-width:44px;height:38px;padding:3px 5px;background:color-mix(in srgb,var(--accent) 6%,var(--bg));border:1px solid transparent;border-radius:6px;cursor:ns-resize;outline:none;-webkit-user-select:none;user-select:none;touch-action:none;transition:box-shadow .1s}.vcell:hover .vcell-knob-track{stroke:color-mix(in srgb,var(--accent) 36%,transparent)}.vcell:focus .vcell-knob-track{stroke:var(--accent)}.vcell:focus{box-shadow:inset 0 0 0 1px var(--accent),0 0 10px color-mix(in srgb,var(--accent) 45%,transparent)}.vcell.off{opacity:.4}.vcell.disabled{opacity:.3;cursor:default}.vcell.muted{opacity:.5}.vcell.muted .vcell-value,.vcell.muted .vcell-knob{filter:grayscale(1) brightness(.8)}.vcell-knob{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none}.vcell-knob-track{fill:none;stroke:color-mix(in srgb,var(--accent) 16%,transparent);stroke-width:2}.vcell-knob-fill{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;filter:drop-shadow(0 0 2px color-mix(in srgb,var(--accent) 70%,transparent))}.vcell-knob-dot{fill:var(--accent);stroke:#06080c;stroke-width:1;filter:drop-shadow(0 0 3px var(--accent))}.vcell-label{font-size:8px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);line-height:1}.vcell-value{font-size:13px;font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent);line-height:1.1;white-space:nowrap}.hotcues{grid-template-columns:repeat(8,minmax(0,1fr));align-items:start;justify-items:center}.pad{background:var(--panel);border:1px solid var(--btn-border, var(--line));color:var(--muted);transition:border-color .12s,box-shadow .12s,color .12s}.bank .pad:hover{border-color:var(--accent);color:var(--text)}.hotcues .pad:nth-child(1).set{background:#ff5d73;color:#06080c;box-shadow:0 0 10px #ff5d73}.hotcues .pad:nth-child(2).set{background:#ffb13c;color:#06080c;box-shadow:0 0 10px #ffb13c}.hotcues .pad:nth-child(3).set{background:#ffe24a;color:#06080c;box-shadow:0 0 10px #ffe24a}.hotcues .pad:nth-child(4).set{background:#6ee7a8;color:#06080c;box-shadow:0 0 10px #6ee7a8}.hotcues .pad:nth-child(5).set{background:#36c2ff;color:#06080c;box-shadow:0 0 10px #36c2ff}.hotcues .pad:nth-child(6).set{background:#7b9cff;color:#06080c;box-shadow:0 0 10px #7b9cff}.hotcues .pad:nth-child(7).set{background:#c77bff;color:#06080c;box-shadow:0 0 10px #c77bff}.hotcues .pad:nth-child(8).set{background:#ff7bd0;color:#06080c;box-shadow:0 0 10px #ff7bd0}.crossfader{width:100%;max-width:260px;margin:0 auto}@media(max-width:768px){.tagline{display:none}.board{gap:1px}.bank,.bank.mirror{padding:6px 5px;gap:5px}.bank-main{gap:4px}.hw-btn{padding:6px 1px;font-size:10px;letter-spacing:0}.transport{grid-template-columns:repeat(4,minmax(0,1fr));gap:3px}.jog{gap:2px}.jog-btn{padding:4px 0;font-size:10px}.hotcues{grid-template-columns:repeat(8,minmax(0,1fr));gap:3px}.bank .pad{font-size:10px}.loops{gap:3px}.loop-sep{display:none}.loop-btn{min-width:20px;padding:4px 0;font-size:10px}.fader-label,.fader-value{font-size:8px}.mixer-center{padding:8px 8px 10px;gap:8px;justify-content:center}.channels{gap:10px}.chan{gap:5px}.chan-id{font-size:12px}.chan-row{gap:4px;align-items:center}.chan-knobs{gap:5px}.chan .knob-dial,.knob-dial{width:20px;height:20px}.chan-stems .knob-dial{width:18px;height:18px}.chan-stems{gap:3px}.chan-stems .knob-label{font-size:6.5px}.chan-row .fader-label{display:none}.chan-row .fader-value{font-size:7px;min-width:16px}.chan-keyshift{gap:1px}.chan-keyshift .key-name{font-size:6.5px;white-space:nowrap}.chan-keyshift .key-step{width:18px;height:16px;font-size:11px;padding:0}.chan .knob-label{font-size:7.5px;line-height:1;letter-spacing:0;white-space:nowrap}.chan .knob-value{font-size:7px}.chan-row .fader.pitch .fader-track,.chan-row .fader.level .fader-track,.chan-row .fader.filter .fader-track,.chan-row .fader.keyfader .fader-track{height:132px;width:12px}.chan-row .fader-thumb{width:15px}.crossfader.vertical .xf-rot{height:132px}.crossfader.vertical .xf-rot input{width:132px}.channels{gap:6px}.mixer-center .knob-ring-fill{filter:none}.mixer-center .knob-pointer,.mixer-center .fader-fill,.mixer-center .fader-thumb,.mixer-center .fader-thumb:after{box-shadow:none}.mixer-center .chan-id{text-shadow:none}.crossfader{max-width:none;gap:8px}.xf-end{font-size:11px}.tempo-width{padding:3px 8px;font-size:11px}.chin-btn{padding:9px 2px;font-size:12px;gap:5px}.chin-ico{font-size:16px}}@media(max-width:380px){.chin-label{display:none}}.bank .pad{aspect-ratio:1 / 1;height:auto;width:100%;max-width:64px;min-width:0}@media(max-width:768px){.bank .pad{font-size:11px}}.bank-main{justify-content:center}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.top-btn{background:var(--panel);border:1px solid var(--line);color:var(--text);border-radius:6px;padding:7px 12px;font-size:13px;cursor:pointer;touch-action:manipulation}.top-btn:hover{border-color:var(--neon-cyan);box-shadow:0 0 10px #00e5ff4d}.browse-toggle{display:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px;animation:backdrop-in .16s ease-out}@media(max-width:768px){.chin{position:relative;z-index:60}.modal-backdrop{top:36px}.modal-backdrop.dock-left,.modal-backdrop.dock-right{top:36px;right:0;bottom:0;left:0;padding:0;background:var(--bg);-webkit-backdrop-filter:none;backdrop-filter:none;align-items:stretch;justify-content:stretch}.modal-backdrop.dock-left>.panel,.modal-backdrop.dock-right>.panel{width:100%;height:100%;max-height:none;border:none;border-radius:0;box-shadow:none}}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.panel{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 20px 60px #0009;overflow:hidden;animation:panel-in .16s ease-out}@keyframes panel-in{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}.settings-panel{width:min(460px,94vw);max-height:50dvh;padding:16px 18px}.help-panel{width:min(540px,94vw);max-height:88dvh;padding:16px 18px}.help-intro{margin:6px 0 12px;font-size:12px;line-height:1.5;color:var(--muted)}.help-rows{display:flex;flex-direction:column;gap:2px;overflow-y:auto}.help-row{display:grid;grid-template-columns:132px 1fr;align-items:center;gap:12px;padding:6px 4px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent)}.help-keys{display:flex;flex-wrap:wrap;gap:4px}.help-desc{font-size:12px;color:var(--text)}.help-shift{color:var(--muted);font-size:11px}.kbd-chip{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 5px;border:1px solid color-mix(in srgb,var(--accent) 35%,var(--line));border-bottom-width:2px;border-radius:5px;background:var(--panel-2);color:var(--text);font:700 11px/1 ui-monospace,monospace}.keybinds{display:flex;flex-direction:column;gap:4px}.keybinds-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 2px 4px;font-size:10px;letter-spacing:.5px;color:var(--muted);text-transform:uppercase}.keybinds-col-label{font-size:10px}.keybinds-reset{background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:5px;padding:4px 9px;font-size:11px;cursor:pointer}.keybinds-reset:hover{border-color:var(--accent)}.bind-group-title{margin:10px 2px 2px;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--accent)}.bind-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:4px 2px;border-bottom:1px solid color-mix(in srgb,var(--line) 55%,transparent)}.bind-desc{font-size:12px;color:var(--text);min-width:0}.bind-shift{color:var(--muted);font-size:11px}.bind-chips{display:flex;gap:5px}.bind-chip{display:inline-flex;align-items:center;gap:4px;min-width:48px;height:26px;padding:0 7px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-bottom-width:2px;border-radius:6px;background:var(--panel-2);color:var(--text);font:700 11px/1 ui-monospace,monospace;cursor:pointer;justify-content:center}.bind-chip:hover{border-color:var(--accent)}.bind-chip.empty{color:var(--muted);border-style:dashed;background:transparent;font-weight:500}.bind-chip.capturing{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 10px -2px var(--accent);font-weight:600}.bind-clear{color:var(--muted);font-size:9px;line-height:1}.bind-clear:hover{color:var(--neon-pink, #ff5c8a)}.settings-tabs{display:flex;gap:4px;margin:8px 0 10px;border-bottom:1px solid var(--line)}.settings-tab{flex:1;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:8px 4px;font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer}.settings-tab:hover{color:var(--text)}.settings-tab.on{color:var(--text);border-bottom-color:var(--neon-purple)}.settings-body{flex:1;overflow-y:auto;margin:0 -18px;padding:0 18px;scrollbar-gutter:stable}.settings-info h3{margin:4px 0 8px;font-size:15px}.info-list{margin:8px 0;padding-left:18px;color:var(--muted);font-size:12px;display:flex;flex-direction:column;gap:4px}.policy{margin:10px 0;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:0 12px}.policy>summary{cursor:pointer;list-style:none;padding:11px 0;font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.policy>summary::-webkit-details-marker{display:none}.policy>summary:before{content:"▸";color:var(--muted);transition:transform .12s}.policy[open]>summary:before{transform:rotate(90deg)}.policy[open]>summary{border-bottom:1px solid var(--line);margin-bottom:8px}.policy .settings-hint{margin:8px 0}.about-faq-head{margin-top:18px!important}.info-links{display:flex;gap:16px;margin-top:14px}.info-links a{color:var(--neon-cyan);font-size:13px}.faq-item{padding:10px 0;border-top:1px solid var(--line)}.faq-item:first-child{border-top:none}.faq-q{font-weight:700;font-size:13px;margin-bottom:4px}.faq-a{margin:0;color:var(--muted);font-size:12px;line-height:1.5}.search-panel,.lib-panel{width:min(900px,96vw);height:min(86dvh,820px)}.search-panel{padding:14px 16px 0}.lib-panel{padding:0}.search-panel .explorer,.lib-main .explorer{flex:1;min-height:0}.search-panel .search-bar,.lib-main .search-bar{position:static;padding:0 0 12px;background:transparent;border-bottom:1px solid var(--line)}.search-panel .result-list{flex:1;overflow-y:auto;margin:0 -16px}.lib-main .result-list{flex:1;overflow-y:auto}.result-tools{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--line)}.result-filter{flex:1;min-width:0;background:var(--panel-2);border:1px solid var(--line);border-radius:6px;color:var(--text);padding:6px 10px;font-size:13px}.result-filter:focus{outline:none;border-color:var(--accent)}.result-sort{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.result-sort select{background:var(--panel-2);border:1px solid var(--line);border-radius:6px;color:var(--text);padding:5px 8px;font-size:12px;cursor:pointer}.result-count{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;text-align:right}.settings-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.search-panel .settings-head{justify-content:flex-end;margin-bottom:0}.lib-panel .settings-head{justify-content:space-between;margin-bottom:0;padding:10px 10px 9px;gap:8px}.lib-panel .settings-head .mini.x{display:none}.lib-head{display:flex;align-items:baseline;gap:8px;min-width:0;margin-right:auto}.lib-burger{flex:none;display:grid;place-items:center;width:30px;height:28px;margin-right:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:6px;color:var(--muted);font-size:15px;line-height:1;cursor:pointer}.lib-burger:hover{color:var(--text);border-color:var(--accent)}.lib-burger.on{color:var(--text);border-color:color-mix(in srgb,var(--accent) 55%,var(--line))}.lib-head-name{font-size:15px;font-weight:700;letter-spacing:.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-head-from{flex:none;font-size:11px;color:var(--muted);white-space:nowrap}.lib-head-toggle{align-items:center;background:none;border:none;padding:4px 8px 4px 6px;margin-left:-6px;border-radius:6px;cursor:pointer;text-align:left}.lib-head-toggle:hover{background:var(--panel-2)}.lib-head-caret{flex:none;font-size:10px;color:var(--muted);transition:color .12s}.lib-head-toggle:hover .lib-head-caret{color:var(--accent)}.tt-deck{display:inline-grid;place-items:center;min-width:1.35em;height:1.35em;padding:0 .25em;margin-right:5px;border-radius:4px;font-size:.78em;font-weight:800;line-height:1;color:#08121a;vertical-align:middle}.settings-head h2{margin:0;font-size:16px;letter-spacing:1px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--line)}.settings-label{font-size:13px;color:var(--text)}.slider-row .settings-slider,.settings-row .settings-slider{flex:1;max-width:160px;accent-color:var(--neon-cyan);cursor:pointer}.slider-hint{font-size:11px;color:var(--muted);margin-left:4px}.swatches{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}.swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;box-shadow:inset 0 0 0 1px #ffffff29;cursor:pointer;padding:0}.swatch.on{border-color:#fff;box-shadow:0 0 8px #ffffff80}.color-tab{display:flex;flex-direction:column;gap:16px}.color-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.color-intro-text{font-size:12px;line-height:1.5;color:var(--muted);max-width:60%}.color-rolls{display:flex;gap:6px;flex:none}.color-roll{background:var(--panel-2);border:1px solid var(--line);border-radius:7px;color:var(--text);font-size:12px;font-weight:700;padding:7px 11px;cursor:pointer;white-space:nowrap;transition:border-color .12s,transform .05s}.color-roll:hover{border-color:var(--accent)}.color-roll:active{transform:translateY(1px)}.color-group{display:flex;flex-direction:column;gap:10px;padding:13px;background:color-mix(in srgb,var(--panel) 55%,transparent);border:1px solid color-mix(in srgb,var(--line) 70%,transparent);border-radius:10px}.color-group-head{display:flex;flex-direction:column;gap:2px}.color-group-title{font-size:12px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--text)}.color-group-desc{font-size:11.5px;line-height:1.45;color:var(--muted)}.color-group .settings-row{padding:8px 0;border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent)}.color-group .settings-row:first-of-type{border-top:none}.color-targets{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:8px}.color-target{position:relative;overflow:hidden;display:flex;align-items:center;gap:9px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:10px 11px;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .12s,transform .05s}.color-target:hover{border-color:var(--text)}.color-target:active{transform:translateY(1px)}.color-target input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;border:none;padding:0;cursor:pointer}.color-target-dot{width:20px;height:20px;border-radius:5px;flex:none;box-shadow:inset 0 0 0 1px #ffffff4d}.color-random{font-size:13px}.color-warnings{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.color-warning{display:flex;align-items:flex-start;gap:7px;font-size:12px;line-height:1.4;color:#ffd76a;background:color-mix(in srgb,var(--shift) 8%,transparent);border-left:2px solid var(--shift);border-radius:4px;padding:7px 10px}.color-warning-ico{flex:0 0 auto}.color-ok{font-size:12px;color:var(--muted);margin-bottom:14px}.swatch.custom{position:relative;overflow:hidden;border:2px solid var(--line);display:grid;place-items:center}.swatch.custom input{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;opacity:0;cursor:pointer}.toggle{width:44px;height:24px;border-radius:12px;border:1px solid var(--line);background:var(--panel);position:relative;cursor:pointer;flex:none}.toggle.on{background:color-mix(in srgb,var(--neon-cyan) 35%,var(--panel));border-color:var(--neon-cyan)}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#d7dbe6;transition:left .12s}.toggle.on .toggle-knob{left:22px}.seg{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}.seg-btn{background:var(--panel);border:1px solid var(--line);color:var(--muted);border-radius:5px;padding:5px 9px;font-size:12px;cursor:pointer}.seg-btn.on{border-color:var(--neon-cyan);color:var(--neon-cyan)}.settings-section{padding:12px 0 2px;border-top:1px solid var(--line)}.settings-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.yt-status{margin-left:8px;font-size:11px;color:var(--muted)}.yt-status.on{color:var(--neon-lime)}.link-btn{background:none;border:none;color:var(--neon-cyan);font-size:12px;cursor:pointer;padding:0;text-decoration:underline}.settings-hint{margin:8px 0;font-size:12px;line-height:1.5;color:var(--muted)}.link-btn.danger{color:#ff5d73}.midi-learn-group{margin-top:10px}.midi-learn-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:6px 0 2px}.midi-learn-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:8px;padding:4px 0;font-size:13px;border-bottom:1px solid var(--line)}.midi-learn-row.learning{background:color-mix(in srgb,var(--shift) 18%,transparent)}.midi-learn-label{color:var(--text)}.midi-learn-addr{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted);min-width:44px;text-align:right}.midi-device-list{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px}.midi-device-chip{font-size:11px;padding:3px 8px;border:1px solid var(--line);border-radius:999px;color:var(--muted)}.midi-device-chip.on{color:#6ee7a8;border-color:#6ee7a8;background:color-mix(in srgb,#6ee7a8 14%,transparent)}.profilebar{display:flex;flex-direction:column;gap:4px}.profilebar-row{display:flex;align-items:center;gap:6px}.profilebar-select{flex:1;min-width:0;background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:13px}.profilebar-badge{flex:none;font-size:11px;color:var(--muted);white-space:nowrap}.profilebar-swatch{flex:none;width:40px;height:24px;border-radius:5px;border:1px solid var(--line)}.profilebar-tools{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.profilebar-note{margin:6px 0 0;font-size:12px;color:var(--neon-cyan)}.hw-btn.small.danger:not(:disabled){color:#ff5d73;border-color:color-mix(in srgb,#ff5d73 50%,var(--line))}.midi-subtabs{display:flex;gap:4px;margin:6px 0 4px}.midi-subtab{flex:1;background:var(--surface);color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:6px 0;font-size:12px;cursor:pointer}.midi-subtab.on{color:var(--text);border-color:var(--neon-cyan);background:color-mix(in srgb,var(--neon-cyan) 12%,transparent)}.midi-monitor{margin-top:6px;max-height:180px;overflow-y:auto;border:1px solid var(--line);border-radius:6px;background:var(--surface);font-family:ui-monospace,monospace;font-size:12px}.midi-monitor-empty{padding:10px;color:var(--muted)}.midi-monitor-row{display:flex;justify-content:space-between;gap:10px;padding:3px 8px;border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent)}.midi-monitor-row:first-child{color:var(--neon-cyan)}.midi-monitor-bytes{letter-spacing:.08em}.midi-monitor-map{flex:1;text-align:center;color:var(--neon-cyan)}.midi-monitor-meta{color:var(--muted)}.midi-dbg-row{display:flex;align-items:center;gap:8px;margin-top:8px}.midi-dbg-hex{flex:1;min-width:140px;padding:7px 9px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--text);font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.06em}.midi-dbg-out{margin-top:10px;max-height:120px}.midi-dbg-out .midi-monitor-row:first-child{color:var(--neon-magenta, #ff5db1)}.stem-quality,.stem-autoenhance{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.settings-sub{font-size:11px;font-variant-numeric:tabular-nums}.settings-select{width:100%;margin-top:8px;padding:8px 10px;background:var(--bg);border:1px solid var(--line);border-radius:6px;color:var(--text);font-size:13px;cursor:pointer}.settings-select:focus{outline:none;border-color:var(--neon-cyan)}.settings-hint strong{color:var(--text)}.yt-cookie{width:100%;resize:vertical;background:var(--bg);border:1px solid var(--line);border-radius:6px;color:var(--text);font-family:ui-monospace,monospace;font-size:11px;padding:8px 10px}.yt-cookie:focus{outline:none;border-color:var(--neon-cyan)}.yt-actions{display:flex;gap:8px;margin-top:8px}.privacy{margin-top:12px;padding:12px;background:var(--surface);border:1px solid var(--line);border-radius:8px;font-size:12px;line-height:1.55;color:var(--muted)}.privacy h3{margin:0 0 8px;font-size:13px;color:var(--text)}.privacy p{margin:0 0 8px}.privacy ul{margin:0;padding-left:16px}.privacy li{margin-bottom:6px}.privacy strong{color:var(--text)}.hw-btn.signin{width:100%;height:38px;font-size:13px;letter-spacing:.3px;background:var(--panel-2);border-color:var(--neon-cyan);color:var(--text)}.hw-btn.signin:hover{border-color:var(--neon-lime)}.yt-account{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}.yt-account-badge{font-size:13px;color:var(--neon-lime);font-weight:600}.acct-profile{display:flex;align-items:center;gap:10px;margin-top:8px}.acct-avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--line)}.acct-id{flex:1;min-width:0}.acct-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acct-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conn-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}.conn-row{display:flex;align-items:center;gap:8px}.conn-dot{width:8px;height:8px;border-radius:50%;background:#444;flex:0 0 auto}.conn-dot.on{background:var(--neon-lime);box-shadow:0 0 6px var(--neon-lime)}.conn-name{font-size:13px;font-weight:600}.conn-note{font-size:11px;color:var(--muted)}.conn-action{margin-left:auto}.sync-full{position:relative;width:min(900px,94vw);height:min(86vh,900px);background:var(--panel);border:1px solid var(--accent);border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;box-shadow:0 0 40px #0009}.sync-full .settings-head{padding:0;margin-bottom:14px}.sync-dir-chip{display:inline-block;font-size:11px;color:var(--muted);margin-left:10px;font-weight:600;letter-spacing:.02em;padding:2px 9px;border:1px solid var(--line);border-radius:999px;background:var(--panel-2);vertical-align:middle}.sync-body{display:flex;flex-direction:column;min-height:0;flex:1}.sync-center{align-items:center;justify-content:center;gap:12px;text-align:center}.sync-progress{width:min(420px,80%);height:8px;border-radius:4px;background:var(--surface);border:1px solid var(--line);overflow:hidden}.sync-progress-bar{height:100%;background:var(--accent);transition:width .2s ease}.sync-done-check{font-size:48px;color:var(--neon-lime);text-shadow:0 0 16px var(--neon-lime)}.sync-review-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 10px;font-size:13px;color:var(--muted)}.sync-write-prompt{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:0 0 10px;padding:8px 12px;border:1px solid var(--accent, #36c2ff);border-radius:8px;background:color-mix(in srgb,var(--accent, #36c2ff) 12%,transparent);font-size:13px}.sync-review{flex:1;overflow-y:auto;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.sync-row{display:grid;grid-template-columns:auto 1fr auto 1fr auto auto;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--line);transition:background .1s}.sync-row:hover{background:var(--panel-2)}.sync-row:last-child{border-bottom:none}.sync-row.skipped{opacity:.4}.sync-src,.sync-dst{min-width:0}.sync-tt{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-ar{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-arrow2{color:var(--accent)}.sync-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap}.sync-badge.c-high{color:#06140a;background:var(--neon-lime)}.sync-badge.c-medium{color:#161204;background:var(--neon-yellow)}.sync-badge.c-low{color:#1a0c04;background:#ff9d4a}.sync-badge.c-none{color:#fff;background:#c0334e}.sync-change{font-size:11px}.sync-alts{grid-column:1 / -1;display:flex;flex-direction:column;gap:2px;padding:6px 0 4px 34px}.sync-alt{display:flex;align-items:center;gap:8px;padding:5px 8px;border:1px solid transparent;border-radius:6px;background:var(--panel-2);color:var(--text);text-align:left;font-size:12px;cursor:pointer}.sync-alt.active{border-color:var(--accent)}.sync-alt img{width:28px;height:28px;border-radius:4px;object-fit:cover}.sync-alt em{color:var(--muted);font-style:normal}.sync-research{display:flex;gap:6px;margin-bottom:4px}.sync-research .yt-input{flex:1}.sync-route{display:flex;align-items:stretch;gap:10px;margin:2px 0 12px}.sync-route-end{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;padding:9px 11px;background:var(--panel-2);border:1px solid var(--line);border-radius:9px}.sync-route-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.sync-select{width:100%;background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:13px;font-weight:600;cursor:pointer}.sync-select:focus{outline:none;border-color:var(--accent)}.sync-select-static{display:flex;align-items:center;padding:6px 8px;font-size:13px;font-weight:700;color:var(--text)}.sync-route-arrow{align-self:center;flex:none;color:var(--accent);font-weight:800;font-size:16px}.sync-picker{flex:1;min-height:0;overflow-y:auto;border:1px solid var(--line);border-radius:10px;padding:6px;display:flex;flex-direction:column;gap:2px;background:var(--surface)}.sync-pl{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:transparent;border:1px solid transparent;color:var(--text);text-align:left;cursor:pointer;transition:background .1s,border-color .1s}.sync-pl:hover{background:var(--panel-2)}.sync-pl.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--panel-2))}.sync-pl-thumb,.sync-pl-ico{flex:0 0 auto;width:34px;height:34px;border-radius:6px;object-fit:cover}.sync-pl-ico{display:grid;place-items:center;font-size:16px;background:var(--panel-2);border:1px solid var(--line)}.sync-pl.active .sync-pl-ico{border-color:color-mix(in srgb,var(--accent) 50%,var(--line))}.sync-pl-name{flex:1;min-width:0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-pl-count{flex:0 0 auto;font-size:11px;font-variant-numeric:tabular-nums;color:var(--muted);padding:1px 8px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line)}.sync-pl-tag{flex:0 0 auto;font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:999px;color:var(--muted);border:1px solid var(--line)}.sync-run{display:flex;gap:8px;margin-top:12px;flex:none}.sync-name{flex:1;height:38px}.sync-go{flex:0 0 auto;height:38px;padding:0 18px;font-size:13px;font-weight:700;letter-spacing:.3px;color:#061018;background:var(--accent);border:1px solid var(--accent);border-radius:8px;cursor:pointer;white-space:nowrap;transition:filter .12s,box-shadow .12s}.sync-go:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 14px color-mix(in srgb,var(--accent) 45%,transparent)}.sync-go:active:not(:disabled){transform:translateY(1px)}.sync-go:disabled{opacity:.45;cursor:default}.sync-report{margin-top:12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.sync-report-head{font-size:13px}.sync-report-head a{color:var(--neon-cyan)}.sync-trunc{color:var(--muted)}.sync-unmatched{margin-top:8px;font-size:12px;color:var(--muted)}.sync-unmatched summary{cursor:pointer}.sync-unmatched ul{margin:6px 0 0;padding-left:18px;max-height:140px;overflow-y:auto}.signin-box{margin-top:10px;padding:14px;background:var(--surface);border:1px solid var(--line);border-radius:8px;text-align:center}.signin-step{margin:0 0 6px;font-size:12px;color:var(--muted);text-align:left}.signin-step a{color:var(--neon-cyan)}.device-code{margin:8px auto 10px;font-family:ui-monospace,monospace;font-size:26px;font-weight:700;letter-spacing:4px;color:var(--text);background:var(--bg);border:1px solid var(--neon-cyan);border-radius:8px;padding:10px 14px;-webkit-user-select:all;user-select:all}.signin-wait{margin:0 0 10px;font-size:12px;color:var(--neon-amber, var(--muted))}.signin-err{margin:8px 0 0;font-size:12px;color:var(--neon-pink, #ff5c8a)}.yt-sub{margin-top:12px;padding-top:10px;border-top:1px dashed var(--line)}.yt-sub:first-of-type{border-top:none;padding-top:4px}.yt-sub-head{font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}.yt-sub-note{font-weight:400;color:var(--muted);margin-left:6px}.src-list{display:flex;flex-direction:column;gap:6px}.src-opt{display:flex;align-items:center;gap:10px;text-align:left;padding:9px 12px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);cursor:pointer;transition:border-color .12s,background .12s}.src-opt:hover:not(:disabled){background:var(--panel-2)}.src-opt.on{border-color:var(--accent-a, var(--text));background:var(--panel-2)}.src-opt:disabled{opacity:.5;cursor:not-allowed}.src-ico{font-size:18px;line-height:1}.src-main{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.src-label{font-size:13px;font-weight:600}.src-reason{font-size:11px;color:var(--muted)}.src-mark{font-size:12px;color:var(--accent-a, var(--text))}.yt-steps{margin:6px 0 8px;padding-left:18px;font-size:12px;line-height:1.6;color:var(--muted)}.yt-steps strong{color:var(--text)}.cookie-msg{margin-top:8px;color:var(--neon-lime)}body:not(.no-glow) .bank,body:not(.no-glow) .lane,body:not(.no-glow) .chan,body:not(.no-glow) .mixer-box,body:not(.no-glow) .lane-info,body:not(.no-glow) .decks-third,body:not(.no-glow) .topbar{box-shadow:0 0 14px color-mix(in srgb,var(--accent) 9%,transparent)}body:not(.no-glow) .jog-btn,body:not(.no-glow) .loop-btn,body:not(.no-glow) .pad,body:not(.no-glow) .pitch-step,body:not(.no-glow) .grid-btn,body:not(.no-glow) .stem-btn{box-shadow:0 0 6px color-mix(in srgb,var(--accent) 13%,transparent)}body:not(.no-glow) .bank.shifted .jog-btn,body:not(.no-glow) .bank.shifted .pitch-step,body:not(.no-glow) .bank.adjusting .jog-btn{box-shadow:0 0 8px color-mix(in srgb,var(--shift) 22%,transparent)}body.no-glow .logo,body.no-glow .chan-id,body.no-glow .xf-end,body.no-glow .lane-id,body.no-glow .lane-bpm{text-shadow:none}body.no-glow .hw-btn.play,body.no-glow .hw-btn:hover,body.no-glow .fader-thumb,body.no-glow .fader-thumb:after,body.no-glow .fader-fill,body.no-glow .knob-pointer,body.no-glow .pad.set,body.no-glow .hotcues .pad.set,body.no-glow .top-btn:hover{box-shadow:none}body.no-glow .knob-ring-fill{filter:none}body.no-glow .bank.focused{box-shadow:inset 0 0 0 1px var(--accent)}body.no-glow .lane.focused:after{box-shadow:none}@media(min-width:769px)and (max-width:1099px){.bank{gap:6px;padding:10px 8px}.bank-main{gap:5px}.pitch-step{padding:5px 2px;font-size:12px}}.pitch-row,.stems-row{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:6px;align-items:stretch}.stem-mode-btn{width:100%;padding:5px 8px;margin-bottom:6px;font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--text-dim);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;cursor:pointer}.stem-mode-btn.on{color:#061018;background:var(--accent);border-color:var(--accent)}.stem-mode-btn:disabled{opacity:.55;cursor:default}.pitch-row>*,.stems-row>*{min-width:0}.stems-row.stems-pending{display:flex;align-items:center;justify-content:center;gap:8px;min-height:50px;border:1px dashed color-mix(in srgb,var(--accent) 40%,transparent);border-radius:6px;background:color-mix(in srgb,var(--accent) 5%,var(--bg));color:var(--muted);font-size:12px;letter-spacing:.5px}.stems-pending-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:stem-pending-pulse 1s ease-in-out infinite}@keyframes stem-pending-pulse{0%,to{opacity:.3}50%{opacity:1}}.eq-row{display:flex;flex-direction:column;min-height:0}.eq-pro{display:flex;flex-direction:column;gap:5px;flex:0 1 auto;height:var(--fx-body-h, 178px);min-height:0;overflow:hidden}.eq-pro.bypassed .eq-curve{opacity:.6}.eq-tools{display:flex;gap:5px;align-items:stretch}.eq-tool{flex:1 1 0;padding:4px 2px;font-size:9.5px;font-weight:800;letter-spacing:.06em;color:var(--tool, var(--accent));background:color-mix(in srgb,var(--tool, var(--accent)) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--tool, var(--accent)) 55%,var(--panel));border-radius:6px;cursor:pointer;text-shadow:0 0 7px color-mix(in srgb,var(--tool, var(--accent)) 65%,transparent);transition:color .12s,border-color .12s,background .12s,box-shadow .12s}body:not(.no-glow) .eq-tool{box-shadow:0 0 9px -2px color-mix(in srgb,var(--tool, var(--accent)) 60%,transparent),inset 0 0 8px color-mix(in srgb,var(--tool, var(--accent)) 15%,transparent)}.eq-tool:hover{color:#fff;border-color:var(--tool, var(--accent));background:color-mix(in srgb,var(--tool, var(--accent)) 26%,var(--surface))}body:not(.no-glow) .eq-tool:hover{box-shadow:0 0 16px color-mix(in srgb,var(--tool, var(--accent)) 80%,transparent),inset 0 0 12px color-mix(in srgb,var(--tool, var(--accent)) 24%,transparent)}.eq-tool.on{color:#08111a;background:var(--tool, var(--accent));border-color:var(--tool, var(--accent));text-shadow:none}body:not(.no-glow) .eq-tool.on{box-shadow:0 0 20px color-mix(in srgb,var(--tool, var(--accent)) 90%,transparent)}.fx-strip{display:flex;flex-direction:column;gap:5px;flex:1;min-height:0;--fx-body-h: 192px}.fx-tabs{display:flex;gap:4px;align-items:stretch;flex:0 0 auto}.fx-tab{padding:3px 9px;font-size:9.5px;font-weight:800;letter-spacing:.06em;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 40%,var(--panel));border-radius:6px;cursor:pointer;transition:color .12s,border-color .12s,background .12s,box-shadow .12s}.fx-tab:hover{color:#fff;border-color:var(--accent);background:color-mix(in srgb,var(--accent) 22%,var(--surface))}.fx-tab.sel{color:#08111a;background:var(--accent);border-color:var(--accent)}body:not(.no-glow) .fx-tab.sel{box-shadow:0 0 16px -2px color-mix(in srgb,var(--accent) 80%,transparent)}.fx-tab.bypassed{opacity:.5;text-decoration:line-through}.fx-tab[draggable]{cursor:grab}.fx-tab.dragging{opacity:.4}.fx-tab.drag-over{border-left:3px solid var(--accent);box-shadow:-2px 0 8px -2px color-mix(in srgb,var(--accent) 80%,transparent)}.fx-tab.fx-add,.fx-tab.fx-remove{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:3px 0;font-size:14px;line-height:1}.fx-add-wrap{position:relative;margin-left:auto;display:flex;gap:4px}.fx-palette{position:absolute;top:calc(100% + 4px);right:0;z-index:20;display:flex;flex-direction:column;gap:2px;padding:4px;background:var(--panel-2);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));border-radius:7px;box-shadow:0 8px 24px -8px #000000b3;min-width:110px}.fx-palette-item{padding:6px 10px;font-size:11px;font-weight:700;text-align:left;color:var(--text);background:transparent;border:0;border-radius:5px;cursor:pointer}.fx-palette-item:hover{color:#08111a;background:var(--accent)}.fx-tab.fx-remove{color:#ff5470;border-color:color-mix(in srgb,#ff5470 50%,var(--panel))}body:not(.no-glow) .fx-tab.fx-remove{box-shadow:0 0 9px -3px color-mix(in srgb,#ff5470 55%,transparent)}.fx-tab.fx-remove:hover{color:#fff;background:#ff5470;border-color:#ff5470}.fx-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.fx-preset-menu{position:fixed;top:auto;right:auto;z-index:41;max-height:240px;overflow-y:auto}.fx-preset-head{padding:3px 10px 5px;font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in srgb,var(--text) 55%,transparent)}.fx-preset-sep{height:1px;margin:3px 4px;background:color-mix(in srgb,var(--accent) 30%,transparent)}.fx-preset-save{color:var(--accent)}.fx-preset-row{display:flex;align-items:stretch;gap:2px}.fx-preset-row .fx-preset-apply{flex:1 1 auto;min-width:0}.fx-preset-mini{flex:0 0 auto;width:22px;border:0;border-radius:5px;background:transparent;color:color-mix(in srgb,var(--text) 55%,transparent);cursor:pointer;font-size:11px;line-height:1}.fx-preset-mini:hover{color:#08111a;background:var(--accent)}.fx-preset-mini.danger:hover{color:#fff;background:#ff5470}.fx-stage{display:flex;flex-direction:column;flex:1;min-height:0}.fx-panel{display:flex;flex-direction:column;gap:5px;flex:0 1 auto;height:var(--fx-body-h, 178px);min-height:0;overflow:hidden}.dly-viz{flex:1 1 0;min-height:0;position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--surface) 80%,#000 8%)}.dly-viz canvas{display:block;width:100%;height:100%}.rv-body{display:flex;flex:1 1 0;min-height:0;gap:8px}.rv-viz{flex:1 1 0;height:100%;min-width:0;position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--surface) 80%,#000 8%);cursor:pointer}.rv-viz canvas{display:block;width:100%;height:100%}.fx-knobs{flex:0 0 auto;overflow:hidden;display:grid;grid-template-columns:repeat(auto-fit,minmax(52px,1fr));grid-auto-rows:40px;justify-content:center;gap:8px 10px}.fx-delay .fx-knobs{flex:0 1 auto;min-height:0;grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:minmax(22px,34px);column-gap:7px;padding-bottom:7px}.fx-reverb .rv-knobs{flex:0 0 auto;width:clamp(58px,24%,92px);min-width:0;min-height:0;height:100%;grid-template-columns:1fr;grid-auto-rows:minmax(28px,1fr);row-gap:8px;padding-bottom:7px}.fx-chip.fx-chip-mode{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,var(--panel));font-weight:800}.fx-knobs .vcell{height:100%;min-height:0;min-width:0;max-width:none}.eq-row .fx-knobs .vcell{height:100%}.fx-foot{display:flex;flex-wrap:nowrap;gap:4px;align-items:stretch;flex:0 0 auto}.fx-chip{flex:1 1 0;min-width:0;overflow:hidden;text-overflow:clip;padding:5px;font-size:9px;font-weight:800;letter-spacing:.06em;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 45%,var(--panel));border-radius:6px;cursor:pointer;white-space:nowrap;transition:color .12s,border-color .12s,background .12s,box-shadow .12s}.fx-chip:hover{color:#fff;border-color:var(--accent)}.fx-chip.on{color:#08111a;background:var(--accent);border-color:var(--accent)}body:not(.no-glow) .fx-chip.on{box-shadow:0 0 14px -2px color-mix(in srgb,var(--accent) 80%,transparent)}.fx-chip.fx-remove{flex:0 0 auto;color:var(--muted);border-color:var(--line)}.fx-chip.fx-remove:hover{color:#fff;border-color:#e0556a;background:color-mix(in srgb,#e0556a 22%,var(--surface))}.fx-unknown{align-items:center;justify-content:center;color:var(--muted);font-size:12px}.eq-readout{position:absolute;top:4px;transform:translate(-50%);padding:1px 6px;font-size:9.5px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text);background:color-mix(in srgb,#000 55%,transparent);border-radius:5px;pointer-events:none;white-space:nowrap;transition:opacity .1s;z-index:3}.eq-curve{position:relative;flex:1 1 0;min-height:48px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--surface) 80%,#000 8%);touch-action:none}.eq-curve-canvas{position:absolute;top:0;right:0;bottom:0;left:0;display:block}.eq-subrow{flex:0 0 auto;display:flex;align-items:stretch;gap:7px;min-height:0;height:38px;margin-bottom:6px}.eq-subrow .vcell{flex:1 1 0;min-width:0}.eq-row .eq-subrow .vcell{height:100%}.eq-subrow-band{flex:0 0 auto;display:flex;align-items:center;padding:0 9px;font-size:9px;font-weight:800;letter-spacing:.04em;border-radius:6px;color:var(--band);border:1px solid color-mix(in srgb,var(--band) 50%,transparent);background:color-mix(in srgb,var(--band) 14%,transparent)}.eq-node.selected{box-shadow:0 0 0 2px color-mix(in srgb,var(--node) 70%,#fff 30%),0 0 10px var(--node)}.eq-shape-btn{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-width:50px;padding:0 8px;border-radius:7px;border:1px solid var(--line);background:color-mix(in srgb,var(--surface) 70%,#000 10%);color:var(--text);cursor:pointer;font-variant-numeric:tabular-nums}.eq-shape-btn:hover{border-color:color-mix(in srgb,var(--accent) 60%,var(--line))}.eq-shape-cap{font-size:7.5px;font-weight:700;letter-spacing:.06em;opacity:.55}.eq-shape-val{font-size:10px;font-weight:800;color:var(--accent)}.eq-node{position:absolute;width:24px;height:24px;margin:0;padding:0;transform:translate(-50%,-50%);border-radius:50%;border:2px solid var(--node);background:color-mix(in srgb,var(--node) 35%,#000 40%);box-shadow:0 0 8px color-mix(in srgb,var(--node) 60%,transparent),inset 0 0 4px color-mix(in srgb,var(--node) 50%,transparent);cursor:grab;touch-action:none;z-index:2}.eq-node:hover{background:var(--node)}.eq-node:active{cursor:grabbing}.eq-node.cut{border-radius:6px;width:22px;height:22px}@media(min-width:769px){.pitch-row .vcell,.stems-row .vcell,.eq-row .vcell{height:50px}}.bank-main>.lfader{order:-2}.bank-main>.bank-load{order:-1}.pitch-step{display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 16%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 42%,var(--panel));border-radius:6px;color:var(--accent);font-size:16px;font-weight:700;line-height:1;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.pitch-step:hover{background:color-mix(in srgb,var(--accent) 24%,transparent);border-color:var(--accent);color:var(--text)}.pitch-step:active{transform:translateY(1px)}.stem-btn{padding:6px 4px;font-size:11px;font-weight:700;letter-spacing:.04em;color:#8a94a6;background:#161a22;border:1px solid #2a3140;border-radius:6px;cursor:pointer;transition:color .12s,background .12s,box-shadow .12s,border-color .12s}.stem-btn:hover:not(:disabled){border-color:var(--accent, #36d1ff)}.stem-btn.on{color:#0a0d12;background:var(--accent, #36d1ff);border-color:var(--accent, #36d1ff);box-shadow:0 0 10px -2px var(--accent, #36d1ff)}.stem-btn:disabled{opacity:.4;cursor:default}body.no-glow .stem-btn.on{box-shadow:none}.stem-models{display:flex;flex-direction:column;gap:8px}.stem-model{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;text-align:left;background:var(--surface, #12141c);border:1px solid var(--line, #2a3140);border-radius:8px;cursor:pointer;transition:border-color .12s,background .12s}.stem-model:hover{border-color:var(--neon-cyan, #36d1ff)}.stem-model.on{border-color:var(--neon-cyan, #36d1ff);box-shadow:inset 0 0 0 1px var(--neon-cyan, #36d1ff)}.stem-model-label{font-weight:700;font-size:13px;color:var(--text, #ecedfb);display:flex;align-items:center;flex-wrap:wrap;gap:6px}.stem-model-note{font-size:11px;color:var(--muted, #8a94a6)}.stem-badge{font-size:9.5px;font-weight:700;letter-spacing:.2px;text-transform:uppercase;padding:2px 6px;border-radius:999px;border:1px solid currentColor;white-space:nowrap}.stem-badge.ok{color:#6ee7a8}.stem-badge.warn{color:#ffcf6e}.stem-badge.cached{color:#06080c;background:#6ee7a8;border-color:#6ee7a8}.stem-status-row{display:flex;align-items:baseline;gap:8px;padding:6px 0;font-size:12.5px;line-height:1.35}.stem-status-row+.stem-status-row{border-top:1px solid var(--border-color, rgba(255, 255, 255, .08))}.stem-status-deck{flex:0 0 auto;width:18px;height:18px;display:grid;place-items:center;border-radius:5px;font-size:10px;font-weight:800;background:#ffffff14;color:var(--text-color, #e8edf4)}.stem-status-detail{flex:1 1 auto}.stem-reanalyze{width:100%;margin-top:10px;padding:9px 12px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.stem-reanalyze:hover:not(:disabled){border-color:var(--neon-cyan, #00e5ff)}.stem-reanalyze:disabled{opacity:.4;cursor:default}.stem-trace{max-height:180px;overflow:auto;margin:6px 0 0;padding:8px 10px;background:var(--surface);border:1px solid var(--line);border-radius:6px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;line-height:1.45;white-space:pre;color:var(--muted);-webkit-overflow-scrolling:touch}.debug-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-top:6px}.debug-block{background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:7px 9px}.debug-block-title{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--accent);margin-bottom:4px}.debug-row{display:flex;justify-content:space-between;gap:10px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;line-height:1.5}.debug-key{color:var(--muted);white-space:nowrap}.debug-val{color:var(--text);text-align:right;word-break:break-word;overflow-wrap:anywhere}.stem-device{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12px}.stem-device-tag{flex:0 0 auto;font-size:10px;font-weight:800;letter-spacing:.6px;padding:3px 8px;border-radius:999px;border:1px solid currentColor}.stem-device-text{flex:1 1 auto;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stem-device.gpu .stem-device-tag{color:#7cc7ff}.stem-device.cpu .stem-device-tag{color:#6ee7a8}.stem-device.none .stem-device-tag{color:#ffcf6e}.stem-blocked-banner{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:12px;border-radius:8px;font-size:12.5px;line-height:1.4;color:#ffcf6e;background:#ffcf6e1a;border:1px solid rgba(255,207,110,.35)}.stem-blocked-banner .link-btn{flex:0 0 auto;white-space:nowrap}.stem-mobile-note{margin-bottom:12px;padding:9px 11px;border-radius:8px;font-size:12px;line-height:1.45;color:var(--muted, #9aa);background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.stem-mobile-note strong{color:var(--text, #e8e8ea);font-weight:600}.stem-model.blocked{opacity:.45;cursor:not-allowed}.stem-model.blocked:hover{background:inherit}.stem-model.untested:not(.on){opacity:.72}.stem-status-row.separating .stem-status-detail{color:var(--shift)}.stem-status-row.cached .stem-status-detail,.stem-status-row.downloading .stem-status-detail,.stem-status-row.ready .stem-status-detail,.stem-status-row.promoted .stem-status-detail{color:#6ee7a8}.stem-status-row.failed .stem-status-detail{color:#ff7a7a}.stem-status-row.unavailable .stem-status-detail{color:#ffcf6e}@media(max-width:1080px){.mixer-box{width:100%;max-width:100%}.mix-row .channels{flex:1 1 auto;width:100%;gap:6px;align-items:stretch}.channels .chan{flex:1 1 0;min-width:0;align-items:flex-start;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.channels .chan:not(.mirror){direction:rtl}.channels .chan:not(.mirror) .chan-row{direction:ltr}.channels .crossfader.vertical{flex:0 0 auto;align-self:center}.channels .chan::-webkit-scrollbar{display:none}}.room{position:relative;display:flex;flex:0 0 auto;order:10}.chin-room{position:relative;flex:0 0 auto;width:42px}.chin-room-i{font-size:17px;line-height:1;transition:color .12s,text-shadow .12s}.chin-room-i.online{color:#38e08a;text-shadow:0 0 7px #38e08a}.chin-room-i.connecting{color:#f5c451;animation:room-pulse 1s ease-in-out infinite}.chin-room-i.error{color:#ff5a6a}@keyframes room-pulse{50%{opacity:.4}}.room-count{position:absolute;top:5px;right:5px;min-width:14px;height:14px;padding:0 3px;border-radius:7px;background:var(--accent);color:#08111a;font-size:9px;font-weight:800;display:grid;place-items:center;line-height:1}.room-catch{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.room-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:41;width:280px;padding:12px;border-radius:12px;background:color-mix(in srgb,var(--surface) 92%,#000);border:1px solid var(--line);box-shadow:0 12px 40px #00000080;display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--text)}.room-head{display:flex;align-items:center;justify-content:space-between}.room-title{font-weight:700;letter-spacing:.3px}.room-switch{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);cursor:pointer}.room-hint{margin:0;font-size:12px;line-height:1.5;color:var(--muted)}.room-tap-hint{margin:0 0 2px}.room-pills{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.room-pill{width:100%;display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;background:color-mix(in srgb,var(--text) 6%,transparent);border:1px solid var(--line);color:var(--text);cursor:pointer;text-align:left;transition:background .12s,border-color .12s}.room-pill:hover:not(:disabled){border-color:color-mix(in srgb,var(--accent) 50%,var(--line))}.room-pill.out{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:var(--accent)}.room-pill-row{display:flex;align-items:center;gap:6px}.room-pill-row .room-pill{flex:1 1 auto}.room-pill.tied:not(.out){box-shadow:inset 3px 0 color-mix(in srgb,var(--accent) 60%,transparent)}.room-leave{flex:0 0 auto;width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:transparent;border:1px solid var(--line);color:var(--muted);cursor:pointer;font-size:12px}.room-leave:hover{color:#ff8a96;border-color:#ff8a96}.room-pill-ico{flex:0 0 auto;font-size:16px;line-height:1}.room-pill-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.room-pill-tag{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--muted)}.room-pill.out .room-pill-tag{color:var(--accent)}.room-status{font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}.room-status.ok{color:#38e08a}.room-status.wait{color:#f5c451}.room-err{font-size:12px;color:#ff8a96}.room-warn{font-size:12px;line-height:1.45;color:#ffcf6b;background:color-mix(in srgb,#ffcf6b 12%,transparent);border:1px solid color-mix(in srgb,#ffcf6b 30%,transparent);border-radius:8px;padding:7px 9px}.room-note{font-size:12px;line-height:1.45;color:var(--muted);text-align:center;padding:2px 4px}.room-note strong{color:var(--text)}.room-peer-ico{flex:0 0 auto;font-size:14px;line-height:1}.room-peers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.room-peer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:8px;background:color-mix(in srgb,var(--text) 5%,transparent)}.room-peer.master{background:color-mix(in srgb,var(--accent) 16%,transparent)}.room-peer.empty{color:var(--muted);justify-content:center}.room-peer-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-you{color:var(--muted);font-size:11px}.room-badge{flex:0 0 auto;font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--accent)}.room-act{flex:0 0 auto;font-size:11px;padding:3px 8px;border-radius:6px;background:transparent;border:1px solid var(--line);color:var(--text);cursor:pointer}.room-actions{display:flex}.room-btn{flex:1;padding:9px 12px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--text);font-weight:600;cursor:pointer}.room-btn.primary{background:var(--accent);border-color:var(--accent);color:#08111a}.room-btn:disabled{opacity:.4;cursor:default}.room-sesh{display:flex;flex-direction:column;gap:3px}.room-sesh-head{display:flex;align-items:center;justify-content:space-between}.room-sesh-title{font-weight:700;letter-spacing:.3px}.room-sesh-sub{margin:0;font-size:12px;line-height:1.45;color:var(--muted)}.room-status.idle{color:var(--muted)}.room-status.warn{color:#ffcf6b}.room-sesh-tools{display:inline-flex;align-items:center;gap:8px}.room-eye{flex:0 0 auto;display:grid;place-items:center;background:transparent;border:none;padding:0 2px;font-size:13px;line-height:1;cursor:pointer;opacity:.6;transition:opacity .12s}.room-eye:hover,.room-eye.on{opacity:1}.acct-avatar.private{filter:blur(7px)}.room-link{display:flex;flex-direction:column;gap:0}.room-dev{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;background:color-mix(in srgb,var(--text) 6%,transparent);border:1px solid var(--line)}.room-dev.output{background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent)}.room-dev-ico{flex:0 0 auto;font-size:18px;line-height:1}.room-dev-meta{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:1px}.room-dev-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-dev-you{color:var(--muted);font-size:11px;font-weight:400}.room-dev-role{font-size:11px;font-weight:600;letter-spacing:.2px;color:var(--muted)}.room-dev.output .room-dev-role{color:color-mix(in srgb,var(--accent) 80%,var(--text))}.room-dev-tag{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--accent)}.room-dev-act{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.2px;padding:6px 11px;border-radius:7px;background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--accent);cursor:pointer;transition:background .12s}.room-dev-act:hover{background:color-mix(in srgb,var(--accent) 26%,transparent)}.room-link-bridge{display:flex;align-items:center;gap:8px;padding:5px 2px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}.room-link-bridge:before,.room-link-bridge:after{content:"";flex:1;height:1px;background:var(--line)}.room-link-bridge.linked{color:var(--accent)}.room-link-bridge.linked:before,.room-link-bridge.linked:after{background:color-mix(in srgb,var(--accent) 40%,transparent)}.bridge-glyph{font-size:12px;line-height:1}.room-ghost{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;border:1px dashed var(--line);color:var(--muted);font-size:12px;line-height:1.4}.room-unlink{width:100%;padding:8px;border-radius:8px;background:transparent;border:1px solid var(--line);color:var(--muted);font-weight:600;font-size:12px;cursor:pointer;transition:color .12s,border-color .12s}.room-unlink:hover{color:#ff8a96;border-color:#ff8a96}.room-roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}.room-card{display:flex;align-items:center;gap:12px;padding:11px 12px;min-height:58px;border-radius:12px;background:color-mix(in srgb,var(--text) 5%,transparent);border:1px solid color-mix(in srgb,var(--text) 8%,transparent)}.room-card:not(.in):not(.self){opacity:.55}.room-card.in{background:color-mix(in srgb,var(--text) 8%,transparent)}.room-card-ico{flex:0 0 auto;width:40px;height:40px;display:grid;place-items:center;font-size:22px;line-height:1;border-radius:10px;background:color-mix(in srgb,var(--text) 7%,transparent)}.room-card-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:6px}.room-card-id{display:flex;align-items:center;gap:7px;min-width:0}.room-card-foot{display:flex;align-items:center;min-height:26px}.room-card .room-dev-name{flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.room-row-status{flex:0 0 auto;font-size:11px;letter-spacing:.2px;color:var(--muted)}.room-row-tog{flex:0 0 auto;display:flex;align-items:center;gap:6px}.room-tog{width:34px;height:30px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line);background:transparent;font-size:15px;line-height:1;cursor:pointer;filter:grayscale(1) opacity(.4);transition:filter .12s,border-color .12s,background .12s}button.room-tog:hover{border-color:var(--accent);filter:grayscale(.3) opacity(.85)}.room-tog.on{filter:none;border-color:color-mix(in srgb,var(--accent) 55%,var(--line));background:color-mix(in srgb,var(--accent) 16%,transparent)}.room-tog.static{cursor:default;width:28px;height:26px;font-size:13px}.room-tog.locked{cursor:not-allowed;border-style:dashed;filter:grayscale(1) opacity(.28)}.room-guest-tag{flex:0 0 auto;font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#9fd0ff;background:color-mix(in srgb,#7fb6ff 16%,transparent);border:1px solid color-mix(in srgb,#7fb6ff 38%,transparent);border-radius:5px;padding:1px 5px}.room-card.guest{box-shadow:inset 3px 0 color-mix(in srgb,#7fb6ff 55%,transparent)}.room-host-tag{flex:0 0 auto;font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#9be9c0;background:color-mix(in srgb,#6bdc9e 15%,transparent);border:1px solid color-mix(in srgb,#6bdc9e 36%,transparent);border-radius:5px;padding:1px 5px}.room-row-acts{flex:0 0 auto;display:flex;align-items:center;gap:6px}.room-act{font-size:11px;font-weight:700;letter-spacing:.2px;padding:6px 10px;border-radius:7px;background:transparent;border:1px solid var(--line);color:var(--text);cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,color .12s}.room-act:hover{border-color:var(--accent);color:var(--accent)}.room-act.primary{background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:color-mix(in srgb,var(--accent) 50%,var(--line));color:var(--accent)}.room-act.primary:hover{background:color-mix(in srgb,var(--accent) 26%,transparent)}.room-foot{display:flex;flex-direction:column;gap:7px}.room-cta{width:100%;padding:10px 12px;border-radius:9px;border:1px solid var(--accent);background:var(--accent);color:#08111a;font-weight:800;letter-spacing:.2px;cursor:pointer;transition:filter .12s}.room-cta:hover:not(:disabled){filter:brightness(1.08)}.room-cta:disabled{opacity:.5;cursor:default;border-color:var(--line);background:color-mix(in srgb,var(--text) 8%,transparent);color:var(--muted)}.room-invite{width:100%;padding:9px 12px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--text);font-weight:600;font-size:12px;cursor:pointer;transition:border-color .12s,color .12s}.room-invite:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.room-invite:disabled{opacity:.55;cursor:default}.room-invite-share{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:2px}.room-invite-link{width:100%;font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--muted);background:color-mix(in srgb,var(--text) 6%,transparent);border:1px solid var(--line);border-radius:7px;padding:7px 9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;cursor:pointer;transition:border-color .12s,color .12s}.room-invite-link:hover,.room-invite-link:active{border-color:var(--accent);color:var(--text)}.room-invite-qr{display:block;border-radius:9px;padding:8px;background:#fff;box-shadow:0 1px 6px #00000040}.room-invite-scan{font-size:10.5px;color:var(--muted);letter-spacing:.2px}.stage{position:relative}.stage-lock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:transparent;cursor:not-allowed}@media(min-width:769px){.loop-sizes .loop-btn,.hotcues .pad{width:100%;max-width:none;aspect-ratio:auto;height:42px}}@media(max-width:768px){.loop-sizes,.hotcues{grid-template-columns:repeat(8,minmax(0,1fr))}.loop-sizes .loop-btn,.hotcues .pad{width:100%;max-width:none;aspect-ratio:auto;height:42px;min-width:0}.pitch-row .vcell,.stems-row .vcell,.eq-row .vcell{height:50px}.loops .loop-btn{padding:7px 0}.stage .decks-row .bank-main{gap:6px}.decks-row .bank-main>.eq-row{flex:0 1 auto;min-height:0}.fx-strip{--fx-body-h: 192px}.eq-curve{min-height:0}.fx-delay .fx-knobs{grid-auto-rows:minmax(20px,28px);gap:6px 7px;padding-bottom:4px}.fx-foot{gap:3px}.fx-chip{padding:4px 3px;font-size:8.5px}}.profile-screen,.social-screen{position:relative;width:min(560px,94vw);max-height:min(86dvh,860px);display:flex;flex-direction:column;gap:12px;padding:16px 18px 18px;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 70px #0000008c;overflow:hidden auto;animation:panel-in .16s ease-out}.profile-head,.social-head{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0}.profile-head-title,.social-title{font-weight:800;font-size:16px;letter-spacing:.2px}.social-head-tools{display:flex;align-items:center;gap:6px}.profile-x{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:14px;cursor:pointer;transition:color .12s,border-color .12s}.profile-x:hover{color:var(--text);border-color:var(--accent)}.profile-signin{display:flex;flex-direction:column;gap:12px;padding:8px 0}.profile-signin-copy{color:var(--muted);font-size:13px;line-height:1.5}.profile-body{display:flex;flex-direction:column;gap:16px}.profile-id{display:flex;align-items:center;gap:12px}.profile-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:1px solid var(--line)}.profile-avatar.private{filter:blur(7px)}.profile-avatar.fallback{display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 22%,var(--panel-2));color:var(--text);font-weight:800;font-size:22px}.profile-id-text{flex:1 1 auto;min-width:0}.profile-name{font-weight:700;font-size:15px}.profile-email{color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-since{color:var(--muted);font-size:11px;margin-top:2px;opacity:.85}.profile-handle{align-self:flex-start;margin:1px 0 2px;padding:0;background:none;border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--accent)}.profile-handle:hover{text-decoration:underline}.profile-handle.claim{color:var(--muted);font-weight:500}.profile-handle.claim:hover{color:var(--accent)}span.profile-handle{cursor:default}span.profile-handle:hover{text-decoration:none}.profile-bio{font-size:12px;margin-top:4px;line-height:1.4;white-space:pre-wrap;opacity:.9}.profile-public{display:flex;flex-direction:column;gap:8px}.profile-public .profile-bio{margin:0}.profile-public-actions{display:flex;gap:10px;align-items:center}.profile-edit-btn,.profile-view-public{padding:5px 10px;border-radius:6px;border:1px solid var(--line);background:var(--panel-2);color:inherit;cursor:pointer;font-size:12px}.profile-edit-btn:hover{border-color:var(--accent)}.profile-view-public{border:none;background:none;color:var(--accent);padding:5px 2px}.profile-view-public:hover{text-decoration:underline}.profile-field{display:flex;flex-direction:column;gap:4px}.profile-field-label{font-size:11px;color:var(--muted)}.profile-bio-input{resize:vertical;font-family:inherit;line-height:1.4}.profile-graph{display:flex;flex-direction:column;gap:8px}.profile-counts{display:flex;gap:14px;font-size:12px;color:var(--muted)}.profile-counts b{color:inherit;font-weight:700}.profile-friend{color:var(--accent)}.profile-graph-actions{display:flex;gap:8px}.follow-btn{padding:6px 16px;border-radius:6px;border:1px solid var(--accent);background:var(--accent);color:#06121a;font-weight:600;font-size:12px;cursor:pointer}.follow-btn.on{background:transparent;color:var(--accent)}.block-btn{padding:6px 12px;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:12px;cursor:pointer}.block-btn:hover{color:#c8506a;border-color:#c8506a}.handle-editor{border:1px solid var(--line);border-radius:8px;background:var(--panel-2);padding:10px;display:flex;flex-direction:column;gap:8px}.handle-editor-field{display:flex;align-items:center;gap:4px}.handle-at{color:var(--muted);font-weight:700}.handle-input{flex:1;min-width:0;background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:6px 8px;color:inherit;font-size:14px}.handle-input:focus{outline:none;border-color:var(--accent)}.handle-status{font-size:11px;white-space:nowrap;color:var(--muted)}.handle-status.ok{color:#3ad29f}.handle-status.bad{color:#c8506a}.handle-editor-actions{display:flex;gap:8px}.handle-save,.handle-cancel{padding:5px 12px;border-radius:6px;border:1px solid var(--line);background:var(--panel);color:inherit;cursor:pointer;font-size:12px}.handle-save{background:var(--accent);border-color:var(--accent);color:#06121a;font-weight:600}.handle-save:disabled{opacity:.45;cursor:default}.handle-cancel:hover{border-color:var(--muted)}.handle-hint{margin:0;font-size:11px;color:var(--muted)}.profile-conns{display:flex;flex-direction:column;gap:8px}.profile-conn{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--panel-2)}.profile-conn-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex:0 0 auto}.profile-conn.on .profile-conn-dot{background:#38d39f}.profile-conn-text{flex:1 1 auto;display:flex;flex-direction:column;min-width:0}.profile-conn-label{font-weight:600;font-size:13px}.profile-conn-sub{color:var(--muted);font-size:11px}.profile-conn-btn{padding:6px 12px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .12s,color .12s}.profile-conn-btn:hover{border-color:var(--accent);color:var(--accent)}.profile-section-head,.social-section-head{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.profile-empty{color:var(--muted);font-size:12.5px;line-height:1.5;padding:6px 2px}.profile-top{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.profile-top-row{display:flex;align-items:center;gap:10px;padding:5px 6px;border-radius:8px}.profile-top-row:hover{background:var(--panel-2)}.profile-top-rank{width:18px;text-align:center;color:var(--muted);font-size:12px;font-weight:700;flex:0 0 auto}.profile-top-thumb{width:40px;height:30px;border-radius:5px;object-fit:cover;flex:0 0 auto;background:var(--panel-2)}.profile-top-meta{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.profile-top-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-top-artist{color:var(--muted);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-top-plays{color:var(--accent);font-size:12px;font-weight:700;flex:0 0 auto}.profile-signout{align-self:flex-start;padding:8px 16px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer}.profile-signout:hover{border-color:#e0617a;color:#e0617a}.social-hint{color:var(--muted);font-size:13px;line-height:1.5;padding:8px 2px}.social-body{display:flex;flex-direction:column;gap:12px}.social-waiting,.social-offline{padding:9px 12px;border-radius:9px;font-size:12.5px;font-weight:600;text-align:center}.social-waiting{background:color-mix(in srgb,var(--accent) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));color:var(--text)}.social-offline{background:color-mix(in srgb,var(--text) 7%,transparent);border:1px solid var(--line);color:var(--muted)}.social-knocks{display:flex;flex-direction:column;gap:6px;padding:10px;border:1px solid color-mix(in srgb,var(--accent) 40%,var(--line));border-radius:11px;background:color-mix(in srgb,var(--accent) 8%,transparent)}.social-knock{display:flex;align-items:center;gap:9px}.social-knock-ico{font-size:16px}.social-knock-name{flex:1 1 auto;font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.social-knock-acts{display:flex;gap:6px;flex:0 0 auto}.social-approve,.social-deny{padding:6px 12px;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--line)}.social-approve{background:var(--accent);border-color:var(--accent);color:#08111a}.social-approve:hover{filter:brightness(1.08)}.social-deny{background:transparent;color:var(--muted)}.social-deny:hover{border-color:#e0617a;color:#e0617a}.social-roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.social-ghost{color:var(--muted);font-size:12.5px;line-height:1.5;padding:10px 12px;border:1px dashed var(--line);border-radius:10px;text-align:center}.social-card{display:flex;align-items:center;gap:11px;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:var(--panel-2)}.social-card.in{border-color:color-mix(in srgb,var(--accent) 35%,var(--line))}.social-card.self{background:color-mix(in srgb,var(--accent) 10%,var(--panel-2))}.social-card-ico{font-size:20px;flex:0 0 auto}.social-card-main{flex:1 1 auto;min-width:0}.social-card-top{display:flex;align-items:center;gap:7px}.social-card-name{font-weight:700;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.social-card-since{color:var(--muted);font-size:10.5px;margin-left:auto;flex:0 0 auto}.social-card-role{color:var(--muted);font-size:11.5px;margin-top:2px}.social-card-acts{display:flex;align-items:center;gap:5px;flex:0 0 auto}.social-kick{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:transparent;font-size:13px;cursor:pointer;transition:border-color .12s,background .12s}.social-kick:hover{border-color:#e0617a;background:color-mix(in srgb,#e0617a 16%,transparent)}.social-foot{display:flex;flex-direction:column;gap:9px;margin-top:2px}.social-invite{display:flex;flex-direction:column;gap:9px}.share-modes{display:flex;flex-direction:column;gap:10px;margin-top:4px;padding-top:12px;border-top:1px solid var(--line)}.share-modes .social-section-head{margin-bottom:0}.share-mode{display:flex;flex-direction:column;gap:9px;padding:11px 12px;border-radius:11px;border:1px solid var(--line);background:var(--panel-2)}.share-mode.public{border-color:color-mix(in srgb,#c8506a 35%,var(--line));background:color-mix(in srgb,#c8506a 5%,var(--panel-2))}.share-mode.public.live{border-color:#c8506a;background:color-mix(in srgb,#c8506a 12%,var(--panel-2))}.share-mode-head{display:flex;flex-direction:column;gap:3px}.share-mode-title{font-weight:700;font-size:13.5px}.share-mode.public .share-mode-title{color:#e87f97}.share-live-dot{color:#ff5d73;animation:live-pulse 1.6s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.35}}.share-mode-sub{font-size:11.5px;line-height:1.45;color:var(--muted)}.share-mode-sub b{color:var(--text);font-weight:600}.gate-select{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.gate-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-right:2px}.gate-opt{padding:4px 11px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer}.gate-opt:hover{border-color:#c8506a;color:#e87f97}.gate-opt.on{background:#c8506a;border-color:#c8506a;color:#fff}.crowd-panel{display:flex;flex-direction:column;gap:9px;padding:10px 12px;margin-bottom:10px;border-radius:11px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));background:var(--panel-2)}.hype-row{position:relative;display:flex;align-items:center;gap:9px}.hype-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);flex:none}.hype-bar{position:relative;flex:1 1 auto;height:9px;border-radius:999px;background:color-mix(in srgb,var(--line) 60%,transparent);overflow:hidden}.hype-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),#ffb13c);transition:width .9s linear}.hype-bar.hot .hype-fill{background:linear-gradient(90deg,#ffb13c,#ff5d73);animation:hype-throb .8s ease-in-out infinite}@keyframes hype-throb{0%,to{filter:brightness(1)}50%{filter:brightness(1.25)}}.hype-sprites{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible}.hype-sprite{position:absolute;bottom:0;font-size:15px;animation:hype-rise 1.5s ease-out forwards}@keyframes hype-rise{0%{transform:translateY(4px) scale(.6);opacity:0}20%{opacity:1}to{transform:translateY(-34px) scale(1.15);opacity:0}}.react-bar{display:flex;gap:6px;flex-wrap:wrap}.react-btn{flex:1 1 0;min-width:40px;padding:7px 0;border-radius:8px;border:1px solid var(--line);background:var(--panel);font-size:17px;line-height:1;cursor:pointer;transition:transform .08s ease,border-color .12s ease}.react-btn:hover{border-color:var(--accent)}.react-btn:active{transform:scale(.86)}.request-form{display:flex;gap:6px}.request-input{flex:1 1 auto;min-width:0;padding:7px 11px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:13px}.request-input:focus{outline:none;border-color:var(--accent)}.request-send{flex:none;padding:7px 14px;border-radius:8px;border:1px solid var(--accent);background:var(--accent);color:#08111a;font-weight:700;font-size:12px;cursor:pointer}.request-send:disabled{opacity:.5;cursor:default}.req-list{display:flex;flex-direction:column;gap:6px}.req-list.crowd{margin-top:2px;padding-top:9px;border-top:1px solid var(--line)}.req-head{display:flex;align-items:center;justify-content:space-between}.req-clear{border:none;background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;text-transform:none;letter-spacing:0}.req-clear:hover{color:#e0617a}.req-row{display:flex;align-items:center;gap:8px}.req-vote{flex:none;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:34px;padding:3px 6px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--muted);cursor:pointer;line-height:1}.req-vote:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.req-vote.on{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);cursor:default}.req-caret{font-size:9px}.req-votes{font-size:12px;font-weight:700}.req-text{flex:1 1 auto;font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.req-who{flex:none;font-size:11px;color:var(--muted)}.req-dismiss{flex:none;border:none;background:transparent;color:var(--muted);font-size:13px;cursor:pointer;padding:2px 4px}.req-dismiss:hover{color:#e0617a}.chat-panel{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;padding:10px 12px;border-radius:11px;border:1px solid var(--line);background:var(--panel-2)}.chat-head{display:flex;align-items:center;justify-content:space-between}.chat-slow-sel{display:flex;gap:3px}.chat-slow-opt{padding:2px 8px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;text-transform:none;letter-spacing:0}.chat-slow-opt.on{background:var(--accent);border-color:var(--accent);color:#08111a}.chat-log{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto;padding-right:2px}.chat-empty{font-size:12px;color:var(--muted);padding:8px 2px}.chat-line{display:flex;align-items:baseline;gap:7px;font-size:13px;line-height:1.35}.chat-who{flex:none;font-weight:700;color:var(--accent);max-width:35%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-line.self .chat-who{color:var(--muted)}.chat-text{flex:1 1 auto;word-break:break-word}.chat-mod{flex:none;display:flex;gap:2px;opacity:0;transition:opacity .12s ease}.chat-line:hover .chat-mod{opacity:1}.chat-mute,.chat-ban{border:none;background:transparent;cursor:pointer;font-size:11px;padding:0 2px;filter:grayscale(.4)}.chat-mute:hover,.chat-ban:hover{filter:none}.chat-form{display:flex;gap:6px}.chat-input{flex:1 1 auto;min-width:0;padding:7px 11px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:13px}.chat-input:focus{outline:none;border-color:var(--accent)}.chat-input:disabled{opacity:.6}.chat-send{flex:none;padding:7px 14px;border-radius:8px;border:1px solid var(--accent);background:var(--accent);color:#08111a;font-weight:700;font-size:12px;cursor:pointer}.chat-send:disabled{opacity:.5;cursor:default}.room-expand{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:color .12s,border-color .12s}.room-expand:hover{color:var(--accent);border-color:var(--accent)}.room-knock-cta{width:100%;margin-top:7px;padding:8px 10px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent) 50%,var(--line));background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--text);font-size:12px;font-weight:700;cursor:pointer}.room-knock-cta:hover{background:color-mix(in srgb,var(--accent) 22%,transparent)}.room-count.knock{background:var(--accent);color:#08111a;animation:knock-pulse 1.3s ease-in-out infinite}@keyframes knock-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}.kicked-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%);z-index:70;max-width:90vw;padding:11px 18px;border-radius:11px;border:1px solid color-mix(in srgb,#e0617a 50%,var(--line));background:color-mix(in srgb,#e0617a 18%,var(--panel));color:var(--text);font-size:13px;font-weight:600;box-shadow:0 10px 30px #00000073;cursor:pointer;animation:panel-in .18s ease-out}@media(max-width:768px){.profile-screen,.social-screen{width:100vw;height:100dvh;max-height:none;border-radius:0;border:none;padding:14px 14px 20px}}.chin-btn.chin-profile{order:9;flex:0 0 auto;width:42px}.chin-globe{font-size:16px;line-height:1}.sync-full.embedded{width:100%;height:100%;max-height:none;min-height:0;border:none;border-radius:0;box-shadow:none}.automix-bar{display:flex;gap:6px;align-items:stretch;margin-bottom:6px}.automix-toggle{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 8px;font-weight:700;letter-spacing:.08em;font-size:12px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;cursor:pointer}.automix-toggle.on{color:#061018;background:var(--accent);border-color:var(--accent)}.automix-count{font-weight:600;font-size:10px;letter-spacing:.04em;opacity:.85}.automix-queue-btn{padding:6px 10px;font-size:12px;color:var(--text);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;cursor:pointer;white-space:nowrap}.automix-queue-btn:hover{border-color:var(--accent)}.mixq{position:fixed;top:64px;right:12px;bottom:12px;width:340px;max-width:calc(100vw - 24px);z-index:60;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:0 18px 50px #0000008c;overflow:hidden}.mixq.drop-active{outline:2px dashed var(--accent);outline-offset:-4px}.mixq.embedded.drop-active{background:color-mix(in srgb,var(--accent) 8%,var(--panel))}.mixq-head{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--line)}.mixq-auto{font-weight:700;letter-spacing:.08em;font-size:12px;padding:6px 10px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;cursor:pointer}.mixq-auto.on{color:#061018;background:var(--accent);border-color:var(--accent)}.mixq-mode{display:flex;gap:0;margin-left:auto;border:1px solid var(--line);border-radius:6px;overflow:hidden}.mixq-mode button{padding:5px 10px;font-size:12px;color:var(--muted);background:transparent;border:0;cursor:pointer}.mixq-mode button[aria-selected=true]{color:var(--text);background:var(--panel-2)}.mixq-close{background:transparent;border:0;color:var(--muted);font-size:14px;cursor:pointer;padding:4px 6px}.mixq-seed{display:flex;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--line)}.mixq-seed select{flex:1;min-width:0;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:5px 6px;font-size:12px}.mixq-smart{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);white-space:nowrap}.mixq-now{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--accent) 8%,var(--panel))}.mixq-countdown{font-size:11px;color:var(--accent);white-space:nowrap}.mixq-list{flex:1;overflow-y:auto;margin:0;padding:4px;list-style:none;border-radius:6px}.mixq-list.drop-active{outline:2px dashed var(--accent);outline-offset:-2px;background:color-mix(in srgb,var(--accent) 8%,transparent)}.mixq-item{display:flex;align-items:center;gap:8px;padding:6px 4px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);border-top:2px solid transparent;border-radius:4px}.mixq-item[draggable=true]{cursor:grab}.mixq-item[draggable=true]:active{cursor:grabbing}.mixq-item:hover{background:color-mix(in srgb,var(--accent) 9%,transparent)}.mixq-item.drag-over{border-top-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.mixq-track{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.mixq-track img{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}.mixq-track-text{display:flex;flex-direction:column;min-width:0}.mixq-title{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mixq-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mixq-badge{display:inline-block;font-size:9px;font-weight:600;letter-spacing:.03em;padding:2px 5px;border-radius:4px;white-space:nowrap;flex-shrink:0}.mixq-badge.tier-high{color:#061810;background:#3ddc84}.mixq-badge.tier-mid{color:#1a1405;background:#e8b84b}.mixq-badge.tier-low{color:#fff;background:#c8506a}.mixq-item-actions{display:flex;gap:2px;flex-shrink:0}.mixq-item-actions button{width:22px;height:22px;font-size:11px;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:4px;cursor:pointer}.mixq-item-actions button:disabled{opacity:.3;cursor:default}.mixq-empty{padding:16px 10px;text-align:center;color:var(--muted);font-size:12px}.mixq-controls{display:flex;gap:6px;padding:10px;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--bg);z-index:2}.mixq-controls button{flex:1 1 0;min-width:0;padding:7px 6px;font-size:12px;color:var(--text);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mixq-controls button:disabled{opacity:.4;cursor:default}.mixq-controls button:not(:disabled):hover{border-color:var(--accent)}.settings-head .automix-bar{margin:0;flex:0 0 auto;align-items:center}.settings-head .automix-toggle{flex:0 0 auto;padding:5px 12px}.mixq-badge.tier-unknown{color:var(--text);background:var(--line)}.mixq-augment{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--line)}.mixq.embedded{display:contents}.mixq.embedded .mixq-close{font-size:12px;color:var(--accent)}.lib-pl-src{cursor:pointer;opacity:.6;transition:opacity .12s,color .12s}.lib-pl-src:hover{opacity:1;color:var(--accent)}.wizard{position:relative;width:460px;max-width:calc(100vw - 24px);max-height:calc(100vh - 48px);display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:0 24px 64px #0009;overflow:hidden}.wizard.embedded{width:100%;max-width:none;height:100%;max-height:none;border:none;border-radius:0;box-shadow:none;background:transparent}.wizard.embedded .wizard-body{flex:1;min-height:0}.wizard.embedded .wizard-pick,.wizard.embedded .wizard-review{flex:1;min-height:0;max-height:none}.wizard-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}.wizard-title{font-weight:700;font-size:15px}.wizard-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.wizard-center{align-items:center;text-align:center;padding:36px 16px}.wizard-lead{color:var(--muted);font-size:13px;margin:0}.wizard-svc{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--line);border-radius:8px}.wizard-svc button{padding:5px 12px;border:1px solid var(--accent);color:var(--accent);background:transparent;border-radius:6px;cursor:pointer}.wizard-ok{color:#3ddc84;font-size:13px}.wizard-pick{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto}.wizard-pl{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:6px;cursor:pointer}.wizard-pl:hover{background:var(--panel-2)}.wizard-pl-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.wizard-pl-meta{font-size:11px;color:var(--muted);white-space:nowrap}.wizard-empty{color:var(--muted);text-align:center;padding:20px;font-size:13px}.wizard-foot{display:flex;justify-content:space-between;gap:8px;margin-top:4px}.wizard-foot button{padding:8px 16px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);border-radius:7px;cursor:pointer;font-size:13px}.wizard-foot button.primary{background:var(--accent);color:#061018;border-color:var(--accent);font-weight:600}.wizard-foot button:disabled{opacity:.4;cursor:default}.wizard-review{display:flex;flex-direction:column;gap:10px;max-height:360px;overflow-y:auto}.wizard-flag{display:flex;flex-direction:column;gap:5px;padding:8px;border:1px solid var(--line);border-radius:8px}.wizard-flag-src{display:flex;flex-direction:column}.wizard-flag-src strong{font-size:13px}.wizard-flag-src span{font-size:11px;color:var(--muted)}.wizard-flag select{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:6px;font-size:12px}.wizard-done{font-size:15px;color:#3ddc84}.wizard-spinner{width:32px;height:32px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:wizard-spin .8s linear infinite;margin-bottom:12px}@keyframes wizard-spin{to{transform:rotate(360deg)}}.mixq-item-x{width:24px;height:24px;flex-shrink:0;font-size:12px;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:5px;cursor:pointer}.mixq-item-x:hover{color:#c8506a;border-color:#c8506a}.social-broadcast{display:flex;flex-direction:column;gap:6px;margin-top:8px}.broadcast-btn{padding:8px 14px;border-radius:7px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer}.broadcast-btn.on{background:#c8506a;border-color:#c8506a;color:#fff}.broadcast-status{font-size:12px;color:var(--muted)}.broadcast-status b{color:var(--accent)}.broadcast-hint{font-size:12px;color:var(--muted)}.live-now{margin-bottom:10px}.live-now-head{color:#c8506a}.live-now-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.live-room{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;border:1px solid var(--line);background:var(--panel-2);cursor:pointer}.live-room:hover{border-color:var(--accent)}.live-room-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;flex:none}.live-room-avatar.fallback{display:grid;place-items:center;background:var(--line);font-size:13px;font-weight:700}.live-room-main{display:flex;flex-direction:column;min-width:0;flex:1}.live-room-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-room-you{color:var(--muted);font-weight:400}.live-room-np{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.live-room-count{font-size:12px;color:var(--muted);flex:none}.listening-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;margin-bottom:10px;border-radius:8px;border:1px solid #c8506a;background:color-mix(in srgb,#c8506a 14%,var(--panel));font-size:13px}.listening-what b{color:#e87f97}.listening-stop{flex:none;padding:5px 12px;border-radius:6px;border:1px solid #c8506a;background:transparent;color:#e87f97;font-weight:600;font-size:12px;cursor:pointer}.listening-stop:hover{background:#c8506a;color:#fff}.live-room.tuned{border-color:#c8506a;background:color-mix(in srgb,#c8506a 10%,var(--panel-2))}.stage-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;margin-bottom:10px;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent) 45%,var(--line));background:color-mix(in srgb,var(--accent) 8%,var(--panel));font-size:13px}.stage-bar.up{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,var(--panel))}.stage-bar.pending{border-style:dashed}.stage-bar.closed{border-color:var(--line);background:var(--panel-2);color:var(--muted)}.stage-bar-what{flex:1 1 auto}.stage-bar-what b{color:var(--accent)}.stage-bar-picks{display:flex;gap:6px;flex:none}.stage-pick{padding:5px 11px;border-radius:6px;border:1px solid var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);font-weight:700;font-size:12px;cursor:pointer}.stage-pick:hover{background:var(--accent);color:#08111a}.stage-down{flex:none;padding:5px 12px;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--muted);font-weight:600;font-size:12px;cursor:pointer}.stage-down:hover{border-color:var(--accent);color:var(--accent)}.stage-req-deck{color:var(--muted);font-weight:500}.stage-alt{padding:6px 10px;border-radius:7px;border:1px dashed var(--accent);background:transparent;color:var(--accent);font-weight:700;font-size:12px;cursor:pointer}.stage-alt:hover{background:color-mix(in srgb,var(--accent) 16%,transparent)}.social-floor{padding:6px 10px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--muted);font-weight:600;font-size:12px;cursor:pointer}.social-floor:hover{border-color:var(--accent);color:var(--accent)}.bank.locked,.xfader-bar.locked{pointer-events:none;opacity:.6}.listen-live-btn{display:block;width:100%;margin:4px 0;padding:10px 14px;border-radius:8px;border:1px solid #c8506a;background:#c8506a;color:#fff;font-weight:700;font-size:14px;cursor:pointer}.listen-live-btn:hover{filter:brightness(1.08)}
