/* ============================
   ESTILOS PARA QUIÉNES SOMOS
   ============================ */

/* --- Sección Principal --- */
.seccion-mision {
    padding: 2rem 1rem;
    background: transparent;
  }
  
  .contenedor-mision {
    max-width: var(--container-max-width);
    margin: 0 auto;
  }
  
  .contenedor-principal h1 {
    font-size: 2.2rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary-dark-blue);
    text-align: center;
  }
  
  .contenedor-principal h2 {
    color: var(--color-primary-green);
    font-size: 2.2rem;
    text-align: center;
  }
  
  .contenedor-principal h3 {
    font-size: 2.2rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary-dark-blue);
    text-align: center;
  }
  
  .contenido-mision h3 {
    font-family: var(--font-family-sans);
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary-green);
    text-align: center;
    margin-bottom: calc(var(--spacing-unit) * 2);
  }
  
  .descripcion-mision {
    font-size: 1.1rem;
    font-weight: var(--font-weight-regular);
    color: var(--color-primary-black);
    text-align: center;
    line-height: 1.7;
    max-width: 800px;
    padding: 20px;

  }
  
  
  /* --- Collage de Imágenes Misión --- */
  .collage-mision {
    position: relative;
    max-width: 100%;
    height: 180px;
    overflow: hidden;
    margin-top: calc(var(--spacing-unit) * 2);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  
  .collage-mision::-webkit-scrollbar {
    display: none;
  }
  
  .grid-imagenes {
    display: flex;
    height: 100%;
    animation: scroll 20s linear infinite;
    will-change: transform;
  }
  
  .grid-imagenes:hover {
    animation-play-state: paused;
  }
  
  /* Efectos de gradiente en los bordes */
  .collage-mision::before,
  .collage-mision::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 30px;
    z-index: 10;
    pointer-events: none;
  }
  
  .collage-mision::before {
    left: 0;
    background: linear-gradient(to right, #ffffff, transparent);
  }
  
  .collage-mision::after {
    right: 0;
    background: linear-gradient(to left, #ffffff, transparent);
  }
  
  .imagen-collage {
    flex: 0 0 220px;
    height: 150px;
    margin-right: 15px;
    padding: 12px;
    border-radius: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .imagen-collage:nth-child(odd) {
    background: var(--color-primary-white);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.1);
  }
  
  .imagen-collage:nth-child(even) {
    background: var(--color-primary-green);
    box-shadow: 0 6px 24px rgba(105, 198, 36, 0.3);
  }
  
  .imagen-collage img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0.8rem;
    transition: transform 0.3s ease;
  }
  
  .imagen-collage:hover {
    transform: translateY(-8px);
  }
  
  .imagen-collage:hover img {
    transform: scale(1.05);
  }
  
  /* Animación de scroll infinito */
  @keyframes scroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50%);
    }
  }
  
  /* ============================
     SECCIÓN VISIÓN
     ============================ */
  #seccion-vision {
    padding: calc(var(--spacing-unit) * 6) calc(var(--spacing-unit) * 2);
  }
  
  .contenedor-vision {
    max-width: var(--container-max-width);
    margin: 0 auto;
  }
  
  .contenido-vision h3 {
    font-size: 2.5rem;
    font-weight: var(--font-weight-bold);
    color: var( --color-primary-green);
    margin-bottom: calc(var(--spacing-unit) * 3);
    text-align: center;
  }
  
  .descripcion-vision {
    font-size: 1.1rem;
    font-weight: var(--font-weight-regular);
    color: var(--color-primary-black);
    text-align: center;
    line-height: 1.7;
    max-width: 800px;
    margin: 0 auto;
  }
  
/* ============================
     SECCIÓN VALORES
   ============================ */
   #seccion-valores {
    padding: calc(var(--spacing-unit) * 8) calc(var(--spacing-unit) * 2);
  }
  
  .contenedor-valores {
    max-width: var(--container-max-width);
    margin: 0 auto;
  }
  
  .contenedor-valores h3 {
    font-size: 2.5rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-primary-green);
    text-align: center;
    margin-bottom: calc(var(--spacing-unit) * 6);
  }
  
  /* --- MODIFICACIONES PRINCIPALES AQUÍ --- */
  .grid-valores {
    display: flex;
    flex-wrap: wrap; /* Permite que los elementos pasen a la siguiente línea */
    justify-content: center; /* Centra los valores horizontalmente como grupo */
    align-items: center; /* Alinea verticalmente los valores en la misma fila */
    gap: calc(var(--spacing-unit) * 2); /* Ajustado para un mejor espaciado */
  }
  
  .tarjeta-valor {
    border-radius: 50px;
    /* Reducido el padding vertical para hacer las tarjetas menos altas */
    padding: calc(var(--spacing-unit) * 1.2) calc(var(--spacing-unit) * 1.2);
    background-color: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
    animation: pulso-infinito 3s ease-in-out infinite;
    height: 30px;
  }
  
  .tarjeta-valor h4 {
    font-size: 1.1rem;
    font-weight: var(--font-weight-semibold);
    line-height: 1.3;
    white-space: nowrap;
    text-align: center; /* Asegura que el texto esté centrado en la tarjeta */
  }
  
  /* Colores de fondo por valor */
  .tarjeta-valor[data-orden="1"],
  .tarjeta-valor[data-orden="5"] {
    background-color: #eef2ff; /* Azul claro */
  }
  
  .tarjeta-valor[data-orden="2"],
  .tarjeta-valor[data-orden="6"],
  .tarjeta-valor[data-orden="4"]{
    background-color: #e6f7ee; /* Verde claro */
  }
  
  .tarjeta-valor[data-orden="3"] {
    background-color: #f0f2f5; /* Gris claro */
  }
  
  /* Colores de texto por valor */
  .tarjeta-valor[data-orden="1"] h4{
    color: var(--color-secondary-light-blue);
  }
  
  .tarjeta-valor[data-orden="2"] h4,
  .tarjeta-valor[data-orden="6"] h4,
  .tarjeta-valor[data-orden="4"] h4 {
    color: var(--color-primary-green);
  }
  
  .tarjeta-valor[data-orden="3"] h4 {
    color: var(--color-secondary-gray);
  }
  
  /* Animación de pulso con delay */
  @keyframes pulso-infinito {
    0%, 100% {
      transform: scale(1);
    }
    50% {
      transform: scale(1.05);
    }
  }
  /* ==============================================
   ESTILOS ODS - ICONOS CON EFECTO FLIP
   ============================================== */

