*{
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: 'Barlow', sans-serif;
}

/* menu */

.nav-container{
    width: 100%;
    background-color: #1b1b39;
}

.navbar{
    display: grid;
    grid-template-columns: 0.2fr auto 1fr;
    align-items: center;
    height: 80px;
    width: 90%;
    max-width: 1720px;
    margin: 0 auto;
    font-size: 22px;
}

#navbar-logo{
    justify-self: start;
    margin-left: 20px;
    width: 75px;
}

#navbar-logo{
    cursor: pointer;
}

.nav-menu{
    display: grid;
    grid-template-columns: repeat(7, auto);
    list-style: none;
    text-align: center;
    width: 90%;
    justify-self: end;
}

.nav-links{
    color: white;
    text-decoration: none;
}

.nav-links:hover{
    color: #2aa264;
    transition: all 0.2s ease-out;
}

.menu-toggle .bar{
    width: 25px;
    height: 3px;
    margin: 5px auto;
    transition: all 0.3s ease-in-out;
    background: white;
}



@media screen and (max-width: 768px){
    .nav-container{
        position: relative;
    }
    
    .nav-menu{
        display: grid;
        grid-template-columns: auto;
        background: #1b1b39;
        margin: 0;
        width: 100%;
        position: absolute;
        top: 80px;
        left: -100%;
        opacity: 0;
        transition: all 0.5s ease;
    }
    
    #navbar-logo{
        margin-left: 20px;
    }
    
    .nav-menu.active{
        background: #1b1b39;
        left: 0;
        opacity: 1;
        transition: all 0.5s ease;
    }
    
    .nav-links{
        text-align: center;
        line-height: 60px;
        width: 100%;
        display: table;
    }
    
    .nav-links:hover{
        background-color: #2aa264;
        color: white;
        transition: all 0.4s ease-out;
    }
    
    .navbar {
        width: 100%;
    }
    
    #mobile-menu{
        position: absolute;
        top: 20%;
        right: 5%;
        transform: translate(5%, 20%)
    }
    
    .menu-toggle .bar{
        display: block;
        cursor: pointer;
    }
    
    .menu-toggle:hover{
        cursor: pointer;
    }
    
    #mobile-menu.is-active .bar:nth-child(2) {
        opacity: 0;
    }
    
    #mobile-menu.is-active .bar:nth-child(1) {
        transform: translateY(8px) rotate(45deg)
    }
    
    #mobile-menu.is-active .bar:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg)
    }
}

/* home */

.home{
    width: 100%;
    height: 100vh;
    margin: 0;
    background-color: #1b1b39;
}

.home .principal{
    max-width: 1200px;
    margin: auto;
    padding-top: 180px;
    padding-left: 2px;
    padding-right: 2px;
}

.home .principal .container{
    transform: translate(0, 30%);
}

.principal .man{
    transform: translate(30%, 0);
}

.principal .man img{
    max-width: 300px;
    margin: auto;
}

.principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 70px;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
}

.principal .container .caption a{
    color: white;
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding: 10px;
    font-size: 30px;
    font-weight: 500;
}

.principal .container .caption a:hover{
    color: #2aa264;
}

@media (max-width:1300px) and (min-width:1024px){
    
    .home{
    width: 100%;
    height: 600px;
    margin: 0;
    background-color: #1b1b39;
}
    
    .principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 40px;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
}
    
    .home .principal{
    max-width: 900px;
    margin: auto;
    padding-top:  100px;
    padding-left: 52px;
    padding-right: 2px;
}
    
    .principal .man img{
    max-width: 250px;
    margin: auto;
    margin-left: 35px;
}
    .home .principal .container{
    transform: translate(0, 50%);
}

    .principal .man{
    transform: translate(0, 10%);
}
    
    .seta{
        display: none;
    }
}

