/* -----------------------------------------
 * ESTILOS EXCLUSIVOS DE LA PÁGINA DE INICIO 
 * -----------------------------------------
 * Todo el código aquí contenido solo se 
 * cargará en body.path-frontpage 
 */

/* =========================================
   PARCHE CONTRA EL SCROLL LATERAL ESTÁTICO
========================================= */
.dialog-off-canvas-main-canvas {
    overflow-x: clip !important; /* CLIP: Oculta el scroll lateral PERO NO bloquea a position: sticky */
    width: 100% !important;
    max-width: 100vw !important;
}

.row, .container-fluid {
    width: 100% !important;
    max-width: 100vw !important;
}

/* BLINDAJE FINAL: Ocultar la paginación numérica pase lo que pase */
[aria-label="Paginación"],
.view-cursos-suba-tic .pager,
.mi-grilla-cursos .pager,
.pager,
.pagination,
.pager__items,
nav.pager,
nav[role="navigation"] .pager {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Proteccion de EXPLORA contra fugas de la página Conócenos */
body.path-frontpage #main-content .layout--twocol-section .layout__region--first h2,
body.path-frontpage #main-content .layout--twocol-section .layout__region--first h3,
body.path-frontpage .layout__region--first h2,
body.path-frontpage .layout__region--first h3 {
    font-size: 40px !important;
    word-spacing: normal !important;
    line-height: 1.2 !important;
}

/* Forzar la cuadrícula de 2 columnas en Desktop (Reemplazo del layout_discovery perdido) */
@media (min-width: 769px) {
    body.path-frontpage .layout--twocol-section {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        width: 100% !important;
        align-items: flex-start !important;
    }
    body.path-frontpage .layout--twocol-section .layout__region--first {
        width: 35% !important;
        padding-right: 20px !important;
    }
    body.path-frontpage .layout--twocol-section .layout__region--second {
        width: 65% !important;
    }
    
    /* Evitar que el carrusel falle al comprimirse */
    body.path-frontpage .layout--twocol-section .layout__region--second .slick-slider {
        width: 100% !important;
    }
}

/* =========================================
   DISEÑO PREMIUM DE FLECHAS Y DOTS (EXPLORA)
========================================= */
/* Eliminar los números 1, 2, 3 (Puntos de Slick) */
.slick-dots {
    display: none !important;
}

/* Ocultar flechas duplicadas (Solo mostrar las de la región de texto frontal) */
.layout__region--second .slick-prev,
.layout__region--second .slick-next {
    display: none !important;
}

/* Transformar "Anterior/Siguiente" en Flechas Redondas */
.slick-prev, .slick-next {
    font-size: 0 !important; /* Oculta la palabra literal */
    color: transparent !important;
    background-color: #28a745 !important; /* Verde vivo */
    border: none !important;
    outline: none !important;
    width: 45px !important;
    height: 45px !important;
    border-radius: 50% !important; /* Redondos perfectos */
    cursor: pointer !important;
    box-shadow: 0 4px 6px rgba(0,0,0,0.2) !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    display: inline-block !important; /* Mantenerlos uno junto al otro */
    margin: 20px 10px 0 0 !important; /* Separación sutil del texto */
}

/* Efecto hover interactivo */
.slick-prev:hover, .slick-next:hover {
    background-color: #218838 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 12px rgba(0,0,0,0.3) !important;
    color: transparent !important;
}

/* Inyectar las flechas visuales ❮ y ❯ */
.slick-prev::before, .slick-next::before {
    font-size: 22px !important;
    color: #ffffff !important;
    line-height: 45px !important;
    display: block !important;
    text-align: center !important;
    font-weight: 900 !important;
    font-family: Arial, sans-serif !important;
}
.slick-prev::before {
    content: "❮" !important; 
}
.slick-next::before {
    content: "❯" !important;
}

/* ============================================================ */
/* ===== 6. ESTRUCTURA LAYOUT BUILDER (ESTILO ATENEA) =====     */
/* ============================================================ */
/* Contenedores Estrictos y Respiración (Adiós a lo "Aplastado") */
#main-wrapper .layout {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 30px 20px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Forzar que el primer contenedor no tenga espacio arriba para que el carrusel pegue al menú */
#main-wrapper .layout:first-of-type,
#main-wrapper .layout:first-child {
    padding-top: 0 !important;
}

/* Hero Full Width Limpio */
.field--name-field-imagen-conocenos img,
.easy-carousel--simple img {
    width: 100% !important;
    height: 60vh !important;
    object-position: top center !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 0 !important;
}

