/* Definición de colores principales */
/* --- Reglas Generales de la Página --- */
html {
    scroll-behavior: smooth; /* ¡Esta es la magia del desplazamiento suave! */
}
:root {
    --westhill-blue: #235587; /* El azul oscuro del banner superior */
    --westhill-green: #25d366; /* El verde de WhatsApp */
    --westhill-caption-blue: rgba(28, 61, 110, 0.85); /* El azul oscuro semitransparente del texto superpuesto */
}
/* --- Reglas Generales de la Página --- */
html, body {
    overflow-x: hidden; /* ¡LA CURA MÁGICA! Oculta todo lo que sobresalga a los lados */
    width: 100%;        /* Asegura que el cuerpo mida exactamente el ancho de la pantalla */
    margin: 0;
    padding: 0;
    scroll-behavior: smooth;
    scroll-padding-top: 90px; 
    font-family: 'Raleway', sans-serif;
    color: #333333;
}

body {
    background-color: #ffffff; /* o el color de fondo que estés usando */
    position: relative;
    padding-bottom: 0 !important; /* ¡CRÍTICO! Esto elimina el hueco gigante al final */
    font-family: 'Raleway', sans-serif;
}
/* =========================================
   FUENTES PERSONALIZADAS
   ========================================= */

/* Raleway - Normal (Soporta todos los grosores del 100 al 900) */
@font-face {
    font-family: 'Raleway';
    src: url('Raleway-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900; /* Al ser variable, abarca de Thin a Black */
    font-style: normal;
    font-display: swap; /* Ayuda a que la página cargue más rápido */
}

/* Raleway - Itálica (Cursiva) */
@font-face {
    font-family: 'Raleway';
    src: url('Raleway-Italic-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}


/************************************INDEX INDEX***************************************************/


/* Contenedor principal de la barra */
.westhill-navbar {
    background-color: #235587 !important; /* El color exacto que pediste */
    min-height: 100px;
    display: flex;
    align-items: center;
}

/* Forzar letras a blanco y tamaño adecuado */
.westhill-navbar .navbar-nav .nav-link {
    color: #ffffff !important; 
    font-weight: 500;
    padding-left: 15px;
    padding-right: 15px;
}

/* Filtro para hacer el logo blanco */
.logo-navbar {
    filter: brightness(0) invert(1);
}

/* Estilo del Botón Verde "Solicita información" */
.btn-solicita-info {
    background-color: #28a745; /* Verde Bootstrap */
    color: #ffffff !important;
    padding: 8px 22px;
    border-radius: 25px;
    text-decoration: none;
    font-weight: bold;
    display: inline-block;
    transition: background-color 0.3s ease;
}

.btn-solicita-info:hover {
    background-color: #218838; /* Verde más oscuro al pasar el mouse */
}

/* Evitar que el menú tape el logo en pantallas de PC */
@media (min-width: 992px) {
    .westhill-navbar .navbar-nav.me-auto {
        padding-right: 130px; 
    }
    .westhill-navbar .navbar-nav.ms-auto {
        padding-left: 130px; 
    }
}
/* --- Carrusel --- */
carousel-inner {
    background-color: #000; /* Fondo negro por si el video tiene bordes */
}

.banner-media {
    width: 100%;
    height: auto; /* La altura se calcula sola */
    aspect-ratio: 16 / 9; /* Mantiene la proporción perfecta de un video estándar */
    object-fit: cover;
}
/* Texto superpuesto al slide 1 */
.westhill-caption {
    background-color: var(--westhill-caption-blue);
    padding: 20px;
    border-radius: 30px;
    left: 5%; /* Ajusta la posición izquierda */
    bottom: 5%; /* Ajusta la posición inferior */
    width: auto;
    color: white;
}

/* --- Botón Flotante de WhatsApp --- */
.whatsapp-float-btn {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 40px;
    right: 40px;
    background-color: var(--westhill-green);
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px #999;
    z-index: 100;
    transition: all .3s ease-in-out;
}

.whatsapp-float-btn:hover {
    color: #FFF;
}

.whatsapp-float-btn i {
    margin-top: 16px;
}

/* --- Animación de sacudida (Shake Animation) --- */
@keyframes shake {
    0% { transform: translate(0, 0); }
    10% { transform: translate(-2px, -2px); }
    20% { transform: translate(2px, 2px); }
    30% { transform: translate(-2px, 2px); }
    40% { transform: translate(2px, -2px); }
    50% { transform: translate(0, 0); }
    100% { transform: translate(0, 0); }
}

/* Aplicar la animación de sacudida al botón de WhatsApp */
.whatsapp-float-btn {
    animation: shake 2s infinite ease-in-out;
}
/* Estilos generales de la sección */
#historia {
  background-color: #f8f8f8; /* El color de fondo que tengas */
  
  /* Reducimos el tercer número (el de abajo) de 80px a 30px o 20px */
  padding: 20px 20px 30px 20px; 
  
  font-family: 'Raleway'; 
}

    .historia-container {
      max-width: 1200px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 50px; /* Separación entre columnas */
    }

    /* Columna de texto (izquierda) */
    .texto-historia {
      flex: 1;
      padding-right: 20px;
    }

    .texto-historia h2 {
      color: #1e3d74; /* Un azul marino oscuro */
      font-size: 36px;
      font-weight: bold;
      margin-bottom: 30px;
    }

    .texto-historia p {
      color: #1e3d74;
      font-size: 16px;
      line-height: 1.8; /* Mejor interlineado para lectura */
      margin: 0;
      text-align: justify;
    }
/* Contenedor principal de las imágenes */
    .imagenes-historia {
      flex: 1;
      display: flex;
      justify-content: center; /* Centra el bloque de círculos */
      align-items: center;
      height: 500px;
    }

    /* El "lienzo" de los círculos. Le damos un tamaño fijo para que la posición sea perfecta */
    .composicion-circulos {
      width: 450px;
      height: 450px;
      position: relative;
    }

    /* Estilos base de los círculos (sin cambios) */
    .composicion-circulos .circulo {
      position: absolute;
      border-radius: 50%;
      border-style: solid;
      border-width: 8px;
      background-size: cover;
      background-position: center;
      overflow: hidden;
      transition: transform 0.3s ease;
    }

    .composicion-circulos .circulo::after {
      content: '';
      position: absolute;
      top: 0; left: 0; width: 100%; height: 100%;
      background-image: inherit; background-size: inherit; background-position: inherit;
      filter: grayscale(100%); opacity: 1; transition: opacity 0.3s ease;
    }

    .composicion-circulos .circulo:hover::after { opacity: 0; }
    .composicion-circulos .circulo:hover { transform: scale(1.03); z-index: 10; }

    /* --- POSICIONES EXACTAS (Para que se toquen) --- */
    .circulo-grande {
      width: 320px;
      height: 320px;
      border-color: #28a745; /* Verde */
      background-image: url('../img/Circulogrande.png');
      top: 0;
      left: 65px; /* Centrado en el lienzo de 450px */
      z-index: 1;
    }

    .circulo-mediano {
      width: 280px;
      height: 280px;
      border-color: #1e3d74; /* Azul */
      background-image: url('../img/Circulomediano.png');
      top: 150px;
      left: 180px; /* Movido a la derecha */
      z-index: 2;
    }

    .circulo-pequeño {
      width: 220px;
      height: 220px;
      border-color: #ffc107; /* Amarillo */
      background-image: url('../img/Circulopequeño.png');
      top: 200px;
      left: -39px; /* Calculado exactamente para tocar el borde del círculo azul */
      z-index: 3;
    }

    /* --- RESPONSIVIDAD MÓVIL (Escalado en lugar de desarmar) --- */
    @media (max-width: 992px) {
      .historia-container {
        flex-direction: column;
        text-align: center;
      }

      .texto-historia {
        padding-right: 0;
        margin-bottom: 20px;
      }

      .imagenes-historia {
        width: 100%;
        height: 350px; /* Reducimos la altura en tablet/móvil */
      }

      .composicion-circulos {
        transform: scale(0.7); /* Encoge toda la pirámide un 30% manteniendo posiciones */
        transform-origin: top center;
      }
    }

    /* Para celulares muy pequeños */
    @media (max-width: 500px) {
      .imagenes-historia {
        height: 260px; /* Menos altura para no dejar espacio en blanco extra */
      }
      .composicion-circulos {
        transform: scale(0.55); /* Encoge casi a la mitad */
      }
    }
/* --- Sección Oferta Académica --- */
.titulo-oferta {
    color: #1f4e74; /* Azul de tu logotipo */
    font-weight: 700;
    font-size: 2.5rem;
}

/* Contenedor principal de la tarjeta */
.tarjeta-academica {
    position: relative;
    height: 420px;
    border-radius: 15px; 
    background-size: cover;
    background-position: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    overflow: hidden; /* IMPORTANTE: Ayuda a que la cinta nazca perfectamente del borde */
    transition: transform 0.3s ease;
}

.tarjeta-academica:hover {
    transform: translateY(-5px); 
}

/* El nuevo diseño de la Cinta / Etiqueta Azul */
.etiqueta-azul {
    position: absolute;
    bottom: 25px; /* Separación desde abajo */
    left: 0;      /* Pegado al borde izquierdo de la tarjeta */
    width: 88%;   /* Ocupa el 88% del ancho (deja un espacio a la derecha) */
    background-color: #245e8a; /* Un tono de azul acorde a tu imagen */
    color: #ffffff;
    text-align: left; /* Alineado a la izquierda */
    padding: 12px 10px 12px 25px; /* Más espacio a la izquierda para empujar el texto */
    font-size: 1.3rem; /* Letra más grande, como en la foto */
    font-weight: 800; /* Letra muy gruesa (bold) */
    
    /* EL TRUCO: Borde recto a la izquierda (0) y redondeado a la derecha (30px) */
    border-radius: 0 30px 30px 0; 
    
    z-index: 2;
    transition: opacity 0.3s ease;
}

/* (El resto de las clases como .tarjeta-overlay, .tarjeta-overlay h3, etc., se quedan exactamente igual y ya no necesitamos .flecha-amarilla) */
/* Capa oscura que aparece en el hover (Overlay) */
.tarjeta-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(60, 60, 60, 0.95); /* Gris muy oscuro, casi negro */
    color: white;
    border-radius: 15px; /* Mismos bordes redondeados */
    padding: 30px 20px;
    display: flex;
    flex-direction: column;
    opacity: 0; /* Oculto por defecto */
    transition: opacity 0.3s ease;
    z-index: 3;
}

/* Título dentro de la capa oscura */
.tarjeta-overlay h3 {
    font-size: 1.8rem;
    font-weight: bold;
    margin-bottom: 20px;
}

/* Ajustes de la lista de programas */
.tarjeta-overlay ul {
    list-style-type: disc;
    padding-left: 20px;
    font-size: 0.85rem;
    line-height: 1.4;
    overflow-y: auto; /* Por si la lista es muy larga, que se pueda hacer scroll internamente */
}

.tarjeta-overlay li {
    margin-bottom: 5px;
}
/* --- INTERACCIÓN (Magia del Hover) --- */

/* Cuando pasas el mouse, la capa oscura aparece */
.tarjeta-academica:hover .tarjeta-overlay {
    opacity: 1;
}

/* Cuando pasas el mouse, la etiqueta azul desaparece */
.tarjeta-academica:hover .etiqueta-azul {
    opacity: 0;
}
/* --- Sección Imagen a pantalla completa --- */
.imagen-full-width {
    width: 100%;
    height: auto;       /* Mantiene la proporción original de la imagen */
    display: block;     /* Evita espacios en blanco debajo de la imagen */
    object-fit: cover;  /* Previene deformaciones extrañas */
}

/* En móviles, la imagen se hará más pequeña para caber en la pantalla.
   Al tener formato horizontal, es normal que se vea más delgada en celulares. */
/* --- Sección de Testimonios --- */

/* Ajuste de la imagen para que siempre se vea bien proporcionada */
.imagen-testimonio {
    max-height: 400px;
    object-fit: cover;
    width: 100%;
}

/* El color casi negro del nombre */
.texto-azul-oscuro {
    color: #111111;
    font-size: 2rem;
}

/* Estilo del párrafo del testimonio */
.texto-testimonio {
    font-size: 1.1rem;
    line-height: 1.7; /* Interlineado amplio para fácil lectura */
    color: #444444; /* Gris oscuro elegante */
    text-align: justify; /* Justificado como en la imagen */
}

/* Contenedor de las flechas y contador (alineado a la derecha) */
.controles-testimonio {
    display: flex;
    justify-content: center; /* <-- ¡Aquí está el cambio! Pasamos de flex-end a center */
    align-items: center;
}

/* Estilo de las flechas (botones) */
.custom-carousel-btn {
    color: #777777; /* Color gris para las flechas */
    transition: color 0.3s ease;
}

.custom-carousel-btn:hover {
    color: #1f4e74; /* Se vuelven azules al pasar el mouse */
}
/* --- Sección Apoyo Financiero --- */

/* Color de fondo azul medio-oscuro */
.seccion-apoyo-financiero {
    background-color: #2b618a; /* Ajustado visualmente según tu captura */
}

/* Estilo de los párrafos */
.texto-apoyo {
    font-size: 1.1rem;
    line-height: 1.5;
    text-align: justify; /* Mantiene el bloque de texto cuadradito */
}

/* Diseño del botón "Más información" */
.btn-mas-info {
    color: #2b618a !important; /* Letras azules del mismo color que el fondo */
    font-weight: 700;
    font-size: 1.15rem;
    padding: 10px 40px; /* Botón ancho como en la imagen */
    border-radius: 5px; /* Bordes poco redondeados */
    transition: background-color 0.3s ease, transform 0.3s ease;
}

.btn-mas-info:hover {
    background-color: #e2e6ea;
    transform: translateY(-3px); /* Un pequeño salto hacia arriba */
}

/* --- Ajustes del Mosaico Multimedia --- */

/* Esta clase es clave para que las 3 piezas mantengan su proporción sin deformarse */
.multimedia-item {
    height: 250px; /* Puedes subirlo a 280px si quieres el bloque más grande */
}

.object-fit-cover {
    object-fit: cover; /* Evita que las caras se achaten o estiren */
}

/* Responsive: En celulares, hacemos que las imágenes no sean tan altas para que quepan en la pantalla */
@media (max-width: 768px) {
    .multimedia-item {
        height: 180px;
    }
    .seccion-apoyo-financiero .text-white {
        text-align: center; /* Centramos el texto en móviles para mejor lectura */
    }
    .texto-apoyo {
        text-align: center;
    }
}
/* --- Sección Claustro Docente --- */

.titulo-claustro {
    color: #1f4e74;
    font-size: 2.5rem;
}

/* Contenedor de la foto del profesor */
.tarjeta-docente {
    position: relative;
    height: 380px; /* Altura de la fotografía */
    border-radius: 10px; /* Bordes redondeados */
    background-size: cover;
    background-position: top center; /* Enfoca la parte superior de la imagen (la cara) */
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    overflow: hidden;
    cursor: pointer; /* Cambia el cursor a una manita */
}

/* Capa azul semitransparente (Overlay) */
.docente-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Un azul oscuro (rgba) al 85% de opacidad para dejar ver un poco el fondo */
    background-color: rgba(31, 78, 116, 0.85); 
    opacity: 0; /* Oculta por defecto */
    transition: opacity 0.3s ease;
}

