/* ============================================================
   episode-page.css — podcast-archive — pages épisode statiques
   Owner: podcast-archive (PA) · 2026-05-07
   ============================================================
   Pré-requis : tokens.css + base.css + layout.css (DS v0) + styles.css local.
   Classes spécifiques aux pages /archive/<slug>/.
   ============================================================ */

.ep-page {
  max-width: 760px;
  margin: 0 auto;
}

.ep-page__head {
  margin-bottom: var(--ds-space-5);
}

.ep-page__title {
  font-size: var(--ds-font-size-2xl);
  line-height: var(--ds-line-height-tight);
  margin: var(--ds-space-2) 0 var(--ds-space-3);
  color: var(--surface-color-text);
}

.ep-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ds-space-4);
  font-size: var(--ds-font-size-sm);
  color: var(--surface-color-text-muted);
  margin: 0;
}
.ep-page__meta i { margin-right: var(--ds-space-1); }
.ep-page__meta a {
  color: var(--surface-color-text-muted);
  text-decoration: none;
}
.ep-page__meta a:hover { color: var(--surface-color-link); }

.ep-series--link {
  display: inline-block;
  text-decoration: none;
  margin-bottom: var(--ds-space-3);
}
.ep-series--link:hover { opacity: 0.85; }

.ep-page__cover {
  margin: 0 0 var(--ds-space-5);
  border-radius: var(--ds-border-radius-md, 8px);
  overflow: hidden;
  background: var(--surface-color-card);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.07);
}
.ep-page__cover img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 360px;
  object-fit: cover;
}

.ep-page__player {
  background: var(--surface-color-card);
  padding: var(--ds-space-4);
  border-radius: var(--ds-border-radius-md, 8px);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.07);
  margin-bottom: var(--ds-space-6);
}
.ep-page__player audio {
  width: 100%;
  height: 40px;
  display: block;
}
.ep-page__player-fallback {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ds-space-2);
  margin: var(--ds-space-3) 0 0;
  font-size: var(--ds-font-size-sm);
}

/* Sections content */
.ep-page__summary,
.ep-page__description,
.ep-page__transcript,
.ep-page__refs {
  margin-bottom: var(--ds-space-7);
}

.ep-page__summary h2,
.ep-page__description h2,
.ep-page__transcript h2,
.ep-page__refs h2 {
  font-size: var(--ds-font-size-xl);
  border-bottom: 2px solid var(--surface-color-rule);
  padding-bottom: var(--ds-space-2);
  margin-bottom: var(--ds-space-4);
}

.ep-page__pubdate-note,
.ep-page__transcript-note {
  font-size: var(--ds-font-size-sm);
  color: var(--surface-color-text-muted);
  margin-bottom: var(--ds-space-4);
}

.ep-page__description-body p,
.ep-page__transcript-body p {
  margin-bottom: var(--ds-space-3);
  line-height: var(--ds-line-height-loose);
}

.ep-page__transcript-body {
  background: var(--surface-color-card);
  padding: var(--ds-space-5);
  border-radius: var(--ds-border-radius-md, 8px);
  border-left: 3px solid var(--surface-color-primary);
  font-size: var(--ds-font-size-sm);
  max-height: 600px;
  overflow-y: auto;
}

/* Cross-references grid */
.ep-page__refs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--ds-space-4);
}

/* Navigation prev/next */
.ep-page__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ds-space-3);
  margin-top: var(--ds-space-7);
  padding-top: var(--ds-space-5);
  border-top: 1px solid var(--surface-color-rule);
}

/* Mobile */
@media (max-width: 600px) {
  .ep-page__title { font-size: var(--ds-font-size-xl); }
  .ep-page__refs-grid { grid-template-columns: 1fr; }
  .ep-page__transcript-body { max-height: 400px; }
}
