/* =====================================================
   LOS COLADOS — Estilos Principales
   Versión: 1.0.0
   Tema: Oscuro con acentos en oro y rojo
   ===================================================== */

/* ── Variables ── */
:root {
  --bg-primary:       #0a0a0a;
  --bg-secondary:     #111111;
  --bg-card:          #1a1a1a;
  --bg-card-hover:    #212121;
  --bg-alt:           #131313;
  --accent-gold:      #f5c518;
  --accent-gold-dark: #d4a017;
  --accent-red:       #e50914;
  --accent-red-dark:  #b8000f;
  --text-primary:     #ffffff;
  --text-secondary:   #b3b3b3;
  --text-muted:       #666666;
  --border-color:     #2a2a2a;
  --border-light:     #333333;
  --player-bg:        #141414;
  --player-height:    88px;
  --header-height:    64px;
  --radius-sm:        6px;
  --radius-md:        12px;
  --radius-lg:        18px;
  --shadow-sm:        0 2px 8px rgba(0,0,0,.4);
  --shadow-md:        0 4px 20px rgba(0,0,0,.5);
  --shadow-lg:        0 8px 40px rgba(0,0,0,.6);
  --transition:       0.25s ease;
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; font-size: 16px; }

body.dark-theme {
  background-color: var(--bg-primary);
  color:            var(--text-primary);
  font-family:      'Inter', system-ui, sans-serif;
  line-height:      1.6;
  min-height:       100vh;
  padding-bottom:   calc(var(--player-height) + 20px);
}

a { color: var(--accent-gold); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--accent-gold-dark); }

img { max-width: 100%; height: auto; }

