*{
    padding: 0;
    margin:0;
    box-sizing: border-box;
    font-family:'Jost', sans-serif;
    list-style: none;
    text-decoration: none;
    scroll-behavior: smooth;
}

:root{
    --bg--color: #fff;
    --text-color: #000;
    --secound-color: #6b6874;
    --main-color: #258EE9;
    --big-font:5rem;
    --h2-font: 3rem;
    --p-font:1.1rem;
}

body{
    background: var(--bg--color);
    color:var(--text-color);
    overflow-x: hidden;
    box-sizing: border-box;
    
}

header{
    position: fixed;
    width: 100%;
    top:0;
    right: 0;
    z-index: 1000;
    display: flex ;
    align-items:center;
    justify-content: space-between;
    background: transparent;
    padding: 30px 18%;
    transition: .3s;
}

.logo img {
    margin-top:6px;
    max-width: 100%;
    width: 140px;
    height: auto;

}

.navlist{
    display: flex;
}

.navlist li{
   position: relative;
}

.navlist a{
    font-size: var(--p-font);
    color: var(--text-color);
    font-weight: 500;
    padding: 10px 27px;
}

.navlist a::after{
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    background: var(--main-color);
    bottom: -3px;
    left:0;
    transition: ease .40s;
}

.navlist a:hover::after{
    width:100%;

}

#menu-icon{
    font-size: 35px;
    color: var(--text-color);
    z-index:10001;
    cursor:pointer;
    display:none;
}

.top-btn{
    display: inline-block;
    padding: 9px 30px;
    background: transparent;
    border:2px solid var(--main-color);
    border-radius: 30px;
    color:var(--text-color);
    letter-spacing:1px;
    font-size: var(--p-font);
    font-weight: 500;
    transition: ease .50s;
    
    
}

.top-btn:hover{
    transform: scale(1.1);
    background: var(--main-color);
    border:2px solid var(--main-color);
    color:var(--bg--color);
    cursor: pointer;
}

section {
padding: 100px 18%;
}

.home{
    min-height: 100vh;
    height: 100%;
    width: 100%;
    background: url(../img/background2.jpg);
    background-size: cover;
    background-position: center;
    position: relative;
    display: grid;
    grid-template-columns: repeat(2,1fr);
    align-items: center;
    gap:4rem;
}

.home-text h1{
    margin: 110px 0px 25px;
    font-size: var(--big-font);
    line-height: 1;
    font-weight: 500;
}

.home-text h5{
    margin-bottom: 23px;
    font-size: 19px;
    font-weight: 500;
}

span{
    color:var(--main-color);
}

#idade{
    color:var(--secound-color);
}

#ano {
    color:var(--text-color)
}

.home-text h3{
    color: var(--main-color);
    font-size: 20px;
    font-weight: 500px;
}

.home-text p{
    font-size: var(--p-font);
    color:var(--secound-color);
    line-height: 28px;
    margin-bottom: 20px;
}

.social a{
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #0E4563;
    font-size: 17px;
    color: var(--bg--color);
    margin-right: 22px;
    margin-bottom: 30px;
}

.social a:hover{
    transform: scale(1.2);
    background: var(--main-color);
    transition: .5s;
}

.btn{
   display: inline-block;
   color: var(--bg--color);
   background: var(--main-color);
   font-size: var(--p-font);
   padding: 10px 40px;
   font-weight: 500px;
   line-height: 24px;
   border-radius: 30px;
   transition: ease .40s;

}

.btn:hover{
    transform: scale(1.1);
}

.home-img img{
    max-width: 100%;
    width: 400px;
    height: auto;
}

header.sticky{
    background: var(--bg--color);
    padding:13px 18%;
    box-shadow: 0px 0px 10px rgba(0 0 0 / 10%);
}

.items{
   display: grid;
       grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
       gap: 2rem;
       align-items: start;
       text-align: center;
       justify-content: center; /* centraliza o grid dentro do container */
       padding: 0.1rem; /* espaçamento interno opcional */
}


.sub-box{
   padding: 25px;
       transition: ease 0.5s;
       max-width: 365px;
       width: 100%;
       height: 100%; /* mais responsivo */
       margin: 0 auto; /* centraliza individualmente caso sobre espaço */
}


.sub-img img{
    max-width: 100%;
    width: 60px;
    height: auto;
    margin-bottom: 20px;
    
}

.sub-box h3{
    margin-bottom: 20px;
    font-size: 24px;
    font-weight: 500;
}

.sub-box p{
    font-size: var(--p-font);
    color:var(--secound-color);
    line-height: 29px;
}

