/* ============================================================
   SiyaqCasts — Main Stylesheet
   Dark political podcast / video platform theme
   ============================================================ */

/* ── Tell browser this site is natively dark — prevents Samsung Browser
   Night Mode, Chrome Android Auto Dark Theme, etc. from inverting colors ── */
:root {
  color-scheme: dark;
}

html {
  color-scheme: dark;
}

/* ── 1. CSS Variables ──────────────────────────────────────── */
:root {
  /* ── Surface Hierarchy (4 elevation levels — Linear/Vercel style) ──────────── */
  --color-bg:          #050506;   /* base — deeper than pure black, slight warm tint */
  --color-bg-2:        #0a0a0c;   /* primary elevated — cards, sections */
  --color-bg-3:        #111114;   /* secondary elevated — nested elements, hover */
  --color-bg-4:        #18181c;   /* overlay level — modals, dropdowns */

  /* ── Brand colors ──────────────────────────────────────────────────────────── */
  --color-gold:        #d4a043;   /* slightly brighter for better contrast (WCAG AA) */
  --color-gold-light:  #e0b85e;
  --color-gold-pale:   rgba(212,160,67,0.12);
  --color-gold-glow:   rgba(212,160,67,0.25);

  /* ── Text — semantic naming with proper hierarchy ──────────────────────────── */
  --color-text-1:      #f5f5f7;   /* primary — slightly off-white (premium feel) */
  --color-text-2:      #c4c4c9;   /* body — soft grey-white */
  --color-text-3:      #8a8a92;   /* muted */
  --color-text-4:      #56565d;   /* very muted, captions */

  /* ── Borders — subtle, layered ──────────────────────────────────────────────── */
  --color-border:      rgba(255,255,255,0.06);   /* default — barely visible */
  --color-border-2:    rgba(255,255,255,0.10);   /* stronger, on hover */
  --color-border-gold: rgba(212,160,67,0.25);

  /* Legacy aliases for compatibility */
  --color-text-light:  var(--color-text-2);
  --color-text-muted:  var(--color-text-3);
  --color-white:       var(--color-text-1);

  /* ── Surface tokens (translucent overlays) ─────────────────────────────────── */
  --surface:           rgba(255,255,255,0.04);
  --surface-hover:     rgba(255,255,255,0.07);
  --surface-active:    rgba(255,255,255,0.10);

  /* ── Multi-layer shadows for cinematic depth ───────────────────────────────── */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.3), 0 1px 3px rgba(0,0,0,0.2);
  --shadow-lg: 0 10px 25px rgba(0,0,0,0.5), 0 4px 10px rgba(0,0,0,0.3), 0 1px 3px rgba(0,0,0,0.2);
  --shadow-glow: 0 0 40px rgba(212,160,67,0.15), 0 8px 24px rgba(0,0,0,0.4);
  --shadow-card:       var(--shadow-md);

  --color-breaking:    var(--color-gold);
  --font-body:         'Inter', sans-serif;
  --font-heading:      'Playfair Display', serif;
  --container:         1280px;
  --radius-sm:         4px;
  --radius-md:         8px;
  --radius-lg:         12px;
  --radius-xl:         20px;
  --radius-pill:       999px;

  /* ── Refined transitions — premium feel ────────────────────────────────────── */
  --ease-out:          cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out:       cubic-bezier(0.65, 0, 0.35, 1);
  --transition:        0.25s var(--ease-out);
  --transition-slow:   0.4s var(--ease-out);
}

/* ── Subtle noise texture for premium feel (very faint) ──────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.012;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* ── 2. Reset & Base ───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--color-bg);
  color: var(--color-text-1);
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; transition: color var(--transition); }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ── 3. Layout Utilities ───────────────────────────────────── */
.container {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 1.5rem;
}

.section-pad { padding-block: 4rem; }

/* ── 4. Typography ─────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text-1);
}

/* ── 5. Buttons ────────────────────────────────────────────── */
.btn-gold {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  background: var(--color-gold);
  color: #0a0a0a;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  border-radius: var(--radius-pill);
  border: 2px solid var(--color-gold);
  transition: background var(--transition), color var(--transition);
}
.btn-gold:hover { background: var(--color-gold-light); border-color: var(--color-gold-light); color: #000; }

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: transparent;
  color: var(--color-text-1);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--color-gold);
  transition: all var(--transition);
}
.btn-outline:hover { background: var(--color-gold-pale); color: var(--color-gold); }

