html{
    font-family: helvetica-neue-thin;
    background-color: #EAE8E4;
}

body{
    margin: 0;
}

main{
    color: #2D2D2D;
    display: flex;
    flex-direction: column;
    align-items: center;
}

@font-face{
    font-family: inter;
    src: url("assets/fonts/Inter/Inter-VariableFont_opsz\,wght.ttf");
}

@font-face{
    font-family: helvetica-neue-roman;
    src: url("assets/fonts/helvetica-neue/HelveticaNeueRoman.otf")
}

@font-face{
    font-family: helvetica-neue-bold;
    src: url("assets/fonts/helvetica-neue/HelveticaNeueBold.otf")
}

@font-face{
    font-family: helvetica-neue-light;
    src: url("assets/fonts/helvetica-neue/HelveticaNeueUltraLight.otf");
}

@font-face{
    font-family: helvetica-neue-thin;
    src: url("assets/fonts/helvetica-neue/HelveticaNeueThin.otf");
}

h1{
    font-family: helvetica-neue-bold;
}

h2{
    font-family: helvetica-neue-roman;
    font-size: 2.6em;
    margin: 0;
}

h3{
    font-size: 1.3em;
    margin: 8px 0;
}

section{
    padding: 40px 0;
}

.alinhamento-conteudo{
    margin: 0 7%;
}

/* HEADER ---------------------------------*/

header{
    background-color: #2D2D2D;
    display: flex;
    justify-content: start;
    color: white;
    border-radius: 0 0 30px 30px;
    min-height: 460px;
    height: 600px;
    position: relative;
}

header #icon-menu{
    display: none;
    cursor: pointer;
    width: 35px;
    padding: 1px;
    z-index: 3;
}

header #icon-back{
    display: none;
    width: 60px;
}

header .hamburguer{
    padding: 0;
}

header .menu-imgs{
    display: flex;
    justify-content: start;
    width: 15%;
}

header #text-box{
    width: 55%;
    margin-left: 7%;
}

#logo{
    min-width: 140px;
    padding-right: 20px;
}

header #text-box nav{
    display: flex;
    align-items: center;
    justify-content:space-between;
    font-size: 1.3em;
    height: 18%;
    gap: 30px;
    width: 100%;
    max-width: 1000px;
}

header #text-box nav a{
    text-decoration: none;
    color: white;
}

header #text-box nav li{
    list-style: none;
}

header #text-box nav li:hover{
    list-style:disc;
    transition: 500ms;
}

header #text-box ul{
    display: flex;
    justify-content: space-between;
    width: 85%;
    padding-left: 30px;
    gap: 5px;
}

header #banner-svg{
    width: 38%;
    object-fit:cover;
    object-position: left;
    border-radius: 0 0 30px 0;
}

header #text{
    height: 82%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
}

header #text h1{
    font-size: 2.8em;
    margin: 0;
}

header #text p{
    font-size: 1.4em;
    margin: 0;
    font-family: helvetica-neue-light;
}

header #text #scroll{
    min-width: 110px;
}

/* HEADER ---------------------------------*/

/* PRODUTOS -------------------------------*/

#produtos{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

#produtos p{
    font-size: 1.2em;
}

#produtos #text-box{
    width: 100%;
}

#produtos-cards{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding-top: 30px;
}

#produtos-cards .card{
    width: 22%;
    text-align: start;
    background-color: #FCFCFD;
    padding: 6px 6px 18px 6px;
    border-radius: 8px;
    box-shadow: 1px 1px 10px -4px rgba(0, 0, 0, 0.46);
}

#produtos-cards .card img{
    width: 100%;
}

#produtos-cards .card .text-img{
    padding: 0 7px;
}

#produtos-cards h3{
    font-family: helvetica-neue-roman;
    font-size: 1.3em;
}

/* PRODUTOS -------------------------------*/

/* GALERIA --------------------------------*/

#galeria{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 775px;
    box-sizing: border-box;
}

#galeria-box{
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(4, 1fr);
    grid-template-areas: 
    "text img2"
    "img1  img2"
    "img1  img3"
    "img1  img3";
    gap: 10px;
    width: 100%;
    height: 100%;
}