/* Sección principal ODS */
#seccion-ods {
  padding: 2rem 1rem;
  background-color: var(--color-primary-white);
}

.contenedor-ods {
  max-width: 100%;
  margin: 0 auto;
}

/* Título de la sección */
.titulo-ods {
  text-align: center;
  margin-bottom: 2rem;
}

#titulo-ods-configurable {
  font-size: 2.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  color: var(--color-primary-dark-blue);
  margin: 0;
  padding: 0 1rem;
}

#titulo-ods-configurable .destacado {
  color: var(--color-primary-green);
}

/* Grid de iconos ODS */
.grid-ods-iconos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  padding: 1rem;
}

/* Tarjeta contenedora del icono */
.tarjeta-ods-icono {
  perspective: 1000px; /* Necesario para el efecto 3D */
  width: 120px;
  height: 120px;
}

/* Contenedor del icono con flip */
.icono-container {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1);
  cursor: pointer;
}

/* Hover effect - voltea el icono */
.tarjeta-ods-icono:hover .icono-container {
  transform: rotateY(180deg);
}

/* Estilos base para ambas caras */
.icono-frontal,
.icono-posterior {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s ease;
}

/* Cara frontal (icono) */
.icono-frontal {
  background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
  border: 2px solid var(--color-primary-green);
}

/* Cara posterior (información) */
.icono-posterior {
  background: var(--color-primary-green);
  color: white;
  transform: rotateY(180deg);
  flex-direction: column;
  text-align: center;
  padding: 1rem;
}

/* Imagen del icono PNG */
.ods-icono {
  width: 80px;
  height: 80px;
  object-fit: contain;
  transition: transform 0.3s ease;
}

.tarjeta-ods-icono:hover .ods-icono {
  transform: scale(1.1);
}

/* Fallback cuando no hay icono */
.ods-fallback {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary-green);
  text-align: center;
}

/* Contenido de la cara posterior */
.numero-ods-back {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
}

.contenido-ods-back h4 {
  font-size: 0.9rem;
  font-weight: 600;
  margin: 0 0 0.5rem 0;
  line-height: 1.2;
  color: white;
}

.contenido-ods-back p {
  font-size: 0.7rem;
  line-height: 1.3;
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
  overflow: hidden;
  display: -webkit-box;
  line-clamp: 4;
  -webkit-box-orient: vertical;
}

/* Efecto hover en la tarjeta completa */
.tarjeta-ods-icono:hover .icono-frontal,
.tarjeta-ods-icono:hover .icono-posterior {
  box-shadow: 0 8px 24px rgba(105, 198, 36, 0.3);
}

/* Animación de entrada */
.tarjeta-ods-icono {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 0.6s ease forwards;
}

.tarjeta-ods-icono:nth-child(1) { animation-delay: 0.1s; }
.tarjeta-ods-icono:nth-child(2) { animation-delay: 0.2s; }
.tarjeta-ods-icono:nth-child(3) { animation-delay: 0.3s; }

@keyframes fadeInUp {
  to {
      opacity: 1;
      transform: translateY(0);
  }
}

/* ==============================================
   MEDIA QUERIES - RESPONSIVE
   ============================================== */

/* Tablets - Pantallas medianas (768px+) */
@media (min-width: 768px) {
  #seccion-ods {
    padding: 3rem 2rem;
  }
  
  .contenedor-ods {
    max-width: 1200px;
  }
  
  #titulo-ods-configurable {
    font-size: 2.5rem;
    margin-bottom: 1rem;
    padding: 0 2rem;
  }
  
  .titulo-ods {
    margin-bottom: 3rem;
  }
  
  .grid-ods-iconos {
    gap: 2rem;
    padding: 2rem;
  }
  
  .tarjeta-ods-icono {
    width: 140px;
    height: 140px;
  }
  
  .ods-icono {
    width: 90px;
    height: 90px;
  }
  
  .contenido-ods-back h4 {
    font-size: 1rem;
    margin-bottom: 0.75rem;
  }
  
  .contenido-ods-back p {
    font-size: 0.8rem;
    line-height: 1.4;
    line-clamp: 5;
  }
}

/* Desktop - Pantallas grandes (1024px+) */
@media (min-width: 1024px) {
  #seccion-ods {
    padding: 4rem 2rem;
  }
  
  #titulo-ods-configurable {
    font-size: 3rem;
    line-height: 1.3;
    padding: 0 3rem;
  }
  
  .titulo-ods {
    margin-bottom: 4rem;
  }
  
  .grid-ods-iconos {
    gap: 3rem;
    padding: 2rem;
    max-width: 800px;
    margin: 0 auto;
  }
  
  .tarjeta-ods-icono {
    width: 160px;
    height: 160px;
  }
  
  .ods-icono {
    width: 100px;
    height: 100px;
  }
  
  .icono-frontal,
  .icono-posterior {
    border-radius: 20px;
  }
  
  .icono-posterior {
    padding: 1.5rem;
  }
  
  .numero-ods-back {
    font-size: 1.1rem;
    margin-bottom: 0.75rem;
  }
  
  .contenido-ods-back h4 {
    font-size: 1.1rem;
    margin-bottom: 1rem;
    line-height: 1.3;
  }
  
  .contenido-ods-back p {
    font-size: 0.85rem;
    line-height: 1.5;
    line-clamp: 6;
  }
  
  /* Efecto hover mejorado para desktop */
  .tarjeta-ods-icono:hover .icono-frontal,
  .tarjeta-ods-icono:hover .icono-posterior {
    box-shadow: 0 12px 32px rgba(105, 198, 36, 0.4);
  }
  
  /* Transición más suave en desktop */
  .icono-container {
    transition: transform 0.7s cubic-bezier(0.4, 0.2, 0.2, 1);
  }
}

