*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg: #0f0f14;
  --surface: rgba(255,255,255,0.06);
  --surface2: rgba(255,255,255,0.10);
  --glass: rgba(255,255,255,0.08);
  --border: rgba(255,255,255,0.12);
  --border2: rgba(255,255,255,0.18);
  --text: #f0f0f8;
  --text2: rgba(240,240,248,0.55);
  --text3: rgba(240,240,248,0.28);
  --mono: 'JetBrains Mono', monospace;
  --sans: 'DM Sans', sans-serif;
  --head: 'Space Grotesk', sans-serif;

  /* Signature gradient palette */
  --lime:   #b4f542;
  --cyan:   #3de8c8;
  --coral:  #ff6b6b;
  --violet: #c77dff;
  --amber:  #ffd166;
  --sky:    #48cae4;

  --g-play: linear-gradient(135deg,#b4f542,#3de8c8);
  --g-stop: linear-gradient(135deg,#ff6b6b,#ff944d);
  --g-part: linear-gradient(135deg,#c77dff,#48cae4);
  --g-bar:  linear-gradient(135deg,#ffd166,#ff944d);

  --nav-h: 76px;
  --safe-b: env(safe-area-inset-bottom, 0px);
}

html,body{height:100%;overflow:hidden}
body{
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 60% 40% at 20% 0%, rgba(180,245,66,.07) 0%, transparent 60%),
    radial-gradient(ellipse 50% 35% at 80% 100%, rgba(71,212,255,.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(199,125,255,.04) 0%, transparent 70%);
  color: var(--text);
  font-family: var(--sans);
  display: flex;
  flex-direction: column;
}

/* ── GLOBAL SCROLLBAR ── */
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

/* ── STATUS BAR AREA ── */
.status-bar{
  height: env(safe-area-inset-top, 20px);
  background: rgba(15,15,20,0.95);
  flex-shrink: 0;
}

/* ── TOP HEADER ── */
.top-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  flex-shrink: 0;
  border-bottom: 1px solid var(--border);
  background: rgba(15,15,20,0.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  position: sticky;
  top: 0;
  z-index: 150;
  gap: 8px;
  min-height: 50px;
}
.app-title{
  font-family: var(--head);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.02em;
  background: var(--g-play);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
  flex-shrink: 0;
}
.header-pills{
  display:flex;gap:5px;align-items:center;
  flex:1;                    /* take remaining space */
  overflow-x:auto;           /* scroll horizontally */
  overflow-y:hidden;
  justify-content:flex-end;  /* right-align */
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:1px;        /* prevent scrollbar flash */
}
.header-pills::-webkit-scrollbar{display:none}
.pill-btn{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text2);
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
  letter-spacing: .05em;
}
.pill-btn:hover,.pill-btn.active{
  background: var(--surface2);
  border-color: var(--border2);
  color: var(--text);
}
.pill-btn.stage-active{
  background: linear-gradient(135deg,rgba(180,245,66,.2),rgba(61,232,200,.2));
  border-color: var(--lime);
  color: var(--lime);
}

/* ── LIVE COUNTER BAR ── */
.live-bar{
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 20px;
  flex-shrink: 0;
  background: rgba(15,15,20,0.5);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.live-counter{
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  border-right: 1px solid var(--border);
  position: relative;
}
.live-counter:last-child{border-right:none}
.lc-label{
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 2px;
}
.lc-value{
  font-family: var(--mono);
  font-size: 32px;
  font-weight: 600;
  line-height: 1;
  transition: color .15s;
}
.lc-bar .lc-value{ color: var(--cyan); }
.lc-beat .lc-value{ color: var(--coral); }
.lc-bpm .lc-value{ font-size: 22px; color: var(--lime); }
.lc-part .lc-value{
  font-family: var(--head);
  font-size: 14px;
  font-weight: 700;
  color: var(--violet);
  max-width: 100px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Time counter — smaller, less space */
.lc-time{flex:0.6}
.lc-time .lc-value{ font-size: 13px; color: var(--text2); line-height:1.2; }
  font-family: var(--head);
  font-size: 14px;
  font-weight: 700;
  color: var(--violet);
  max-width: 100px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Flash animation */
@keyframes flash-beat{0%{opacity:1;transform:scale(1.08)}100%{opacity:1;transform:scale(1)}}
.lc-value.flash{animation:flash-beat .12s ease-out}

/* ── MAIN CONTENT AREA ── */
.main-content{
  flex: 1;
  overflow: hidden;
  position: relative;
  background: var(--bg);
}
.tab-panel{
  position: absolute;
  inset: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 16px 16px calc(var(--nav-h) + var(--safe-b) + 16px);
  display: none;
  flex-direction: column;
  gap: 14px;
  scroll-behavior: smooth;
  background: var(--bg);
  z-index: 0;
}
.tab-panel.active{display:flex;z-index:2}

/* ── GLASS CARD ── */
.gcard{
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.gcard-label{
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  overflow: hidden;
}
.gcard-label>span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gcard-label-accent{
  display: inline-block;
  width: 6px;height: 6px;
  border-radius: 50%;
  background: var(--g-play);
  margin-right: 7px;
  vertical-align: middle;
}

/* ── WAVEFORM ── */
.waveform-wrap{
  position: relative;
  height: 72px;
  border-radius: 12px;
  overflow: hidden;
  background: rgba(0,0,0,.3);
  cursor: pointer;
}
canvas#waveform{width:100%;height:100%;display:block}
#playhead{
  position: absolute;top:0;bottom:0;width:2px;
  background: var(--lime);
  box-shadow: 0 0 12px var(--lime);
  pointer-events: none;
  left: 0;
}
.loop-region{
  position:absolute;top:0;bottom:0;
  background:rgba(61,232,200,.15);
  border-left:2px solid var(--cyan);
  border-right:2px solid var(--cyan);
  pointer-events:none;
}
#tapAlignOverlay{
  position:absolute;inset:0;border-radius:12px;
  background:rgba(180,245,66,.08);
  border:2px dashed var(--lime);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s;pointer-events:none;
}
#tapAlignOverlay.active{opacity:1}

/* ── BEAT GRID ── */
.beat-grid{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.beat-cell{
  flex:1 1 auto;min-width:32px;max-width:52px;height:42px;
  border-radius:10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;
  color: var(--text3);
  transition: all .08s;
}
.beat-cell.downbeat{border-color:rgba(255,255,255,.14);color:var(--text2)}
.beat-cell.active{
  background: rgba(180,245,66,.25);
  border-color: var(--lime);
  color: var(--lime);
  font-weight:600;
  box-shadow: 0 0 16px rgba(180,245,66,.4);
}
.beat-cell.active.downbeat-active{
  background: rgba(255,107,107,.25);
  border-color: var(--coral);
  color: var(--coral);
  box-shadow: 0 0 20px rgba(255,107,107,.5);
}
.beat-cell.countin-active{
  background: rgba(199,125,255,.25);
  border-color: var(--violet);
  color: var(--violet);
  box-shadow: 0 0 16px rgba(199,125,255,.4);
}

/* ── BIG TRANSPORT BUTTONS ── */
.transport-row{display:flex;gap:12px;align-items:center}
.btn-play{
  flex: 1;
  height: 68px;
  border-radius: 16px;
  border: none;
  background: var(--g-play);
  color: #0f1a0a;
  font-family: var(--head);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: .05em;
  cursor: pointer;
  display: flex;align-items:center;justify-content:center;gap:8px;
  transition: transform .15s, box-shadow .15s;
  box-shadow: 0 4px 24px rgba(180,245,66,.3);
}
.btn-play:hover{transform:translateY(-1px);box-shadow:0 6px 32px rgba(180,245,66,.4)}
.btn-play:active{transform:scale(.97)}
.btn-play:disabled{opacity:.4;transform:none;box-shadow:none;cursor:not-allowed}
.btn-stop{
  width: 68px;height: 68px;
  border-radius: 16px;
  border: 1px solid rgba(255,107,107,.3);
  background: rgba(255,107,107,.12);
  color: var(--coral);
  font-size: 24px;
  cursor: pointer;
  display:flex;align-items:center;justify-content:center;
  transition: all .15s;
}
.btn-stop:hover{background:rgba(255,107,107,.22);border-color:rgba(255,107,107,.5)}
.btn-tap{
  width: 68px;height: 68px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: var(--surface);
  color: var(--text2);
  font-family: var(--mono);
  font-size: 10px;
  font-weight:600;
  letter-spacing:.05em;
  cursor: pointer;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px;
  transition: all .15s;
}
.btn-tap:active{background:var(--surface2);transform:scale(.95)}

/* ── BPM CONTROL ── */
.bpm-control{display:flex;align-items:center;gap:16px}
.bpm-big{
  font-family: var(--mono);
  font-size: 56px;
  font-weight: 600;
  line-height: 1;
  background: var(--g-play);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  min-width: 100px;
}
.bpm-controls-col{flex:1;display:flex;flex-direction:column;gap:8px}
input[type=range]{
  -webkit-appearance:none;appearance:none;
  width:100%;height:5px;
  background:rgba(255,255,255,.12);
  border-radius:3px;outline:none;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--g-play);
  box-shadow:0 0 10px rgba(180,245,66,.5);
  cursor:pointer;transition:transform .1s;
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}

/* ── SELECTS / INPUTS ── */
select,input[type=number],input[type=text]{
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13px;
  padding: 10px 14px;
  border-radius: 10px;
  width: 100%;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  transition: border-color .15s;
}
select:focus,input:focus{border-color:rgba(255,255,255,.3)}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.setting-block{display:flex;flex-direction:column;gap:6px}
.setting-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--text3);text-transform:uppercase}

/* ── SETLIST ── */
.set-item{
  display:flex;align-items:center;gap:8px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 10px 12px;
  cursor: pointer;
  transition: all .15s;
  user-select: none;
  min-width:0;
  overflow:hidden;
}
.set-item:active,.set-item:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}
.set-item.active{
  background: rgba(180,245,66,.08);
  border-color: rgba(180,245,66,.3);
}
.set-item.playing{
  background: rgba(255,107,107,.08);
  border-color: rgba(255,107,107,.3);
  box-shadow: 0 0 20px rgba(255,107,107,.1);
}
.set-num{font-family:var(--mono);font-size:11px;color:var(--text3);min-width:18px;text-align:right;flex-shrink:0}
.set-name{
  font-family:var(--head);font-size:14px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  min-width:0;
}
.set-meta{font-family:var(--mono);font-size:10px;color:var(--text3);white-space:nowrap;flex-shrink:0}
/* Primary buttons always visible */
.set-btns{display:flex;gap:3px;flex-shrink:0;align-items:center}
/* Secondary buttons — hidden by default on mobile, shown on desktop or when expanded */
.set-btns-secondary{display:none;gap:3px;align-items:center}
.set-item.expanded .set-btns-secondary{display:flex}
.icon-btn{
  background:none;border:none;cursor:pointer;
  font-size:15px;color:var(--text3);
  padding:4px 5px;border-radius:7px;transition:all .1s;
  flex-shrink:0;
  /* Larger tap target on mobile */
  min-width:32px;min-height:32px;
  display:flex;align-items:center;justify-content:center;
}
.icon-btn:hover{color:var(--text);background:rgba(255,255,255,.06)}
.icon-btn.del:hover{color:var(--coral)}
.icon-btn.more-btn{font-size:14px;letter-spacing:1px}
.drag-handle{font-size:13px;color:var(--text3);cursor:grab;padding:0 2px;flex-shrink:0}

