/* =========================================
   NOSOTROS - HOJA DE ESTILOS
   ========================================= */

/* --- HERO SECTION (Full Background) --- */
.nosotros-hero {
    position: relative;
    /* Altura reducida comparada con el Home (85vh) */
    height: 50vh; 
    min-height: 450px; 
    width: 100%;
    display: flex;
    align-items: center;
    background-image: url('../img/hero-nosotros.webp'); /* Asegúrate de tener una imagen aquí o usa un color sólido por mientras */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #215fc2; /* Fondo de respaldo */
    margin-top: 0; /* Asegura que pegue con el header */
}

/* Capa Oscura (Overlay) */
.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to right, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.4) 100%);
    z-index: 1;
}

/* Contenedor (80% Ancho) */
.nosotros-hero .contenedor {
    width: 80%;
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
    z-index: 2; /* Texto arriba del overlay */
}

/* Texto del Hero */
.hero-content {
    max-width: 650px; /* Ancho máximo del texto para que no se estire demasiado */
}

.hero-content h1 {
    font-family: 'Outfit', sans-serif;
    font-size: 3.5rem;
    font-weight: 800;
    color: #ffffff;
    line-height: 1.1;
    margin-bottom: 1.5rem;
}

.hero-content p {
    font-family: 'Outfit', sans-serif;
    font-size: 1.25rem;
    color: #e2e8f0; /* Blanco hueso para lectura suave */
    line-height: 1.6;
    font-weight: 400;
}

/* Responsive */
@media (max-width: 900px) {
    .nosotros-hero {
        height: auto;
        padding: 6rem 0;
    }
    
    .nosotros-hero .contenedor {
        width: 90%;
    }

    .hero-content h1 {
        font-size: 2.5rem;
    }
    
    .hero-content p {
        font-size: 1.1rem;
    }
}

/* --- SECCIÓN TRUST (Why Choose Us) --- */
.nosotros-trust {
    padding: 6rem 0;
    background-color: #f8fafc; /* Fondo ligeramente gris para separar secciones */
}

.nosotros-trust .contenedor {
    width: 80%;
    max-width: 1400px;
    margin: 0 auto;
}

/* Encabezado Superior */
.trust-header {
    max-width: 800px;
    margin: 0 auto 4rem auto; /* "auto" a los lados centra el bloque */
    text-align: center;       /* Esto centra el texto y el subtítulo */
}

.trust-header h2 {
    font-size: 2.5rem;
    color: #15233A;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
}

.trust-header p {
    font-size: 1.1rem;
    color: #5B5A63;
    line-height: 1.6;
}

/* Grid Layout */
.trust-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* 50% Imagen | 50% Lista */
    gap: 5rem;
    align-items: center; /* Alineación superior para que la lista crezca hacia abajo */
}

/* Imagen Izquierda */
.trust-img-col img {
    width: 100%;
    height: auto;
    border-radius: 20px;
    box-shadow: 0 15px 30px rgba(0,0,0,0.1);
    object-fit: cover;
    min-height: 500px; /* Altura para igualar la lista visualmente */
}

/* Lista Derecha */
.trust-list-col {
    display: flex;
    flex-direction: column;
    gap: 2.5rem; /* Espacio entre items */
}

/* Item Individual */
.trust-item {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start; /* Icono alineado arriba */
}

/* Círculo del Icono */
.icon-circle {
    flex-shrink: 0; /* Evita que el círculo se aplaste */
    width: 60px;
    height: 60px;
    background-color: #e2e8f0; /* Gris suave de fondo */
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #15233A; /* Color del Icono */
    font-size: 1.5rem;
    transition: all 0.3s ease;
}

.trust-item:hover .icon-circle {
    background-color: #187495; /* Azul al pasar el mouse */
    color: #ffffff;
    transform: scale(1.1);
}

/* Texto del Item */
.trust-content h4 {
    font-size: 1.2rem;
    color: #15233A;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.trust-content p {
    font-size: 0.95rem;
    color: #64748b;
    line-height: 1.5;
    margin: 0;
}