/* La frase dentro de la capa azul */
.frase-docente {
    color: white;
    font-size: 1.15rem;
    font-style: italic;
    font-weight: 500;
    line-height: 1.4;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.5); /* Sombrita para que resalte más */
}

/* --- EFECTO HOVER --- */
/* Muestra la capa azul al pasar el mouse */
.tarjeta-docente:hover .docente-overlay {
    opacity: 1;
}

/* --- Texto debajo de la tarjeta --- */
.nombre-docente {
    color: #1f4e7483;
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 5px;
    line-height: 1.2;
}

.facultad-docente {
    color: #666666; /* Gris más suave para no competir con el nombre */
    font-size: 0.95rem;
    margin-bottom: 0;
}
/* --- Sección Ubicación --- */

/* Título principal de la ubicación */
.titulo-ubicacion {
    color: #111111; /* Casi negro */
    font-size: 2.6rem;
    line-height: 1.2;
    letter-spacing: -0.5px;
}

/* Contenedor con borde azul y esquinas redondeadas para el mapa */
.contenedor-mapa {
    border: 3px solid #1f4e74; /* Borde azul institucional */
    border-radius: 25px; /* Esquinas muy redondeadas */
    overflow: hidden; /* CRÍTICO: Corta el mapa para que no se salga de las esquinas redondas */
    background-color: #fff;
}

/* Ajuste para que el iframe (mapa) no deje espacios en blanco abajo */
.contenedor-mapa iframe {
    display: block;
    width: 100%;
}

/* Iconos de la sección (azul Westhill) */
.icono-ubicacion {
    color: #1f4e74;
    font-size: 1.6rem;
}

/* Texto de detalles de dirección, teléfono, etc. */
.texto-contacto {
    font-size: 1.1rem;
    color: #444444; /* Gris oscuro para fácil lectura */
}

/* Responsive: Reducimos el tamaño del título en móviles */
@media (max-width: 768px) {
    .titulo-ubicacion {
        font-size: 2rem;
    }
    .contenedor-mapa iframe {
        height: 350px; /* Mapa un poco más bajito en celulares */
    }
}
/* --- Sección Formulario de Contacto --- */

.titulo-contacto {
    color: #111111;
    font-size: 2.8rem;
    line-height: 1.2;
    letter-spacing: -0.5px;
}

/* Contenedor del Iframe (Le da el look de "tarjeta") */
.contenedor-formulario {
    background-color: #ffffff8c;
    border-radius: 20px; 
    overflow: hidden; 
    height: 100%;
    /* AUMENTAMOS ESTE VALOR para que el formulario de Smartsheet quepa completo sin scroll */
    min-height: 850px; 
    border: 1px solid #f0f0f0ab;
    padding-bottom: 10px;  
}

/* Imagen de la derecha */
.imagen-formulario {
    border-radius: 20px; 
    object-fit: cover; 
    height: 100%;
    /* DEBE TENER EL MISMO VALOR que el formulario para mantener la simetría */
    min-height: 850px; 
    padding-bottom: 0px; 
}

/* Responsividad: Ajustes para teléfonos y tablets */
@media (max-width: 992px) {
    .contenedor-formulario {
        min-height: 800px; /* Un poco menos en móviles*/
    }
    .imagen-formulario {
        min-height: 400px; /* La imagen se queda más pequeña en celular para no ocupar tanta pantalla */
    }
    .titulo-contacto {
        font-size: 2.2rem;
    }
}
/* =========================================
   SECCIÓN: FOOTER / PIE DE PÁGINA
   ========================================= */

/* --- Contenedor General --- */
#footer-uw {
    width: 100%;
    background-color: #ffffff;
    margin-top: -60px;
}

/* =========================================
   CUERPO DEL FOOTER (PARTE AZUL)
   ========================================= */
.footer-body {
    /* Imagen y Fondo */
    background-image: url('../img/footer.png') !important;
    background-size: 100% 100%; /* Estira la imagen para cubrir todo sin romper proporciones */
    background-position: top center;
    background-repeat: no-repeat;
    background-color: #265b82; 
    
    /* Configuración Flexbox para centrado vertical absoluto */
    display: flex;
    align-items: center; /* Centra las columnas a lo alto en medio del espacio azul */
    
    /* Espaciado responsivo y proporcional */
    /* clamp(minimo, valor ideal dinamico, maximo) - Protege el texto de la onda amarilla */
    padding-top: clamp(140px, 16vw, 300px); 
    padding-bottom: 20px; 
    
    color: #ffffff;
    font-family: 'Raleway';
    width: 100%;
}

/* --- Información de Contacto --- */
.contact-col p {
    margin-bottom: 8px; /* Separación compacta */
    font-size: 1.05rem; /* Tamaño de lectura cómodo */
}

/* Flexbox para mantener los iconos perfectamente alineados con su texto (Incluso si están centrados) */
.contacto-item {
    display: flex;
    align-items: center;
    justify-content: center; /* Centra el conjunto de icono + texto horizontalmente */
    margin-bottom: 8px;
}

.contacto-item i {
    margin-right: 12px;
    width: 20px;
    text-align: center;
    font-size: 1.1rem;
}

/* --- Redes Sociales (Cuadritos Blancos) --- */
.social-box {
    display: flex;
    justify-content: center; /* Centra los cuadritos en su contenedor */
    gap: 12px;
    margin-top: 20px;
}

.social-box a {
    background-color: #ffffff;
    color: #265b82; /* Icono azul institucional */
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px; /* Bordes ligeramente redondeados */
    text-decoration: none;
    font-size: 1.3rem;
    transition: transform 0.3s ease, background-color 0.3s ease;
}

.social-box a:hover {
    transform: translateY(-3px); /* Pequeño salto al pasar el mouse */
    background-color: #07b0ff; /* Amarillo Westhill */
    color: #ffffff;
}

/* --- Listas de Enlaces --- */
.footer-links {
    list-style: none;
    padding-left: 0 !important; /* CRÍTICO: Quita el espacio oculto a la izquierda en todas las pantallas */
    margin: 0;
}

.footer-links li {
    margin-bottom: 12px; /* Separación vertical entre enlaces */
}

.footer-links li a {
    color: #ffffff !important; /* Forzamos color blanco */
    text-decoration: none;
    font-size: 1.05rem;
    transition: color 0.3s ease;
}

.footer-links li a:hover {
    color: #25a4ff !important; /* Amarillo al pasar el mouse */
}

/* --- Botón Verde de Admisiones --- */
.btn-admisiones {
    display: inline-block; 
    background-color: #38b04a; 
    color: #ffffff;
    padding: 8px 25px; 
    border-radius: 25px; 
    text-decoration: none;
    font-weight: 500;
    font-size: 1.05rem;
    transition: background-color 0.3s ease;
    
    /* NUEVO: Esto "jala" el botón 20px hacia arriba */
    margin-top: -30px; 
}

.btn-admisiones:hover {
    background-color: #2e963c; /* Verde más oscuro al hover */
    color: #ffffff;
}

/* =========================================
   BARRA BLANCA INFERIOR
   ========================================= */
.footer-bottom-bar {
    background-color: #ffffff;
    padding: 20px 0; /* Un poco más de aire para que se vea limpio */
}

.copy-text {
    color: #265b82; /* Texto azul */
    font-size: 0.95rem;
}

/* --- Lema Central --- */
.lema-institucional {
    text-align: center;
}

.lema-institucional .lema-latin {
    font-weight: bold;
    font-size: 1.15rem;
    margin: 0;
    color: #265b82;
}

.lema-institucional .lema-esp {
    font-size: 0.8rem;
    margin: 0;
    color: #265b82;
}

/* --- Enlace de Privacidad (Naranja/Coral) --- */
.privacidad-link {
    color: #ef5e4e; 
    text-decoration: none;
    font-size: 0.95rem;
}

.privacidad-link:hover {
    text-decoration: underline;
    color: #d14638; /* Naranja más oscuro al hover */
}

/* =========================================
   COMPORTAMIENTO RESPONSIVE (MÓVILES)
   ========================================= */
@media (max-width: 991px) {
    .footer-body {
        /* Ocultamos la imagen de la onda en pantallas pequeñas */
        background-image: none !important;
        background-color: #265b82;
        
        /* Reducimos el colchón de espacio porque ya no hay onda */
        padding-top: 60px; 
        padding-bottom: 50px;
    }
    
    /* Separación extra debajo del bloque de contacto en móvil */
    .contact-col {
        margin-bottom: 40px !important;
    }

    /* Modificamos el ítem de contacto para que el icono se ponga arriba del texto si no cabe */
    .contacto-item {
        flex-direction: column;
        margin-bottom: 15px;
    }

    .contacto-item i {
        margin-right: 0;
        margin-bottom: 5px;
        font-size: 1.3rem;
    }

    /* Aseguramos que la barra blanca inferior apile bien sus elementos */
    .footer-bottom-bar .row > div {
        margin-bottom: 15px;
    }
}
/****************************FIN INDEX************************************************/