/* Desktop — always show all buttons */
@media(min-width:1025px){
  .set-name{font-size:15px}
  .set-btns-secondary{display:flex !important}
  .icon-btn.more-btn{display:none !important}
  .set-item{padding:12px 14px;gap:10px}
}

.add-song-zone{
  border: 2px dashed rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  cursor: pointer;
  position: relative;
  transition: all .2s;
  margin-top: 4px;
}
.add-song-zone:hover,.add-song-zone.drag-over{
  border-color: rgba(180,245,66,.4);
  background: rgba(180,245,66,.04);
}
.add-song-zone input{position:absolute;inset:0;opacity:0;cursor:pointer}
.add-zone-text{
  font-family:var(--head);font-size:15px;font-weight:600;
  color:var(--text3);letter-spacing:.02em;
}

/* ── PARTS ── */
.part-row-wrap{margin-bottom:6px;border-radius:14px;overflow:hidden}
.part-row{
  display:flex;align-items:center;gap:8px;
  padding:12px 14px;
  transition:all .15s;
}
.part-name-col{flex:1;min-width:0;overflow:hidden}
.part-name{font-family:var(--head);font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.part-bars-badge{
  font-family:var(--mono);font-size:10px;
  padding:3px 8px;border-radius:6px;
  background:rgba(0,0,0,.25);color:inherit;
  white-space:nowrap;flex-shrink:0;
}
.part-btns{display:flex;gap:4px;flex-shrink:0;align-items:center}
.part-action-btn{
  width:32px;height:32px;border-radius:8px;border:none;
  background:rgba(255,255,255,.07);  /* always visible */
  color:rgba(255,255,255,.5);
  cursor:pointer;font-size:13px;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;flex-shrink:0;
}
.part-action-btn:active{background:rgba(255,255,255,.18);transform:scale(.92)}
.part-action-btn.jump{background:rgba(180,245,66,.15);color:var(--lime)}
.part-action-btn.gear{background:rgba(255,255,255,.07);color:rgba(255,255,255,.45)}
.part-action-btn.gear.open{background:rgba(180,245,66,.2);color:var(--lime)}
.part-action-btn.cues-btn{background:rgba(71,212,255,.1);color:var(--cyan)}
.part-action-btn.del-btn{background:rgba(255,107,107,.1);color:var(--coral)}
.part-expand-panel{
  padding:14px;
  background:rgba(0,0,0,.2);
  border-top:1px solid rgba(255,255,255,.06);
}

/* ── CUE ITEMS ── */
.cue-list{overflow-y:auto;max-height:160px}
.cue-item{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
  padding:8px 10px;
  font-family:var(--mono);font-size:11px;
  margin-bottom:5px;
  min-width:0;
  flex-wrap:nowrap;
}
.cue-scope{font-size:8px;padding:2px 6px;border-radius:4px;background:rgba(199,125,255,.2);color:var(--violet);flex-shrink:0;white-space:nowrap}
.cue-time{color:var(--cyan);min-width:48px;flex-shrink:0;white-space:nowrap}
.cue-text{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.cue-voice-badge{font-size:8px;padding:1px 5px;border-radius:4px;border:1px solid rgba(255,255,255,.12);color:var(--text3);flex-shrink:0;white-space:nowrap}
.cue-del{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:2px;flex-shrink:0}
.cue-del:hover{color:var(--coral)}

/* ── CHANNEL STRIPS ── */
.strips{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.strip{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  padding:14px 10px 10px;
  width:96px;flex-shrink:0;  /* fixed width so layout is predictable */
  transition:opacity .2s;
  overflow:hidden;  /* clip anything that overflows */
}
.strip.muted{opacity:.4}
.strip-name{
  font-family:var(--mono);font-size:9px;letter-spacing:.14em;
  color:var(--text3);text-transform:uppercase;text-align:center;
  margin-bottom:4px;width:100%;
}
/*
  VERTICAL FADER:
  - fader-wrap is a NARROW container (same width as strip content)
  - We rotate the input -90deg inside it
  - The wrapper clips overflow so layout is correct
  - The input width = travel length (tall fader)
*/
.fader-wrap{
  position:relative;
  width:76px;
  height:190px;
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  touch-action:none;
  user-select:none;-webkit-user-select:none;
}
/* Track line */
.fader-wrap::before{
  content:'';position:absolute;
  left:50%;top:10px;bottom:10px;
  transform:translateX(-50%);
  width:4px;
  background:linear-gradient(to top,rgba(255,255,255,.12) 0%,rgba(180,245,66,.35) 100%);
  border-radius:2px;
  pointer-events:none;
}
/* Thumb — positioned by JS */
.fader-thumb{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#fff 0%,#d8d8d8 38%,#888 100%);
  box-shadow:0 3px 12px rgba(0,0,0,.85),0 0 0 2px rgba(255,255,255,.3);
  pointer-events:none;
  transition:box-shadow .1s;
  z-index:2;
}
.fader-wrap.dragging .fader-thumb{
  box-shadow:0 4px 16px rgba(0,0,0,.9),0 0 0 3px rgba(180,245,66,.5);
}
/* Hide the old input (keep for value storage only) */
.fader-vert{display:none}
.fader-val{
  font-family:var(--mono);font-size:10px;color:var(--text3);
  text-align:center;width:100%;margin-top:2px;
}
/* L/R/S — below fader, never overlapped */
.strip-ch{display:flex;gap:4px;margin-top:4px;justify-content:center}
.ch-btn{
  font-family:var(--mono);font-size:10px;padding:6px 9px;border-radius:7px;
  cursor:pointer;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);color:var(--text3);
  transition:all .15s;min-width:28px;text-align:center;
  position:relative;z-index:5;
}
.ch-btn:active{transform:scale(.92)}
.ch-btn.active-L{border-color:var(--lime);color:var(--lime);background:rgba(180,245,66,.15);font-weight:700}
.ch-btn.active-R{border-color:var(--cyan);color:var(--cyan);background:rgba(61,232,200,.15);font-weight:700}
.ch-btn.active-S{border-color:var(--violet);color:var(--violet);background:rgba(199,125,255,.15);font-weight:700}
.strip-mute,.strip-solo{
  font-family:var(--mono);font-size:9px;padding:4px 8px;border-radius:6px;cursor:pointer;
  background:none;border:1px solid rgba(255,255,255,.10);color:var(--text3);
  width:100%;text-align:center;transition:all .12s;
}
.strip-mute.muted{background:rgba(255,107,107,.15);border-color:var(--coral);color:var(--coral)}
.strip-solo.soloed{background:rgba(180,245,66,.15);border-color:var(--lime);color:var(--lime)}
.stem-badge{font-family:var(--mono);font-size:8px;padding:1px 5px;border-radius:4px;background:rgba(199,125,255,.15);border:1px solid var(--violet);color:var(--violet)}

/* ── CLOCK ROW ── */
.clock-row{
  display:flex;gap:10px;flex-wrap:wrap;
}
.clock-tile{
  flex:1;min-width:80px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  padding:10px 12px;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.clock-lbl{font-family:var(--mono);font-size:8px;letter-spacing:.16em;color:var(--text3);text-transform:uppercase}
.clock-val{font-family:var(--mono);font-size:18px;font-weight:600}
.clock-elapsed{color:var(--cyan)}
.clock-countdown{color:var(--coral)}
.clock-settime{color:var(--lime)}
.clock-realtime{color:var(--text3)}
.setlist-prog{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-top:10px}
.setlist-prog-fill{height:100%;background:var(--g-play);border-radius:2px;transition:width .5s}

/* ── SECTION TOGGLES / INLINE LOCKS ── */
.inline-lock-btn{
  background:none;border:1px solid rgba(255,255,255,.12);border-radius:8px;
  cursor:pointer;font-size:13px;padding:4px 8px;color:var(--text3);
  transition:all .15s;
}
.inline-lock-btn.locked{border-color:var(--violet);color:var(--violet);background:rgba(199,125,255,.12)}
.card.section-locked{border-color:rgba(199,125,255,.25)}

/* ── SUBDIV / LOOP BTNS ── */
.tool-btn{
  font-family:var(--mono);font-size:10px;font-weight:600;
  padding:8px 14px;border-radius:10px;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:var(--text2);transition:all .15s;white-space:nowrap;
}
.tool-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.tool-btn.active{
  background:rgba(61,232,200,.15);border-color:var(--cyan);color:var(--cyan);
}
.tool-btn.active-lime{background:rgba(180,245,66,.15);border-color:var(--lime);color:var(--lime)}
.tool-btn.active-coral{background:rgba(255,107,107,.15);border-color:var(--coral);color:var(--coral)}

/* ── TEMPO MAP ── */
.tempo-map-list{display:flex;flex-direction:column;gap:5px;max-height:140px;overflow-y:auto}
.tempo-map-row{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:8px;padding:7px 12px;font-family:var(--mono);font-size:12px;
}
.tempo-map-bar{color:var(--cyan);min-width:50px}
.tempo-map-bpm{color:var(--lime);flex:1}
.tempo-map-sig{color:var(--text3);min-width:32px}

/* ── HOTKEY HINTS ── */
.hotkey-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.hotkey-hint{font-family:var(--mono);font-size:10px;color:var(--text3);display:flex;align-items:center;gap:4px}
kbd{
  display:inline-block;font-family:var(--mono);font-size:9px;
  padding:3px 6px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);border-radius:6px;
  color:var(--text2);line-height:1.4;
}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.7);
  display:none;align-items:flex-end;justify-content:center;
  z-index:500;padding:0;
  backdrop-filter:blur(8px);
}
.modal-overlay.open{display:flex}
.modal{
  background:#1a1a24;
  border:1px solid var(--border);
  border-radius:24px 24px 0 0;
  padding:20px 20px calc(var(--safe-b) + 20px);
  width:100%;max-width:600px;
  display:flex;flex-direction:column;gap:14px;
  max-height:85vh;overflow-y:auto;
}
.modal-handle{width:40px;height:4px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 8px}
.modal h2{font-family:var(--head);font-size:20px;font-weight:700;
  background:var(--g-part);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.modal label{font-family:var(--mono);font-size:10px;color:var(--text3);display:block;margin-bottom:4px}
.modal-row{display:flex;gap:10px}
.modal-row>*{flex:1}
.modal-footer{display:flex;gap:10px;justify-content:flex-end}
.modal-section{border-top:1px solid var(--border);padding-top:12px}

/* ── PRIMARY / SECONDARY BUTTONS ── */
.btn{
  font-family:var(--head);font-weight:700;font-size:14px;
  letter-spacing:.02em;text-transform:uppercase;
  padding:12px 22px;border:none;border-radius:12px;cursor:pointer;
  transition:all .15s;
}
.btn-primary{background:var(--g-play);color:#0f1a0a;box-shadow:0 4px 16px rgba(180,245,66,.25)}
.btn-primary:hover{box-shadow:0 6px 24px rgba(180,245,66,.4);transform:translateY(-1px)}
.btn-primary:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.btn-secondary{background:rgba(255,255,255,.07);color:var(--text);border:1px solid rgba(255,255,255,.12)}
.btn-secondary:hover{background:rgba(255,255,255,.12)}
.btn-danger{background:rgba(255,107,107,.12);color:var(--coral);border:1px solid rgba(255,107,107,.25)}
.btn-purple{background:rgba(199,125,255,.12);color:var(--violet);border:1px solid rgba(199,125,255,.25)}

/* ── BOTTOM NAV ── */
.bottom-nav{
  height: calc(var(--nav-h) + var(--safe-b));
  padding-bottom: var(--safe-b);
  background: rgba(15,15,20,0.85);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: stretch;
  position: relative;
  z-index: 100;
  flex-shrink: 0;
}
.nav-item{
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  color: var(--text3);
  transition: color .15s;
  padding-bottom: 6px;
  border: none;
  background: none;
  position: relative;
}
.nav-item.active{color:var(--lime)}
.nav-item.active::before{
  content:'';position:absolute;top:0;left:20%;right:20%;height:2px;
  background:var(--g-play);border-radius:0 0 3px 3px;
}
.nav-icon{font-size:22px;line-height:1}
.nav-label{font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;font-weight:600}

/* ── SETLIST DRAWER ── */
/* ── PLAYLIST SIDE PANEL ── */
/* Backdrop overlay */
.pl-panel-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:400;
  opacity:0;pointer-events:none;
  transition:opacity .25s;
}
.pl-panel-overlay.open{opacity:1;pointer-events:all}

/* Side panel itself */
.pl-panel{
  position:fixed;
  top:0;bottom:0;left:0;
  width:min(320px, 85vw);
  background:#131318;
  border-right:1px solid var(--border);
  z-index:401;
  display:flex;flex-direction:column;
  transform:translateX(-100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  /* Safe area for notch phones */
  padding-top:env(safe-area-inset-top,0px);
}
.pl-panel.open{transform:translateX(0)}

/* Panel header */
.pl-panel-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 16px 12px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.pl-panel-title{
  font-family:var(--head);font-size:18px;font-weight:700;
  background:var(--g-play);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.pl-panel-close{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:var(--text3);cursor:pointer;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.pl-panel-close:hover{background:rgba(255,255,255,.12);color:var(--text)}

/* New setlist button inside panel */
.pl-panel-new{
  margin:12px 16px 8px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:12px;border-radius:12px;cursor:pointer;
  border:2px dashed rgba(180,245,66,.3);
  background:rgba(180,245,66,.05);
  color:var(--lime);font-family:var(--head);font-weight:700;font-size:14px;
  transition:all .18s;flex-shrink:0;
}
.pl-panel-new:hover{background:rgba(180,245,66,.1);border-color:rgba(180,245,66,.5)}
.pl-panel-new:active{transform:scale(.97)}

/* Scrollable list */
.pl-panel-list{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:8px 12px 24px;
  display:flex;flex-direction:column;gap:6px;
  /* iOS momentum scroll */
  -webkit-overflow-scrolling:touch;
}
.pl-panel-list::-webkit-scrollbar{width:3px}
.pl-panel-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

/* Each playlist row */
.pl-item{
  display:flex;align-items:center;gap:0;
  border-radius:12px;overflow:hidden;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:all .15s;flex-shrink:0;
}
.pl-item.active{
  background:rgba(180,245,66,.1);
  border-color:rgba(180,245,66,.35);
}
.pl-item-name{
  flex:1;padding:14px 16px;
  font-family:var(--head);font-size:15px;font-weight:600;
  color:var(--text3);cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  min-width:0;
  transition:color .12s;
}
.pl-item.active .pl-item-name{color:var(--lime)}
.pl-item-actions{
  display:flex;border-left:1px solid rgba(255,255,255,.07);flex-shrink:0;
}
.pl-item-btn{
  width:44px;height:52px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text3);font-size:15px;
  background:none;border:none;
  transition:all .12s;
}
.pl-item-btn:hover{background:rgba(255,255,255,.07);color:var(--text)}
.pl-item-btn.del:hover{background:rgba(255,107,107,.1);color:var(--coral)}
.pl-item-btn + .pl-item-btn{border-left:1px solid rgba(255,255,255,.07)}

/* Trigger button in setlist tab */
.setlist-drawer-bar{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.setlist-drawer-toggle{
  flex:1;display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-radius:12px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text);font-family:var(--head);font-weight:700;font-size:14px;
  transition:all .15s;
}
.setlist-drawer-toggle:hover{background:var(--surface2)}
.setlist-drawer-toggle .pl-icon{font-size:18px;flex-shrink:0}
/* Hide old dropdown */
.setlist-drawer,.pl-tabs{display:none !important}

/* ── STATUS ── */
#status{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:.05em}
#status.ok{color:var(--lime)}
#status.err{color:var(--coral)}
#status.info{color:var(--cyan)}

/* ── PULSE RING ── */
.pulse-ring{
  position:fixed;top:50%;left:50%;width:0;height:0;border-radius:50%;
  transform:translate(-50%,-50%);pointer-events:none;z-index:99;
  border:2px solid var(--coral);opacity:0;
}
.pulse-ring.fire{animation:pulse-out .4s ease-out forwards}
@keyframes pulse-out{0%{width:0;height:0;opacity:.9}100%{width:160px;height:160px;opacity:0}}
#cue-flash{
  position:fixed;top:42%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--head);font-weight:900;font-size:clamp(28px,7vw,56px);
  letter-spacing:.06em;color:var(--cyan);text-shadow:0 0 32px rgba(61,232,200,.7);
  pointer-events:none;opacity:0;z-index:200;text-align:center;text-transform:uppercase;
  transition:opacity .14s;
}

/* ── MIDI BADGE ── */
.midi-badge{
  font-family:var(--mono);font-size:9px;padding:4px 9px;border-radius:6px;
  border:1px solid rgba(255,255,255,.1);color:var(--text3);
}
.midi-badge.connected{border-color:#47ff8a;color:#47ff8a}
.midi-badge.sending{border-color:var(--lime);color:var(--lime);animation:midi-pulse .5s ease-in-out infinite alternate}
@keyframes midi-pulse{from{opacity:.6}to{opacity:1}}

/* ── STAGE MODE ── */
body.stage-mode .live-bar{padding:6px 16px}
body.stage-mode .lc-value{font-size:clamp(48px,12vw,96px)}
body.stage-mode .lc-bpm .lc-value,.lc-time .lc-value{font-size:clamp(32px,8vw,64px)}
body.stage-mode .lc-part .lc-value{font-size:clamp(20px,5vw,40px);max-width:200px}
body.stage-mode .beat-cell{height:58px;font-size:16px}
body.stage-mode #barCounterLabel{font-size:7px;letter-spacing:.12em}

/* ── COLOR DOTS ── */
.color-dot{
  width:22px;height:22px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:all .12s;flex-shrink:0;
}
.color-dot.selected{border-color:#fff;transform:scale(1.15);box-shadow:0 0 8px currentColor}

/* ── PART SETTINGS PANEL ── */
.part-settings-panel{
  background:rgba(180,245,66,.04);
  border:1px solid rgba(180,245,66,.15);
  border-top:none;border-radius:0 0 14px 14px;
  padding:14px;
}

/* ── DRAG OVER ── */
.set-item.drag-over{border-color:rgba(61,232,200,.4);background:rgba(61,232,200,.06)}
.part-row-wrap.part-drag-over{outline:2px solid var(--cyan);border-radius:14px}

/* ── PILL BTN FIXES ── */
.pill-btn{white-space:nowrap;flex-shrink:0}
/* header-pills styles consolidated above */

/* ── LIVE BAR SONG MARQUEE ── */
.lc-song{flex:1.2;min-width:0;overflow:hidden}
.live-song-marquee-wrap{
  width:100%;overflow:hidden;
  position:relative;
}
.live-song-marquee{
  font-family:var(--head);font-size:12px;font-weight:700;
  color:var(--text2);white-space:nowrap;
  display:inline-block;
  /* Start paused — JS adds .scrolling when text overflows */
}
.live-song-marquee.scrolling{
  animation:marquee-scroll 12s linear infinite;
}
@keyframes marquee-scroll{
  0%   {transform:translateX(0)}
  15%  {transform:translateX(0)}          /* pause at start */
  80%  {transform:translateX(var(--marquee-offset,-100%))} /* scroll to end */
  85%  {transform:translateX(var(--marquee-offset,-100%))} /* pause at end */
  100% {transform:translateX(0)}          /* jump back */
}

/* ── PUBLIC SONG BANK ── */
.pub-bank-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.03);border-radius:12px 12px 0 0;
  flex-shrink:0;gap:8px;
}
.pub-bank-tab{
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 12px;border-radius:8px;cursor:pointer;
  background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text3);
  transition:all .15s;
}
.pub-bank-tab.active{background:rgba(180,245,66,.12);border-color:rgba(180,245,66,.3);color:var(--lime)}
.pub-song-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.05);
  cursor:pointer;transition:background .12s;
}
.pub-song-row:hover{background:rgba(255,255,255,.05)}
.pub-song-info{flex:1;min-width:0}
.pub-song-name{font-family:var(--head);font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;color:var(--text);white-space:nowrap}
.pub-song-meta{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:2px}
.pub-song-add{
  flex-shrink:0;padding:6px 12px;border-radius:8px;border:none;
  background:rgba(180,245,66,.12);color:var(--lime);
  font-family:var(--head);font-weight:700;font-size:12px;cursor:pointer;
  transition:all .14s;white-space:nowrap;
}
.pub-song-add:active{transform:scale(.94)}
.pub-pagination{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:12px;border-top:1px solid var(--border);flex-shrink:0;
}
.pub-page-btn{
  padding:7px 14px;border-radius:8px;border:1px solid var(--border);
  background:var(--surface);color:var(--text);font-family:var(--mono);font-size:11px;
  cursor:pointer;transition:all .14s;
}
.pub-page-btn:disabled{opacity:.35;cursor:not-allowed}
.pub-page-info{font-family:var(--mono);font-size:11px;color:var(--text3)}
.bank-action-bar{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:14px;
  flex-shrink:0;
  /* Sticky so it stays visible when list scrolls */
  position:sticky;
  top:8px;
  z-index:10;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  background:rgba(15,15,20,.92);
}
.bank-upload-btn{
  display:flex;align-items:center;justify-content:center;
  padding:8px 12px;
  border-radius:10px;
  background:rgba(180,245,66,.1);
  border:1px solid rgba(180,245,66,.25);
  color:var(--lime);
  font-family:var(--head);font-weight:700;font-size:12px;
  cursor:pointer;white-space:nowrap;
  transition:all .15s;
}
.bank-upload-btn:hover{background:rgba(180,245,66,.18);border-color:rgba(180,245,66,.45)}
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;padding:12px 14px;
  cursor:pointer;transition:all .15s;user-select:none;
  margin-bottom:6px;
}
.bank-item:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16)}
.bank-item-name{font-family:var(--head);font-size:15px;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bank-item-meta{font-family:var(--mono);font-size:10px;color:var(--text3);white-space:nowrap;flex-shrink:0}
.bank-add-btn{
  flex-shrink:0;height:36px;min-width:36px;border-radius:10px;border:none;
  background:rgba(180,245,66,.15);color:var(--lime);
  cursor:pointer;font-size:13px;font-family:var(--head);font-weight:700;
  padding:0 12px;display:flex;align-items:center;justify-content:center;gap:4px;
  transition:all .15s;white-space:nowrap;
}
.bank-add-btn:active{transform:scale(.9);background:rgba(180,245,66,.25)}

/* ── TRIM CONTROLS ── */
.trim-wrap{position:relative;margin-bottom:8px}
.trim-region{
  position:absolute;top:0;bottom:0;
  background:rgba(180,245,66,.08);
  border-left:2px solid var(--lime);
  border-right:2px solid var(--lime);
  pointer-events:none;
}
.trim-handle{
  position:absolute;top:0;bottom:0;width:12px;
  cursor:col-resize;z-index:10;
  background:var(--lime);opacity:.7;border-radius:3px;
}
.trim-touch-handle{
  position:absolute;top:0;bottom:0;width:28px;
  background:var(--lime);opacity:.85;border-radius:4px;
  cursor:col-resize;z-index:20;touch-action:none;
  display:flex;align-items:center;justify-content:center;
}
.trim-touch-handle::after{content:'⋮';color:#000;font-size:16px;font-weight:900;pointer-events:none}
.trim-info{font-family:var(--mono);font-size:10px;color:var(--lime);margin-top:6px}

/* ── LABEL FIXES ── */
.setting-label{font-family:var(--mono);font-size:9px;letter-spacing:.15em;color:var(--text3);text-transform:uppercase;white-space:nowrap}
.lc-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── PARTS TAB EMPTY STATE ── */
.empty-state{text-align:center;padding:32px 20px;color:var(--text3);font-family:var(--mono);font-size:12px;line-height:2}
.empty-state-icon{font-size:40px;margin-bottom:8px}

/* ── PLAYLIST TAB ACTIONS ── */
.tab-actions{display:inline-flex;gap:2px;margin-left:6px;opacity:0;transition:opacity .15s;vertical-align:middle}
.pl-tab:hover .tab-actions,.pl-tab.active .tab-actions{opacity:1}
.tab-action-btn{font-size:11px;padding:1px 4px;border-radius:4px;cursor:pointer;color:var(--text3);transition:all .1s;line-height:1}
.tab-action-btn:hover{color:var(--text);background:rgba(255,255,255,.1)}
.tab-action-btn.tab-del:hover{color:var(--coral)}

/* ── STAGE MODE PARTS 2-COL ── */
body.stage-mode #tab-parts .partsWrap-inner{display:grid;grid-template-columns:1fr 1fr;gap:8px}
body.stage-mode .part-action-btn:not(.jump){display:none} /* only show jump in stage mode */
body.stage-mode .part-row{padding:10px 12px}
body.stage-mode .part-name{font-size:13px}

/* ── BEAT DONE INDICATOR ── */
.beat-cell.done{
  background:rgba(71,212,255,.18);
  border-color:rgba(71,212,255,.4);
  color:var(--cyan);
  font-weight:600;
}
/* Beat progress fill inside current beat cell */
.beat-cell.active .beat-fill{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--lime);border-radius:0 0 10px 10px;
}
.beat-cell{position:relative;overflow:hidden}

/* ── TIME SIG BEAT GROUPS ── */
.beat-grid-groups{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.beat-group{display:flex;gap:5px;padding:4px 6px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}

/* ── LABEL FIXES ── */
.setting-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--text3);text-transform:uppercase;white-space:nowrap;display:block}
input[type=number],input[type=text],select{min-width:0;width:100%}
.gcard input[type=number]{-moz-appearance:textfield}
.count-in-row{display:flex;gap:6px;align-items:flex-end;flex-wrap:nowrap}
.count-in-row>*{min-width:0;flex:1}