.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  background: transparent;
  color: var(--color-text-2);
  font-size: 13px;
  font-weight: 500;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  transition: all var(--transition);
}
.btn-whatsapp:hover { border-color: #25d366; color: #25d366; }
.btn-whatsapp svg  { color: #25d366; flex-shrink: 0; }
.btn-whatsapp--full { width: 100%; justify-content: center; margin-top: 12px; }

/* ── 6. Breaking Ticker ────────────────────────────────────── */
.breaking-ticker {
  display: flex;
  align-items: center;
  height: 36px;
  background: var(--color-bg-2);
  border-bottom: 1px solid var(--color-border);
  overflow: hidden;
  position: relative;
  z-index: 100;
}

.ticker-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 14px;
  background: var(--color-gold);
  color: #0a0a0a;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  height: 100%;
  white-space: nowrap;
  flex-shrink: 0;
}

.ticker-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #0a0a0a;
  animation: tickerPulse 1.2s ease-in-out infinite;
}

@keyframes tickerPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

.ticker-track {
  flex: 1;
  overflow: hidden;
  height: 100%;
  display: flex;
  align-items: center;
}

.ticker-content {
  white-space: nowrap;
  font-size: 13px;
  color: var(--color-text-2);
  padding-left: 16px;
  animation: tickerScroll 20s linear infinite;
}

@keyframes tickerScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.ticker-social {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 16px;
  flex-shrink: 0;
}
.ticker-social-link { color: var(--color-text-3); display: flex; }
.ticker-social-link:hover { color: var(--color-gold); }

/* ── 7. Site Header ────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(10,10,10,0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
}

.header-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  height: 68px;
}

/* Logo */
.site-branding { flex-shrink: 0; }
.site-branding img { height: 44px; width: auto; }
.site-name {
  font-family: var(--font-heading);
  font-size: 22px;
  font-weight: 700;
  color: var(--color-white);
}

/* Nav */
.main-nav { flex: 1; }

.nav-menu {
  display: flex;
  align-items: center;
  gap: 0;
}

.nav-menu li { position: relative; }

.nav-menu a {
  display: block;
  padding: 8px 16px;
  font-size: 15px;
  color: var(--color-text-2);
  transition: color var(--transition);
}
.nav-menu a:hover,
.nav-menu .current-menu-item > a,
.nav-menu .current_page_item > a { color: var(--color-white); }

/* Gold underline on active item */
.nav-menu .current-menu-item > a::after,
.nav-menu .current_page_item > a::after {
  content: '';
  display: block;
  height: 2px;
  background: var(--color-gold);
  border-radius: 2px;
  margin-top: 2px;
}

/* Dropdown menus */
.nav-menu .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: var(--color-bg-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 8px 0;
  z-index: 200;
}
.nav-menu li:hover > .sub-menu { display: block; }
.nav-menu .sub-menu a { padding: 8px 16px; font-size: 14px; }

/* Header CTA */
.header-cta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-2);
  white-space: nowrap;
  transition: all var(--transition);
  flex-shrink: 0;
}
.header-cta:hover { border-color: #25d366; color: #25d366; }
.header-cta svg { color: #25d366; }

/* Mobile toggle */
.menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 6px;
  margin-left: auto;
}
.menu-toggle-bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text-2);
  border-radius: 2px;
  transition: all var(--transition);
}

/* ── 8. Hero Section ───────────────────────────────────────── */
.hero-section {
  position: relative;
  min-height: 420px;
  background: var(--color-bg-2);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10,10,10,0.95) 40%, rgba(10,10,10,0.3) 100%);
  z-index: 1;
}

.hero-inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
  padding-block: 4rem;
  width: 100%;
}

.hero-content { max-width: 520px; }

.hero-title {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 800;
  color: var(--color-white);
  margin-bottom: 0.5rem;
}

.hero-subtitle {
  font-size: 1.1rem;
  color: var(--color-text-2);
  margin-bottom: 2rem;
  font-family: var(--font-body);
  font-weight: 400;
}

.hero-cta { font-size: 15px; padding: 13px 26px; }

.hero-emblem {
  flex-shrink: 0;
  width: 340px;
}
.hero-emblem-img { width: 100%; height: auto; }

/* ── 9. Section Headers ────────────────────────────────────── */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.section-title {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 700;
  color: var(--color-white);
}

/* ── 10. Episode Tabs ──────────────────────────────────────── */
.episode-tabs {
  display: flex;
  align-items: center;
  gap: 0;
}

.episode-tab {
  padding: 6px 18px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-3);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  transition: all var(--transition);
  cursor: pointer;
}
.episode-tab:hover  { color: var(--color-text-2); }
.episode-tab.active {
  color: var(--color-white);
  border-bottom-color: var(--color-gold);
}