@media (max-width:1023px) and (min-width:700px){
    .principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 33px;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
}
    
    .home .principal{
    max-width: 900px;
    margin: auto;
    padding-top:  80px;
    padding-left: 35px;
    padding-right: 2px;
}
    
    .principal .man img{
    max-width: 230px;
    margin: auto;
}
    .home .principal .container{
    transform: translate(0, 50%);
    padding-left: 35px;
}

    .principal .man{
    transform: translate(0, 0);
    
}
    .home{
    width: 100%;
    height: 450px;
    margin: 0;
    background-color: #1b1b39;
}
    .principal .container .caption a{
    color: white;
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding:7px;
    font-size: 20px;
    font-weight: 500;
}
    .seta{
        display: none;
    }
}

@media (max-width:699px) and (min-width:450px){

.home .principal{
    max-width: 690px;
    margin: auto;
    padding-top:  110px;
    padding-left: 75px;
    padding-right: 45px;
}

.home .principal .container{
    transform: translate(0, 0);
}

.principal .man{
    transform: translate(0, 0);
}

.principal .man img{
    max-width: 250px;
    margin: auto;
    padding-top: 20px;
}

.principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 40px;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
    
}

.principal .container .caption a{
    color: white;
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding: 10px;
    font-size: 20px;
    font-weight: 500;
}
}

@media (max-width:449px) and (min-width:370px){
    .home .principal{
    max-width: 100%;
    margin: auto;
    padding-top:  35%;
    padding-left: 10%;
    padding-right: 45px;
}

.home .principal .container{
    transform: translate(0, 0);
}

.principal .man{
    transform: translate(0, 0);
}

.principal .man img{
    max-width: 75%;
    margin: auto;
    padding-top: 10%;
}

.principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 230%;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
    
}

.principal .container .caption a{
    color: white;
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding: 8px;
    font-size: 20px;
    font-weight: 500;
}
}

@media (max-width:369px){
        
    .home .principal{
    max-width: 100%;
    margin: auto;
    padding-top:  40%;
    padding-left: 10%;
    padding-right: 10%;
}

.home .principal .container{
    transform: translate(0, 0);
}

.principal .man{
    transform: translate(0, 0);
}

.principal .man img{
    max-width: 180px;
    margin: auto;
    padding-top: 8%;
}

.principal .container .caption h1{
    color: white;
    font-family: 'Barlow', sans-serif;
    font-size: 200%;
    line-height: 1;
    margin: 0;
    text-align: left;
    font-weight: 500;
    
}

.principal .container .caption a{
    color: white;
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding: 8px;
    font-size: 15px;
    font-weight: 500;
}
}


.seta{
    position: absolute;
    top: 95vh;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 30px;
}


/* intro */

.intro{
    max-width: 790px;
    margin: auto;
    padding: 120px 1% 0;
}

.intro .verde{
    font-size: 18px;
    color: #2aa264;
    font-family: 'Barlow', sans-serif;
}

.intro h2{
    font-size: 60px;
    line-height: 1;
    margin: auto;
    font-family: 'Barlow', sans-serif;
}

.intro p{
    font-size: 18px;
}

@media (max-width:1024px){
    .intro{
    max-width: 100%;
    margin: auto;
    padding: 100px 5% 0;
    }
    .intro h2{
    font-size: 27px;
    line-height: 1;
    margin: auto;
    font-family: 'Barlow', sans-serif;
}
}


/* serviços */

#servicos .atuacao .respiro{
    padding-right: 20px;
    padding-bottom: 20px;
    width: 33.33333%;
    float: left;
}

#servicos .atuacao{
    max-width: 790px;
    margin: auto;
    overflow: hidden; 
    height: auto;
    padding: 0 1%;
}

#servicos .atuacao h3{
    font-family: 'Barlow', sans-serif;
    line-height: 1;
    font-size: 18px;
}

#servicos .atuacao p{
        font-size: 18px;
    }
    
@media (max-width:1024px) and (min-width:450px){
    #servicos .atuacao{
    max-width: 100%;
    margin: auto;
    padding: 0 5%;
    }}
   

