
:root{
  --bg:#040404;
  --panel:#07090c;
  --border:#b98300;
  --text:#fff5cf;
  --muted:#d3b66a;
  --slider:#e3c15f;
  --track:#5d5d5d;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif;overflow:hidden}
body{font-size:16px;line-height:1.15}
button,select,input{font:inherit}
.app{
  height:100vh;
  display:grid;
  grid-template-rows:42px 1fr;
  background:#000;
}
.topbar{
  display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--border);padding:0 12px;
  background:#050505;
}
.brand{font-weight:700;font-size:23px;color:#f6c648}
.topnote{font-size:15px;color:#e6cf90;text-align:right}
.workspace{
  min-height:0;
  display:grid;
  grid-template-rows:minmax(280px, 41vh) minmax(275px, calc(59vh - 42px));
  gap:8px;
  padding:8px;
}
.panel{
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg,#03060c,#040404 70%);
  min-width:0;
  min-height:0;
  overflow:hidden;
}
.deck,.mixer{padding:12px}
.deck h2,.mixer h2,.panel h3{margin:0 0 2px 0;font-size:34px;color:#f4c343}
.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}
.panel-head.smallhead h3{font-size:26px}
.sub{font-size:16px;color:var(--muted)}
.badge{
  border:1px solid var(--border);border-radius:999px;padding:6px 12px;
  color:#f3c446;font-size:15px;white-space:nowrap
}
.workspace > .deck, .workspace > .mixer{min-height:0}
.workspace > .deck:nth-child(1), .workspace > .mixer, .workspace > .deck:nth-child(3){height:100%}
.workspace{ }
.workspace > :not(.bottom-grid){
}
.workspace > .deck, .workspace > .mixer{
}
.workspace{
}
.workspace > .deck, .workspace > .mixer{
}
.workspace > .deck, .workspace > .mixer{ }
.workspace > .deck, .workspace > .mixer{ }
.workspace > .deck, .workspace > .mixer{ }

.workspace > section:not(.bottom-grid){ }
.workspace > .bottom-grid{
  display:grid;
  grid-template-columns:1.18fr .95fr;
  gap:8px;
  min-height:0;
}
.workspace{
}
.workspace:before{content:"";display:none}
.workspace > .deck:nth-of-type(1), .workspace > .mixer, .workspace > .deck:nth-of-type(2){
}
.workspace{ }
.workspace > .deck, .workspace > .mixer{ }
.workspace{ }
.workspace > .deck, .workspace > .mixer{ }

.workspace{ }
.workspace > .deck, .workspace > .mixer { }

.workspace{
  grid-template-columns: 1.02fr 1.12fr 1.02fr;
}
.workspace > .deck:nth-of-type(1){grid-row:1;grid-column:1}
.workspace > .mixer{grid-row:1;grid-column:2}
.workspace > .deck:nth-of-type(2){grid-row:1;grid-column:3}
.workspace > .bottom-grid{grid-row:2;grid-column:1 / 4}

.track-info{margin-bottom:8px}
.track-name{font-size:22px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-meta{font-size:16px;color:#efcf7b}
.btn-row{display:grid;gap:8px}
.btn-row.six{grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:8px}
.btn-row.two{grid-template-columns:repeat(2,minmax(0,1fr))}
button,select{
  border:1px solid var(--border);border-radius:12px;background:#06080c;color:white;
  min-height:46px;padding:0 10px;cursor:pointer
}
button:hover,select:hover{background:#0b1118}
.slider-wrap{display:grid;grid-template-columns:74px 1fr 60px;align-items:center;gap:10px;margin-bottom:8px}
.slider-wrap.compact{margin-bottom:0}
.slider-wrap span{font-size:16px;color:#f1c95f}
.slider-wrap b{font-size:15px;color:#efd88d;font-weight:600;text-align:right}
input[type=range]{width:100%;accent-color:var(--slider)}
.bottom-buttons{margin-top:4px}
.deck-note{margin-top:8px;font-size:14px;color:#d0b367}
.hidden-media{display:none}
.center-tight{margin-bottom:6px}
.mixer-topline{
  display:grid;
  grid-template-columns:170px 130px minmax(220px,1fr);
  gap:10px;
  align-items:center;
  margin-bottom:8px;
}
.master-inline{
  display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;
}
.master-inline span{color:#f2c95d;font-weight:700;white-space:nowrap;font-size:16px}
.video-band{
  display:grid;
  grid-template-columns:34px minmax(260px, 320px) 34px;
  gap:10px;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
}
.uv-col{display:flex;flex-direction:column;align-items:center;gap:8px}
.uv-label{font-size:13px;color:#efd88d;white-space:nowrap}
.uv-meter{
  width:18px;height:min(20vh,165px);border:1px solid var(--border);border-radius:12px;
  display:flex;align-items:flex-end;overflow:hidden;background:#060606;
}
.uv-fill{
  width:100%;height:22%;
  background:linear-gradient(180deg,#31d877 0%, #f2d05f 60%, #ff7e4d 100%);
  border-radius:0 0 12px 12px;
}
.master-video-wrap{
  position:relative;
  width:100%;
  max-width:min(28vh, 300px);
  aspect-ratio:4/3;
  margin:0 auto;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  background:#000;
}
.master-video-wrap video{width:100%;height:100%;object-fit:cover;background:#000;display:block}
.master-chip{
  position:absolute;left:10px;top:10px;z-index:2;
  border:1px solid var(--border);border-radius:999px;background:#191100;color:#f3cf66;
  padding:4px 10px;font-size:14px
}
.mixer-controls{display:grid;gap:8px}
.fx-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}
.status-line{font-size:14px;color:#d9bf77;margin-top:8px}

.bottom-grid .panel{padding:10px}
.toolbar{
  display:grid;gap:8px;margin-bottom:8px;align-items:center
}
.library-tools{grid-template-columns:1.2fr repeat(7,minmax(0,1fr))}
.automix-tools{grid-template-columns:1.05fr 1fr 1fr .95fr .85fr repeat(4,minmax(0,1fr))}
.file-pick input{width:100%;color:white}
.table-wrap{
  height:calc(100% - 112px);
  min-height:130px;
  overflow:auto;border:1px solid var(--border);border-radius:14px;background:#020407
}
.bottom-grid table{width:100%;border-collapse:collapse;font-size:17px}
th,td{padding:10px 12px;border-bottom:1px solid rgba(185,131,0,.25);text-align:left}
th{position:sticky;top:0;background:#090b10;color:#f3c446;z-index:1}
tr:hover td{background:#0a0d12}
.small-btn{min-height:40px;padding:0 12px}
.row-check{transform:scale(1.3)}
.tiny-top{grid-template-columns:repeat(2,minmax(0,1fr));width:270px}
@media (max-width: 1600px){
  body{font-size:15px}
  .brand{font-size:20px}
  .deck h2,.mixer h2,.panel h3{font-size:29px}
  .workspace{grid-template-rows:minmax(290px, 44vh) minmax(240px, calc(56vh - 42px))}
  .mixer-topline{grid-template-columns:160px 130px minmax(220px,1fr)}
  .library-tools{grid-template-columns:1.1fr repeat(7,minmax(0,1fr))}
}
@media (max-width: 1300px){
  .workspace{
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto minmax(230px,1fr);
    overflow:auto;
  }
  .workspace > .deck:nth-of-type(1), .workspace > .mixer, .workspace > .deck:nth-of-type(2), .workspace > .bottom-grid{
    grid-column:1;grid-row:auto;
  }
  .workspace > .bottom-grid{grid-template-columns:1fr}
  .library-tools,.automix-tools,.fx-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mixer-topline{grid-template-columns:1fr 1fr}
  .master-inline{grid-column:1 / -1}
  html,body{overflow:auto}
}

.bpm-cell{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bpm-value{min-width:32px;display:inline-block;font-weight:700}
.mini-btn{min-height:28px;padding:0 8px;border-radius:8px;font-size:13px}


.bpm-cell{display:flex;align-items:center;gap:6px;justify-content:flex-start;}
.bpm-spinner{width:72px;min-height:34px;padding:4px 8px;background:#06080c;color:#fff;border:1px solid var(--border);border-radius:10px;}
.bpm-spinner::-webkit-outer-spin-button,.bpm-spinner::-webkit-inner-spin-button{opacity:1;}
.mini-btn{min-height:34px;padding:0 10px;border-radius:10px;}


/* v23 mixer resize */
.mixer{display:grid;grid-template-rows:auto auto auto auto;align-content:start}
.mixer-controls{gap:6px}
.fx-grid .slider-wrap{grid-template-columns:60px 1fr 30px}
.master-video-wrap video{object-fit:contain}


.file-pick-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.hidden-file{
  display:none;
}
#m3uImportBtn{
  white-space:nowrap;
}

.file-pick-row{
  display:flex;
  align-items:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
.picker-block{
  display:flex;
  flex-direction:column;
  gap:4px;
  color:var(--gold, #f2c14e);
  font-size:12px;
}
.picker-block input[type="file"]{
  max-width:220px;
}
#m3uImportBtn{
  align-self:flex-end;
}


.file-pick.file-pick-row{
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  gap:10px !important;
  flex-wrap:nowrap !important;
  width:auto !important;
}
.file-pick-row .picker-block{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  gap:4px !important;
  min-width:0;
  flex:0 0 auto;
}
.file-pick-row .picker-block input[type="file"]{
  width:170px !important;
  max-width:170px !important;
}
.file-pick-row #m3uImportBtn{
  align-self:flex-end !important;
  white-space:nowrap;
  flex:0 0 auto;
}


/* v33 inline toolbar */
.library-tools{
  display:flex;
  align-items:flex-end;
  gap:8px;
  flex-wrap:nowrap;
}
.picker-inline{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:2px;
  font-size:11px;
  line-height:1.1;
  color:var(--gold, #f2c14e);
  flex:0 0 auto;
}
.picker-inline input[type="file"]{
  width:140px !important;
  max-width:140px !important;
}
.library-tools #searchBox{
  flex:1 1 180px;
  min-width:150px;
}
.library-tools button{
  flex:0 0 auto;
}
@media (max-width: 1200px){
  .library-tools{
    flex-wrap:wrap;
  }
}


/* v35 match screenshot: pickers in header row, buttons/search on next row */
.library-head{
  display:flex !important;
  align-items:flex-end !important;
  justify-content:space-between !important;
  gap:12px !important;
}
.library-head-left{
  min-width:0;
}
.library-head-right{
  display:flex !important;
  align-items:flex-end !important;
  gap:10px !important;
  flex:0 0 auto;
}
.library-head-right .picker-inline{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  gap:2px !important;
  font-size:11px !important;
  line-height:1.1 !important;
}
.library-head-right .picker-inline input[type="file"]{
  width:140px !important;
  max-width:140px !important;
}
.library-head-right #m3uImportBtn{
  align-self:flex-end !important;
  white-space:nowrap !important;
  height:34px;
}

.library-tools{
  display:grid !important;
  grid-template-columns: 1fr auto auto auto auto auto auto auto;
  gap:8px !important;
  align-items:center !important;
}
.library-tools #searchBox{
  min-width:150px !important;
  width:100% !important;
}
.library-tools .picker-inline,
.library-tools #m3uImportBtn{
  display:none !important;
}

@media (max-width: 1200px){
  .library-head{
    flex-wrap:wrap;
  }
  .library-tools{
    grid-template-columns: 1fr repeat(3, auto);
  }
}


/* v36: M3U auto-loads when chosen, no separate button */
.library-head-right #m3uImportBtn{
  display:none !important;
}


.library-head-right{
  display:flex;
  align-items:flex-end;
  gap:10px;
}
.library-head-right .picker-inline{
  display:flex;
  flex-direction:column;
  gap:2px;
  font-size:11px;
  color:#f2c14e;
}
#m3uExportBtn{
  align-self:flex-end;
  white-space:nowrap;
}


/* v40 M3U import/export fix */
.library-head-right{
  display:flex;
  align-items:flex-end;
  gap:10px;
}
#m3uExportBtn{
  align-self:flex-end;
  white-space:nowrap;
}


/* v43: M3U removed */
#m3uPicker,
#m3uExportBtn{
  display:none !important;
}


/* v44 mixer restyle */
#mixer{
  overflow:hidden;
}
.mixer-topline{
  margin-bottom:8px;
}
.mixer-stage{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:14px;
  align-items:center;
  margin-bottom:10px;
}
.mixer-video-band{
  display:grid;
  grid-template-columns: auto auto auto;
  gap:14px;
  align-items:center;
}
.compact-master-video{
  width:260px;
  height:190px;
  border:1px solid #c99718;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  background:#020406;
}
.compact-master-video video{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:16px;
  background:#000;
}
.fx-side{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.fx-line{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:8px;
  color:#f2c14e;
  font-size:13px;
}
.fx-line span,
.fx-line b{
  white-space:nowrap;
}
.fx-line input[type="range"]{
  width:100%;
}
.mixer-controls-restyled{
  margin-top:2px;
}
.crossfader-wrap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
}
.crossfader-wrap input[type="range"]{
  width:100%;
}
#crossfader{
  accent-color:#d6b04f;
}
#crossfader::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:16px;
  height:28px;
  border-radius:2px;
  background:#d6b04f;
  border:1px solid #d6b04f;
}
#crossfader::-moz-range-thumb{
  width:16px;
  height:28px;
  border-radius:2px;
  background:#d6b04f;
  border:1px solid #d6b04f;
}
@media (max-width: 1400px){
  .mixer-stage{
    grid-template-columns:1fr;
    justify-items:center;
  }
  .fx-side{
    width:100%;
    max-width:540px;
  }
}


/* v45 closer to user mock */
.mixer-stage-mock{
  display:grid;
  grid-template-columns: 210px 1fr 210px;
  gap:14px;
  align-items:start;
}
.center-band{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.center-top{
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:14px;
  align-items:center;
}
.mock-master-video{
  width:250px;
  height:190px;
  justify-self:center;
}
.mock-side{
  padding-top:42px;
}
.mock-side .fx-line{
  display:grid;
  grid-template-columns: 44px 1fr 0;
  gap:8px;
  margin-bottom:8px;
}
.mock-side .fx-line b{
  display:none;
}
.mock-side .fx-line span{
  font-weight:700;
  text-align:left;
  white-space:nowrap;
}
.mixer-controls-restyled{
  margin-top:2px;
}
.crossfader-wrap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:10px;
  align-items:center;
}
.crossfader-wrap span{
  font-size:14px;
  font-weight:700;
}
.crossfader-wrap input[type="range"]{
  width:100%;
}
.speaker-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
  align-items:center;
}
.speaker-line{
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:8px;
  align-items:center;
  color:#f2c14e;
  font-size:12px;
}
.speaker-line b{
  display:none;
}
.speaker-line span{
  white-space:nowrap;
}
.speaker-line input[type="range"]{
  width:100%;
}
@media (max-width: 1500px){
  .mixer-stage-mock{
    grid-template-columns: 180px 1fr 180px;
  }
  .mock-master-video{
    width:220px;
    height:170px;
  }
}
@media (max-width: 1300px){
  .mixer-stage-mock{
    grid-template-columns: 1fr;
  }
  .mock-side{
    padding-top:0;
  }
  .center-top{
    justify-items:center;
  }
  .speaker-row{
    grid-template-columns: 1fr;
  }
}


/* v49 CSS-only deck resize + fit fix */
html,body{height:100%;overflow:hidden;}
.app{height:100vh;display:flex;flex-direction:column;}
.topbar{flex:0 0 auto;}

.workspace{
  flex:1 1 auto;
  display:grid !important;
  grid-template-columns: 0.78fr 1.44fr 0.78fr !important;
  grid-template-rows: minmax(260px, 44vh) minmax(240px, 1fr) !important;
  gap:8px;
  padding:8px;
  min-height:0;
}

.workspace > #deckA{grid-column:1;grid-row:1; min-width:0;}
.workspace > #mixer{grid-column:2;grid-row:1; min-width:0;}
.workspace > #deckB{grid-column:3;grid-row:1; min-width:0;}
.workspace > .bottom-grid{grid-column:1 / span 3; grid-row:2; min-height:0;}

#deckA, #deckB{
  transform:scale(0.94);
  transform-origin:top center;
}
#mixer{
  transform:scale(0.98);
  transform-origin:top center;
}

.deck h2,.mixer h2,.panel h3{font-size:28px;}
.sub{font-size:14px;}
.badge{font-size:13px;padding:5px 10px;}
button{padding:6px 9px;font-size:12px;}
.slider-wrap span,.slider-wrap b,.deck-note,.speaker-line,.fx-line,.uv-label,.status-line{font-size:12px;}
.track-name{font-size:18px;}
.track-meta{font-size:13px;}

.table-wrap{flex:1;overflow:auto;min-height:0;}
.bottom-grid{
  display:grid !important;
  grid-template-columns: 1.28fr 0.92fr;
  gap:8px;
  min-height:0;
}
.panel{display:flex;flex-direction:column;min-height:0;overflow:hidden;}

.mixer-stage-mock{
  grid-template-columns: 170px 1fr 170px !important;
  gap:10px !important;
}
.mock-master-video{
  width:220px !important;
  height:155px !important;
}
.mock-side{padding-top:18px !important;}
.speaker-row{gap:10px !important;}
.center-band{gap:8px !important;}
.center-top{gap:10px !important;}

@media (max-width: 1400px){
  .workspace{
    grid-template-columns: 0.74fr 1.52fr 0.74fr !important;
  }
  .mixer-stage-mock{
    grid-template-columns: 145px 1fr 145px !important;
  }
  .mock-master-video{
    width:190px !important;
    height:135px !important;
  }
}

@media (max-width: 1100px){
  .workspace{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto minmax(220px,1fr) !important;
    overflow:auto;
  }
  .workspace > #deckA,
  .workspace > #mixer,
  .workspace > #deckB,
  .workspace > .bottom-grid{
    grid-column:1 !important;
    grid-row:auto !important;
    transform:none !important;
  }
  .bottom-grid{
    grid-template-columns:1fr !important;
  }
}


/* v60 sync/next/cover layout */
#deckA, #deckB { position: relative; }
#deckACover, #deckBCover, .deck-cover{
  width: 82px;
  height: 82px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid #c99718;
  background: #111;
  box-shadow: 0 0 10px rgba(0,0,0,.35);
  position: absolute;
  top: 10px;
  right: 52px; /* more padding from state badge */
}
.track-info{
  padding-right: 120px; /* room for album art */
}
.next-center{
  display:flex;
  justify-content:center;
  margin-top:10px;
  margin-bottom:6px;
}
#nextCenterBtn{
  min-width:120px;
}


/* v61 cover moved under loop/set cue */
#deckA, #deckB { position: relative; }
.deck-cover-slot{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:92px;
  margin:10px 0 6px 0;
}
.deck-cover{
  width:82px;
  height:82px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid #c99718;
  background:#111;
  box-shadow:0 0 10px rgba(0,0,0,.35);
  position:static !important;
  top:auto !important;
  right:auto !important;
}
.track-info{ padding-right:0 !important; }


/* v62 cover placement under Loop Off / Set Cue */
.deck-cover-slot{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:98px;
  margin:14px 0 8px 0;
}
.deck-cover{
  width:86px;
  height:86px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid #c99718;
  background:#111;
  box-shadow:0 0 10px rgba(0,0,0,.35);
  position:static !important;
}