/* ── 11. Featured Episode ──────────────────────────────────── */
.featured-episode {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 2.5rem;
  margin-bottom: 3rem;
  align-items: center;
}

.featured-episode-media { position: relative; }

.featured-episode-thumb-link { display: block; position: relative; border-radius: var(--radius-lg); overflow: hidden; }
.featured-episode-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }

.featured-play-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.2);
  opacity: 0;
  transition: opacity var(--transition);
}
.featured-episode-thumb-link:hover .featured-play-overlay { opacity: 1; }

.play-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0a0a0a;
}
.play-icon svg { width: 26px; height: 26px; }

.featured-player-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--color-bg-3);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  font-size: 13px;
  color: var(--color-text-3);
}
.player-bar-icon { font-size: 10px; }
.player-bar-views, .player-bar-duration { display: flex; align-items: center; gap: 5px; }

.featured-episode-topics { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }

.topic-badge {
  display: inline-block;
  padding: 3px 11px;
  border-radius: var(--radius-pill);
  background: var(--color-gold-pale);
  border: 1px solid var(--color-border-gold);
  color: var(--color-gold);
  font-size: 12px;
  font-weight: 500;
  transition: background var(--transition);
}
.topic-badge:hover { background: var(--color-gold); color: #0a0a0a; }

.featured-episode-title {
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  margin-bottom: 0.75rem;
}
.featured-episode-title a:hover { color: var(--color-gold); }

.featured-episode-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  color: var(--color-text-3);
  margin-bottom: 12px;
}
.meta-channel { display: flex; align-items: center; gap: 5px; }

.featured-episode-excerpt { color: var(--color-text-2); font-size: 14px; line-height: 1.6; margin-bottom: 1.5rem; }

/* ── 12. Episode Grid ──────────────────────────────────────── */
.episodes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* Episode Card */
.episode-card {
  background: var(--color-bg-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  transition: border-color var(--transition), transform var(--transition);
}
.episode-card:hover { border-color: var(--color-border-gold); transform: translateY(-3px); }

.episode-card-thumb-link { display: block; }

.episode-card-thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--color-bg-3);
}
.episode-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.episode-card:hover .episode-card-thumb img { transform: scale(1.04); }
.episode-card-thumb-placeholder { width: 100%; height: 100%; background: var(--color-bg-4); }

.card-play-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition);
}
.episode-card:hover .card-play-overlay { opacity: 1; }

.card-play-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0a0a0a;
}

.badge-breaking {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 2px 8px;
  background: #e53935;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  z-index: 2;
}

.card-duration {
  position: absolute;
  bottom: 8px;
  right: 8px;
  padding: 2px 7px;
  background: rgba(0,0,0,0.75);
  color: #fff;
  font-size: 12px;
  border-radius: var(--radius-sm);
}

.episode-card-info { padding: 14px 16px 18px; }

.card-topics { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.card-topic-link { font-size: 11px; color: var(--color-gold); font-weight: 500; }
.card-topic-link:hover { text-decoration: underline; }

.episode-card-title { font-size: 15px; font-weight: 600; line-height: 1.35; margin-bottom: 8px; font-family: var(--font-body); }
.episode-card-title a:hover { color: var(--color-gold); }

.card-meta { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--color-text-3); flex-wrap: wrap; }
.card-meta-channel { display: flex; align-items: center; gap: 4px; }

/* Loading */
.episodes-loading { display: flex; justify-content: center; padding: 2rem; }
.loading-spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-gold);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.load-more-wrap { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.view-all-link { display: inline-flex; align-items: center; gap: 0.5rem; }

/* ── 13. Trending Section ──────────────────────────────────── */
.trending-section { background: var(--color-bg-2); }

.trending-tags {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.trending-tag {
  display: inline-block;
  padding: 6px 18px;
  border-radius: var(--radius-pill);
  background: var(--color-bg-3);
  border: 1px solid var(--color-border);
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-2);
  transition: all var(--transition);
}
.trending-tag:hover,
.trending-tag--active { background: var(--color-gold); color: #0a0a0a; border-color: var(--color-gold); }
.trending-tag--sm { padding: 4px 12px; font-size: 12px; }

/* Thumbnail strip */
.trending-strip { overflow-x: auto; scrollbar-width: thin; scrollbar-color: var(--color-border) transparent; }
.trending-strip::-webkit-scrollbar { height: 4px; }
.trending-strip::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

.trending-strip-inner {
  display: flex;
  gap: 12px;
  padding-bottom: 8px;
  min-width: max-content;
}

.strip-item {
  display: block;
  position: relative;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.strip-thumb {
  position: relative;
  width: 160px;
  aspect-ratio: 16/9;
  background: var(--color-bg-3);
}
.strip-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.strip-item:hover .strip-thumb img { transform: scale(1.05); }

.strip-play-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.3);
  color: var(--color-gold);
}

.strip-meta {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 4px 8px;
  background: rgba(0,0,0,0.7);
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--color-text-2);
}