@media (max-width:699px) and (min-width:450px){

    #servicos .atuacao{
    max-width: 100%;
    margin: auto;
    padding: 0 5%;
    overflow: hidden; 
    height: auto;
}
    #servicos .atuacao .respiro{
    padding-right: 20px;
    padding-bottom: 20px;
    width: 50%;
    float: left;
}
}
    

@media (max-width:449px){
    #servicos .atuacao{
    max-width: 100%;
    margin: auto;
    overflow: hidden; 
    height: auto;
    padding: 0 5%;}
    #servicos .atuacao .respiro{
    padding-bottom: 20px;
    float: left;
    width: 100%;}
    #servicos .intro h2{
    font-size: 27px;
    line-height: 1;
    margin: auto;
    font-family: 'Barlow', sans-serif;}
}

.margem{
    margin-top: 80px;
    margin-bottom: 10px;
}
    

/* trabalhos */

.cases{
    max-width: 1700px;
    margin: auto;
    overflow: hidden; 
    height: auto;
    padding-top: 1%;
}

.saibamais img{
    width: 100%;
}

.saibamais{
    position: relative;
    text-align: center;
}

.flutuar{
    width: 50%;
    float: left;
}

.cases .flutuar .esquerda{
    padding-right: 0.5%;
    padding-bottom: 1%;
}

.cases .flutuar .direita{
    padding-left: 0.5%;
    padding-bottom: 1%;
}

.pageprojeto{
    position: absolute;
    bottom: 8px;
    right: 16px;
}

.pageprojeto mark{
    background-color: #2aa264;
    color: white;
    padding: 3px 8px;
    font-size: 18px;
}

.cases .flutuar .image {
    display: block;
    width: 100%;
    height: auto;
}

.cases .flutuar .overlay{
    position: absolute;
    top: 0;
    bottom: 0;
    height: 99%;
    width: 99.5%;
    opacity: 0;
    transition: .5s ease;
    background-color: #2aa264;
}

.flutuar:hover .overlay {
  opacity: 0.9;
}

.marca {
  color: white;
  font-size: 40px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}

@media (max-width:449px){
    .flutuar{
    width: 100%;
}

.cases .flutuar .esquerda{
    padding-right: 0;
    padding-bottom: 1%;
}

.cases .flutuar .direita{
    padding-left: 0;
    padding-bottom: 1%;
}
}

/* clientes */

.clientes{
    max-width: 790px;
    margin: auto;
    padding: 180px 1% 0;
    overflow: hidden; 
    height: auto;
}

.clientes img{
    max-width: 200px;
    
}

.clientes .logo{
    float: left;
    padding-right: 5%;
}

.clientes .texto{
    padding: 2% 0;
}

.clientes h1{
    font-family: 'Barlow', sans-serif;
    line-height: 0;
}
.clientes h2{
    font-family: 'Barlow', sans-serif;
    line-height: 1;
    color: gray;
    font-size: 15px;
    padding-top: 12px;
}

.clientes p {
    font-size: 18px;
}

.website iframe{
    width: 100%;
}

.insta{
    max-width: 1720px;
    margin: auto;
    overflow: hidden; 
    height: auto;
    padding-bottom: 0.75%;
}

iframe.desk{
    height: 447px;
    margin-bottom: 25px;
}

iframe.cell{
    height: 410px;
    margin-bottom: 25px;
}

.artes{
    width: 90%;
    margin: auto;
}
.insta .meio img{
    padding: 0 0.25%;
}

.insta .esquerda img{
    padding-right:0.5%;
}

.insta .direita img{
    padding-left: 0.5%;
}

.insta img{
    width: 33.33333%;
    float: left;
}
.aplicacao{
    max-width: 1000px;
    margin: auto;
}
.aplicacao img{
    width: 100%;
    margin: auto;
}