/* ── VOICE SELECT BADGE ── */
.voice-select{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:var(--text);font-family:var(--mono);font-size:11px;
  padding:5px 8px;border-radius:8px;cursor:pointer;outline:none;
  -webkit-appearance:none;appearance:none;
}
.voice-select.male{border-color:rgba(71,212,255,.4);color:var(--cyan)}
.voice-select.female{border-color:rgba(199,125,255,.4);color:var(--violet)}

/* ── CLOUD SYNC BUTTON ── */
.cloud-btn{
  background:rgba(71,212,255,.1);
  border-color:rgba(71,212,255,.3);
  color:var(--cyan);
  font-weight:600;
}
.cloud-btn.signed-in{
  background:rgba(180,245,66,.12);
  border-color:rgba(180,245,66,.35);
  color:var(--lime);
}
.cloud-btn.syncing{
  animation:cloud-pulse .8s ease-in-out infinite alternate;
}
@keyframes cloud-pulse{
  from{opacity:.6;box-shadow:none}
  to{opacity:1;box-shadow:0 0 12px rgba(71,212,255,.4)}
}
.header-clock{
  font-family:var(--mono);font-size:14px;font-weight:600;
  color:var(--text2);letter-spacing:.08em;
  padding:4px 10px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  flex-shrink:0;white-space:nowrap;
}