/****************************NOSOTROS******************************************************/
/* =========================================
   SECCIÓN: NOSOTROS - HISTORIA
   ========================================= */

#nosotros-historia {
    background-color: #ffffff;
    width: 100%;
}

/* --- Contenedor de la Imagen --- */
.about-image-wrapper {
    /* Mantenemos la relación de aspecto y preparamos el borde */
    width: 100%;
    position: relative;
    overflow: hidden; /* Asegura que la imagen no se salga si hay zoom */
    
    /* Configuración de los bordes redondeados (tomada de la imagen original) */
    border-radius: 30px;
    
    /* Prepara la transición suave del efecto */
    transition: box-shadow 0.4s ease;
}

/* --- La Imagen Mismo --- */
.about-image {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Asegura que la imagen llene el contenedor sin deformarse */
    
    /* Imagen en escala de grises por defecto (como en la captura) */
    filter: grayscale(100%);
    
    /* Transición suave para todos los efectos (incluido el color si se cambia) */
    transition: all 0.4s ease;
}

/* --- EFECTO HOVER: Brillo (Glow) y Brillo (Brightness) --- */
.about-image-wrapper:hover {
    /* 1. Agrega una sombra de 'brillo' amarillo suave (como el de la universidad) */
    /* Sintaxis: box-shadow: horizontal vertical desenfoque extension color; */
    box-shadow: 0 0 20px 8px rgba(255, 193, 7, 0.5); /* Color amarillo Westhill con transparencia */
}

.about-image-wrapper:hover .about-image {
    /* 2. Aumenta el brillo y el contraste de la foto de forma sutil */
    filter: grayscale(100%) brightness(1.2) contrast(1.1);
}

/* --- Estilos de Texto --- */
.about-content .about-title {
    color: #265b82; /* Azul institucional */
    font-weight: 700; /* Negrita */
    font-size: 2.5rem; /* Título grande */
    margin: 0;
}

.about-content .about-text {
    color: #265b82; /* Texto oscuro para lectura fácil */
    font-size: 1.1rem; /* Un poco más grande para el cuerpo */
    line-height: 1.7; /* Espaciado entre líneas para descanso visual */
    margin-bottom: 20px; /* Separación entre párrafos */
    text-align: justify;
}

/* --- Adaptación para Móviles --- */
@media (max-width: 991px) {
    .about-content .about-title {
        font-size: 2rem; /* Título un poco más pequeño en móviles */
    }
}
/* =========================================
   SECCIÓN: FILOSOFÍA INSTITUCIONAL
   ========================================= */

#filosofia-institucional {
    background-color: #ffffff;
    width: 100%;
}

.filosofia-main-title {
    color: #265b82; /* Azul Westhill */
    font-weight: 700;
    font-size: 2.5rem;
    margin-bottom: 40px;
    font-family: 'Raleway', sans-serif;
}

/* --- Estilo de las tarjetas de Misión y Visión (Pastillas) --- */
.filosofia-card {
    border-radius: 60px; /* Forma de pastilla vertical */
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08); /* Sombra suave */
    transition: transform 0.3s ease;
}

.filosofia-card:hover {
    transform: translateY(-8px); /* Pequeña animación */
}

/* --- Colores de Fondo --- */
.filosofia-card.bg-verde {
    background-color: #38b04a; /* Verde Westhill */
}

.filosofia-card.bg-azul {
    background-color: #265b82; /* Azul Westhill */
}

/* --- Tipografía Interna --- */
.filosofia-card .card-title {
    font-size: 2.2rem;
    letter-spacing: 1px;
}

.filosofia-card .card-text {
    font-size: 1rem;
    line-height: 1.6;
}

/* Asegurar el justificado de texto para profesionalismo */
.text-justify {
    text-align: justify;
}

/* =========================================
   SECCIÓN: FILOSOFÍA INSTITUCIONAL
   ========================================= */

#filosofia-institucional {
    background-color: #ffffff;
    width: 100%;
}

.filosofia-main-title {
    color: #265b82; 
    font-weight: 700;
    font-size: 2.5rem;
    margin-bottom: 40px;
    font-family: 'Raleway', sans-serif;
}

/* --- Estilo de las tarjetas de Misión y Visión --- */
.filosofia-card {
    border-radius: 60px; /* Forma de pastilla */
    /* SOMBRA ACENTUADA: Más oscura y amplia para dar volumen */
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.18); 
    transition: transform 0.3s ease;
    height: 100%; /* Asegura que midan lo mismo */
}

.filosofia-card:hover {
    transform: translateY(-8px); 
}

.filosofia-card.bg-verde {
    background-color: #38b04a; 
}

.filosofia-card.bg-azul {
    background-color: #265b82; 
}

.filosofia-card .card-title {
    font-size: 2.2rem;
    letter-spacing: 1px;
    font-family: 'Raleway', sans-serif;
}

.filosofia-card .card-text {
    font-size: 1rem;
    line-height: 1.6;
}

.text-justify {
    text-align: justify;
}

/* =========================================
   SECCIÓN: FILOSOFÍA INSTITUCIONAL
   ========================================= */

#filosofia-institucional {
    background-color: #ffffff;
    width: 100%;
}

.filosofia-main-title {
    color: #265b82; 
    font-weight: 700;
    font-size: 2.5rem;
    margin-bottom: 40px;
    font-family: 'Raleway', sans-serif;
}

/* --- Estilo de las tarjetas de Misión y Visión --- */
.filosofia-card {
    border-radius: 60px; 
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.18); 
    transition: transform 0.3s ease;
    
    /* CAMBIO CLAVE: z-index alto para que estén POR ENCIMA del círculo */
    position: relative;
    z-index: 10; 
}

.filosofia-card:hover {
    transform: translateY(-8px); 
}

.filosofia-card.bg-verde {
    background-color: #38b04a; 
}

.filosofia-card.bg-azul {
    background-color: #265b82; 
}

.filosofia-card .card-title {
    font-size: 2.2rem;
    letter-spacing: 1px;
    font-family: 'Raleway', sans-serif;
}

.filosofia-card .card-text {
    font-size: 1rem;
    line-height: 1.6;
}

.text-justify {
    text-align: justify;
}

/* =========================================
   FOTOGRAFÍA CIRCULAR (CON SUPERPOSICIÓN POR DETRÁS)
   ========================================= */
.filosofia-photo-circle {
    width: 350px; 
    height: 350px;
    border-radius: 50% !important; 
    overflow: hidden; 
    border: 12px solid #ffffff; 
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.25); 
    
    /* CAMBIO CLAVE: z-index bajo para que quede POR DETRÁS de la tarjeta azul */
    position: relative;
    z-index: 1; 
    
    transition: transform 0.3s ease;
}

.filosofia-photo-circle:hover {
    transform: scale(1.03); 
}

.filosofia-photo {
    width: 100%;
    height: 100%;
    object-fit: cover; 
    object-position: center; 
}

/* =========================================
   TRUCO DE SOLAPAMIENTO Y RESPONSIVE
   ========================================= */

@media (min-width: 992px) {
    .filosofia-photo-circle {
        /* Jala la foto a la izquierda, pero ahora se esconde detrás de la tarjeta azul */
        margin-left: -90px; 
    }
}

@media (max-width: 991px) {
    .filosofia-main-title {
        font-size: 2rem;
        text-align: center;
    }

    .filosofia-photo-circle {
        width: 280px;
        height: 280px;
        margin-left: 0; 
        /* En móvil lo subimos para que se esconda debajo del borde inferior de la tarjeta azul */
        margin-top: -40px; 
    }
}
/* =========================================
   SECCIÓN: NOSOTROS - HISTORIA (CONTINUACIÓN)
   ========================================= */

#nosotros-historia-2 {
    background-color: #ffffff !important; /* Fondo gris muy claro para diferenciar secciones */
    width: 100%;
}

/* --- Estilos de Texto --- */
.about-content-2 .about-text-2 {
    color: #265b82; /* Texto oscuro para lectura fácil */
    font-size: 1.1rem; /* Mismo tamaño que la primera sección */
    line-height: 1.7; /* Espaciado entre líneas para descanso visual */
    margin-bottom: 20px; /* Separación entre párrafos */
    text-align: justify;
}

/* --- Contenedor de la Imagen --- */
.about-image-wrapper-2 {
    /* Mantenemos la relación de aspecto y preparamos el borde */
    width: 100%;
    position: relative;
    overflow: hidden; /* Asegura que la imagen no se salga si hay zoom */
    
    /* Configuración de los bordes redondeados (tomada de la imagen original) */
    border-radius: 30px;
    
    /* Prepara la transición suave del efecto */
    transition: box-shadow 0.4s ease, filter 0.4s ease;
}

/* --- La Imagen Mismo (Color) --- */
.about-image-2 {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Asegura que la imagen llene el contenedor sin deformarse */
    
    /* Transición suave para todos los efectos (incluido el color si se cambia) */
    transition: all 0.4s ease;
}

/* --- EFECTO HOVER: Brillo (Glow) y Brillo (Brightness) --- */
.about-image-wrapper-2:hover {
    /* 1. Agrega una sombra de 'brillo' amarillo suave (como el de la universidad) */
    /* Sintaxis: box-shadow: horizontal vertical desenfoque extension color; */
    box-shadow: 0 0 25px 10px rgba(255, 193, 7, 0.5); /* Color amarillo Westhill con transparencia */
}

.about-image-wrapper-2:hover .about-image-2 {
    /* 2. Aumenta el brillo y el contraste de la foto de forma sutil */
    filter: brightness(1.2) contrast(1.1);
}
/* =========================================
   SECCIÓN: VALORES, PRINCIPIOS Y LEMA
   ========================================= */

#valores-principios {
    background-color: #ffffff;
    width: 100%;
}

/* --- Tipografía de Títulos y Textos --- */
.vp-title {
    color: #265b82; /* Azul Westhill */
    font-weight: 700;
    font-size: 2.2rem;
    margin-bottom: 10px;
    font-family: 'Raleway', sans-serif;
}

.vp-text {
    color: #3b6b8c; /* Azul más suave para los párrafos */
    font-size: 1.25rem;
    line-height: 1.6;
    font-weight: 400;
}

/* --- Círculo de la Fotografía --- */
.valores-photo-circle {
    width: 100%;
    max-width: 480px; /* Tamaño máximo que alcanzará en PC */
    
    /* EL TRUCO MODERNO: Fuerza a que la caja siempre sea cuadrada */
    aspect-ratio: 1 / 1; 
    
    border-radius: 50%; /* La vuelve un círculo */
    overflow: hidden;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1); /* Sombra suave y elegante */
    transition: transform 0.4s ease;
}

.valores-photo-circle:hover {
    transform: scale(1.02); /* Ligero zoom al pasar el mouse */
}

/* --- Caja del Lema Institucional --- */
.lema-box {
    background-color: #265b82; /* Azul oscuro */
    border-radius: 50px; /* Borde estilo pastilla */
    padding: 20px 45px;
    display: inline-block; /* Hace que la caja envuelva al texto, no a toda la pantalla */
    box-shadow: 0 10px 25px rgba(38, 91, 130, 0.35); /* Sombra teñida de azul */
    transition: transform 0.3s ease;
}

.lema-box:hover {
    transform: translateY(-5px); /* Salto sutil al hover */
}

.lema-box-latin {
    color: #ffffff;
    font-weight: 800; /* Súper negrita */
    font-size: 1.8rem;
    font-family: 'Raleway', sans-serif;
}

.lema-box-esp {
    color: #ffffff;
    font-weight: 400;
    font-size: 1.1rem;
}

/* =========================================
   COMPORTAMIENTO RESPONSIVE (MÓVILES)
   ========================================= */
