#banner .box {
    color: var(--branco);
    width: 33.33%;
}

#banner .box .num {
    font-weight: 800;
    font-size: 1.875vw;
    border-bottom: 0.94px solid #CDCDCD;
    padding-bottom: 5px;
    margin-bottom: 10px;
    text-align: center;
}

#banner .box .numv2 {
    font-weight: 700;
    font-size: 0.9375vw;
    border-bottom: 0.94px solid #CDCDCD;
    text-transform: uppercase;
    padding-bottom: 5px;
    margin-bottom: 10px;
    text-align: center;
}

#banner .box .num .mais {
    color: #08A8F7;
    font-size: 1.354vw;
}

#banner .box .num .apoio {
    font-size: 1.25vw;
}

#banner .box .info {
    text-align: center;
    font-size: 13.5px;
}

#banner .blocos {
    display: flex;
    gap: 3.125vw;
    row-gap: 1.5vw;
}

#banner .esq {
    width: 50.45%;
    position: relative;
}

#banner .dir {
    width: 49%;
    height: 39vw;
    position: absolute;
    right: 0;
    bottom: 0;
    background-image: url(../../tecnologia/produtos/mistral-produtos-banner.webp);
    background-repeat: no-repeat;
    background-size: cover;
}

#banner .container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

#banner {
    background-color: #fafbff;
    background-image: url(../../tecnologia/home/banner-bg.webp);
    background-repeat: no-repeat;
    background-size: 21.968vw;
    background-position: left 8vw;
    padding: 13.5vw 0 13vw;
    position: relative;
    overflow: hidden;
}

#banner .titulo {
    color: var(--roxo);
    font-weight: 700;
    font-size: 2.5vw;
    line-height: 2.9166vw;
}

#banner .texto {
    color: #26276C;
    font-size: 0.9375vw;
    line-height: 1.4583vw;
    letter-spacing: 0.01em;
    max-width: 586px;
    margin: 1.8vw 0;
}

#banner .btn-contato {
    color: var(--branco);
    font-size: 0.7291vw;
    background-color: var(--roxo);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;
    display: block;
    padding: 0.59895vw 0vw;
    font-weight: 700;
    overflow: hidden;
    position: relative;
    transition: var(--transicao);
    -webkit-transition: var(--transicao);
    -moz-transition: var(--transicao);
    -ms-transition: var(--transicao);
    -o-transition: var(--transicao);
    max-width: 214px;
}

#banner .btn-contato svg {
    filter: brightness(10);
}

#banner .conteudo {
    position: relative;
    z-index: 1;
    padding: 0 7vw 0 10vw;
}

#banner .destaque {
    color: var(--branco);
    font-weight: 500;
    font-size: 14px;
    line-height: 24px;
    text-align: center;
    text-transform: uppercase;
    margin-bottom: 20px;
}

#solucoes {
    padding: 4vw 0;
    position: relative;
    background-color: #fafbff;
}

#solucoes .titulo {
    font-weight: 300;
    font-size: 1.875vw;
    line-height: 2.5vw;
    text-align: center;
    margin-bottom: 25px;
}

#solucoes .titulo b {
    font-weight: 700;
    color: var(--roxo);
}

#solucoes .texto {
    font-weight: 500;
    font-size: 0.833vw;
    line-height: 1.3541vw;
    text-align: center;
    max-width: 750px;
    margin: 0 auto;
}

#solucoes .tit {
    font-size: 1.45833vw;
    line-height: 1.875vw;
    color: var(--roxo);
    margin-bottom: 15px;
}

#solucoes .info {
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
}

#solucoes .blocos {
    display: flex;
    flex-wrap: wrap;
    gap: 25px;
    row-gap: 50px;
    margin-top: 40px;
    position: relative;
}

#solucoes .blocos::after {
    content: url(../../tecnologia/triangulos.png);
    transform: rotate(90deg);
    position: absolute;
    top: 55%;
    right: -5vw;
}

#solucoes::before {
    content: ' ';
    display: block;
    width: 17.2395vw;
    height: 22.4479vw;
    background-image: url(../../tecnologia/home/solucoes-detalhe.webp);
    background-size: cover;
    position: absolute;
    top: 22vw;
    left: 0;
}