@media (max-width:768px) and (min-width:500px){
    .clientes{
    max-width: 100%;
    margin: auto;
    padding: 180px 5% 0;
}
    .website{
    max-width: 100%;
    margin: auto;
    padding: 0 5%;
}
    iframe.desk{
    height: 450px;
    margin-bottom: 25px;
}

    iframe.cell{
    height: 410px;
    margin-bottom: 25px;
}
    .artes{
    width: 100%;
    margin: auto;
}
    .insta .meio img{
        padding: 0;
        margin-bottom: 1%;
    }

    .insta .esquerda img{
        padding-right:0;
        margin-bottom: 1%;
    }

    .insta .direita img{
        padding-left: 0;
        margin-bottom: 1%
    }

    .insta img{
        width: 100%;
    }
}

@media (max-width:499px){
    .clientes{
    max-width: 100%;
    margin: auto;
    padding: 180px 5% 0;
}
    
    .website{
    max-width: 100%;
    margin: auto;
    padding: 0 5%;
}
    
    .clientes .logo{
    float: none;
    padding: 0 5%;
    margin-bottom: 20px;
}

    .clientes .texto{
    padding: 2% 5%;
}
    iframe.desk{
    height: 300px;
    margin-bottom: 25px;
}

    iframe.cell{
    height: 410px;
    margin-bottom: 25px;
}
    .artes{
    width: 100%;
    margin: auto;
}
    .insta .meio img{
        padding: 0;
        margin-bottom: 1%;
    }

    .insta .esquerda img{
        padding-right:0;
        margin-bottom: 1%;
    }

    .insta .direita img{
        padding-left: 0;
        margin-bottom: 1%
    }

    .insta img{
        width: 100%;
    }
}

.outros{
    max-width: 790px;
    margin: auto;
    text-align: center;
    height: 100px;
    margin-top: 50px
}

.outros a{
    text-decoration: none;
    width: 150px;
    border-style: solid;
    padding: 10px;
    font-size: 20px;
    font-weight: 500;
}

.outros a:hover{
    color: #2aa264;
}

/* quem somos */

#quemsomos{
    overflow: hidden; 
    height: auto;
}

#quemsomos img{
    width: 100%;
    margin-top: 80px;
}

#quemsomos .container{
    float: left;
    width: 50%;
}

#quemsomos .container .content{
    margin-top: 150px;
    padding-left: 4%;
    padding-right: 3%;
}

#quemsomos .container .content .verde{
    font-size: 18px;
    color: #2aa264;
    font-family: 'Barlow', sans-serif;
}

#quemsomos .container .content p{
    font-size: 18px;
}

#quemsomos .container .content h1{
    font-size: 27px;
    margin: auto;
    font-family: 'Barlow', sans-serif;
    margin-bottom: 10px;
    margin-top: 13px;
}

#quemsomos .container .content .us .one{
    width: 40%;
    float: left;
    font-family: 'Barlow', sans-serif;
    font-size: 18px;
    padding-bottom: 13px;
}

.redes{
    display: grid;
    grid-template-columns: repeat(3, auto);
    list-style: none;
    width: 60%;
    justify-self: end;
    padding-top: 10px
}

.redes .links{
    color: white;
    background-color: #1b1b39;
    border: none;
    padding: 8px;
    border-radius: 50%;
}

.redes .links:hover{
    background-color: #2aa264;
}

@media (max-width:1230px) and (min-width:801px){
    #quemsomos .container{
    width: 100%;
}
    .redes{
    display: grid;
    grid-template-columns: repeat(3, auto);
    list-style: none;
    width: 40%;
    justify-self: end;
    padding-top: 10px
}
    #quemsomos .container .content{
    margin-top: 100px;
    padding-left: 5%;
    padding-right: 5%;
}
    #quemsomos .container .content .us .one{
    width: 50%;
    float: left;
    font-family: 'Barlow', sans-serif;
    font-size: 18px;
    margin-bottom: 5%
}
}

