/* Contenedor principal */
.hero-static-section {
    position: relative;
    width: 100%;
    overflow: hidden;
}

/* Imagen hero */
.hero-static-img {
    width: 100%;
    height: auto; /* respeta proporción de la imagen */
    display: block;
}

/* Contenedor del contenido */
.hero-item-content {
    position: relative;
}

/* Texto centrado */
.hero-static-caption {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    text-align: center;
    max-width: 900px;
    width: 90%;
    color: white;
}

/* Título */
.hero-static-caption h2 {
    font-size: 3.5rem;
    font-weight: 800;
    margin-bottom: 1rem;
}

/* Bajada */
.hero-static-text {
    font-size: 1.5rem;
    color: #EC1C23;
}

/* --- Responsive --- */
@media (max-width: 1024px) {
    .hero-static-caption h2 { font-size: 2.5rem; }
    .hero-static-text { font-size: 1.2rem; }
    .hero-item-content {
    margin-top:77px;
   }
}

@media (max-width: 768px) {
    .hero-static-caption h2 { font-size: 1.8rem; }
    .hero-static-text { font-size: 1rem; }
    .hero-item-content {
    margin-top:77px;
   }
}

@media (max-width: 480px) {
    .hero-static-caption h2 { font-size: 2.3rem; }
    .hero-static-text { font-size: 1.5rem; }
     .hero-item-content {
    margin-top:77px;
   }
}



.nosotros-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  width: 100%;
  min-height: 100vh;
}

.box {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 40px;
  overflow: hidden;
  position: relative;
 opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s ease-out;
}
.box.show {
  opacity: 1;
  transform: translateY(0);
}

/* Delay escalonado para que no aparezcan todas al mismo tiempo */
.box:nth-child(1) { transition-delay: 0.1s; }
.box:nth-child(2) { transition-delay: 0.3s; }
.box:nth-child(3) { transition-delay: 0.5s; }
.box:nth-child(4) { transition-delay: 0.7s; }
.box h2 {
  font-size: 3rem;
  font-weight: 700;
  margin: 0;
}

.box h2 span {
  color: #EC1C23;
  font-weight: 800;
}

.box p {
  max-width: 500px;
  color: white;
  font-size: 1.2rem;
  line-height: 1.5;
}