/* HERO CARRUSEL: Ancho completo y altura controlada para párrafos o vistas slick */
.paragraph--type--carrusel-inicio,
.view-slider,
#block-easy-carousel-principal-inicio,
.block-simple-carousel-block {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.paragraph--type--carrusel-inicio img,
.paragraph--type--carrusel-inicio .slick-slide img,
.view-slider img,
#block-easy-carousel-principal-inicio img,
.block-simple-carousel-block img {
    width: 100vw !important;
    height: 420px !important;
    max-height: 55vh !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
}

/* Títulos con Jerarquía y Fuerza */
.layout__region h2,
.layout__region h3 {
    font-weight: 900 !important;
    color: #1a1a1a !important;
}

/* Imágenes que no se cortan (Construyendo futuro) */
.layout__region img {
    margin-bottom: 0 !important;
    display: block !important;
    max-width: 100% !important;
    height: auto !important;
}

/* ============================================================ */
/* ===== 7. GALERÍA ESCALONADA =====                            */
/* ============================================================ */
.view-carrusel-imagenes-inicio .view-content {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 15px !important;
    padding: 30px 0 !important;
}

.view-carrusel-imagenes-inicio .views-row {
    flex: 0 0 auto !important;
}

.view-carrusel-imagenes-inicio img {
    border-radius: 18px !important;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15) !important;
    width: 180px !important;
    height: 300px !important;
    object-fit: cover !important;
    transition: transform 0.4s ease, box-shadow 0.4s ease !important;
}

.view-carrusel-imagenes-inicio img:hover {
    transform: scale(1.05) translateY(-5px) !important;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.25) !important;
}

.view-carrusel-imagenes-inicio .views-row:nth-child(even) {
    margin-top: 35px !important;
}

.view-carrusel-imagenes-inicio .views-field-title {
    display: none !important;
}

/* ============================================================ */
/* ===== 8. GRID DE CURSOS (TABS Y BOTONES) =====               */
/* ============================================================ */
.field--name-field-tabs-centros {
    transition: background-color 0.4s ease !important;
    border-radius: 20px;
    position: relative;
    padding: 0 !important;
    margin-top: 40px;
}

.custom-tabs-header {
    display: flex;
    width: 100%;
    border-radius: 20px 20px 0 0;
    overflow: hidden;
}

.custom-tab-button {
    flex: 1;
    border: none !important;
    padding: 15px 10px;
    font-weight: bold;
    font-size: 16px;
    color: #1a1a1a !important;
    cursor: pointer;
    transition: filter 0.3s;
    text-align: center;
}

.custom-tab-button.active {
    box-shadow: inset 0 -5px 0 rgba(0, 0, 0, 0.2) !important;
    font-weight: 900 !important;
    filter: brightness(1.05);
}

.paragraph--type--centro-experiencia {
    background: transparent !important;
    width: 100% !important;
    padding: 40px 20px !important;
}

/* Grid responsivo PRO */
.paragraph--type--centro-experiencia .field--name-field-cursos>.field__items {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
    gap: 30px !important;
    justify-items: center !important;
}

.paragraph--type--cursi-item {
    text-align: center;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    width: 100%;
}

.paragraph--type--cursi-item img {
    background: white !important;
    border-radius: 50% !important;
    padding: 20px !important;
    width: 130px !important;
    height: 130px !important;
    object-fit: contain !important;
    flex-shrink: 0 !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05) !important;
    margin-bottom: 15px !important;
}

.paragraph--type--cursi-item .field--name-field-titulo-texto {
    font-weight: 800;
    color: #0056b3;
    text-transform: uppercase;
    font-size: 16px;
    margin-top: 10px;
}

/* =========================================
   13. CARRUSEL DE CURSOS SUBA-TIC (FIX DOM REAL)
========================================= */

/* --- CONTENEDOR PRINCIPAL --- */
.vista-carrusel-cursos {
    max-width: 1200px;
    margin: 60px auto 80px auto !important;
    padding: 0 15px !important;
}

/* --- TÍTULO DE LA SECCIÓN --- */
.vista-carrusel-cursos h2 {
    font-size: 45px !important;
    margin: 0 0 60px 0 !important;
    color: #1a1a1a !important;
    line-height: 1.1 !important;
}
.vista-carrusel-cursos h2 span.cyan,
.vista-carrusel-cursos h2 strong,
.vista-carrusel-cursos span.cyan {
    color: #00d2ff !important;
    font-weight: 800 !important;
}

