/* =============================================================================
   public/css/Certificaciones.css
   ============================================================================= */

/* 1) RESET BÁSICO & BOX‐SIZING */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* 2) VARIABLES GLOBALES PARA ESTE COMPONENTE */
.certificaciones {
  --cert-margin-top: 5rem;
  --cert-max-width: 1200px;
  --cert-color-azul-oscuro: #0d315e;
  --cert-color-gris-claro: #f2f2f2;
  --cert-color-blanco: #ffffff;
  --cert-color-gris-media: #e5e5e5;
  --cert-color-azul-secundario: #4a8bd4;
  --cert-color-azul-tercerario: #0d315e;
  --cert-color-azul-cuarto: #0077c2;
  --cert-color-azul-quinto: hwb(0 100% 0% / 0.075);
  --cert-color-azul-secundario-hover: #0077c2;
  --cert-fuente-principal: Arial, sans-serif;
  width: 100%;
  max-width: var(--cert-max-width);
  margin: var(--cert-margin-top) auto 0;
  padding: 0 1rem;
}

/* ====================================================================
   3) BLOQUE SUPERIOR: Texto + Logos
   ==================================================================== */
.certificaciones__top {
  background-color: var(--cert-color-azul-oscuro);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 2.5rem 1rem;
  width: 100%;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.certificaciones__texto {
  flex: 1 1 100%;
  max-width: 100%;
  color: var(--cert-color-blanco);
  font-family: var(--cert-fuente-principal);
}

/* En desktop, el texto ocupa hasta 50% */
@media (min-width: 992px) {
  .certificaciones__texto {
    flex: 1 1 50%;
    max-width: 50%;
    padding-right: 1rem;
  }
}

.certificaciones__titulo {
  font-size: 2rem; /* ~32px */
  font-weight: bold;
  margin-bottom: 1rem;
  line-height: 1.2;
}

.certificaciones__descripcion {
  font-size: 0.95rem;
  line-height: 1.6;
  text-align: justify;
  text-justify: inter-word;
}

/* Logos de certificación */
.certificaciones__logos {
  flex: 1 1 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* En desktop, los logos ocupan hasta 40% */
@media (min-width: 992px) {
  .certificaciones__logos {
    flex: 1 1 40%;
    max-width: 40%;
  }
}

.certificaciones__logos-lista {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
  justify-content: center;
}

.certificaciones__logo-item {
  flex: 0 0 auto;
}

/* Tamaño de la imagen frontal */
.certificaciones__logo-img {
  width: 100%;
  max-width: 200px; /* no excede 200px en pantallas grandes */
  height: auto;     /* mantiene proporción */
  display: block;
}

/* -------------------------------------------------
   FLIP LOGOS: FRONT y BACK de cada logo de certificación
   ------------------------------------------------- */

/* Contenedor 3D que envuelve front y back */
.certificaciones__logo-flip-container {
  position: relative;
  width: 200px;      /* igual a max-width de .certificaciones__logo-img */
  height: 200px;     /* igual para mantener proporción cuadrada */
  perspective: 1000px;
  margin: 0 auto;    /* centrar dentro del <li> */
}

/* Lados front y back ocupan todo el contenedor */
.certificaciones__logo-front,
.certificaciones__logo-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  overflow: hidden;
  transition: transform 0.6s ease, border-color 0.3s ease;
}

/* Lado frontal: la imagen, mantiene forma circular */
/*  Ahora con borde inicialmente transparente */
.certificaciones__logo-front {
  z-index: 2;
  transform: rotateY(0deg);
  border-radius: 50%;
  border: 5px solid transparent;
}

.certificaciones__logo-front .certificaciones__logo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
}

/* Lado posterior: será cuadrado */
.certificaciones__logo-back {
  background-color: var(--cert-color-azul-cuarto);
  color: var(--cert-color-blanco);
  transform: rotateY(180deg);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
  height: 230px;
}

/* Overlay semitransparente: cuadrado */
.certificaciones__logo-back-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--cert-color-azul-oscuro);
  opacity: 0.5;
  border-radius: 20px;
  z-index: 1;
}

/* Texto en la cara trasera */
.certificaciones__logo-back-text {
  position: relative;
  z-index: 2;
  padding: 1rem;
  text-align: center;
  font-family: var(--cert-fuente-principal);
}

.certificaciones__logo-back-text h4 {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
}

.certificaciones__logo-back-text p {
  font-size: 0.9rem;
  line-height: 1.4;
}

/* Al hacer hover, gira el front y back
   y al mismo tiempo el borde se vuelve blanco */
.certificaciones__logo-flip-container:hover .certificaciones__logo-front {
  transform: rotateY(-180deg);
  border-color: var(--cert-color-blanco);
}
.certificaciones__logo-flip-container:hover .certificaciones__logo-back {
  transform: rotateY(0deg);
}

/* En móvil/táctil, activar con focus-within */
.certificaciones__logo-flip-container:focus-within .certificaciones__logo-front {
  transform: rotateY(-180deg);
  border-color: var(--cert-color-blanco);
}
.certificaciones__logo-flip-container:focus-within .certificaciones__logo-back {
  transform: rotateY(0deg);
}

/* --- RESPONSIVE: apilar vertical en < 992px --- */
@media (max-width: 992px) {
  .certificaciones__top {
    flex-direction: column;
    padding: 2rem 1rem;
  }
  .certificaciones__texto {
    margin-bottom: 1.5rem;
    padding-right: 0;
  }
  .certificaciones__logos {
    margin-bottom: 1rem;
  }
}