#galeria-box #text-box{
    grid-area: text;
 }
#galeria-box #galeria-img1{
    grid-area: img1;
}

#galeria-box #galeria-img2{
    grid-area: img2;
}

#galeria-box #galeria-img3{
    grid-area: img3;
}

#galeria-box .galeria-imgs{
    width: 100%;
    height: 100%;
}
/* GALERIA --------------------------------*/

/* APP ------------------------------------*/

#app{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

#app-box{
    display: flex;
    justify-content: space-around;
    align-items: center;
    background-color: #3C0C60;
    border-radius: 30px;
    color: white;
    padding: 20px 40px;
    width: 100%;
    box-sizing: border-box;
}

#app-box #buttons img{
    width: 200px;
    display: block;
    padding: 7px 0;
}
#app-box #text-box{
    padding-right: 20px;
}

#app-box #text-box h3{
    font-weight: 400;
}

/* APP ------------------------------------*/

/* TIPOS PRODUTOS -------------------------*/

#tipos-produtos{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#tipos-produtos h2{
    width: 100%;
}

#tipos-produtos ul{
    width: 91%;
    list-style: none;
    color: #7D26C9;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    padding-top: 40px;
    margin: 0 80px;
    gap: 20px;
    margin: 0;
}

#tipos-produtos li p{
    background-color: #DFDCD5;
    padding: 8px 40px;
    border-radius: 20px;
    border: 1px solid #7D26C9;
    font-family: inter;
    font-size: 1.3em;
    font-weight: 600;
    margin: 0;
}

#tipos-produtos li p:hover {
    background-color: #f3f2ee;
    color: #b371ec;
    transform: scale(1.13);
    transition: 300ms;
    cursor:default;

}

/* TIPOS PRODUTOS -------------------------*/

/* CARDS ----------------------------------*/

#cards{
    width: 100%;
}

#cards-box{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2%;
}

#cards .card{
    width: 32%;
    background-color: #FFFFFF;
    border: 2px solid #DFBBFE;
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    box-shadow: 1px 1px 10px -4px rgba(0, 0, 0, 0.46);
    box-sizing: border-box;
    min-height: 285px;
}

#cards .card h3{
    font-family: helvetica-neue-roman;
    font-size: 1.5em;
}

#cards .card p{
    font-size: 1.3em;
    line-height: 30px;
}

#cards .card button{
    font-family: inter;
    font-weight: 600;
    font-size: 1em;
    color: #2D2D2D;
    padding: 8px 40px;
    background-color: #DFBBFE;
    border: none;
    border-radius: 4px;
}

#cards .card button:hover{
    background-color: #e6d2f8;
    color: #747373;
    transition: 500ms;
}

/* CARDS ----------------------------------*/

/* FORMULÁRIO -----------------------------*/

#form{
    background-color: #2D2D2D;
    padding: 50px 0;
    width: 100%;
}

#formulario{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 3%;
}

#formulario #formulario-box{
    background-color: #EAE8E4;
    width: 72%;
    padding: 24px;
    border-radius: 24px;
    display: flex;
    flex-direction: column;
    max-width: 950px;
    box-sizing: border-box;
}

#formulario #input-box{
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 30px;
}

#formulario #input-box .inputs{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
    height: 100%;
}

#formulario #input-box .inputs input{
    border-radius: 8px;
    border: none;
    width: 100%;
    height: 40px;

}

#formulario #input-box .inputs input, #formulario #verificacao input {
    color: #777777;
    font-size: 1.3em;
    font-family: helvetica-neue-light;
    font-weight: 600;
    padding-left: 10px;
}

#formulario #form-img{
    width: 25%;
}

#formulario #verificacao input{
    border-radius: 8px;
    border: none;
    height: 40px;
}

#formulario #verificacao{
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: center;
    font-family: helvetica-neue-roman;
    font-weight: 600;
    gap: 5px;
    width: 100%;
}

#formulario #verificacao #soma{
    color: #7D26C9;
    font-size: 1.2em;
    background-color: #DFDCD5;
    padding: 10px 25px;
    width: 178px;
    text-align: center;
    word-spacing: 20px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

#formulario #verificacao p:first-of-type{
    font-size: 1.4em;
}