#solucoes .container {
    position: relative;
}

#solucoes .antes {
    width: 4.427vw;
    height: 5.156vw;
    position: absolute;
    top: -2vw;
    left: 10vw;
}

#solucoes .depois {
    width: 4.427vw;
    height: 5.156vw;
    position: absolute;
    top: 0;
    right: 10vw;
}

#solucoes .box {
    background-color: #eceff6;
    border: 1px solid #D7D7D7;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
    padding: 3.3333vw 2.8645vw;
    width: calc(33.333% - 16.6666px);
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 17.0833vw;
    transition: var(--transicao);
    -webkit-transition: var(--transicao);
    -moz-transition: var(--transicao);
    -ms-transition: var(--transicao);
    -o-transition: var(--transicao);
}

#solucoes .box:hover {
    box-shadow: 0px 5px 10px 0px #00000040;
}

#solucoes .btn {
    color: var(--branco);
    font-size: 0.7291vw;
    background-color: var(--chumbo);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;
    display: block;
    padding: 0.59895vw 1.1458vw;
    font-weight: 700;
    overflow: hidden;
    position: relative;
    transition: var(--transicao);
    -webkit-transition: var(--transicao);
    -moz-transition: var(--transicao);
    -ms-transition: var(--transicao);
    -o-transition: var(--transicao);
    position: absolute;
    width: calc(100% - 5.729vw);
    left: 2.8645vw;
    bottom: -19px;
}

#solucoes .btn.animacao-btn::before,
#solucoes .btn.animacao-btn::after {
    background: var(--roxo);
}

#solucoes .btn.animacao-btn span {
    justify-content: space-between;
}

#solucoes .ico {
    position: absolute;
    top: 2.343vw;
    right: 2.343vw;
}

#problemas {
    position: relative;
    padding: 5vw 0;
    background: #FAFBFF;
}

#problemas::before {
    content: ' ';
    display: block;
    width: 17.2395vw;
    height: 22.4479vw;
    background-image: url(../../tecnologia/home/solucoes-detalhe.webp);
    background-size: cover;
    position: absolute;
    bottom: 10vw;
    right: 0;
    transform: rotateY(180deg);
    -webkit-transform: rotateY(180deg);
    -moz-transform: rotateY(180deg);
    -ms-transform: rotateY(180deg);
    -o-transform: rotateY(180deg);
}

#problemas .container {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
}

#problemas .container::after {
    content: url(../../tecnologia/triangulos.png);
    transform: rotate(90deg);
    position: absolute;
    top: 1%;
    left: -5vw;
}

#problemas .esq {
    width: 47%;
    position: sticky;
    top: 80px;
}

#problemas .esq img {
    margin-left: -0.7vw;
}

#problemas .dir {
    width: 50%;
}

#problemas .titulo {
    color: var(--roxo);
    font-weight: 700;
    font-size: 1.875vw;
    line-height: 2.2916vw;
    margin-bottom: 20px;
}

#problemas .texto {
    font-weight: 500;
    font-size: 0.833vw;
    line-height: 1.3541vw;
    margin-bottom: 45px;
    max-width: 594px;
}

#problemas .texto span {
    font-weight: 700;
    color: #26276C;
}

#problemas .etapa {
    border: 1px solid #D7D7D7;
    background-color: #EDEFF7;
    position: relative;
    padding: 1.45vw 2.04vw;
    margin-top: 20px;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}

#problemas .etapa .titulo-etapa {
    font-size: 16px;
    font-weight: 700;
    line-height: 24px;
    margin-top: 15px;
    color: #26276C;
}

#problemas .btn-contato {
    color: var(--branco);
    font-size: 0.7291vw;
    background-color: var(--chumbo);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;
    display: block;
    padding: 0.59895vw 1.1458vw;
    font-weight: 700;
    overflow: hidden;
    position: relative;
    transition: var(--transicao);
    -webkit-transition: var(--transicao);
    -moz-transition: var(--transicao);
    -ms-transition: var(--transicao);
    -o-transition: var(--transicao);
    max-width: 294px;
    margin-top: 30px;
}