/* Responsive */
@media (max-width: 900px) {
    .trust-grid {
        grid-template-columns: 1fr; /* Una columna en móvil */
        gap: 3rem;
    }
    
    .trust-img-col {
        order: -1; /* Mantiene la imagen arriba en móvil, o quítalo para que vaya abajo */
    }
    
    .trust-header h2 {
        font-size: 2rem;
    }
}

/* --- SECCIÓN GALERÍA INFINITA --- */
.nosotros-galeria {
    padding: 4rem 0;
    background-color: #ffffff;
    overflow: hidden; /* Oculta lo que se salga de la pantalla */
}

/* El Carrusel */
.marquee-wrapper {
    width: 100%;
    margin-bottom: 1.5rem; /* Espacio antes de la frase */
    display: flex;
    overflow: hidden;
    position: relative;
}

/* La pista que se mueve */
.marquee-track {
    display: flex;
    gap: 1.5rem; /* Espacio entre fotos */
    width: max-content; /* Importante: permite que las fotos se alineen horizontalmente */
    animation: scroll-left 40s linear infinite; /* Animación continua de 40 segundos */
}

/* Estilo de las Imágenes */
.marquee-track img {
    height: 260px; /* Altura fija para uniformidad */
    width: 350px;  /* Ancho rectangular */
    object-fit: cover;
    border-radius: 16px; /* Bordes redondeados */
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    flex-shrink: 0; /* Evita que se aplasten */
}

/* Animación (Mueve la pista hacia la izquierda) */
@keyframes scroll-left {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%); /* Se mueve hasta la mitad (donde empieza la copia) */
    }
}

/* Pausar al pasar el mouse (Opcional, se ve elegante) */
.marquee-wrapper:hover .marquee-track {
    animation-play-state: paused;
}

/* --- Frase del Objetivo --- */
.objective-quote {
    font-family: 'Outfit', sans-serif;
    font-size: 0.95rem; /* Texto pequeño */
    font-style: italic; /* Cursiva */
    color: #64748b; /* Gris medio elegante */
    text-align: right; /* Alineado a la derecha */
    max-width: 700px; /* Para que no sea una línea eterna en pantallas grandes */
    margin-left: auto; /* Empuja el bloque a la derecha */
    line-height: 1.6;
}

/* Ajuste Mobile */
@media (max-width: 768px) {
    .marquee-track img {
        height: 200px;
        width: 300px;
    }
    .objective-quote {
        text-align: center; /* En celular se ve mejor centrado */
        margin: 0 auto;
    }
}

/* --- SECCIÓN VIDEOS --- */
.nosotros-videos {
    padding: 5rem 0; /* Un poco más compacto */
    background-color: #f8fafc;
}

.videos-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 3rem auto;
    padding: 0 1rem; /* Margen de seguridad en móviles */
}

.videos-header h2 {
    font-size: 2.5rem;
    color: #15233A;
    font-weight: 700;
    margin-bottom: 1rem;
    line-height: 1.2;
}

.videos-header p {
    font-size: 1.1rem;
    color: #64748b;
}

/* Grid de Videos */
.videos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);

    gap: 1.5rem; 
    
    align-items: start;
    justify-items: center;
    max-width: 960px; 
    margin: 0 auto; 
}

/* Tarjeta contenedora (Ahora es transparente, solo agrupa video + texto) */
.video-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 280px; 
}

/* EL VIDEO (El cuadro 1x1) */
.video-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1; /* <<< CAMBIO CLAVE: FORMATO CUADRADO */
    border-radius: 20px;
    overflow: hidden;
    background: #000;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1); /* Sombra suave */
    transition: transform 0.3s ease;
}

/* Efecto hover sutil en el cuadro */
.video-wrapper:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0,0,0,0.15);
}

.video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Asegura que llene el cuadrado */
    display: block;
}

/* Títulos de los videos (h4) */
.video-card h4 {
    margin-top: 1.2rem;
    color: #15233A;
    font-weight: 700;
    font-size: 1.25rem;
    text-align: center;
    line-height: 1.3;
}

/* Capa Oscura y Botón Play */
.play-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.2);
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: background 0.3s ease;
    z-index: 2;
}

.play-overlay:hover {
    background-color: rgba(0,0,0,0.1);
}

