/*
 * Estilos específicos para la página de Comunicados Oficiales.
 * Este archivo centraliza todos los estilos del template para una
 * mejor mantenibilidad.  Incluye la grilla de collage, las tarjetas
 * de comunicados, noticias y eventos, así como el paginador y
 * ajustes de espaciado.  Ajusta los valores de colores y medidas
 * utilizando los tokens definidos en style.css si fuese necesario.
 */

/*
 * Sección collage de destacados
 *
 * Por defecto, .sec-collage hereda la clase .container que limita el ancho a
 * var(--container-max) y centra el contenido.  Para este collage, no
 * utilizamos flexbox sino que centramos manualmente la grilla .collage y
 * permitimos que el contenedor maneje los márgenes laterales.
 */
.page-comunicados .sec-collage {
  margin: 0 0 var(--space-4, 32px);
  /* no usamos flex aquí para evitar desalineaciones */
  display: block;
}

/* Centrar la grilla del collage dentro de la sección y asegurar ancho máximo */
.page-comunicados .sec-collage .collage {
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

/*
 * Collage de destacados con 12 columnas.
 *
 * Utilizamos un grid de 12 columnas para distribuir los 5 elementos:
 *   - .item--lg: 8 columnas y 2 filas (imagen grande)
 *   - .item--md: 4 columnas cada una (dos imágenes medianas)
 *   - .item--sm: 6 columnas cada una (dos imágenes pequeñas que llenan el ancho)
 * En tablet (≤1024px) el collage pasa a 8 columnas. En móvil se
 * colapsa a 1 columna.
 */
.collage {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 22px;
}

/* Tarjetas del collage */
.col-card {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: #f8f8f8;
  height: 100%;
}
.col-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.col-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 14px;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 0.55) 100%);
  color: #fff;
}
.col-card__badge {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  opacity: 0.9;
}
.col-card__title {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.3;
}

/* Distribución por tamaños */
.collage .item--lg { grid-column: 1 / span 8; grid-row: 1 / span 2; aspect-ratio: 16/10; }
.collage .item--md:nth-of-type(2) { grid-column: 9 / span 4; grid-row: 1 / span 1; aspect-ratio: 16/10; }
.collage .item--md:nth-of-type(3) { grid-column: 9 / span 4; grid-row: 2 / span 1; aspect-ratio: 16/10; }
.collage .item--sm:nth-of-type(4) { grid-column: 1 / span 6; grid-row: 3 / span 1; aspect-ratio: 16/10; }
.collage .item--sm:nth-of-type(5) { grid-column: 7 / span 6; grid-row: 3 / span 1; aspect-ratio: 16/10; }

@media (max-width: 1024px) {
  .collage { grid-template-columns: repeat(8, 1fr); }
  .collage .item--lg { grid-column: 1 / span 8; grid-row: auto; }
  .collage .item--md:nth-of-type(2) { grid-column: 1 / span 4; grid-row: auto; }
  .collage .item--md:nth-of-type(3) { grid-column: 5 / span 4; grid-row: auto; }
  .collage .item--sm:nth-of-type(4) { grid-column: 1 / span 4; grid-row: auto; }
  .collage .item--sm:nth-of-type(5) { grid-column: 5 / span 4; grid-row: auto; }
}

@media (max-width: 600px) {
  .collage { grid-template-columns: 1fr; }
  .collage .item--lg,
  .collage .item--md:nth-of-type(2),
  .collage .item--md:nth-of-type(3),
  .collage .item--sm:nth-of-type(4),
  .collage .item--sm:nth-of-type(5) {
    grid-column: auto;
    grid-row: auto;
    aspect-ratio: 16/10;
  }
}

/* Encabezados de sección */
.sec-head {
  margin-bottom: 12px;
}
.sec-head h2 {
  font-size: 1.6rem;
  margin: 0;
}

/* Grilla de 3 columnas (comunicados, noticias) */
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
@media (max-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .grid-3 {
    grid-template-columns: 1fr;
  }
}

/* Grilla de 2 columnas (eventos) */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}
@media (max-width: 800px) {
  .grid-2 {
    grid-template-columns: 1fr;
  }
}