/* ── LIVE-BAR TRANSPORT — play + stop inside the counter bar ── */
.live-bar-transport{
  display:flex;gap:6px;align-items:center;
  padding:6px 14px 6px 8px;
  flex-shrink:0;
  /* No border-left here — add it only when visible via a pseudo-element */
}
/* Show divider only when transport is visible (not display:none) */
.live-bar-transport::before{
  content:'';
  display:block;
  width:1px;
  height:70%;
  background:var(--border);
  margin-right:8px;
  flex-shrink:0;
}
.lb-play-btn{
  height:40px;padding:0 16px;
  border-radius:10px;border:none;
  background:var(--g-play);color:#0f1a0a;
  font-family:var(--head);font-weight:700;font-size:13px;
  cursor:pointer;transition:all .14s;
  white-space:nowrap;min-width:90px;
}
.lb-play-btn:active{transform:scale(.96)}
.lb-stop-btn{
  width:40px;height:40px;border-radius:10px;
  border:1px solid rgba(255,107,107,.35);
  background:rgba(255,107,107,.12);color:var(--coral);
  font-size:16px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:all .14s;
}
.lb-stop-btn:active{background:rgba(255,107,107,.25)}
.mini-transport{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--bg); /* fully opaque — no bleed-through */
  border:1px solid var(--border);
  border-radius:14px;
  /* Sticky within the scrollable tab panel */
  position:sticky;
  top:8px;
  z-index:50;
  /* Subtle shadow to lift it above content when scrolling */
  box-shadow:0 4px 20px rgba(0,0,0,.5);
  flex-shrink:0;
}
.mini-play-btn{
  height:36px;flex:1;border-radius:10px;border:none;
  background:var(--g-play);color:#0f1a0a;
  font-family:var(--head);font-weight:700;font-size:13px;
  cursor:pointer;transition:all .14s;
}
.mini-play-btn:disabled{opacity:.35;cursor:not-allowed}
.mini-stop-btn{
  width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,107,107,.3);
  background:rgba(255,107,107,.1);color:var(--coral);font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .14s;
}
.part-dots{display:flex;gap:3px;flex-wrap:wrap;margin-top:5px}
.part-dots>div{
  width:10px;height:10px;border-radius:3px;
  transition:background .15s,box-shadow .15s;flex-shrink:0;
}
.dot-done{background:rgba(71,212,255,.6);box-shadow:0 0 4px rgba(71,212,255,.4)}
.dot-current{background:var(--lime);box-shadow:0 0 6px var(--lime)}
.dot-empty{background:rgba(255,255,255,.1)}