/* ── Scrollbar ── */
::-webkit-scrollbar              { width: 6px; height: 6px; }
::-webkit-scrollbar-track        { background: var(--bg-secondary); }
::-webkit-scrollbar-thumb        { background: #333; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover  { background: var(--accent-gold); }

/* ── Utilidades de color ── */
.text-gold   { color: var(--accent-gold) !important; }
.text-red    { color: var(--accent-red)  !important; }
.text-green  { color: #2ecc71 !important; }
.text-orange { color: #e67e22 !important; }

/* ── Botones personalizados ── */
.btn-gold {
  background:    var(--accent-gold);
  border-color:  var(--accent-gold);
  color:         #000;
  font-weight:   600;
  transition:    all var(--transition);
}
.btn-gold:hover, .btn-gold:focus {
  background:   var(--accent-gold-dark);
  border-color: var(--accent-gold-dark);
  color:        #000;
  transform:    translateY(-1px);
  box-shadow:   0 4px 15px rgba(245,197,24,.3);
}
.btn-outline-gold {
  border:  1px solid var(--accent-gold);
  color:   var(--accent-gold);
  background: transparent;
  font-weight: 600;
  transition: all var(--transition);
}
.btn-outline-gold:hover {
  background:  var(--accent-gold);
  color:       #000;
}
.btn-icon {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  padding: 6px;
  cursor: pointer;
  transition: color var(--transition);
}
.btn-icon:hover { color: var(--text-primary); }

/* ── Cards oscuras ── */
.card-dark {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding:       1.5rem;
  margin-bottom: 1.5rem;
}

/* ── Header / Navbar ── */
.site-header {
  position:   sticky;
  top:        0;
  z-index:    1000;
  background: rgba(10,10,10,.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-color);
  height: var(--header-height);
}

#mainNav {
  padding-top: 0;
  padding-bottom: 0;
  height: 100%;
}

.logo-brand {
  display:         flex;
  flex-direction:  column;
  line-height:     1;
  text-decoration: none;
}
.logo-main {
  font-family:   'Playfair Display', serif;
  font-size:     1.5rem;
  font-weight:   900;
  letter-spacing: 2px;
  color:          var(--text-primary);
}
.logo-accent    { color: var(--accent-gold); }
.logo-tagline   { font-size: .65rem; letter-spacing: 3px; color: var(--text-muted); text-transform: uppercase; }

.navbar-nav .nav-link {
  color:       var(--text-secondary);
  font-size:   .9rem;
  font-weight: 500;
  padding:     0 .9rem;
  transition:  color var(--transition);
  height:      var(--header-height);
  display:     flex;
  align-items: center;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active { color: var(--text-primary); }

.navbar-toggler {
  border: 1px solid var(--border-color);
  padding: .35rem .6rem;
}
.navbar-toggler-icon { filter: invert(1); }

/* Search */
.search-wrapper { position: relative; }
.search-input-group {
  display:       flex;
  align-items:   center;
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: 50px;
  overflow:      hidden;
  transition:    border-color var(--transition);
}
.search-input-group:focus-within { border-color: var(--accent-gold); }
.search-input {
  background:    transparent;
  border:        none;
  outline:       none;
  color:         var(--text-primary);
  padding:       8px 14px;
  font-size:     .875rem;
  width:         220px;
}
.search-btn {
  background:    var(--accent-gold);
  border:        none;
  color:         #000;
  padding:       8px 14px;
  cursor:        pointer;
  transition:    background var(--transition);
}
.search-btn:hover { background: var(--accent-gold-dark); }
.search-suggestions {
  position:      absolute;
  top:           100%;
  left:          0;
  right:         0;
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-top:    none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  z-index:       200;
  display:       none;
  max-height:    300px;
  overflow-y:    auto;
}
.suggestion-item {
  padding: .6rem 1rem;
  cursor:  pointer;
  font-size: .875rem;
  transition: background var(--transition);
}
.suggestion-item:hover { background: var(--bg-card-hover); }

/* User menu */
.btn-user {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  color:         var(--text-secondary);
  display:       flex;
  align-items:   center;
  gap:           .5rem;
  padding:       6px 12px;
  border-radius: 50px;
  font-size:     .875rem;
}
.user-avatar-sm {
  width:         28px;
  height:        28px;
  border-radius: 50%;
  object-fit:    cover;
}
.dropdown-menu-dark { background: var(--bg-card); border: 1px solid var(--border-color); }
.dropdown-item      { color: var(--text-secondary); transition: all var(--transition); }
.dropdown-item:hover{ color: var(--text-primary); background: var(--bg-card-hover); }

/* ── Hero ── */
.hero-section {
  position:      relative;
  min-height:    100vh;
  display:       flex;
  align-items:   center;
  overflow:      hidden;
  background:    linear-gradient(135deg, #0a0a0a 0%, #1a0a00 50%, #0a0a0a 100%);
}
.hero-bg-overlay {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 60% 50%, rgba(245,197,24,.08) 0%, transparent 60%),
              radial-gradient(ellipse at 20% 70%, rgba(229,9,20,.06) 0%, transparent 50%);
  pointer-events: none;
}
.hero-content {
  position:   relative;
  z-index:    1;
  max-width:  700px;
  padding:    6rem 0 8rem;
}
.hero-logo-wrapper { margin-bottom: 1rem; }
.hero-logo {
  font-family:   'Playfair Display', serif;
  font-size:     clamp(3rem, 8vw, 6rem);
  font-weight:   900;
  letter-spacing: 4px;
  line-height:   1;
  margin:        0;
}
.hero-logo-line {
  height:     4px;
  width:      80px;
  background: var(--accent-gold);
  margin-top: 1rem;
  border-radius: 2px;
}
.hero-tagline {
  font-family: 'Playfair Display', serif;
  font-size:   clamp(1.2rem, 3vw, 1.8rem);
  font-weight: 700;
  color:       var(--text-secondary);
  margin:      1.5rem 0 .5rem;
  line-height: 1.3;
}
.hero-sub { color: var(--text-muted); font-size: 1rem; margin-bottom: 2rem; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 2rem; }
.btn-hero { padding: .75rem 2rem; font-size: 1rem; font-weight: 600; border-radius: 50px; }
.hero-platforms { display: flex; align-items: center; gap: .75rem; }
.platform-link {
  font-size:     1.5rem;
  color:         var(--text-muted);
  transition:    color var(--transition), transform var(--transition);
}
.platform-link:hover { color: var(--accent-gold); transform: scale(1.15); }
.hero-scroll-indicator {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display:  flex; flex-direction: column; align-items: center; gap: 4px;
}
.hero-scroll-indicator span {
  display: block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-gold); opacity: .4;
  animation: scrollBounce 1.5s infinite;
}
.hero-scroll-indicator span:nth-child(2) { animation-delay: .2s; }
.hero-scroll-indicator span:nth-child(3) { animation-delay: .4s; }
@keyframes scrollBounce {
  0%, 100% { opacity: .2; transform: translateY(0); }
  50%       { opacity: 1;  transform: translateY(4px); }
}

/* ── Secciones de inicio ── */
.section-home {
  padding: 4rem 0;
}
.section-dark-alt { background: var(--bg-secondary); }
.section-header {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  margin-bottom:   2rem;
}
.section-title {
  font-family: 'Playfair Display', serif;
  font-size:   1.75rem;
  font-weight: 700;
  margin:      0;
}
.section-subtitle {
  font-size:   1.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
.section-link {
  color:      var(--text-muted);
  font-size:  .875rem;
  font-weight: 500;
  transition: color var(--transition);
}
.section-link:hover { color: var(--accent-gold); }

/* ── Episode Cards ── */
.episodes-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:                   1.5rem;
}

.episode-card {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow:      hidden;
  transition:    transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  cursor:        pointer;
}
.episode-card:hover {
  transform:    translateY(-4px);
  box-shadow:   var(--shadow-md);
  border-color: var(--border-light);
}
.episode-card-cover {
  position:    relative;
  aspect-ratio: 1/1;
  overflow:    hidden;
}
.episode-cover-img {
  width:            100%;
  height:           100%;
  object-fit:       cover;
  transition:       transform .4s ease;
  display:          block;
}
.episode-card:hover .episode-cover-img { transform: scale(1.05); }

.play-overlay-btn {
  position:       absolute;
  inset:          0;
  display:        flex;
  align-items:    center;
  justify-content: center;
  background:     rgba(0,0,0,.5);
  color:          #fff;
  border:         none;
  cursor:         pointer;
  opacity:        0;
  transition:     opacity var(--transition);
  font-size:      2.5rem;
}
.episode-card:hover .play-overlay-btn { opacity: 1; }

.badge-featured {
  position:      absolute;
  top:           .75rem;
  left:          .75rem;
  background:    var(--accent-gold);
  color:         #000;
  font-size:     .7rem;
  font-weight:   700;
  padding:       3px 8px;
  border-radius: 50px;
}
.badge-category {
  position:      absolute;
  bottom:        .75rem;
  left:          .75rem;
  background:    rgba(0,0,0,.75);
  color:         var(--text-secondary);
  font-size:     .7rem;
  padding:       3px 8px;
  border-radius: 50px;
  text-decoration: none;
  transition:    color var(--transition);
}
.badge-category:hover { color: var(--accent-gold); }

.episode-card-body { padding: 1rem; }
.episode-meta {
  display:        flex;
  gap:            .75rem;
  align-items:    center;
  margin-bottom:  .5rem;
  font-size:      .75rem;
  color:          var(--text-muted);
}
.ep-number {
  background:    var(--accent-gold);
  color:         #000;
  font-weight:   700;
  padding:       2px 6px;
  border-radius: 4px;
  font-size:     .7rem;
}
.episode-card-title {
  font-size:   1rem;
  font-weight: 600;
  margin:      0 0 .5rem;
  line-height: 1.3;
}
.episode-card-title a { color: var(--text-primary); transition: color var(--transition); }
.episode-card-title a:hover { color: var(--accent-gold); }
.episode-card-desc { font-size: .825rem; color: var(--text-muted); margin-bottom: .75rem; }
.episode-stats {
  display:     flex;
  gap:         .75rem;
  font-size:   .75rem;
  color:       var(--text-muted);
}
.episode-stats span { display: flex; align-items: center; gap: 3px; }

/* ── Carrusel ── */
.carousel-episode {
  display:        flex;
  gap:            2rem;
  align-items:    center;
  padding:        1rem;
  background:     var(--bg-card);
  border-radius:  var(--radius-lg);
  min-height:     340px;
}
.carousel-ep-cover {
  position:      relative;
  flex-shrink:   0;
  width:         clamp(200px, 30vw, 300px);
  aspect-ratio:  1/1;
  border-radius: var(--radius-md);
  overflow:      hidden;
}
.carousel-ep-cover img {
  width: 100%; height: 100%; object-fit: cover;
}
.carousel-ep-overlay {
  position:        absolute;
  inset:           0;
  display:         flex;
  align-items:     center;
  justify-content: center;
  background:      rgba(0,0,0,.4);
  opacity:         0;
  transition:      opacity var(--transition);
}
.carousel-episode:hover .carousel-ep-overlay { opacity: 1; }
.btn-play-big {
  width:      70px; height: 70px;
  border-radius: 50%;
  background: var(--accent-gold);
  border:     none;
  color:      #000;
  font-size:  1.5rem;
  cursor:     pointer;
  transition: transform var(--transition), background var(--transition);
}
.btn-play-big:hover { background: var(--accent-gold-dark); transform: scale(1.1); }

.ep-badge {
  background: var(--accent-red);
  color:      #fff;
  font-size:  .75rem;
  font-weight: 700;
  padding:    3px 10px;
  border-radius: 50px;
  display:    inline-block;
  margin-bottom: .5rem;
}
.ep-num-sm { color: var(--text-muted); font-size: .8rem; margin-left: .5rem; }
.carousel-ep-title {
  font-family: 'Playfair Display', serif;
  font-size:   1.6rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: .75rem;
}
.carousel-ep-title a { color: var(--text-primary); }
.carousel-ep-title a:hover { color: var(--accent-gold); }
.carousel-ep-desc { color: var(--text-secondary); margin-bottom: 1rem; font-size: .9rem; }
.carousel-ep-meta { display: flex; gap: 1.25rem; color: var(--text-muted); font-size: .85rem; margin-bottom: 1rem; }
.carousel-ep-actions { display: flex; gap: .75rem; }

.carousel-indicators-custom { bottom: -40px; }
.carousel-indicators-custom button {
  width:         10px; height: 10px;
  border-radius: 50%;
  background:    var(--border-light);
  border:        none;
  opacity:       1;
}
.carousel-indicators-custom button.active { background: var(--accent-gold); }

/* ── Popular list ── */
.popular-list { display: flex; flex-direction: column; gap: .75rem; }
.popular-item {
  display:        flex;
  align-items:    center;
  gap:            1rem;
  padding:        .75rem;
  background:     var(--bg-card);
  border-radius:  var(--radius-sm);
  border:         1px solid var(--border-color);
  transition:     border-color var(--transition);
}
.popular-item:hover { border-color: var(--accent-gold); }
.popular-rank {
  font-family:   'Playfair Display', serif;
  font-size:     1.5rem;
  font-weight:   700;
  color:         var(--text-muted);
  min-width:     2rem;
  text-align:    center;
}
.rank-gold   { color: var(--accent-gold); }
.rank-silver { color: #9e9e9e; }
.rank-bronze { color: #cd7f32; }
.popular-cover {
  width: 56px; height: 56px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}
.popular-info { flex: 1; min-width: 0; }
.popular-title {
  display:       block;
  color:         var(--text-primary);
  font-weight:   600;
  font-size:     .9rem;
  white-space:   nowrap;
  overflow:      hidden;
  text-overflow: ellipsis;
  margin-bottom: .2rem;
}
.popular-title:hover { color: var(--accent-gold); }
.popular-meta { font-size: .75rem; color: var(--text-muted); }
.popular-play {
  background:    rgba(245,197,24,.1);
  border:        1px solid var(--accent-gold);
  color:         var(--accent-gold);
  width:         38px; height: 38px;
  border-radius: 50%;
  cursor:        pointer;
  flex-shrink:   0;
  transition:    all var(--transition);
}
.popular-play:hover { background: var(--accent-gold); color: #000; }

/* ── Guests scroller ── */
.guests-scroller {
  display:    flex;
  gap:        1rem;
  overflow-x: auto;
  padding-bottom: .5rem;
}
.guests-scroller::-webkit-scrollbar { height: 4px; }
.guest-pill {
  display:       flex;
  flex-direction: column;
  align-items:   center;
  gap:           .5rem;
  min-width:     90px;
  text-align:    center;
  cursor:        pointer;
  transition:    transform var(--transition);
}
.guest-pill:hover { transform: translateY(-3px); }
.guest-pill-photo {
  width:         70px; height: 70px;
  border-radius: 50%;
  object-fit:    cover;
  border:        3px solid var(--border-color);
  transition:    border-color var(--transition);
}
.guest-pill:hover .guest-pill-photo { border-color: var(--accent-gold); }
.guest-pill-name { font-size: .8rem; color: var(--text-secondary); }

/* ── Categories grid (home) ── */
.categories-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap:                   1rem;
}
.category-card {
  display:       flex;
  flex-direction: column;
  align-items:   center;
  padding:       1.5rem 1rem;
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition:    all var(--transition);
  text-align:    center;
}
.category-card:hover {
  border-color: var(--cat-color, var(--accent-gold));
  transform:    translateY(-3px);
  box-shadow:   0 4px 20px rgba(0,0,0,.4);
}
.category-icon {
  font-size:     2rem;
  color:         var(--cat-color, var(--accent-gold));
  margin-bottom: .75rem;
}
.category-name { font-weight: 600; font-size: .9rem; color: var(--text-primary); margin-bottom: .25rem; }
.category-count { font-size: .75rem; color: var(--text-muted); }

/* Large categories page */
.categories-grid-large {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap:                   1.5rem;
}
.category-card-large {
  display:        flex;
  flex-direction: column;
  padding:        2rem 1.5rem;
  background:     var(--bg-card);
  border:         2px solid var(--border-color);
  border-radius:  var(--radius-lg);
  text-decoration: none;
  position:       relative;
  overflow:       hidden;
  transition:     all var(--transition);
}
.category-card-large::before {
  content:     '';
  position:    absolute;
  top:         0; left: 0; right: 0;
  height:      4px;
  background:  var(--cat-color, var(--accent-gold));
}
.category-card-large:hover {
  border-color: var(--cat-color, var(--accent-gold));
  transform:    translateY(-4px);
  box-shadow:   var(--shadow-md);
}
.category-card-icon { font-size: 2.5rem; color: var(--cat-color, var(--accent-gold)); margin-bottom: 1rem; }
.category-card-name { font-size: 1.2rem; font-weight: 700; color: var(--text-primary); margin-bottom: .5rem; }
.category-card-desc { font-size: .85rem; color: var(--text-muted); flex: 1; margin-bottom: 1rem; }
.category-card-count { font-size: .8rem; color: var(--text-secondary); font-weight: 600; }
.category-card-arrow { position: absolute; bottom: 1rem; right: 1.25rem; color: var(--cat-color, var(--accent-gold)); opacity: .5; }

/* ── Newsletter section ── */
.section-newsletter {
  padding: 4rem 0;
  background: linear-gradient(135deg, rgba(245,197,24,.05) 0%, transparent 100%);
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
}
.newsletter-cta {
  display:        flex;
  align-items:    center;
  gap:            2rem;
  flex-wrap:      wrap;
}
.newsletter-cta-icon { font-size: 3rem; color: var(--accent-gold); }
.newsletter-cta-text { flex: 1; }
.newsletter-cta-text h3 { font-family: 'Playfair Display', serif; font-size: 1.5rem; margin-bottom: .25rem; }
.newsletter-cta-form { min-width: 280px; }
.newsletter-input-group { max-width: 420px; }
.newsletter-input-group .form-control {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  color:         var(--text-primary);
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
}
.newsletter-input-group .form-control:focus { border-color: var(--accent-gold); box-shadow: none; }

/* Footer newsletter */
.footer-newsletter .newsletter-input-group { display: flex; }
.footer-newsletter .newsletter-input {
  flex:       1;
  background: var(--bg-card);
  border:     1px solid var(--border-color);
  border-right: none;
  color:      var(--text-primary);
  padding:    .5rem 1rem;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  font-size:  .875rem;
}
.footer-newsletter .newsletter-input:focus { outline: none; border-color: var(--accent-gold); }
.footer-newsletter .newsletter-btn {
  background:    var(--accent-gold);
  border:        none;
  color:         #000;
  padding:       .5rem 1rem;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  cursor:        pointer;
  transition:    background var(--transition);
}
.footer-newsletter .newsletter-btn:hover { background: var(--accent-gold-dark); }

/* ── Footer ── */
.site-footer {
  background:    var(--bg-secondary);
  border-top:    1px solid var(--border-color);
  padding:       3rem 0 0;
  margin-top:    auto;
}
.footer-top { padding-bottom: 3rem; }
.footer-logo { display: block; margin-bottom: .75rem; }
.footer-tagline { color: var(--text-muted); font-size: .9rem; line-height: 1.5; }
.footer-socials { display: flex; gap: .75rem; margin-top: 1rem; }
.social-btn {
  width:          36px; height: 36px;
  border-radius:  50%;
  background:     var(--bg-card);
  border:         1px solid var(--border-color);
  display:        flex;
  align-items:    center;
  justify-content: center;
  color:          var(--text-muted);
  font-size:      .9rem;
  transition:     all var(--transition);
  text-decoration: none;
}
.social-btn:hover         { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.social-spotify:hover     { background: #1db954; border-color: #1db954; color: #fff; }
.social-apple:hover       { background: #fc3c44; border-color: #fc3c44; color: #fff; }
.social-instagram:hover   { background: linear-gradient(45deg, #f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-color: #dc2743; color: #fff; }
.social-tiktok:hover      { background: #010101; border-color: #69c9d0; color: #69c9d0; }
.social-youtube:hover     { background: #ff0000; border-color: #ff0000; color: #fff; }
.social-x:hover           { background: #000; border-color: #fff; color: #fff; }
.social-whatsapp:hover    { background: #25d366; border-color: #25d366; color: #fff; }

.footer-heading { color: var(--text-primary); font-size: .85rem; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 1rem; font-weight: 600; }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: .5rem; }
.footer-links a { color: var(--text-muted); font-size: .875rem; transition: color var(--transition); }
.footer-links a:hover { color: var(--accent-gold); }

.footer-bottom {
  border-top:      1px solid var(--border-color);
  padding:         1rem 0;
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  flex-wrap:       wrap;
  gap:             .5rem;
  font-size:       .8rem;
}
.footer-bottom-links { display: flex; gap: 1rem; }
.footer-bottom-links a { color: var(--text-muted); transition: color var(--transition); }
.footer-bottom-links a:hover { color: var(--accent-gold); }

/* ── Reproductor ── */
.audio-player {
  position:   fixed;
  bottom:     0; left: 0; right: 0;
  z-index:    2000;
  background: var(--player-bg);
  border-top: 2px solid var(--accent-gold);
  box-shadow: 0 -4px 30px rgba(0,0,0,.7);
}
.full-player { padding: 0 .5rem .5rem; }

.player-progress-wrapper { padding: 4px 0 0; }
.player-progress-bar {
  position:   relative;
  height:     4px;
  background: var(--border-color);
  cursor:     pointer;
  transition: height var(--transition);
}
.player-progress-bar:hover { height: 6px; }
.player-progress-fill {
  height:         100%;
  background:     var(--accent-gold);
  border-radius:  2px;
  pointer-events: none;
  width:          0%;
  transition:     width .1s linear;
}
.player-progress-thumb {
  position:    absolute;
  top:         50%;
  transform:   translate(-50%, -50%);
  width:       12px; height: 12px;
  border-radius: 50%;
  background:  var(--accent-gold);
  opacity:     0;
  pointer-events: none;
  transition:  opacity var(--transition);
  left:        0%;
}
.player-progress-bar:hover .player-progress-thumb { opacity: 1; }
.player-times {
  display:  flex;
  justify-content: space-between;
  font-size: .72rem;
  color:    var(--text-muted);
  padding:  2px 2px 0;
}

.player-body {
  display:        flex;
  align-items:    center;
  gap:            1rem;
  padding:        .5rem .5rem 0;
  min-height:     60px;
}

.player-episode-info {
  display:    flex;
  align-items: center;
  gap:         .75rem;
  min-width:   0;
  flex:        1;
  max-width:   300px;
}
.player-cover {
  width:         48px; height: 48px;
  border-radius: var(--radius-sm);
  object-fit:    cover;
  flex-shrink:   0;
}
.player-meta { min-width: 0; }
.player-episode-num { font-size: .7rem; color: var(--accent-gold); font-weight: 700; display: block; }
.player-title {
  font-size:     .875rem;
  font-weight:   600;
  white-space:   nowrap;
  overflow:      hidden;
  text-overflow: ellipsis;
  display:       block;
  color:         var(--text-primary);
}

.player-controls {
  display:         flex;
  align-items:     center;
  gap:             .5rem;
  flex:            0 0 auto;
}
.player-btn {
  background:    transparent;
  border:        none;
  color:         var(--text-secondary);
  cursor:        pointer;
  padding:       6px;
  border-radius: 50%;
  transition:    all var(--transition);
  display:       flex;
  align-items:   center;
  justify-content: center;
  font-size:     1rem;
}
.player-btn:hover { color: var(--text-primary); background: rgba(255,255,255,.08); }
.player-btn-main {
  background:  var(--accent-gold) !important;
  color:       #000 !important;
  width:       44px; height: 44px;
  font-size:   1.1rem;
  border-radius: 50%;
}
.player-btn-main:hover { background: var(--accent-gold-dark) !important; transform: scale(1.05); }
.player-btn-rewind, .player-btn-forward {
  font-size: .65rem;
  position:  relative;
}
.player-btn-rewind span,
.player-btn-forward span {
  position:  absolute;
  bottom:    2px;
  font-size: .55rem;
  font-weight: 700;
}

.player-secondary {
  display:     flex;
  align-items: center;
  gap:         .35rem;
  flex:        1;
  justify-content: flex-end;
}
.player-btn-sm { font-size: .8rem; padding: 5px 8px; border-radius: var(--radius-sm); }
.player-btn-sm.active { color: var(--accent-gold); }

.volume-control { display: flex; align-items: center; gap: .25rem; }
.volume-slider {
  -webkit-appearance: none;
  width:           80px;
  height:          3px;
  background:      var(--border-light);
  border-radius:   2px;
  outline:         none;
  cursor:          pointer;
}
.volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width:  12px; height: 12px;
  border-radius: 50%;
  background:    var(--accent-gold);
  cursor:        pointer;
}

.speed-menu { min-width: 80px; }
.speed-option { font-size: .85rem; padding: .4rem .75rem; color: var(--text-secondary); }
.speed-option.active { color: var(--accent-gold); font-weight: 700; }
.speed-option:hover  { color: var(--text-primary); }

/* Playlist */
.player-playlist {
  border-top:  1px solid var(--border-color);
  max-height:  200px;
  overflow-y:  auto;
}
.playlist-header {
  display:          flex;
  justify-content:  space-between;
  align-items:      center;
  padding:          .5rem 1rem;
  font-size:        .875rem;
  font-weight:      600;
  border-bottom:    1px solid var(--border-color);
}
.playlist-items {}
.playlist-item {
  display:         flex;
  align-items:     center;
  gap:             .75rem;
  padding:         .5rem 1rem;
  cursor:          pointer;
  transition:      background var(--transition);
  border-bottom:   1px solid rgba(255,255,255,.04);
  font-size:       .8rem;
}
.playlist-item:hover      { background: var(--bg-card-hover); }
.playlist-item.playing    { background: rgba(245,197,24,.1); }
.playlist-item img        { width: 36px; height: 36px; border-radius: 4px; object-fit: cover; }
.playlist-item-title      { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.playlist-item-duration   { color: var(--text-muted); }

/* Mini player */
.mini-player {
  display:        flex;
  align-items:    center;
  gap:            .75rem;
  padding:        .5rem 1rem;
}
.mini-cover {
  width:  40px; height: 40px;
  border-radius: var(--radius-sm);
  object-fit: cover;
}
.mini-info { flex: 1; min-width: 0; }
.mini-title { font-size: .85rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; }
.mini-btn {
  background: transparent;
  border:     none;
  color:      var(--text-secondary);
  cursor:     pointer;
  padding:    6px;
  transition: color var(--transition);
}
.mini-btn:hover { color: var(--accent-gold); }

/* ── Flash Messages ── */
.flash-message {
  position:   fixed;
  top:        76px; right: 1.5rem;
  z-index:    3000;
  padding:    .85rem 1.25rem;
  border-radius: var(--radius-md);
  display:    flex;
  align-items: center;
  gap:        .75rem;
  font-size:  .9rem;
  font-weight: 500;
  box-shadow: var(--shadow-md);
  animation:  slideInRight .3s ease;
  max-width:  380px;
}
.flash-success { background: #1a3a1a; border: 1px solid #2ecc71; color: #2ecc71; }
.flash-error   { background: #3a1a1a; border: 1px solid var(--accent-red); color: var(--accent-red); }
.flash-close {
  background: transparent;
  border:     none;
  color:      inherit;
  cursor:     pointer;
  margin-left: auto;
  padding:    0 2px;
}
@keyframes slideInRight { from { opacity:0; transform: translateX(100%); } to { opacity:1; transform: translateX(0); } }

/* ── Page header ── */
.page-header {
  background:  linear-gradient(to bottom, var(--bg-secondary), var(--bg-primary));
  padding:     3rem 0 2rem;
  border-bottom: 1px solid var(--border-color);
}
.page-title {
  font-family: 'Playfair Display', serif;
  font-size:   2rem;
  font-weight: 700;
  margin:      0 0 .25rem;
}
.page-subtitle { margin: 0; font-size: .95rem; }

/* ── Episode detail ── */
.breadcrumb-nav { padding: .75rem 0; background: var(--bg-secondary); }
.breadcrumb { margin: 0; font-size: .85rem; }
.breadcrumb-item a { color: var(--text-muted); }
.breadcrumb-item a:hover { color: var(--accent-gold); }
.breadcrumb-item.active { color: var(--text-secondary); }
.breadcrumb-item+.breadcrumb-item::before { color: var(--text-muted); }

.episode-detail-wrapper { padding: 2rem 0 4rem; }
.episode-hero { display: flex; gap: 2rem; margin-bottom: 2rem; flex-wrap: wrap; }
.episode-hero-cover { position: relative; flex-shrink: 0; width: clamp(200px, 30vw, 280px); border-radius: var(--radius-lg); overflow: hidden; }
.episode-hero-cover img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1/1; display: block; }
.episode-hero-play {
  position:   absolute; inset: 0;
  display:    flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.45);
  opacity:    0;
  transition: opacity var(--transition);
  border:     none; color: #fff; font-size: 3rem; cursor: pointer;
}
.episode-hero-cover:hover .episode-hero-play { opacity: 1; }
.episode-hero-info { flex: 1; min-width: 260px; }
.episode-badges { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: .75rem; }
.badge { font-size: .75rem; padding: 3px 10px; border-radius: 50px; }
.badge-category-pill { background: rgba(229,9,20,.15); color: var(--accent-red); border: 1px solid rgba(229,9,20,.3); }
.badge-episode-num { background: rgba(245,197,24,.15); color: var(--accent-gold); border: 1px solid rgba(245,197,24,.3); font-weight: 700; }
.badge-season { background: var(--bg-card); color: var(--text-muted); border: 1px solid var(--border-color); }
.episode-detail-title {
  font-family: 'Playfair Display', serif;
  font-size:   clamp(1.4rem, 3vw, 2rem);
  font-weight: 700;
  margin-bottom: .75rem;
}
.episode-detail-meta { display: flex; flex-wrap: wrap; gap: 1rem; color: var(--text-muted); font-size: .875rem; margin-bottom: 1rem; }
.episode-guests-row { display: flex; align-items: center; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; }
.guest-chip {
  display:       flex;
  align-items:   center;
  gap:           .4rem;
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: 50px;
  padding:       4px 10px 4px 4px;
  font-size:     .8rem;
  color:         var(--text-secondary);
  transition:    all var(--transition);
}
.guest-chip img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
.guest-chip:hover { border-color: var(--accent-gold); color: var(--accent-gold); }
.episode-actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.25rem; }
.btn-action {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  color:         var(--text-secondary);
  font-size:     .875rem;
  padding:       .5rem 1rem;
  border-radius: var(--radius-sm);
  cursor:        pointer;
  transition:    all var(--transition);
}
.btn-action:hover, .btn-action.liked, .btn-action.favorited {
  border-color: var(--accent-gold);
  color:        var(--accent-gold);
}
.btn-action.liked .fa-heart { color: var(--accent-red); }

/* Episode description */
.episode-desc-content {
  color:       var(--text-secondary);
  line-height: 1.8;
  white-space: pre-wrap;
  font-size:   .95rem;
}
.episode-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1rem; }
.tag-pill {
  background:    var(--bg-card-hover);
  border:        1px solid var(--border-color);
  color:         var(--text-muted);
  font-size:     .75rem;
  padding:       3px 10px;
  border-radius: 50px;
  transition:    all var(--transition);
}
.tag-pill:hover { border-color: var(--accent-gold); color: var(--accent-gold); }

/* Share */
.share-section {}
.share-buttons { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.share-btn {
  display:       flex;
  align-items:   center;
  gap:           .4rem;
  padding:       .45rem .9rem;
  border-radius: var(--radius-sm);
  font-size:     .825rem;
  font-weight:   500;
  cursor:        pointer;
  border:        1px solid;
  transition:    all var(--transition);
  text-decoration: none;
}
.share-whatsapp  { border-color: #25d366; color: #25d366; background: rgba(37,211,102,.05); }
.share-whatsapp:hover  { background: #25d366; color: #fff; }
.share-facebook  { border-color: #1877f2; color: #1877f2; background: rgba(24,119,242,.05); }
.share-facebook:hover  { background: #1877f2; color: #fff; }
.share-x         { border-color: #fff; color: #fff; background: rgba(255,255,255,.04); }
.share-x:hover   { background: #000; }
.share-telegram  { border-color: #2ca5e0; color: #2ca5e0; background: rgba(44,165,224,.05); }
.share-telegram:hover  { background: #2ca5e0; color: #fff; }
.share-copy      { border-color: var(--border-light); color: var(--text-secondary); background: var(--bg-card); }
.share-copy:hover{ border-color: var(--accent-gold); color: var(--accent-gold); }

/* Comments */
.comment-form { margin-bottom: 1.5rem; }
.comment-input-wrapper { display: flex; gap: .75rem; }
.comment-avatar { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; flex-shrink: 0; margin-top: .25rem; }
.comment-textarea {
  width:         100%;
  background:    var(--bg-card-hover);
  border:        1px solid var(--border-color);
  color:         var(--text-primary);
  border-radius: var(--radius-sm);
  padding:       .75rem;
  resize:        vertical;
  font-size:     .875rem;
  transition:    border-color var(--transition);
}
.comment-textarea:focus { outline: none; border-color: var(--accent-gold); }
.comment-form-footer { display: flex; justify-content: space-between; align-items: center; margin-top: .5rem; }
.comment-login-prompt {
  padding: 1rem;
  background: var(--bg-card-hover);
  border-radius: var(--radius-sm);
  font-size: .875rem;
  color: var(--text-muted);
  margin-bottom: 1rem;
}
.comment-item { display: flex; gap: .75rem; padding: 1rem 0; border-bottom: 1px solid var(--border-color); }
.comment-item:last-child { border-bottom: none; }
.comment-body { flex: 1; }
.comment-header { display: flex; align-items: center; gap: .75rem; margin-bottom: .35rem; }
.comment-user { font-size: .875rem; }
.comment-date { font-size: .75rem; }
.comment-text { color: var(--text-secondary); font-size: .9rem; margin: 0; }

/* Sidebar */
.sidebar-card { margin-bottom: 1.5rem; }
.sidebar-title { font-size: 1rem; font-weight: 700; margin-bottom: 1rem; color: var(--text-primary); }
.guest-sidebar-item { display: flex; align-items: center; gap: .75rem; padding: .75rem 0; border-bottom: 1px solid var(--border-color); text-decoration: none; transition: color var(--transition); }
.guest-sidebar-item:last-child { border-bottom: none; }
.guest-sidebar-photo { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.guest-sidebar-item strong { color: var(--text-primary); font-size: .875rem; }
.guest-sidebar-item:hover strong { color: var(--accent-gold); }

.related-item { display: flex; align-items: center; gap: .75rem; padding: .75rem 0; border-bottom: 1px solid var(--border-color); }
.related-item:last-child { border-bottom: none; }
.related-cover { width: 54px; height: 54px; border-radius: var(--radius-sm); object-fit: cover; flex-shrink: 0; }
.related-info { flex: 1; min-width: 0; }
.related-title { display: block; color: var(--text-primary); font-size: .825rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: color var(--transition); }
.related-title:hover { color: var(--accent-gold); }
.related-meta { font-size: .75rem; }
.related-play {
  background:    rgba(245,197,24,.1);
  border:        1px solid var(--border-color);
  color:         var(--text-muted);
  width:         32px; height: 32px;
  border-radius: 50%;
  cursor:        pointer;
  flex-shrink:   0;
  font-size:     .7rem;
  transition:    all var(--transition);
}
.related-play:hover { background: var(--accent-gold); border-color: var(--accent-gold); color: #000; }

/* ── Auth pages ── */
.auth-page {
  min-height: calc(100vh - var(--header-height) - var(--player-height));
  display:    flex;
  align-items: center;
  justify-content: center;
  padding:    2rem 1rem;
}
.auth-card {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding:       2.5rem;
  width:         100%;
  max-width:     420px;
  box-shadow:    var(--shadow-lg);
}
.auth-card-wide { max-width: 600px; }
.auth-logo { text-align: center; margin-bottom: 1.5rem; }
.auth-title { font-family: 'Playfair Display', serif; font-size: 1.5rem; font-weight: 700; text-align: center; margin-bottom: .25rem; }
.auth-subtitle { text-align: center; font-size: .875rem; margin-bottom: 1.5rem; }
.auth-footer-text { text-align: center; margin-top: 1.5rem; font-size: .875rem; color: var(--text-muted); }
.auth-form .form-label { font-size: .875rem; color: var(--text-secondary); margin-bottom: .4rem; }

.input-icon-group { position: relative; }
.input-icon { position: absolute; left: .9rem; top: 50%; transform: translateY(-50%); color: var(--text-muted); font-size: .875rem; pointer-events: none; }
.form-control-icon { padding-left: 2.4rem !important; }
.toggle-password {
  position:   absolute;
  right:      .75rem; top: 50%; transform: translateY(-50%);
  background: none; border: none;
  color:      var(--text-muted); cursor: pointer;
  transition: color var(--transition);
}
.toggle-password:hover { color: var(--text-primary); }

.form-control-dark, .form-select-dark {
  background:    var(--bg-card-hover);
  border:        1px solid var(--border-color);
  color:         var(--text-primary);
  border-radius: var(--radius-sm);
}
.form-control-dark:focus, .form-select-dark:focus {
  background:  var(--bg-card-hover);
  border-color: var(--accent-gold);
  box-shadow:  0 0 0 3px rgba(245,197,24,.15);
  color:       var(--text-primary);
}
.form-control-dark::placeholder { color: var(--text-muted); }
.form-select-dark option { background: var(--bg-card); }

.password-strength { height: 4px; background: var(--border-color); border-radius: 2px; overflow: hidden; }
.password-strength::after { content: ''; display: block; height: 100%; width: 0%; border-radius: 2px; transition: width .3s, background .3s; }

/* ── Profile ── */
.profile-card { text-align: center; padding: 2rem; }
.profile-avatar-wrapper { position: relative; display: inline-block; margin-bottom: 1rem; }
.profile-avatar { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; border: 3px solid var(--accent-gold); }
.profile-avatar-edit {
  position: absolute; bottom: 0; right: 0;
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--accent-gold); color: #000;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; cursor: pointer;
}
.profile-name { font-size: 1.25rem; font-weight: 700; margin-bottom: .25rem; }
.profile-email { font-size: .875rem; margin-bottom: .5rem; }
.profile-badge {
  display: inline-block; padding: 3px 12px; border-radius: 50px;
  font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px;
}
.badge-admin { background: rgba(245,197,24,.2); color: var(--accent-gold); border: 1px solid rgba(245,197,24,.3); }
.badge-user  { background: var(--bg-card-hover); color: var(--text-muted); border: 1px solid var(--border-color); }

/* ── History ── */
.history-list { display: flex; flex-direction: column; gap: .75rem; }
.history-item {
  display:       flex;
  align-items:   center;
  gap:           1rem;
  padding:       .75rem;
  background:    var(--bg-card);
  border-radius: var(--radius-sm);
  border:        1px solid var(--border-color);
}
.history-cover { width: 60px; height: 60px; border-radius: var(--radius-sm); object-fit: cover; flex-shrink: 0; }
.history-info { flex: 1; min-width: 0; }
.history-title { display: block; font-weight: 600; font-size: .9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-primary); transition: color var(--transition); }
.history-title:hover { color: var(--accent-gold); }
.listen-progress-bar { height: 3px; background: var(--border-color); border-radius: 2px; margin-top: .4rem; overflow: hidden; }
.listen-progress-fill { height: 100%; background: var(--accent-gold); border-radius: 2px; }
.history-play {
  background:    rgba(245,197,24,.1);
  border:        1px solid var(--border-color);
  color:         var(--text-muted);
  width:         36px; height: 36px;
  border-radius: 50%; cursor: pointer;
  font-size:     .75rem; flex-shrink: 0;
  transition:    all var(--transition);
}
.history-play:hover { background: var(--accent-gold); border-color: var(--accent-gold); color: #000; }

/* ── Guests grid (page) ── */
.guests-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap:                   1.5rem;
}
.guest-card {
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow:      hidden;
  text-decoration: none;
  transition:    all var(--transition);
}
.guest-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--accent-gold); }
.guest-card-photo-wrapper { aspect-ratio: 1/1; overflow: hidden; }
.guest-card-photo { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.guest-card:hover .guest-card-photo { transform: scale(1.05); }
.guest-card-body { padding: 1rem; }
.guest-card-name { font-weight: 700; font-size: 1rem; color: var(--text-primary); margin-bottom: .35rem; }
.guest-card-bio { font-size: .8rem; color: var(--text-muted); margin-bottom: .5rem; }
.guest-card-episodes { font-size: .75rem; color: var(--accent-gold); font-weight: 600; }

/* Guest detail */
.guest-detail-header { background: var(--bg-secondary); padding: 3rem 0; border-bottom: 1px solid var(--border-color); }
.guest-detail-profile { display: flex; gap: 2rem; align-items: flex-start; flex-wrap: wrap; }
.guest-detail-photo { width: 140px; height: 140px; border-radius: 50%; object-fit: cover; border: 4px solid var(--accent-gold); flex-shrink: 0; }
.guest-detail-name { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; margin-bottom: .5rem; }
.guest-detail-bio { color: var(--text-secondary); max-width: 600px; }
.guest-socials { display: flex; gap: .75rem; margin-top: 1rem; }

/* ── About ── */
.about-hero { background: var(--bg-secondary); padding: 4rem 0 3rem; border-bottom: 1px solid var(--border-color); }
.about-hero-content { max-width: 600px; }
.about-title { font-family: 'Playfair Display', serif; font-size: 3rem; font-weight: 900; }
.about-title-line { height: 4px; width: 60px; background: var(--accent-gold); margin: 1rem 0; }
.about-lead { font-size: 1.25rem; color: var(--text-secondary); font-style: italic; }
.about-section { padding: 4rem 0; }
.about-subtitle { font-family: 'Playfair Display', serif; font-size: 1.75rem; font-weight: 700; }
.about-text-block p { color: var(--text-secondary); font-size: .95rem; line-height: 1.8; margin-bottom: 1rem; }
.about-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.about-stat { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 1.5rem; text-align: center; }
.about-stat i { font-size: 1.75rem; margin-bottom: .5rem; display: block; }
.about-stat-num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; display: block; }
.about-stat-label { font-size: .8rem; color: var(--text-muted); }
.about-values {}
.value-card { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 1.5rem; height: 100%; }
.value-icon { font-size: 2rem; color: var(--accent-gold); margin-bottom: 1rem; }
.value-card h4 { font-weight: 700; margin-bottom: .5rem; }

/* ── Contact ── */
.contact-section { padding: 3rem 0 5rem; }
.contact-form { }
.form-section-title { font-family: 'Playfair Display', serif; font-size: 1.25rem; font-weight: 700; margin-bottom: 1.5rem; }
.contact-info { }
.contact-item { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.25rem; padding-bottom: 1.25rem; border-bottom: 1px solid var(--border-color); }
.contact-item:last-child { border-bottom: none; }
.contact-item-icon { width: 40px; height: 40px; border-radius: 50%; background: rgba(245,197,24,.1); display: flex; align-items: center; justify-content: center; color: var(--accent-gold); flex-shrink: 0; }
.proposal-cta { text-align: center; padding: 1.5rem; background: rgba(245,197,24,.05); border: 1px solid rgba(245,197,24,.2); border-radius: var(--radius-md); }

/* ── Filters ── */
.episodes-filters { margin-bottom: 1.5rem; }
.filter-select {
  background:  var(--bg-card);
  border:      1px solid var(--border-color);
  color:       var(--text-primary);
  padding:     .45rem .9rem;
  border-radius: var(--radius-sm);
  font-size:   .875rem;
  cursor:      pointer;
  transition:  border-color var(--transition);
}
.filter-select:focus { outline: none; border-color: var(--accent-gold); }
.filter-select option { background: var(--bg-card); }

/* ── Pagination ── */
.pagination-dark .page-link {
  background:   var(--bg-card);
  border-color: var(--border-color);
  color:        var(--text-secondary);
}
.pagination-dark .page-link:hover { background: var(--bg-card-hover); color: var(--accent-gold); border-color: var(--accent-gold); }
.pagination-dark .page-item.active .page-link { background: var(--accent-gold); border-color: var(--accent-gold); color: #000; }

/* ── Empty state ── */
.empty-state {
  text-align:  center;
  padding:     4rem 2rem;
  color:       var(--text-muted);
}
.empty-state i { font-size: 3.5rem; margin-bottom: 1rem; display: block; color: var(--border-light); }
.empty-state h3 { font-size: 1.25rem; margin-bottom: .5rem; }

/* ── Error / 404 ── */
.error-page { min-height: calc(100vh - 200px); display: flex; align-items: center; justify-content: center; text-align: center; padding: 2rem; }
.error-icon { font-size: 5rem; margin-bottom: 1rem; }
.error-code { font-family: 'Playfair Display', serif; font-size: 6rem; font-weight: 900; line-height: 1; margin-bottom: .5rem; }
.error-message { font-size: 1.5rem; margin-bottom: .5rem; }

/* ── Search page ── */
.search-page-form { margin-bottom: 1.5rem; }
.search-page-bar {
  display:       flex;
  gap:           .5rem;
  margin-bottom: .75rem;
}
.search-page-input {
  flex:          1;
  background:    var(--bg-card);
  border:        1px solid var(--border-color);
  color:         var(--text-primary);
  padding:       .65rem 1rem;
  border-radius: var(--radius-sm);
  font-size:     1rem;
}
.search-page-input:focus { outline: none; border-color: var(--accent-gold); }
.search-page-filters { display: flex; gap: .75rem; flex-wrap: wrap; }

/* ── Overlay ── */
.overlay {
  display:     none;
  position:    fixed;
  inset:       0;
  background:  rgba(0,0,0,.6);
  z-index:     500;
}
.overlay.active { display: block; }

/* ══════════════════════════
   RESPONSIVE
══════════════════════════ */
@media (max-width: 991px) {
  .navbar-collapse {
    background: var(--bg-secondary);
    border:     1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding:    1rem;
    margin-top: .5rem;
  }
  .navbar-nav .nav-link { height: auto; padding: .5rem 0; }
  .search-wrapper { width: 100%; margin: .5rem 0; }
  .search-input { width: 100%; }
  .user-menu { width: 100%; margin-top: .5rem; }
  .auth-buttons { display: flex; gap: .5rem; }
  .carousel-episode { flex-direction: column; min-height: auto; }
  .carousel-ep-cover { width: 100%; }
  .player-episode-info { max-width: 160px; }
  .player-secondary { gap: .2rem; }
  .volume-slider { width: 60px; }
}

@media (max-width: 575px) {
  .hero-logo { letter-spacing: 1px; }
  .episode-detail-wrapper { padding-top: 1rem; }
  .episode-hero { flex-direction: column; gap: 1rem; }
  .episode-hero-cover { width: 100%; max-width: 280px; margin: 0 auto; }
  .player-episode-info { max-width: 120px; }
  .volume-control { display: none; }
  .player-btn-sm:not(#playlistBtn):not(#minimizeBtn) { display: none; }
  .about-stats-grid { grid-template-columns: 1fr 1fr; }
}
