:root{
  --bg:#0b0c10;
  --panel:#11131a;
  --text:#e9e9ef;
  --muted:rgba(233,233,239,0.72);
  --line:rgba(233,233,239,0.12);
  --soft:rgba(233,233,239,0.06);
  --accent:#a7f3d0;
  --radius:16px;
  --shadow: 0 14px 40px rgba(0,0,0,0.38);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:var(--sans);
  background:
    radial-gradient(1200px 800px at 20% 0%, rgba(167,243,208,0.10), transparent 55%),
    radial-gradient(900px 600px at 80% 20%, rgba(147,197,253,0.10), transparent 60%),
    var(--bg);
  color:var(--text);
}

.topbar{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:0.9rem 1rem;
  background:rgba(11,12,16,0.66);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}

.brand{ display:flex; align-items:center; gap:0.8rem; }
.sigil{
  width:34px; height:34px; border-radius:12px;
  background: linear-gradient(135deg, rgba(167,243,208,0.65), rgba(147,197,253,0.45));
  box-shadow: 0 0 0 1px rgba(255,255,255,0.10) inset;
}
.title h1{ margin:0; font-size:1rem; letter-spacing:0.2px; }
.subtitle{ margin:0.15rem 0 0 0; font-size:0.85rem; color:var(--muted); }

.status{ display:flex; gap:0.5rem; flex-wrap:wrap; justify-content:flex-end; }
.pill{
  display:inline-flex; align-items:center;
  font-size:0.82rem;
  padding:0.25rem 0.6rem;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.03);
  color:var(--muted);
}

.stage{
  max-width:1200px;
  margin:0 auto;
  padding:1rem;
}

.controller{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(0,0,0,0.22);
  padding: 1rem;
  display:grid;
  gap: 0.9rem;
  grid-template-columns: 1fr 0.9fr 1fr;
  align-items: start;
  box-shadow: var(--shadow);
}

@media (max-width: 980px){
  .controller{ grid-template-columns: 1fr; }
}

.deck,.mixer{
  border:1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  padding: 0.9rem;
}

.deckHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 0.8rem;
  margin-bottom: 0.75rem;
}

.deckLabel,.mixerLabel{
  font-family: var(--mono);
  font-size: 0.82rem;
  color: var(--muted);
  letter-spacing: 0.08em;
}

.deckTitle{ font-size: 1.05rem; line-height: 1.25; }
.deckMeta{ font-size: 0.9rem; color: var(--muted); margin-top: 0.2rem; }

.jogWrap{ display:grid; gap: 0.55rem; }

.jog{
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,0.08), rgba(0,0,0,0.55) 55%, rgba(0,0,0,0.85));
  border: 1px solid rgba(255,255,255,0.14);
  overflow: hidden;
  cursor: grab;
}

.jog:active{ cursor: grabbing; }

.jogFace{
  position:absolute;
  inset: 12%;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.18);
}

.jogMarker{
  position:absolute;
  top: 6%;
  left: 50%;
  width: 2px;
  height: 16%;
  transform: translateX(-50%);
  background: rgba(167,243,208,0.75);
}

.jog.spin .jogFace{
  animation: spin 1.2s linear infinite;
}

@keyframes spin{
  from{ transform: rotate(0deg); }
  to{ transform: rotate(360deg); }
}

.seek{ width:100%; accent-color: var(--accent); }

.timeRow{
  display:flex;
  justify-content:space-between;
}

.time{
  font-family: var(--mono);
  font-size: 0.85rem;
  color: var(--muted);
}

.transport{
  display:flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-top: 0.7rem;
}

.deckRow{
  margin-top: 0.75rem;
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 0.7rem;
}

@media (max-width: 980px){
  .deckRow{ grid-template-columns: 1fr; }
}

.ctl{ display:grid; gap: 0.35rem; }
.ctlLabel{ font-size: 0.85rem; color: var(--muted); }
.hint{ margin-top:0.3rem; font-size:0.82rem; color: var(--muted); }

.select{
  border-radius: 999px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.25);
  color: var(--text);
  padding: 0.55rem 0.75rem;
  outline: none;
}

.knob, .fader, .xfade{
  width:100%;
  accent-color: var(--accent);
}

.pads{
  margin-top: 0.9rem;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
}

.pad{
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  color: var(--text);
  aspect-ratio: 1 / 1;
  cursor:pointer;
}

.pad:hover{ background: rgba(255,255,255,0.06); }

.mixerHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.vu{
  flex: 1;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  overflow:hidden;
}

.vuBar{
  height: 100%;
  width: 0%;
  background: rgba(167,243,208,0.70);
}

.mixerGrid{ display:grid; gap: 0.85rem; }

.mixerBtns{
  display:flex;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.wide{ grid-column: 1 / -1; }

.portalPads{
  margin-top: 1rem;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.6rem;
}

.portalPad{
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.20);
  color: var(--text);
  padding: 0.65rem 0.8rem;
  cursor:pointer;
}

.portalPad:hover{ background: rgba(255,255,255,0.06); }

.btn{
  border:1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  color:var(--text);
  padding:0.55rem 0.85rem;
  border-radius:999px;
  cursor:pointer;
  font-size:0.95rem;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.4rem;
}

.btn:hover{
  background: rgba(255,255,255,0.09);
  border-color: rgba(255,255,255,0.22);
}

.btnGhost{ background:transparent; }

.play{
  border-color: rgba(167,243,208,0.30);
}

.muted{ color: var(--muted); }

/* Overlay panel */
.overlay{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:1rem;
  z-index:50;
}

.overlay.show{ display:flex; }

.overlayBackdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.70);
}

.overlayCard{
  position:relative;
  width:min(880px, 96vw);
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: rgba(15,17,23,0.94);
  box-shadow: var(--shadow);
  padding:1rem;
}

.overlayTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:0.8rem;
  margin-bottom:0.75rem;
}

.overlayLabel{
  font-family: var(--mono);
  font-size:0.82rem;
  color: var(--muted);
  letter-spacing:0.12em;
  text-transform:uppercase;
  margin-bottom:0.25rem;
}

.overlayTitle{ margin:0; font-size:1.4rem; }
.overlaySub{ margin:0.35rem 0 0 0; }
.overlayBody{ margin-top:0.8rem; line-height:1.5; }

.themeAlt{
  --bg:#07070a;
  --accent:#fca5a5;
}