/* Desktop grande - Pantallas extra grandes (1200px+) */
@media (min-width: 1200px) {
  .contenedor-ods {
    max-width: 1400px;
  }
  
  #titulo-ods-configurable {
    font-size: 3.5rem;
    padding: 0 4rem;
  }
  
  .grid-ods-iconos {
    gap: 4rem;
    max-width: 900px;
  }
  
  .tarjeta-ods-icono {
    width: 180px;
    height: 180px;
  }
  
  .ods-icono {
    width: 120px;
    height: 120px;
  }
  
  .icono-posterior {
    padding: 2rem;
  }
  
  .numero-ods-back {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
  
  .contenido-ods-back h4 {
    font-size: 1.3rem;
    margin-bottom: 1.25rem;
  }
  
  .contenido-ods-back p {
    font-size: 0.9rem;
    line-height: 1.6;
    line-clamp: 7;
  }
}

/* Ajustes para pantallas ultra anchas (1440px+) */
@media (min-width: 1440px) {
  #seccion-ods {
    padding: 5rem 3rem;
  }
  
  .titulo-ods {
    margin-bottom: 5rem;
  }
  
  .grid-ods-iconos {
    gap: 5rem;
    max-width: 1000px;
  }
  
  .tarjeta-ods-icono {
    width: 200px;
    height: 200px;
  }
  
  .ods-icono {
    width: 140px;
    height: 140px;
  }
}

/* ==============================================
   ACCESIBILIDAD Y ESTADOS ESPECIALES
   ============================================== */

/* Focus visible para navegación por teclado */
.tarjeta-ods-icono:focus-within .icono-container {
  outline: 3px solid var(--color-primary-green);
  outline-offset: 4px;
  transform: rotateY(180deg);
}

/* Reducir movimiento si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce) {
  .icono-container {
    transition: none;
  }
  
  .tarjeta-ods-icono {
    animation: none;
    opacity: 1;
    transform: none;
  }
  
  .ods-icono {
    transition: none;
  }
  
  .tarjeta-ods-icono:hover .ods-icono {
    transform: none;
  }
}

/* Modo de alto contraste */
@media (prefers-contrast: high) {
  .icono-frontal {
    border-width: 3px;
    background: #ffffff;
  }
  
  .icono-posterior {
    background: var(--color-primary-dark-blue);
  }
  
  .ods-fallback {
    color: var(--color-primary-dark-blue);
    font-weight: 900;
  }
}

/* Estados para dispositivos táctiles */
@media (hover: none) and (pointer: coarse) {
  /* En dispositivos táctiles, mostrar el flip al tocar */
  .tarjeta-ods-icono:active .icono-container {
    transform: rotateY(180deg);
  }
  
  /* Mantener el estado por un momento después del toque */
  .tarjeta-ods-icono.touched .icono-container {
    transform: rotateY(180deg);
  }
}

/* Ajustes para pantallas muy pequeñas */
@media (max-width: 360px) {
  #seccion-ods {
    padding: 1.5rem 0.75rem;
  }
  
  #titulo-ods-configurable {
    font-size: 1.8rem;
    padding: 0 0.5rem;
  }
  
  .grid-ods-iconos {
    gap: 1rem;
    padding: 1rem 0.5rem;
  }
  
  .tarjeta-ods-icono {
    width: 100px;
    height: 100px;
  }
  
  .ods-icono {
    width: 70px;
    height: 70px;
  }
  
  .icono-posterior {
    padding: 0.75rem;
  }
  
  .numero-ods-back {
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
  }
  
  .contenido-ods-back h4 {
    font-size: 0.8rem;
    margin-bottom: 0.25rem;
  }
  
  .contenido-ods-back p {
    font-size: 0.6rem;
    line-height: 1.2;
    line-clamp: 3;
  }
}

/* ==============================================
   UTILIDADES ADICIONALES
   ============================================== */

/* Clase para forzar el estado flippeado (útil para JavaScript) */
.tarjeta-ods-icono.flipped .icono-container {
  transform: rotateY(180deg);
}

/* Clase para deshabilitar el efecto hover temporalmente */
.tarjeta-ods-icono.no-hover:hover .icono-container {
  transform: none;
}

/* Indicador de carga para cuando las imágenes están cargando */
.ods-icono.loading {
  opacity: 1;
}

