/*
 * Altura compartida de los heroes de la web publica.
 *
 * Este archivo es la unica fuente de verdad para Inicio, Nosotros, Donar,
 * Conexion Corporativa, Transparencia y Campana. En Donar se controla el slide
 * superior de campana, no el bloque informativo que aparece debajo. El alto se
 * mantiene igual entre paginas para un mismo viewport.
 */
:root {
    /* Respaldo para navegadores que aun no reconocen las unidades svh. */
    --afa-public-hero-height: 780px;
}

@supports (height: 100svh) {
    :root {
        --afa-public-hero-height: clamp(
            760px,
            calc(100svh - var(--afa-global-header-height, 90px)),
            820px
        );
    }
}

/*
 * Cuando existe navegación contextual, la altura compartida corresponde a la
 * unidad completa: hero/slide + topic-nav. La fila del hero toma el espacio
 * restante y la navegación conserva solamente el alto que necesita.
 */
.afa-hero-topics {
    height: var(--afa-public-hero-height) !important;
    min-height: var(--afa-public-hero-height) !important;
    max-height: var(--afa-public-hero-height) !important;
}

#afa-inicio-wrapper .afa-inicio-hero-section,
#afa-nosotros .nos-hero,
#afa-donar .donar-campaign,
#afa-conexion .cx-hero,
.afa-tp-hero,
#afa-campana .hero {
    box-sizing: border-box !important;
    height: var(--afa-public-hero-height) !important;
    min-height: var(--afa-public-hero-height) !important;
    max-height: var(--afa-public-hero-height) !important;
}

/* Un hero dentro de la unidad compuesta no vuelve a reservar el alto total. */
#afa-inicio-wrapper .afa-hero-topics > .afa-inicio-hero-section,
#afa-nosotros .afa-hero-topics > .nos-hero,
#afa-donar .afa-hero-topics > .donar-campaign,
#afa-conexion .afa-hero-topics > .cx-hero,
#afa-transparencia .afa-hero-topics > .afa-tp-hero,
#afa-campana .afa-hero-topics > .hero,
#afa-contacto .afa-hero-topics > .afa-contacto-hero,
#afa-programas .afa-hero-topics > .afa-programas-hero,
#afa-noticias-eventos .afa-hero-topics > .ne-hero,
#afa-impacto-publico .afa-hero-topics > .imp-header {
    height: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
}

#afa-noticias-eventos .afa-hero-topics > .ne-hero,
#afa-impacto-publico .afa-hero-topics > .imp-header {
    margin-bottom: 0 !important;
}

/* El slider de Inicio conserva el recorte fotografico y nunca crea scroll. */
#afa-inicio-wrapper .afa-inicio-hero-section {
    aspect-ratio: auto !important;
    overflow: hidden !important;
}

/*
 * Los heroes con texto conservan todo su contenido si el usuario aumenta el
 * tamano tipografico. En la escala normal no aparece desplazamiento.
 */
#afa-nosotros .nos-hero,
#afa-donar .donar-campaign,
#afa-conexion .cx-hero,
.afa-tp-hero,
#afa-campana .hero {
    overflow-x: hidden !important;
    overflow-y: auto !important;
}

/* Centrado vertical de las composiciones que no lo declaraban originalmente. */
#afa-donar .donar-campaign,
.afa-tp-hero,
#afa-campana .hero {
    display: grid;
    align-items: center;
}

/*
 * El rotulo y la imagen de Donar se distribuyen dentro de la altura comun.
 * Se anula la proporcion especial para pantallas ultraanchas porque producia
 * un alto distinto al resto de las paginas.
 */
#afa-donar .donar-campaign-shell {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    height: 100%;
    min-height: 0;
}

#afa-donar .donar-campaign-slider {
    height: auto !important;
    min-height: 0 !important;
    align-self: stretch;
    aspect-ratio: auto !important;
}

#afa-donar .donar-campaign {
    overflow: hidden !important;
}

.afa-tp-hero__inner {
    align-content: center;
}

/*
 * En tablet y celular se compactan solamente los elementos visuales del hero.
 * Los textos y acciones permanecen completos, bilingues y tactiles.
 */
@media (max-width: 979px) {
    #afa-nosotros .nos-hero,
    #afa-conexion .cx-hero,
    #afa-campana .hero {
        padding-block: clamp(1.5rem, 5vw, 2.5rem) !important;
    }

    #afa-nosotros .nos-hero-grid,
    #afa-donar .donar-hero-grid,
    #afa-conexion .cx-hero-grid,
    #afa-campana .hero__layout {
        gap: clamp(0.9rem, 3vw, 1.5rem) !important;
    }

    #afa-nosotros .nos-hero-map {
        min-height: 190px !important;
    }

    #afa-conexion .cx-hero-media {
        width: min(100%, 360px) !important;
        margin-inline: auto !important;
    }

    #afa-conexion .cx-hero-media video {
        width: 100% !important;
        height: 190px !important;
        max-height: 190px !important;
        aspect-ratio: auto !important;
        object-fit: cover !important;
    }

    #afa-campana .hero__visual {
        width: min(100%, 280px) !important;
        min-height: 210px !important;
    }

    #afa-campana .hero__art--main {
        width: min(62%, 170px) !important;
    }

    .afa-tp-hero__inner {
        padding-block: clamp(1.5rem, 5vw, 2.5rem) !important;
    }
}

@media (max-width: 420px) {
    #afa-campana .hero__visual {
        min-height: 180px !important;
    }

    #afa-campana .hero__art--main {
        width: min(54%, 145px) !important;
    }
}

/* La impresion no debe reservar una altura de pantalla artificial. */
@media print {
    .afa-hero-topics,
    #afa-inicio-wrapper .afa-inicio-hero-section,
    #afa-nosotros .nos-hero,
    #afa-donar .donar-campaign,
    #afa-conexion .cx-hero,
    .afa-tp-hero,
    #afa-campana .hero {
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: visible !important;
    }
}
