/**
Agregue abajo sus estilos personalizados de css
*/

/* Estilos adicionales para el historial de canciones */
#history-songs {
  margin-top: 64px; /* Mismo margen que otras secciones */
}

#history-songs h2 {
  margin-bottom: 24px; /* Margen consistente con otras secciones */
}

#history-songs ul {
  display: flex;
  justify-content: center;
  gap: 16px;
  max-width: 100%;
  overflow-x: hidden;
  padding: 0 16px;
}

/* Limitar a solo 4 elementos visibles */
#history-songs ul li:nth-child(n+5) {
  display: none !important;
}

/* Asegurar que los elementos del historial estén centrados y con tamaño uniforme */
.hst-item {
  min-width: 280px;
  max-width: 300px;
  flex-shrink: 0;
}

/* Estilos para la carátula del historial */
.hst-item-cover {
  width: 80px !important;
  height: 80px !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  border-radius: 0.375rem !important;
  background: #1a1a1a !important;
}

.hst-item-cover img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0.375rem !important;
}

/* Mejorar el diseño de las tarjetas del historial - Layout horizontal estilo Spotify */
.hst-item {
  background: #1a1a1a !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 0.75rem !important;
  padding: 0.75rem !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
  transition: all 0.3s ease !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.75rem !important;
  min-height: auto !important;
}

.hst-item:hover {
  transform: translateY(-2px) !important;
  background: #282828 !important;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.4) !important;
}

/* Estilos para el cuerpo de la tarjeta */
.hst-item-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.25rem !important;
  flex: 1 !important;
  min-width: 0 !important;
}

/* Estilos para títulos largos con puntos suspensivos */
.hst-item-title,
.hst-item h4,
.hst-item .song-title {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  max-width: 100% !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  margin: 0 !important;
}

.hst-item-desc,
.hst-item p,
.hst-item .song-artist {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  max-width: 100% !important;
  font-size: 0.8rem !important;
  color: #b3b3b3 !important;
  margin: 0 !important;
}

/* Estilos para el enlace externo de Spotify */
.hst-item-external-link {
  margin: 0 !important;
  padding: 0.25rem !important;
  background: transparent !important;
  border-radius: 0.5rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
  flex-shrink: 0 !important;
}

.hst-item-external-link:hover {
  transform: scale(1.15) !important;
  opacity: 0.8 !important;
}

.hst-item-external-link img {
  width: 30px !important;
  height: 30px !important;
  max-width: 30px !important;
  max-height: 30px !important;
  display: block !important;
  object-fit: contain !important;
}

/* Estilos para enlaces del footer */
footer nav a {
  transition: all 0.3s ease;
  position: relative;
}

/* Enlaces activos (con URL configurada) */
footer nav a.is-on {
  opacity: 1 !important;
  color: #ffffff;
  cursor: pointer;
}

/* Enlaces inactivos (sin URL configurada) */
footer nav a:not(.is-on) {
  opacity: 0.4 !important;
  color: #9ca3af;
  cursor: default;
  pointer-events: none;
}

/* Efecto hover solo para enlaces activos */
footer nav a.is-on:hover {
  opacity: 1 !important;
  transform: translateY(-2px);
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

/* Responsive para móviles */
@media (max-width: 768px) {
  #history-songs ul {
    justify-content: flex-start;
    padding: 0 16px;
    gap: 12px;
  }
  




  .hst-item {
    min-width: 240px;
    max-width: 260px;
  }
}

/* Centrar cuando hay menos de 4 elementos */
@media (min-width: 769px) {
  #history-songs ul {
    justify-content: center;
  }
}

/* Skeleton loader para el historial */
.hst-item-skel {
  width: 280px !important;
  height: 360px !important;
  border-radius: 1rem !important;
  background: linear-gradient(90deg, #f3f4f6 25%, #e5e7eb 50%, #f3f4f6 75%) !important;
  background-size: 200% 100% !important;
  animation: skeleton-loading 1.5s ease-in-out infinite !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

@keyframes skeleton-loading {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}



/* Estilos para el historial horizontal */
#history-songs-horizontal {
  margin-top: 2rem;
  margin-bottom: 2rem;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

#history-songs-horizontal .history-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

#history-songs-horizontal .history-item {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 0.5rem;
  padding: 0.525rem;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  transition: all 0.3s ease;
}

#history-songs-horizontal .history-item:hover {
  background: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
}

#history-songs-horizontal .history-item img {
  width: 100%;
  height: 42px;
  object-fit: cover;
  border-radius: 0.375rem;
  margin-bottom: 0.35rem;
}