@media (max-width: 991px) {
    .valores-photo-circle {
        max-width: 320px; /* Círculo más pequeño en móvil */
    }
    
    .vp-title {
        font-size: 2rem;
    }
    
    .vp-text {
        font-size: 1.1rem;
    }

    .lema-box {
        padding: 15px 25px; /* Pastilla más compacta */
    }

    .lema-box-latin {
        font-size: 1.4rem;
    }
}
/* =========================================
   SECCIÓN: PORTAL ALGEBRAIX (IFRAME)
   ========================================= */

#portal-algebraix {
    background-color: #ffffff; 
    width: 100%;
}

.iframe-wrapper {
    width: 100%;
    /* Aseguramos una altura generosa para que quepa el portal de Algebraix sin necesidad de scroll */
    height: 750px; 
    
    border-radius: 30px; 
    /* ¡CRÍTICO! Esto corta cualquier elemento del iframe que intente salirse (como barras ocultas) */
    overflow: hidden; 
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.281); 
    
    animation: fadeIn 0.8s ease-in-out;
}

.iframe-wrapper iframe {
    width: 100%;
    height: 100%;
    border: none; 
}

/* =========================================
   ADAPTACIÓN PARA MÓVILES
   ========================================= */
@media (max-width: 991px) {
    .iframe-wrapper {
        height: 600px; /* Un poco más alto en móvil para que el formulario entre completo */
        border-radius: 20px;
    }
}
/* =========================================
   SECCIÓN: EVENTOS SEMANALES
   ========================================= */

#eventos-semanales {
    background-color: #ffffff; /* O el color de fondo que prefieras */
    width: 100%;
}

/* --- Estilo de las Tarjetas (Flyers) --- */
.evento-card {
    display: block; /* Necesario porque es una etiqueta <a> */
    border-radius: 20px; /* Bordes redondeados como en tu diseño */
    overflow: hidden; /* Evita que la imagen se salga de los bordes curvos */
    
    /* EFECTO 3D BASE: Sombra elegante y difuminada */
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15); 
    
    /* Prepara la animación para que sea fluida (0.4 segundos) */
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    height: 100%;
}

/* --- Imagen dentro de la tarjeta --- */
.evento-card img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Evita que la imagen se estire feo */
    
    /* TRUCO: Fuerza a que todas las tarjetas tengan proporción de flyer vertical (3 de ancho x 4 de alto) */
    aspect-ratio: 3 / 4; 
}

/* --- EFECTO HOVER: Movimiento y 3D --- */
.evento-card:hover {
    /* 1. Mueve la tarjeta 15 píxeles hacia arriba */
    transform: translateY(-15px); 
    
    /* 2. Hace la sombra más grande y oscura, dando el efecto de que "flota" más cerca de ti */
    box-shadow: 0 25px 45px rgba(0, 0, 0, 0.25); 
}
/* =========================================
   SECCIÓN: ATENCIÓN PSICOLÓGICA
   ========================================= */

#atencion-psicologica {
    background-color: #ffffff;
    width: 100%;
}

/* --- Estilo de la Imagen --- */
.img-psicologia {
    border-radius: 40px; /* Bordes muy redondeados como en tu diseño */
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08); /* Sombra elegante */
    object-fit: cover;
    width: 100%;
}

/* --- Tipografía y Textos --- */
.psicologia-title {
    color: #000000;
    font-weight: 700;
    font-size: 2.5rem;
    font-family: 'Raleway', sans-serif;
}

.psicologia-text {
    color: #333333;
    font-size: 1.15rem;
    line-height: 1.6;
}

.psicologia-subtitle {
    color: #333333;
    font-size: 1.15rem;
    font-weight: 600; /* Un poco más grueso para destacar */
}

/* --- Lista de Palomitas --- */
.psicologia-list li {
    font-size: 1.15rem;
    color: #333333;
    margin-bottom: 5px;
}
/* 1. Agregamos la transición a la clase que ya tienes para que el movimiento sea suave */
.img-psicologia {
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

/* 2. Creamos el efecto Hover (Un ligero zoom y la sombra se hace más profunda) */
.img-psicologia:hover {
    transform: scale(1.02); /* Crece un 2% */
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15); /* La sombra se expande */
}

/* --- Pastilla Verde ("Agenda tu cita") --- */
.badge-cita {
    background-color: #27ae60; /* Verde similar al de tu imagen */
    color: #ffffff;
    padding: 8px 22px;
    border-radius: 25px; /* Forma de pastilla redonda */
    font-weight: 500;
    font-size: 1.1rem;
    display: inline-block;
}

/* --- Teléfonos de Contacto --- */
.telefonos-cita a {
    font-size: 1.2rem;
    font-weight: 400;
    transition: color 0.3s ease;
}

.telefonos-cita a:hover {
    color: #27ae60 !important; /* Se pinta de verde al pasar el mouse */
}

.icon-green {
    color: #27ae60; /* Ícono verde */
    margin-right: 10px;
    font-size: 1.1rem;
}

/* =========================================
   COMPORTAMIENTO RESPONSIVE (MÓVILES)
   ========================================= */
@media (max-width: 991px) {
    .psicologia-title {
        font-size: 2rem;
        text-align: center;
    }
    
    /* Centramos los textos en pantallas pequeñas */
    .psicologia-text, 
    .psicologia-subtitle, 
    .psicologia-list {
        text-align: center;
    }
    
    /* Acomodamos la pastilla y los teléfonos para que queden centrados */
    .contacto-cita-box {
        flex-direction: column;
        justify-content: center;
        text-align: center;
        margin-top: 30px;
    }
    
    .telefonos-cita {
        margin-top: 15px;
    }
}
/* =========================================
   BUZÓN WESTHILL - FONDO AJUSTADO Y CENTRADO
   ========================================= */

.buzon-ajustado-bg {
    background-color: #225a84 !important;
    width: 100% !important;
    display: block !important; 
    
    /* Le damos el espaciado exacto arriba y abajo por separado */
    padding-top: 30px !important; 
    padding-bottom: 70px !important; /* Esto reemplaza a los 3 <br> */
    padding-left: 15px !important;
    padding-right: 15px !important;
    
    box-sizing: border-box !important;
}

.buzon-ajustado-card {
    background-color: #e8ebee !important;
    width: 100% !important;
    max-width: 950px !important;
    
    /* CENTRADO INFALIBLE: Mantiene la caja en medio pase lo que pase */
    margin: 0 auto !important; 
    
    border-radius: 30px !important;
    padding: 40px 50px !important;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15) !important;
    box-sizing: border-box !important;
}

.img-buzon-ajustado {
    max-height: 160px !important;
    width: auto !important;
    display: inline-block !important;
}

.texto-buzon-ajustado {
    font-size: 1.3rem !important;
    line-height: 1.4 !important;
    color: #111111 !important;
    font-family: 'Raleway', sans-serif !important;
    font-weight: 400 !important;
}

.texto-buzon-ajustado strong {
    font-weight: 800 !important;
}

.link-buzon-ajustado {
    color: #111111 !important;
    font-weight: 800 !important;
    text-decoration: underline !important;
    text-decoration-thickness: 2px !important;
    text-underline-offset: 3px !important;
    transition: color 0.3s ease, text-decoration-color 0.3s ease !important;
}

.link-buzon-ajustado:hover {
    color: #225a84 !important;
    text-decoration-color: #225a84 !important;
}

/* =========================================
   MÓVILES
   ========================================= */
@media (max-width: 768px) {
    .buzon-ajustado-bg {
        padding: 20px 10px !important; /* Aún más ajustado en celulares */
    }
    .buzon-ajustado-card {
        padding: 30px 20px !important;
        border-radius: 20px !important;
    }
    .texto-buzon-ajustado {
        font-size: 1.15rem !important;
    }
    .img-buzon-ajustado {
        max-height: 120px !important;
    }
}
/* =========================================
   SECCIÓN: BANNER DE AVISOS (PEGADO A LA DERECHA)
   ========================================= */

#banner-aviso {
    background-color: #ffffff; 
    width: 100%;
    overflow-x: hidden; /* Evita que genere barras de desplazamiento horizontales */
}

/* --- Contenedor Principal (La Sombra Amarilla) --- */
.aviso-wrapper {
    background-color: #f1c40f; 
    
    /* Curvamos solo las esquinas IZQUIERDAS */
    border-radius: 60px 0 0 60px; 
    
    /* Le damos un ancho máximo generoso, pero dejamos que se pegue a la derecha */
    width: 100%;
    max-width: 1050px; 
    margin-left: auto; /* Empuja la caja totalmente hacia la derecha */
    margin-right: 0;
    
    /* Sombra amarilla hacia abajo e izquierda */
    padding-top: 0px;
    padding-right: 0px; /* Cero padding derecho para que la caja azul toque el borde de la pantalla */
    padding-bottom: 20px; 
    padding-left: 20px;   
}

/* --- Caja Azul Principal --- */
.aviso-caja-azul {
    background-color: #225a84; 
    border-radius: 60px 0 0 60px; 
    padding: 45px 50px 45px 60px; /* Un poco más de espacio a la izquierda para respirar */
    height: 100%; 
}

/* --- Pastilla "AVISO" --- */
.badge-aviso {
    background-color: #3498db; 
    color: #ffffff;
    font-weight: 800;
    font-family: 'Raleway', sans-serif;
    font-size: 1.4rem;
    padding: 8px 25px;
    border-radius: 8px; 
    display: inline-block;
}

/* --- Textos --- */
.aviso-titulo {
    color: #ffffff !important;
    font-weight: 700;
    font-family: 'Raleway', sans-serif;
    font-size: 1.8rem;
    line-height: 1.3;
}

.aviso-texto-principal {
    color: #ffffff;
    font-size: 1.15rem;
    font-weight: 300; 
}

.aviso-link {
    color: #ffffff;
    text-decoration: underline;
    text-decoration-thickness: 1.5px;
    text-underline-offset: 3px;
    transition: color 0.3s ease;
}

.aviso-link:hover {
    color: #f1c40f; 
}

.aviso-texto-secundario {
    color: #ffffff;
    font-size: 1rem;
    font-weight: 300;
}

/* =========================================
   COMPORTAMIENTO RESPONSIVE (MÓVILES)
   ========================================= */
@media (max-width: 768px) {
    .aviso-wrapper {
        border-radius: 30px 0 0 30px; 
        padding-bottom: 10px;
        padding-left: 10px;
    }
    
    .aviso-caja-azul {
        border-radius: 30px 0 0 30px; 
        padding: 30px 20px;
        text-align: center; 
    }
    
    .aviso-titulo {
        font-size: 1.4rem;
    }
    
    .badge-aviso {
        margin-bottom: 15px; 
    }
}
/* =========================================
   SECCIÓN: CONTINUA TUS ESTUDIOS
   ========================================= */

/* --- Título Principal --- */
.estudios-main-title {
    color: #111111;
    font-weight: 700;
    font-size: 2.2rem;
    font-family: 'Raleway', sans-serif;
}

/* --- La Tarjeta Base --- */
.tarjeta-estudio {
    width: 100%;
    max-width: 320px; /* Ancho ideal para mantener la proporción de la foto */
    height: 480px; /* Tarjeta alta y elegante */
    
    background-color: #cccccc; /* Gris por si la imagen tarda en cargar */
    background-size: cover;
    background-position: center;
    
    border-radius: 25px; /* Bordes muy redondeados como en tu diseño */
    position: relative;
    overflow: hidden; /* Corta todo lo que se salga de los bordes curvos */
    
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15); /* Sombra 3D */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Un sutil salto hacia arriba de toda la tarjeta al pasar el ratón */
.tarjeta-estudio:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.25);
}

/* --- La Etiqueta Azul (Default) --- */
.etiqueta-estudio {
    position: absolute;
    bottom: 30px; /* Separada del fondo */
    left: 0; /* Pegada al borde izquierdo de la tarjeta */
    
    background-color: #225a84; /* Azul Westhill */
    color: #ffffff;
    font-weight: 700;
    font-size: 1.4rem;
    font-family: 'Raleway', sans-serif;
    
    /* Curva solo del lado derecho */
    padding: 12px 35px 12px 25px;
    border-radius: 0 30px 30px 0; 
    
    transition: opacity 0.4s ease;
    z-index: 2; /* Se mantiene por encima de la foto */
}