@keyframes pulse {
  0%, 100% {
    opacity: 0.5;
  }
  50% {
    opacity: 0.8;
  }
}

  
  .tarjeta-valor[data-orden="1"] { animation-delay: 0s; }
  .tarjeta-valor[data-orden="2"] { animation-delay: 0.5s; }
  .tarjeta-valor[data-orden="3"] { animation-delay: 1s; }
  .tarjeta-valor[data-orden="4"] { animation-delay: 1.5s; }
  .tarjeta-valor[data-orden="5"] { animation-delay: 2s; }
  .tarjeta-valor[data-orden="6"] { animation-delay: 2.5s; }
  
  @media (hover: hover) {
    .tarjeta-valor:hover {
      transform: scale(1.1);
      animation-play-state: paused;
    }
  }
  
  /* ============================
     SECCIÓN COLLAGE VISIÓN Y VALORES
     ============================ */
  #collage-vision-valores {
    padding: calc(var(--spacing-unit) * 4) calc(var(--spacing-unit) * 2);
  }
  
  .collage-vv-contenedor {
    max-width: var(--container-max-width);
    margin: 0 auto;
    border-radius: 35px;
  }
  
  .collage-vv-grid {
    display: grid;
    grid-template-columns: repeat(2, 1.5fr);
    gap: calc(var(--spacing-unit) * 1.5);
  }
  
  .collage-vv-item {
    border-radius: 5px;
    padding: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-sizing: border-box;
  }
  
  .collage-vv-item[data-orden="0"],
  .collage-vv-item[data-orden="3"] {
    background: var(--color-primary-white);
    box-shadow: 0 6px 24px rgba(105, 198, 36, 0.3);
  }
  
  .collage-vv-item[data-orden="1"],
  .collage-vv-item[data-orden="2"] {
    background: var(--color-primary-white);
    box-shadow: 0 6px 24px rgba(105, 198, 36, 0.3);
    padding: 0.5rem;
  }
  
  .collage-vv-item img {
    width: 100%;
    height: 100%;
    display: block;
    border-radius: 25px;
    object-fit: cover;
    animation: pulso-infinito 3s ease-in-out;
  }
  
  /* ============================
     CLASES AUXILIARES Y ANIMACIONES
     ============================ */
  .fade-in-up {
    animation: fadeInUp 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
  }
  
  @keyframes fadeInUp {
    from {
      opacity: 0;
      transform: translateY(50px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  /* ============================
     MEDIA QUERIES
     ============================ */
  
/* --- Tablets y pantallas medianas (768px+) --- */
@media (min-width: 768px) {
  /*
    MEJORA: Se añade padding horizontal para que el contenido no
    esté pegado a los bordes en tablets.
  */
  #seccion-mision {
    padding: 0 2rem;
  }

  .contenedor-principal h1,
  .contenedor-principal h3 {
    text-align: center;
  }

  .contenedor-principal h1 {
    font-size: 2.5rem;
    line-height: 1.2;
    margin-bottom: 1.5rem;
  }

  .contenedor-principal h3 {
    font-size: 2rem;
  }

  .contenido-mision h3 {
    font-size: 2.5rem;
  }

  .descripcion-mision {
    font-size: 1rem;
    /* MEJORA: Se aumenta el interlineado para mejorar la legibilidad del párrafo. */
    line-height: 1.7; 
    text-align: left;
    margin-bottom: 0;
    padding: 0;
  }

  .collage-mision {
    height: 300px;
    margin-top: calc(var(--spacing-unit) * 3);
  }

  .imagen-collage {
    flex: 0 0 280px;
    height: 240px;
    margin-right: 20px;
    transform: translateY(50px);
    opacity: 0;
    transition: all 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    /* MEJORA: Se añade una sombra sutil y esquinas redondeadas para un
      look más moderno y profesional, reemplazando el borde grueso.
    */
    border-radius: 12px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    overflow: hidden; /* Necesario para que el borde redondeado recorte la imagen */
  }

  .imagen-collage.visible {
    transform: translateY(0);
    opacity: 1;
  }

/* Visión y Valores Layout */
    .vision-valores-layout {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-template-areas: "collage contenido";
      gap: 4rem;
      max-width: 1200px;
      margin: 0 auto;
      padding: 2rem;
    }
  
    #collage-vision-valores {
      grid-area: collage;
      margin: 0;
    }
  
    .contenido-derecha {
      grid-area: contenido;
      display: flex;
      flex-direction: column;
      gap: 1.5rem;
    }
  
    #seccion-vision,
    #seccion-valores {
      margin: 0;
      padding: 0;
    }
    
    .contenedor-vision,
    .contenedor-valores {
      padding-top: 0;
      margin-top: 0;
    }
  
    .contenido-vision {
      text-align: left;
      padding-top: 0;
      margin-top: 0;
    }
    
    .contenido-vision h3,
    .contenedor-valores h3 {
      color: var(--color-primary-green);
      font-size: 2rem;
      font-weight: 700;
      text-align: left;
      margin: 0 0 2rem 0;
      padding-top: 2.5rem;
    }

    .descripcion-vision {
      font-size: 1rem;
      line-height: 1.4;
      text-align: left;
      margin-bottom: 0;
    }
    
    .collage-vv-contenedor {
        /* CAMBIO: Se remueve height: 100% para que se adapte al contenido */
        height: auto;
    }
    
    .collage-vv-grid {
        /* CAMBIO: Se remueve height: 100% para que se adapte al contenido */
        height: 100%;
    }
  
    /* Grid de imágenes: 1 columna para pantallas medianas (768px - 1150px) */
    .collage-vv-grid {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: repeat(4, 1fr);
        gap: 1rem;
    }
  
    .collage-vv-item {
        border-radius: 8px;
        overflow: hidden;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        /* AGREGADO: Altura fija para cada item para mantener consistencia */
        height: 120px;
    }

    .collage-vv-item img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.3s ease;
    }
  
    .collage-vv-item:hover img {
        transform: scale(1.05);
    }
  
    /* Grid de Valores */
    .grid-valores {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-template-rows: repeat(3, auto);
      gap: 0.6rem;
      margin-top: 0.5rem;
    }
    
    .tarjeta-valor[data-orden="1"] { grid-area: 1 / 2 / 2 / 3; text-align: center; }
    .tarjeta-valor[data-orden="2"] { grid-area: 2 / 1 / 3 / 2; text-align: left; }
    .tarjeta-valor[data-orden="3"] { grid-area: 2 / 2 / 3 / 3; text-align: right; }
    .tarjeta-valor[data-orden="4"] { grid-area: 3 / 2 / 4 / 3; text-align: center; }
    .tarjeta-valor[data-orden="5"] { grid-area: 3 / 1 / 4 / 2; text-align: left; }
    .tarjeta-valor[data-orden="6"] { grid-area: 4 / 2 / 5 / 3; text-align: right; }
  
    .tarjeta-valor h4 {
        font-size: 0.95rem;
        font-weight: 500;
        padding: 0.3rem 0;
        margin: 0;
        line-height: 1.2;
    }
}


  
  /* --- Pantallas grandes (1024px+) --- */
  @media (min-width: 1024px) {
   #seccion-mision {
    padding: 0 3rem;
  }

  .contenedor-principal h1,
  .contenedor-principal h3 {
    text-align: left;
  }

  .contenedor-mision {
    max-width: 1400px;
    display: grid;
    grid-template-columns: 1fr 450px;
    gap: 5rem;
    align-items: start;
    margin: 2rem auto;
  }

  .descripcion-mision {
    font-size: 1.25rem;
    /* MEJORA: Se mantiene el interlineado mejorado. */
    line-height: 1.7; 
    text-align: left;
    margin-bottom: 0;
  }


    .columna-contenido {
      grid-column: 1;
      grid-row: 1;
      display: flex;
      flex-direction: column;
    }
  
    .contenedor-principal {
      margin-bottom: 0;
      text-align: left;
    }
  
    .contenido-mision {
      margin-bottom: 0;
      padding-right: 0;
    }
    
  .contenido-mision h3 {
    font-size: 3rem;
    margin-bottom: 2rem;
    text-align: left;
    /* MEJORA: Se añade consistencia de estilo. El título "Misión"
      ahora usa el color primario, igual que "Visión" y "Valores".
    */
    color: var(--color-primary-green);
  }
    .collage-mision {
      grid-column: 2;
      grid-row: 1;
      height: auto;
      position: relative;
      border-radius: 16px;
      padding: 2rem;
      margin-top: 0;
    }
  
    .contenedor-principal h1 { font-size: 3.5rem; margin-bottom: 2rem; line-height: 1.2; }
    .contenedor-principal h2 { font-size: 3rem; margin-bottom: 2.5rem; text-align: left; }
    .contenedor-principal p { font-size: 1.1rem; text-align: left; }
    .contenido-mision h3 { font-size: 3rem; margin-bottom: 2rem; text-align: left; }
    .descripcion-mision { font-size: 1.25rem; }
  
    .collage-mision::before,
    .collage-mision::after {
      display: none;
    }
  
    .grid-imagenes {
      display: grid;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      animation: none;
    }
  
    .imagen-collage {
      flex: none;
      width: 100%;
      height: 180px;
      margin-right: 0;
    }
    
    .imagen-collage.visible {
        transform: translateY(0);
        opacity: 1;
    }
  
    /* Alineación alternada para collage en desktop */
    .imagen-collage:nth-child(1) { margin-left: -1rem; margin-right: 3rem; transition-delay: 0.1s; }
    .imagen-collage:nth-child(2) { margin-left: 1rem; margin-right: 1rem; transition-delay: 0.2s; }
    .imagen-collage:nth-child(3) { margin-left: -0.5rem; margin-right: 2.5rem; transition-delay: 0.3s; }
    .imagen-collage:nth-child(4) { margin-left: 2rem; margin-right: 0; transition-delay: 0.4s; }
    .imagen-collage:nth-child(5) { margin-left: -1rem; margin-right: 3rem; transition-delay: 0.5s; }
  
    /* Visión y Valores */
    .vision-valores-layout {
      gap: 4rem;
      padding: 3rem;
      /* AGREGADO: Alinear elementos al inicio para evitar estiramiento */
      align-items: start;
    }
    
    /* CAMBIO PRINCIPAL: Mantener la misma estructura de grid que en 768px */
    .collage-vv-contenedor {
        height: auto; /* Mantener altura automática */
    }
    
    .collage-vv-grid {
        height: auto; /* Mantener altura automática */
        /* Mantener la misma configuración de grid que en 768px */
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: repeat(4, auto); /* Cambio: auto en lugar de 1fr */
        gap: 1.5rem; /* Aumentar gap para pantallas más grandes */
    }
    
    .collage-vv-item {
        /* CAMBIO: Aumentar la altura para pantallas más grandes pero mantener proporción */
        height: 140px;
    }
  
    .contenido-vision h3 { font-size: 3rem; }
    .descripcion-vision { font-size: 1.2rem; }
    .contenedor-valores h3 { font-size: 2.2rem; }
    .tarjeta-valor h4 { font-size: 1.2rem; }
  }


  /* Media query específica para pantallas grandes (1150px+) donde vuelve a 2 columnas */