/* Fondos */
.box-white { background: #ffffff; color: #000; }
.box-red { background: #EC1C23; color: white; }
.box-darkgray { background: #555555; color: white; }
.box-black { background: #1A1A1A; color: white; }

/* Iconos decorativos */
.bg-icon {
  position: absolute;
  width: 40%;
  opacity: 0.5;
  bottom: 25px;
  pointer-events: none;
}

/* Responsive */
@media (max-width: 768px) {
  .nosotros-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  
  .box {
    padding: 30px 20px;
  }

  .box h2 {
    font-size: 2.3rem;
  }

  .box p {
    font-size: 1.4rem;
  }
  .bg-icon {
  position: absolute;
  width: 55%;
  opacity: 0.5;
  bottom: 40px;
  pointer-events: none;
}
}
/******************************************************/
/* --- Contenedor Principal (Cambio en el gradiente para mayor control) --- */
.mision-vision {
    width: 100%;
    min-height: 60vh;
    display: flex;
    position: relative;
    overflow: hidden;
    color: #fff;
    /* ❌ Quitamos el linear-gradient de aquí. Lo moveremos a la columna de Misión. */
    background-color: #e00613; /* Establecemos el color de Visión (Derecha) como fondo */
    top:50px;
}

.lado {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  
}

/* --- COLUMNA DE MISIÓN (LADO IZQUIERDO) --- */

.lado-izq {
    /* Usamos un pseudo-elemento para el color y la forma de la izquierda (Negro) */
    background-color: #000;
    /* Ajustamos el z-index para que esta columna esté por encima del lado derecho, 
       pero se cortará más adelante con el clip-path en el lado derecho. */
    z-index: 2; 
}

/* --- COLUMNA DE VISIÓN (LADO DERECHO) --- */

.lado-der {
    /* La columna derecha ahora no necesita color de fondo, ya lo tiene el .mision-vision */
    z-index: 1; /* Debe estar detrás del lado izquierdo */
    /* Este margen negativo es clave para superponer la columna de Visión sobre la de Misión 
       y hacer que el corte sea visible, simulando el ángulo. */
    margin-left: -75px; /* Ajusta este valor para hacer la diagonal más o menos ancha */
}

/* --- IMÁGENES DE FONDO (SIMPLIFICADO) --- */

.fondo-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    /*opacity: 0.3;*/
    /* Subimos el z-index de la imagen ligeramente para que esté detrás del texto pero delante del fondo de color */
    z-index: 1; 
 
}

/* ❌ ELIMINAR LOS CLIP-PATH DE LAS IMÁGENES:
.lado-izq .fondo-img { clip-path: polygon(0 0, 100% 0, 50% 100%, 0% 100%); }
.lado-der .fondo-img { clip-path: polygon(50% 0, 100% 0, 100% 100%, 0 100%); }
Esto causaba la superposición y el problema de la diagonal. */


/* --- ¡LA CLAVE DE LA DIAGONAL (\) --- */

/* Aplicamos el clip-path a la COLUMNA IZQUIERDA (Misión) para cortarla, 
   revelando la columna de Visión debajo y creando el efecto de "corte". */
.lado-izq {
    /* El polígono define los puntos: 
       0 0 (esquina superior izquierda), 
       55% 0 (punto diagonal superior),
       100% 100% (punto diagonal inferior),
       0 100% (esquina inferior izquierda) 
       Ajusta el 55% para el ángulo exacto. */
    clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%); 
}

/* --- Contenido (Ajustes) --- */

.contenido-col {
    position: relative;
    z-index: 3; /* Aseguramos que el texto esté siempre en la capa superior */
    text-align: center;
    padding: 2rem;
    max-width: 500px; /* Limita el ancho del texto para mejor lectura */
  
}
.contenido-col p {
   font-size: 1.4rem;
}

/* Ajuste de padding en la columna de Visión para que el texto no se oculte por el solapamiento */
.lado-der .contenido-col {
    /* Añade espacio a la izquierda para compensar el margen negativo */
    padding-left: 70px; 
}

.contenido-col h2 {
    margin-bottom: 1rem;
    font-size: 2.2rem;
    text-transform: uppercase;
    font-weight: 900;
}

/* Media Query para responsividad: Desactivar el clip-path en móviles */
@media (max-width: 768px) {
    .mision-vision {
        flex-direction: column;
        overflow: visible;
        background-color: #000; /* Fondo negro para móvil */
    }

    .lado-izq {
        clip-path: none; /* Quitamos el corte diagonal */
        margin-right: 0;
        z-index: auto;
    }
    
    .lado-der {
        margin-left: 0;
        background-color: #e00613; /* Fondo rojo para móvil */
        z-index: auto;
    }
    
    .lado-der .contenido-col {
        padding-left: 2rem; /* Reseteamos el padding de compensación */
    }
    
    .fondo-img {
        opacity: 0.2; /* Menos opacidad en móvil si se superpone */
    }
}




/* --- Contenedor Principal (ACTUALIZADO) --- */
.politica-calidad-container {
    display: flex;
    max-width: 1200px;
    /* 🎨 CAMBIO CLAVE: Agregamos margin-top y margin-bottom para separar la sección. */
    margin: 170px auto; /* 80px superior/inferior, 'auto' para centrado horizontal */
    padding: 20px;
    position: relative;
    min-height: 400px; 
}

/* --- Lado Izquierdo: Texto Introductorio (Igual) --- */
.texto-introductorio {
    flex: 1;
    padding-right: 40px;
    padding-top: 50px; 
}

.texto-introductorio h2 {
    font-size: 3.5rem;
    color: black;
    font-weight: 700;
    margin-bottom: 20px;
    line-height: 1;
}

.texto-introductorio .introduccion {
    font-size: 1.4rem;
    line-height: 1.7;
    color: #333;
    max-width: 450px;
}

.texto-introductorio .triangulo {
    color: #e00613;
    font-size: 1.5rem;
    margin-right: 5px;
}

/* --- Lado Derecho: Tarjeta de Compromisos (ACTUALIZADO) --- */
.tarjeta-compromisos {
    flex: 1;
    background-color: #e00613; 
    color: white;
    padding: 30px 40px;
    border-radius: 10px; 
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2); 
    position: absolute; 
    right: 20px;
    top: 0; 
    width: 50%; 
    max-width: 550px;
    min-height: 350px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.tarjeta-compromisos .norma {
    font-size: 1.4rem;
    margin-bottom: 20px;
    line-height: 1.5;
}

.tarjeta-compromisos ul {
    list-style: none;
    padding: 0;
}

.tarjeta-compromisos ul li {
    font-size: 1.1rem;
    margin-bottom: 15px;
    line-height: 1.5;
    padding-left: 25px; 
    position: relative;
}

.tarjeta-compromisos ul li::before {
    content: "•"; 
    color: white;
    font-size: 1.5rem;
    position: absolute;
    left: 0;
    top: -5px;
}

/* --- Responsivo (Igual) --- */
@media (max-width: 900px) {
    .politica-calidad-container {
        flex-direction: column;
        min-height: auto;
        /* Aseguramos que el margen se mantenga también en móvil */
        margin: 40px auto; 
    }
    
    .texto-introductorio {
        padding-right: 20px;
        padding-top: 20px;
        padding-bottom: 30px;
        width: 100%;
        text-align: center;
    }
    
    .texto-introductorio h2 {
        font-size: 2.5rem;
        margin-top: 100px;
    }

    .texto-introductorio .introduccion {
        max-width: 100%;
        text-align: center;
    }

    .tarjeta-compromisos {
        position: static; 
        width: 100%;
        max-width: none;
        min-height: auto;
        border-radius: 0 0 10px 10px; 
        box-shadow: none; 
    }
}
.hero-static-caption h2,
.hero-static-caption .hero-static-bajada {
  opacity: 0;
  transform: translateY(20px); /* opcional: efecto de desplazamiento */
  animation: fadeInUp 1s forwards;
  animation-delay: 0.3s; /* retraso para que no aparezca inmediatamente */
}

.hero-static-caption .hero-static-bajada {
  animation-delay: 1s; /* aparece después del título */
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
