* {
	box-sizing: border-box;
}


.montserrat-<uniquifier> {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

body {
	background: #ffffff;
	height: 100%;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    font-style: normal;
    margin: 0;
	padding: 0;
    overflow-x: hidden;
    font-size: 16px;
}

html {
	height: 100%;
    margin: 0;
	padding: 0;
}

.wrap-content{
    position: relative;
    width: 90%;
    max-width: 1185px;
    margin: 0 auto;
}

.wrap-content2{
    max-width: 925px;
}

h1{
    font-weight: 700;
}

a{
    text-decoration: none;
    color: #74b854
}

:focus {
    outline: -webkit-focus-ring-color auto 0px;
}

.clear{
    clear: both;
}

.header{
    position: absolute;
    width: 100%;
    z-index: 4;
    transition: all .25s ease-in-out;
    background: #106861;
    height: 102px;
}

.header_fake{
    position: relative;
    width: 100%;
    height: 102px;
}

.header.fix{
    position: fixed;
    top: 0;
    height: 70px;
    box-shadow: 0 0 6px #0000009e;
    z-index: 3;
}


.topo-infos{
    position: absolute;
    padding: 20px 0;
    right: 20px;
    text-align: right;
    font-size: 20px;
    top: 20px;
}

.topo-infos.fix{
    top: 4px;
}

.topo-infos a{
    margin-right: 20px;
    color: #fff;
}

.topo-infos a:hover{
   color: #74b854;
}

.logo{
    position: absolute;
    z-index: 2;
    width: 265px;
    height: 60px;
    top: 21px;
    color: #fff;
    background: url(img/sav_logo_bc.svg) no-repeat center center;
    background-size: contain;
    transition: all .25s ease-in-out;
}

.logo:hover{
   background-image: url(img/sav_logo_vd.svg);
}

.logo.fix {
    height: 40px;
    top: 12px;
}

.menu{
    position: relative;
    text-align: center;
    width: 85%;
    margin: 0 auto;
}

.menu ul{
    text-decoration: none;
    margin: 0;
    padding: 0;
    position: relative;
    overflow: auto;
}

.menu ul li{
    position: relative;
    display: inline-block;
    margin: 0;
    padding: 0;
}

.menu ul li:first-child{
    width: 211px;
}

.menu ul li:last-child{
    width: 145px;
}

.menu ul li a{
    display: block;
    color: #fff;
    font-size: 16px;
    margin: 0;
    padding: 44px 25px 39px 25px;
    transition: color 500ms ease;
}

.menu ul li a.fix {
    padding: 24px 20px 20px 20px;
}

.menu ul li a:hover{
    cursor: pointer;
    color: #74b854;
}

.menu ul li a:before {
    position: absolute;
    top: 0px;
    left: 0;
    width: 0%;
    height: 5px;
    background: #74b854;
    content: "";
    transition: all 500ms ease;
}

.menu ul li a:hover::before{
    width: 100%
}

.menu ul li .menu_active::before{
    width: 100%
}

.bt-2:hover{
    background: #19252e;
    border: 1px solid #19252e;
}

.whatsapp{
    position: fixed;
    z-index: 10;
    width: 60px;
    height: 60px;
    right: 50px;
    bottom: 30px;
    background: #74b854;
    color: #fff;
    font-size: 37px;
    text-align: center;
    border-radius: 50%;
    box-shadow: 0 0 6px #00000030;
    padding-top: 7px;
}

.whatsapp:hover{
    background: #74b854;
}


#menu-bt2{
    z-index: 3;
}

#menu-bt2.fix {
    top: 25px;
}

.banner{
    position: relative;
    width: 100%;
    height: 518px;
    background: url(img/banner.webp) no-repeat center center;
    background-size: contain;
}

.banner_txt{
    position: absolute;
    color: #74b854;
    font-size: 60px;
    line-height: 51px;
}

.banner_txt1{
    left: 50%;
    margin-left: -531px;
    margin-top: -82px;
    top: 50%;
    text-align: right;
}

.banner_txt2{
    left: 50%;
    margin-left: 231px;
    margin-top: 17px;
    top: 50%;
}

.home{
    position: relative;
    width: 100%;
}

