/*---------------------------------------------------------------------------------------------------------------------------------------------------*/

*{
   font-family: 'Montserrat', sans-serif; 
}

/*carreras oferta academica*/
/*coton postulate ya*/
.btn-rojo-personalizado {
    /* Color de fondo solicitado */
    background-color: #f6303a; 
    /* Color del texto */
    color: white; 
    
    font-family: 'Montserrat', sans-serif;
    /* Asegura que el borde no sea el predeterminado */
    border-color: #f6303a; 
    /* Padding y fuente por si se pierde el estilo de Bootstrap */
    padding: 0.5rem 1rem;
    font-size: 1rem;
    border-radius: 5px;
    font-weight: bold;
}

/* Estilo al pasar el ratón (hover) */
.btn-rojo-personalizado:hover {
    /* Oscurece ligeramente el rojo para dar un efecto de interacción */
    background-color: #f6303a; 
    border-color: #f6303a;
    color: white;
}

/* Modificación del bloque de datos clave para el estilo oscuro (Ficha Técnica) */
.key-data-box.new-layout {
    display: grid;
    grid-template-columns: repeat(5, 1fr); /* 5 contenedores */
    gap: 20px;
    background-color: transparent;
    padding: 0;
    margin-top: 10px;
    margin-bottom: 5px;
}

.key-data-box .data-item {
    background-color: rgb(30, 58, 138);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 15px 10px; /* Ajustado padding para mejor visualización vertical */
    border-radius: 5px;
    box-sizing: border-box;
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    color: white;
    text-align: center;
}


/* Modificamos los estilos internos para que no interfieran con el centrado */
.key-data-box .data-item strong {
    text-align: center; /* Asegura el centrado del strong */
}

.key-data-box .data-item ul {
    
    list-style: none;
    padding-left: 0;
    margin-top: 10px;
    /* Asegura que la lista dentro de la tarjeta también esté centrada */
    text-align: center; 
}

.key-data-box .data-item ul li {
    list-style-type: none; 
    padding-left: 0;
    margin-bottom: 5px;
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
}