#problemas .btn-contato svg {
    filter: brightness(10);
}

#problemas .animacao-btn::before,
#problemas .animacao-btn::after {
    background: var(--roxo);
}

#porque {
    padding: 2vw 0 5vw;
    position: relative;
    background-color: #fafbff;
}

#porque .titulo {
    font-weight: 300;
    font-size: 1.875vw;
    line-height: 2.5vw;
    text-align: center;
}

#porque .titulo span {
    font-weight: 700;
    color: var(--roxo);
}

#porque .texto {
    font-weight: 500;
    font-size: 0.833vw;
    line-height: 1.3541vw;
    text-align: center;
    max-width: 798px;
    margin: 40px auto 0;
}

#porque .destaque {
    font-weight: 700;
    font-size: 0.9375vw;
    line-height: 1.3541vw;
    text-align: center;
    color: var(--roxo);
    max-width: 798px;
    margin: 20px auto 0;
}

#porque .ico {
    width: 45px;
    height: 45px;
    background-color: var(--roxo);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#porque .tit {
    font-size: 1.45833vw;
    line-height: 1.875vw;
    color: var(--roxo);
    margin-bottom: 15px;
    text-align: center;
}

#porque .info {
    font-weight: 500;
    font-size: 16px;
    line-height: 22px;
    text-align: center;
}

#porque p:empty {
    display: none;
}

#porque .blocos {
    display: flex;
    flex-wrap: wrap;
    gap: 25px;
    row-gap: 50px;
    margin-top: 40px;
    position: relative;
}

#porque .blocos::after {
    content: url(../../tecnologia/triangulos.png);
    transform: rotate(90deg);
    position: absolute;
    top: 55%;
    right: -5vw;
}

#porque::before {
    content: ' ';
    display: block;
    width: 17.2395vw;
    height: 22.4479vw;
    background-image: url(../../tecnologia/home/solucoes-detalhe.webp);
    background-size: cover;
    position: absolute;
    top: 22vw;
    left: 0;
}

#porque .container {
    position: relative;
}

#porque .antes {
    width: 4.427vw;
    height: 5.156vw;
    position: absolute;
    top: -2vw;
    left: 17.5vw;
}

#porque .depois {
    width: 4.427vw;
    height: 5.156vw;
    position: absolute;
    top: 0;
    right: 17.5vw;
}

#porque .box {
    background-color: #eceff6;
    border: 1px solid #D7D7D7;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
    padding: 2.3333vw 2.885vw;
    width: calc(33.333% - 16.6666px);
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 15px;
    min-height: 11.4583vw;
    transition: var(--transicao);
    -webkit-transition: var(--transicao);
    -moz-transition: var(--transicao);
    -ms-transition: var(--transicao);
    -o-transition: var(--transicao);
}

#porque .box:hover {
    box-shadow: 0px 5px 10px 0px #00000040;
}

@media screen and (max-width: 1440px) {

    #banner .texto {
        font-size: 16px;
        line-height: 24px;
    }

    #banner .btn-contato,
    #solucoes .btn,
    #problemas .btn-contato {
        font-size: 13px;
        padding: 10px 15px;
    }

    #banner .dir {
        width: 50%;
    }

    #banner .conteudo {
        padding: 0 5% 0 6vw;
    }

    #banner {
        padding: 12.5vw 0 15vw;
    }

    #porque .texto,
    #problemas .texto,
    #solucoes .texto {
        font-size: 14px;
        line-height: 22px;
    }

    #solucoes .blocos::after,
    #porque .blocos::after {
        right: -4%;
    }

    #problemas .destaque,
    #porque .destaque {
        font-size: 16px;
        line-height: 24px;
    }

    #problemas .esq {
        width: 48%
    }

    #problemas .esq img {
        margin-left: -2.7vw;
    }

    #problemas .etapa .numero {
        font-size: 8.8125vw;
        top: 1.5vw;
    }
}

