main{
    background-color: #FCFCFC;
}

.banner{
    width: 100%;
    position: relative;
    align-items: center;
}
.banner-slider{
    width: 100%;
}
.banner-slider .banner-slide{
    width: 100%;
    position: relative;
}
.banner-slider .banner-slide picture,
.banner-slider .banner-slide picture img{
    width: 100%;
    height: fit-content;
    display: flex;
    position: relative;
    object-fit: contain;
}
.banner-slider .banner-slide picture::after{
    content: "";
    display: flex;
    width: 100%;
    height: 100%;
    top: 0;
    position: absolute;
    z-index: 2;
    background-color: #00000045;
    /* background-image: url(../imagens/home/filter.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: top center; */
}
.banner-slider .banner-slide .absolute-container{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    z-index: 10;
}
.banner-slider .banner-slide .absolute-container .container{
    display: flex;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
    gap: 20px;
}
.banner-slider .banner-slide .absolute-container .container .texto{
    max-width: 733px;
    width: 100%;
    gap: 25px;
    margin-left: auto;
    align-items: self-end;
    text-align: end;
    gap: 50px;
}
.banner-slider .banner-slide .absolute-container .container .texto div{
    display: flex;
    gap: 20px;
}
.banner-slider .banner-slide .absolute-container .container .texto div::after{
    content: "";
    display: flex;
    width: 13px;
    height: auto;
    background-color: var(--cor-1);
    border-radius: 50px;
}
.banner-slider .banner-slide .absolute-container .container .texto div h1{
    max-width: calc(100% - 33px);
}
.banner-slider .banner-slide .absolute-container .container .texto div h1,
.banner-slider .banner-slide .absolute-container .container .texto div h1 span{
    color: #fff;
    font-size: 88px;
}
.banner-slider .banner-slide .absolute-container .container .texto div h1 span{
    font-weight: 700;
}
.banner-slider .banner-slide .absolute-container .container .texto a{
    max-width: 265px;
    width: 100%;
    font-weight: 300;
}
.banner .arrows{
    display: flex;
    flex-direction: column;
    gap: 5px;
    position: absolute;
    right: 25px;
}
.banner .arrows i{
    width: 58px;
    height: 58px;
    background-color: transparent;
    border: 2px solid #fff;
    border-radius: 50%;
    cursor: pointer;
    text-align: center;
    align-content: center;
    font-size: 20px;
    color: #fff;
    transition: ease .3s;
}
.banner .arrows i:hover{
    background-color: #fff;
    color: var(--cor-1);
    transition: ease .3s;
}


.conteudo-1{
    width: 100%;
    background-image: url(../imagens/home/bg1.png);
    background-size: cover;
    background-position: center bottom;
    background-repeat: no-repeat;
    background-attachment: fixed;
}
.conteudo-1 .container{
    gap: 75px;
    padding: 200px 0;
}


/* SERVICOS */
.servicos{
    width: 100%;
    height: fit-content;
    gap: 30px;
    transition: ease .3s;
}
.servicos .titulo{
    width: 100%;
    align-items: center;
    gap: 5px;
}
.servicos-div{
    width: 100%;
    height: fit-content;
    justify-content: center;
    position: relative;
    gap: 10px;
    transition: ease .3s;
}
.servicos-div .box-div{
    width: calc(100% - 67% - 10px);
    height: 530px;
    margin: 0 auto;
}
.servicos-div .box{
    width: 100%;
    margin: 0 auto;
    z-index: 10;
    border-radius: 10px;
    position: relative;
    z-index: 2;
    overflow: hidden;
    transition: transform 0.5s ease;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
}
.servicos-div .box .img{
    width: 100%;
    overflow: hidden;
}
.servicos-div .box .img img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.3s ease;
}
.servicos-div .box .texto {
    position: relative;
    text-align: center;
    justify-content: center;
    padding: 20px;
    gap: 10px;
    background: #fff;
    transition: 0.3s ease;
}
.servicos-div .box .texto h4{
    width: 100%;
    text-align: center;
    overflow: hidden; 
    text-overflow: ellipsis; 
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical; 
}
.servicos-div .box .texto p{
    font-size: 18px;
    width: 100%;
    height: 0;
    opacity: 0;
    text-align: justify;
    transition: 0.2s ease;
}
.servicos-div .box .texto .div{
    display: flex;
    opacity: 1;
    width: 100%;
    height: 1px;
    background-color: #000;
}
.servicos-div .box .saiba-mais {
    margin-top: 10px;
    height: fit-content;
    opacity: 1;
}
.servicos-div .box:hover .texto p{
    max-height: 160px;
    height: fit-content;
    overflow: auto;
    opacity: 1;
    transition: 0.5s ease;
}
.servicos-div .box:hover .div,
.servicos-div .box:hover .saiba-mais{
    height: 0;
    opacity: 0;
}


