/* Banner */

.enclosure {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-height: 60vh;
    align-items: center;
    justify-content: center;
}

.banner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: 16px 0px;
}

.banner p {
    font-family: 'Roboto', sans-serif !important;
    margin: 0px !important;
}

.banner1 {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 16px;
    width: 100%;
    min-height: 50vh;
}

.banner1 .esquerda {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
}

.banner1 .direita {
    flex: 1;
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
}

.banner1 .direita .preview {
    display: block;
    height: 100% !important;
    background-size: cover;
    background-position: center;
}

.banner2 {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    align-items: center;
    gap: 16px;
    width: 100%;
    min-height: 50vh;
}

.banner2 .esquerda {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
}


.banner2 .direita {
    flex: 1;
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
}

.banner2 .direita .preview {
    display: block;
    height: 100% !important;
    background-size: cover;
    background-position: center;
}

.banner3 {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 16px;
    width: 100%;
    min-height: 50vh;

}

.banner3 .centro {
    flex: 2;
    display: flex;
    flex-direction: column;
    gap: 16px;
    justify-content: flex-start;
    align-items: center;
    text-align: center;
}

.banner3 .direita {
    flex: 1;
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 8/10;
}

.banner3 .direita .preview {
    display: block;
    height: 100% !important;
    background-size: cover;
    background-position: center;
}

.banner3 .esquerda {
    flex: 1;
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 8/10;
}

.banner3 .esquerda .preview {
    display: block;
    height: 100% !important;
    background-size: cover;
    background-position: center;
}

@media (min-width: 1025px) and (max-width: 1560px){
    .banner .high p{
        font-size: 4.8rem !important;
    }
}

.banner .high p {
    font-size: 5.8rem;
    font-weight: bold;
    line-height: 5.6rem;
    margin: 0px;
}

.banner .subtitle p {
    font-size: 1.8rem;
    font-weight: bold;
    margin: 0px;
}

@media (max-width: 599px) {

    .banner {
        justify-content: space-between;
        padding: 16px 0px;
    }

    .banner1 {
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        min-height: 70vh;
    }

    .banner1 .esquerda {
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 8px;
        align-items: center;

    }

    .banner1 .direita {
        flex: 1 !important;
        display: block;
        position: relative;
        width: calc(100vw - 32px);
        aspect-ratio: 16/9;
    }

    .banner1 .direita .preview {
        display: block;
        height: 100% !important;
        background-size: cover;
        background-position: center;
    }

    .banner2 {
        flex-direction: column;
        align-items: center;
        min-height: 70vh;
    }

    .banner2 .esquerda {
        align-items: center;
        justify-content: center;
        gap: 8px;

    }

    .banner2 .direita {
        display: block;
        position: relative;
        width: calc(100vw - 32px);
        aspect-ratio: 16/9;
    }

    .banner2 .direita .preview {
        display: block;
        height: 100% !important;
        background-size: cover;
        background-position: center;
    }


    .banner3 {
        flex-direction: column-reverse;
        align-items: center;
        min-height: 70vh;
    }

    .banner3 .esquerda {
        flex: 1 !important;
        display: block;
        position: relative;
        width: calc(100vw - 32px);
        aspect-ratio: 16/9;
    }

    .banner3 .esquerda .preview {
        display: block;
        height: 100% !important;
        background-size: cover;
        background-position: center;
    }

    .banner3 .centro {
        gap: 8px;
        justify-content: center;
    }

    .banner3 .direita {
        flex: 1;
        display: none;
    }


    /* helper */
    @media (max-width: 350px){
        .banner .high p{
            font-size: 3rem !important;
        }
    }


    .banner .high p {
        font-size: clamp(3.5rem, 1rem, 5.4rem);
        font-weight: bold;
        line-height: clamp(3.5rem, 1rem, 5.4rem);
        margin: 0px;
        text-align: center;
        width: 100% !important;
        word-break: break-word;
    }

    .banner .subtitle p {
        font-size: 1.8rem;
        font-weight: bold;
        margin: 0px;
        text-align: center;
    }
}