.play-btn {
    width: 70px;
    height: 70px;
    background-color: #187495;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-size: 1.8rem;
    padding-left: 4px;
    box-shadow: 0 0 20px rgba(24, 116, 149, 0.6);
    transition: transform 0.3s ease, background-color 0.3s ease;
}

.play-overlay:hover .play-btn {
    transform: scale(1.1);
    background-color: #15233A;
}

/* --- RESPONSIVE (Tableta y Móvil) --- */
@media (max-width: 900px) {
    
    .videos-header h2 {
        font-size: 2rem; 
    }
    .videos-header p {
        font-size: 1rem;
    }

    .videos-grid {
        grid-template-columns: 1fr; 
        gap: 3rem;
        margin: 0 auto;
    }

    /* En móvil permitimos que crezcan un poquito más para que se vean bien */
    .video-card {
        max-width: 300px; /* Tamaño ideal para celulares */
    }

    .play-btn {
        width: 60px;
        height: 60px;
        font-size: 1.5rem;
    }
    
    .video-card h4 {
        font-size: 1.15rem;
    }
}
/* --- SECCIÓN CTA (Invertido) --- */
.cta-section {
    padding: 6rem 0;
    background-color: #ffffff; /* Fondo Blanco */
    text-align: center;
}

.cta-content h2 {
    font-size: 2.5rem;
    font-weight: 800;
    margin-bottom: 1rem;
    color: #15233A; /* Texto Azul Oscuro */
}

.cta-content p {
    font-size: 1.25rem;
    margin-bottom: 2.5rem;
    color: #187495; /* Subtítulo en Azul Corporativo para resaltar */
    font-weight: 500;
}

/* Botón Azul (Invertido) */
.btn-cta-blue {
    background-color: #187495; /* Fondo Azul */
    color: #ffffff; /* Texto Blanco */
    padding: 1rem 3rem;
    font-size: 1.1rem;
    font-weight: 700;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    box-shadow: 0 10px 20px rgba(24, 116, 149, 0.3); /* Sombra azulada suave */
    transition: all 0.3s ease;
}

.btn-cta-blue:hover {
    transform: translateY(-3px);
    background-color: #15233A; /* Se oscurece al pasar el mouse */
    box-shadow: 0 15px 25px rgba(21, 35, 58, 0.4);
}


/* --- SECCIÓN PILARES (Nosotros) --- */

.ns-pilares-section {
    padding: 6rem 0;
    background-color: #ffffff;
    overflow: hidden; /* Evita desbordamientos */
}

/* El Grid que parte la pantalla en 2 */
.ns-pilares-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* 50% Texto | 50% Imagen */
    gap: 4rem; /* Espacio entre columnas */
    align-items: center; /* Centrado vertical */
    max-width: 1300px; /* Ancho máximo para que no se estire demasiado */
    margin: 0 auto;
}

/* --- Columna Izquierda: Texto --- */
.ns-text-col {
    padding-right: 2rem; /* Aire extra antes de la imagen */
}

/* La etiqueta pequeña de arriba */
.ns-badge {
    display: inline-block;
    background-color: #E6EFF5;
    color: #187495;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    letter-spacing: 0.5px;
}

.ns-main-desc {
    font-size: 1.2rem;
    line-height: 1.6;
    color: #15233A; /* Azul oscuro fuerte */
    margin-bottom: 2.5rem;
    font-weight: 500;
}

/* --- Lista de Pilares --- */
.ns-list-wrapper h3 {
    font-size: 1.5rem;
    color: #15233A;
    margin-bottom: 1.5rem;
    font-weight: 700;
}

.ns-pilares-list {
    list-style: none; /* Quitamos los puntos por defecto */
    padding: 0;
    margin: 0;
}

.ns-pilares-list li {
    position: relative;
    padding-left: 1.5rem; /* Espacio para la viñeta personalizada */
    margin-bottom: 1rem;
    color: #5B5A63;
    font-size: 1rem;
    line-height: 1.5;
}

/* Viñeta personalizada (Cuadrito azul) */
.ns-pilares-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px; /* Ajuste visual */
    width: 8px;
    height: 8px;
    background-color: #187495; /* Azul cian */
    border-radius: 2px;
}