/* Tarjetas mínimas de fallback */
.card-mini {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.card-thumb img {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
}
.card-title {
  font-size: 1.05rem;
  line-height: 1.3;
  margin: 12px 14px 0;
}
.card-title a {
  color: #1f2937;
  text-decoration: none;
}
.card-excerpt {
  margin: 6px 14px 0;
  color: #606060;
}
.btn-read {
  margin: 12px 14px 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--color-primary, #C8553D);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}
.btn-read:hover {
  filter: brightness(0.95);
}

/* Paginador */
.paginador {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 18px;
}
.paginador a,
.paginador span {
  padding: 8px 12px;
  border: 1px solid #ddd;
  border-radius: 999px;
  text-decoration: none;
}
.paginador .current {
  background:  #4A6B47;
  color: #fff;
  border-color:  #4A6B47;
}

/* Margen adicional para la sección de eventos: separación arriba y abajo */
.sec-eventos {
  margin-top: 24px;
  margin-bottom: 64px;
}

/*
 * Contenedor de collage para Comunicados Oficiales
 *
 * La clase comof-wrap reemplaza al contenedor estándar para la sección de collage.
 * Esto elimina las restricciones del .container (que alineaba el contenido
 * hacia la izquierda) y centra la grilla .collage dentro del ancho disponible.
 * Se utiliza flexbox únicamente en el contenedor para centrar su hijo.
 */
.comof-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
}
.comof-wrap > .collage {
  width: 100%;
  max-width: 1200px;
  /* se ajusta padding desde el padre sec-collage si es necesario */
  margin-left: auto;
  margin-right: auto;
}
/* === FORCE CENTER: Collage encabezado === */
.page-comunicados .sec-collage{ 
  display:block;           /* por si algún padre la hace flex */
  padding-inline:16px;     /* pequeño respiro lateral */
}

.page-comunicados .sec-collage > .collage{
  width:min(100%, 1200px); /* ancho controlado */
  max-width:1200px;
  margin-left:auto !important;
  margin-right:auto !important; /* CENTRADO REAL */
}

/* Por si algún padre es flex y está empujando a la izquierda */
.page-comunicados .sec-collage{
  justify-content:center !important;
  align-items:stretch !important;
}

/* ===== FIX DEFINITIVO: centrar collage encabezado ===== */
main.page-comunicados .sec-collage.container{
  max-width:100% !important;   /* suelta el tope del .container */
  width:100% !important;
  padding-left:0; 
  padding-right:0;
  display:flex !important;     /* centramos al hijo */
  justify-content:center !important;
}

main.page-comunicados .sec-collage.container > .collage{
  width:1200px;                /* ancho de trabajo */
  max-width:100%;
  margin-left:auto !important; /* centro real */
  margin-right:auto !important;
  box-sizing:border-box;
  padding-inline:16px;         /* respirito lateral */
}

/*
 * ===============================================
 *  Sección de menú interno para Comunicados Oficiales
 * -----------------------------------------------
 * Esta franja blanca muestra una serie de botones que dirigen a
 * distintas áreas temáticas del sitio.  El menú se construye desde
 * ACF mediante un repeater y sus estilos se definen aquí para
 * asegurar consistencia con la maqueta.  Los botones son de
 * esquinas redondeadas (30px) y utilizan el color #4A6B47.
 */
.page-comunicados .sec-menu-oficial {
  background-color: #FFFFFF;
  padding-top: 16px;
  padding-bottom: 16px;
  margin-top: 16px;
  margin-bottom: 32px;
}
.page-comunicados .menu-oficial-wrap {
  /* Mantenemos los elementos en una misma fila utilizando flexbox.  El
   * título/pregunta y los botones se distribuyen horizontalmente con
   * espacio uniforme entre ellos.  Permitimos el wrap en pantallas
   * pequeñas mediante flex-wrap para que el menú se adapte a móvil.
   */
  display: flex;
  /*
   * Aseguramos que los elementos del menú se dispongan horizontalmente.
   * Algunas configuraciones del servidor o plugins de caché pueden
   * conservar versiones antiguas de esta hoja de estilos y causar que
   * flex-direction herede un valor por defecto.  Forzamos la propiedad
   * a 'row' con !important para evitar que cualquier regla previa la
   * sobrescriba.  También mantenemos flex-wrap para que en móviles se
   * reorganice en varias líneas.
   */
  flex-direction: row !important;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.page-comunicados .menu-oficial-title {
  color: #DF8233;
  font-weight: 700;
  font-size: 1rem;
  margin: 0;
  /* Ocupa el ancho completo para situarse encima de la línea de botones. */
  flex-basis: 100%;
}
.page-comunicados .menu-oficial-buttons {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
}
.page-comunicados .menu-oficial-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 30px;
  border-radius: 30px;
  background-color: #4A6B47;
  color: #FFFFFF;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition: filter 0.2s ease;
}
.page-comunicados .menu-oficial-btn:hover {
  filter: brightness(0.95);
}

/* Pregunta del menú (“¿Qué estás buscando?”) se muestra en una sola línea y
 * adopta el color institucional naranja.  Evitamos que el texto se rompa
 * para mantenerlo alineado con los botones. */
.page-comunicados .menu-oficial-question {
  white-space: nowrap;
  color: #DF8233;
  font-weight: 700;
  font-size: 1.3rem;
  margin: 0;
}

/*
 * Encabezado personalizado de últimas noticias
 * Ajustamos el color y tamaño del título y descripción obtenidos
 * mediante ACF.  Se eliminan márgenes innecesarios para alinear
 * correctamente con el grid de tarjetas.
 */
.page-comunicados .sec-ultimas .ultimas-head {
  margin-bottom: 1rem;
}
.page-comunicados .sec-ultimas .ultimas-title {
  color: #DF8233;
  margin: 0;
  font-size: 1.6rem;
  font-weight: 700;
}
.page-comunicados .sec-ultimas .ultimas-desc {
  color: #57534E;
  margin: 0.5rem 0 0;
  font-size: 1rem;
}

/*
 * Eliminamos borde y sombra de las tarjetas en la sección de últimas noticias
 * para replicar el estilo limpio de Figma.  Aplicamos tanto a las
 * tarjetas estándar (.news-card) como al fallback (.card-mini).
 */
.page-comunicados .sec-ultimas .news-card {
  background: var(--color-bg);
  border: none;
  box-shadow: none;
}
.page-comunicados .sec-ultimas .card-mini {
  border: none;
  box-shadow: none;
}

/*
 * Texto fijo debajo del menú de enlaces en Comunicados Oficiales
 */
.page-comunicados .menu-oficial-question {
  margin: 0;
  color: #DF8233;
  font-size: 1.3rem;
  font-weight: 700;
  white-space: nowrap;
}