/* Responsive para que se apilen correctamente en móviles */
@media (max-width: 1200px) {
    .key-data-box.new-layout {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .key-data-box.new-layout {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .key-data-box.new-layout {
        grid-template-columns: 1fr;
    }
}

/*parte se submenus de informacion de carrera*/
/* Variables del IST 17 de Julio consolidadas para evitar errores de referencia */
:root {
    --color-primario: #1e40af; /* Azul oscuro corporativo (Texto no activo) */
    --color-secundario: #f1f1f1; /* Gris claro para fondos */
    --color-activo-rojo: #f6303a; /* Rojo para el estado activo */
    --color-fondo-claro: #f8f8f8; /* Fondo de la sección de contenido */
    --color-borde: #1e40af; /* Color similar al cian/turquesa del borde */
    --color-gris-sidebar: #e9ecef; /* Fondo sutil para la columna lateral */
    --color-contenido-fondo: #e9ecef; /* Fondo del contenido de acordeón */
    --color-texto-contenido: #333;
}

/* 1. Estilo del contenedor de la navegación */
.carrera-tabs-nav {
    margin: 30px 0;
    justify-content: center;
    padding: 0;
    background-color: white; /* Fondo claro debajo de la barra */
    border-radius: 40px;
}

/* 2. Estilo de la lista de pestañas */
.carrera-tabs-list {
    display: flex;
    flex-wrap: wrap; /* Para que se ajuste en móviles */
    justify-content: center;
    list-style: none;
    
    border-bottom: 2px solid var(--color-secundario);
}

/* 3. Estilo de cada pestaña */
.tab-item {
    margin-right: 65px;
    padding: 0;
}

.carrera-tabs-list .tab-item:last-child {
    margin-right: 0;
}


.tab-item a {
    display: block;
    padding: 10px 20px;
    text-decoration: none;
    font-weight: 600;
    color: var(--color-primario); /* Texto azul oscuro por defecto */
    transition: all 0.3s ease;
    border-radius: 4px 4px 0 0;
    /* La línea inferior se crea en el estado activo */
}

.tab-item.active a {
    color: white; /* Texto rojo */
    background: #d12a32; 
    /* Crea la línea roja SOLAMENTE debajo del elemento activo */
    border-bottom: 3px #d12a32; 
}

/* CSS para controlar la visibilidad de los paneles de contenido */
.tab-content-pane {
    display: none; /* Oculta todos los paneles por defecto */
    padding-top: 20px;
}

.tab-content-pane.active {
    display: block; /* Muestra solo el panel que tiene la clase 'active' */
}

/* 5. Ajustes para móviles */
@media (max-width: 768px) {
    .carrera-tabs-list {
        flex-direction: column;
        border-bottom: none;
    }
    .tab-item {
        margin-right: 0;
        margin-bottom: 5px;
    }
    .tab-item a {
        border-radius: 4px;
        text-align: center;
    }
}


/* --- Estilos del Acordeón (del parte de submenus informacion de la carrera) --- */

/* --- 1. Estructura de Columnas (Acordeón + Sidebar) --- */
.acordeon-layout {
    display: flex;
    gap: 30px;            /* Espacio entre columnas */
    padding: 20px 0;
    align-items: flex-start;  /* CAMBIADO: Inicia desde arriba para que el sidebar sea independiente */
}

.centered-layout {
    max-width: 1200px;    /* Ancho máximo */
    margin: 0 auto;       /* Centrado horizontal */
    padding: 0 20px;      /* Padding lateral */
}

/* Columna izquierda (Acordeón) */
.acordeon-columna {
    flex: 2;              /* 2/3 del espacio */
}

/* Columna derecha (Sidebar) */
.sidebar-columna {
    flex: 1;              /* 1/3 del espacio */
    display: flex;
    flex-direction: column; /* ASEGURA QUE TODO DENTRO SEA VERTICAL */
    gap: 20px;            /* Espacio entre la resolución y las tarjetas azules */
}

/* NUEVA REGLA: Forzar que las tarjetas azules en el sidebar sean verticales */
.sidebar-columna .key-data-box {
    display: flex;
    flex-direction: column; /* Vertical: uno debajo de otro */
    gap: 15px;              /* Espacio entre cada tarjeta azul */
    grid-template-columns: 1fr; /* Anula las 5 columnas por si acaso */
}

.sidebar-columna .data-item {
    width: 100%;            /* Que ocupe todo el ancho de la columna sidebar */
}

/* Tarjeta Sidebar */
.sidebar-info {
    padding: 20px;
    border-radius: 8px;
    background-color: var(--color-gris-sidebar);
}

.sidebar-info h2 {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.1rem;
    color: #333;
    margin-bottom: 15px;
}

.resolucion-list {
    list-style: none;
    padding-left: 0;
}

.resolucion-list li {
    margin-bottom: 10px;
     font-family: 'Montserrat', sans-serif;
    font-size: 1.1rem;
    color: black;
}


/* --- 2. Estilos del Acordeón --- */
.acordeon-item {
    margin-bottom: 15px;
    border: 2px solid var(--color-borde);
    border-radius: 5px;
    overflow: hidden;
    transition: all 0.3s ease;
    background-color: white; /* INACTIVO → fondo blanco */
}

.acordeon-item.active {
    border-color: #1e40af;
    background-color: #1e40af; /* ACTIVO → fondo azul */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/* --- HEADER --- */
.acordeon-header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 30px;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;

    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    font-weight: 600;

    color: #1e40af; /* INACTIVO → texto azul */
    transition: all 0.3s ease;
}

/* --- HEADER ACTIVO (texto blanco) --- */
.acordeon-item.active .acordeon-header {
    color: white; /* ACTIVO → texto blanco */
}

/* --- ÍCONO (FLECHA ▼) --- */
.acordeon-icon {
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    margin-left: 15px;

    color: #1e40af; /* INACTIVO → azul */
    transition: transform 0.3s ease, color 0.3s ease;
    display: inline-block;
}

/* Ícono cuando el acordeón está activo → blanco y rotado (▼ → ▲) */
.acordeon-item.active .acordeon-icon {
    color: white;
    transform: rotate(180deg);
}

/* --- CONTENIDO --- */
.acordeon-content {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95rem;
    max-height: 0;
    overflow: hidden;
    padding: 0 30px;
    transition: max-height 0.4s ease-out, padding 0.4s ease-out;
    background-color: white;
    border-top: 1px solid var(--color-fondo-claro);
    color: black;
}

.acordeon-content.show {
    padding: 20px 30px;
}

.acordeon-content p, 
.acordeon-content ul {
    max-width: 90%;
    margin: 0 auto 1em;
    line-height: 1.6;
}

.acordeon-content ul {
    padding-left: 20px;
}

.acordeon-content p:last-child,
.acordeon-content ul:last-child {
    margin-bottom: 0;
}



/* Media query para móviles: apilar las columnas */
@media (max-width: 768px) {
    .acordeon-layout {
        flex-direction: column;
    }
    .acordeon-item {
        border-radius: 8px; /* Redondeo menos extremo en móvil */
    }
    .centered-layout {
        padding: 0 15px; /* Menos padding en móviles */
    }
    .acordeon-content p,
    .acordeon-content ul {
        max-width: 100%; /* Permite que el texto ocupe todo el ancho disponible en móviles */
        margin: 0; /* Elimina el margen auto y centrador en móviles */
    }
    .acordeon-header {
        padding: 15px 20px; /* Ajusta el padding del header en móvil */
    }
    .acordeon-content.show {
        padding: 15px 20px; /* Ajusta el padding del contenido en móvil */
    }
}

/* ---------------------------------------------------------------------------------- */
/* --- ESTILOS DE NAVEGACIÓN POR PESTAÑAS (TABS - ESTILO PÍLDORA) --- */
/* ---------------------------------------------------------------------------------- */

.tab-item a {
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    
    padding: 12px 25px;
    
    /* Texto azul para pestañas INACTIVAS */
    color:  white; 
    text-decoration: none;
    background-color: #1e40af;
    /* CAMBIO CLAVE: Borde redondeado y color de borde cian */
    border-radius: 5px; 
    border: 1px solid var(--color-borde); 
    
    
    
}

/* Estilo para la pestaña ACTIVA: ROJO */
.tab-item.active a {
    background-color: #f6303a; 
    /* El texto de la pestaña seleccionada es ROJO */
    color: white; 
    /* Borde rojo para la pestaña seleccionada */
    border: 1px solid #f6303a ;
}

/* Estilo al pasar el mouse por las pestañas INACTIVAS */
.tab-item:not(.active) a:hover {
    background-color: #f0f0f0; 
    color: var(--color-primario); 
}

/* ---------------------------------------------------------------------------------- */
/* --- ESTILOS PARA LA VISIBILIDAD DEL CONTENIDO DE TABS --- */
/* ---------------------------------------------------------------------------------- */

.tabs-content-container {
    max-width: 1200px; 
    margin: 0 auto; 
    padding: 0 20px 40px;
}

/* Ocultar todos los contenidos por defecto */
.tabs-content-container .content-section {
    display: none;
}

/* Mostrar solo el contenido con la clase 'show' */
.tabs-content-container .content-section.show {
    display: block;
}


.malla-card {
    width: 100%;
    max-width: 650px;
    margin: 0 auto; /* Centrado */
    background: #ffffff;
    border: 2px solid #1e40af;
    border-radius: 10px;
    overflow: hidden; /* IMPORTANTE para que la imagen se ajuste al borde */
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
}

/* Imagen al 100% del card */
.malla-card img {
    width: 100%;
    height: auto;
    display: block; /* Elimina espacio fantasma */
}

/* Nuevo estilo para botón con borde azul */
.btn-borde-azul {
    background-color: #1e40af; 
    color: white; /* Texto azul oscuro */
    border: 2px solid #1e40af; /* Borde cian/turquesa */
    padding: 0.5rem 1rem;
    font-size: 1rem;
    border-radius: 5px;
    text-decoration: none;
    font-family: 'Montserrat', sans-serif;
    
}

.btn-borde-azul:hover {
    background-color: #eaf6fd; /* Gris sutil al pasar el ratón */
    border-color:#1e40af ;
    color: #1e40af;
}

/* --- Media query para móviles: Asegura que se vea bien en pantallas pequeñas --- */
@media (max-width: 768px) {
    .malla-curricular .semestre {
        /* Redondeo menor en móvil para mejor uso del espacio */
        border-radius: 8px; 
    }
    .malla-curricular h3 {
        /* Ajustar redondeo superior del h3 */
        border-top-left-radius: 8px;
        border-top-right-radius: 8px;
    }
    .malla-curricular ul {
        /* Ajustar redondeo inferior del contenido */
        border-bottom-left-radius: 8px; 
        border-bottom-right-radius: 8px;
    }
}


/* --- Estilos para la Tarjeta del Director/Coordinador (YA LO TENÍAS) --- */
.director-card {
    display: flex;
    flex-wrap: wrap; 
    gap: 30px; 
    padding: 30px 0;
    max-width: 1000px; 
    margin: 0 auto;

    align-items: center;  
}

.director-imagen-columna {
    flex: 0 0 300px; 
    display: flex;
    flex-direction: column;
    align-items: center;
}

.director-imagen-marco {
    width: 260px;          /* ancho ideal para un card vertical */
    height: auto;          /* el alto se ajusta automáticamente */
    border: 3px solid var(--color-borde, #80cedb);
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.director-imagen-marco img {
    width: 100%;
    height: auto;          /* mantiene proporción exacta */
    object-fit: contain;   /* evita recortes */
    display: block;
}

.director-nombre-info {
    margin-top: 15px;
    text-align: center;
}

.director-nombre-info strong {
    display: block;
    
font-family: 'Montserrat', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: #1e40af; 
}

.director-nombre-info span {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    color: #555;
    margin-top: 5px;
}

/* Columna de la Información (Biografía) */
.director-info-columna {
    
font-family: 'Montserrat', sans-serif;
    flex: 1; 
    padding-top: 20px;
    line-height: 1.7;
    color: #333;
    font-size: 1rem;
    
    /* CAMBIO CLAVE PARA CENTRADO VERTICAL */
    display: flex;
    flex-direction: column; /* Asegura que el texto fluya verticalmente */
    justify-content: center; /* Centra el contenido (párrafos) verticalmente */
}

/* Opcional: Asegúrate de que el párrafo tenga margen cero para que el centrado sea preciso */
.director-info-columna p {
    margin: 0;
}

/* Adaptabilidad Móvil (YA LO TENÍAS) */
@media (max-width: 768px) {
    .director-card {
        flex-direction: column;
        align-items: center; 
        padding: 20px 10px;
    }
    
    .director-imagen-columna {
        flex: 0 0 auto; 
        margin-bottom: 20px;
    }

    .director-imagen-marco {
        width: 250px; 
        height: 250px;
    }

    .director-info-columna {
        padding-top: 0;
    }
}

/* Contenedor principal de dos columnas */
.planta-docente-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Dos columnas iguales */
    gap: 30px; /* Espacio entre columnas */
}

/* --- Alternar por bloques de dos tarjetas --- */
.docente-card:nth-child(4n+1),
.docente-card:nth-child(4n+2) {
    flex-direction: row; /* Imagen a la izquierda */
}

.docente-card:nth-child(4n+3),
.docente-card:nth-child(4n+4) {
    flex-direction: row-reverse; /* Imagen a la derecha */
}

/* --- Layout tipo fila --- */
.docente-card {
    display: flex;
    align-items: center;
    gap: 20px;

    background-color: white;
    border: 1px solid #ddd;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
    border-radius: 10px;
    padding: 20px;
    transition: transform 0.3s ease;

    width: 100%;       /* Misma anchura */
    max-width: 550px;  /* Limita la anchura máxima */
    height: 220px;     /* Misma altura */
    box-sizing: border-box;
    margin: 0 auto;
}

/* Hover */
.docente-card:hover {
    transform: translateY(-3px);
}

/* Imagen */
.docente-foto-contenedor {
    width: 150px;
    height: auto;
    border-radius: 10px;
    overflow: visible;
}

.docente-foto-contenedor img {
    width: 100%;
    height: auto;
    border-radius: 5px;
    object-fit: contain;
    display: block;
}

/* Información centrada */
.docente-info {
    flex: 1;
    text-align: center; /* Texto centrado */
    display: flex;
    flex-direction: column;
    justify-content: center; /* Centrado vertical */
}

.docente-nombre {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: #122b76;
    margin: 0 0 8px;
}

.docente-titulo {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.9rem;
    color: #444;
    margin: 2px 0;
}

/* --- RESPONSIVE (se vuelve vertical en móvil) */
@media(max-width: 768px){
    .planta-docente-grid {
        grid-template-columns: 1fr; /* Una columna en móvil */
    }

    .docente-card {
        flex-direction: column !important;
        text-align: center !important;
        width: 100%;
        height: auto;
        margin: 0 auto;
    }

    .docente-card .docente-info {
        justify-content: center !important;
        text-align: center !important;
    }

    .docente-foto-contenedor {
        width: 200px;
        height: 200px;
    }
}
/*encabezado de hitoria*/
* {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }


        .hero {
            position: relative;
            height: 370px;
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
        }

        .hero-background {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .hero-overlay {
            position: absolute;
            inset: 0;
            background-color: rgba(0, 0, 0, 0.5);
        }

        .hero-content {
    position: relative;
    z-index: 10;
    text-align: center;
    /* Agregar flexbox al contenedor del texto y el botón */
    display: flex; 
    flex-direction: column; 
    align-items: center; /* Centrado horizontal del contenido */
    justify-content: center; /* Centrado vertical del contenido (redundante, pero bueno si .hero-content fuera más pequeño) */
    height: 100%; /* Asegura que ocupe todo el espacio del hero */
}

        .hero-title {
            font-size: 2.5rem;
    font-weight: 900;
    text-transform: uppercase; 
    letter-spacing: 2px; 
    color: #fdfeff;
    text-align: center;
    margin: 0; 
    line-height: 1.2;
    text-shadow: 2px 2px 5px rgba(0,0,0,0.3);
    font-family: "Montserrat", sans-serif;
            
            
        }

        /* Curved bottom */
        .hero::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100%;
            height: 60px;
            background-color: white;
            border-radius: 50% 50% 0 0 / 100% 100% 0 0;
        }

        /* Responsive */
        @media (max-width: 768px) {
            .hero {
                height: 250px;
            }

            .hero-title {
                font-size: 40px;
            }
        }




 .hero-1 {
            position: relative;
            height: 370px;
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
        }

        .hero-background-1 {
            position: absolute;
            inset: 0;
            top: 0;
            left: 0;
            width: 100%;
            height: 120%;
            z-index: -1;
            object-fit: cover;
            will-change: transform;
        }

        .hero-overlay-1 {
            position: absolute;
            inset: 0;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0, 0, 0, 0.5);
            z-index: 0;
        }


        .hero-content-1 {
    position: relative;
    z-index: 1;
    text-align: center;
    /* Agregar flexbox al contenedor del texto y el botón */
    display: flex; 
    flex-direction: column; 
    align-items: center; /* Centrado horizontal del contenido */
    justify-content: center; /* Centrado vertical del contenido (redundante, pero bueno si .hero-content fuera más pequeño) */
    height: 100%; /* Asegura que ocupe todo el espacio del hero */
}

  .hero-title-1 {
            font-size: 2.5rem;
    font-weight: 900;
    text-transform: uppercase; 
    letter-spacing: 2px; 
    color: #fdfeff;
    text-align: center;
    margin: 0; 
    line-height: 1.2;
    text-shadow: 2px 2px 5px rgba(0,0,0,0.3);
    font-family: "Montserrat", sans-serif;
            
            
        }

        /* Curved bottom */
        .hero-1::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100%;
            height: 60px;
            background-color: white;
            border-radius: 50% 50% 0 0 / 100% 100% 0 0;
        }

/* ====================================================== */
/* --- AJUSTES DE RESPONSIVIDAD ADICIONALES (AÑADIDOS) --- */
/* ====================================================== */

@media (max-width: 992px) {
    .tab-item {
        margin-right: 20px; /* Reducción de espacio en tablets */
    }
}

@media (max-width: 768px) {
    /* Ajuste de Hero 1 para móviles */
    .hero-1 {
        height: 250px;
    }
    .hero-title-1 {
        font-size: 1.8rem;
        padding: 0 15px;
    }

    /* Ajuste de márgenes de pestañas */
    .carrera-tabs-nav {
        border-radius: 10px;
        margin: 15px 0;
    }

    /* Sidebar stacked */
    .sidebar-columna {
        width: 100%;
    }
    
    /* Asegura que las imágenes de directores no sean gigantes en móviles pequeños */
    .director-imagen-marco {
        width: 220px;
        height: auto;
    }
}

@media (max-width: 480px) {
    .hero-title, .hero-title-1 {
        font-size: 1.5rem;
    }
    
    .btn-borde-azul, .btn-rojo-personalizado {
        width: 100%;
        text-align: center;
        margin-bottom: 10px;
    }

    .acordeon-header {
        padding: 12px 15px;
        font-size: 0.9rem;
    }
}