.home_gradiente{
   background: linear-gradient(0deg, #fcfdf9, transparent);
}

.wrap{
    position: relative;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

.wrap2{
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.home1 h1{
    font-size: 26px;
    color: #106861;
    margin: 80px 0;
}

.home2{
    color: #106861;
    display: flex;
    justify-content: center;
    gap: 50px;
}

.home2 p{
    line-height: 24px;
}

.home2_1 img{
    width: 100%;
    max-width: 440px;
}

.home2_2{
    width: 392px
}

.home2_2 img{
    width: 260px
}

.home2 a{
    font-weight: 600;
}

.home3_1{
    width: 300px;
}

.home3{
    z-index: 2;
    position: relative;
    align-items: center;
    gap: 100px;
}

.home3 h1{
    font-size: 80px;
    margin: -5px;
}

.home3_2 img{
    width: 352px
}

.home_linhas{
    position: absolute;
    z-index: 0;
    background: url(img/linhas2.webp) no-repeat bottom center;
    width: 100%;
    height: 100%;
    background-size: contain;
    left: 50%;
    margin-left: -451px;
}

.func_faixa{
    position: absolute;
    width: 100%;
    height: 315px;
    background: #106861;
    top: -41px;
}

.func1{
    position: relative;
    color: #fff;
    display: flex;
    justify-content: center;
    gap: 50px;
    align-items: center;
    margin-bottom: 90px;
}

.func1_1{
    font-size: 50px;
    font-weight: 700;
    width: 291px;
    border-top: 3px solid #74b854;
    padding-top: 25px;
}

.func1_2{
    line-height: 24px;
    width: 80%;
    max-width: 450px;
}

.func2 {
    display: flex;
    justify-content: center;
    gap: 5px;
    position: relative; /* Garante que os elementos dentro dela respeitem o posicionamento */
}

.func2_wrap {
    position: relative;
}

.func2_1 {
    position: relative;
    background: #fff;
    border: 3px solid #74b854;
    border-radius: 8px;
    padding: 10px;
    width: 200px;
    height: 100%;
    text-align: center;
    font-size: 15px;
    transition: all .2s ease-in-out;
}

.func2_1:hover {
    transform: translate(0, -30px);
    cursor: pointer;
}

.func2_1_1{
    position: relative;
    background: #74b854;
    color: #fff;
    font-weight: 600;
    padding: 10px;
    border-radius: 4px;
    margin: -31px auto auto auto;
}

.func2_1_shadow {
    position: absolute;
    bottom: -19px;
    left: 50%;
    width: 156px;
    height: 14px;
    background: rgba(0, 0, 0, 0.2);
    border-radius: 50%;
    transform: translateX(-50%);
    filter: blur(5px);
    transition: opacity 0.2s ease-in-out;
}

.home_prod{
    text-align: center;
    padding: 100px 0;
}

.home_prod span{
    color: #106861;
    font-size: 18px;
    font-weight: 600;
}
.home_prod button{
    color: #fff;
    font-size: 28px;
    font-weight: 600;
    background: #74b854;
    padding: 10px 30px;
    border-radius: 35px;
    border: 0;
    margin-top: 20px;
    z-index: 2;
    position: relative;
    cursor: pointer;
}

.home_prod button:hover{
    background: #106861;
}

.home_prod h1{
    color: #106861;
    font-size: 48px;
    margin: 20px 0;
}

.home_prod h2{
    color: #74b854;
    font-size: 28px;
    margin: 0;
    font-weight: 400;
}

.home4_wrap{
    padding: 40px 0;
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
}

.sav_prod_linha {
    height: 330px;
    width: 4px;
    background: #72ba52;
    transform: translate(0, 162px);
    margin: 0 100px;
}
.sav_prod{
    text-align: center
}
.sav_prod h1 {
    font-size: 33px;
    color: #106861;
    margin: 0
}
.sav_prod p {
    margin: 0 0 50px 0;
}

.home_dife{
    background: url(img/banner-verde.webp) no-repeat center center;
    background-size: cover;
    height: 500px;
}

.lihnas2{
    position: absolute;
    width: 100%;
}

.lihnas2 img{
    width: 100%;
    transform: rotate(5deg);
}

.dife2{
    position: relative;
    background: #fcfdf9;
    width: 85%;
    max-width: 1200px;
    padding: 100px;
    margin: -171px auto 0 auto;
    border-bottom: 10px solid #707964;
    border-radius: 0 127px 0 0;
    color: #106861;
}

.dife2 hr{
    border: 1px solid #707964;
    width: 426px;
    max-width: 100%;
    margin: 0;
}

.dife2_title{
    position: absolute;
    font-size: 35px;
    font-weight: 700;
    color: #106861;
    top: -23px;
    background: #fff;
    padding: 15px 25px;
    border: 6px solid #d3d8c9;
    border-radius: 0 45px 45px 45px;
}
.dife2_in{
    line-height: 28px;
    padding: 20px 0;
}

.dife2_in h1{
    color: #74b854
}

.home_5{
    background: #74b854;
    padding: 80px 0;
    margin-top: 80px;
    overflow: hidden;
}

.home_5_1{
    color: #fff;
    align-items: center;
}

.home_5_1 h1{
    font-size: 35px
}

.linhas4{
    position: absolute;
    background: url(img/linhas.webp) no-repeat;
    background-size: cover;
    width: 2000px;
    height: 900px;
    right: -604px;
    top: -60px;
    transform: rotate(-74deg);
}

footer{
    position: relative;
    width: 100%;
    background-color: #064338;
    background-image: url(img/mapa.webp);
    background-size: 80% auto;
    background-repeat: no-repeat;
    background-position: center;
}

.footer-01{
    position: relative;
    width: 100%;
    background: #000;
}

.footer-01 ul{
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-01 ul li {
    width: 33%;
    display: inline-block;
    border-right: 1px solid #74b854;
    padding: 30px;
    color: #fff;
    font-size: 16px;
    font-weight: 300;
}

.footer-01 ul li:last-child {
    border: 0
}

.footer-01 ul li i{
    color: #74b854;
    margin-right: 10px;
    font-size: 21px;
}

.footer-01 ul li span{
    color: #fff;
}


.footer-02{
    position: relative;
    width: 100%;
    padding-top: 40px;
}

.footer-02in{
    float: left;
    width: 33%;
    padding-right: 20px;
}

.logo_rodape{
    position: relative;
    width: 185px;
    height: 53px;
    background: url(img/sav_logo_vd2.svg) no-repeat center center;
    background-size: contain;
    margin-bottom: 30px;
}

.footer-02in h1{
    color: #74b854;
    font-size: 18px;
    margin: 0 0 30px 0;
    font-weight: 500;
    text-align: left;
}

.footer-02in p{
    color: #fff;
    line-height: 22px;
    margin: 0 0 30px 0;
    font-weight: 300;
    text-align: left;
    font-size: 15px;
    padding-right: 45px;
}

.footer-02in a{
    color: #fff;
}

.footer-02in a i{
    color: #fff;
    font-size: 37px;
    margin: 0 10px 0 0;
}

.footer-02in a i:hover{
    color: #74b854;
}

.footer-02in a .fa-map-marker-alt{
    color: #74b854;
    margin-right: 4px;
    font-size: 18px;
}


.footer-02in a:hover{
    color: #fff;
}

.footer-02in iframe{
    width: 100%;
    height: 260px;
    margin-bottom: 15px;
}

.footer-barra{
    position: relative;
    width: 100%;
    padding: 30px 10px;
    background: #000;
    color: #555454;
    font-size: 14px;
    margin-top: 30px;
    text-align: center;
}

.footer-barra img{
    margin: 0 15px;
    transition: all .25s ease-in-out;
}

.footer-barra img:hover{
    transform: scale(1.1);
}

.footer-barra .enm{
    margin-bottom: 30px;
}

.wrap-content-footer{
    border-top: 1px solid #3a3a3a;
    margin-top: 30px;
    padding-top: 30px;
}

.footer-barra01{
    float: left;
}

.footer-barra02{
    float: right;
}

.footer-barra02 a{
    color: #555454;
}

.footer-barra02 a:hover{
    color: #fff;
}

.banner_quem{
    position: relative;
    width: 100%;
    overflow: hidden;
    text-align: center;
    background: url(img/banner2.webp) repeat center;
}
.banner_quem picture{
    position: relative;
    left: 50%;
    margin-left: -100%;
}

.home1 p{
    color: #106861;
    line-height: 30px;
    text-align: justify;
    margin-bottom: 80px;
}

.quem_3{
    background: #106861;
    padding: 80px 0;
    margin-top: 80px;
}

.quem_3 p{
    color: #fff;
    margin: 0 auto;
    max-width: 800px;
}

.linhas5{
    position: absolute;
    background: url(img/linhas5.webp) no-repeat;
    background-size: cover;
    width: 878px;
    height: 899px;
    left: 50%;
    bottom: -82px;
    transform: rotate(0deg);
    margin-left: -1220px;
    z-index: -1;
}

.quem_4{
    padding: 80px 0;
}

.quem_4_1{
    font-weight: 700;
    position: relative;
    margin: 0 auto;
    text-align: center;
    color: #106861;
    font-size: 18px;
    letter-spacing: 2px;
}

.quem_4_2{
    display: flex;
    gap: 50px;
    justify-content: center;
    margin-top: 50px;
}

.quem_4_2_1{
    width: 260px;
    color: #106861;
}

.quem_4_2_1 h1{
    font-size: 22px;
    color: #74b854;
}

.quem_4_2_1 p{
    line-height: 24px
}

.quem_4_3{
    padding: 80px 100px;
    margin: 50px auto 0 auto;
    border-radius: 50px 50px 0 0;
}

.quem_4_3 p{
    text-align: justify;
}

.premios{
    text-align: center;
    padding: 80px 0;
}

.premios img{
    max-width: 90%;
}

.linhas6{
    position: absolute;
    background: url(img/linhas3.webp) no-repeat center bottom;
    background-size: 120% auto;
    width: 100%;
    height: 804px;
    z-index: -1;
    top: 50%;
    margin-top: -613px;
}

.premios_2{
    align-items: flex-end;
    margin-bottom: 50px;
}

.premios_2_1 h1{
    color: #fff;
    font-size: 18px;
    padding: 0px 5px;
    text-align: center;
}

.premios_2_1 img{
    width: 100%;
}

.premios_1{
    position: absolute;
    width: 100%;
    height: 250px;
    background: #74b854;
    top: -28px;
}

.premios_title{
    text-align: center;
    color: #106861;
    font-size: 30px;
}

.cert_1{
    gap: 20px;
    margin-bottom: 80px;
}

.cert_1 div{
    position: relative;
    width: 100px;
}

.cert_1 div::after {
    content: "";
    display: block;
    position: relative;
    bottom: -7px;
    left: 50%;
    width: 105px;
    height: 14px;
    background: rgba(0, 0, 0, 0.2);
    border-radius: 50%;
    transform: translateX(-50%);
    filter: blur(4px);
}

.otimi{
    background: #fcfdf9;
    padding: 60px 0 120px 0;
}

.otimi_1 img{
    position: relative;
    width: 100%;
    z-index: 2
}

.otimi_1{
    position: relative;
}

.otimi_1::before{
    content: "";
    display: block;
    position: absolute;
    top: -9px;
    right: 0;
    width: 59%;
    height: 9px;
    background: #74b854;
}

.otimi_1::after{
    content: "";
    display: block;
    position: absolute;
    bottom: -25px;
    left: -25px;
    width: 59%;
    height: 216px;
    background: #106861;
    border-radius: 20px 0 0 0;
    z-index: 0;
}

.linhas7{
    position: absolute;
    background: url(img/linhas6.webp) no-repeat center bottom;
    background-size: 130% auto;
    width: 100%;
    height: 100%;
    bottom: -30px;
}

.banner_port{
    background: url(img/banner-verde-vivo.webp) no-repeat center bottom;
    background-size: cover;
}

.port_1{
    align-items: flex-start;
    margin-top: 36px;
}

.port3_2 img{
    margin-top: -294px;
    width: 434px;
}

.port_2{
    background: #fcfdf9;
    padding: 60px 0;
    text-align: center;
}

.port_2 img{
    width: 300px
}

.port_2 h1{
    color: #106861;
    font-size: 38px;
    margin: 50px 0;
}
.port_2_1{
    position: relative;
    display: flex;
    gap: 50px;
    justify-content: center;
    text-align: left;
    z-index: 2;
    padding-top: 80px;
}

.port_2_1_1 h1{
    font-size: 22px;
    color: #74b854;
    margin: 0
}

.port_2_1_1 img{
    width: 900px;
    border-radius: 80px 0 80px 0;
    margin-left: -80px;
}

.port_2_1_1 p{
    color: #fff;
    margin-bottom: 30px
}

.port_2_1_2{
    width: 250px
}

.port_2_1_2 p{
    color: #106861;
    line-height: 26px;
    margin-bottom: 30px
}

.port_2_3{
    position: absolute;
    width: 100%;
    height: 676px;
    background: #106861;
    border-radius: 0 50px 50px 0;
    top: 290px;
    left: -40%;
}

.linhas8{
    position: absolute;
    width: 600px !important;
    left: 0;
    bottom: -265px;
}

.img_orgonograma{
    max-width: 100%;
}

.vantagem{
    position: relative;
    width: 100%;
    background: #d3d8c9;
    text-align: center;
    padding: 100px 0;
}

.vantagem h1{
    color: #fff;
    background: #74b854;
    padding: 15px 80px;
    position: absolute;
    left: 50%;
    transform: translate(-50%, 0);
    top: -35px;
    border-radius: 0 0 25px 25px;
}

.vantagem-carrosel{
    position: relative;
    width: 900px;
    max-width: 90%;
    margin: 0 auto;
    z-index: 2;
}

.carousel-cell, .carousel-cell img{
    width: 100%;
}

.linhas9{
    position: absolute;
    background: url(img/linhas3.webp) no-repeat center center;
    background-size: 160% 60%;
    width: 100%;
    height: 100%;
    top: 0;
}

.para_quem{
    margin: 80px 0;
}

.para_faixa{
    position: absolute;
    width: 100%;
    height: 35px;
    background: #74b854;
    top: -75px;
}

.para1{
    margin-bottom: 50px;
}

.para1_1{
    border: 0;
}

.para2_1{
    border: 0;
    background: #106861;
    color: #fff;
    font-weight: 600;
    border-radius: 30px;
    padding: 26px 10px 10px 10px;
}

.para2_1_1{
    background: #fff;
    border: 3px solid #74b854;
    border-radius: 20px;
    width: 150px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

.para2_1_1 img{
    max-width: 69px;
    max-height: 69px;
}

.para_faixa_gradient{
    background: linear-gradient(0deg, #093935, #106861);
    height: 357px;
}

.port_prod button{
    font-size: 18px;
    margin-top: 30px;
}

.btn_wpp{
    border-radius: 8px;
    padding: 5px 10px;
    background: #74b854;
    border: 0;
    color: #fff;
    display: flex;
    align-items: center;
    cursor: pointer;
    margin-top: 10px;
}

.menu ul li .menu_active::before {
    width: 50%;
    left: 50%;
    transform: translate(-50%, 5px);
}
/* -----------------------------------480------------------------------*/

@media screen and (max-width: 480px) {
    
     .topo-infos {
         display: none;
        top: auto;
        bottom: 30px;
        right: auto;
        left: 50%;
        transform: translate(-42%, 0);
    }
    
    .topo-infos.fix {
    top: auto;
}
    
    .menu {
    left: 0;
    margin-left: 0;
    width: 100%;
        text-align: center;
        top: 0;
        background: #106861;
}
    
    .menu ul{
        display: none;
        height: 606px;
    }
    
    .menu ul li {
    display: block;
    width: 80%;
    margin: 0 auto;
}
    
    .menu ul li a {
    padding: 18px 0;
}
    .menu ul li a.fix {
   padding: 18px 0;
}
    
        .logo {
        width: 230px;
    height: 53px;
    top: 16px;
}
    
    .logo.fix {
    height: 40px;
    top: 12px;
    width: 185px;
}
    .menu ul li:first-child {
    width: 100%;
    height: 126px;
}
    
    .menu ul li a:before {
        top: auto;
    bottom: 14px;
    }
    
    .banner {
    height: 395px;
    background: url(img/banner.webp) no-repeat center center;
    background-size: auto 345px;
}
    .banner_txt {
    display: none;
}
    
    .home1 h1 {
    font-size: 22px;
    margin: 60px 0;
}
    
    .home2 {
    flex-wrap: wrap;
        margin-bottom: 60px;
}
    
    .home2 p {
    text-align: justify;
}
    
    .home3_1 {
    width: auto;
}
    .home3 {
    gap: 10px;
}
    .home_linhas {
    background: url(img/linhas2.webp) no-repeat -399px 64%;
    background-size: 240% auto;
    left: 0;
    margin-left: 0px;
}
    .func1 {
    gap: 30px;
    flex-direction: column;
}
    .func_faixa {
    height: 354px;
}
    
    .func2 {
    flex-wrap: wrap;
}
    
    .func2_wrap {
    width: 45%;
    margin-bottom: 61px;
}
    .func2_1 {
        width: 100%;
    }
    .home_prod {
    padding: 60px 10px;
}
    
    .home4_wrap {
    align-content: center;
    flex-wrap: wrap;
}
    .sav_prod, .sav_prod img {
    max-width: 80%;
    }
    .sav_prod_linha {
    height: 3px;
    width: 80%;
    transform: translate(0, 0);
    margin: 20px auto;
}
    .sav_prod h1, .sav_prod p{
    text-align: left;
}
    .home_prod button {
    font-size: 18px;
    }
    .home_prod span {
    font-size: 18px;
    margin: 0 50px;
    display: block;
}
    .lihnas2 {
        overflow: hidden;
}
    
    .lihnas2 img {
    width: 213%;
        position: relative;
        transform: translate(-118px, 0);
}
    .home_dife {
    background: url(img/banner-verde.webp) no-repeat left center;
    height: 315px;
}
    .dife2 {
    padding: 20px;
}
    .dife2_title {
    font-size: 28px;
    top: -35px;
}
    .home_5_1 h1 {
    font-size: 24px;
}
      footer {
    background-size: contain;
    background-position: center;
}
    
    .footer-01 {
    width: 110%;
    margin-left: -5%;
}
    
    .footer-01 ul li {
    width: 100%;
    border-bottom: 1px solid #74b854;
    font-size: 15px;
    border-right: 0;
    text-align: left;
}
    
    .footer-02in {
    width: 100%;
    padding-right: 0px;
    margin-bottom: 20px;
}
    
    .footer-02in p {
    line-height: 22px;
    font-size: 13px;
    padding-right: 0;
}
    
    .footer-barra img {
    margin: 15px 10px;
    width: 80px;
}
    
    .footer-barra01 {
    float: none;
}
    
    .footer-barra02 {
    float: none;
    font-size: 13px;
    margin-top: 20px;
}
      .footer-barra .enm{
    margin-bottom: 20px;
        width: 120px;
}
    .banner_quem{
        background: #fff;
    }
    .banner_quem img{
        width: 100%;
    }
    .quem_4_2 {
    gap: 30px;
    flex-direction: column;
}
    .quem_4_2_1 {
    width: 100%;
}
    .quem_4_3 {
    width: 100%;
}
    .premios {
    padding: 0;
}
    .linhas6 {
    background-size: 194% auto;
    margin-top: -671px;
}
    .premios img {
    max-width: 70%;
}
    .premios_2 {
    align-content: center;
        flex-wrap: wrap;
}
        .premios_2_1 {
        width: 260px;
    }
    .premios_2_1 h1 {
    color: #106861;
}
    .cert_1 {
    gap: 20px;
    flex-wrap: wrap;
        flex-direction: row;
}
    .linhas7 {
    background-size: 216% auto;
    bottom: 0px;
}
    .otimi_1::after {
    height: 299px;
}
    .banner_port {
    background: url(img/banner-verde-vivo.webp) no-repeat -87px bottom;
    background-size: cover;
}
    .port_1 {
    flex-wrap: nowrap;
    flex-direction: column-reverse;
}
        .port3_2{
    text-align: right
}
    .port3_2 img {
    width: 321px;
}
    .port_2 h1 {
    font-size: 28px;
    margin: 30px 0;
}
    .port_2_1 {
    gap: 20px;
    flex-wrap: wrap;
        width: 90%;
        margin: 0 auto;
        padding-top: 40px;
}
    .port_2_1_1 h1 {
    font-size: 18px;
}
    .port_2_1_1 img {
    width: 100%;
    border-radius: 60px 0 80px 0;
    margin-left: 0;
}
    .port_2_3 {
    width: 95%;
    height: 304px;
    top: 263px;
    left: 0;
}
    .linhas8 {
    width: 264px !important;
    bottom: -130px;
}
    .para_faixa_gradient {
    height: 457px;
}
    .para_frame{
        margin-bottom: 40px;
    }
    .home_prod h1 {
    font-size: 35px;
    margin: 10px 0;
}
    
    .banner_quem picture{
    position: relative;
    left: auto;
    margin-left: auto;
}
    
}

/* -----------------------------------481-767---------------------------*/

@media screen and (min-width: 481px) and (max-width: 767px) {
    .home_prod h1 {
    font-size: 35px;
    margin: 10px 0;
}
    
        .topo-infos {
         display: none;
        top: auto;
        bottom: 30px;
        right: auto;
        left: 50%;
        transform: translate(-42%, 0);
    }
    
    .topo-infos.fix {
    top: auto;
}
    
    .menu {
    left: 0;
    margin-left: 0;
    width: 100%;
        text-align: center;
        top: 0;
        background: #106861;
}
    
    .menu ul{
        display: none;
        height: 606px;
    }
    
    .menu ul li {
    display: block;
    width: 80%;
    margin: 0 auto;
}
    
    .menu ul li a {
    padding: 25px 0;
}
    
        .logo {
        width: 230px;
    height: 53px;
    top: 16px;
}
    
    .logo.fix {
    height: 40px;
    top: 12px;
    width: 185px;
}
    .menu ul li:first-child {
    width: 100%;
    height: 126px;
}
    
    .menu ul li a:before {
        top: auto;
    bottom: 14px;
    }
    
    .banner {
    height: 395px;
    background: url(img/banner.webp) no-repeat center center;
    background-size: auto 345px;
}
    .banner_txt {
    display: none;
}
    
    .home1 h1 {
    font-size: 22px;
    margin: 60px 0;
}
    
    .home2 {
    flex-wrap: wrap;
        margin-bottom: 60px;
}
    
    .home2 p {
    text-align: justify;
}
    
    .home3_1 {
    width: auto;
}
    .home3 {
    gap: 10px;
}
    .home_linhas {
    background: url(img/linhas2.webp) no-repeat -399px 64%;
    background-size: 240% auto;
    left: 0;
    margin-left: 0px;
}
    .func1 {
    gap: 30px;
    flex-direction: column;
}
    .func_faixa {
    height: 354px;
}
    
    .func2 {
    flex-wrap: wrap;
        gap: 15px;
}
    
    .func2_wrap {
    width: 260px;
    margin-bottom: 61px;
}
    .func2_1 {
        width: 100%;
    }
    .home_prod {
    padding: 60px 10px;
}
    
    .home4_wrap {
    flex-direction: column;
    align-content: center;
    flex-wrap: wrap;
}

    .sav_prod_linha {
    height: 3px;
    width: 80%;
    transform: translate(0, 0);
    margin: 20px auto;
}
    .sav_prod h1, .sav_prod p{
    text-align: left;
}
    .home_prod button {
    font-size: 18px;
    }
    .home_prod span {
    font-size: 18px;
    margin: 0 50px;
    display: block;
}
    .lihnas2 {
        overflow: hidden;
}
    
    .lihnas2 img {
    width: 213%;
        position: relative;
        transform: translate(-118px, 0);
}
    .home_dife {
    background: url(img/banner-verde.webp) no-repeat left center;
    height: 315px;
}
    .dife2 {
    padding: 20px;
}
    .dife2_title {
    font-size: 28px;
    top: -35px;
}
    .home_5_1 h1 {
    font-size: 24px;
}
      footer {
    background-size: contain;
    background-position: center;
}
    
    .footer-01 {
    width: 110%;
    margin-left: -5%;
}
    
    .footer-01 ul li {
    width: 100%;
    border-bottom: 1px solid #74b854;
    font-size: 15px;
    border-right: 0;
    text-align: left;
}
    
    .footer-02in {
    width: 100%;
    padding-right: 0px;
    margin-bottom: 20px;
}
    
    .footer-02in p {
    line-height: 22px;
    font-size: 13px;
    padding-right: 0;
}
    
    .footer-barra img {
    margin: 15px 10px;
    width: 80px;
}
    
    .footer-barra01 {
    float: none;
}
    
    .footer-barra02 {
    float: none;
    font-size: 13px;
    margin-top: 20px;
}
      .footer-barra .enm{
    margin-bottom: 20px;
        width: 120px;
}
    .banner_quem{
        background: #fff;
    }
    .banner_quem img{
        width: 100%;
    }
    .quem_4_2 {
    gap: 30px;
        flex-wrap: wrap;
}
    .quem_4_2_1 {
    width: 100%;
}
    .quem_4_3 {
    width: 100%;
}
    .premios {
    padding: 0;
}
    .linhas6 {
    background-size: 194% auto;
    margin-top: -671px;
}
    .premios img {
    max-width: 70%;
}
    .premios_2 {
    align-content: center;
        flex-wrap: wrap;
}
        .premios_2_1 {
        width: 260px;
    }
    .premios_2_1 h1 {
    color: #106861;
}
    .cert_1 {
    gap: 20px;
    flex-wrap: wrap;
        flex-direction: row;
}
    .linhas7 {
    background-size: 216% auto;
    bottom: 0px;
}
    .otimi_1::after {
    height: 299px;
}
    .banner_port {
    background: url(img/banner-verde-vivo.webp) no-repeat -87px bottom;
    background-size: cover;
}
    .port_1 {
    flex-wrap: nowrap;
    flex-direction: column-reverse;
}
        .port3_2{
    text-align: right
}
    .port3_2 img {
    width: 321px;
}
    .port_2 h1 {
    font-size: 28px;
    margin: 30px 0;
}
    .port_2_1 {
    gap: 20px;
    flex-wrap: wrap;
        width: 90%;
        margin: 0 auto;
        padding-top: 40px;
}
    .port_2_1_1 h1 {
    font-size: 18px;
}
    .port_2_1_1 img {
    width: 100%;
    border-radius: 60px 0 80px 0;
    margin-left: 0;
}
    .port_2_3 {
    width: 95%;
    height: 304px;
    top: 263px;
    left: 0;
}
    .linhas8 {
    width: 264px !important;
    bottom: -130px;
}
    .para_faixa_gradient {
    height: 457px;
}
    .para_frame{
        margin-bottom: 40px;
    }
        .banner_quem picture{
    position: relative;
    left: auto;
    margin-left: auto;
}
    
}

/* --------------------------------768-1023------------------------------*/

@media screen and (min-width: 768px) and (max-width: 1023px) {
    
    .topo-infos {
         display: none;
        top: auto;
        bottom: 30px;
        right: auto;
        left: 50%;
        transform: translate(-42%, 0);
    }
    
    .topo-infos.fix {
    top: auto;
}
    
    .menu {
    left: 0;
    margin-left: 0;
    width: 100%;
        text-align: center;
        top: 0;
        background: #106861;
}
    
    .menu ul{
        display: none;
        height: 606px;
    }
    
    .menu ul li {
    display: block;
    width: 80%;
    margin: 0 auto;
}
    
    .menu ul li a {
    padding: 25px 0;
}
    
        .logo {
        width: 230px;
    height: 53px;
    top: 16px;
}
    
    .logo.fix {
    height: 40px;
    top: 12px;
    width: 185px;
}
    .menu ul li:first-child {
    width: 100%;
    height: 126px;
}
    
    .menu ul li a:before {
        top: auto;
    bottom: 14px;
    }
    
    .banner {
    height: 395px;
    background: url(img/banner.webp) no-repeat center center;
    background-size: auto 345px;
}
    .banner_txt {
    font-size: 38px;
    line-height: 40px;
}
    
    .banner_txt1 {
    margin-left: -344px;
    }
    
    .banner_txt2 {
    margin-left: 154px;
    }
    
    .home_gradiente {
    margin-top: 40px;
}
   
    
    .home1 h1 {
    font-size: 22px;
    margin: 60px 0;
}
    
    .home2 p {
    text-align: justify;
}
    
    .home3_1 {
    width: auto;
}
    .home3 {
    gap: 10px;
}
    .home_linhas {
    background: url(img/linhas2.webp) no-repeat 119px 58%;
        background-size: 240% auto;
        left: 0;
        margin-left: 0px;
}
    .func1 {
    padding: 0 60px;
}
    .func_faixa {
    height: 354px;
}
    
    .func2 {
    flex-wrap: wrap;
        gap: 15px;
}
    
    .func2_wrap {
    width: 260px;
    margin-bottom: 61px;
}
    .func2_1 {
        width: 100%;
    }
    .home_prod {
    padding: 60px 10px;
}

    .sav_prod_linha {
    margin: 20px 30px;
}
    .sav_prod h1, .sav_prod p{
    text-align: left;
}
    .home_prod button {
    font-size: 18px;
    }
    .home_prod span {
    font-size: 18px;
    margin: 0 50px;
    display: block;
}
    .lihnas2 {
        overflow: hidden;
}
    
    .lihnas2 img {
    width: 213%;
        position: relative;
        transform: translate(-118px, -126px);
}
    .home_dife {
    height: 315px;
}
    .dife2 {
    padding: 20px;
}
    .dife2_title {
    font-size: 28px;
    top: -35px;
}
    .home_5_1 h1 {
    font-size: 24px;
}
      footer {
    background-size: contain;
    background-position: center;
}
    
    .footer-01 {
    width: 110%;
    margin-left: -5%;
}
    
    .footer-01 ul li {
    width: 100%;
    border-bottom: 1px solid #74b854;
    font-size: 15px;
    border-right: 0;
    text-align: left;
}
    
    .footer-02in {
    width: 100%;
    padding-right: 0px;
    margin-bottom: 20px;
}
    
    .footer-02in p {
    line-height: 22px;
    font-size: 13px;
    padding-right: 0;
}
    
    .footer-barra img {
    margin: 15px 10px;
    width: 80px;
}
    
    .footer-barra01 {
    float: none;
}
    
    .footer-barra02 {
    float: none;
    font-size: 13px;
    margin-top: 20px;
}
      .footer-barra .enm{
    margin-bottom: 20px;
        width: 120px;
}
    .banner_quem{
        background: #fff;
    }
    .banner_quem img{
        width: 100%;
    }
    .quem_4_2 {
    gap: 30px;
        flex-wrap: wrap;
}
    .quem_4_2_1 {
    width: 100%;
}
    .quem_4_3 {
    width: 100%;
}
    .premios {
    padding: 0;
}
    .linhas6 {
    background-size: 194% auto;
    margin-top: -671px;
}
    .premios img {
    max-width: 70%;
}
    .premios_2 {
    align-content: center;
        flex-wrap: wrap;
}
        .premios_2_1 {
        width: 260px;
    }
    .premios_2_1 h1 {
    color: #106861;
}
    .cert_1 {
    gap: 20px;
    flex-wrap: wrap;
        flex-direction: row;
}
    .linhas7 {
    background-size: 216% auto;
    bottom: 0px;
}

    .banner_port {
    background: url(img/banner-verde-vivo.webp) no-repeat center bottom;
    background-size: cover;
}
        .port3_2{
    text-align: right
}
    .port3_2 img {
    width: 321px;
}
    .port_2 h1 {
    font-size: 28px;
    margin: 30px 0;
}
    .port_2_1 {
    gap: 20px;
    flex-wrap: wrap;
        width: 90%;
        margin: 0 auto;
        padding-top: 40px;
}
    .port_2_1_1 h1 {
    font-size: 18px;
}
    .port_2_1_1 img {
    width: 100%;
    border-radius: 60px 0 80px 0;
    margin-left: 0;
}
    .port_2_3 {
    width: 95%;
    height: 304px;
    top: 263px;
    left: 0;
}
    .linhas8 {
    width: 264px !important;
    bottom: -130px;
}

    .para_frame{
        margin-bottom: 40px;
    }
        .banner_quem picture{
    position: relative;
    left: auto;
    margin-left: auto;
}
}

/* --------------------------------------------------------------*/

@media screen and (min-width: 1024px) and (max-width: 1170px) {
    
    .topo-infos {
         display: none;
        top: auto;
        bottom: 30px;
        right: auto;
        left: 50%;
        transform: translate(-42%, 0);
    }
    
    .topo-infos.fix {
    top: auto;
}
    
    .menu {
    left: 0;
    margin-left: 0;
    width: 100%;
        text-align: center;
        top: 0;
        background: #106861;
}
    
    .menu ul{
        display: none;
        height: 606px;
    }
    
    .menu ul li {
    display: block;
    width: 80%;
    margin: 0 auto;
}
    
    .menu ul li a {
    padding: 25px 0;
}
    
        .logo {
        width: 230px;
    height: 53px;
    top: 16px;
}
    
    .logo.fix {
    height: 40px;
    top: 12px;
    width: 185px;
}
    .menu ul li:first-child {
    width: 100%;
    height: 126px;
}
    
    .menu ul li a:before {
        top: auto;
    bottom: 14px;
    }
    
    .banner {
    height: 395px;
    background: url(img/banner.webp) no-repeat center center;
    background-size: auto 345px;
}
    .banner_txt {
    font-size: 38px;
    line-height: 40px;
}
    
    .banner_txt1 {
    margin-left: -344px;
    }
    
    .banner_txt2 {
    margin-left: 154px;
    }
    
    .home_gradiente {
    margin-top: 40px;
}
   
    
    .home1 h1 {
    font-size: 22px;
    margin: 60px 0;
}
    
    .home2 p {
    text-align: justify;
}
    
    .home3_1 {
    width: auto;
}
    .home3 {
    gap: 10px;
}
    .home_linhas {
    background: url(img/linhas2.webp) no-repeat 119px 58%;
        background-size: 240% auto;
        left: 0;
        margin-left: 0px;
}
    .func1 {
    padding: 0 60px;
}
    .func_faixa {
    height: 354px;
}
    
    .func2 {
    padding: 0 10px;
}
    
    .func2_wrap {
    width: 260px;
    margin-bottom: 61px;
}
    .func2_1 {
        width: 100%;
    }
    .home_prod {
    padding: 60px 10px;
}

    .sav_prod_linha {
    margin: 20px 30px;
}
    .sav_prod h1, .sav_prod p{
    text-align: left;
}
    .home_prod button {
    font-size: 18px;
    }
    .home_prod span {
    font-size: 18px;
    margin: 0 50px;
    display: block;
}
    .lihnas2 {
        overflow: hidden;
}
    
    .lihnas2 img {
    width: 213%;
        position: relative;
        transform: translate(-118px, -147px);
}
    .home_dife {
    height: 315px;
}
    .dife2 {
    padding: 20px;
}
    .dife2_title {
    font-size: 28px;
    top: -35px;
}
    .home_5_1 h1 {
    font-size: 24px;
}
     
    .banner_quem{
        background: #fff;
    }
    .banner_quem img{
        width: 100%;
    }
    .quem_4_2 {
    gap: 30px;
        flex-wrap: wrap;
}
    .quem_4_2_1 {
    width: 100%;
}
    .quem_4_3 {
    width: 100%;
}
    .premios {
    padding: 0;
}
    .linhas6 {
    background-size: 194% auto;
    margin-top: -671px;
}
    .premios img {
    max-width: 70%;
}
    .premios_2 {
    align-content: center;
        flex-wrap: wrap;
}
        .premios_2_1 {
        width: 260px;
    }
    .premios_2_1 h1 {
    color: #106861;
}
    .cert_1 {
    gap: 20px;
    flex-wrap: wrap;
        flex-direction: row;
}
    .linhas7 {
    background-size: 216% auto;
    bottom: 0px;
}

    .banner_port {
    background: url(img/banner-verde-vivo.webp) no-repeat center bottom;
    background-size: cover;
}

    .para_frame{
        margin-bottom: 40px;
    }
}

/* --------------------------------------------------------------*/

@media screen and (min-width: 1171px) and (max-width: 1400px) {
    
    .menu {
    width: 100%;
    }
        
        .menu ul li a {
    padding: 44px 15px 39px 15px;
}
    .menu ul li:first-child {
    width: 112px;
}
    .logo {
    width: 190px;
    }

}

/* --------------------------------------------------------------*/

@media screen and (min-width: 1401px) and (max-width: 1665px) {
    
    .menu {
    width: 90%;
    }
        
        .menu ul li a {
    padding: 44px 15px 39px 15px;
}
    .menu ul li:first-child {
    width: 112px;
}
    .logo {
    width: 190px;
    }

}

/* --------------------------------------------------------------*/

@media screen and (min-width: 1171px) {
    
    #menu-bt2 {
    display: none
}
    
}