@media (min-width: 1150px) {
    .collage-vv-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(2, auto); /* Cambio: auto en lugar de 1fr */
    }
    
    .collage-vv-item {
        /* Altura ajustada para 2 columnas */
        height: 160px;
    }
}
  
/* --- Pantallas extra grandes (1200px+) --- */
  @media (min-width: 1200px) {
      .vision-valores-layout {
          max-width: 1400px;
          gap: 4rem;
      }
      .collage-vv-item {
        /* CAMBIO: Aumentar la altura para pantallas más grandes pero mantener proporción */
        height: auto;
    }
      /* Restaurar comportamiento de altura completa para pantallas grandes */
      .collage-vv-contenedor,
      .collage-vv-grid {
          height: 100%;
      }
  
      .contenido-vision h3,
      .contenedor-valores h3 {
          font-size: 3.2rem;
      }
  
      .descripcion-vision {
          font-size: 1.25rem;
          line-height: 1.7;
      }
  
      .tarjeta-valor h4 {
          font-size: 1.1rem;
      }
  }
   /* --- Pantallas extra grandes (1440px+) --- */
  @media (min-width: 1440px) {
#seccion-mision {
    padding: calc(var(--spacing-unit) * 12) 4rem;
  }
  
  
    .contenedor-mision {
      max-width: 1600px;
      grid-template-columns: 1fr 500px;
      gap: 6rem;
    }
  
    .contenedor-principal h1 { font-size: 4rem; }
    .contenedor-principal h2 { font-size: 3.5rem; }
    .contenedor-principal p { font-size: 1.2rem; }
    .contenido-mision h3 { font-size: 3.5rem; }
    .descripcion-mision { font-size: 1.25rem; }
  
    .collage-mision { padding: 2.5rem; }
    .grid-imagenes { gap: 2rem; }
    .imagen-collage { height: 200px; }
  
    .imagen-collage:nth-child(1),
    .imagen-collage:nth-child(5) { margin-left: -1.5rem; margin-right: 4rem; }
    .imagen-collage:nth-child(3) { margin-left: -1rem; margin-right: 3rem; }
  }
  /* ============================
     MEJORAS DE ACCESIBILIDAD Y SOPORTE
     ============================ */
  
  /* Reducir movimiento */
  @media (prefers-reduced-motion: reduce) {
    .grid-imagenes {
      animation: none;
    }
  
    .imagen-collage,
    .imagen-collage img {
      transition: none;
    }
  
    .imagen-collage {
      transform: none !important;
      opacity: 1 !important;
    }
  }
  
  /* Pantallas de alta densidad */
  @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
    .imagen-collage {
      box-shadow: 0 4px 12px rgba(51, 51, 51, 0.15);
    }
  }


  
  
  /* --- Estilos para la Sección de Equipo (Móvil) --- */