#formulario #formulario-box button{
    font-family: inter;
    font-weight: 600;
    font-size: 1.2em;
    color: #2D2D2D;
    padding: 8px 40px;
    background-color: #DFBBFE;
    border: none;
    border-radius: 4px;
    display: flex;
    align-self: center;
    margin: 15px 0;
}

#formulario #formulario-box button:hover{
    background-color: #e6d2f8;
    color: #747373;
    transition: 500ms;
}

#formulario #formulario-box .msgs{
    font-weight: bold;
}

#formulario #formulario-box .alert-ok.show{
    border: 2px solid green;
    color: rgb(93, 241, 93);
    margin: 20px 0;
    padding: 15px;
    display: inline-block;
    font-size: 1.3em;
    font-weight: bold;
}

#formulario #formulario-box .alert-error.show, #formulario #formulario-box .alert-error-resultado.show{
    border: 2px solid red;
    color: rgb(228, 98, 98);
    margin: 20px 0;
    padding: 15px;
    display: inline-block;
    font-size: 1.3em;
    font-weight: bold;
}

#formulario #formulario-box .msgs.show{
    display: inline-block;
}

#formulario #formulario-box .msgs, #formulario #formulario-box .alert-error, #formulario #formulario-box .alert-ok, #formulario #formulario-box .alert-error-resultado{
    display: none;
}



/* FORMULÁRIO -----------------------------*/

/* FOOTER ---------------------------------*/

footer{
    background-color: #2D2D2D;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#social{
    width: 80%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
    padding: 40px 0;
    border-top: 1px solid #DFBBFE;
}

footer #text-box{
    color: #EAE8E4;
    text-align: center;
    margin-bottom: 30px;
}

footer #text-box ul{
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    padding: 0;
}

footer #icon-insta:hover svg path{
    fill: #964B00;
    transition: 500ms;
}

footer #icon-wpp:hover svg path{
    fill: #25d366;
    transition: 500ms;
}

footer #icon-tt:hover svg path{
    fill: #1DA1F2;
    transition: 500ms;
}

footer #icon-face:hover svg path{
    fill: #3b5998;
    transition: 500ms;
}

/* FOOTER ---------------------------------*/

/* MEDIA QUERYS ---------------------------*/

@media (min-width: 1650px) {
    html{
        font-size: 1.3em;
    }

    header #text #scroll{
        min-width: 150px;
    }

    #cards .card{
        min-height: 385px;
    }

    #formulario #formulario-box button, #cards .card button{
        padding: 15px 60px

    }   

    #galeria{
        height: 1000px;
    }    

    #formulario #input-box .inputs input, #formulario #verificacao input {
        height: 60px;
    }

    #tipos-produtos li p{
        padding: 15px 50px;
        border-radius: 30px;
    }

    #logo{
        width: 130px;
    }

}

@media (max-width: 1025px) {
    
    header #banner-svg{
        position: absolute;
        left: 59%;
        height: 600px;
        width: 41%;
    }

    header #text-box{
        width: 63%;
    }

    header a{
        font-size: 0.9em;
    }

    header #text-box nav li{
        min-width: 82px;
    }

    header #text-box nav{
        gap: 35px;
    }

    header #text-box ul{
        gap: 3px;
    }

    html{
        font-size: 0.9em;
    }

    .alinhamento-conteudo{
        margin: 0 4%;
    }
}