.sub-box:hover{
  background: #fff;
  box-shadow: 18px 0px 87px 0px rgb(10 15 70 / 7%);  
  border-radius: 12px;
  will-change: transform;
  transform: perspective(1000px) rotateX(4.80deg) rotateY(10.23deg) scale3d(1.05,1.05,1.05);
}

.about{
    display: grid;
    grid-template-columns: repeat(2, 2fr);
    align-items: center;
    gap: 2rem;
    
}

.about-img img{
    max-width: 100%;
    width: 540px;
    height: auto;
}

.about-text h2{
    font-size: var(--h2-font);
    font-weight: 500;
    margin:8px 0px 25px;
    line-height: 1.1;
}

.about-text h3 {
    color: var(--main-color);
    font-size:20px;
    font-weight: 500;
}

.about-text p{
    max-width: 550px;
    font-size: var(--p-font);
    color: var(--secound-color);
    line-height: 28px;
    margin-bottom: 20px;

}

.about-text i{
    color: #258EE9;
    margin-right: 15px;
}

.heading{
    text-align: center;
}

.heading h2{
    font-size: var(--h2-font);
    font-weight: 500;
    margin: 7px 0px 20px;
    line-height: 1.1;
}

.heading h3{
    color:var(--main-color);
    font-size: 20px;
    font-weight: 500;
}

.heading p{
    font-size: var(--p-font);
    color: var(--secound-color);
    line-height: 28px;
}

.portfolio-content{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, auto));
    gap: 2rem;
    align-items: center;
    margin-top: 5rem;
    text-align: center;
    cursor: pointer;
}

.col{
    position: relative;
}

.col img{
    max-width: 100%;
    width: 550px;
    height:auto;
    object-fit: cover;
    border-radius: 12px;
}

.layer{
    background: linear-gradient(rgba(0,0,0,0.5) 0%, #191919);
    height: 100%;
    width: 100%;
    position: absolute;
    top:0;
    left: 0;
    border-radius: 12px;
    transition: all .40s;

}

.layer:hover{
    background: transparent;
}

.layer h3{
    position: absolute;
    width: 100%;
    font-size: 25px;
    font-weight: 500;
    color: var(--bg--color);
    bottom:10px;
    left: 50%;
    transform: translate(-50%);
    opacity: 0;
    transition: all .40s;
}

.layer:hover h3{
    bottom:52%;
    opacity:1;
}

.layer h5{
    position: absolute;
    width: 100%;
    font-size: 17px;
    font-weight: 500;
    color: var(--bg--color);
    bottom:0;
    left: 50%;
    transform: translate(-50%);
    opacity: 0;
    transition: all .40s;
    
}

.layer:hover h5{
    bottom:48%;
    opacity:1;
}

.service-content{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, auto));
    gap: 2rem;
    align-items: center;
    margin-top: 5rem; 
}

.row{
    background: #fff;
    box-shadow: 18px 0px 87px 0px rgb(10 15 70/ 7%);
    border-radius: 12px;
    padding: 45px 45px 45px 45px;
    transition: ease .45s;
    cursor:pointer; 
}

.s img{
   height: 65px;
   width: 65px;
   background: #8BCBF5;
   padding: 15px;
   border-radius: 50%;
   margin-bottom: 20px; 
}



.s.s-two img{
    background: #258EE9;
}

.s.s-three img{
    background: #d9d1fa;
}

.s.s-four img{
    background: #faedce;
}

.row h3{
    font-size: 24px;
    font-weight: 500;
    margin-bottom: 2px;
}

.row h5{
    font-size: 17px;
    font-weight: 500;
    margin-bottom: 19px;
}

.row p{
    font-size: var(--p-font);
    color: var(--secound-color);
    line-height: 28px;
    text-align:justify;
}

.row:hover{
    will-change: transform;
    transform: perspective(1000px) rotateX(4.80deg) rotateY(10.23deg) scale3d(1.05,1.05,1.05);
}

.cta-box{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-top: 5rem; 
    text-align: center;
    justify-content: center;
}

.wrap{
    background: #fff;
    box-shadow: 18px 0px 87px 0px rgb(10 15 70/ 7%); 
    border-radius: 12px;
    padding: 40px 50px 50px 50px;
    transition: ease .40s;
    width:100%;
    height: auto;
    margin: 0 auto;
}



.one{
    background: #93C4E6;
}

.two{
    background: #A5E7F7;
}

.three{
    background: #8BCBF5;
}

.wrap h3{
    font-size: 24px;
    font-weight: 500;
    margin-bottom: 2px;
}