/* --- El Overlay Oscuro (Aparece al Hover) --- */
.overlay-estudio {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    
    background-color: rgba(30, 30, 30, 0.85); /* Gris muy oscuro transparente */
    
    display: flex;
    flex-direction: column;
    justify-content: flex-start; /* Alinea el contenido arriba */
    
    opacity: 0; /* Oculto por defecto */
    transition: opacity 0.4s ease;
    z-index: 3;
    
    overflow-y: auto; /* Permite hacer scroll interno si la lista es muy larga */
}

/* --- Animación al pasar el mouse --- */
.tarjeta-estudio:hover .overlay-estudio {
    opacity: 1; /* Revela la capa oscura y la lista */
}

.tarjeta-estudio:hover .etiqueta-estudio {
    opacity: 0; /* Oculta la etiqueta azul para que no estorbe */
}

/* --- Textos dentro del Overlay --- */
.overlay-titulo {
    color: #ffffff;
    font-weight: 800;
    font-size: 2rem;
    font-family: 'Raleway', sans-serif;
    border-bottom: 2px solid rgba(255, 255, 255, 0.2); /* Una línea sutil debajo del título */
    padding-bottom: 10px;
    margin-bottom: 15px;
}

.overlay-lista {
    color: #ffffff;
    padding-left: 20px; /* Sangría para las viñetas */
    margin: 0;
}

.overlay-lista li {
    font-size: 0.95rem;
    font-weight: 300;
    margin-bottom: 8px;
    line-height: 1.3;
}

/* =========================================
   MÓVILES
   ========================================= */
@media (max-width: 768px) {
    .tarjeta-estudio {
        height: 400px; /* Un poco más cortas en celular */
        max-width: 100%; /* Ocupan todo el ancho disponible */
    }
    
    .estudios-main-title {
        font-size: 1.8rem;
    }
}
/* =========================================
   SECCIÓN: BOLSA DE TRABAJO
   ========================================= */

#bolsa-trabajo {
    background-color: #ffffff;
    width: 100%;
}

/* --- Título Principal --- */
.titulo-bolsa {
    font-family: 'Raleway', sans-serif;
    font-weight: 600; /* Negrita media */
    font-size: 2.2rem;
    color: #111111;
}

.linea-titulo {
    width: 150px; /* Línea corta debajo del título */
    border: 0;
    border-top: 2px solid #e0e0e0; 
    margin: 0;
    opacity: 1;
}

/* --- La Tarjeta de Vacante --- */
.job-card {
    background: #ffffff;
    border: 1px solid #eaeaea; /* Borde gris muy tenue */
    border-radius: 2px; /* Esquinas casi cuadradas, muy corporativo */
    padding: 25px 25px 30px 25px; /* Espaciado interno generoso */
    height: 100%; /* Obliga a todas las tarjetas a medir lo mismo de alto */
    display: flex;
    flex-direction: column; /* Organiza el interior en columna */
    transition: box-shadow 0.3s ease;
}

/* Efecto opcional: sombra sutil al pasar el mouse */
.job-card:hover {
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05); 
}

/* --- Encabezado de la Tarjeta (Línea divisoria) --- */
.job-header {
    border-bottom: 1px solid #eaeaea; /* Línea que separa el logo del texto */
    padding-bottom: 15px;
    margin-bottom: 20px;
}

.job-logo {
    max-width: 70px; /* Tamaño del logo */
    max-height: 40px;
    object-fit: contain; /* Evita que el logo se deforme */
}

.job-company {
    font-size: 0.9rem;
    color: #999999; /* Texto gris claro para el nombre de la empresa */
    font-weight: 600;
    text-align: right;
    max-width: 60%;
    line-height: 1.2;
}

/* --- Cuerpo (Textos) --- */
.job-body {
    margin-bottom: 25px;
}

.job-text {
    font-size: 0.85rem;
    color: #777777; /* Gris medio */
    margin-bottom: 10px;
    line-height: 1.5;
}

.job-text strong {
    color: #333333; /* Resalta las palabras Puesto y Sueldo en oscuro */
    font-weight: 700;
}

/* --- Botón "VER VACANTE" --- */
.btn-vacante {
    background-color: #225a84; /* Azul institucional */
    color: #ffffff;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 10px 25px;
    text-decoration: none;
    display: inline-block;
    border-radius: 2px;
    letter-spacing: 0.5px; /* Separa un poco las letras */
    transition: background-color 0.3s ease;
}

.btn-vacante:hover {
    background-color: #174060; /* Azul más oscuro al pasar el ratón */
    color: #ffffff;
}
/* =========================================
   SECCIÓN: AVISO IMPORTANTE (SALUD)
   ========================================= */

#aviso-salud {
    background-color: #ffffff;
    width: 100%;
}

/* --- Contenedor y efecto de la Imagen --- */
.aviso-img-wrapper {
    overflow: hidden; /* Asegura que al crecer la imagen no se salga de sus bordes redondeados */
    border-radius: 30px; /* Bordes suaves como en el diseño */
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.671); /* Sombra muy sutil */
    
    /* Limitamos un poco el ancho para que coincida con la proporción de tu foto */
    max-width: 450px; 
    margin: 0 auto; /* Centra la imagen si la pantalla es más pequeña */
}

.aviso-img {
    width: 100%;
    height: auto;
    object-fit: cover;
    
    /* Preparamos la animación para que sea suave (0.4 segundos) */
    transition: transform 0.4s ease; 
}

/* El efecto HOVER: Crece un 4% al pasar el mouse */
.aviso-img-wrapper:hover .aviso-img {
    transform: scale(1.04); 
}

/* --- Tipografía --- */
.aviso-titulo {
    color: #111111;
    font-size: 2.6rem; /* Título grande y llamativo */
    line-height: 1.2;
    font-family: 'Raleway', sans-serif;
    font-weight: 300; /* Peso ligero para la segunda mitad del texto */
    text-align: center;
}

.aviso-titulo strong {
    font-weight: 800; /* Peso muy grueso para "Aviso Importante" */
}

.aviso-texto {
    color: #444444; /* Gris oscuro para lectura cómoda */
    font-size: 1.15rem;
    line-height: 1.6;
    font-family: 'Raleway', sans-serif;
    font-weight: 400;
    text-align: justify;
    margin-bottom: 15px; /* Separación entre los párrafos */
}

/* =========================================
   MÓVILES
   ========================================= */
@media (max-width: 991px) {
    .aviso-titulo {
        font-size: 2rem;
        text-align: center;
        margin-top: 20px;
    }
    
    .aviso-texto {
        font-size: 1.05rem;
        text-align: justify; /* Justificado en móviles suele verse más ordenado, o puedes cambiarlo a center */
    }
}
/* =========================================
   SECCIÓN: CAMINATA WESTHILL / ARTÍCULOS
   ========================================= */

#caminata-westhill {
    background-color: #ffffff; /* Fondo blanco limpio */
    width: 100%;
}

/* --- Textos --- */
.caminata-titulo {
    color: #111111; /* Casi negro para máximo contraste */
    font-family: 'Raleway', sans-serif;
    font-weight: 800; /* Letra gruesa como en tu diseño */
    font-size: 2.8rem;
    line-height: 1.2;
}

.caminata-texto {
    color: #333333; /* Gris oscuro para lectura cómoda */
    font-family: 'Raleway', sans-serif;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1.6;
    text-align: justify; /* Justificado perfecto como solicitaste */
}

/* --- Contenedor y efecto de la Imagen (Igual al de salud) --- */
.caminata-img-wrapper {
    overflow: hidden; /* Esto es vital: corta la imagen cuando crece para no perder el borde curvo */
    border-radius: 35px; /* Bordes bien redondeados según tu foto */
    margin: 0 auto; 
    max-width: 500px; /* Ancho máximo para mantener buena proporción */
}

.caminata-img {
    width: 100%;
    height: auto;
    object-fit: cover;
    
    /* La transición para que el zoom sea suave */
    transition: transform 0.4s ease; 
}

/* El Efecto: Crece un 4% al hacer hover */
.caminata-img-wrapper:hover .caminata-img {
    transform: scale(1.04); 
}

/* =========================================
   MÓVILES Y TABLETS
   ========================================= */
@media (max-width: 991px) {
    .caminata-titulo {
        font-size: 2.2rem;
    }
    
    .caminata-texto {
        font-size: 1.05rem;
    }
    
    .caminata-img-wrapper {
        margin-top: 15px; /* Un poco de aire arriba de la foto cuando pasa a estar debajo del texto */
    }
}
/* =========================================
   SECCIÓN: ACTIVIDADES WEST
   ========================================= */
/* --- Título --- */
.actividades-titulo {
    color: #225a84;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 2.5rem;
    text-align: left; 
}

/* --- ESTA ES LA CORRECCIÓN CLAVE --- */
.row-actividades {
    /* 90px para compensar la foto + 30px de aire visual = 120px */
    margin-top: 120px !important; 
}

/* --- (El resto de tu CSS para .actividad-card, .actividad-img-wrapper se queda igual) --- */

/* --- La Tarjeta Base (Fondo Azul) --- */
.actividad-card {
    background-color: #225a84; /* Color base */
    
    /* Agregamos una marca de agua de fondo (Asegúrate de tener un PNG transparente blanco/claro) */
    background-image: url('img/marca-agua.png');/*actividades west*/
    background-size: contain;
    background-position: bottom center;
    background-repeat: no-repeat;
    
    width: 78%;
    max-width: 350px; /* Limita el ancho para que no se vea desproporcionada */
    
    /* Bordes: Curvos arriba (para seguir la foto) y abajo */
    border-radius: 40px; 
    
    position: relative; /* CRUCIAL: Permite posicionar la foto de forma absoluta adentro */
    
    /* El padding superior es gigante (110px) para dejar espacio interno a la foto que entra desde arriba */
    padding: 110px 30px 40px 30px;
    
    /* Sombra para despegarlo del fondo blanco */
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    transition: transform 0.3s ease;
}

.actividad-card:hover {
    transform: translateY(-5px); /* Pequeño salto al pasar el mouse */
}

/* --- La Imagen Superpuesta --- */
.actividad-img-wrapper {
    position: absolute;
    
    /* La mitad de su altura (180/2 = 90) para que quede exactamente a la mitad del borde superior */
    top: -90px; 
    left: 50%;
    transform: translateX(-50%); /* Lo centra horizontalmente de forma perfecta */
    
    width: 180px;
    height: 180px;
    border-radius: 50%; /* Lo hace un círculo perfecto */
    
    /* Borde grueso del mismo color que la tarjeta para simular el "cuello" */
    border: 8px solid #225a84; 
    
    background-color: #ffffff;
    overflow: hidden;
    z-index: 2; /* Asegura que esté por encima del fondo */
}

.actividad-img-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Evita que las fotos se aplasten */
}

/* --- Textos Internos --- */
.actividad-content {
    text-align: center;
    color: #ffffff;
    position: relative;
    z-index: 3; /* Asegura que el texto esté por encima de la marca de agua */
}

.actividad-card-title {
    font-size: 1.3rem;
    font-weight: 700;
    font-family: 'Raleway', sans-serif;
    margin-bottom: 20px;
    line-height: 1.2;
}

.actividad-card-text {
    font-size: 0.95rem;
    font-weight: 300;
    line-height: 1.5;
    text-align: justify;
    margin: 0;
}

/* =========================================
   MÓVILES
   ========================================= */
@media (max-width: 768px) {
    .actividades-titulo {
        text-align: center;
        font-size: 2rem;
    }
    
    .actividad-card {
        margin-top: 80px; /* Margen un poco más chico en móvil */
        padding: 100px 20px 30px 20px;
    }
}

/* =========================================
   REGLAMENTOS - TÍTULOS AL BORDE IZQUIERDO
   ========================================= */

.titulos-borde-izquierdo {
    width: 100%;
    margin: 0;
}