/* --- LA CUADRÍCULA REAL (Usando CSS Grid) --- */
/* Apuntamos directamente a .view-content que vimos en tu inspector */
.vista-carrusel-cursos .view-content {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important; /* Fuerza las 4 columnas */
    gap: 60px 30px !important; /* 60px de espacio vertical para el ícono, 30px horizontal */
    padding-top: 45px !important; /* Espacio para que el ícono sobresalga y no se corte */
    margin: 0 auto !important; /* Resetea el margen de la clase .row de Bootstrap */
    width: 100% !important;
}

/* --- LA TARJETA GRIS (Apuntamos a .views-row) --- */
.vista-carrusel-cursos .views-row {
    background-color: #f2f2f2 !important; 
    border-radius: 6px !important;
    padding: 0 15px 20px 15px !important;
    display: flex !important;
    flex-direction: column !important; /* Elementos en columna */
    align-items: center !important;
    justify-content: flex-end !important;
    min-height: 110px !important; 
    transition: transform 0.3s ease, background-color 0.3s ease !important;
    margin: 0 !important;
}

.vista-carrusel-cursos .views-row:hover {
    transform: translateY(-5px) !important;
    background-color: #e8e8e8 !important; 
}

/* --- ORDENAMOS EL CONTENIDO (Porque Drupal lo saca al revés) --- */
.vista-carrusel-cursos .views-field-field-icono-del-curso {
    order: 1 !important; /* Obligamos al ícono a ir arriba */
    width: 100% !important;
    margin: 0 !important;
}

.vista-carrusel-cursos .views-field-title {
    order: 2 !important; /* Obligamos al título a ir abajo */
}

