:root{--bg:#0e1014;--panel:#171a21;--panel2:#1f242e;--line:#2a303c;--txt:#e6e9ef;
  --dim:#8b93a4;--accent:#5ad1c4;--accent2:#f0a14e}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--txt);overflow:hidden;
  font:13px/1.4 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
#app{display:flex;flex-direction:column;height:100vh}
header{display:flex;align-items:center;gap:10px;padding:9px 14px;background:var(--panel);
  border-bottom:1px solid var(--line);flex:0 0 auto}
header h1{font-size:13px;margin:0;font-weight:600} header h1 span{color:var(--accent)}
.btn{background:var(--accent);color:#04201c;border:0;padding:7px 13px;border-radius:6px;
  font-weight:600;cursor:pointer;font-size:12px}
.btn:hover{filter:brightness(1.08)}
.btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
.btn.ghost.on{border-color:var(--accent);color:var(--accent)}
.btn.play{background:var(--accent2);color:#2a1500;min-width:74px}
#pick{background:var(--accent2);color:#2a1500}   /* same amber as the Play button */
.seg{display:flex;background:var(--panel2);border:1px solid var(--line);border-radius:7px;overflow:hidden}
.seg button{background:none;border:0;color:var(--dim);padding:7px 14px;cursor:pointer;font-weight:600;font-size:12px}
.seg button.on{background:var(--accent);color:#04201c}
#search{flex:1;max-width:260px;background:var(--panel2);border:1px solid var(--line);
  color:var(--txt);padding:7px 10px;border-radius:6px;outline:none}
.bpm{display:flex;align-items:center;gap:6px;color:var(--dim)}
.bpm input{width:70px;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  padding:6px;border-radius:6px;outline:none;text-align:center}
.mvol{display:flex;align-items:center;gap:6px;color:var(--dim);font-size:11px}
.mvol input{width:92px;accent-color:var(--accent2)}
.stat{color:var(--dim);font-size:12px;margin-left:auto}
main{flex:1;min-height:0;position:relative}
/* ---- MAP VIEW ---- */
#mapview{position:absolute;inset:0;display:flex}
#side{width:180px;flex:0 0 auto;background:var(--panel);border-right:1px solid var(--line);overflow:auto;padding:8px}
#side h3{font-size:10px;letter-spacing:1px;color:var(--dim);margin:4px 6px 8px;text-transform:uppercase}
.crumbs{padding:2px 6px 8px;font-size:11px;border-bottom:1px solid var(--line);margin-bottom:6px;line-height:1.7}
.crumb{cursor:pointer;color:var(--accent)} .crumb:hover{text-decoration:underline}
.crumb.last{color:var(--txt);cursor:default} .csep{color:var(--dim)}
.cat{display:flex;justify-content:space-between;align-items:center;padding:5px 9px;border-radius:6px;cursor:pointer;color:var(--dim)}
.cat:hover{background:var(--panel2)}
.cat .lbl{display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cat .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.cat .n{font-size:10px;background:#0c0e12;padding:1px 6px;border-radius:10px}
#stage{flex:1;display:flex;flex-direction:column;min-width:0}
#selbar{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:6px 12px;border-bottom:1px solid var(--line);background:var(--panel)}
#selname{font-size:12px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
#selname b{color:var(--txt)}
#target{font-size:11px;color:var(--accent2);font-weight:600;white-space:nowrap}
#wave{width:150px;height:32px;background:#0a0c10;border-radius:5px;flex:0 0 auto}
#mapwrap{flex:1;position:relative;min-height:0}
#map{width:100%;height:100%;display:block;background:radial-gradient(ellipse at center,#12161d,#0a0c10 72%);cursor:crosshair}
#maphint{position:absolute;top:10px;left:14px;color:var(--dim);font-size:12px;pointer-events:none}
#prog{position:absolute;top:10px;right:14px;color:var(--accent);font-size:12px;pointer-events:none}
.legend{flex:0 0 auto;display:flex;flex-wrap:wrap;gap:8px;padding:5px 12px;font-size:10px;color:var(--dim);border-top:1px solid var(--line);background:var(--panel)}
.legend span{display:inline-flex;align-items:center;gap:4px;cursor:pointer;padding:2px 6px;border-radius:10px}
.legend span:hover{background:var(--panel2)} .legend span.off{opacity:.32}
.legend i{width:8px;height:8px;border-radius:50%}
.welcome{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;text-align:center;color:var(--dim)}
.welcome a{color:var(--accent);text-decoration:none;font-weight:600}
.welcome a:hover{text-decoration:underline}
code{background:#0c0e12;padding:1px 5px;border-radius:4px;color:var(--accent2)}
/* ---- SEQUENCER VIEW ---- */
#seqview{position:absolute;inset:0;display:none;flex-direction:column;overflow:auto}
#fxpanel{flex:0 0 auto;background:var(--panel);border-bottom:1px solid var(--line);padding:9px 14px;
  display:flex;align-items:center;gap:14px}
#fxpanel .ttl{font-weight:600;color:var(--accent)}
.fxhint{color:var(--dim);font-size:11px}
#grid{padding:10px 14px;min-width:max-content}
.track{display:flex;align-items:center;gap:8px;margin-bottom:6px}
/* per-track rotary knobs */
.knobs{display:flex;gap:5px;flex:0 0 auto;padding:0 8px}
.knob2{width:40px;text-align:center;cursor:ns-resize;user-select:none;touch-action:none}
.knob2 svg{width:36px;height:36px;display:block;margin:0 auto}
.knob2 .kt{stroke:#2a303c}
.knob2 .klabel{font-size:8px;letter-spacing:.4px;color:var(--dim);margin-top:-3px}
.knob2 .kval{font-size:9px;color:var(--txt);font-variant-numeric:tabular-nums;line-height:1.1}
.knob2:hover .klabel{color:var(--accent)} .knob2:hover .kp{r:3}
.slot{width:190px;flex:0 0 auto;display:flex;align-items:center;gap:7px;background:var(--panel2);
  border:1px solid var(--line);border-radius:6px;padding:5px 8px;height:30px;cursor:pointer}
.slot.active{border-color:var(--tcol,var(--accent))}
.slot .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto;background:#333}
.slot .tn{flex:1;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--dim)}
.slot .tn.has{color:var(--txt)}
.slot .m{font-size:10px;border:1px solid var(--line);border-radius:4px;padding:1px 5px;color:var(--dim)}
.slot .m.on{background:#ff6b6b22;border-color:#ff6b6b;color:#ff6b6b}
.slot .ld{font-size:12px;border:1px solid var(--line);border-radius:4px;padding:0 5px;color:var(--dim)}
.slot .ld:hover{border-color:var(--accent);color:var(--accent)}
.fxbtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:6px;
  padding:6px 11px;cursor:pointer;font-size:11px;font-weight:600}
.fxbtn:hover{border-color:var(--accent);color:var(--accent)}
.steps{display:flex;gap:3px}
.step{width:21px;height:30px;border-radius:4px;background:#11151b;border:1px solid #232a35;cursor:pointer}
.step.g{margin-left:8px} .step.on{background:var(--tcol,var(--accent));border-color:var(--tcol,var(--accent))}
.step.play{outline:2px solid var(--accent2);outline-offset:-2px}
.hint{color:var(--dim);font-size:11px;padding:0 14px 12px}