@media (min-width: 600px) and (max-width: 1024px) {

    .banner {
        padding: 16px 0px;
    }

    .banner1 {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        min-height: 80vh;
    }

    .banner1 .esquerda {
        display: flex;
        flex-direction: column;
        gap: 16px;
        align-items: center;
        position: relative;
        width: 60% !important;
    }

    .banner1 .direita {
        flex: 1 !important;
        display: block;
        position: relative;
        width: 100%;
        aspect-ratio: 16/8;
    }

    .banner1 .direita .preview {
        display: block;
        height: 100% !important;
        background-size: cover;
        background-position: center;
    }

    .banner2 {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        column-gap: 16px;
        gap: 16px;
        min-height: 80vh;
    }

    .banner2 .esquerda {
        display: flex;
        flex-direction: column;
        gap: 16px;
        align-items: center;
        width: 60%;
    }

    .banner2 .direita {
        flex: 1 !important;
        display: block;
        position: relative;
        width: 100%;
        aspect-ratio: 16/8;
    }

    .banner2 .direita .preview {
        display: block;
        height: 100% !important;
        background-position: center;
        background-size: contain
    }

    .banner3 {
        display: flex;
        flex-direction: column-reverse;
        justify-content: flex-end;
        align-items: center;
        gap: 16px;
        min-height: 80vh;
    }

    .banner3 .esquerda {
        flex: 1 !important;
        display: block;
        position: relative;
        width: 100%;
        aspect-ratio: 16/8;
    }

    .banner3 .esquerda .preview {
        display: block;
        height: 100% !important;
        background-size: cover;
        background-position: center;
    }

    .banner3 .centro {
        flex: 1;
        display: flex;
        flex-direction: column;
        gap: 16px;
        align-items: flex-start;
        justify-content: center;
        align-items: center;
        text-align: center;
        width: 60%;
    }

    .banner3 .direita {
        flex: 1;
        display: none;
    }

    .banner .high p {
        font-size: 5.6rem;
        font-weight: bold;
        line-height: 5.6rem;
        margin: 0px;
        text-align: center;
    }

    .banner .subtitle p {
        font-size: 1.8rem;
        font-weight: bold;
        margin: 0px;
        text-align: center;
    }

    .banner .high p {
        font-size: 3.8rem;
        font-weight: bold;
        line-height: 5.6rem;
        margin: 0px;
    }
    
    .banner .subtitle p {
        font-size: 1.8rem;
        font-weight: bold;
        margin: 0px;
    }
}


@media(max-width: 599px) {
    .desapear {
        display: none;
    }

    .desapear_med {
        display: none;
    }

    .alm_banner_download {
        width: 100%;
        height: 37vh !important;
        background-image: url('/images/banner_downloads_m.svg');
        background-position: bottom;
        background-repeat: no-repeat;
        padding: 16px !important;

    }

}

@media (min-width: 600px) and (max-width: 1024px) {
    .desapear {
        display: none;
    }

    .desapear_min {
        display: none;
    }


    .alm_banner_download {
        width: 100%;
        height: 37vh !important;
        background-image: url('/images/banner_downloads_l.svg');
        background-position: bottom;
        background-repeat: no-repeat;
        padding: 16px !important;

    }
}

@media (min-width: 1025px) {
    .desapear_med {
        display: none;
    }

    .desapear_min {
        display: none;
    }



    .alm_banner_download {
        width: 100%;
        height: 37vh !important;
        background-image: url('/images/banner_downloads.svg');
        background-position: bottom;
        background-repeat: no-repeat;
        padding: 16px !important;

    }
}

/* Parceiros */
.geweb {
    background-image: url("/images/geweb_new.svg");
    background-size: 80%;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
    transition: all .2s ease-in-out;
    cursor: pointer
}

.alimentacao {
    background-image: url("/images/nutrigov_min.svg");
    background-size: 80%;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
    transition: all .2s ease-in-out;
    cursor: pointer
}

.compras {
    background-image: url("/images/comprasgov_min.svg");
    background-size: 80%;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
    filter: grayscale(100);
    transition: all .2s ease-in-out;
    cursor: not-allowed
}

.etransporte {
    background-image: url("/images/etransporte_min.svg");
    background-size: 80%;
    background-position: center;
    position: relative;
    background-repeat: no-repeat;
    filter: grayscale(100);
    transition: all .2s ease-in-out;
    cursor: not-allowed
}