/* Contenedor principal de la sección */
#seccion-equipo {
  padding: 4rem 0; /* Espaciado superior e inferior */
  background-color: #ffffff; /* O el color de fondo que necesites */
}

/* Título principal "Nuestro Equipo" */
#seccion-equipo h3 {
  font-size: 2.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-dark-blue);
  text-align: center;
  margin-bottom: 2rem; /* Espacio antes de las tarjetas */
}

/* Contenedor del carrusel (grid-equipo)
- Usamos Flexbox para crear una fila horizontal.
- overflow-x: auto permite el deslizamiento horizontal.
- scroll-snap-type hace que el scroll se "enganche" a cada tarjeta.
*/
.grid-equipo {
  display: flex;
  overflow-x: auto;
  gap: 1.5rem; /* Espacio entre las tarjetas */
  padding: 1rem 1.5rem 2rem 1.5rem; /* Espaciado interno para que las tarjetas no se peguen a los bordes */
  scroll-snap-type: x mandatory;
  /* Ocultar la barra de scroll para un diseño más limpio */
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none;  /* Internet Explorer 10+ */
}

.grid-equipo::-webkit-scrollbar { 
  display: none;  /* Safari and Chrome */
}

/* Tarjeta individual de cada miembro
- flex: 0 0 85% define que cada tarjeta ocupará el 85% del ancho del contenedor.
- scroll-snap-align centra la tarjeta cuando el usuario desliza.
*/
.tarjeta-miembro {
  flex: 0 0 85%; /* No crecer, no encoger, base del 85% del ancho */
  scroll-snap-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background-color: #f9fafb; /* Un gris muy claro como en el mock-up */
  padding: 2.5rem 1.5rem;
  border-radius: 16px; /* Bordes redondeados */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); /* Sombra sutil */
}

/* Contenedor de la imagen para asegurar la forma */
.imagen-miembro {
  margin-bottom: 1.5rem;
}

/* Imagen del miembro del equipo */
.imagen-miembro img {
  width: 120px;
  height: 120px;
  border-radius: 50%; /* Hace la imagen perfectamente redonda */
  object-fit: cover; /* Asegura que la imagen cubra el espacio sin deformarse */
}

/* Nombre del miembro */
.info-miembro h4 {
  font-size: 1.5rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-dark-blue); /* Un color oscuro para el nombre */
  margin: 0 0 0.25rem 0; /* Ajuste de margen inferior */
}

/* Puesto del miembro (Ej. "Profesora") */
.info-miembro .puesto {
  color: var(--color-primary-green);
  font-size: 1.1rem;
  font-weight: 600; /* Un poco más de grosor */
  margin-bottom: 1rem;
}

/* Frase destacada del miembro */
.info-miembro .frase {
  font-size: 1rem;
  color: var(--color-secondary-gray); /* Un gris intermedio para la frase */
  font-style: italic;
  line-height: 1.5;
}


/* ==============================================
   ESTILOS MOBILE - SECCIÓN ODS
   ============================================== */

/* Sección principal ODS */
#seccion-ods {
  padding: 2rem 1rem;
  background-color: var(--color-primary-white);
}

.contenedor-ods {
  max-width: 100%;
  margin: 0 auto;
}

/* Título de la sección */
.titulo-ods {
  text-align: center;
  margin-bottom: 2rem;
}

#titulo-ods-configurable {
  font-size: 2.2rem;
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  color:var(--color-primary-dark-blue);
  margin: 0;
  padding: 0 1rem;
}

#titulo-ods-configurable .destacado {
  color: var(--color-primary-green);
}

/* Grid de tarjetas ODS */
.grid-ods {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* Tarjetas ODS */
.tarjeta-ods {
  background: #ffffff;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  border: 1px solid #e9ecef;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.tarjeta-ods:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

/* Número ODS */
.numero-ods {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-primary-green);
  margin-bottom: 0.5rem;
  line-height: 1;
}

/* Contenido de la tarjeta */
.contenido-ods h4 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-dark-blue);
  margin: 0 0 0.75rem 0;
  line-height: 1.3;
}

.contenido-ods p {
  font-size: 0.9rem;
  color: var(--color-primary-black);
  line-height: 1.5;
  margin: 0;
}