/* DIFERENCIAIS */
.diferenciais{
    width: 100%;
    gap: 30px;
}
.diferenciais .titulo{
    width: 100%;
    align-items: center;
    gap: 5px;
}
.diferenciais .diferenciais-div{
    width: 100%;
    gap: 40px;
}
.diferenciais .diferenciais-div .diferenciais-dots{
    max-width: 1187px;
    width: 100%;
    margin: 0 auto;
    gap: 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.diferenciais .diferenciais-div .diferenciais-dots .arrow i{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: var(--cor-1);
    font-size: 16px;
    color: #fff;
}
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links{
    max-width: calc(100% - 120px);
    width: 100%;
    margin: 0 auto;
}
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links .slick-track{
    margin: 0 auto;
}
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links .slick-slide{
    min-height: 38px;
}
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links .slick-slide.slick-current .box,
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links .box:hover{
    background-color: var(--cor-1);
    transition: ease .3s;
}
.diferenciais .diferenciais-div .diferenciais-dots .diferenciais-links .box{
    width: 95%;
    min-height: 38px;
    height: 100%;
    margin: 0 auto;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: var(--cor-2);
    color: #fff;
    padding: 5px 10px;
    font-size: 20px;
    font-weight: 200;
    transition: ease .3s;
}
.diferenciais .diferenciais-div .diferenciais-slider{
    width: 100%;
}
.diferenciais .diferenciais-div .diferenciais-slider .box{
    width: 99%;
    height: 100%;
    margin: 0 auto;
    display: flex;
    gap: 50px;
}
.diferenciais .diferenciais-div .diferenciais-slider .box .img{
    max-width: 661px;
    width: 100%;
    height: fit-content;
    position: relative;
    padding-bottom: 10px;
}
.diferenciais .diferenciais-div .diferenciais-slider .box .img .img-1{
    width: 99%;
    margin-left: auto;
    object-fit: contain;
    position: relative;
    z-index: 2;
}
.diferenciais .diferenciais-div .diferenciais-slider .box .img .img-2{
    content: "";
    width: 99%;
    object-fit: contain;
    position: absolute;
    z-index: 1;
    left: 0;
    top: 4%;
}
.diferenciais .diferenciais-div .diferenciais-slider .box .texto{
    width: 100%;
}
.diferenciais .diferenciais-div .diferenciais-slider .box .texto p{
    margin-top: 20px;
    font-weight: 200;
}
.diferenciais .diferenciais-div .btn-box{
    max-width: 291px;
    width: 100%;
    margin: 0 auto;
}
.diferenciais .diferenciais-div .btn-box a{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

/* FALE COM EQUIPE */
.fale-equipe{
    width: 100%;
    background-color: var(--primaria);
    background-image: url(../imagens/home/bg-equipe.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.fale-equipe .container{
    display: flex;
    gap: 40px 20px;
}
.fale-equipe .texto{
    max-width: 924px;
    width: 100%;
    gap: 10px;
    padding: 50px 0;
}
.fale-equipe .texto p{
    margin: 10px 0 30px;
    color: #fff;
    font-weight: 200;
    font-size: 22px;
}
.fale-equipe .texto a{
    max-width: 265px;
    width: 100%;
    gap: 10px;
    color: #fff;
    font-size: 18px;
    font-weight: 500;
    margin: 0 auto;
    transition: ease .3s;
}
.fale-equipe .texto a i{
    color: #fff;
    transition: ease .3s;
}
.fale-equipe .texto a:hover{
    background-color: #fff;
    color: var(--cor-1);
    transition: ease .3s;
}
.fale-equipe .texto a:hover i{
    color: var(--cor-1);
    transition: ease .3s;
}
.fale-equipe .img{
    max-width: 578px;
    width: 100%;
    position: relative;
}
.fale-equipe .img img{
    width: 100%;
    position: absolute;
    bottom: 0;
}


.conteudo-2{
    width: 100%;
    background-image: url(../imagens/home/bg2.png);
    background-size: auto;
    background-position: center bottom;
    background-repeat: no-repeat;
}
.conteudo-2 .container{
    gap: 60px;
    padding: 200px 0;
}


/* SOBRE NOS */
.sobre{
    width: 100%;
    display: flex;
    gap: 30px 20px;
    position: relative;
}
.sobre .img{
    max-width: 640px;
    width: 100%;
    align-items: center;
    height: fit-content;
    position: relative;
    z-index: 2;
}
.sobre .img::before{
    content: "";
    width: 120%;
    height: 88%;
    background-color: var(--primaria);
    position: absolute;
    left: -38%;
    z-index: 1;
}
.sobre .img img{
    width: 100%;
    object-fit: contain;
    position: relative;
    z-index: 2;
}
.sobre .texto{
    max-width: 845px;
    width: 100%;
    position: relative;
    z-index: 2;
}
.sobre .texto p {
    margin-top: 20px;
    font-weight: 200;
    font-size: 22px;
}


/* VIDEO */
.video{
    width: 100%;
}
.video iframe{
    width: 100%;
}


/* NUMEROS */
.numeros{
    width: 100%;
    padding: 50px 0;
    background-color: var(--primaria);
    background-image: url(../imagens/home/bg-num.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.numeros .container{
    display: flex;
    gap: 30px;
}
.numeros .titulo{
    width: 100%;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 10px;
}
.numeros .num-div{
    max-width: 1210px;
    width: 100%;
    margin: 0 auto;
    gap: 20px;
    justify-content: center;
}
.numeros .num-div .box{
    max-width: calc(100% - 50% - 10px);
    width: 100%;
    border: 1px solid #ffffff52;
    border-radius: 3px;
    padding: 20px;
    text-align: center;
}
.numeros .num-div .box h2,
.numeros .num-div .box h2 span{
    font-weight: 500;
    font-size: 94px;
}
.numeros .num-div .box h2{
    color: #fff;
}
.numeros .num-div .box h2 span{
    color: var(--cor-1);
}
.numeros .num-div .box p,
.numeros .num-div .box p span{
    font-size: 22px;
    color: #fff;
}
.numeros .num-div .box p{
    font-weight: 400;
}
.numeros .num-div .box p span{
    font-weight: 700;
}


/* DEPOIMENTOS */
.depoimentos{
    width: 100%;
    padding: 200px 0 300px;
    background-image: url(../imagens/home/bg3.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.depoimentos .container{
    gap: 50px;
}
.depoimentos .titulo{
    width: 100%;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 10px;
}
.depoimentos .depoimentos-slider{
    width: 100%;
}
.depoimentos .depoimentos-slider .box{
    display: flex;
    flex-direction: column;
    width: 95%;
    height: 100%;
    margin: 0 auto;
    background-color: #fff;
}
.depoimentos .depoimentos-slider .box p{
    padding: 20px 20px 0 20px;
    background-color: #fff;
    border: 1px solid #00000052;
    border-bottom: none;
    border-radius: 3px;
    font-size: 20px;
}
.depoimentos .depoimentos-slider .box p span{
    font-size: 24px;
    font-weight: 700;
}
.depoimentos .depoimentos-slider .box span.div-2{
    display: flex;
    width: 100%;
    height: 32px;
    border: 1px solid #00000052;
    border-top: none;
}
.depoimentos .depoimentos-slider .box span.div{
    display: flex;
    width: 42px;
    height: 42px;
    background-color: #fff;
    border-bottom: 1px solid #00000052;
    border-right: 1px solid #00000052;
    transform: rotate(45deg);
    margin-left: 30px;
    margin-top: -21px;
}
.depoimentos .depoimentos-slider .box .user{
    margin-top: auto;
    padding-top: 20px;
    display: flex;
    gap: 10px;
}
.depoimentos .depoimentos-slider .box .user img{
    width: 105px;
    height: 105px;
    object-fit: contain;
    border-radius: 50%;
}
.depoimentos .depoimentos-slider .box .user div{
    justify-content: center;
}
.depoimentos .depoimentos-slider .box .user div span:nth-child(1){
    font-size: 21px;
    font-weight: 600;
    text-transform: uppercase;
}
.depoimentos .depoimentos-slider .box .user div span:nth-child(2){
    font-size: 21px;
    font-weight: 600;
    opacity: 50%;
}


.formulario{
    width: 100%;
    min-height: 901px;
    position: relative;
    margin-top: -155px;
}
.formulario .img{
    width: 100%;
    object-fit: cover;
}
.formulario .absolute{
    width: 100%;
    height: 100%;
    align-items: center;
    position: absolute;
    top: 0;
}
.formulario .form{
    max-width: 687px;
    width: 100%;
    padding: 30px;
    background-color: #fff;
    border-radius: 5px;
    margin-left: auto;
    gap: 30px;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
}
.formulario .form .topo{
    width: 100%;
    gap: 10px;
}
.formulario .form .topo p{
    font-weight: 300;
    font-size: 22px;
}
.formulario .form .inputs{
    gap: 10px;
    width: 100%;
}
.formulario .form .inputs input,
.formulario .form .inputs textarea{
    border-radius: 3px;
    border: 1px solid #00000052;
    font-size: 16px;
    color: #00000052;
}
.formulario .form .inputs input{
    max-width: calc(100% - 50% - 5px);
    width: 100%;
    height: 68px;
    position: relative;
}
.formulario .form .inputs input.name1,
.formulario .form .inputs input.name2{
    padding: 0 20px;
}
.formulario .form .inputs input.ass{
    max-width: 100%;
    width: 100%;
    padding: 0 20px;
}
.formulario .form .inputs textarea{
    width: 100%;
    height: 163px;
    padding: 20px;
}
.formulario .form .inputs input::placeholder,
.formulario .form .inputs textarea::placeholder{
    font-size: 16px;
    color: #00000052;
}
.formulario .form .inputs .input-1{
    width: 100%;
    gap: 10px;
}
.formulario .form .inputs .input-1 div{
    width: calc(50% - 5px);
    position: relative;
}
.formulario .form .inputs .input-1 div .bg-call {
    display: flex;
    width: 72px; height: 68px;
    background: url('../imagens/header/css_sprites.png') -123px -10px;
    position: absolute;
    left: 0;
    z-index: 5;
}
.formulario .form .inputs .input-1 div .bg-mail {
    display: flex;
    width: 72px; height: 68px;
    background: url('../imagens/header/css_sprites.png') -10px -123px;
    position: absolute;
    left: 0;
    z-index: 5;
}
.formulario .form .inputs .input-1 div input{
    max-width: 100%;
    padding: 0 20px 0 92px;
}
.formulario .form .bottom{
    width: 100%;
    gap: 10px;
    text-align: center;
}
.formulario .form .bottom button{
    text-align: center;
    width: 100%;
    height: 60px;
    border-radius: 50px;
    background-color: var(--cor-1);
    color: #fff;
    font-size: 25px;
    font-weight: 600;
    transition: ease .3s;
}
.formulario .form .bottom button:hover{
    background-color: var(--primaria);
    transition: ease .3s;
}
.formulario .form .bottom p,
.formulario .form .bottom p strong{
    font-size: 17px;
}



/* MEDIA DESKTOP */
@media screen and (max-width: 1900px){
    .banner-slider .banner-slide .absolute-container .container .texto div h1, 
    .banner-slider .banner-slide .absolute-container .container .texto div h1 span{
        font-size: 4.7vw;
    }

    .video iframe{
        height: 44vw;
    }
}
@media screen and (max-width: 1500px){
    .banner-slider .banner-slide .absolute-container .container .texto div h1, 
    .banner-slider .banner-slide .absolute-container .container .texto div h1 span{
        font-size: 5.4vw;
    }
    .banner-slider .banner-slide .absolute-container .container .texto a{
        height: 50px!important;
        font-size: 16px;
    }
}

@media screen and (max-width: 1440px){
    .numeros .num-div .box h2,
    .numeros .num-div .box h2 span{
        font-size: 7vw;
    }

    .depoimentos .depoimentos-slider .box .user img{
        width: 90px;
        height: 90px;
    }
}

@media screen and (max-width: 1366px){

}

@media screen and (max-width: 1280px){
    .banner-slider .banner-slide .absolute-container .container .texto div h1, 
    .banner-slider .banner-slide .absolute-container .container .texto div h1 span{
        font-size: 5.9vw;
    }
    .banner-slider .banner-slide .absolute-container .container .texto a{
        height: 40px!important;
        font-size: 14px;
    }

    .depoimentos .depoimentos-slider .box .user img{
        width: 80px;
        height: 80px;
    }
}

@media screen and (max-width: 1200px){
    .banner{
        justify-content: center;
    }
    .banner .arrows{
        right: unset;
        bottom: 10px;
        transform: rotate(-90deg);
    }
    .banner .arrows i{
        width: 40px;
        height: 40px;
        font-size: 20px;
    }

    .servicos-div .box-div{
        width: calc(100% - 50% - 10px);
    }

    .diferenciais .diferenciais-div .diferenciais-slider .box{
        flex-direction: column;
    }
    .diferenciais .diferenciais-div .diferenciais-slider .box .img,
    .diferenciais .diferenciais-div .diferenciais-slider .box .texto{
        max-width: 661px;
        margin: 0 auto;
    }

    .sobre{
        flex-direction: column;
    }
    .sobre .img{
        max-width: 100%;
    }
    .sobre .img::before{
        width: 115%;
    }
    .sobre .img img{
        max-width: 640px;
        margin: 0 auto;
    }
    
    .numeros .num-div .box p,
    .numeros .num-div .box p span{
        font-size: 20px;
    }

    .fale-equipe .container{
        flex-direction: column;
        align-items: center;
    }
    .fale-equipe .img img{
        position: relative;
    }
    
}

@media screen and (max-width: 1100px){
    .banner-slider .banner-slide picture, .banner-slider .banner-slide picture img{
        height: 539px;
        object-fit: cover;
        object-position: left;
    }

    .numeros .num-div .box{
        max-width: 100%;
    }
    .numeros .num-div .box h2,
    .numeros .num-div .box h2 span{
        font-size: 8vw;
    }
    
    .numeros .num-div .box p,
    .numeros .num-div .box p span{
        font-size: 18px;
    }

    .depoimentos .depoimentos-slider .box .user img{
        width: 70px;
        height: 70px;
    }
}

/* MOBILE */
@media screen and (max-width: 1000px){
    
}

@media screen and (max-width: 800px){
    .depoimentos .depoimentos-slider .box .user img{
        width: 60px;
        height: 60px;
    }


    .conteudo-1 .container,
    .conteudo-2 .container{
        padding: 100px 0;
    }
    .depoimentos{
        padding: 100px 0 200px;
    }
}

@media screen and (max-width: 600px){
    .numeros .num-div .box h2,
    .numeros .num-div .box h2 span{
        font-size: 12vw;
    }
    .numeros .num-div .box p,
    .numeros .num-div .box p span{
        font-size: 16px;
    }
    
    .servicos-div{
        gap: 40px;
    }
    .servicos-div .box-div{
        max-width: 400px;
        width: 100%;
        height: fit-content;
    }
    .servicos-div .box .texto p{
        max-height: unset!important;
        height: fit-content;
        opacity: 1;
    }
    .servicos-div .box .texto .div, .servicos-div .box .saiba-mais{
        display: none;
    }

    .depoimentos{
        padding: 100px 0;
    }
    .depoimentos .depoimentos-slider .box p span{
        font-size: 16px;
    }

    .formulario{
        margin-top: 0;
    }
    .formulario .img{
        display: none;
    }
    .formulario .absolute{
        position: relative;
    }
    .formulario .form .inputs input{
        max-width: 100%!important;
    }
    .formulario .form .inputs .input-1 div{
        width: 100%!important;
    }
}

@media screen and (max-width: 400px){

}

@media screen and (max-width: 375px){

}