.badge-reglamentos {
    background-color: #225a84;
    color: #ffffff;
    font-family: 'Raleway', sans-serif;
    font-weight: 800;
    font-size: 2.2rem;
    display: inline-block; 
    padding: 10px 40px 10px 50px; 
    border-radius: 0 40px 40px 0;
}

.titulo-normativas {
    color: #225a84;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 2.2rem;
    padding-left: 50px;
}

/* =========================================
   TARJETAS - REGLAMENTOS"
   ========================================= */

.tarjeta-documento {
    display: block;
    width: 100%;
    height: 380px;
    border-radius: 15px;
    position: relative;
    overflow: hidden; /* Mantiene el zoom de la foto dentro de la tarjeta */
    text-decoration: none;
    background-color: #f8f9fa;
    
    /* Sombra normal */
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    
    /* Transición para el movimiento de la tarjeta */
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

/* === HOVER DE LA TARJETA (Elevación y Sombra profunda) === */
.tarjeta-documento:hover {
    transform: translateY(-10px) !important; /* Flota 10px arriba */
    box-shadow: 0 20px 40px rgba(0,0,0,0.3) !important; /* Sombra intensa */
}

/* --- La imagen de fondo (Div interno) --- */
.img-fondo-doc {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    z-index: 1;
    
    /* Transición para el zoom */
    transition: transform 0.4s ease;
}

/* === HOVER DE LA IMAGEN (Zoom 1.05) === */
.tarjeta-documento:hover .img-fondo-doc {
    transform: scale(1.05); /* La foto crece un 5% */
}

/* --- Overlay oscuro (Hover) --- */
.doc-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(224, 28, 28, 0.92); 
    opacity: 0;
    transition: opacity 0.35s ease;
    z-index: 2; /* Por encima de la foto */
    padding: 30px 25px;
}

.tarjeta-documento:hover .doc-overlay {
    opacity: 1;
}

.doc-titulo {
    color: #ffffff;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 1.2;
}

/* =========================================
   RESPONSIVE
   ========================================= */
@media (max-width: 768px) {
    .badge-reglamentos, .titulo-normativas { padding-left: 20px; }
    .badge-reglamentos { font-size: 1.8rem; }
    .titulo-normativas { font-size: 1.8rem; }
    .tarjeta-documento { max-width: 320px; margin: 0 auto; }
}
/* --- El "Enlace" Centrado en el Overlay --- */
.doc-btn-centrado {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Lo ancla en el centro matemático perfecto */
    
    color: #ffffff;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: .8 rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-align: center;
    
    /* Diseño tipo botón "fantasma" */
    border: 2px solid #ffffff;
    padding: 10px 24px;
    border-radius: 30px;
    
    /* Transición si el mouse pasa sobre el botón mismo */
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Efecto al pasar el mouse por encima del botón específicamente */
.doc-btn-centrado:hover {
    background-color: #ffffff;
    color: #225a84; /* Cambia a tu azul institucional */
}


/* =========================================
   SECCIÓN: PUERTA AL CONOCIMIENTO
   ========================================= */

#puerta-conocimiento {
    background-color: #ffffff;
    width: 100%;
}

/* --- Título principal --- */
.titulo-conocimiento {
    color: #111111;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 2.5rem;
    line-height: 1.2;
}

/* --- Párrafos --- */
.texto-conocimiento {
    color: #333333;
    font-family: 'Raleway', sans-serif;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1.6;
    text-align: justify;
    margin-bottom: 20px;
}

/* --- Imagen con bordes curvos --- */
.img-conocimiento {
    width: 100%;
    height: auto;
    
    /* Bordes bien redondeados idénticos a la sección anterior */
    border-radius: 25px; 
    
    object-fit: cover;
    
    /* Efecto hover suave (opcional para consistencia) */
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.img-conocimiento:hover {
    transform: scale(1.02);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

/* =========================================
   MÓVILES Y TABLETS
   ========================================= */
@media (max-width: 991px) {
    .titulo-conocimiento {
        font-size: 2rem;
    }
    
    .texto-conocimiento {
        font-size: 1.05rem;
    }
}
/* =========================================
   SECCIÓN: BANNER BIBLIOTECA (EFECTO SHINE)
   ========================================= */

/* --- Ajustes del contenedor del banner --- */
.banner-biblioteca {
    position: relative;
    width: 100%;
    height: 60vh; /* Altura del banner (60% de la pantalla) */
    min-height: 400px;
    
    /* VITAL: Evita que el brillo genere scroll horizontal cuando sale por la derecha */
    overflow: hidden; 
    
    background-color: #1a1a1a; /* Fondo por si la imagen tarda en cargar */
    cursor: pointer;
}

/* --- Ajuste de la imagen --- */
.banner-biblioteca img {
    width: 100%;
    height: 100%;
    
    /* COVER es la magia: llena el espacio sin deformar la foto */
    object-fit: cover; 
    object-position: center;
}

/* --- (Opcional) Texto centrado sobre el banner --- */
.texto-encima {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3; /* Por encima del brillo */
    color: white;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
    text-align: center;
    pointer-events: none; /* Para que no interrumpa el hover */
}

/* =========================================
   SECCIÓN: BANNER BIBLIOTECA (EFECTO SHINE)
   ========================================= */

/* --- Aseguramos que el contenedor general tome el 100% --- */
.hover14 {
    width: 100%;
    display: block;
    overflow: hidden;
}

/* --- Ajustes del Banner --- */
.banner-biblioteca {
    position: relative;
    width: 100%;
    height: 60vh; /* Altura del banner (60% de la pantalla) */
    min-height: 400px; /* Altura mínima para celulares */
    margin: 0; /* VITAL: Quita márgenes por defecto del navegador */
    padding: 0;
    overflow: hidden;
    background-color: #1a1a1a;
    cursor: pointer;
    display: block;
}

/* --- La Imagen (Magia del Cover) --- */
.img-banner {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Llena el espacio SIN deformar la foto */
    object-position: center; /* Mantiene el centro de la foto visible */
    display: block;
}

/* --- Texto centrado sobre el banner --- */
.texto-encima {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3; /* Por encima de la imagen y del brillo */
    color: #ffffff;
    text-align: center;
    pointer-events: none; /* No bloquea el hover del ratón */
}

/* Diseño del título */
.texto-encima h2 {
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 3.5rem; /* Letra grande para el banner */
    margin: 0;
    /* Sombra oscura para que se lea perfecto sobre cualquier foto */
    text-shadow: 2px 2px 10px rgba(0,0,0,0.8); 
}

/* =========================================================
   EFECTO COMBINADO: SHINE + ZOOM
========================================================= */

/* Contenedor principal de la imagen */
.hover14 figure {
    position: relative;
    overflow: hidden; /* CRUCIAL: Corta la imagen para que el zoom no se salga de los bordes*/
    margin: 0;        /* Reseteo de márgenes por defecto*/
    background: #000; /* Fondo negro por si la imagen tarda en cargar*/
}

/* Ajustes de la imagen para que ocupe el ancho y responda al zoom */
.hover14 figure img {
    display: block;   /* Quita espacios extra abajo*/
    width: 100%;      /* Ocupa todo el ancho*/
    height: auto;     /* Mantiene proporción*/
    
    /* PREPARACIÓN PARA ZOOM: Indica qué propiedad animar y cuánto tiempo*/
    -webkit-transition: -webkit-transform 0.75s ease;
    transition: transform 0.75s ease; /* Sincronizado con la duración del brillo*/
}

/* --- EL ZOOM ---
   Cuando se pasa el mouse por el figure, escalamos la imagen un 10%*/
.hover14 figure:hover img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1); /* Agranda la imagen un 10%*/
}


/* =========================================
   SECCIÓN: BANNER BIBLIOTECA (SHINE + ZOOM)
   ========================================= */

/* --- Contenedor Principal --- */
.hover14 {
    width: 100%;
    display: block;
}

/* --- El Banner (Figure) --- */
.hover14 figure.banner-biblioteca {
    position: relative;
    width: 100%;
    height: 60vh; /* La altura de tu banner */
    min-height: 400px;
    margin: 0;
    padding: 0;
    
    /* VITAL: Corta la imagen para que el zoom y el brillo no se salgan */
    overflow: hidden; 
    
    background-color: #1a1a1a;
    cursor: pointer;
    display: block;
}

/* --- LA IMAGEN CORREGIDA --- */
.hover14 figure.banner-biblioteca img.img-banner {
    display: block;
    width: 100%;
    
    /* ESTA FUE LA CORRECCIÓN CLAVE: 100% en lugar de auto */
    height: 100%; 
    
    /* COVER: Mantiene la proporción perfecta recortando lo que sobra */
    object-fit: cover; 
    object-position: center;
    
    /* Preparación para el zoom suave */
    -webkit-transition: -webkit-transform 0.75s ease;
    transition: transform 0.75s ease;
}

/* --- EL ZOOM (Al pasar el ratón) --- */
.hover14 figure.banner-biblioteca:hover img.img-banner {
    /* Un zoom sutil del 5% para que se vea elegante */
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
}

/* --- Texto centrado sobre el banner --- */
.texto-encima {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3; /* Por encima de la imagen y del brillo */
    color: #ffffff;
    text-align: center;
    pointer-events: none; /* No interrumpe el hover del ratón */
}

.texto-encima h2 {
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 4rem; /* Tamaño de letra grande */
    margin: 0;
    text-shadow: 2px 2px 10px rgba(0,0,0,0.8); /* Sombra para legibilidad */
}

/* =========================================
   EFECTO SHINE (BRILLO)
   ========================================= */

.hover14 figure.banner-biblioteca::before {
    position: absolute;
    top: 0;
    left: -100%;
    z-index: 2;
    display: block;
    content: '';
    width: 50%;
    height: 100%;
    background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
    background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
    -webkit-transform: skewX(-25deg);
    transform: skewX(-25deg);
}

.hover14 figure.banner-biblioteca:hover::before {
    -webkit-animation: shine 0.75s;
    animation: shine 0.75s;
}

@-webkit-keyframes shine {
    100% { left: 125%; }
}

@keyframes shine {
    100% { left: 125%; }
}

/* =========================================
   MÓVILES
   ========================================= */
@media (max-width: 768px) {
    .texto-encima h2 {
        font-size: 2.5rem; /* Letra un poco más chica en celulares */
    }
}
/* =========================================
   SECCIÓN: EXPERIENCIA BIBLIOTECA
   ========================================= */

#experiencia-biblioteca {
    background-color: #ffffff; /* Fondo blanco */
    width: 100%;
}

/* --- Título principal --- */
.titulo-experiencia {
    color: #111111; /* Casi negro */
    font-family: 'Raleway', sans-serif;
    font-weight: 700; /* Negrita */
    font-size: 2.5rem;
    line-height: 1.2;
}

/* --- Párrafos --- */
.texto-experiencia {
    color: #333333; /* Gris oscuro para lectura cómoda */
    font-family: 'Raleway', sans-serif;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1.6;
    text-align: justify;
}

/* --- Lista con viñetas --- */
.lista-experiencia {
    color: #333333;
    font-family: 'Raleway', sans-serif;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1.6;
    padding-left: 2rem; /* Deja espacio para los puntos de la lista */
}

.lista-experiencia li {
    margin-bottom: 6px; /* Separación sutil entre cada punto */
}

/* --- Imagen con bordes curvos --- */
.img-experiencia {
    width: 100%;
    height: auto;
    
    /* Recrea los bordes muy redondeados de tu diseño */
    border-radius: 25px; 
    
    object-fit: cover;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

/* Leve interactividad al pasar el mouse */
.img-experiencia:hover {
    transform: scale(1.02);
    box-shadow: 0 10px 25px rgba(0,0,0,0.1); /* Sombra suave */
}

/* =========================================
   MÓVILES Y TABLETS
   ========================================= */
@media (max-width: 991px) {
    .titulo-experiencia {
        font-size: 2rem;
    }
    
    .texto-experiencia, .lista-experiencia {
        font-size: 1.05rem;
    }
    
    /* Da más espacio entre el último párrafo y la foto cuando se apilan */
    .img-experiencia {
        margin-top: 20px; 
    }
}
/* =========================================
   SECCIÓN AISLADA: BIBLIOTECA VIRTUAL (MARQUEE)
   ========================================= */

#seccion-biblioteca-virtual .bv-titulo {
    color: #000000;
    font-family: 'Raleway', sans-serif;
    font-weight: 800;
    font-size: 2.5rem;
    margin-bottom: 2rem;
}