/* ====================================================================
   4) BARRA DE ESTADÍSTICAS
   ==================================================================== */
.certificaciones__stats {
  background-color: var(--cert-color-gris-media);
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  padding: 1.5rem 1rem;
  gap: 1rem;
  border-radius: 50px;
  flex-wrap: wrap; /* permitir que los items bajen en pantallas estrechas */
}

.certificaciones__stat-item {
  flex: 1 1 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1rem;
}

/* En pantallas medias y grandes, tres columnas iguales */
@media (min-width: 768px) {
  .certificaciones__stat-item {
    flex: 1 1 calc(33.333% - 1rem);
    max-width: calc(33.333% - 1rem);
    margin-bottom: 0;
  }
}

.certificaciones__stat-numero {
  font-family: var(--cert-fuente-principal);
  font-size: 4rem;
  font-weight: bold;
  color: var(--cert-color-azul-oscuro);
}

.certificaciones__stat-label {
  font-family: 'Ghino', sans-serif;
  font-size: 0.95rem;
  color: var(--cert-color-azul-oscuro);
  margin-top: 0.25rem;
}

/* RESPONSIVE: apilar vertical en < 768px */
@media (max-width: 768px) {
  .certificaciones__stats {
    flex-direction: column;
    gap: 1rem;
  }
  .certificaciones__stat-item {
    margin-bottom: 1rem;
  }
}

/* ====================================================================
   5) BLOQUE PRODUCTOS ESPECIALES (Tarjetas circulares)
   ==================================================================== */
.certificaciones__productos {
  background-color: var(--cert-color-azul-oscuro);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2rem;
  padding: 2.5rem 1rem 3rem; /* espacio extra debajo para respirar */
  width: 100%;
}

.certificaciones__producto-card {
  flex: 1 1 calc(33.333% - 2rem);
  max-width: calc(33.333% - 2rem);
  display: flex;
  flex-direction: column;
  align-items: center;
  color: var(--cert-color-blanco);
  text-align: center;
}

/* Dos columnas en < 992px */
@media (max-width: 992px) {
  .certificaciones__producto-card {
    flex: 1 1 calc(50% - 2rem);
    max-width: calc(50% - 2rem);
  }
}

/* Una columna en < 576px */
@media (max-width: 576px) {
  .certificaciones__producto-card {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

/* 1) Estado inicial: borde blanco al 50% de opacidad */
.certificaciones__producto-circle {
  width: 250px;                     /* o el tamaño que uses */
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: var(--cert-color-azul-quinto);
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  margin-bottom: 1rem;

  /* <-- borde semitransparente -->
     rgba(255,255,255,0.5) == blanco al 50% de opacity */
  border: 5px solid rgba(255, 255, 255, 0.5);
  transition: border-color 0.3s ease;
}

/* 2) Estado inicial: la imagen ocupa todo el círculo (sin transform) */
.certificaciones__producto-img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  /* Quita cualquier transform que hiciera scale en hover */
}

/* 3) Al pasar el cursor: el borde se vuelve blanco puro */
.certificaciones__producto-card:hover .certificaciones__producto-circle {
  border-color: #ffffff;
}

/* (Opcional) Para accesibilidad por teclado */
.certificaciones__producto-card:focus-within .certificaciones__producto-circle {
  border-color: #ffffff86;
}


.certificaciones__producto-titulo {
  font-family: var(--cert-fuente-principal);
  font-size: 1.125rem; /* ~18px */
  font-weight: bold;
  margin-bottom: 0.75rem;
}

.certificaciones__producto-boton {
  display: inline-block;
  background-color: var(--cert-color-azul-secundario);
  color: var(--cert-color-blanco);
  font-family: var(--cert-fuente-principal);
  font-size: 0.95rem;
  font-weight: bold;
  text-decoration: none;
  padding: 0.6rem 1.25rem;
  border-radius: 6px;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.certificaciones__producto-boton:hover,
.certificaciones__producto-boton:focus {
  background-color: var(--cert-color-azul-secundario-hover);
  transform: translateY(-2px);
}

@media (max-width: 1024px) and (min-width: 768px){
  .certificaciones__logo-flip-container {
    position: relative;
    width: 170px;
    height: 170px;
    perspective: 1000px;
    margin: 0 auto;
    }
    .menu__social-icons a svg{
      width: 15px;
    height: 15px;
    fill: #fff;
    }
}
/* ——— Responsive 600px–800px ——— */
@media screen and (min-width: 600px) and (max-width: 800px) {
  /* 4) ESTADÍSTICAS: columna única */
  .certificaciones__stats {
    flex-direction: column;
    gap: 1rem;
  }
  .certificaciones__stat-item {
    flex: 1 1 100%;
    max-width: 100%;
  }

  /* 5) PRODUCTOS: apilar y centrar tarjetas */
  .certificaciones__productos {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    padding: 2rem 1rem 3rem;
  }
  .certificaciones__producto-card {
    flex: 1 1 100%;
    max-width: 240px;
  }
  .certificaciones__producto-circle {
    width: 200px;
    height: 200px;
  }
  .certificaciones__producto-img {
    max-width: 100%;
    max-height: 100%;
  }
  .certificaciones__producto-titulo {
    font-size: 1.125rem;
  }
  .certificaciones__producto-boton {
    padding: 0.5rem 1rem;
  }

}