@media (max-width: 769px) {

    html{
        font-size: 1.0em;
    }

    header #banner-svg{
        width: 55%;
        left: 45%;
    }

    header #icon-menu{
        display: block;
    }

    header nav{
        width: 220px;
    }

    header #text-box{
        width: 54%;
    }

    h3{
        font-size: 1.6em;
    }

    #logo{
        width: 160px;
    }

    #produtos-cards{
        flex-direction: column;
        justify-content: center;
        gap: 30px;
    }

    #produtos-cards .card{
        width: 100%;
        height: 22%;
        font-size: 1.6em;
        border-radius: 20px;
    }

    #galeria{
        height: auto;
    }

    #galeria-box{
        grid-template-columns: 1fr;
        grid-template-rows: 0.5fr repeat(7, 1fr);
        grid-template-areas: 
            "text"
            "img1"
            "img1"
            "img1"
            "img2"
            "img2"
            "img3"
            "img3";    
        justify-content: center;
        align-items:start;
        max-height: 1472px;
    }

    #app-box{
        flex-direction: column;
    }

    #app-box h3{
        font-size: 2.2em;
        
    }

    #app-box #text-box{
        padding: 20px;
    }

    #app-box #buttons img{
        width: 100%;
    }

    #cards-box{
        flex-direction: column;
        gap: 30px;
    }

    #cards .card{
        max-width: auto;
        width: 100%;
        height: 430px;
        font-size: 1.6em;
    }


    #cards .card p{
        line-height: 50px;
    }

    #formulario{
        flex-direction: column;
        justify-content: space-between;
        gap: 50px;
    }

    #formulario #form-img{
        width: 100%;
        height: 30%;
    }

    #formulario #formulario-box{
        height: 65%;
        width: 100%;
    }

    #formulario #formulario-box #text-box p, #formulario #formulario-box #text-box h3{
        font-size: 1.4em;
    }

    #formulario #input-box{
        flex-direction: column;
        gap: 0;
    }

    #formulario #input-box .inputs{
        height: 100%;
    }

    #formulario #formulario-box button, #cards .card button{
        padding: 15px 60px

    }
    
    #formulario #formulario-box #verificacao{
        flex-wrap: wrap;
    }

    #formulario #formulario-box #verificacao p:first-of-type{
        width: 100%;
        font-size: 2.0em;
    }

    #formulario #input-box .inputs input, #formulario #verificacao input, #formulario #formulario-box #soma {
        height: 70px;
    }

    #tipos-produtos li p{
        padding: 15px 50px;
        border-radius: 30px;
    }

    #tipos-produtos ul{
        padding: 30px 0 0 0;
    }


    header .hamburguer li{
        display: none;
    }

    header .hamburguer.on li{
        display: block;
    }
    
    header .hamburguer.on{
        display: block;
        position: fixed;
        width: 100vw;
        height: 60vh;
        margin: 0;
        background-color: #DFBBFE;
        transition:0.6s;
        z-index: 1;
    }
    
    header .hamburguer.on nav{
        flex-direction: column;
        height: 100%;
    }

    header .hamburguer.on ul{
        display: flex;
        flex-direction: column;
        align-items: start;
        justify-content: space-between;
        width: 90%;
        margin: 0;
        padding-left: 50px;
    }

    header .hamburguer.on .menu-imgs{
        background-color: #2D2D2D;
        padding: 15px 0;
        border-radius: 0 0 20px 20px;
        width: 100%;
        height: 20px;
    }

    header .hamburguer.on #logo{
        padding-left: 50px;
    }

    header #text-box.on{
        margin: 0;
    }

    header #text-box.on nav{
        gap: 12px;
    }

    header #text-box.on nav a {
        color: #2D2D2D;
        font-family: helvetica-neue-roman;
        font-weight: 600;  
        font-size: 1.2em;
        
    }

    header #text-box.on nav ul li{   
        list-style: disc;
        color: #2D2D2D;
        padding: 10px 0;
    }

    header .hamburguer.on #icon-back{
        display: block;

    }

    #formulario #input-box .inputs input, #formulario #verificacao input, #formulario #formulario-box #soma {
        height: 40px;
        box-sizing: border-box;
    }

}

@media (max-width: 570px) {
    html{
        font-size: 0.8em;
    }

    

    #formulario #verificacao input, #formulario #formulario-box #soma{
        width: 40%;
    }

    #formulario #formulario-box #soma img {
        width: 10px;
    }
    
}

@media (max-width: 426px) {
    html{
        font-size: 0.7em;
    }

    header #banner-svg{
        left: 32%;
        bottom: 0;
        width: 68%;
    }

    #logo{
        min-width: 100px;
    }

    #app-box{
        padding: 10px 20px;
        font-size: 0.9em;
    }

    #tipos-produtos ul p{
        padding: 12px 20px;
    }

    #cards .card p{
        line-height: 40px;
    }

    header #icon-back{
        width: 50px;
    }
 }
/* MEDIA QUERYS ---------------------------*/