/* 30-panels.css — panels, cards, chips, lists, forms for
   Playlists / Spots / Pins / Space / Integrations / Program Log. */

.panel{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
}
.panel + .panel{ margin-top:14px; }
.panel > .panel-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:16px;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:12px;
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}
.panel > .panel-title .spacer{ flex:1; }

.form-row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-top:10px; }
.form-row label{ flex:none; }
.form-grid{
  display:grid; grid-template-columns:auto 1fr; gap:8px 12px;
  align-items:center; margin-top:10px;
}
@media (max-width:480px){
  .form-grid{ grid-template-columns:1fr; }
}

.empty{
  color:var(--muted);
  font-size:13.5px;
  padding:18px 8px;
  text-align:center;
}
.inline-warn{
  color:var(--warn);
  font-size:12.5px;
  margin-top:6px;
}
.help{ font-size:12.5px; color:var(--muted); margin-top:8px; }
.help code{ background:#1B1D22; border:1px solid var(--line); border-radius:3px; padding:1px 4px; }

/* ---------- playlists ---------- */
.pl-list{ display:flex; flex-direction:column; gap:4px; }
.pl-item{
  display:flex; align-items:center; gap:8px;
  padding:8px 10px;
  border:1px solid transparent;
  border-radius:var(--radius);
  background:transparent;
  color:var(--text);
  cursor:pointer;
  text-align:left; width:100%;
  font-size:13.5px;
}
.pl-item:hover{ background:#1E2026; }
.pl-item.sel{ background:#26241C; border-color:#4A3D1B; color:var(--accent); }
.pl-item .pl-count{ margin-left:auto; font-family:var(--font-mono); font-size:11.5px; color:var(--muted); }
.pl-item .active-tag{
  font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ok); border:1px solid #2C4A36; border-radius:3px; padding:1px 5px;
}

.track-list{ display:flex; flex-direction:column; }
.track-row{
  display:flex; align-items:center; gap:8px;
  padding:7px 6px;
  border-bottom:1px solid var(--line);
  min-width:0;
}
.track-row:last-child{ border-bottom:none; }
.track-idx{ font-family:var(--font-mono); font-size:11.5px; color:var(--muted); width:2.4ch; text-align:right; flex:none; }
.track-title{ flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-size:13.5px; }
.track-dur{ font-family:var(--font-mono); font-size:12px; color:var(--muted); flex:none; }
.track-row .btn.icon{ padding:3px 8px; font-size:12px; flex:none; }
.track-row.playing .track-title{ color:var(--accent); }

.upload-list{ margin-top:10px; display:flex; flex-direction:column; gap:4px; }
.upload-item{
  display:flex; align-items:center; gap:10px;
  font-size:12.5px; color:var(--muted);
  font-family:var(--font-mono);
}
.upload-item .u-name{ flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.upload-item progress{ width:110px; height:8px; accent-color:var(--accent); }
.upload-item .u-ok{ color:var(--ok); }
.upload-item .u-err{ color:var(--err); }

/* ---------- spots ---------- */
.spot-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  display:flex; flex-direction:column; gap:9px;
}
.spot-card.disabled{ opacity:.55; }
.spot-head{ display:flex; align-items:center; gap:8px; }
.spot-name{ font-weight:600; font-size:14.5px; flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.badge{
  font-size:10.5px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  border-radius:3px; padding:2px 6px;
  border:1px solid;
  flex:none;
}
.badge.advert { color:var(--accent); border-color:#5A481A; }
.badge.message{ color:var(--blue);   border-color:#414A58; }
.badge.jingle { color:var(--ok);     border-color:#2C4A36; }
.badge.ticker { color:var(--gold);   border-color:#57491F; }
.spot-mode{ font-size:12px; color:var(--muted); flex:none; }
.spot-preview{
  font-size:12.5px; color:var(--muted);
  background:#1B1D22; border:1px solid var(--line); border-radius:var(--radius);
  padding:8px 10px;
  max-height:64px; overflow:hidden;
}
.spot-actions{ display:flex; gap:6px; flex-wrap:wrap; align-items:center; }
.spot-actions .spacer{ flex:1; }
.spot-edit{ border-top:1px solid var(--line); padding-top:10px; }

/* ---------- pins ---------- */
.pin-row{
  display:flex; align-items:center; gap:10px;
  padding:9px 6px;
  border-bottom:1px solid var(--line);
  min-width:0; flex-wrap:wrap;
}
.pin-row:last-child{ border-bottom:none; }
.chip{
  font-size:10.5px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  border-radius:3px; padding:2px 7px;
  border:1px solid; flex:none;
}
.chip.pending { color:var(--warn); border-color:#57491F; }
.chip.pinned  { color:var(--ok);   border-color:#2C4A36; }
.chip.removing{ color:var(--err);  border-color:#553233; }
.pin-url{ font-family:var(--font-mono); font-size:12.5px; flex:1; min-width:140px; overflow:hidden; white-space:nowrap; }
.pin-note{ font-size:12.5px; color:var(--muted); flex-basis:100%; padding-left:2px; }
.lock-btn{
  background:transparent; border:1px solid transparent; border-radius:var(--radius);
  font-size:15px; cursor:pointer; padding:2px 7px; opacity:.4;
}
.lock-btn:hover{ border-color:var(--line); }
.lock-btn.on{ opacity:1; }

/* ---------- space ---------- */
.air-board{
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
}
.air-state-big{
  font-family:var(--font-display);
  font-weight:800;
  font-size:42px;
  letter-spacing:.06em;
  color:var(--muted);
  line-height:1;
}
.air-state-big.on{ color:var(--live); }
.air-actions{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.space-url{ font-family:var(--font-mono); font-size:12.5px; margin-top:10px; word-break:break-all; }

.callout{
  border:1px solid #5A481A;
  border-left:4px solid var(--accent);
  background:#26221A;
  border-radius:var(--radius);
  padding:14px 16px;
  margin-bottom:14px;
}
.callout .co-title{ font-weight:700; color:var(--accent); margin-bottom:6px; }
.callout ol{ margin:6px 0 10px; padding-left:20px; color:var(--text); font-size:13.5px; }

.shot-wrap{ margin-top:10px; }
.shot-wrap img{
  width:100%; max-width:720px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:block;
  background:#101114;
}
.shot-ts{ font-family:var(--font-mono); font-size:11.5px; color:var(--muted); margin-top:6px; }

/* ---------- integrations ---------- */
.sms-list{ display:flex; flex-direction:column; }
.sms-row{
  padding:9px 4px;
  border-bottom:1px solid var(--line);
  display:flex; gap:12px; align-items:baseline; flex-wrap:wrap;
}
.sms-row:last-child{ border-bottom:none; }
.sms-from{ font-family:var(--font-mono); font-size:12.5px; color:var(--accent); flex:none; }
.sms-body{ flex:1; min-width:200px; font-size:13.5px; }
.sms-when{ font-family:var(--font-mono); font-size:11.5px; color:var(--muted); flex:none; }
.hook-url{
  font-family:var(--font-mono); font-size:12.5px;
  background:#1B1D22; border:1px solid var(--line); border-radius:var(--radius);
  padding:9px 11px; word-break:break-all;
  display:flex; align-items:center; gap:10px; justify-content:space-between; flex-wrap:wrap;
}
.soon{ opacity:.55; }

/* ---------- program log ---------- */
.log-toolbar{ display:flex; gap:10px; align-items:center; margin-bottom:10px; flex-wrap:wrap; }
.log-view{
  font-family:var(--font-mono);
  font-size:12.5px;
  line-height:1.55;
  background:#141519;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:10px 12px;
  height:min(62vh, 640px);
  overflow-y:auto;
  overscroll-behavior:contain;
}
.log-line{ display:flex; gap:10px; white-space:pre-wrap; word-break:break-word; }
.log-t{ color:var(--muted); flex:none; }
.log-line .log-msg{ min-width:0; }
.log-line.info  .log-msg{ color:var(--text); }
.log-line.warn  .log-msg{ color:var(--warn); }
.log-line.error .log-msg{ color:var(--err); }
.log-line.debug .log-msg{ color:var(--muted); }