.ns-pilares-list strong {
    color: #15233A;
    font-weight: 700;
}

/* --- Columna Derecha: Imagen --- */
.ns-img-col {
    position: relative;
}

.ns-img-col img {
    width: 100%;
    height: 500px; /* Altura fija para uniformidad */
    object-fit: cover; /* Recorta la imagen para llenar el espacio sin deformar */
    border-radius: 20px;
    box-shadow: 0 20px 40px rgba(0,0,0,0.1); /* Sombra elegante */
    transition: transform 0.3s ease;
}

/* Efecto hover sutil en la imagen */
.ns-img-col img:hover {
    transform: translateY(-5px);
}

/* --- RESPONSIVE (Celular) --- */
@media (max-width: 900px) {
    .ns-pilares-grid {
        grid-template-columns: 1fr; /* Una sola columna */
        gap: 3rem;
    }

    .ns-text-col {
        padding-right: 0;
        text-align: left; /* O center si prefieres */
    }

    .ns-img-col img {
        height: 350px; /* Imagen más baja en celular */
    }
}


/* --- SECCIÓN CLIENTES (Fondo Blanco) --- */

.ns-clientes-section {
    padding: 5rem 0;       /* Espaciado arriba y abajo */
    background-color: #ffffff; 
    border-top: 1px solid rgba(0,0,0,0.05); /* Línea sutil arriba para separar */
}

/* Encabezado */
.ns-clientes-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 3.5rem auto; /* Centrado y margen abajo */
}

.ns-clientes-header h2 {
    font-size: 2.2rem;
    color: #15233A;
    font-weight: 700;
    margin-bottom: 0.8rem;
}

.ns-clientes-header p {
    font-size: 1.1rem;
    color: #5B5A63;
}

/* Grid de Logos */
.ns-logos-grid {
    display: flex;
    justify-content: center; /* Centrar todos los logos en el contenedor */
    align-items: center;     /* Alinear verticalmente */
    flex-wrap: wrap;         /* Si no caben, bajan a la siguiente línea */
    gap: 3rem;               /* Espacio entre logos */
    
    max-width: 1200px;
    margin: 0 auto;
}

/* Estilo de cada logo */
.ns-logo-item img {
    max-height: 60px;    /* Altura máxima uniforme */
    max-width: 160px;    /* Ancho máximo para que no se vean gigantes */
    width: auto;         /* Mantiene proporción */
    
    /* Efecto Elegante: Blanco y negro y semitransparente */
    filter: grayscale(100%);
    opacity: 0.6;
    transition: all 0.3s ease;
}

/* Hover: A color y totalmente visible */
.ns-logo-item img:hover {
    filter: grayscale(0%);
    opacity: 1;
    transform: scale(1.05); /* Pequeño zoom al pasar el mouse */
}

/* --- Responsive (Tableta y Móvil) --- */
@media (max-width: 900px) {
    
    /* 1. AJUSTE DE TEXTOS (Para que no se vean gigantes) */
    .ns-clientes-header h2 {
        font-size: 2rem !important; /* Reducido de 2.2rem */
        line-height: 1.2;
    }

    .ns-clientes-header p {
        font-size: 1rem !important; /* Reducido de 1.1rem */
        padding: 0 1rem; /* Un poco de margen lateral para que no pegue a los bordes */
    }

    /* 2. AJUSTE DE LOGOS (Mantenemos lo que tenías) */
    .ns-logos-grid {
        gap: 2rem; 
    }
    
    .ns-logo-item img {
        max-height: 50px; /* Tamaño optimizado */
        max-width: 130px;
    }
}

/* --- SECCIÓN CERTIFICACIONES Y RESPALDO --- */
.certificaciones-section {
    padding: 6rem 0;
    background-color: #F8FAFC; /* Gris muy claro para diferenciar de fondo blanco */
}

.certificaciones-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    margin-top: 3rem;
}

/* Estilos Generales de Columna */
.cert-col h3 {
    font-size: 1.8rem;
    color: #15233A;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 10px;
}

.cert-col h3 i {
    color: #187495;
    font-size: 1.5rem;
}

