/* radio.css — estils del reproductor d'StreamCAT compartit per la família
 * Nexe. Carregat via <link> al index.html per respectar CSP estricte
 * (style-src 'self'). El color del brand del botó s'aplica via tokens del
 * projecte (--primary), no via inline style. Vegeu el comentari de CSP a
 * shared/js/thanks-modal.js per al detall.
 *
 * Markup: vegeu radio.js. La tira es compon de:
 *   .radio-strip (contenidor flex centrat)
 *     .radio-btn (pill amb 3 estats data-state)
 *     .radio-status (text aria-live)
 *     .radio-credit (atribució discreta enllaçada a streamcat.cat)
 *
 * Pensada per ser visualment integrada amb els tokens del projecte
 * (--primary del brand, --bg-soft, --border, --ink-3 com a colors base).
 */

.radio-strip {
  max-width: 380px;
  margin: 18px auto;
  padding: 8px 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 12px;
}

.radio-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px 8px 10px;
  border: 1.5px solid var(--border, #e5e5e5);
  border-radius: 999px;
  background: var(--bg-elevated, var(--bg, #fff));
  color: var(--ink, #0a0a0a);
  font: 600 0.9rem/1 inherit;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s, transform .08s;
  -webkit-tap-highlight-color: transparent;
}
.radio-btn:hover { border-color: var(--primary, #888); color: var(--primary, var(--ink, #0a0a0a)); }
.radio-btn:focus-visible {
  outline: 2px solid var(--primary, #888);
  outline-offset: 2px;
}
.radio-btn:active { transform: translateY(1px); }

.radio-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  /* color-mix amb el brand a 12% per tenir un fons suau coherent amb el
     projecte; fallback a un gris pàl·lid si el navegador no suporta. */
  background: color-mix(in srgb, var(--primary, #888) 12%, transparent);
  color: var(--primary, #555);
  flex: 0 0 26px;
}
.radio-icon-play, .radio-eq { position: absolute; }
.radio-eq {
  display: flex;
  align-items: end;
  gap: 2px;
  height: 14px;
  width: 16px;
}
.radio-eq i {
  width: 2px;
  background: currentColor;
  border-radius: 1px;
  height: 30%;
}
/* Estat per defecte (off): play visible, eq amagat */
.radio-btn .radio-eq { display: none; }

/* Loading: spinner CSS al cercle */
.radio-btn[data-state="loading"] .radio-icon-play { display: none; }
.radio-btn[data-state="loading"] .radio-icon::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: radio-spin .8s linear infinite;
}

/* On: equalitzador animat (substitueix l'icona play) */
.radio-btn[data-state="on"] {
  border-color: var(--primary, #888);
  color: var(--primary, var(--ink, #0a0a0a));
  background: color-mix(in srgb, var(--primary, #888) 8%, var(--bg-elevated, var(--bg, #fff)));
}
.radio-btn[data-state="on"] .radio-icon-play { display: none; }
.radio-btn[data-state="on"] .radio-eq { display: flex; }
.radio-btn[data-state="on"] .radio-eq i {
  animation: radio-eq 0.9s ease-in-out infinite;
}
.radio-btn[data-state="on"] .radio-eq i:nth-child(2) { animation-delay: .15s }
.radio-btn[data-state="on"] .radio-eq i:nth-child(3) { animation-delay: .30s }
.radio-btn[data-state="on"] .radio-eq i:nth-child(4) { animation-delay: .45s }

@keyframes radio-spin { to { transform: rotate(360deg) } }
@keyframes radio-eq {
  0%, 100% { height: 30%; }
  50%      { height: 95%; }
}

/* prefers-reduced-motion: cap animació; el botó canvia d'estat sense
   moviment. El feedback s'aporta amb text + color (a11y) i aria-live. */
@media (prefers-reduced-motion: reduce) {
  .radio-btn[data-state="on"] .radio-eq i { animation: none; height: 70%; }
  .radio-btn[data-state="loading"] .radio-icon::after { animation: none; }
}

.radio-status {
  font: 500 0.8rem/1.2 inherit;
  color: var(--ink-3, #737373);
  min-height: 1.2em;
}

.radio-credit {
  font: 500 0.72rem/1 inherit;
  color: var(--ink-4, #a3a3a3);
  text-decoration: none;
  border-bottom: 1px dotted currentColor;
  padding-bottom: 1px;
}
.radio-credit:hover { color: var(--primary, var(--ink, #0a0a0a)); }

/* Selector d'emissora — pill petit i discret coherent amb el botó. Defaults
   apareix dins el flow de l'strip, abans del crèdit. */
.radio-station {
  font: 500 0.78rem/1 inherit;
  color: var(--ink-2, #404040);
  background: var(--bg-soft, var(--bg, #fafafa));
  border: 1px solid var(--border, #e5e5e5);
  border-radius: 999px;
  padding: 5px 26px 5px 12px;
  /* Caret personalitzat (background SVG) per estètica uniforme cross-browser
     en lloc del menu natiu. SVG inline en base64-free per coherència CSP. */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position: calc(100% - 14px) 52%, calc(100% - 9px) 52%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  cursor: pointer;
  transition: border-color .15s, color .15s, background-color .15s;
}
.radio-station:hover { border-color: var(--primary, #888); color: var(--primary, var(--ink, #0a0a0a)); }
.radio-station:focus-visible {
  outline: 2px solid var(--primary, #888);
  outline-offset: 2px;
  border-color: var(--primary, #888);
}
