:root{
    --bg:#0b0f14;
    --panel:#111823;
    --panel2:#0f151f;
    --text:#e8edf6;
    --muted:#aab6c8;
    --line:#223045;
    --good:#2ce6a6;
    --warn:#ffcc66;
    --bad:#ff6b6b;
    --shadow: 0 12px 30px rgba(0,0,0,.35);
    --radius: 16px;
  }
  
  *{ box-sizing:border-box; }
  
  body{
    margin:0;
    background: radial-gradient(1200px 600px at 20% 10%, #142033 0%, var(--bg) 55%) fixed;
    color:var(--text);
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    letter-spacing:.2px;
  }
  
  header{
    padding: 22px 18px 10px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
    position: sticky;
    top: 0;
    backdrop-filter: blur(10px);
    z-index: 5;
  }
  
  .wrap{ max-width: 1100px; margin:0 auto; padding: 18px; }
  
  .brandRow{
    display:flex;
    gap:14px;
    align-items:center;
    justify-content:space-between;
    flex-wrap:wrap;
  }
  
  .brandLeft{ display:flex; gap:14px; align-items:center; }
  
  .logo{
    width:44px; height:44px;
    border-radius: 12px;
    background: linear-gradient(135deg, #2ce6a6, #4aa3ff);
    box-shadow: var(--shadow);
  }
  
  h1{ margin:0; font-size: 20px; }
  
  .sub{ margin:2px 0 0; color:var(--muted); font-size: 13px; }
  
  .onAir{
    display:flex; align-items:center; gap:10px;
    padding: 10px 12px;
    border-radius: 999px;
    background: rgba(44,230,166,.10);
    border: 1px solid rgba(44,230,166,.25);
  }
  
  .dot{
    width:10px; height:10px; border-radius:999px;
    background: var(--bad);
    box-shadow: 0 0 0 0 rgba(255,107,107,.55);
    animation: pulse 1.4s infinite;
  }
  
  @keyframes pulse {
    0%{ box-shadow: 0 0 0 0 rgba(255,107,107,.55); }
    70%{ box-shadow: 0 0 0 12px rgba(255,107,107,0); }
    100%{ box-shadow: 0 0 0 0 rgba(255,107,107,0); }
  }
  
  .onAirText{ font-size: 13px; color: var(--text); }
  .onAirSmall{ font-size: 12px; color: var(--muted); }
  
  .card{
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
    border: 1px solid rgba(255,255,255,.06);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow:hidden;
  }
  
  .cardHead{
    padding: 14px 14px 10px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 10px;
  }
  
  .cardTitle{ font-weight: 650; }
  .cardMeta{ color: var(--muted); font-size: 13px; margin-top: 4px; }
  
  .playerWrap{
    background: #000;
    aspect-ratio: 16/9;
    width:100%;
  }
  #player{ width:100%; height:100%; }
  
  .controls{
    padding: 14px;
    background: rgba(0,0,0,.15);
    border-top: 1px solid rgba(255,255,255,.06);
  }
  
  .controlsRow{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
  }
  
  .controlsRowSecondary{
    margin-top: 12px;
  }
  
  button{
    border:1px solid rgba(255,255,255,.10);
    background: rgba(17,24,35,.55);
    color: var(--text);
    padding: 10px 12px;
    border-radius: 12px;
    cursor:pointer;
    font-size: 14px;
  }
  
  button:hover{ border-color: rgba(255,255,255,.22); }
  
  button.primary{
    background: rgba(44,230,166,.16);
    border-color: rgba(44,230,166,.35);
  }
  
  button.danger{
    background: rgba(255,107,107,.10);
    border-color: rgba(255,107,107,.25);
  }
  
  button:disabled{ opacity:.45; cursor:not-allowed; }

  button.resume-attn{
    background: rgba(74,163,255,.16);
    border-color: rgba(74,163,255,.45);
    box-shadow: 0 0 0 0 rgba(74,163,255,.35);
    animation: resumePulse 1.2s infinite;
  }
  @keyframes resumePulse{
    0%{ box-shadow: 0 0 0 0 rgba(74,163,255,.35); }
    70%{ box-shadow: 0 0 0 10px rgba(74,163,255,0); }
    100%{ box-shadow: 0 0 0 0 rgba(74,163,255,0); }
  }
  
  
  .nowPlaying{
    padding: 14px;
    display:grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }
  
  .npLabel{ color: var(--muted); font-size: 12px; }
  .npTitle{ font-size: 16px; font-weight: 650; line-height: 1.25; }
  
  /* Toast */
  .toast{
    position: fixed;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    padding: 10px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(17,24,35,.92);
    color: var(--text);
    box-shadow: var(--shadow);
    font-size: 13px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
    z-index: 100;
    max-width: calc(100vw - 40px);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .toast.show{
    opacity: 1;
    transform: translateX(-50%) translateY(-6px);
  }
  