/* CONVENIOS.CSS */
/*
 * PÁGINA: Hoja de Estilos de Convenios y Alianzas (Convenios CSS) - As Tech Computer
 * PROPÓSITO: Definir la presentación visual y el diseño interactivo de la página de convenios, proveedores y alianzas estratégicas corporativas.
 * FUNCIONALIDADES:
 * - Centralización de la paleta de colores corporativa y variables globales de diseño mediante :root.
 * - Estilización de la sección principal (Hero) con títulos destacados y líneas decorativas dinámicas (pseudo-elementos).
 * - Implementación de un sistema de cuadrícula (CSS Grid) adaptativo para las tarjetas informativas, asegurando uniformidad estructural en múltiples resoluciones.
 * - Diseño de animaciones suaves de entrada (FadeIn) y efectos de transición interactivos (Hover) en tarjetas para mejorar la experiencia de usuario (UX).
 * - Formateo visual del carrusel de marcas aliadas, aplicando filtros de imagen progresivos (de escala de grises a color real) y botones de navegación absolutos.
 * - Ajustes responsivos (Media Queries) orientados a optimizar la legibilidad y accesibilidad en dispositivos móviles.
 */

/* =========================================
   1. VARIABLES GLOBALES Y RESETEO BÁSICO
   ========================================= */
/**
 * Se declaran las variables globales del sistema para garantizar la 
 * consistencia de la paleta de colores y sombreados en toda la página.
 * Además, se resetean los estilos base del cuerpo (body).
 */


body {
    background-color: var(--blanco);
    color: var(--gris-oscuro);
    font-family: 'Lato', sans-serif;
    line-height: 1.6;
    margin: 0;
}
header-convenio{
    background: #eee;
}
.fa-handshake{
    font-size: 4rem; color: #999;
}

/* =========================================
   2. SECCIÓN PRINCIPAL (HERO)
   ========================================= */
/**
 * El bloque hero actúa como la cabecera visual de la página. 
 * Integra un subrayado decorativo centrado creado mediante un 
 * pseudo-elemento (::after) debajo del título principal.
 */
.seccion-convenios {
    padding: 80px 20px 80px;
    text-align: center;
    background: var(--gris-claro);
    border-bottom: 1px solid var(--borde);
}
#dark{
    background-color: #99999967;
}

.titulo-convenios {
    font-size: 3.2rem;
    font-weight: 900;
    color: #52073a;
    text-transform: uppercase;
    margin-bottom: 15px;
    position: relative;
}
/* =========================
   VARIABLES DE TEMAS
========================= */

.tema-naranja{
    --color-principal:#e17203;
    --color-secundario: #e1720327;
}

.tema-morado{
     --color-principal: #52073a;
    --color-secundario: #52073a3f;
}

.titulo-convenios::after {
    content: "";
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 250px;
    height: 3px;
    background-color: var(--color-principal);
}

.subtitulo-convenios {
    max-width: 1000px;
    margin: 35px auto 0;
    color: var(--gris-medio);
    font-size: 1.2rem;
    line-height: 1.8;
    letter-spacing: 0.5px;
}

/* =========================================
   3. ESTRUCTURA GLOBAL Y TÍTULOS DE BLOQUE
   ========================================= */
/**
 * Define el contenedor maestro con un ancho máximo estandarizado 
 * y aplica una animación de aparición sutil (fadeIn) al momento 
 * de cargar el documento.
 */