#history-songs-horizontal .history-item h4 {
  font-size: 0.8125rem;
  font-weight: 600;
  color: white;
  margin: 0 0 0.175rem 0;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#history-songs-horizontal .history-item p {
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.8);
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Responsive para móviles */
@media (max-width: 768px) {
  #history-songs-horizontal .history-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  
  #history-songs-horizontal .history-item {
    display: flex;
    align-items: center;
    gap: 0.525rem;
  }
  
  #history-songs-horizontal .history-item img {
    width: 35px;
    height: 35px;
    margin-bottom: 0;
    flex-shrink: 0;
  }
  
  #history-songs-horizontal .history-item div {
     flex: 1;
     min-width: 0;
   }
 }

/* Estilos para que la programación ocupe todo el espacio disponible */
#programs {
  width: 100%;
}

#programs .programs-container {
  width: 100%;
  max-width: none;
}

/* Ajustar el grid de programas para ocupar más espacio - 40% más pequeños */
#programs .programs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(168px, 1fr)); /* 280px * 0.6 = 168px */
  gap: 0.6rem; /* 1rem * 0.6 = 0.6rem */
  width: 100%;
}

/* Aplicar grid a los tabs de programas */
.proms-tabs__item {
  display: grid;
  /* El diseño se define al final del archivo con !important */
  width: 100%;
}

.proms-tabs__item.is-active {
  display: grid !important;
}

/* Responsive para la programación */
@media (max-width: 768px) {
  .proms-tabs__item {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  }
}

/* Cuadros de programación cuadrados perfectos con imagen de fondo - 4 en línea */
.prog-card {
    aspect-ratio: 2 / 1 !important;
    width: 100% !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    position: relative !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 8px !important; /* Esquinas menos redondeadas */
    box-shadow: 0 10px 20px rgba(0,0,0,0.15) !important;
}

.prog-card::before {
    content: '' !important;
    display: block !important;
    padding-top: 50% !important;
}

/* Ocultar la imagen ya que usaremos background-image */
.prog-card__img {
    display: none !important;
}

.prog-card__body {
    padding: 0.4rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    height: 100% !important;
    text-align: left !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: linear-gradient(to bottom, transparent 0%, transparent 50%, rgba(0,0,0,0.7) 100%) !important;
    color: white !important;
}

.prog-card__title {
    font-size: 0.84rem !important; /* 0.7rem * 1.2 = 0.84rem */
    font-weight: 600 !important;
    margin-bottom: 0.15rem !important;
    line-height: 1.1 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    color: white !important;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8) !important;
}

.prog-card__desc {
    font-size: 0.72rem !important; /* 0.6rem * 1.2 = 0.72rem */
    margin-bottom: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    color: rgba(255,255,255,0.9) !important;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8) !important;
}

.prog-card__desc span {
    font-size: 0.66rem !important; /* 0.55rem * 1.2 = 0.66rem */
    font-weight: 600 !important;
    color: white !important;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8) !important;
    display: block !important;
    margin-bottom: 0.1rem !important;
}



/* Programa EN VIVO destacado */
.prog-card.is-onlive {
    position: relative;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15) !important;
    border: 4px solid #374151 !important; /* Gris Antracita para contraste máximo */
}

.prog-card .is-onlive {
    position: absolute;
    top: 8px;
    left: 8px;
    background: #ffffff !important;
    color: #000000 !important;
    border: none !important;
    padding: 4px 8px;
    border-radius: 4px !important;
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    z-index: 10;
    display: none !important; /* Ocultar por defecto */
}

.prog-card.is-onlive .is-onlive {
    display: block !important; /* Solo mostrar cuando la tarjeta tenga la clase is-onlive */
}

/* Keyframes eliminados para mantener el cuadro fijo */

/* Responsive para el carrusel */
@media (max-width: 1024px) {
    .programs-track .prog-card {
        flex: 0 0 calc(25% - 0.3rem);
    }
    
    .programs-track {
        gap: 0.4rem;
    }
    
    .prog-card__title {
        font-size: 0.65rem !important;
    }
    
    .prog-card__desc {
        font-size: 0.55rem !important;
    }
}

@media (max-width: 768px) {
    .programs-track .prog-card {
        flex: 0 0 calc(50% - 0.15rem); /* 2 programas visibles en tablet */
    }
    
    .programs-track {
        gap: 0.3rem;
    }
    
    .prog-card__body {
        padding: 0.3rem !important;
    }
    
    .prog-card__title {
        font-size: 0.6rem !important;
        margin-bottom: 0.1rem !important;
    }
    
    .prog-card__desc {
        font-size: 0.5rem !important;
        -webkit-line-clamp: 1 !important;
        line-clamp: 1 !important;
        -webkit-box-orient: vertical !important;
    }
    
    .prog-card__desc span {
        font-size: 0.45rem !important;
    }
}

