html {
  scroll-behavior: smooth;
}

/* =========================================
   Sección TVC En Vivo (Banner)
   ========================================= */
.seccion-en-vivo {
  background-color: #000000; /* Fondo negro sólido según el diseño */
  padding: 80px 5%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  width: 100%;
  height: calc(100dvh - 108px);
}

.seccion-en-vivo .en-vivo-container {
  max-width: 1200px;
  margin: 0 auto;
}

.seccion-en-vivo .en-vivo-container h2 {
  color: #ffffff;
  /* Texto dinámico: 2.5rem en móviles, escalando hasta 5.5rem en escritorio */
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  font-weight: 400; /* Peso de fuente regular/ligero como en la imagen */
  line-height: 1.2;
  letter-spacing: 1px;
  margin: 0;
}

.seccion-en-vivo .en-vivo-container h2 .highlight-green {
  color: var(--primario); /* Tu variable verde para mantener la consistencia */
}

.seccion-en-vivo .en-vivo-container .btn-llamativo {
  display: inline-block;
  margin-top: 20px;
  padding: 16px 48px;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--primario);
  text-decoration: none;
  letter-spacing: 1px;

  /* Efecto Glassmorphism del diseño original */
  background-color: var(--primario-desvanecido);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  border: 2px solid var(--primario);
  border-radius: 50px;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Transición con un pequeño rebote */
}

/* El Hover interactivo */
.seccion-en-vivo .en-vivo-container .btn-llamativo:hover {
  background-color: var(--primario);
  color: #ffffff; /* Texto oscuro para contrastar con el fondo amarillo */
  transform: translateY(-6px) scale(1.05); /* Se levanta y se agranda un poco */
  box-shadow: 0 15px 25px rgba(64, 248, 51, 0.4); /* Resplandor dorado debajo */
  border-color: var(--primario);
}

/* Efecto al hacer clic */
.seccion-en-vivo .en-vivo-container .btn-llamativo:active {
  transform: translateY(2px) scale(0.98);
  box-shadow: 0 5px 10px rgba(248, 177, 51, 0.3);
}

/* Responsive para móviles si deseas ajustar el espaciado interior */
@media (max-width: 576px) {
  .seccion-en-vivo {
    padding: 60px 5%;
  }
}

/* =========================================
   Sección de Streaming en Vivo
   ========================================= */
.live-streaming-section {
  min-height: 110vh;
  background-image: url("../assets/sala.png");
  background-size: cover;
  background-position: 50% 14%;
  background-repeat: no-repeat;
  overflow: hidden;
  position: relative;
  display: flex;
  color: white;

  /* CORRECCIÓN 2: Alineación al tope (flex-start) y centro horizontal */
  justify-content: center;
  align-items: flex-start;
  padding-top: 50px; /* Espacio opcional para que no pegue al borde exacto */
}

.live-streaming-section .logo-fixed {
	display:none;
  position: absolute;
  top: 9%; /* Ajustado para que no dependa del scroll */
  left: 1%;
  font-size: 20px;
  font-weight: bold;
  z-index: 50;
  background-color: var(--primario);
  padding: 12px 22px;
  border-radius: 0px 20px 20px 0px;
}

.live-streaming-section .logo-fixed .logo-tvc {
  color: white;
}

.live-streaming-section .logo-fixed .logo-envivo {
  color: #7bc676;
}

.live-streaming-section .streaming-container {
  width: 70%;
  max-width: 1200px;
  display: flex;
  justify-content: center;
  /* Eliminamos el color de fondo de prueba para limpieza */
}

.live-streaming-section .streaming-container .tv-video-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  /* CORRECCIÓN 3: El contenedor relativo asegura que ambos hijos se muevan juntos */
}

.live-streaming-section .streaming-container .tv-video-wrapper .video-iframe {
  position: absolute;
  /* Ajusta estos valores según los bordes internos de tu imagen de TV */
  top: 1%;
  left: 0%;
  width: 99.5%;
  height: 96%;
  border: none;
  z-index: 1; /* El video va atrás */
}

.live-streaming-section .streaming-container .tv-video-wrapper .tv-frame-img {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
  z-index: 2; /* La imagen va adelante */

  /* CORRECCIÓN 1: Permite que los clics pasen a través de la imagen al video */
  pointer-events: none;
}

