:root{
  --bg:#0a0b0f;--panel:#0e1015;--card:#14161e;--elev:#181b25;
  --bdr:#1e2130;--bhi:#2a2f44;
  --blue:#3d9bff;--orange:#ff7a35;--green:#00e589;
  --purple:#aa88ff;--red:#ff4466;--yellow:#ffd84a;
  --text:#e6e8ee;--dim:#8a91a1;--mute:#5a6172;
  --mono:'JetBrains Mono','SF Mono','Fira Code',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--mono);
  font-size:12px;font-variant-numeric:tabular-nums;overflow:hidden;
  background-image:linear-gradient(rgba(0,212,255,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(0,212,255,.05) 1px,transparent 1px);background-size:48px 48px}

/* TOPBAR */
.tb{height:44px;display:flex;align-items:center;gap:8px;padding:0 14px;
  background:linear-gradient(180deg,#11141c,#0a0b0f);border-bottom:1px solid var(--bdr);
  position:relative;z-index:10}
.brand{display:flex;align-items:center;gap:8px}
.bmark{color:var(--orange);font-size:16px;letter-spacing:-2px;text-shadow:0 0 6px rgba(255,122,53,.5)}
.bname{font-weight:700;letter-spacing:.18em}
.bver{color:var(--mute);font-size:10px;padding:2px 6px;border:1px solid var(--bhi);border-radius:3px}
.sp{flex:1}
.led{font-size:13px;color:var(--mute);transition:color .2s}
.led.live{color:var(--green);text-shadow:0 0 8px var(--green);animation:pulse 1.4s infinite}
.led.err{color:var(--red);text-shadow:0 0 8px var(--red)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.stxt{font-size:10px;color:var(--dim);letter-spacing:.14em;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dvd{width:1px;height:22px;background:var(--bhi);margin:0 3px}
.fps{font-size:10px;color:var(--mute);min-width:52px;text-align:right}

/* BUTTONS */
.btn{appearance:none;background:var(--card);color:var(--text);font:inherit;font-size:10px;
  letter-spacing:.14em;padding:6px 10px;border:1px solid var(--bhi);border-radius:4px;
  cursor:pointer;transition:background .1s,border-color .1s;user-select:none}
.btn:hover{background:var(--elev);border-color:#3a405a}
.btn:active{transform:translateY(1px)}
.btn.on{color:var(--blue);border-color:var(--blue);box-shadow:0 0 8px rgba(61,155,255,.3) inset}
.btn.prim{color:var(--blue);border-color:var(--blue);background:linear-gradient(180deg,#1c2440,#131829)}
.ibtn{display:flex;align-items:center;gap:6px}
.ithumb{width:22px;height:22px;border-radius:3px;background:var(--elev);border:1px solid var(--bdr);
  overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-size:9px;color:var(--mute)}
.ithumb img{width:100%;height:100%;object-fit:cover;display:block}
.ibtn.loaded{border-color:var(--blue);color:var(--blue)}

/* LAYOUT */
.layout{display:grid;grid-template-columns:1fr 110px;height:calc(100vh - 44px);gap:10px;padding:12px}
.stage{position:relative;background:#050608;border:1px solid var(--bdr);border-radius:6px;
  overflow:hidden;display:flex;align-items:center;justify-content:center}
#cv{width:100%;height:100%;display:block}

/* OVERLAY — fixed so it always sits above floating panels (z > 250) */
.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(10,11,15,.88);backdrop-filter:blur(4px);z-index:300;transition:opacity .25s}
.overlay.gone{opacity:0;pointer-events:none}
.ocard{text-align:center;padding:18px 22px;border:1px dashed var(--bhi);border-radius:8px;
  background:rgba(20,22,30,.92);max-width:760px;width:calc(100% - 24px);
  max-height:calc(100vh - 80px);display:flex;flex-direction:column;gap:6px;overflow:hidden}
.oicon{font-size:36px;color:var(--blue);margin-bottom:10px;text-shadow:0 0 20px rgba(61,155,255,.6)}
.otitle{font-size:13px;letter-spacing:.22em;margin-bottom:6px}
.ohint{font-size:10px;color:var(--dim);margin-bottom:14px;letter-spacing:.1em}
.oactions{display:flex;gap:8px;justify-content:center;margin-bottom:14px}
.oor{font-size:9px;color:var(--mute);letter-spacing:.18em;
  display:flex;align-items:center;gap:8px;margin-bottom:10px}
.oor::before,.oor::after{content:'';flex:1;height:1px;background:var(--bhi)}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.stile{aspect-ratio:1;border-radius:4px;overflow:hidden;cursor:pointer;border:1px solid var(--bhi);
  background:var(--card);position:relative;transition:border-color .12s,transform .08s}
.stile:hover{border-color:var(--blue);transform:scale(1.05)}
.stile img{width:100%;height:100%;object-fit:cover;display:block}
.stile .sl{position:absolute;bottom:0;left:0;right:0;font-size:8px;letter-spacing:.12em;
  padding:3px;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);text-align:center}
.sempty{font-size:10px;color:var(--mute);padding:14px;border:1px dashed var(--bdr);
  border-radius:4px;grid-column:1/-1}

/* OVERLAY TABS */
.otabs{display:flex;gap:2px;margin-bottom:8px;border-bottom:1px solid var(--bhi);padding-bottom:6px}
.otab{appearance:none;background:transparent;border:1px solid transparent;color:var(--mute);
  font:inherit;font-size:10px;letter-spacing:.14em;padding:5px 12px;border-radius:4px;
  cursor:pointer;transition:color .1s,border-color .1s,background .1s}
.otab:hover{color:var(--text);background:var(--elev)}
.otab.active{color:var(--blue);border-color:var(--blue);background:rgba(61,155,255,.08)}
.otab-body{max-height:min(70vh, 620px);overflow-y:auto}
.otab-body::-webkit-scrollbar{width:4px}
.otab-body::-webkit-scrollbar-thumb{background:var(--bhi);border-radius:2px}

/* Keyframe scene grid (larger tiles than samples) */
.skgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.sktile{border-radius:5px;overflow:hidden;cursor:pointer;border:1px solid var(--bhi);
  background:var(--card);position:relative;transition:border-color .12s,transform .08s}
.sktile:hover{border-color:var(--blue);transform:scale(1.03)}
.sktile img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.sktile .skl{padding:4px 6px;font-size:8px;letter-spacing:.12em;color:var(--dim);
  display:flex;justify-content:space-between;align-items:center}
.sktile .skmap{font-size:7px;color:var(--orange);letter-spacing:.1em}
.sktile.active-kf{border-color:var(--green);box-shadow:0 0 8px rgba(0,229,137,.2)}

/* STAGE FLASH */
.sflash{position:absolute;inset:0;z-index:15;pointer-events:none;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  background:rgba(61,155,255,.1);border:2px solid var(--blue);border-radius:6px;
  opacity:0;transition:opacity .1s}
.sflash.on{opacity:1}
.sflash-icon{font-size:32px;color:var(--blue);text-shadow:0 0 16px rgba(61,155,255,.8)}
.sflash-lbl{font-size:12px;letter-spacing:.22em}

/* SWAP BAR */
.swapbar{position:absolute;bottom:0;left:0;right:0;z-index:10;
  background:linear-gradient(0deg,rgba(8,10,18,.92),transparent);
  padding:18px 12px 10px;display:flex;align-items:center;gap:10px;
  opacity:0;transition:opacity .25s}
.stage:hover .swapbar,.swapbar:focus-within{opacity:1}
.sbthumb{width:48px;height:36px;object-fit:cover;border-radius:3px;border:1px solid var(--bhi);flex-shrink:0}
.sbinfo{flex:1;min-width:0}
.sbname{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sbhint{font-size:9px;color:var(--mute);margin-top:2px;letter-spacing:.1em}
.rstrip{display:flex;gap:5px}
.rtile{width:40px;height:30px;border-radius:3px;overflow:hidden;cursor:pointer;
  border:1px solid var(--bhi);flex-shrink:0;transition:border-color .1s}
.rtile:hover{border-color:var(--blue)}
.rtile img{width:100%;height:100%;object-fit:cover;display:block}

/* RIGHT COL */
.rc{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:2px}
.rc::-webkit-scrollbar{width:6px}
.rc::-webkit-scrollbar-thumb{background:var(--bhi);border-radius:3px}

/* PANELS */
.panel{background:var(--panel);border:1px solid var(--bdr);border-radius:6px;overflow:hidden}
.pbar{display:flex;align-items:center;gap:8px;padding:8px 12px;
  background:linear-gradient(180deg,#181b25,#11141c);border-bottom:1px solid var(--bdr);
  font-size:10px;letter-spacing:.18em;cursor:pointer;user-select:none}
.pbar.nc{cursor:default}
.picon{color:var(--blue)}
.ptitle{color:var(--text);font-weight:600}
.ptog{margin-left:auto;color:var(--mute);font-size:10px}
.pbody{padding:12px;display:flex;flex-direction:column;gap:9px}
.pbody.shut{display:none}

/* SLIDERS */
.kv{display:grid;grid-template-columns:86px 1fr 40px;gap:6px;align-items:center}
.kv label{font-size:9px;color:var(--dim);letter-spacing:.16em}
.kv .ro{font-size:10px;text-align:right}
input[type=range]{-webkit-appearance:none;width:100%;height:4px;
  background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:2px;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;
  border-radius:50%;background:var(--text);border:2px solid var(--blue);
  box-shadow:0 0 6px rgba(61,155,255,.6);cursor:pointer}

/* AUDIO */
.srcrow{display:flex;gap:6px}
.srcrow .btn{flex:1}
.srcst{font-size:10px;color:var(--dim);min-height:16px}
#monitorBtn{font-size:10px;padding:5px 10px}
#monitorBtn.on{color:var(--green);border-color:var(--green);box-shadow:0 0 8px rgba(0,229,137,.25) inset}
#monitorBtn.off{color:var(--red);border-color:var(--red);opacity:.8}
.deck{display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--card);
  border-radius:4px;border:1px solid var(--bdr)}
.dhdr{display:flex;justify-content:space-between;font-size:10px;align-items:center}
.dtitle{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:190px}
.dtime{color:var(--mute)}
.drow{display:flex;gap:4px}
.drow .btn{font-size:9px;padding:4px 8px}
.drow .btn:first-child{flex:1}
.dlist{list-style:none;max-height:90px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.dlist li{display:flex;gap:6px;align-items:center;padding:3px 6px;background:var(--elev);
  border-radius:3px;cursor:pointer;font-size:10px;border:1px solid transparent}
.dlist li:hover{border-color:var(--bhi)}
.dlist li.cur{color:var(--orange);border-color:var(--orange)}
.dlist .dn{color:var(--mute);min-width:16px;text-align:right}
.dlist .dt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
audio{width:100%;height:32px}

/* METERS */
.meters{display:flex;flex-direction:column;gap:4px}
.meter{display:grid;grid-template-columns:32px 1fr 36px;gap:6px;align-items:center}
.mlbl{font-size:9px;color:var(--dim);letter-spacing:.16em}
.mval{font-size:9px;text-align:right}
.mbar{height:10px;background:var(--card);border:1px solid var(--bhi);border-radius:2px;overflow:hidden;position:relative}
.mbar::after{content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(90deg,transparent 0,transparent 6px,rgba(0,0,0,.5) 6px,rgba(0,0,0,.5) 7px);
  pointer-events:none}
.mfill{height:100%;width:0%;background:linear-gradient(90deg,var(--green) 0%,var(--green) 60%,var(--yellow) 78%,var(--red) 100%);
  transition:width .04s linear;box-shadow:0 0 8px rgba(0,229,137,.4)}
.beat-row{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--dim)}
.blbl{color:var(--mute);margin-left:auto;font-size:9px}

/* FX */
.fxrack{display:flex;flex-direction:column;gap:5px}
.fxrow{display:grid;grid-template-columns:20px 70px 1fr 36px 20px 18px;gap:5px;align-items:center;
  padding:4px 6px;background:var(--card);border:1px solid var(--bdr);border-radius:4px;
  transition:border-color .15s}
.fxrow.bnd{border-color:var(--orange);box-shadow:0 0 8px rgba(255,122,53,.15) inset}
.fxrow.manual{border-color:var(--purple);box-shadow:0 0 8px rgba(170,136,255,.18) inset}
.fx-rst{appearance:none;background:transparent;border:1px solid transparent;
  color:var(--mute);width:18px;height:18px;border-radius:3px;cursor:pointer;
  font-size:9px;font-family:var(--mono);line-height:1;padding:0;
  display:flex;align-items:center;justify-content:center;transition:color .1s,border-color .1s}
.fx-rst:hover{color:var(--orange);border-color:var(--orange)}
.tgl{width:18px;height:10px;background:#2a2f44;border-radius:5px;position:relative;cursor:pointer;transition:background .12s}
.tgl::after{content:'';position:absolute;width:8px;height:8px;border-radius:50%;
  background:var(--mute);top:1px;left:1px;transition:left .1s,background .1s}
.tgl.on{background:var(--blue)}
.tgl.on::after{left:9px;background:#fff;box-shadow:0 0 5px rgba(255,255,255,.5)}
.fxname{font-size:10px;letter-spacing:.12em}

/* MAPPING */
.madd{display:grid;grid-template-columns:1fr 14px 1fr 54px;gap:5px;align-items:center}
.arrow{text-align:center;color:var(--dim)}
select{appearance:none;background:var(--card);color:var(--text);border:1px solid var(--bhi);
  border-radius:3px;padding:4px 6px;font:inherit;font-size:10px;width:100%}
/* deprecated rule kept harmless for cascade — real one is below */
.mlist{display:flex;flex-direction:column;gap:4px;overflow-y:auto}
.mcard{padding:6px 8px;background:var(--card);border:1px solid var(--bdr);
  border-radius:4px;font-size:10px;position:relative;display:grid;grid-template-columns:1fr auto;gap:4px}
.mcard.ghost{opacity:.4;font-style:italic}
.mcard .sensrow{grid-column:1/-1;display:grid;grid-template-columns:38px 1fr 30px;gap:5px;align-items:center;margin-top:2px}
.mcard .sensrow label{font-size:8px;color:var(--mute);letter-spacing:.14em}
.mcard .sensrow .sro{font-size:9px;text-align:right;color:var(--dim)}
.fadespd{font-size:9px;color:var(--mute);letter-spacing:.12em;min-width:80px;text-align:right}
.fadespd span{color:var(--orange)}
.arrow-hint{font-size:9px;color:var(--mute);letter-spacing:.12em;padding:3px 0}
.arrow-hint kbd{background:var(--elev);border:1px solid var(--bhi);border-radius:3px;padding:1px 5px;
  font-family:var(--mono);font-size:9px;color:var(--blue)}
.msrc{color:var(--blue)}.mtgt{color:var(--orange)}.mcurve{color:var(--mute);font-size:9px}
.mbar{grid-column:1/-1;height:4px;background:var(--elev);border-radius:2px;overflow:hidden;margin-top:3px}
.mfill{height:100%;background:linear-gradient(90deg,var(--blue),var(--orange));width:0%;transition:width .04s}
.bx{background:transparent;border:1px solid var(--bhi);color:var(--mute);font-size:10px;
  padding:2px 6px;border-radius:3px;cursor:pointer;font-family:var(--mono)}
.bx:hover{color:var(--red);border-color:var(--red)}
.psetbar{display:flex;gap:4px;align-items:center;padding:6px 8px;
  background:var(--card);border:1px solid var(--bdr);border-radius:4px}
.psetbar label{font-size:9px;color:var(--dim);white-space:nowrap;letter-spacing:.14em}
.psetbar select{flex:1}
.psetbar .btn{font-size:9px;padding:4px 8px;white-space:nowrap}

/* REC */
.rbtn{display:flex;align-items:center;gap:5px;color:var(--red);border-color:var(--red)}
.rdot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 6px var(--red)}
.rbtn.recording .rdot{animation:pulse .9s infinite}
.rtime{font-size:10px;color:var(--red);min-width:44px}

/* TOASTS */
.thost{position:fixed;bottom:14px;right:14px;display:flex;flex-direction:column;gap:5px;z-index:999}
.toast{background:var(--panel);border:1px solid var(--bhi);border-radius:4px;padding:8px 12px;
  font-size:11px;max-width:340px;box-shadow:0 6px 24px rgba(0,0,0,.5);animation:tin .2s ease-out}
.toast.ok{border-color:var(--green);color:var(--green)}
.toast.err{border-color:var(--red);color:var(--red)}
.toast.info{border-color:var(--blue);color:var(--blue)}
@keyframes tin{from{transform:translateY(6px);opacity:0}to{transform:none;opacity:1}}

/* ABOUT */
.mbg{position:fixed;inset:0;z-index:500;background:rgba(5,6,10,.8);backdrop-filter:blur(6px);
  display:flex;align-items:flex-start;justify-content:center;padding:5vh 4vw;overflow-y:auto;
  opacity:0;pointer-events:none;transition:opacity .18s}
.mbg.open{opacity:1;pointer-events:auto}
.mcard{width:100%;max-width:820px;background:var(--panel);border:1px solid var(--bhi);
  border-radius:8px;padding:22px 24px 16px;box-shadow:0 24px 80px rgba(0,0,0,.7)}
.mhdr{display:flex;justify-content:space-between;align-items:center;
  margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--bdr)}
.mtitle{font-size:15px;font-weight:700;letter-spacing:.2em}
.mcls{appearance:none;background:transparent;border:1px solid var(--bhi);color:var(--mute);
  width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:13px;font-family:var(--mono)}
.mcls:hover{color:var(--red);border-color:var(--red)}
.as h2{font-size:12px;letter-spacing:.2em;color:var(--blue);margin:14px 0 6px;
  padding-bottom:4px;border-bottom:1px solid var(--bdr)}
.as p,.as li{font-size:11px;color:var(--dim);margin:4px 0;line-height:1.55}
.as ul{padding-left:16px;margin:4px 0}
.as li{list-style:none}
.as li::before{content:'▸ ';color:var(--orange)}
.as code{background:var(--card);padding:1px 4px;border-radius:3px;color:var(--purple);font-size:10px}
.fxdocs{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:7px;margin-top:6px}
.fxdoc{background:var(--card);border:1px solid var(--bdr);border-radius:4px;padding:8px 10px}
.fxdn{font-size:11px;font-weight:700;margin-bottom:3px}
.fxdd{font-size:10px;color:var(--dim)}
.fxdt{font-size:9px;color:var(--mute);margin-top:4px}

@media(max-width:800px){.layout{grid-template-columns:1fr}.rc{max-height:45vh}}

/* ── FLOATING PANELS ── */
.fpanel{
  position:fixed;
  z-index:200;
  background:rgba(14,16,21,0.96);
  border:1px solid var(--bhi);
  border-radius:6px;
  box-shadow:0 16px 48px rgba(0,0,0,.7),0 0 0 1px rgba(61,155,255,.06);
  display:flex;flex-direction:column;
  min-width:260px;
  max-width:92vw;
  overflow:hidden;
  backdrop-filter:blur(14px);
  /* no transition on transform/position — must feel instant while dragging */
}
.fpanel.fp-top{z-index:250;}
.fpanel.minimised>.fpanel-body{display:none}
.fpanel.minimised>.fpanel-resize{display:none}
.fpanel-bar{
  display:flex;align-items:center;gap:8px;padding:9px 12px;
  background:linear-gradient(180deg,#1a1e2a,#11141c);
  border-bottom:1px solid var(--bdr);
  font-size:10px;letter-spacing:.18em;
  cursor:grab;user-select:none;flex-shrink:0;
  -webkit-user-select:none;
}
.fpanel-bar.dragging{cursor:grabbing}
.fpanel.minimised .fpanel-bar{border-bottom:none;border-radius:6px}
.fpanel-icon{color:var(--blue);font-size:12px}
.fpanel-title{color:var(--text);font-weight:600;letter-spacing:.16em}
.fpanel-sp{flex:1}
.fpanel-btn{
  appearance:none;background:transparent;border:1px solid transparent;
  color:var(--mute);width:22px;height:22px;border-radius:3px;
  cursor:pointer;font-size:12px;font-family:var(--mono);line-height:1;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:color .1s,border-color .1s,background .1s;
  padding:0;
}
.fpanel-btn:hover{color:var(--text);border-color:var(--bhi);background:var(--elev)}
.fpanel-btn.cls:hover{color:var(--red);border-color:var(--red)}
.fpanel-body{
  overflow-y:auto;overflow-x:hidden;
  padding:10px 12px 12px;
  display:flex;flex-direction:column;gap:9px;
  /* height is set dynamically via JS */
}
.fpanel-body::-webkit-scrollbar{width:5px}
.fpanel-body::-webkit-scrollbar-thumb{background:var(--bhi);border-radius:3px}
.fpanel-resize{
  position:absolute;bottom:0;right:0;
  width:18px;height:18px;cursor:se-resize;z-index:10;
  /* SE corner grip lines */
  background:
    linear-gradient(135deg,transparent 40%,var(--bhi) 40%,var(--bhi) 46%,transparent 46%),
    linear-gradient(135deg,transparent 55%,var(--bhi) 55%,var(--bhi) 61%,transparent 61%),
    linear-gradient(135deg,transparent 70%,var(--bhi) 70%,var(--bhi) 76%,transparent 76%);
}

/* right-column launch strip */
.rc{
  display:flex;flex-direction:column;gap:5px;
  padding:6px 4px;overflow-y:auto;width:100%;
}
.panel-launch{
  display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:var(--panel);border:1px solid var(--bdr);border-radius:5px;
  font-size:10px;letter-spacing:.14em;cursor:pointer;user-select:none;
  transition:border-color .12s,background .12s,color .12s;white-space:nowrap;
}
.panel-launch:hover{border-color:var(--blue);background:var(--elev);color:var(--blue)}
.panel-launch.open{border-color:var(--blue);color:var(--blue);
  background:rgba(61,155,255,.07);}
.panel-launch .pi{color:var(--blue);width:14px;text-align:center;flex-shrink:0}

/* per-effect reset button */
.fx-reset{
  appearance:none;background:transparent;border:1px solid var(--bdr);
  color:var(--mute);width:18px;height:18px;border-radius:3px;
  cursor:pointer;font-size:10px;font-family:var(--mono);line-height:1;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  padding:0;transition:color .1s,border-color .1s;
}
.fx-reset:hover{color:var(--orange);border-color:var(--orange)}
.fx-reset:active{color:var(--red)}

/* crossfade overlay canvas — opacity animated by JS */
#xfCanvas{position:absolute;inset:0;pointer-events:none;z-index:3;opacity:0;}

/* Recent strip: slot number badge */
.rtile{position:relative}
.rtile-num{position:absolute;top:1px;left:2px;font-size:7px;color:var(--blue);
  background:rgba(0,0,0,.7);padding:0 2px;border-radius:2px;line-height:1.4}

/* FX row key hint */
.fxkey{font-size:8px;color:var(--mute);letter-spacing:.08em;margin-left:3px}
.fxrow.bnd .fxkey{color:var(--orange)}

/* Mapping list: grows to fill the panel as it resizes */
/* mapping list: takes all remaining vertical space inside the section */
#mlist.mlist{flex:1 1 auto;min-height:60px;overflow-y:auto;display:grid;grid-template-columns:1fr;gap:4px}
/* H11: 2-column bindings list when panel is wide (msection-grow provides the container) */
.msection.msection-grow{container-type:inline-size}
@container (min-width:460px){#mlist.mlist{grid-template-columns:1fr 1fr}}

/* MAPPING PANEL SECTIONS — collapsible */
.msection{display:flex;flex-direction:column;background:var(--elev);border:1px solid var(--bdr);
  border-radius:4px;overflow:hidden;flex-shrink:0}
.msection.msection-grow{flex:1 1 auto;min-height:120px}
.msection-hdr{display:flex;align-items:center;gap:6px;padding:5px 8px;background:var(--card);
  cursor:pointer;user-select:none;font-size:9px;letter-spacing:.18em;
  border-bottom:1px solid var(--bdr);transition:background .12s}
.msection-hdr:hover{background:var(--bhi)}
.msection-hdr.static{cursor:default}
.msection-hdr.static:hover{background:var(--card)}
.ms-chev{font-size:8px;color:var(--blue);transition:transform .15s}
.msection.collapsed .ms-chev{transform:rotate(-90deg)}
.msection.collapsed .msection-body{display:none}
.ms-title{color:var(--text);font-weight:600;flex-shrink:0}
.ms-meta{flex:1;text-align:right;font-size:8px;color:var(--mute);letter-spacing:.12em}
.msection-body{padding:6px;display:flex;flex-direction:column;gap:5px;overflow-y:auto;max-height:280px}
.msection.msection-grow > .msection-body{flex:1 1 auto;max-height:none}
.msection.msection-grow > .mlist{margin:5px;padding:0}

/* Active preset card highlight (when its preset is currently loaded) */
.preset-card.active-preset{
  border-color:var(--green) !important;
  box-shadow:0 0 0 1px var(--green), 0 0 12px rgba(0,229,137,.35);
  background:linear-gradient(180deg, rgba(0,229,137,.08), var(--card));
}
.preset-card.active-preset .pcname{color:var(--green)}

/* Bottom-dock panel (DECK) */
.fpanel-bottom{
  position:fixed;bottom:0;left:0;right:0;z-index:200;
  border-radius:6px 6px 0 0;border-bottom:none;
  width:100% !important;
}
.fpanel-bottom .fpanel-body{flex-direction:row;overflow:hidden}

/* FX key hint bar in panel header */
.fx-hint-row{font-size:8px;color:var(--mute);letter-spacing:.1em;
  padding:3px 0 5px;border-bottom:1px solid var(--bdr);margin-bottom:2px}

/* Preset hotkey hint in mapping panel */
.preset-hint{font-size:8px;color:var(--mute);letter-spacing:.1em;
  padding:2px 0 4px;border-bottom:1px solid var(--bdr)}

/* Active/on state for fpanel-btn */
.fpanel-btn.on{color:var(--green);border-color:var(--green);border:1px solid}

/* ── Preset grid (Task 1) ── */
#psetgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:5px;margin-bottom:6px}
.preset-card{background:var(--card);border:1px solid var(--bdr);border-radius:4px;
  padding:6px 8px;cursor:pointer;transition:border-color .1s}
.preset-card:hover{border-color:var(--blue)}
.preset-card.user-preset{border-color:var(--orange)}
.pcname{font-size:10px;font-weight:600;display:flex;align-items:center;gap:4px;margin-bottom:2px}
.pckey{font-size:8px;color:var(--blue);background:rgba(61,155,255,.15);
  padding:1px 4px;border-radius:2px;letter-spacing:.1em}
.pcmeta{font-size:8px;color:var(--mute);margin-bottom:4px}
.pccontrols{display:flex;gap:4px;align-items:center}
.pccontrols .btn{font-size:8px;padding:2px 5px}
.pctoggle{display:flex;align-items:center;gap:3px;font-size:8px;color:var(--dim);cursor:pointer}
.pctoggle input{accent-color:var(--orange);width:12px;height:12px}

/* ── Ghost fade bar (Task 2) ── */
.ghostbar{grid-column:1/-1;height:3px;background:var(--elev);border-radius:2px;overflow:hidden;margin-top:2px}
.ghostfill{height:100%;background:var(--orange);width:100%;transition:none;box-shadow:0 0 4px var(--orange)}

/* OVERLAY CLOSE BUTTON */
.obclose{appearance:none;background:transparent;border:1px solid var(--bhi);
  color:var(--mute);width:26px;height:26px;border-radius:4px;cursor:pointer;
  font-size:12px;font-family:var(--mono);transition:color .1s,border-color .1s}
.obclose:hover{color:var(--red);border-color:var(--red)}

/* UPLOAD ZONE */
.oupload-zone{display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 16px;border:1px dashed var(--bhi);border-radius:6px;margin:8px 0;
  transition:border-color .15s}
.oupload-zone:hover{border-color:var(--blue)}

/* ───── VARIANTS TAB ───── */
.variants-pane{display:flex;flex-direction:column;gap:10px;padding:8px}
.variants-header{display:flex;align-items:baseline;gap:8px;padding-bottom:6px;
  border-bottom:1px solid var(--bdr)}
.vh-label{font-size:8px;color:var(--mute);letter-spacing:.18em}
.vh-name{font-size:11px;color:var(--text);letter-spacing:.14em;font-weight:600}
.vh-meta{flex:1;text-align:right;font-size:8px;color:var(--mute);letter-spacing:.1em}

.variants-compass{
  display:grid;grid-template-columns:1fr 1.4fr 1fr;
  grid-template-rows:auto auto auto;gap:6px;
  align-items:center;justify-items:center;
  padding:6px;background:var(--card);border-radius:5px;
}
.vc-tile{
  position:relative;width:100%;aspect-ratio:16/9;
  border:2px solid;border-radius:4px;overflow:hidden;
  cursor:default;transition:transform .12s, box-shadow .12s;
}
.vc-tile:hover{transform:scale(1.04);box-shadow:0 0 12px rgba(255,255,255,.15)}
.vc-tile img{width:100%;height:100%;object-fit:cover;display:block}
.vc-tile-label{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;justify-content:space-between;
  padding:3px 6px;font-size:8px;letter-spacing:.14em;font-weight:600;
  background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);
}
.vc-tile-pct{color:var(--text);font-variant-numeric:tabular-nums}

.vc-centre{
  position:relative;width:100%;aspect-ratio:16/9;
  border:2px solid var(--green);border-radius:5px;overflow:hidden;
  box-shadow:0 0 16px rgba(0,229,137,.3);
}
.vc-centre img{width:100%;height:100%;object-fit:cover;display:block}
.vc-centre-label{
  position:absolute;bottom:0;left:0;right:0;
  padding:3px 6px;font-size:9px;letter-spacing:.14em;
  background:linear-gradient(0deg,rgba(0,229,137,.6),transparent);
  color:#000;font-weight:600;text-align:center;
}

.variants-sliders{display:flex;flex-direction:column;gap:4px}
.vs-row{
  display:grid;grid-template-columns:18px 60px 1fr 38px 50px;
  gap:6px;align-items:center;
  padding:5px 8px;background:var(--card);border:1px solid var(--bdr);border-radius:4px;
}
.vs-emoji{font-size:11px;text-align:center;color:var(--dim)}
.vs-label{font-size:9px;letter-spacing:.14em;font-weight:600}
.vs-slider{accent-color:var(--orange);height:3px}
.vs-val{font-size:9px;text-align:right;color:var(--dim);font-variant-numeric:tabular-nums}
.vs-use{font-size:8px;padding:3px 5px;letter-spacing:.1em}

.variants-audiobind{
  background:var(--card);border:1px solid var(--bdr);
  border-radius:4px;padding:8px;
}
.vab-title{font-size:8px;color:var(--blue);letter-spacing:.18em;
  margin-bottom:5px;font-weight:600}
.vab-row{display:flex;gap:5px;align-items:center;margin-bottom:5px}
.vab-row select{flex:1;font-size:9px}
.vab-row .btn{font-size:9px;padding:4px 8px;letter-spacing:.14em}
.vab-row .btn.on{color:var(--green);border-color:var(--green);
  box-shadow:0 0 8px rgba(0,229,137,.3)}
.vab-hint{font-size:8px;color:var(--mute);line-height:1.4;letter-spacing:.05em}

/* ── Threshold UI additions ── */
/* Binding card mbar wrapper — allows threshold line to overlay the fill */
.mbar-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
  grid-column: 1 / -1;
}
.mbar-wrap .mbar {
  flex: 1;
  height: 8px;
  background: var(--card);
  border: 1px solid var(--bhi);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
  cursor: crosshair;
}
.mbar-wrap .mfill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  background: var(--blue);
  transition: width 60ms linear;
}
.mbar-wrap .mthresh {
  position: absolute;
  top: -1px;
  bottom: -1px;
  width: 2px;
  background: var(--orange);
  cursor: ew-resize;
  box-shadow: 0 0 4px var(--orange);
  z-index: 2;
}
.thresh-val {
  font-size: 7px;
  color: var(--orange);
  letter-spacing: .1em;
  white-space: nowrap;
  min-width: 44px;
}

/* Meters mbar threshold line */
.mthresh-band {
  position: absolute;
  top: -1px;
  bottom: -1px;
  width: 2px;
  background: var(--orange);
  cursor: ew-resize;
  box-shadow: 0 0 4px var(--orange);
  z-index: 2;
  transition: background .1s, box-shadow .1s;
}

/* Slideshow on/active button style (already had .on but reinforcing) */
#ss-shuffle.on, #ss-randxf.on {
  color: var(--green);
  border-color: var(--green);
}