#seccion-biblioteca-virtual .bv-slider-contenedor {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 20px 0;
}

/* Difuminado lateral */
#seccion-biblioteca-virtual .bv-slider-contenedor::before,
#seccion-biblioteca-virtual .bv-slider-contenedor::after {
    content: "";
    position: absolute;
    top: 0;
    width: 150px;
    height: 100%;
    z-index: 2;
}

#seccion-biblioteca-virtual .bv-slider-contenedor::before {
    left: 0;
    background: linear-gradient(to right, #f8f9fa00 0%, rgba(248, 249, 250, 0) 100%);
}

#seccion-biblioteca-virtual .bv-slider-contenedor::after {
    right: 0;
    background: linear-gradient(to left, #ffffff00 0%, rgba(248, 249, 250, 0) 100%);
}

/* Pista de movimiento */
#seccion-biblioteca-virtual .bv-slider-track {
    display: flex;
    align-items: center;
    width: calc(250px * 8); /* Ajusta a la cantidad total de logos */
    animation: scrollLogosBiblioteca 25s linear infinite;
}

#seccion-biblioteca-virtual .bv-slider-contenedor:hover .bv-slider-track {
    animation-play-state: paused;
}

/* Contenedor individual del logo */
#seccion-biblioteca-virtual .bv-logo-item {
    width: 250px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 30px;
}

/* Imagen del logo controlada y aislada */
#seccion-biblioteca-virtual .bv-logo-item img {
    width: 100%;
    max-height: 90px;
    object-fit: contain;
    display: block; /* Evita que herede estilos de display inline */
    margin: 0;
    padding: 0;
}

/* Animación con nombre único para evitar choques */
@keyframes scrollLogosBiblioteca {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc(-250px * 4)); } /* Ajustar si pones más/menos logos */
}

/* Responsive */
@media (max-width: 768px) {
    #seccion-biblioteca-virtual .bv-titulo {
        font-size: 2rem;
    }
    #seccion-biblioteca-virtual .bv-slider-contenedor::before,
    #seccion-biblioteca-virtual .bv-slider-contenedor::after {
        width: 50px;
    }
}
/*informaicon*/
/* =========================================
   SECCIÓN AISLADA: OPORTUNIDAD WESTHILL
   ========================================= */

#oportunidad-westhill {
    background-color: #ffffff;
    padding: 80px 0 150px 0; /* 150px de espacio abajo para el footer */
    position: relative;
    overflow: hidden; 
}

/* --- Título --- */
#oportunidad-westhill .titulo-oportunidad {
    color: #000000;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 2.5rem;
    line-height: 1.2;
}

/* --- Contenedor del Formulario (Sin fondo, sin sombra) --- */
#oportunidad-westhill .contenedor-formulario {
    /* Establecemos una altura mínima compartida para que ambos lados midan igual */
    min-height: 700px; 
    width: 100%;
}

/* --- Iframe del Formulario --- */
#oportunidad-westhill .iframe-smartsheet {
    width: 100%;
    height: 100%;
    min-height: 700px;
    border: none;
    background: transparent !important;
    overflow: hidden;
}

/* --- Contenedor de la Imagen Derecha (Igualando tamaño) --- */
#oportunidad-westhill .contenedor-imagen-oportunidad {
    width: 100%;
    min-height: 700px; /* Exactamente la misma altura mínima que el formulario */
    border-radius: 15px;
    overflow: hidden; /* VITAL para que la imagen no se desborde al hacer zoom */
    
    /* Opcional: Una leve sombra para que la foto destaque */
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08); 
}

/* --- La Imagen (Magia del Cover) --- */
#oportunidad-westhill .img-oportunidad {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Llena el espacio sin deformarse */
    object-position: center;
    display: block;
    
    /* Prepara el movimiento suave */
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease; 
}

/* --- EFECTO HOVER DE LA IMAGEN --- */
#oportunidad-westhill .contenedor-imagen-oportunidad:hover .img-oportunidad {
    /* Hace un zoom del 5% hacia adentro al pasar el mouse */
    -webkit-transform: scale(1.05);
    transform: scale(1.05); 
}


/* --- Responsivo para Celulares --- */
@media (max-width: 991px) {
    #oportunidad-westhill .titulo-oportunidad {
        font-size: 2rem;
    }
    
    /* En móviles la imagen ya no necesita forzar la misma altura que el form */
    #oportunidad-westhill .contenedor-imagen-oportunidad {
        min-height: 400px;
    }
}
/* =========================================
   SECCIÓN AISLADA: CONVENIOS CON EMPRESAS
   ========================================= */

#seccion-convenios {
    background-color: #ffffff; /* Fondo blanco limpio */
    padding: 60px 0;
    width: 100%;
}

/* --- Título Principal --- */
#seccion-convenios .titulo-convenio {
    color: #1a4b82; /* Azul oscuro similar al de tu diseño */
    font-family: 'Raleway', sans-serif;
    font-weight: 600; /* Semi-negrita */
    font-size: 2.2rem;
}

/* --- Logo de la Empresa --- */
#seccion-convenios .logo-convenio {
    max-width: 85%; /* Evita que el logo sea demasiado invasivo */
    height: auto;
    display: inline-block;
}

/* --- Subtítulo (Semillero de Talentos) --- */
#seccion-convenios .subtitulo-convenio {
    color: #000000;
    font-family: 'Raleway', sans-serif;
    font-size: 2.2rem;
    font-weight: 400; /* Peso normal para la palabra "Talentos" */
    line-height: 1.2;
    margin-bottom: 1.5rem;
}

/* Fuerza el texto en negrita dentro del subtítulo */
#seccion-convenios .subtitulo-convenio strong {
    font-weight: 800; /* Extra negrita para destacar */
}

/* --- Párrafo de texto --- */
#seccion-convenios .texto-convenio {
    color: #333333; /* Gris oscuro para facilitar la lectura */
    font-family: 'Raleway', sans-serif;
    font-size: 1.05rem;
    line-height: 1.6;
    text-align: justify; /* Texto justificado como en la imagen de referencia */
}

/* =========================================
   AJUSTES PARA MÓVILES (Responsivo)
   ========================================= */
@media (max-width: 768px) {
    #seccion-convenios .titulo-convenio {
        font-size: 1.8rem;
        text-align: center; /* Centramos el título en celulares */
    }
    
    #seccion-convenios .subtitulo-convenio {
        font-size: 1.8rem;
        text-align: center; /* Centramos el subtítulo en celulares */
    }
    
    #seccion-convenios .logo-convenio {
        max-width: 60%; /* Reducimos un poco el logo en pantallas pequeñas */
    }
}
/* =========================================
   SECCIÓN: CONVENIOS ESCOLARES
   ========================================= */

#seccion-convenios-escolares {
    background-color: #2b5f8c; 
    width: 100%;
    overflow: hidden; 
    font-family: 'Raleway', sans-serif;
    
    /* AÑADIDO: Espaciado interno para centrar todo visualmente */
    padding-top: 20px; 
    padding-bottom: 80px; /* Crea el espacio azul debajo de la segunda cinta */
}
#seccion-convenios-escolares .ce-titulo {
    color: #ffffff;
    font-weight: 600;
    font-size: 2.5rem;
}

#seccion-convenios-escolares .ce-label-buscar {
    font-size: 1.1rem;
}

#seccion-convenios-escolares .ce-input-buscar {
    width: 250px;
    border-radius: 5px;
    border: none;
    padding: 8px 15px;
}

#seccion-convenios-escolares .ce-badge-verde {
    background-color: #28a745; /* Verde del botón */
    color: white;
    padding: 5px 15px;
    border-radius: 20px;
    font-weight: 500;
}

/* --- ESTILOS DE LOS LOGOS CIRCULARES --- */
#seccion-convenios-escolares .ce-logo-item {
    width: 160px; /* Ancho fijo para los círculos */
    height: 160px; /* Alto fijo, igual al ancho para que sea un círculo perfecto */
    background-color: #ffffff; /* Fondo blanco */
    border-radius: 50%; /* Hace que sea un círculo */
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 20px; /* Espaciado entre cada logo */
    flex-shrink: 0;
    overflow: hidden; /* Corta lo que se salga del círculo */
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}
/* 2. Regla extra para asegurar que la segunda cinta no empuje elementos de más */
#seccion-convenios-escolares .ce-slider-cinta:last-child {
    margin-bottom: 0 !important; /* Elimina márgenes extra por debajo de la última cinta */
}

#seccion-convenios-escolares .ce-logo-item img {
    max-width: 85%;
    max-height: 85%;
    object-fit: contain; /* Ajusta la imagen sin deformarla */
}

/* --- ANIMACIONES DE LAS CINTAS --- */
/* --- ANIMACIONES DE LAS CINTAS --- */
#seccion-convenios-escolares .ce-slider-cinta {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: 10px 0;
}

#seccion-convenios-escolares .ce-track {
    display: flex;
    align-items: center;
    /* max-content hace que crezca infinitamente según el número de logos
       evitando que se corte en pantallas de alta resolución */
    width: max-content; 
}

/* Animación hacia la Izquierda (Cinta Superior) */
#seccion-convenios-escolares .ce-track-izq {
    animation: moverIzquierda 20s linear infinite;
}

/* Animación hacia la Derecha (Cinta Inferior) */
#seccion-convenios-escolares .ce-track-der {
    /* Empezamos en -50% y vamos a 0 para que se mueva al lado contrario */
    animation: moverDerecha 20s linear infinite;
}

/* Pausar al pasar el ratón */
#seccion-convenios-escolares .ce-slider-cinta:hover .ce-track {
    animation-play-state: paused;
}

/* Fotogramas Clave (Keyframes) */
@keyframes moverIzquierda {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); } /* Se mueve la mitad de su ancho total */
}

@keyframes moverDerecha {
    0% { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

/* --- CUADRÍCULA PARA LOS RESULTADOS DE BÚSQUEDA --- */
#seccion-convenios-escolares .ce-grid-resultados {
    display: flex;
    flex-wrap: wrap; /* Permite que bajen a la siguiente línea */
    gap: 20px;
    justify-content: center;
    padding: 20px 0;
}
/* =========================================
   SECCIÓN AISLADA: CONVENIO INTERNACIONAL
   ========================================= */

#convenio-internacional {
    background-color: #ffffff; /* Fondo blanco limpio */
    padding: 80px 0;
    width: 100%;
}

/* --- Estilo de la Imagen --- */
#convenio-internacional .img-convenio-int {
    max-width: 100%;
    height: auto;
    border-radius: 25px; /* Crea los bordes redondeados suaves del diseño */
    box-shadow: 0 10px 30px rgba(0,0,0,0.08); /* Sombra sutil para darle profundidad */
}

/* --- Título Principal --- */
#convenio-internacional .titulo-conv-int {
    color: #111111;
    font-family: 'Raleway', sans-serif;
    font-size: 2.8rem;
    font-weight: 300; /* Hace que el texto general del título sea más delgado */
    line-height: 1.2;
}

/* Fuerza el texto en negrita solo para la etiqueta <strong> */
#convenio-internacional .titulo-conv-int strong {
    font-weight: 800; /* Destaca fuertemente la palabra "Medicina" */
}

/* --- Párrafos de texto --- */
#convenio-internacional .texto-conv-int {
    color: #333333; /* Gris muy oscuro para lectura cómoda */
    font-family: 'Raleway', sans-serif;
    font-size: 1.1rem;
    line-height: 1.6;
    text-align: justify; /* Mantiene los bordes de texto rectos como en la imagen */
}

