/* 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;
    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; 
    }
}