/*
  ================================================================
  Estilos para Módulo: Programas - Estilo Vertical
  Versión: 4.0 (Professional Design & Responsive)
  ================================================================
*/

{% scope_css %}

:root {
  --color-primary-brand: #AC0B32;
  --color-text-dark: #2B0007;
  --card-border-radius: 12px;
  --card-transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* --- Estilos Generales de la Sección --- */
.otros-programas {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  padding: 60px 20px;
  text-align: center;
}

.otros-programas__title {
  color: var(--color-primary-brand);
  font-weight: 700;
  font-size: clamp(28px, 4vw, 36px); /* Tipografía fluida */
  margin-bottom: 15px;
}

.otros-programas__intro {
  color: var(--color-text-dark);
  max-width: 800px;
  margin: 0 auto 50px auto;
  line-height: 1.7;
  font-size: 1.1rem;
}

/* --- Cuadrícula de Tarjetas --- */
.otros-programas__grid {
  display: grid;
  /* La distribución de 3 columnas que solicitaste */
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  text-align: left;
}

/* --- Estilos de la Tarjeta Individual --- */
.otros-programas__card {
  position: relative;
  border: 1px solid #EAEAEA;
  border-radius: var(--card-border-radius);
  overflow: hidden;
  background-color: #FFFFFF;
  transition: var(--card-transition);
  box-shadow: 0 4px 20px rgba(43, 0, 7, 0.05);
}

.otros-programas__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 10px 30px rgba(43, 0, 7, 0.1);
  border-color: var(--color-primary-brand);
}

.otros-programas__card-image img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9; /* Ratio moderno para imágenes */
  object-fit: cover;
  border-bottom: 1px solid #EAEAEA;
}

.otros-programas__card-content {
  padding: 25px;
}

.otros-programas__card-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-text-dark);
  margin: 0;
  line-height: 1.3;
}

/* --- Lógica del Enlace Estirado (Stretched Link) --- */
.otros-programas__card-link {
  color: inherit;
  text-decoration: none;
}

.otros-programas__card-link::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  z-index: 1;
}

/* --- Spacer para balancear la cuadrícula (No requiere estilos visuales) --- */
.otros-programas__card-spacer {
  display: none; /* Ocultamos por defecto, la cuadrícula lo maneja */
}

/* --- Estilos Responsivos Profesionales (Mobile-First) --- */

/* Dispositivos Pequeños (1 columna) */
@media (max-width: 767px) {
  .otros-programas__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .otros-programas__intro {
    font-size: 1rem;
  }
}

/* Dispositivos Medianos (Tablets, 2 columnas) */
@media (min-width: 768px) and (max-width: 991px) {
  .otros-programas__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Dispositivos Grandes (Desktop, 3 columnas) - ya definido por defecto */