/* Estilos específicos para números de ODS destacados */
.tarjeta-ods[data-numero="4"] {
  background: linear-gradient(135deg, #e8f5e8 0%, #ffffff 100%);
  border-left: 4px solid var(--color-primary-green);
}

.tarjeta-ods[data-numero="5"] {
  background: var(--color-primary-white);
}

.tarjeta-ods[data-numero="17"] {
  background: linear-gradient(135deg, #e8f5e8 0%, #ffffff 100%);
  border-left: 4px solid var(--color-primary-green);
}

/* Animación de entrada */
.tarjeta-ods {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 0.6s ease forwards;
}

.tarjeta-ods:nth-child(1) { animation-delay: 0.1s; }
.tarjeta-ods:nth-child(2) { animation-delay: 0.2s; }
.tarjeta-ods:nth-child(3) { animation-delay: 0.3s; }
.tarjeta-ods:nth-child(4) { animation-delay: 0.4s; }
.tarjeta-ods:nth-child(5) { animation-delay: 0.5s; }

@keyframes fadeInUp {
  to {
      opacity: 1;
      transform: translateY(0);
  }
}

/* Efecto hover para dispositivos que lo soporten */
@media (hover: hover) {
  .tarjeta-ods:hover .numero-ods {
      color: var(--color-primary-green);
      transform: scale(1.05);
  }
  
  .tarjeta-ods:hover .contenido-ods h4 {
      color: var(--color-primary-dark-blue);
  }
}

/* Ajustes para pantallas muy pequeñas */
@media (max-width: 360px) {
  #seccion-ods {
      padding: 1.5rem 0.75rem;
  }
  
  #titulo-ods-configurable {
      font-size: 1.25rem;
      padding: 0 0.5rem;
  }
  
  .tarjeta-ods {
      padding: 1.25rem;
  }
  
  .numero-ods {
      font-size: 2rem;
  }
  
  .contenido-ods h4 {
      font-size: 1.1rem;
  }
  
  .contenido-ods p {
      font-size: 0.85rem;
  }
}

/* ==============================================
 MEDIA QUERIES - PANTALLAS MEDIANAS Y GRANDES
 ============================================== */

/* Tablets - Pantallas medianas (768px+) */
@media (min-width: 768px) {
  #seccion-ods {
      padding: 3rem 2rem;
  }
  
  .contenedor-ods {
      max-width: 1200px;
  }
  
  /* Título ajustado para tablets */
  #titulo-ods-configurable {
      font-size: 2rem;
      margin-bottom: 1rem;
      padding: 0 2rem;
  }
  
  .titulo-ods {
      margin-bottom: 3rem;
  }
  
  /* Grid de 2 columnas para tablets */
  .grid-ods {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
  }
  
  /* Tarjetas más amplias */
  .tarjeta-ods {
      padding: 2rem;
  }
  
  .numero-ods {
      font-size: 3rem;
      margin-bottom: 1rem;
  }
  
  .contenido-ods h4 {
      font-size: 1.4rem;
      margin-bottom: 1rem;
  }
  
  .contenido-ods p {
      font-size: 1rem;
      line-height: 1.6;
  }
}

/* Desktop - Pantallas grandes (1024px+) */
@media (min-width: 1024px) {
  #seccion-ods {
      padding: 4rem 2rem;
  }
  
  /* Título más grande para desktop */
  #titulo-ods-configurable {
      font-size: 2.5rem;
      line-height: 1.3;
      padding: 0 3rem;
  }
  
  .titulo-ods {
      margin-bottom: 4rem;
  }
  
  /* Grid de 3 columnas para desktop */
  .grid-ods {
      grid-template-columns: repeat(3, 1fr);
      gap: 2.5rem;
      max-width: 1200px;
      margin: 0 auto;
  }
  
  /* Tarjetas más espaciosas */
  .tarjeta-ods {
      padding: 2.5rem;
      min-height: 280px;
      display: flex;
      flex-direction: column;
  }
  
  .numero-ods {
      font-size: 3.5rem;
      margin-bottom: 1.5rem;
  }
  
  .contenido-ods {
      flex-grow: 1;
      display: flex;
      flex-direction: column;
  }
  
  .contenido-ods h4 {
      font-size: 1.5rem;
      margin-bottom: 1.25rem;
      line-height: 1.25;
  }
  
  .contenido-ods p {
      font-size: 1.1rem;
      line-height: 1.7;
      flex-grow: 1;
  }
  
  /* Efectos hover mejorados para desktop */
  .tarjeta-ods:hover {
      transform: translateY(-4px);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  }
  
  .tarjeta-ods:hover .numero-ods {
      transform: scale(1.1);
  }
}

/* Desktop grande - Pantallas extra grandes (1200px+) */
@media (min-width: 1200px) {
  .contenedor-ods {
      max-width: 1400px;
  }
  
  #titulo-ods-configurable {
      font-size: 3rem;
      padding: 0 4rem;
  }
  
  .grid-ods {
      gap: 3rem;
      max-width: 1300px;
  }
  
  .tarjeta-ods {
      padding: 3rem;
      min-height: 320px;
  }
  
  .numero-ods {
      font-size: 4rem;
      margin-bottom: 2rem;
  }
  
  .contenido-ods h4 {
      font-size: 1.75rem;
      margin-bottom: 1.5rem;
  }
  
  .contenido-ods p {
      font-size: 1.2rem;
      line-height: 1.8;
  }
}

/* Ajustes para pantallas ultra anchas (1440px+) */
@media (min-width: 1440px) {
  #seccion-ods {
      padding: 5rem 3rem;
  }
  
  .contenedor-ods {
      max-width: 1600px;
  }
  
  #titulo-ods-configurable {
      font-size: 3.5rem;
      padding: 0 5rem;
  }
  
  .titulo-ods {
      margin-bottom: 5rem;
  }
  
  .grid-ods {
      gap: 3.5rem;
      max-width: 1500px;
  }
}