/* ════════════════════════════════
   RESPONSIVE — Phone / iPad / Desktop
   ════════════════════════════════ */

/* ── PHONE (< 480px) ── */
@media(max-width:479px){
  :root{--nav-h:60px}
  .top-header{padding:6px 10px}
  .pill-btn{padding:5px 9px;font-size:9px}
  .pill-btn{padding:4px 8px;font-size:9px}
  .live-bar{padding:0 8px}
  .lc-value{font-size:22px}
  .lc-bpm .lc-value{font-size:18px}
  .lc-part .lc-value{font-size:11px;max-width:60px}
  .lc-label{font-size:7px}
  .gcard{padding:12px}
  .btn-play{height:54px;font-size:16px}
  .btn-stop,.btn-tap{width:54px;height:54px}
  .bpm-big{font-size:40px}
  .nav-icon{font-size:18px}
  .nav-label{font-size:7px}
  .beat-cell{min-width:24px;height:34px;font-size:10px}
  .part-row{padding:8px 10px;gap:6px}
  .part-action-btn{width:28px;height:28px;font-size:11px}
  .settings-grid{grid-template-columns:1fr}
  .gcard-label{font-size:8px}
  .modal{border-radius:18px 18px 0 0}
}

/* ── TABLET / iPAD (480-1024px) ── */
@media(min-width:480px)and(max-width:1024px){
  .settings-grid{grid-template-columns:1fr 1fr}
  .live-bar{padding:0 16px}
  .lc-value{font-size:28px}
}