@media (max-width:801px) and (min-width:500px){
    #quemsomos .container{
    width: 100%;
}
    #quemsomos .container .content{
    margin-top: 80px;
    padding-left: 5%;
    padding-right: 5%;
}
    #quemsomos .container .content h1{
    font-size: 27px;
    line-height: 1;
    margin: auto;
    font-family: 'Barlow', sans-serif;
    padding-bottom: 10px;
}
    .redes{
    display: grid;
    grid-template-columns: repeat(3, auto);
    list-style: none;
    width: 50%;
    justify-self: end;
    padding-top: 10px;
}
    #quemsomos .container .content .us .one{
    width: 50%;
    float: left;
    font-family: 'Barlow', sans-serif;
    font-size: 18px;
    margin-bottom: 10%;
}
}

@media (max-width:499px){
    #quemsomos .container{
    width: 100%;
}
    #quemsomos .container .content{
    margin-top: 80px;
    padding-left: 5%;
    padding-right: 5%;
}
    #quemsomos .container .content h1{
    font-size: 27px;
    line-height: 1;
    margin: auto;
    font-family: 'Barlow', sans-serif;
    padding-bottom: 10px;
}
    .redes{
    display: grid;
    grid-template-columns: repeat(3, auto);
    list-style: none;
    width: 50%;
    justify-self: end;
    padding-top: 5px;
}
    #quemsomos .container .content .us .one{
    width: 100%;
    float: left;
    font-family: 'Barlow', sans-serif;
    font-size: 18px;
    margin-bottom: 10%;
}
    .redes .links{
    color: white;
    background-color: #1b1b39;
    border: none;
    padding: 8px;
    border-radius: 50%;
    font-size: 14px;
}
}


.blog{
    width: 100%;
    margin: auto;
}

.blog .topoimagem{
    background-color: #2aa264;
    padding-top: 80px;
}

.blog .topoimagem img{
    max-width: 30%;
    padding: 2% 5%;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.blog p{
    font-size: 18px;
}

.blog .credito{
    max-width: 1000px;
    margin: auto;
    padding: 0 1%;
    text-align: end;
    font-size: 15px;
}

.blog .conteudo{
    max-width: 1000px;
    margin: auto;
    padding: 5% 1%;
}

.blog .conteudo h1{
    font-size: 60px;
    font-family: 'Barlow', sans-serif;
    line-height: 1;
}

.blog .conteudo .autoria{
    line-height: 1.3;
    font-size: 15px;
}

.blog .conteudo img{
    width: 100%;
}

.blog .conteudo a:hover{
    color: #2aa264;
}

@media (max-width:1000px){
    .blog .conteudo{
    width: 100%;
    margin: auto;
    padding: 5%;
}
    .blog .conteudo h1{
    font-size: 27px;
    font-family: 'Barlow', sans-serif;
    line-height: 1;
}
}

/* contato */

#contato{
    height: 90vh;
    background-color: #2aa264;
}

#contato .chamada{
    max-width: 790px;
    margin: auto;
    padding: 30vh 1% 0;
}

#contato .chamada h2{
    color: #1b1b39;
    font-size: 60px;
    font-family: 'Barlow', sans-serif;
}

#contato .chamada h3{
    color: white;
    font-size: 30px;
    font-family: 'Barlow', sans-serif;
}

#contato .chamada p{
    color: #1b1b39;
    font-size: 30px;
    line-height: 1;
}

#contato .chamada mark{
    color: #2aa264;
    background-color: white;
    padding: 1px 10px;
}

@media (max-width:1023px){
    #contato .chamada{
    max-width: 100%;
    margin: auto;
    padding: 30vh 5% 0;
    }
    #contato .chamada h2{
    font-size: 40px;
    margin: auto;
    font-family: 'Barlow', sans-serif;
    line-height: 1;
}
    #contato .chamada h3{
    color: white;
    font-size: 18px;
    font-family: 'Barlow', sans-serif;
}
    #contato .chamada p{
    color: #1b1b39;
    font-size: 18px;
    line-height: 1;
    }
    #contato .chamada mark{
    color: #2aa264;
    background-color: white;
    padding: 1px 10px;
}
}


/* footer */

footer{
    height: 10vh;
    background-color: #2aa264;
}

footer p{
    max-width: 790px;
    padding: 1%;
    margin: auto;
    text-align: center;
    font-size: 18px;
}