/* ── 14. About Section ─────────────────────────────────────── */
.about-section { background: var(--color-bg-2); }

.about-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.about-title {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  margin-bottom: 0.5rem;
}
.about-subtitle { font-size: 1rem; color: var(--color-text-2); margin-bottom: 1.25rem; }
.about-text { color: var(--color-text-2); font-size: 14px; line-height: 1.75; margin-bottom: 1.75rem; }
.about-text p { margin-bottom: 0.75rem; }
.about-btn { }

.about-photo-wrap { text-align: center; }
.about-host-photo {
  width: 100%;
  max-width: 420px;
  border-radius: var(--radius-lg);
  object-fit: cover;
  filter: grayscale(20%);
  margin-inline: auto;
}

/* ── 15. Single Episode Page ───────────────────────────────── */
.episode-page { padding-block: 2rem; }

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-text-3);
  margin-bottom: 1.5rem;
}
.breadcrumb a:hover { color: var(--color-gold); }
.breadcrumb-sep { color: var(--color-text-4); }
.breadcrumb-current { color: var(--color-text-2); }

/* Two-column layout */
.episode-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 2.5rem;
  align-items: start;
}

.episode-main {}

/* Episode header */
.episode-header { margin-bottom: 1.25rem; }

.episode-title {
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.25;
  margin-bottom: 0.75rem;
}

.episode-meta-bar {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 13px;
  color: var(--color-text-3);
  flex-wrap: wrap;
}
.episode-date, .episode-duration, .episode-views { display: flex; align-items: center; gap: 6px; }

/* Video player */
.episode-player-wrap { margin-bottom: 1.75rem; }

.video-player { border-radius: var(--radius-lg); overflow: hidden; background: #000; aspect-ratio: 16/9; }
.video-player iframe,
.video-player video { width: 100%; height: 100%; border: none; display: block; }
.video-player--placeholder img { width: 100%; height: 100%; object-fit: cover; }
.video-player__no-video { padding: 1rem; color: var(--color-text-3); text-align: center; font-size: 13px; }

/* Episode content sections */
.episode-description { color: var(--color-text-2); font-size: 15px; line-height: 1.75; margin-bottom: 2rem; }

.episode-section-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-border);
}

.episode-highlights { margin-bottom: 2rem; }
.highlights-list { display: flex; flex-direction: column; gap: 10px; }
.highlight-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 14px;
  color: var(--color-text-2);
  line-height: 1.5;
}
.highlight-bullet { color: var(--color-gold); font-size: 18px; line-height: 1; flex-shrink: 0; margin-top: 1px; }

.episode-topics { margin-bottom: 2rem; }
.episode-topic-item { margin-bottom: 1.5rem; }
.topic-item-title { font-size: 1.05rem; font-weight: 600; color: var(--color-gold); margin-bottom: 0.5rem; font-family: var(--font-body); }
.topic-item-content { font-size: 14px; color: var(--color-text-2); line-height: 1.7; }

.episode-tags { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 2rem; }
.tags-label { font-size: 13px; color: var(--color-text-3); font-weight: 500; }