/* --- ÍCONOS FLOTANTES --- */
.vista-carrusel-cursos img,
.vista-carrusel-cursos svg {
    height: 85px !important; 
    width: 85px !important;
    object-fit: contain !important;
    margin: -65px auto 15px auto !important; /* Extraemos el ícono hacia arriba */
    display: block !important;
    position: relative !important;
    z-index: 5 !important;
    filter: drop-shadow(0.5px 0 0 #00bfeb) drop-shadow(-0.5px 0 0 #00bfeb) drop-shadow(0 0.5px 0 #00bfeb) drop-shadow(0 -0.5px 0 #00bfeb) !important;
    transition: all 0.4s ease !important;
}

.vista-carrusel-cursos .views-row:hover img,
.vista-carrusel-cursos .views-row:hover svg {
    transform: scale(1.15) !important;
    filter: drop-shadow(0 0 10px #00e7ff) drop-shadow(0 0 15px rgba(0, 231, 255, 0.6)) !important;
}

/* --- TEXTOS DEL CURSO --- */
.vista-carrusel-cursos .views-field-title {
    font-size: 13px !important;
    color: #333333 !important;
    margin: 0 !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
    text-transform: uppercase !important;
    text-align: center !important;
    width: 100% !important;
    display: block !important;
}

/* Limpieza de nombres de archivo no deseados (En caso de que Drupal los meta de nuevo) */
.vista-carrusel-cursos div[class*="views-field-icono"] .field--name-name,
.vista-carrusel-cursos .field--name-name {
    display: none !important;
}

/* --- AJUSTE MÓVIL: GALERÍA TÁCTIL 2x2 --- */
@media (max-width: 768px) {
    .vista-carrusel-cursos {
        overflow: hidden !important; /* Para que el slider crezca pero no dañe la pantalla */
    }
    
    .vista-carrusel-cursos .view-content {
        /* Configuración del CSS Grid para forzar orientación horizontal con 2 filas */
        display: grid !important;
        grid-template-columns: none !important; /* CRÍTICO: Matar las 4 columnas del desktop */
        grid-template-rows: repeat(2, 1fr) !important;
        grid-auto-columns: 42vw !important; /* Forzar el ancho de la columna estrictamente al 42% */
        grid-auto-flow: column !important; /* Construye el contenido hacia la derecha, no hacia abajo */
        gap: 65px 15px !important;
        column-gap: 15px !important; /* Refuerzo para iOS */
        row-gap: 65px !important;
        
        /* Habilitar deslizamiento suave */
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        scrollbar-width: none; /* Firefox */
        
        /* Romper contenedores para que el slider fluya de lado a lado */
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(-50vw + 50%) !important;
        padding-left: 5vw !important;
        padding-right: 5vw !important;
        padding-bottom: 25px !important;
        box-sizing: border-box !important;
    }
    
    /* Ocultar barra en Webkit */
    .vista-carrusel-cursos .view-content::-webkit-scrollbar {
        display: none !important;
    }

    .vista-carrusel-cursos .views-row {
        scroll-snap-align: start;
        width: 100% !important; 
        
        /* EL TRUCO DEFINITIVO: Cortar la pintura gris en los bordes */
        border-left: 8px solid white !important;
        border-right: 8px solid white !important;
        background-clip: padding-box !important; /* Evita que el gris pinte debajo del borde blanco */
        
        margin: 0 auto !important; /* Centrado */
    }
}

/* =========================================
   14. SECCIÓN EXPLORA Y FRANJA ROJA
========================================= */

/* --- 1. FRANJA ROJA REBELDE (Ancho 100vw) --- */
.franja-roja-subalab {
    background-color: #f5333f;
    color: #ffffff;
    /* El truco mágico para romper un contenedor sin usar absolute ni scripts */
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    padding: 15px 20px;
    box-sizing: border-box !important; /* CRÍTICO: Evita el desbordamiento por culpa del padding */
    text-align: center;
    font-size: 18px;
    font-weight: 500;
    margin-top: 40px;
    margin-bottom: 60px;
}

/* --- 2. CARRUSEL IMÁGENES DERECHO (.carrusel-imagenes-explora) --- */
.carrusel-imagenes-explora .slick-slide {
    padding: 0 10px; /* Para que las tarjetas no se peguen entre sí */
    position: relative;
}

/* El bloque contenedor de cada imagen */
.carrusel-imagenes-explora .views-row {
    height: 400px; /* Altura fija vertical para ese look elegante */
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Controlando la imagen de fondo (object-fit cover) */
.carrusel-imagenes-explora img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

/* Película negra translúcida para que la letra sobre la foto resalte (Filtro base) */
.carrusel-imagenes-explora .views-row::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.45);
    z-index: 2;
}

/* --- APAGAMOS LOS BOTONES DUPLICADOS DE LAS IMÁGENES --- */
.carrusel-imagenes-explora .slick-arrow {
    display: none !important;
}

/* --- 3. TÍTULOS SUPERPUESTOS EN LAS IMÁGENES --- */
.carrusel-imagenes-explora .views-field-title {
    position: relative;
    z-index: 3;
    font-size: 32px;
    font-weight: 900;
    text-transform: uppercase;
    text-align: center;
    line-height: 1.1;
    max-width: 140px; 
    padding: 15px; 
    border: 3px solid #ffffff; 
    color: #ffffff;
}

/* Magia de Colores Rotativos para Textos y Bordes */
.carrusel-imagenes-explora .slick-slide:nth-child(3n+1) .views-field-title {
    color: #f7d002;
    border-color: #f7d002;
}
.carrusel-imagenes-explora .slick-slide:nth-child(3n+2) .views-field-title {
    color: #f5333f;
    border-color: #f5333f;
}
.carrusel-imagenes-explora .slick-slide:nth-child(3n+3) .views-field-title {
    color: #00d2ff;
    border-color: #00d2ff;
}

/* --- 4. TEXTOS DINÁMICOS IZQUIERDOS (.carrusel-textos-explora) --- */
.carrusel-textos-explora .views-field-title {
    font-size: 30px;
    font-weight: 800;
    color: #5add8b; 
    margin-bottom: 5px;
}

.carrusel-textos-explora .views-field-body,
.carrusel-textos-explora p {
    font-size: 16px;
    color: #555555;
    line-height: 1.5;
    margin-bottom: 20px;
}

/* --- 5. CONTROLES Y FLECHAS DE SLICK IZQUIERDO --- */
.carrusel-textos-explora .slick-slider {
    padding-bottom: 60px;
}

.carrusel-textos-explora .slick-arrow {
    width: 45px !important;
    height: 45px !important;
    background-color: #5add8b !important; 
    border-radius: 0; 
    top: auto; 
    bottom: 0px; 
    transform: none; 
    z-index: 10;
}

.carrusel-textos-explora .slick-prev {
    left: 0;
}
.carrusel-textos-explora .slick-next {
    left: 55px; 
}

.carrusel-textos-explora .slick-prev::before,
.carrusel-textos-explora .slick-next::before {
    color: #000000 !important;
    font-size: 24px;
    opacity: 1 !important; 
}