/* --- Lista con viñetas --- */
#convenio-internacional .lista-conv-int {
    color: #333333;
    font-family: 'Raleway', sans-serif;
    font-size: 1.1rem;
    line-height: 1.6;
    padding-left: 1.8rem; /* Espacio para los puntos de la lista */
    margin-bottom: 1rem;
}

/* Separa ligeramente cada punto de la lista */
#convenio-internacional .lista-conv-int li {
    margin-bottom: 0.4rem; 
}

/* =========================================
   AJUSTES PARA MÓVILES (Responsivo)
   ========================================= */
@media (max-width: 991px) {
    #convenio-internacional .titulo-conv-int {
        font-size: 2rem; /* Reduce el tamaño del título en celulares */
    }
    
    #convenio-internacional .texto-conv-int,
    #convenio-internacional .lista-conv-int {
        text-align: left; /* En móviles es mejor alinear a la izquierda para leer mejor */
    }
}
/* =========================================
   SECCIÓN AISLADA: CONVENIO CANADÁ
   ========================================= */

#convenio-canada {
    background-color: #ffffff; /* Fondo blanco */
    padding: 80px 0;
    width: 100%;
}

/* --- Título Principal --- */
#convenio-canada .titulo-canada {
    color: #111111;
    font-family: 'Raleway', sans-serif;
    font-size: 2.8rem;
    font-weight: 300; /* Texto delgado por defecto */
    line-height: 1.2;
}

/* Fuerza el texto en negrita solo para la etiqueta <strong> */
#convenio-canada .titulo-canada strong {
    font-weight: 800; /* Letra extra gruesa para destacar el campus */
}

/* --- Párrafo de texto --- */
#convenio-canada .texto-canada {
    color: #333333;
    font-family: 'Raleway', sans-serif;
    font-size: 1.1rem;
    line-height: 1.6;
    text-align: justify; /* Mantiene los márgenes rectos como en tu diseño */
}

/* --- Estilo de la Imagen --- */
#convenio-canada .img-canada {
    max-width: 100%;
    height: auto;
    border-radius: 25px; /* Mismos bordes curvos que la sección anterior */
    box-shadow: 0 10px 30px rgba(0,0,0,0.08); /* Sombra suave */
}

/* =========================================
   AJUSTES PARA MÓVILES (Responsivo)
   ========================================= */
@media (max-width: 991px) {
    #convenio-canada .titulo-canada {
        font-size: 2rem; /* Achicamos el título en celulares */
    }
    
    #convenio-canada .texto-canada {
        text-align: left; /* Alinear a la izquierda es mejor para leer en pantallas pequeñas */
    }
}
/* =========================================
   SECCIÓN AISLADA: LICENCIATURAS Y PROMOCIÓN
   ========================================= */

#seccion-licenciaturas {
    background-color: #ffffff;
    font-family: 'Raleway', sans-serif;
}

/* --- Cuadrícula Principal (CSS Grid) --- */
.grid-licenciaturas {
    display: grid;
    grid-template-columns: repeat(4, 1fr); 
    gap: 20px;
    grid-auto-flow: dense; 
}

/* --- Tarjetas (Rectángulos perfectos) --- */
.card-lic {
    position: relative;
    border-radius: 15px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
    transition: box-shadow 0.4s ease;
    height: 380px; /* Altura estricta para ser rectangulares */
}

.card-lic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}

/* --- Cintillo Azul (Generado con CSS) --- */
.cintillo-azul {
    position: absolute;
    bottom: 15px;
    left: 0;
    background-color: #1a568c; 
    color: #ffffff;
    font-weight: 700;
    font-size: 1.05rem;
    padding: 8px 20px;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
    z-index: 2;
    transition: opacity 0.3s ease;
    box-shadow: 2px 2px 8px rgba(0,0,0,0.2);
    line-height: 1.2;
}

/* --- Capa Oscura y Textos (Estado Hover) --- */
.hover-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7); 
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0; 
    transition: opacity 0.4s ease;
    z-index: 3;
}

.hover-overlay .titulo-hover {
    color: #ffffff;
    font-weight: 800;
    font-size: 1.4rem;
    text-align: center;
    padding: 20px;
    transform: translateY(20px);
    transition: transform 0.4s ease;
    line-height: 1.2;
}


/* --- EFECTOS HOVER --- */
.card-lic:hover {
    box-shadow: 0 15px 35px rgba(0,0,0,0.2);
}
.card-lic:hover img {
    transform: scale(1.1); /* Zoom elegante */
}
.card-lic:hover .cintillo-azul {
    opacity: 0; /* Desaparece el cintillo azul */
}
.card-lic:hover .hover-overlay {
    opacity: 1; /* Aparece fondo, título centrado y triángulo amarillo */
}
.card-lic:hover .hover-overlay .titulo-hover {
    transform: translateY(0);
}

/* --- BLOQUE CENTRAL (Formulario y Video) --- */
.bloque-central-promo {
    grid-column: span 3; /* AHORA OCUPA 3 COLUMNAS, DEJANDO 1 PARA LAS TARJETAS */
    grid-row: span 2;    /* Ocupa el equivalente a 2 tarjetas de alto */
    background-color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-left: 20px; /* Separación visual de la columna izquierda */
}

.titulo-promo {
    color: #111111;
    font-weight: 800;
    font-size: 2rem;
}

.promo-contenido {
    display: flex;
    gap: 20px;
    align-items: stretch;
    height: 100%; /* Toma el espacio completo generado por grid-row: span 2 */
}

/* --- IFRAME (Sin Scroll) Y VIDEO --- */
.promo-iframe-container,
.promo-video-container {
    flex: 1; 
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 8px 25px rgba(0,0,0,0.08);
}

.promo-iframe-container {
    background-color: #fff;
    overflow: hidden !important; 
}

.promo-iframe-container iframe {
    width: 100%;
    height: 100%;
    min-height: 650px; /* Asegura que el formulario completo se vea */
    border: none;
    overflow: hidden !important;
}

.promo-video-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* --- RESPONSIVO --- */
@media (max-width: 1200px) {
    .bloque-central-promo {
        padding-left: 0; 
    }
}

@media (max-width: 991px) {
    .grid-licenciaturas {
        grid-template-columns: repeat(2, 1fr); /* 2 columnas en tablet */
    }
    .bloque-central-promo {
        grid-column: span 2; /* Ocupa ambas columnas en tablet */
    }
}

@media (max-width: 768px) {
    .grid-licenciaturas {
        grid-template-columns: 1fr; /* 1 columna en celulares */
    }
    .bloque-central-promo {
        grid-column: span 1;
    }
    .promo-contenido {
        flex-direction: column; 
    }
    .promo-iframe-container iframe,
    .promo-video-container video {
        min-height: 550px;
    }
}
/* =========================================
   SECCIÓN AISLADA: ACREDITACIONES
   ========================================= */

#seccion-acreditaciones {
    width: 100%;
    background-color: #ffffff;
    font-family: 'Raleway', sans-serif;
    margin-bottom: 40px; /* Da un poco de espacio con la sección de abajo */
}

/* --- Encabezado Azul --- */
#seccion-acreditaciones .acreditaciones-header {
    background-color: #2b5f8c; /* Azul característico de la universidad */
    padding: 15px 0;
}

#seccion-acreditaciones .titulo-acreditaciones {
    color: #ffffff;
    font-weight: 700;
    font-size: 2.2rem;
}

/* --- Contenedor de la Cinta --- */
#seccion-acreditaciones .acreditaciones-slider {
    width: 100%;
    overflow: hidden; /* Oculta los logos que salen de la pantalla */
    padding: 40px 0; /* Espaciado arriba y abajo de los logos */
    position: relative;
}

/* --- Pista de Movimiento --- */
#seccion-acreditaciones .acreditaciones-track {
    display: flex;
    align-items: center;
    width: max-content; /* Permite que la pista sea tan ancha como todos los logos sumados */
    
    /* Llama a la animación. Cambia '25s' a un número menor si lo quieres más rápido */
    animation: moverIzquierdaADerecha 25s linear infinite;
}

/* Pausar la animación cuando el usuario pone el mouse encima (Opcional) */
#seccion-acreditaciones .acreditaciones-slider:hover .acreditaciones-track {
    animation-play-state: paused;
}

/* --- Cajas Individuales de los Logos --- */
#seccion-acreditaciones .acreditaciones-logo {
    width: 250px; /* Define el ancho reservado para cada logo */
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 30px;
    flex-shrink: 0;
}

/* --- Imágenes de los Logos --- */
#seccion-acreditaciones .acreditaciones-logo img {
    max-width: 100%;
    max-height: 85px; /* Altura máxima para uniformidad */
    object-fit: contain; /* Evita que los logos se deformen o se estiren */
}

/* --- LA ANIMACIÓN MAGICA --- */
@keyframes moverIzquierdaADerecha {
    0% {
        /* Inicia desplazado hacia la izquierda (la mitad de su ancho total) */
        transform: translateX(-50%);
    }
    100% {
        /* Termina en la posición 0, habiéndose movido hacia la derecha */
        transform: translateX(0);
    }
}

/* --- RESPONSIVO PARA MÓVILES --- */
@media (max-width: 768px) {
    #seccion-acreditaciones .titulo-acreditaciones {
        font-size: 1.8rem;
    }
    
    #seccion-acreditaciones .acreditaciones-logo {
        width: 180px; /* Logos un poco más juntos en celulares */
        padding: 0 15px;
    }
    
    #seccion-acreditaciones .acreditaciones-logo img {
        max-height: 60px; /* Logos un poco más pequeños en celulares */
    }
}
/* =========================================
   SECCIÓN: REVISTAS VESTIGIA Y MODAL
   ========================================= */

#seccion-revistas {
    background-color: #ffffff;
    font-family: 'Raleway', sans-serif;
}

/* --- Cuadrícula Principal --- */
.grid-revistas {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); 
    gap: 25px;
    grid-auto-rows: 350px; 
}

/* --- Título Azul --- */
/* --- Título Azul (Pegado a la izquierda) --- */
.titulo-vestigia {
    background-color: #1a568c; 
    color: #ffffff;
    border-radius: 0 40px 40px 0; 
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px; 
    
    /* EL TRUCO PARA PEGARLO AL BORDE */
    margin-left: -1.5rem; /* Un margen negativo que compensa el espacio del contenedor */
    padding-left: 1.5rem; /* Añadimos padding adentro para que la letra no quede pegada al borde de la pantalla */
}

.titulo-vestigia h2 {
    font-weight: 800;
    font-size: 2.5rem;
    margin: 0;
}

/* --- Tarjetas --- */
.card-revista {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-revista img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top; 
}

/* --- Hover (Capa Oscura y Triángulo) --- */
.hover-revista {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); 
    display: flex;
    flex-direction: column;
    padding: 20px;
    opacity: 0; 
    transition: opacity 0.3s ease;
}

.hover-revista .titulo-hover {
    color: #ffffff;
    font-weight: 700;
    font-size: 1.8rem;
    margin: 0;
    transform: translateY(-10px);
    transition: transform 0.3s ease;
}

.hover-revista .subtitulo-hover {
    color: #dddddd;
    font-size: 0.9rem;
    margin-top: 5px;
}

.hover-revista .triangulo-amarillo {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 0;
    height: 0;
    border-bottom: 80px solid #eab308;
    border-left: 80px solid transparent;
}

/* --- Interacción Mouse --- */
.card-revista:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.2);
}
.card-revista:hover .hover-revista {
    opacity: 1; 
}
.card-revista:hover .titulo-hover {
    transform: translateY(0); 
}

/* =========================================
   ESTILOS DE LA VENTANA MODAL (VISOR)
   ========================================= */
.modal-revista-custom {
    max-width: 90vw !important; 
    height: 90vh;
}

.btn-cerrar-visor {
    position: absolute;
    top: -15px;
    right: -15px;
    background-color: #ffffff;
    border-radius: 50%;
    padding: 10px;
    opacity: 1;
    z-index: 9999;
    box-shadow: 0 4px 10px rgba(0,0,0,0.3);
    border: 2px solid #1a568c;
}