.wrap p{
    font-size: var(--p-font);
}

.contact{
    background: #8067f0eb;
    width: 64%;
    margin:100px auto;
    display: flex;
    padding: 70px 150px;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background-image: url(../img/intro.jpg);
    background-size: cover;
}

input,label{
    display: block;
   
    
}
label{
    color:var(--bg--color);
    padding: 12px 15px;
}
.contact .action form{
    align-items: center;

}
.center h3{
    font-size: 30px;
    font-weight: 500;
    margin-bottom: 3px;
    color:var(--bg--color);
    text-align: center;
}

.center p{
    font-size: var(--p-font);
    color: var(--bg--color);
    line-height: 26px;
    margin-bottom: 25px;
    text-align: center;
}

.contact .action form textarea{
    max-width: 100%;
    width: 600px;
    padding: 12px 15px;
    color: var(--text-color);
    border:none;
    outline: none;
    margin:0 10px 20px 0;
    border-radius: 20px;
   
}

.contact .action form input[type="text"], [type="email"]{
   width: 100%;
       padding: 12px 15px;
       font-size: --p-font;
       border: none;
       outline: none;
       border-radius: 20px;
       margin-bottom: 20px;
       box-sizing: border-box;
}

.contact .action form input[type="submit"]{
    padding: 12px 40px;
    background: var(--main-color);
    color: var(--bg--color);
    border: none;
    outline: none;
    border-radius: 20px;
    cursor: pointer;
    transition: ease .40s;
    width: 50%;
    display: block;
    margin: 0 auto 20px auto;
    text-align: center;
    
}

.contact .action form input[type="submit"]:hover{
transform: scale(1.1);
}

.ends{
    text-align:center;
    padding: 40px;
}

.ends p{
    font-size: var(--p-font);
}

@media (max-width: 1425px){
    body{
        overflow-x: hidden;
        box-sizing: border-box;
    }

    header{
        padding: 16px 3%;
        transition: .3s;    
    }

    header.sticky{
        padding: 10px 3%;
        transition: .3s;
    }

    section{
        padding: 70px 3%;
        transition: .3s;
    }

    .contact{
        width: 95%;
        transition: .3s;
    }

    :root{
        --big-font:4rem;
        --h2-font:2.3rem;
        --p-font:0.9rem;
        transition: .3s;
    }

    .items{
        width: auto;
        height: auto;
    }

    
}
  

@media (max-width: 970px){
    body{
        overflow-x: hidden;
        box-sizing: border-box;
    }
    #menu-icon{
        display: block;
    }

    .home{
      min-height: 80vh;  
    }

    .navlist{
        position: absolute;
        top: -600px;
        left: 0;
        right: 0;
        flex-direction: column;
        background: var(--main-color);
        text-align: right;
        transition: all .40s;
    }

    .navlist a{
        display: block;
        padding: 1.2rem;
        margin: 1.5rem;
        border-right: 2px solid var(--bg--color);
        color: var(--bg--color);
    }

    .navlist a:hover{
       background: var(--bg--color);
       color: var(--main-color);
    }

    .navlist a:after{
        display: none;
     }

     .navlist.active{
        top:100%;
     }

     .wrap{
            width: auto;
        }

        .items{
            display:grid;
            grid-template-columns: repeat(1,1fr);
            gap: 2rem;
            align-items:start;
            text-align: center;
            vertical-align:top;
        }

}

@media (max-width: 820px){
    body{
        overflow-x: hidden;
        box-sizing: border-box;
    }
    .home{
        grid-template-columns: 1fr;
        min-height: 130vh;
        gap:1rem;
    }

    .home-text{
       padding-top: 55px; 
    }

    .home-img{
        text-align: center; 
     }

     .home-img img{
       width: 440px;
       height: auto;
     }

     .about{
        grid-template-columns: 1fr;
     }

     .about img{
        text-align: center;
        margin-bottom: 30px;
     }

     :root{
        --big-font:3.4rem;
        --h2-font:2rem;
     }

     section{
        padding: 65px 3%;
        transition: .3s;
     }

    .wrap{
        height: auto;
    }
     
}

     @media (max-width: 540px){
        .contact .action form textarea{
            width: 100%;
        }
        
        .contact .action form input[type="text"]{
            width: 100%;
            height: auto;
        }

        .top-btn{
            padding: 9px 30px;
            font-size: 10px;
            transition: ease .50s;
        }    

        .wrap{
            width: auto;
            height: auto;
        }

        .row p{
            text-align:left;
        }
        
        form{
            width: 265px;
        }

     }