.cert-intro {
    color: #64748b;
    margin-bottom: 2rem;
    font-size: 1.05rem;
}

/* --- ESTILOS LADO LEGAL (Tarjetas de Permisos) --- */
.license-card {
    background-color: #ffffff;
    border-left: 5px solid #187495; /* Borde azul a la izquierda */
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    border-radius: 8px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    display: flex;
    align-items: center;
    gap: 1.5rem;
    transition: transform 0.3s ease;
}

.license-card:hover {
    transform: translateX(5px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.license-icon {
    font-size: 2rem;
    color: #cbd5e1;
}

.license-info {
    display: flex;
    flex-direction: column;
}

.license-label {
    font-size: 0.85rem;
    text-transform: uppercase;
    color: #94a3b8;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.license-number {
    font-size: 1.25rem;
    color: #15233A;
    font-family: 'Outfit', sans-serif;
}

/* Badge ANERPV */
.anerpv-badge {
    background-color: #15233A; /* Azul Oscuro */
    color: #ffffff;
    padding: 1.5rem;
    border-radius: 12px;
    margin-top: 2rem;
}

.anerpv-content {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.anerpv-content .check-icon {
    font-size: 1.5rem;
    color: #4ade80; /* Verde brillante */
}

.anerpv-content p {
    margin: 0;
    font-size: 0.9rem;
    color: #cbd5e1;
    margin-top: 0.3rem;
}

/* --- ESTILOS LADO HUMANO (Lista) --- */
.cert-list {
    list-style: none;
    padding: 0;
}

.cert-list li {
    display: flex;
    gap: 1.5rem;
    margin-bottom: 2rem;
    align-items: flex-start;
}

.cert-list li i {
    background-color: #E0F2FE;
    color: #187495;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.2rem;
    flex-shrink: 0; /* Evita que el icono se aplaste */
}

.cert-list strong {
    display: block;
    color: #15233A;
    font-size: 1.1rem;
    margin-bottom: 0.3rem;
}

.cert-list p {
    margin: 0;
    color: #64748b;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Responsive */
@media (max-width: 900px) {
    .certificaciones-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
}

/* --- SECCIÓN INTERACTIVA CERTIFICACIONES --- */
.certificaciones-interactivas {
    padding: 6rem 0;
    background-color: #F8FAFC;
}

.cert-viewer-layout {
    display: flex;
    align-items: center;
    gap: 5rem;
    max-width: 1200px;
    margin: 0 auto;
}

/* Columna Izquierda (Texto) */
.cert-text-panel {
    flex: 1; /* Ocupa el espacio disponible */
}

.cert-title {
    font-size: 2.5rem;
    color: #15233A; /* Azul Oscuro */
    font-weight: 700;
    margin-bottom: 0.5rem;
    transition: opacity 0.3s ease;
    line-height: 1.2;
}

.cert-subtitle {
    font-size: 1.2rem;
    color: #187495; /* Azul Cian */
    font-weight: 600;
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: opacity 0.3s ease;
}

.cert-description {
    font-size: 1.1rem;
    color: #5B5A63;
    line-height: 1.7;
    transition: opacity 0.3s ease;
}

/* Columna Derecha (Grid) */
.cert-logos-grid {
    flex: 1;
    display: grid;
    grid-template-columns: 1fr 1fr; /* 2 columnas */
    gap: 1.5rem;
}

/* Botones / Tarjetas de Logo */
.cert-item {
    background-color: #ffffff;
    border: 2px solid #e2e8f0; /* Borde gris suave por defecto */
    border-radius: 12px;
    padding: 2rem 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    height: 160px; /* Altura fija para uniformidad */
    outline: none;
}

.cert-item i {
    font-size: 2.5rem;
    color: #94a3b8; /* Gris apagado */
    transition: color 0.3s ease;
}

.cert-item span {
    font-weight: 600;
    color: #64748b;
    font-size: 0.9rem;
}

.cert-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}

/* ESTADO ACTIVO (Seleccionado) */
.cert-item.active {
    border-color: #187495; /* Borde de color activo (como el naranja de tu foto, pero en azul marca) */
    background-color: #ffffff;
    box-shadow: 0 5px 15px rgba(24, 116, 149, 0.15);
}

.cert-item.active i {
    color: #187495; /* Icono se prende */
}

.cert-item.active span {
    color: #15233A;
    font-weight: 700;
}

/* =========================================
   AJUSTE DE LOGOS (Solo Imagen)
   ========================================= */

/* Botón contenedor */
.cert-item {
    /* Centrado perfecto */
    display: flex;
    align-items: center;
    justify-content: center;
    
    padding: 1.5rem;      /* Relleno uniforme */
    height: 160px;        /* Altura fija */
    background-color: #ffffff;
    border: 2px solid #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
}

/* Imagen del Logo */
.cert-item .cert-logo {
    height: 80px;         /* AUMENTADO: Antes 55px, ahora 80px para mayor presencia */
    width: auto;
    object-fit: contain;
    margin: 0;            /* Quitamos márgenes extra */
    
    /* Efecto: Blanco y negro suave */
    filter: grayscale(100%); 
    opacity: 0.7;
    transition: all 0.3s ease;
}

/* HOVER y ACTIVO */
.cert-item.active .cert-logo,
.cert-item:hover .cert-logo {
    filter: grayscale(0%); /* Color completo */
    opacity: 1;
    transform: scale(1.1); /* Efecto de "zoom" un poco más notorio */
}

.cert-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}

.cert-item.active {
    border-color: #187495;
    box-shadow: 0 5px 15px rgba(24, 116, 149, 0.15);
}

/* Responsive */
@media (max-width: 900px) {
    .cert-viewer-layout {
        flex-direction: column;
        gap: 1rem;
        text-align: center;
    }
    
    .cert-logos-grid {
        width: 100%;
        grid-template-columns: 1fr 1fr; /* En móvil mantenemos 2 columnas si caben */
    }
}
@media (max-width: 480px) {
    .cert-logos-grid {
        grid-template-columns: 1fr; /* En pantallas muy chicas, 1 columna */
    }
}


/* --- HERO SECTION para la versión movil --- */
/* --- HERO SECTION para la versión movil --- */

/* =========================================
   AJUSTE DE ALINEACIÓN (Más a la izquierda)
   ========================================= */

@media (max-width: 1024px) {

    /* 1. CONTENEDOR MÁS ANCHO = MÁS A LA IZQUIERDA */
    .nosotros-hero .contenedor {
        width: 90% !important; /* CAMBIO: De 80% a 90% para acercarlo al borde */
        margin-left: auto !important;
        margin-right: auto !important;
    }

    /* El resto se queda igual... */
    .nosotros-hero {
        height: auto !important;
        min-height: 400px !important;
        padding: 6rem 0 !important;
        align-items: center !important; 
    }

    .hero-content {
        text-align: left !important;
        max-width: 100% !important;
        margin: 0 !important;
    }

    .hero-content h1 {
        font-size: 2.2rem !important;
        line-height: 1.2 !important;
        margin-bottom: 1rem !important;
    }

    .hero-content p {
        font-size: 1rem !important;
        line-height: 1.5 !important;
        color: #e2e8f0 !important;
        font-weight: 400 !important;
    }
}

/* En móvil se mantiene igual al 90% */
@media (max-width: 600px) {
    .nosotros-hero .contenedor {
        width: 90% !important; 
    }
    .hero-content h1 {
        font-size: 1.8rem !important;
    }
}




/* --- TRUST SECTION para la versión movil --- */
/* --- TRUST SECTION para la versión movil --- */

/* =========================================
   AJUSTE SECCIÓN TRUST (Ocultar imagen en Tablet/Móvil)
   ========================================= */

@media (max-width: 1024px) {
    
    /* 1. OCULTAR LA IMAGEN */
    .trust-img-col {
        display: none !important;
    }

    /* 2. REAJUSTAR LA GRILLA (Para que el texto use todo el ancho) */
    .trust-grid {
        grid-template-columns: 1fr !important; /* 1 sola columna */
        gap: 0 !important;
    }

    /* 3. ALINEACIÓN CONTENEDOR */
    .trust-list-col {
        width: 100% !important;
    }
    
    /* Mantenemos el estilo de los iconos igual (alineados a la izquierda) 
       como pediste, sin cambios extra en .trust-item */
}

/* REEMPLAZO: Hover Sutil (Sin cambio brusco de color) */
.trust-item:hover .icon-circle {
    background-color: #dbeafe !important; /* Un azul MUY clarito (casi gris) */
    color: #15233A !important;            /* El icono MANTIENE su color oscuro original */
    transform: translateY(-5px) !important; /* Solo sube un poquito, no se hace gigante */
    box-shadow: 0 10px 20px rgba(0,0,0,0.05) !important; /* Sombra suave */
}


/* --- BRAND SECTION para la versión movil --- */
/* --- BRAND SECTION para la versión movil --- */

/* =========================================
   AJUSTES FINALES: ESPACIO Y ESTABILIDAD (Globales)
   ========================================= */

/* 1. Reducir espacio superior en general */
.certificaciones-interactivas {
    padding-top: 2rem !important; 
    padding-bottom: 6rem; 
}

/* 2. Estabilidad para ESCRITORIO (Pantallas grandes) */
.cert-description {
    min-height: 110px !important; /* Espacio reservado en Desktop */
    padding-bottom: 1rem !important;
    transition: height 0.3s ease;
}


/* =========================================
   AJUSTE MÓVIL Y TABLET (Unificado < 900px)
   ========================================= */
@media (max-width: 900px) {

    /* --- A. CONTENEDOR DE TEXTO (Anti-brinco) --- */
    .cert-text-panel {
        /* Altura fija para contener Título + Subtítulo + Texto */
        min-height: 280px !important; 
        
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important; 
        margin-bottom: 2rem !important; 
    }

    /* --- B. AJUSTE DE FUENTES --- */
    .cert-title {
        font-size: 2rem !important;
        margin-bottom: 0.5rem !important;
        line-height: 1.1 !important;
    }
    
    .cert-subtitle {
        font-size: 1rem !important;
        margin-bottom: 1rem !important;
    }

    /* Reseteamos la descripción porque ahora manda el panel padre */
    .cert-description {
        min-height: auto !important; 
        font-size: 1rem !important;
    }

    /* --- C. GRID 2x2 Y BOTONES --- */
    .cert-logos-grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important; /* 2 columnas */
        gap: 0.8rem !important;
    }

    .cert-item {
        height: 120px !important;
        padding: 0.8rem !important;
    }

    .cert-item .cert-logo {
        height: 50px !important;
        max-width: 100% !important;
    }
}

/* =========================================
   AJUSTE EXTRA (Celulares pequeños < 480px)
   ========================================= */
@media (max-width: 480px) {
    .cert-title {
        font-size: 1.8rem !important;
    }
    /* Mantenemos el grid 2x2 asegurado */
    .cert-logos-grid {
        grid-template-columns: 1fr 1fr !important;
    }
}


/* =========================================
   GALERÍA SWIPER (CARRUSEL INFINITO)
   ========================================= */

/* 1. Contenedor Principal (Máscara y espacio) */
.gallery-ticker-wrapper {
    position: relative;
    overflow: hidden; /* Oculta lo que se sale de la pantalla */
    padding: 3rem 0 2rem 0; /* Espacio arriba y abajo */
    
    /* Efecto: Desvanecimiento suave en los bordes izquierdo y derecho */
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}

/* 2. El área del deslizador */
.galeria-swiper {
    width: 100%;
    height: 250px; /* ALTURA FIJA: Esto evita que sean gigantes */
}

/* 3. Ajuste para movimiento continuo suave */
.galeria-swiper .swiper-wrapper {
    transition-timing-function: linear !important;
}

/* 4. Cada tarjeta (Slide) */
.galeria-swiper .swiper-slide {
    height: 100%;
    width: 350px; /* ANCHO FIJO: Define qué tan ancha es cada foto */
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 5. La Imagen */
.galeria-swiper .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Recorta la foto para llenar el cuadro sin deformarse */
    border-radius: 12px; /* Bordes redondeados */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); /* Sombra suave */
}

/* 6. Ajuste del texto de abajo (Cita) */
.objective-quote {
    margin-top: 2rem;
    position: relative;
    z-index: 2;
}