/* ── DESKTOP PRO STUDIO (≥ 1025px) ── */
@media(min-width:1025px){
  html,body{
    height:100%;
    overflow:hidden;
    margin:0;padding:0;
  }

  /* Use a wrapper approach — sidebar fixed, everything else in a column */
  .status-bar{display:none !important}

  /* Sidebar nav — fixed left column */
  .bottom-nav{
    position:fixed !important;
    left:0 !important;top:0 !important;bottom:0 !important;
    width:64px !important;
    height:100vh !important;      /* override calc(nav-h + safe-b) from base */
    flex-direction:column !important;
    align-items:center;
    justify-content:flex-start;
    border-top:none;
    border-right:1px solid var(--border);
    padding:12px 0;
    gap:2px;
    z-index:1000 !important;    /* highest so nothing covers it */
    overflow:visible;             /* don't clip nav items */
    background:rgba(15,15,20,0.97) !important;
    backdrop-filter:blur(20px);
  }
  .nav-item{flex:none;width:64px;padding:10px 0;gap:4px;height:auto}
  .nav-icon{font-size:19px}
  .nav-label{font-size:7px;letter-spacing:.06em}
  .nav-item.active::before{display:none}
  .nav-item.active::after{
    content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;
    background:var(--g-play);border-radius:0 3px 3px 0;
  }

  /* Everything right of sidebar */
  .top-header{
    position:fixed !important;
    top:0;left:64px;right:0;
    height:50px;
    padding:0 16px;
    z-index:200;
    border-bottom:1px solid var(--border);
    background:rgba(15,15,20,.98);
  }

  .live-bar{
    position:fixed !important;
    top:50px;left:64px;right:0;
    height:56px;
    z-index:199;
    background:rgba(15,15,20,.98);
    border-bottom:1px solid var(--border);
    padding:0 12px;
  }

  /* Main scrollable area — pushed below header+livebar, right of nav */
  .main-content{
    position:fixed !important;
    top:106px;
    left:64px;
    right:0;
    bottom:0;
    overflow-y:auto;
    overflow-x:hidden;
    background:var(--bg);
    z-index:1;  /* nav is z-index:300, sits above */
  }

  .tab-panel{
    position:absolute;
    inset:0;
    overflow-y:auto;
    overflow-x:hidden;
    padding:20px 24px 40px;
    display:none;
    flex-direction:column;
    gap:16px;
    background:var(--bg);
    z-index:0;
  }
  .tab-panel.active{display:flex;z-index:2}

  /* Play tab — 2 col grid */
  #tab-play.active{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
    align-content:start;
    padding:20px 24px 40px;
  }
  #tab-play #nowPlayingBar,
  #tab-play #card-waveform,
  #tab-play #card-tempo-map,
  #tab-play .gcard:first-of-type{
    grid-column:1/-1;
  }
  /* Settings — 2 col */
  #tab-settings.active{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
    align-content:start;
    padding:20px 24px 40px;
  }
  /* All other tabs — single full-width column */
  #tab-setlist.active,
  #tab-parts.active,
  #tab-mix.active,
  #tab-bank.active{
    display:flex;
    flex-direction:column;
    gap:16px;
  }

  /* Beat cells */
  .beat-cell{min-width:36px;height:40px;font-size:12px}

  /* Live counters */
  .lc-value{font-size:26px}
  .lc-bpm .lc-value{font-size:17px}
  .lc-part .lc-value{font-size:13px;max-width:120px}

  /* Modal centered */
  .modal-overlay{align-items:center}
  .modal{border-radius:20px;max-width:540px}

  /* Strips */
  .strips{gap:14px;flex-wrap:wrap}
  .strip{width:100px}

  /* Part dots */
  .part-dots>div{width:13px;height:13px;border-radius:4px}

  /* Stage mode 3-col parts */
  body.stage-mode #tab-parts .partsWrap-inner{grid-template-columns:1fr 1fr 1fr}
}

/* ── LANDSCAPE PHONE ── */

@media(max-width:844px)and(orientation:landscape){
  :root{--nav-h:52px}
  .live-bar{padding:0 10px}
  .lc-value{font-size:20px}
  .main-content{height:calc(100vh - 52px - 52px - env(safe-area-inset-top,0px))}
}

@media print{.bottom-nav,.top-header,.live-bar,button,.add-song-zone,.strips,.gcard-label button{display:none!important}body{background:#fff;color:#000}}