/* Responsive */
@media (max-width: 768px) {
  .live-streaming-section .streaming-container {
    width: 95%;
  }
  .live-streaming-section .logo-fixed {
    font-size: 16px;
  }
}

/* =========================================
   Sección Grilla de Programación
   ========================================= */

.seccion-programacion {
  padding: 80px 5%;
  background-color: #f8f9fa; /* Fondo gris súper claro para la página */
}

.seccion-programacion .programacion-container {
  max-width: 1300px;
  margin: 0 auto;
  background-color: #ffffff; /* Fondo blanco para el contenedor */

  /* El borde redondeado que pediste para el contenedor de la sección */
  border-radius: 40px;
  padding: 50px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); /* Sombra suave para que resalte */
}

/* Encabezado y Filtros */
.seccion-programacion .programacion-header {
  text-align: center;
  margin-bottom: 40px;
}

.seccion-programacion .programacion-header h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 20px;
}

.seccion-programacion .programacion-header .filtros-dias {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap; /* Para que bajen de línea si no caben en móviles */
}

.seccion-programacion .programacion-header .filtros-dias .btn-dia {
  background-color: transparent;
  border: 2px solid var(--gris-claro, #e5e7eb);
  padding: 8px 20px;
  border-radius: 20px;
  font-size: 1rem;
  font-weight: 500;
  color: #4a4a4a;
  cursor: pointer;
  transition: all 0.3s ease;
}

.seccion-programacion .programacion-header .filtros-dias .btn-dia:hover {
  border-color: var(--primario);
  color: var(--primario);
}

.seccion-programacion .programacion-header .filtros-dias .btn-dia.active {
  background-color: var(--primario);
  color: #ffffff; /* Ajusta el color del texto si el primario es muy claro */
  border-color: var(--primario);
}

/* Grilla de Tarjetas */
.seccion-programacion .grilla-programas {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 tarjetas por fila */
  gap: 30px;
}

/* Estilos de cada Tarjeta */
.seccion-programacion .grilla-programas .card-programa {
  background-color: #ffffff;
  border: 2px solid var(--gris, #1a1a1a); /* Borde negro como en la imagen */
  border-radius: 25px; /* Bordes redondeados de la tarjeta */
  overflow: hidden; /* Muy importante para que la imagen no se salga de las curvas superiores */
  display: flex;
  flex-direction: column;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
}

.seccion-programacion .grilla-programas .card-programa:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 25px rgba(0, 0, 0, 0.1);
}

/* Contenedor de la Imagen */
.seccion-programacion
  .grilla-programas
  .card-programa
  .programa-imagen-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9; /* Proporción estándar de video/TV */
}

.seccion-programacion
  .grilla-programas
  .card-programa
  .programa-imagen-wrapper
  .programa-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Etiqueta "NUEVO" superpuesta */
.seccion-programacion
  .grilla-programas
  .card-programa
  .programa-imagen-wrapper
  .badge-nuevo {
  position: absolute;
  top: 15px;
  left: 15px;
  background-color: var(--primario, #86efac); /* Verde claro */
  color: #000000;
  font-weight: 800;
  font-size: 0.85rem;
  padding: 6px 12px;
  border-radius: 8px;
  z-index: 2;
}

/* Textos de la tarjeta */
.seccion-programacion .grilla-programas .card-programa .programa-info {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* Hace que el área de texto tome todo el espacio restante */
}

.seccion-programacion .grilla-programas .card-programa .programa-info h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #000;
  margin-bottom: 8px;
  line-height: 1.3;
}

.seccion-programacion
  .grilla-programas
  .card-programa
  .programa-info
  .programa-horario {
  font-size: 1rem;
  color: #333;
  font-weight: 500;
  margin-bottom: 12px;
}

.seccion-programacion
  .grilla-programas
  .card-programa
  .programa-info
  .programa-desc {
  font-size: 0.9rem;
  color: #666;
  line-height: 1.5;
  margin: 0;
}

/* Responsive Design */
@media (max-width: 992px) {
  .seccion-programacion .programacion-container {
    padding: 30px 20px;
  }
  .seccion-programacion .grilla-programas {
    grid-template-columns: repeat(2, 1fr); /* 2 columnas en tablets */
    gap: 20px;
  }
}