/* Related strip at bottom of single */
.episode-related-strip { margin-top: 2rem; }
.related-strip-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.related-strip-item { border-radius: var(--radius-md); overflow: hidden; background: var(--color-bg-2); }
.related-strip-thumb { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.related-strip-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.related-strip-item:hover .related-strip-thumb img { transform: scale(1.05); }
.related-strip-info { padding: 6px 8px; display: flex; justify-content: space-between; font-size: 11px; color: var(--color-text-3); }

/* ── 16. Sidebar ───────────────────────────────────────────── */
.episode-sidebar {
  position: sticky;
  top: 80px;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.sidebar-widget {
  background: var(--color-bg-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
}

.widget-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-white);
  margin-bottom: 1rem;
  padding-bottom: 0.625rem;
  border-bottom: 1px solid var(--color-border);
}

/* Related episodes widget */
.related-episodes-list { display: flex; flex-direction: column; gap: 12px; }
.related-episode-item {}
.related-episode-link {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.related-episode-thumb {
  position: relative;
  width: 100px;
  flex-shrink: 0;
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.related-episode-thumb img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.related-episode-duration {
  position: absolute;
  bottom: 3px;
  right: 3px;
  font-size: 10px;
  background: rgba(0,0,0,0.75);
  color: #fff;
  padding: 1px 5px;
  border-radius: 3px;
}
.related-episode-info { flex: 1; }
.related-episode-title {
  font-size: 13px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--color-text-1);
  font-family: var(--font-body);
  margin-bottom: 4px;
  transition: color var(--transition);
}
.related-episode-link:hover .related-episode-title { color: var(--color-gold); }
.related-episode-meta { font-size: 11px; color: var(--color-text-3); }

/* Social follow widget */
.social-follow-icons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: var(--color-bg-3);
  border: 1px solid var(--color-border);
  color: var(--color-text-2);
  transition: all var(--transition);
}
.social-icon:hover { background: var(--color-gold-pale); border-color: var(--color-border-gold); color: var(--color-gold); }

/* Host photo widget */
.host-photo-wrap {}
.host-photo { width: 100%; border-radius: var(--radius-md); display: block; }
.host-caption { text-align: center; font-size: 12px; color: var(--color-text-3); margin-top: 8px; }

/* About widget */
.about-widget-content {}
.about-widget-subtitle { font-size: 13px; color: var(--color-gold); font-weight: 500; margin-bottom: 8px; }
.about-widget-text { font-size: 13px; color: var(--color-text-2); line-height: 1.6; margin-bottom: 12px; }
.about-widget-social { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }

/* ── 17. Archive / Search ──────────────────────────────────── */
.archive-header { margin-bottom: 2.5rem; }
.archive-title { font-size: clamp(1.5rem, 3vw, 2.2rem); margin-bottom: 0.5rem; }
.archive-description { color: var(--color-text-2); font-size: 14px; }

/* ── 18. Pagination ────────────────────────────────────────── */
.pagination { display: flex; justify-content: center; margin-top: 3rem; }
.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  font-size: 14px;
  color: var(--color-text-3);
  border: 1px solid var(--color-border);
  margin: 0 3px;
  transition: all var(--transition);
}
.pagination .page-numbers:hover,
.pagination .page-numbers.current { background: var(--color-gold); color: #0a0a0a; border-color: var(--color-gold); }

/* ── 19. Footer ────────────────────────────────────────────── */
.site-footer {
  background: var(--color-bg-2);
  border-top: 1px solid var(--color-border);
  padding-top: 2rem;
}

.footer-main {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 1.5rem;
}

.footer-brand img { height: 40px; }
.footer-site-name { font-family: var(--font-heading); font-size: 20px; color: var(--color-white); }

.footer-nav {}
.footer-menu {
  display: flex;
  gap: 0;
  flex-wrap: wrap;
}
.footer-menu a { padding: 4px 14px; font-size: 14px; color: var(--color-text-3); transition: color var(--transition); }
.footer-menu a:hover { color: var(--color-white); }
.footer-menu .current-menu-item > a { color: var(--color-gold); }

.footer-widgets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 1.5rem;
}
.footer-widget {}
.footer-widget-title { font-size: 14px; font-weight: 600; color: var(--color-text-1); margin-bottom: 0.75rem; }

.footer-bottom {
  padding: 1.25rem 0;
  border-top: 1px solid var(--color-border);
  text-align: center;
}
.footer-copyright { font-size: 13px; color: var(--color-text-4); }

/* ── 20. 404 ───────────────────────────────────────────────── */
.error-404-title { font-size: 7rem; color: var(--color-gold); margin-bottom: 0.5rem; }
.error-404-text  { font-size: 1.1rem; color: var(--color-text-2); margin-bottom: 2rem; }

/* ── 21. No content ────────────────────────────────────────── */
.no-posts, .no-episodes, .widget-no-content {
  color: var(--color-text-3);
  font-size: 14px;
  text-align: center;
  padding: 2rem;
}

/* ── 22. WordPress Core Classes ────────────────────────────── */
.alignleft  { float: left; margin-right: 1.5rem; margin-bottom: 1rem; }
.alignright { float: right; margin-left: 1.5rem; margin-bottom: 1rem; }
.aligncenter { display: block; margin-inline: auto; margin-bottom: 1rem; }
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 12px; color: var(--color-text-3); text-align: center; margin-top: 4px; }

/* Screen reader only */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  height: 1px;
  width: 1px;
  overflow: hidden;
}