@media (max-width: 480px) {
    .programs-track .prog-card {
        flex: 0 0 calc(100% - 0.1rem); /* 1 programa visible en móvil */
    }
    
    .programs-track {
        gap: 0.2rem;
    }
    
    .prog-card__body {
        padding: 0.25rem !important;
    }
    
    .prog-card__title {
        font-size: 0.55rem !important;
    }
    
    .prog-card__desc {
        font-size: 0.45rem !important;
    }
    
    .prog-card__desc span {
        font-size: 0.4rem !important;
    }
    
    .carousel-controls {
        gap: 0.5rem;
    }
    
    .carousel-btn {
        width: 35px;
        height: 35px;
    }
}

/* Tema Deep Blue para elementos onlive */
.onlive {
    background: linear-gradient(135deg, #0f172a, #1e293b, #334155) !important;
    border: 1px solid rgba(51, 65, 85, 0.4) !important;
    box-shadow: 0 8px 32px rgba(15, 23, 42, 0.5) !important;
    color: white !important;
}

.onlive-title {
    color: white !important;
    font-weight: 600 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    max-width: 100% !important;
    position: relative !important;
}

.onlive-title span {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.onlive-title.marquee span {
    animation: marquee 8s linear infinite !important;
}

.onlive-desc {
    color: rgba(255, 255, 255, 0.8) !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    max-width: 100% !important;
    position: relative !important;
}

.onlive-desc .onlive-about {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.onlive-desc.marquee .onlive-about {
    animation: marquee 10s linear infinite !important;
}

/* Animación de marquesina */
@keyframes marquee {
    0% {
        transform: translateX(0) !important;
    }
    25% {
        transform: translateX(0) !important;
    }
    75% {
        transform: translateX(calc(-100% + 200px)) !important;
    }
    100% {
        transform: translateX(calc(-100% + 200px)) !important;
    }
}

/* Pausar animación al hacer hover */
.onlive:hover .marquee span,
.onlive:hover .marquee .onlive-about {
    animation-play-state: paused !important;
}

.onlive-horario {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 600 !important;
    flex-shrink: 0 !important;
}

.onlive-badge {
    background: #ffffff !important;
    color: #000000 !important;
    border: none !important;
    border-radius: 4px !important;
    flex-shrink: 0 !important;
}

/* Tema para el siguiente programa */
.onlive.is-next {
    background: linear-gradient(135deg, #374151, #4b5563, #6b7280) !important;
    border: 1px solid rgba(107, 114, 128, 0.3) !important;
    box-shadow: 0 8px 32px rgba(55, 65, 81, 0.3) !important;
    color: white !important;
}

.onlive.is-next .onlive-title {
    color: white !important;
}

.onlive.is-next .onlive-desc {
    color: rgba(255, 255, 255, 0.7) !important;
}

.onlive.is-next .onlive-horario {
    color: rgba(255, 255, 255, 0.8) !important;
}

.onlive.is-next .onlive-badge {
    background: linear-gradient(135deg, #6b7280, #9ca3af) !important;
    color: white !important;
    flex-shrink: 0 !important;
}

/* Mejoras adicionales para evitar que las cajas se alarguen */
.onlive-wrapper {
    min-width: 0 !important;
    flex: 1 !important;
    overflow: hidden !important;
}

/* Asegurar que el contenedor principal no se expanda */
.onlive {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Estilos específicos para los elementos de descripción */
.onlive-desc span.onlive-about {
    max-width: calc(100% - 80px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    display: inline-block !important;
    vertical-align: top !important;
}

/* Mejoras adicionales para prog-card con marquesina */
.prog-card__title {
    overflow: hidden !important;
    white-space: nowrap !important;
    position: relative !important;
}

.prog-card__title span {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.prog-card__title.marquee span {
    animation: marquee-small 6s linear infinite !important;
}

.prog-card__desc {
    overflow: hidden !important;
    white-space: nowrap !important;
    position: relative !important;
}

.prog-card__desc span.desc-text {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.prog-card__desc.marquee span.desc-text {
    animation: marquee-small 8s linear infinite !important;
}

/* Animación de marquesina para prog-card */
@keyframes marquee-small {
    0% {
        transform: translateX(0) !important;
    }
    25% {
        transform: translateX(0) !important;
    }
    75% {
        transform: translateX(calc(-100% + 150px)) !important;
    }
    100% {
        transform: translateX(calc(-100% + 150px)) !important;
    }
}

/* Pausar animación al hacer hover en prog-card */
.prog-card:hover .marquee span {
    animation-play-state: paused !important;
}

/* Estilos de marquesina para elementos onlive */
.onlive-title {
    overflow: hidden !important;
    white-space: nowrap !important;
    position: relative !important;
}

.onlive-title span {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.onlive-title.marquee span {
    animation: marquee 10s linear infinite !important;
}

.onlive-desc {
    overflow: hidden !important;
    white-space: nowrap !important;
    position: relative !important;
}

.onlive-desc .onlive-about {
    display: inline-block !important;
    transition: transform 0.3s ease !important;
}

.onlive-desc.marquee .onlive-about {
    animation: marquee 12s linear infinite !important;
}

/* Animación principal de marquesina */
@keyframes marquee {
    0% {
        transform: translateX(0) !important;
    }
    20% {
        transform: translateX(0) !important;
    }
    80% {
        transform: translateX(calc(-100% + 200px)) !important;
    }
    100% {
        transform: translateX(calc(-100% + 200px)) !important;
    }
}

/* Pausar animación al hacer hover en onlive */
.onlive:hover .marquee span,
.onlive:hover .marquee .onlive-about {
    animation-play-state: paused !important;
}

/* Asegurar que las cajas de programación mantengan su tamaño */
.proms {
    width: 100% !important;
    overflow: hidden !important;
}

.proms-tabs__item {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
    gap: 1rem !important;
    width: 100% !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .proms-tabs__item {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
    }
    
    .onlive {
        flex-direction: column !important;
        text-align: center !important;
    }
    
    .onlive img {
        margin-bottom: 0.5rem !important;
    }
    
    .onlive-wrapper {
        width: 100% !important;
    }
}
/* Ajuste para que el banner sea más horizontal */
.slides-wrapper {
    width: 100% !important;
    max-height: 250px !important; /* Altura máxima reducida */
    overflow: hidden !important;
    border-radius: 8px !important;
}

.slides .slide img {
    width: 100% !important;
    height: 250px !important;
    object-fit: cover !important; /* Ajuste moderno para no deformar */
}

/* --- Diseño Moderno para el Modal PWA --- */
.pwa-modal {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 1rem !important;
    z-index: 9999 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: flex-end !important;
}

.pwa-modal__wrapper {
    background: rgba(15, 15, 15, 0.8) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding: 1.5rem !important;
    border-radius: 24px !important;
    max-width: 480px !important;
    width: 100% !important;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5) !important;
    animation: pwa-slide-up 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

@keyframes pwa-slide-up {
    from { transform: translateY(120%) scale(0.9); opacity: 0; }
    to { transform: translateY(0) scale(1); opacity: 1; }
}

.pwa-modal__wrapper p {
    color: white !important;
    font-family: 'Rubik', sans-serif !important;
    font-size: 1rem !important;
    margin-bottom: 1.5rem !important;
    line-height: 1.5 !important;
    text-align: center !important;
}

.pwa-modal__wrapper p strong {
    color: #ffffff !important;
    text-decoration: underline decoration-sky-500 !important;
}

.pwa-modal__group {
    display: flex !important;
    gap: 1rem !important;
    justify-content: center !important;
}

.pwa-modal__btn {
    padding: 0.75rem 1.75rem !important;
    border-radius: 100px !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.6rem !important;
    border: none !important;
}

.pwa-modal__btn svg {
    width: 18px !important;
    height: 18px !important;
    fill: currentColor !important;
}

/* Botón Instalar (Principal) */
.pwa-modal__btn:not(.no-ty) {
    background: #ffffff !important;
    color: #000000 !important;
    box-shadow: 0 4px 15px rgba(255, 255, 255, 0.2) !important;
}

.pwa-modal__btn:not(.no-ty):hover {
    transform: scale(1.05) translateY(-2px) !important;
    background: #f0f0f0 !important;
    box-shadow: 0 8px 25px rgba(255, 255, 255, 0.3) !important;
}

/* Botón No gracias (Secundario) */
.pwa-modal__btn.no-ty {
    background: rgba(255, 255, 255, 0.1) !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

.pwa-modal__btn.no-ty:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
}

@media (min-width: 768px) {
    .pwa-modal {
        justify-content: flex-end !important;
        padding: 2rem !important;
    }
    .pwa-modal__wrapper {
        width: 380px !important;
    }
}

/* --- Estilos para el Footer Moderno --- */
.footer-modern {
    background: linear-gradient(to bottom, #18181b, #09090b) !important;
}

footer.footer-modern {
    margin-top: 3rem !important;
}

.footer-modern a {
    text-decoration: none !important;
}

.footer-modern .group:hover img {
    filter: grayscale(0) brightness(1.2);
}

.footer-modern h3 {
    font-family: 'Inter', sans-serif !important;
}

/* --- Footer Moderno Consolidado y Centrado (Ultra-Compacto - Pegado Abajo) --- */
.footer-modern {
    padding: 1.5rem 1rem 0 !important; /* Cero abajo */
    background: linear-gradient(to bottom, #18181b, #050506) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    margin-bottom: 0 !important; /* Cero margen abajo */
}

.footer-container {
    max-width: 1100px !important;
    width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 1.25rem !important; /* Gap mínimo */
    justify-content: center !important;
    text-align: center !important;
}

.footer-col {
    flex: 1 1 180px !important;
    max-width: 260px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important; /* Alineado a la izquierda */
    text-align: left !important;
}

.footer-brand {
    font-size: 1.25rem !important;
    margin-bottom: 0.25rem !important;
    text-align: left !important;
}

.footer-text {
    color: rgba(255, 255, 255, 0.45) !important;
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
    text-align: left !important;
}

.footer-title {
    color: white !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    margin-bottom: 0.6rem !important; /* Pegado */
    width: 100% !important;
}

.footer-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.4rem !important;
}

.footer-links a, .footer-platforms a {
    color: rgba(255, 255, 255, 0.45) !important;
    text-decoration: none !important;
    font-size: 0.8rem !important;
    transition: all 0.3s ease !important;
}

.footer-links a:hover, .footer-platforms a:hover {
    color: white !important;
    transform: translateY(-1px) !important;
}

.footer-bottom {
    max-width: 1000px !important;
    width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding-top: 0.75rem !important;
    padding-bottom: 0px !important; /* Cero Absoluto */
    border-top: 1px solid rgba(255, 255, 255, 0.03) !important;
    margin-top: 1.25rem !important;
    flex-wrap: wrap !important;
    gap: 1rem !important;
}

@media (max-width: 768px) {
    .footer-container {
        flex-direction: column !important;
        align-items: center !important;
        gap: 2rem !important;
    }
    .footer-bottom {
        flex-direction: column !important;
        text-align: center !important;
    }
}

/* --- Correcciones finales de Iconos --- */
.footer-col svg, .footer-col img {
    width: 20px !important;
    height: 20px !important;
    display: inline-block !important;
    margin: 0 !important;
}

.p-link {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important; /* Alineado a la izquierda para los iconos */
    gap: 0.75rem !important;
}

.footer-platforms {
    list-style: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.4rem !important;
    margin: 0 !important;
    padding: 0 !important;
}

.icon-spotify { color: #1DB954 !important; }
.icon-alexa { color: #00CAFF !important; }

 .news-blog {
     display: flex !important;
     flex-direction: column !important;
     gap: 1.25rem !important;
 }

 .news-hero {
     width: 100% !important;
 }

 .news-hero-swiper {
     width: 100% !important;
 }

 .news-hero-swiper .swiper-pagination {
     position: relative !important;
     margin-top: 0.75rem !important;
 }

 .news-hero-swiper .swiper-pagination-bullet {
     background: rgba(17, 24, 39, 0.35) !important;
     opacity: 1 !important;
 }

 .news-hero-swiper .swiper-pagination-bullet-active {
     background: #111827 !important;
 }

 .news-grid {
     display: grid !important;
     grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
     gap: 1rem !important;
 }

 .news-footer {
     display: flex !important;
     justify-content: center !important;
     padding: 0.25rem 0 1rem 0 !important;
 }

 .news-load-more {
     display: inline-flex !important;
     align-items: center !important;
     justify-content: center !important;
     padding: 0.75rem 1.25rem !important;
     border-radius: 0.75rem !important;
     border: 1px solid rgba(0,0,0,0.12) !important;
     background: #ffffff !important;
     color: #111827 !important;
     font-weight: 700 !important;
     cursor: pointer !important;
 }

 .news-load-more:hover {
     background: #f9fafb !important;
 }

 .news-card {
     background: #ffffff !important;
     border-radius: 1rem !important;
     overflow: hidden !important;
     border: 1px solid rgba(0,0,0,0.06) !important;
     box-shadow: 0 1px 10px rgba(0,0,0,0.05) !important;
     cursor: pointer !important;
     transition: transform 0.18s ease, box-shadow 0.18s ease !important;
     display: flex !important;
     flex-direction: column !important;
     min-height: 100% !important;
 }

 .news-card:hover {
     transform: translateY(-2px) !important;
     box-shadow: 0 10px 25px rgba(0,0,0,0.08) !important;
 }

 .news-card-media {
     position: relative !important;
     width: 100% !important;
     height: 160px !important;
     background: #111827 !important;
 }

 .news-card--hero .news-card-media {
     height: 320px !important;
 }

 .news-card-image {
     width: 100% !important;
     height: 100% !important;
     object-fit: cover !important;
     display: block !important;
 }

 .news-card-content {
     padding: 1rem !important;
     display: flex !important;
     flex-direction: column !important;
     gap: 0.5rem !important;
 }

 .news-card-tag {
     font-size: 0.7rem !important;
     font-weight: 800 !important;
     letter-spacing: 0.08em !important;
     text-transform: uppercase !important;
     color: #ef4444 !important;
 }

 .news-card-title {
     font-size: 1.05rem !important;
     font-weight: 800 !important;
     color: #111827 !important;
     line-height: 1.2 !important;
     margin: 0 !important;
 }

 .news-card--hero .news-card-title {
     font-size: 1.6rem !important;
 }

 .news-card--hero .news-card-content {
     padding: 1rem 1rem 1.25rem 1rem !important;
     gap: 0.35rem !important;
 }

 .news-card-excerpt {
     font-size: 0.95rem !important;
     color: #4b5563 !important;
     line-height: 1.45 !important;
 }

 .news-card-meta {
     font-size: 0.8rem !important;
     color: #6b7280 !important;
     font-weight: 600 !important;
 }

 @media (max-width: 1024px) {
     .news-grid {
         grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
     }
 }

 @media (max-width: 768px) {
     .news-grid {
         grid-template-columns: 1fr !important;
     }

     .news-card--hero .news-card-media {
         height: 220px !important;
     }

     .news-card--hero .news-card-title {
         font-size: 1.35rem !important;
     }
 }

/* --- Grid Blog para Noticias (Fila Destacada + Grid) --- */
.news-blog-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5rem !important;
    margin-top: 1.5rem !important;
}

/* Fila horizontal para las primeras noticias */
.news-blog-grid .news-featured-row {
    display: flex !important;
    gap: 1rem !important;
    overflow-x: auto !important;
    padding-bottom: 0.5rem !important;
}

.news-blog-grid .news-featured-row::-webkit-scrollbar {
    height: 4px !important;
}

.news-blog-grid .news-featured-row::-webkit-scrollbar-track {
    background: rgba(0,0,0,0.05) !important;
    border-radius: 2px !important;
}

.news-blog-grid .news-featured-row::-webkit-scrollbar-thumb {
    background: rgba(0,0,0,0.2) !important;
    border-radius: 2px !important;
}

/* Cards en la fila horizontal */
.news-blog-grid .news-featured-row .card-multimedia {
    min-width: 220px !important;
    max-width: 260px !important;
    flex-shrink: 0 !important;
}

/* Grid para el resto de noticias */
.news-blog-grid .news-regular-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
    gap: 1rem !important;
}

/* Card Blog Ultra Compacta */
.news-blog-grid .card-multimedia {
    background: white !important;
    border-radius: 0.5rem !important;
    overflow: hidden !important;
    box-shadow: 0 1px 8px rgba(0,0,0,0.04) !important;
    border: 1px solid rgba(0,0,0,0.03) !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    text-decoration: none !important;
    color: inherit !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
}

.news-blog-grid .card-multimedia:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08) !important;
    border-color: rgba(99, 102, 241, 0.08) !important;
}

.news-blog-grid .card-multimedia:active {
    transform: translateY(0px) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
}

/* Indicador de toque para móvil */
.news-blog-grid .card-multimedia::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(99, 102, 241, 0.05) !important;
    opacity: 0 !important;
    transition: opacity 0.2s ease !important;
    pointer-events: none !important;
}

.news-blog-grid .card-multimedia:active::after {
    opacity: 1 !important;
}

/* Imagen ultra compacta */
.news-blog-grid .card-thumb {
    width: 100% !important;
    height: 120px !important;
    border-radius: 0 !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

/* Contenido ultra compacto */
.news-blog-grid .card-content {
    padding: 0.75rem !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.4rem !important;
    flex: 1 !important;
}

/* Badge mini */
.news-blog-grid .card-tag {
    font-size: 0.6rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: #ef4444 !important;
    background: rgba(239, 68, 68, 0.06) !important;
    padding: 0.15rem 0.5rem !important;
    border-radius: 100px !important;
    display: inline-block !important;
    width: fit-content !important;
    margin-bottom: 0.2rem !important;
}

/* Título compacto */
.news-blog-grid .card-title {
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: #18181b !important;
    line-height: 1.3 !important;
    margin-bottom: 0.3rem !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    flex: 1 !important;
}

/* Meta más visible */
.news-blog-grid .card-meta {
    font-size: 0.7rem !important;
    color: #6b7280 !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.3rem !important;
    margin-top: 0.5rem !important;
    font-weight: 500 !important;
}

/* Descripción ultra corta */
.news-blog-grid .card-description {
    font-size: 0.8rem !important;
    color: #6b7280 !important;
    line-height: 1.4 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    margin-bottom: 0.5rem !important;
}

/* Responsive ultra compacto */
@media (max-width: 768px) {
    .news-blog-grid .news-featured-row {
        gap: 0.75rem !important;
    }
    
    .news-blog-grid .news-featured-row .card-multimedia {
        min-width: 200px !important;
        max-width: 240px !important;
    }
    
    .news-blog-grid .news-regular-grid {
        grid-template-columns: 1fr !important;
        gap: 0.875rem !important;
    }
    
    .news-blog-grid .card-thumb {
        height: 100px !important;
    }
    
    .news-blog-grid .card-content {
        padding: 0.625rem !important;
    }
    
    .news-blog-grid .card-title {
        font-size: 0.825rem !important;
    }
    
    /* Mejor tocabilidad para móvil */
    .news-blog-grid .card-multimedia {
        min-height: 48px !important; /* Mínimo para tocabilidad iOS */
        padding: 2px !important; /* Espacio extra para evitar errores de toque */
    }
    
    /* Feedback visual mejorado para móvil */
    .news-blog-grid .card-multimedia::after {
        background: rgba(99, 102, 241, 0.1) !important;
    }
    
    .news-blog-grid .card-multimedia:active::after {
        opacity: 1 !important;
    }
}

/* --- Modal para Noticias Completas --- */
.modal.modal-news {
    background: rgba(0, 0, 0, 0.55) !important;
    z-index: 999999 !important;
}

.modal.modal-audio {
    background: rgba(0, 0, 0, 0.55) !important;
    z-index: 999999 !important;
}

.modal.modal-audio.is-active {
    display: grid !important;
}

.modal.modal-audio .modal-wrapper {
    background: transparent !important;
    padding: 0 !important;
    opacity: 100% !important;
}

.audio-modal-content {
    background: #ffffff !important;
    border-radius: 1rem !important;
    overflow: hidden !important;
    width: 100% !important;
}

.audio-modal-header {
    height: 200px !important;
    background: #000000 !important;
}

.audio-modal-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.audio-modal-body {
    padding: 1.25rem !important;
    color: #111827 !important;
}

.audio-modal-title {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.25rem !important;
    color: #111827 !important;
}

.audio-modal-date {
    font-size: 0.85rem !important;
    color: #6b7280 !important;
    margin-bottom: 1rem !important;
}

.audio-modal-player {
    width: 100% !important;
}

.audio-modal-actions {
    margin-top: 1rem !important;
    display: flex !important;
    justify-content: flex-end !important;
}

/* El sistema base muestra modales con .is-active */
.modal.modal-news.is-active {
    display: grid !important;
}

.modal.modal-news .modal-wrapper {
    background: transparent !important;
    padding: 0 !important;
    opacity: 100% !important;
    scale: 1 !important;
}

/* Asegurar que el wrapper sea visible aunque existan overrides previos */
.modal.modal-news.is-active .modal-wrapper {
    opacity: 100% !important;
    scale: 1 !important;
}

.news-modal-content {
    background: #ffffff !important;
    border-radius: 1rem !important;
    overflow: hidden !important;
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.25) !important;
    border: 1px solid rgba(0, 0, 0, 0.12) !important;
    width: 100% !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

.news-modal-header {
    position: relative !important;
    height: 300px !important;
    overflow: hidden !important;
    background: #000000 !important;
}

.news-modal-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.news-modal-overlay {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    background: linear-gradient(to top, rgba(0,0,0,0.95), transparent) !important;
    padding: 2rem !important;
    color: #ffffff !important;
    z-index: 1 !important;
}

.news-modal-tag {
    display: inline-block !important;
    background: #ef4444 !important;
    color: #ffffff !important;
    padding: 0.3rem 0.8rem !important;
    border-radius: 100px !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 1rem !important;
}

.news-modal-title {
    font-size: 2rem !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    margin-bottom: 0.5rem !important;
    color: #ffffff !important;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.8) !important;
}

.news-modal-meta {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.news-modal-date {
    font-size: 0.875rem !important;
    color: #ffffff !important;
    font-weight: 600 !important;
    background: rgba(0,0,0,0.5) !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 0.25rem !important;
}

.news-modal-body {
    padding: 2rem !important;
    background: #ffffff !important;
    color: #000000 !important;
}

.news-modal-description {
    font-size: 1.05rem !important;
    line-height: 1.75 !important;
    color: #111827 !important;
}

.news-modal-description * {
    color: #111827 !important;
}

.news-modal-actions {
    display: flex !important;
    gap: 1rem !important;
    justify-content: flex-end !important;
    padding-top: 1rem !important;
    border-top: 1px solid rgba(0, 0, 0, 0.12) !important;
}

.btn-share {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    background: #2563eb !important;
    color: #ffffff !important;
    border: none !important;
    padding: 0.75rem 1.25rem !important;
    border-radius: 0.5rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.btn-share:hover {
    background: #1d4ed8 !important;
    transform: translateY(-1px) !important;
}

.btn-close {
    background: #111827 !important;
    color: #ffffff !important;
    border: none !important;
    padding: 0.75rem 1.25rem !important;
    border-radius: 0.5rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.btn-close:hover {
    background: #0b1220 !important;
    transform: translateY(-1px) !important;
}

/* Botón de cerrar del modal */
.modal.modal-news .modal-close {
    display: none !important;
}

.modal.modal-news .modal-close:hover {
    background: #0b1220 !important;
    transform: scale(1.05) !important;
}

@media (max-width: 768px) {
    .news-modal-content {
        width: 95% !important;
        margin: 10px !important;
        border: 3px solid #000000 !important;
    }
    
    .news-modal-header {
        height: 200px !important;
    }
    
    .news-modal-overlay {
        padding: 1rem !important;
    }
    
    .news-modal-title {
        font-size: 1.5rem !important;
    }
    
    .news-modal-body {
        padding: 1rem !important;
    }
    
    .news-modal-description {
        font-size: 1.2rem !important;
    }
    
    .news-modal-actions {
        flex-direction: column !important;
    }
    
    .btn-share,
    .btn-close {
        width: 100% !important;
        justify-content: center !important;
    }
}
.podcasts-list {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0.75rem !important;
}

.podcasts-list .card-multimedia {
    background: white !important;
    border-radius: 0.5rem !important;
    padding: 0.5rem !important;
    display: flex !important;
    gap: 0.6rem !important;
    border: 1px solid rgba(0,0,0,0.03) !important;
    box-shadow: 0 1px 6px rgba(0,0,0,0.03) !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    text-decoration: none !important;
    color: inherit !important;
}

.podcasts-list .card-multimedia:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 3px 12px rgba(0,0,0,0.06) !important;
}

.podcasts-list .card-thumb {
    width: 52px !important;
    height: 52px !important;
    border-radius: 0.375rem !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

.podcasts-list .card-content {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 0.25rem !important;
    flex: 1 !important;
}

.podcasts-list .inline-card .card-content {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0.75rem !important;
    flex-wrap: wrap !important;
}

.podcasts-list .inline-card .card-info {
    min-width: 0 !important;
    flex: 1 1 auto !important;
}

.podcasts-list .inline-card .card-controls {
    flex: 0 1 220px !important;
    display: flex !important;
    justify-content: flex-end !important;
}

.podcasts-list .inline-card .card-player {
    width: 100% !important;
    margin-top: 0 !important;
}

.podcasts-list .card-tag {
    font-size: 0.6rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    color: #8b5cf6 !important;
    background: rgba(139, 92, 246, 0.06) !important;
    padding: 0.15rem 0.4rem !important;
    border-radius: 100px !important;
    display: inline-block !important;
    width: fit-content !important;
}

.podcasts-list .card-title {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    color: #18181b !important;
    line-height: 1.2 !important;
    margin-bottom: 0.2rem !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.podcasts-list .card-meta {
    font-size: 0.62rem !important;
    color: #9ca3af !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.3rem !important;
}

.podcasts-list .inline-card .card-player {
    height: 34px !important;
}

@media (max-width: 768px) {
    .podcasts-list .card-thumb {
        width: 48px !important;
        height: 48px !important;
    }
    
    .podcasts-list .card-content {
        gap: 0.2rem !important;
    }
    
    .podcasts-list .card-title {
        font-size: 0.775rem !important;
    }

    .podcasts-list .inline-card .card-content {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0.5rem !important;
    }

    .podcasts-list .inline-card .card-controls {
        flex: 1 1 auto !important;
        justify-content: flex-start !important;
    }
}

@media (max-width: 1024px) {
    .podcasts-list {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .podcasts-list {
        grid-template-columns: 1fr !important;
    }
}

/* --- Nuevas Secciones: Podcasts y Noticias --- */
.section-title {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    font-weight: 700 !important;
    color: #18181b !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 1.5rem !important;
    font-size: 1.1rem !important;
}

.section-title svg {
    opacity: 0.7 !important;
}

.news-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.25rem !important;
}

/* Card Estilizada */
.card-multimedia {
    background: white !important;
    border-radius: 1rem !important;
    padding: 1rem !important;
    display: flex !important;
    gap: 1.25rem !important;
    border: 1px solid rgba(0,0,0,0.05) !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    text-decoration: none !important;
    color: inherit !important;
}

.card-multimedia:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 10px 25px -5px rgba(0,0,0,0.1) !important;
    border-color: rgba(255,255,255,0.1) !important;
}

.card-thumb {
    width: 100px !important;
    height: 100px !important;
    border-radius: 0.75rem !important;
    object-fit: cover !important;
    flex-shrink: 0 !important;
}

.card-content {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.card-tag {
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #3b82f6 !important; /* Azul por defecto */
    margin-bottom: 0.35rem !important;
    display: block !important;
}

.card-title {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #18181b !important;
    line-height: 1.3 !important;
    margin-bottom: 0.5rem !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.card-meta {
    font-size: 0.75rem !important;
    color: #71717a !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.empty-state {
    padding: 3rem 1.5rem !important;
    background: rgba(0,0,0,0.02) !important;
    border: 2px dashed rgba(0,0,0,0.05) !important;
    border-radius: 1.5rem !important;
    text-align: center !important;
    color: #71717a !important;
}

/* Forzar pegado final del documento */
body {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}