/* ==============================================
   CAROUSEL STYLES - MOBILE FIRST APPROACH
   ============================================== */

/* Contenedor principal del carrusel */
.contenedor-equipo {
    position: relative;
    padding: 0 1rem; /* Padding mobile para dar espacio a las flechas */
    overflow: hidden; /* Previene scroll horizontal no deseado */
}

/* Grid del equipo */
.grid-equipo {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc(100% - 2rem); /* Mobile: casi todo el ancho menos padding */
    gap: 1rem;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    padding: 1rem 0;
    
    /* Ocultar scrollbar pero mantener funcionalidad */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
}

.grid-equipo::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}

/* Tarjetas individuales */
.tarjeta-miembro {
    scroll-snap-align: center;
    flex-shrink: 0;
}

/* ==============================================
   INDICADORES DE PAGINACIÓN
   ============================================== */

.carousel-indicators {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1.5rem;
    padding: 0 1rem;
}

.carousel-indicator {
    width: 24px; /* Más pequeño en mobile */
    height: 3px;
    border-radius: 2px;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    padding: 0;
    background-color: rgba(105, 198, 36, 0.3);
}

.carousel-indicator.active {
    background-color: var(--color-primary-green);
    width: 32px; /* Indicador activo más largo */
}

.carousel-indicator:hover {
    background-color: var(--color-primary-green);
    opacity: 0.8;
}

/* ==============================================
   BOTONES DE NAVEGACIÓN (FLECHAS)
   ============================================== */

.carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    
    /* Estilos mobile-first */
    background-color: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(0, 0, 0, 0.1);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    
    display: flex;
    align-items: center;
    justify-content: center;
    
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transition: all 0.3s ease;
}

/* Solo mostrar flecha derecha en mobile */
.carousel-nav.prev {
    display: none;
}

.carousel-nav.next {
    right: 0.5rem; /* Posicionado dentro del padding del contenedor */
}

/* Efecto hover/focus */
.carousel-nav:hover, 
.carousel-nav:focus {
    background-color: var(--color-primary-green);
    color: white;
    transform: translateY(-50%) scale(1.05);
    box-shadow: 0 4px 12px rgba(105, 198, 36, 0.3);
    outline: none;
}

.carousel-nav:active {
    transform: translateY(-50%) scale(0.95);
}

/* Icono SVG */
.carousel-nav svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    transition: fill 0.3s ease;
}

/* ==============================================
   TABLET STYLES (768px y más)
   ============================================== */

@media (min-width: 768px) {
    .contenedor-equipo {
        padding: 0 3rem; /* Más padding para las flechas más grandes */
    }
    
    .grid-equipo {
        grid-auto-columns: calc(50% - 0.5rem); /* Tablet: 2 columnas */
        gap: 1rem;
    }
    
    .carousel-indicators {
        margin-top: 2rem;
    }
    
    .carousel-indicator {
        width: 28px;
        height: 4px;
    }
    
    .carousel-indicator.active {
        width: 36px;
    }
    
    /* Mostrar ambas flechas en tablet */
    .carousel-nav {
        width: 44px;
        height: 44px;
    }
    
    .carousel-nav.prev {
        display: flex;
        left: 0.5rem;
    }
    
    .carousel-nav.next {
        right: 0.5rem;
    }
    
    .carousel-nav svg {
        width: 20px;
        height: 20px;
    }
}

/* ==============================================
   DESKTOP STYLES (1024px y más)
   ============================================== */

@media (min-width: 1024px) {
    .contenedor-equipo {
        padding: 0 4rem; /* Aún más padding para desktop */
    }
    
    .grid-equipo {
        grid-auto-columns: calc(25% - 0.75rem); /* Desktop: 4 columnas */
        gap: 1rem;
    }
    
    .carousel-nav {
        width: 48px;
        height: 48px;
    }
    
    .carousel-nav.prev {
        left: 1rem;
    }
    
    .carousel-nav.next {
        right: 1rem;
    }
    
    .carousel-nav svg {
        width: 24px;
        height: 24px;
    }
    
    /* Efecto hover más pronunciado en desktop */
    .carousel-nav:hover {
        transform: translateY(-50%) scale(1.1);
        box-shadow: 0 6px 16px rgba(105, 198, 36, 0.4);
    }
}

/* ==============================================
   ACCESIBILIDAD Y ESTADOS ESPECIALES
   ============================================== */

/* Focus visible para navegación por teclado */
.carousel-nav:focus-visible {
    outline: 2px solid var(--color-primary-green);
    outline-offset: 2px;
}

/* Reducir movimiento si el usuario lo prefiere */
@media (prefers-reduced-motion: reduce) {
    .grid-equipo {
        scroll-behavior: auto;
    }
    
    .carousel-nav,
    .carousel-indicator {
        transition: none;
    }
}

/* Estados de carga o cuando no hay JavaScript */
.no-js .carousel-nav {
    display: none;
}

.no-js .carousel-indicators {
    display: none;
}

/* ==============================================
   UTILIDADES ADICIONALES
   ============================================== */

/* Clase para ocultar elementos temporalmente durante transiciones */
.carousel-transitioning .carousel-nav {
    pointer-events: none;
    opacity: 0.5;
}

/* Estilo para cuando el carrusel está en pausa (hover en desktop) */
.carousel-paused .carousel-nav {
    background-color: var(--color-primary-green);
    color: white;
}

/* Responsive breakpoint específico para pantallas muy pequeñas */
@media (max-width: 320px) {
    .contenedor-equipo {
        padding: 0 0.5rem;
    }
    
    .carousel-nav {
        width: 32px;
        height: 32px;
    }
    
    .carousel-nav svg {
        width: 16px;
        height: 16px;
    }
    
    .carousel-nav.next {
        right: 0.25rem;
    }
}