.contenedor-convenios {
    max-width: 1200px;
    margin: 60px auto;
    padding: 0 20px;
    animation: fadeIn 0.8s ease-in-out;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.titulo-bloque {
    font-size: 2.3rem;
    color: #52073a;
    position: relative;
    padding-bottom: 15px;
    margin-bottom: 80px;
    font-weight: 700;
    margin-top:80px;
}

.titulo-bloque::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 90%;
    height: 2px;
    background: linear-gradient(to right, #e17203, rgba(225, 114, 3, 0.1), transparent);
    border-radius: 2px;
}

.bloque-logos .titulo-bloque {
    text-align: center;
}

.bloque-logos .titulo-bloque::after {
    left: 50%;
    transform: translateX(-50%);
}

/* =========================================
   4. SISTEMA DE CUADRÍCULA (GRID) Y TARJETAS
   ========================================= */
/**
 * Implementa CSS Grid con auto-fit y minmax para lograr tarjetas que se
 * adapten inteligentemente al ancho de la pantalla sin necesidad de 
 * media queries estrictas, incorporando efectos de elevación al interactuar.
 */
.grid-convenios {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
}

/* TARJETA */
.card-convenio{
    width: 100%;
    max-width: 520px;
    background: var(--blanco);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    border: 1px solid var(--borde);
    position: relative;
    transition: 0.3s ease;
    display:flex;
    flex-direction: column;
    height:100%;
}

.card-convenio:hover{
    transform: translateY(-4px);
}

/* BADGE */
.badge-convenio{
    position: absolute;
    top: 15px;
    right: 15px;
    background:var(--color-principal);
    color: white;
    padding: 6px 14px;
    border-radius: 30px;
    font-size: 1.0rem;
    font-weight: 600;
}

/* LOGO GRANDE */
.logo-empresa{
    width: 100%;
    height: 230px;
    background: #eeeeee88;
    display: flex;
    align-items: center;
    justify-content: center;
 
    border-bottom: 1px solid var(--borde);
}

.logo-empresa img{

    height: 100%;
    object-fit: contain;
}

/* CONTENIDO */
.contenido-card{
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    flex:1;
}

/* TITULOS */
.card-convenio h3{
    color: var(--color-principal);
    font-size: 1.6rem;
    font-weight: 700;
    text-align:center;
}
.texto-beneficios{
    text-align: center;
    padding: 5px;
    background-color:var(--gris-claro);
    border-radius: 5px;
    font-size: 0.95rem;;
}
.texto-naranja{
    color: var(--color-principal);
    font-weight: 600;
    text-align: center;
    margin-right:5px;
}

.card-convenio h2{
    color: var(--gris-medio);
    font-size: 0.95rem;
    line-height: 1.5;
    font-weight: 400;
     text-align:center;
}

/* TITULO SECCION */
.titulo-seccion{
    color: var(--color-principal);
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 12px;
}

/* BENEFICIOS */




.info-item{
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.info-label{
    color: var(--color-principal);
    font-size: 0.88rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
}

.info-value{
    color: var(--gris-oscuro);
    font-size: 0.92rem;
}

/* PALABRAS CLAVE */
.palabras-clave{
    margin-top: auto;
    padding-top: 15px;
    gap: 50px;
    text-align: center;
}

.tag-palabra{
    background: var(--color-secundario);
    color: var(--color-principal);
    padding: 7px 14px;
    margin-top: 10px;
    border-radius: 30px;
    font-size: 0.79rem;
    font-weight: 600;
}
/* CONTENEDOR DE BENEFICIOS + INFO */
.detalles-convenio{
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 18px;
    align-items: start;
}

/* BENEFICIOS */
.seccion-card{
   
    border-radius: 14px;
    padding: 16px;
    height: 100%;
}

/* INFO EMPRESA */
.info-empresa{
    display: flex;
    flex-direction: column;
    gap: 14px;
    background: var(--gris-claro);
    border-radius: 14px;
    padding: 16px;
    height: 100%;
}
/* Contenedor de la sección Educativa */
.bloque-educativo {
    width: 100%;
    margin-top: 50px;
    padding: 20px 0;
}

/* Forzar que el grid ocupe todo el ancho y sea flexible */
.grid-convenios-full {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 25px;
    width: 100%;
}

/* Estilo de la Tarjeta Educativa */
.card-educativa {
    background: #fff;
    border-radius: 15px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 25px rgba(0,0,0,0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border-top: 5px solid #e17203; /* Color institucional naranja */
}

.card-educativa:hover {
    transform: translateY(-10px);
    box-shadow: 0 15px 35px rgba(0,0,0,0.1);
}

/* Imagen de la institución */
.imagen-institucion {
    width: 100%;
    overflow: hidden;


}

.imagen-institucion img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ajusta la imagen sin deformarla */
    transition: scale 0.5s ease;
}

.card-educativa:hover .imagen-institucion img {
    scale: 1.1;
}

/* Cuerpo de la tarjeta */
.body-convenio-edu {
    padding: 25px;
    flex-grow: 1;
}

.body-convenio-edu h3 {
    font-size: 1.5rem;
    color: #333;
    margin-bottom: 5px;
    font-weight: 700;
}

.body-convenio-edu small {
    color: #666;
    font-size: 0.9rem;
    display: block;
    margin-bottom: 15px;
}

.beneficios-lista-edu {
    list-style: none;
    padding: 0;
    margin-top: 15px;
}

.beneficios-lista-edu li {
    margin-bottom: 10px;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    color: #444;
}

.beneficios-lista-edu li i {
    color: #e17203;
    margin-right: 10px;
}

/* Badge de estado */
.badge-edu {
    background: #e17203;
    color: white;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: bold;
    display: inline-block;
    margin-bottom: 10px;
}
.footer-convenio{
    padding: 15px; 
    border-top: 1px solid #eee;
     font-size: 0.85rem;
    color: #777;

}
.card-educativa-prox{
    background-color: #afababc2;
    border-radius: 20px;
    border-top-color: #ccc; opacity: 0.8;
}
#proximamente{
    display: flex; 
    flex-direction: column; 
    align-items: center; 
    justify-content: center;
    text-align: center;
     height: 100%; 
    min-height: 300px;

.fa-handshake-angle{
    font-size: 4rem; color: #000000; margin-bottom: 20px;

}
/* =========================================
   7. DISEÑO RESPONSIVO (OPTIMIZADO)
   ========================================= */

/* --- TABLETS (Menos de 1024px) --- */
@media (max-width: 1024px) {
    .contenedor-convenios {
        padding: 0 30px;
    }
    
    .grid-convenios, .grid-convenios-full {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 20px;
    }

    .titulo-convenios {
        font-size: 2.5rem;
    }
}

/* --- MÓVILES GRANDES / PHABLETS (Menos de 768px) --- */
@media (max-width: 768px) {
    /* Ajustes de Cabecera */
    .seccion-convenios {
        padding: 50px 15px;
    }

    .titulo-convenios {
        font-size: 2rem;
    }

    .titulo-convenios::after {
        width: 150px;
    }

    .subtitulo-convenios {
        font-size: 1rem;
        margin-top: 20px;
    }

    .titulo-bloque {
        font-size: 1.8rem;
        margin-bottom: 40px;
        text-align: center;
    }

    .titulo-bloque::after {
        left: 50%;
        transform: translateX(-50%);
        width: 80%;
    }

    /* Ajuste de Tarjetas de Convenio */
    .detalles-convenio {
        grid-template-columns: 1fr; /* Apila beneficios e info empresa */
        gap: 10px;
    }

    .seccion-card, .info-empresa {
        padding: 15px;
    }

    /* Ajuste de Tarjetas Educativas */
    .grid-convenios-full {
        grid-template-columns: 1fr; /* Una sola columna en móvil */
    }

    .card-educativa {
        max-width: 100%;
    }

    .logo-empresa {
        height: 180px;
    }
}

/* --- MÓVILES PEQUEÑOS (Menos de 480px) --- */
@media (max-width: 480px) {
    .titulo-convenios {
        font-size: 1.6rem;
    }

    .badge-convenio {
        font-size: 0.8rem;
        padding: 4px 10px;
    }

    .card-convenio h3 {
        font-size: 1.3rem;
    }

    /* Hacemos que los tags de palabras clave no se amontonen */
    .palabras-clave {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }

    .tag-palabra {
        font-size: 0.50rem;
        padding: 5px 10px;

    }

    /* Reducimos el padding general para ganar espacio horizontal */
    .contenedor-convenios {
        margin: 30px auto;
        padding: 0 15px;
    }

    .info-label {
        font-size: 0.8rem;
    }

    .info-value {
        font-size: 0.85rem;
    }
}

/* --- SOLUCIÓN A ERRORES DE SINTAXIS EN TU CÓDIGO --- */
/* Asegúrate de borrar la última llave de tu código anterior o reemplazarlo con esto */
#proximamente {
    display: flex; 
    flex-direction: column; 
    align-items: center; 
    justify-content: center;
    text-align: center;
    height: 100%; 
    min-height: 300px;
}

.fa-handshake-angle {
    font-size: 4rem; 
    color: #000000; 
    margin-bottom: 20px;
}
/* RESPONSIVE */
@media(max-width: 700px){

    .detalles-convenio{
        grid-template-columns: 1fr;
    }

}

/* RESPONSIVE */
@media(max-width: 900px){

    .contenedor-convenios{
        grid-template-columns: 1fr;
    }

    .card-convenio{
        max-width: 100%;
    }

}

/* =========================================
   7. DISEÑO RESPONSIVO (DISPOSITIVOS MÓVILES)
   ========================================= */
/**
 * Adapta el espaciado interno, reduce la tipografía de los encabezados 
 * y reajusta la posición absoluta de los botones del carrusel para prevenir 
 * desbordamientos en pantallas estrechas.
 */
@media (max-width: 768px) {
    .titulo-convenios {
        font-size: 1.8rem;
    }
    
    .seccion-convenios {
        padding: 60px 20px;
    }

    .prev { left: 0; }
    .next { right: 0; }
}
}