@media (max-width: 600px) {
  .seccion-programacion .grilla-programas {
    grid-template-columns: 1fr; /* 1 columna en celulares */
  }
  .seccion-programacion .programacion-header .filtros-dias {
    gap: 5px;
  }
  .seccion-programacion .programacion-header .filtros-dias .btn-dia {
    padding: 6px 15px;
    font-size: 0.9rem;
  }
}

/* =========================================
   Estilos para la Tabla de Programación
   ========================================= */
.tabla-responsive {
  width: 100%;
  overflow-x: auto; /* Permite scroll horizontal en móviles */
  margin-top: 30px;
  border-radius: 15px; /* Bordes redondeados para la tabla */
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05); /* Sombra suave */
}

.tabla-horarios {
  width: 100%;
  border-collapse: collapse;
  min-width: 800px; /* Asegura que no se aplaste demasiado en móviles */
  background-color: #ffffff;
  text-align: left;
}

.tabla-horarios thead tr {
  background-color: #1a1a1a; /* Fondo oscuro, puedes cambiarlo a var(--primario) */
  color: #ffffff;
}

.tabla-horarios th,
.tabla-horarios td {
  padding: 15px 20px;
  border-bottom: 1px solid #eeeeee;
}

.tabla-horarios th {
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
}

.tabla-horarios tbody tr {
  transition: background-color 0.3s ease;
}

/* Efecto cebra para mejor lectura */
.tabla-horarios tbody tr:nth-of-type(even) {
  background-color: #fafafa;
}

.tabla-horarios tbody tr:hover {
  background-color: #f0f7f0; /* Un verde súper clarito al pasar el mouse */
}

.tabla-horarios td {
  font-size: 0.95rem;
  color: #4a4a4a;
}

.tabla-horarios td strong {
  color: #1a1a1a;
  font-weight: 600;
}

/* =========================================
   Sección Tarjetas Programas Destacados
   ========================================= */
.seccion-programas-destacados {
  padding: 60px 5%;
  background-color: #ffffff;
}

.seccion-programas-destacados .destacados-container {
  max-width: 1300px;
  margin: 0 auto;
}

.titulo-destacados {
  text-align: center;
  font-size: clamp(2rem, 4vw, 2.5rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 40px;
}

/* Grilla de Tarjetas (Reubicada y adaptada) */
.seccion-programas-destacados .grilla-programas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.seccion-programas-destacados .card-programa {
  background-color: #ffffff;
  border: 2px solid var(--gris, #1a1a1a);
  border-radius: 25px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
}

.seccion-programas-destacados .card-programa:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 25px rgba(0, 0, 0, 0.1);
}

.seccion-programas-destacados .programa-imagen-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.seccion-programas-destacados .programa-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.seccion-programas-destacados .badge-nuevo {
  position: absolute;
  top: 15px;
  left: 15px;
  background-color: var(--primario, #86efac);
  color: #000000;
  font-weight: 800;
  font-size: 0.85rem;
  padding: 6px 12px;
  border-radius: 8px;
  z-index: 2;
}

.seccion-programas-destacados .programa-info {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.seccion-programas-destacados .programa-info h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: #000;
  margin-bottom: 8px;
  line-height: 1.3;
}

.seccion-programas-destacados .programa-horario {
  font-size: 1rem;
  color: #333;
  font-weight: 500;
  margin-bottom: 12px;
}

.seccion-programas-destacados .programa-desc {
  font-size: 0.9rem;
  color: #666;
  line-height: 1.5;
  margin: 0;
}

/* Responsive Tarjetas */
@media (max-width: 992px) {
  .seccion-programas-destacados .grilla-programas {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}

@media (max-width: 600px) {
  .seccion-programas-destacados .grilla-programas {
    grid-template-columns: 1fr;
  }
}

/* Clase que aplicará JS para ocultar las filas no deseadas */
.fila-programa.oculto {
  display: none;
}

/* Animación suave al cambiar de día */
.fila-programa {
  animation: fadeInRow 0.4s ease-in-out;
}

@keyframes fadeInRow {
  from {
    opacity: 0;
    transform: translateY(5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