@media screen and (max-width: 1024px) {
    #banner {
        padding: 150px 0 50px;
    }

    #banner .esq {
        width: 100%;
        padding: 0 5%;
    }

    #banner .container {
        flex-direction: column;
        gap: 100px;
        width: 100%;
    }

    #banner .dir {
        width: 106%;
        height: 81vw;
        position: relative;
    }

    #banner .conteudo {
        padding: 0 5% 0 12vw;
    }

    #banner .titulo {
        font-size: 33px;
        line-height: 42px;
    }

    #banner .texto {
        font-size: 18px;
        line-height: 28px;
        margin: 20px 0;
    }

    #banner .box .num {
        font-size: 36px;
    }

    #banner .box .numv2 {
        font-size: 20px;
    }

    #banner .box .num .mais {
        font-size: 26px;
    }

    #banner .box .num .apoio {
        font-size: 24px;
    }

    #banner .blocos {
        gap: 20px;
        row-gap: 25px;
    }

    #banner .box {
        width: calc(50% - 10px);
    }

    #porque .titulo,
    #problemas .titulo,
    #solucoes .titulo {
        font-size: 28px;
        line-height: 36px;
    }

    #porque .texto,
    #problemas .texto,
    #solucoes .texto {
        font-size: 16px;
        line-height: 24px;
    }

    #solucoes .blocos::after,
    #porque .blocos::after {
        right: -6%;
    }

    #solucoes .antes,
    #solucoes .depois {
        display: none;
    }

    #solucoes {
        padding: 50px 0;
    }

    #solucoes .tit {
        font-size: 24px;
        line-height: 28px;
    }

    #solucoes .blocos {
        gap: 20px;
        row-gap: 50px;
    }

    #solucoes .box {
        padding: 40px 30px;
        width: calc(50% - 10px);
        min-height: 42.697vw;
    }

    #solucoes::before {
        content: none;
    }

    #problemas .container::after {
        left: -5vw;
    }

    #problemas {
        padding: 60px 0;
    }

    #problemas .container {
        flex-direction: column;
        gap: 60px;
    }

    #problemas .esq {
        width: 100%;
        position: relative;
        top: auto;
    }

    #problemas .dir {
        width: 100%;
    }

    #problemas .etapa {
        padding: 40px 30px;
    }

    #problemas .etapa .numero {
        font-size: 130px;
        line-height: 100px;
        top: 10px;
        left: 10px;
    }

    #problemas .esq img {
        margin: 0 auto !important;
    }

    #porque .antes,
    #porque .depois {
        display: none;
    }

    #porque {
        padding: 50px 0;
    }

    #porque .tit {
        font-size: 24px;
        line-height: 28px;
    }

    #porque .blocos {
        gap: 20px;
        row-gap: 50px;
    }

    #porque .box {
        padding: 40px 30px;
        width: calc(50% - 10px);
        min-height: 39.697vw;
    }

    #porque::before {
        content: none;
    }
}

@media screen and (max-width: 600px) {
    #banner {
        padding: 150px 0 40px;
    }

    #banner .blocos {
        justify-content: center;
        flex-wrap: wrap;
    }

    #banner .box {
        width: calc(50% - 10px);
    }

    #banner .box .num {
        font-size: 28px;
    }

    #banner .conteudo {
        padding: 0 5% 0 20vw;
    }

    #porque .titulo,
    #problemas .titulo,
    #solucoes .titulo {
        font-size: 26px;
        line-height: 34px;
    }

    #porque .texto,
    #problemas .texto,
    #solucoes .texto {
        font-size: 14px;
        line-height: 22px;
    }

    #solucoes .box {
        padding: 30px 20px 40px;
        width: 100%;
        min-height: 47.697vw;
    }

    #solucoes .blocos::after {
        right: -7%;
        scale: 0.8;
    }

    #solucoes .titulo span {
        display: inline;
    }

    #solucoes .ico {
        top: 12px;
        right: 12px;
    }

    #problemas .container::after {
        left: -7vw;
        scale: 0.8;
    }

    #porque .box {
        padding: 30px 20px;
        width: 100%;
        min-height: 43.697vw;
    }

    #porque .titulo span {
        display: inline;
    }

    #porque .ico {
        top: 12px;
        right: 12px;
    }

    #porque .blocos::after {
        right: -7%;
        scale: 0.8;
    }
}