@import url('https://fonts.googleapis.com/css2?family=Lobster&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

* {
    box-sizing: border-box;
}


body {
    margin: 0;
    font-family: "Montserrat", sans-serif;
}

.navbar {
    display: flex;
    flex-flow: row wrap;
    height: 85px;
    background-color: black;
    justify-content: center;
    align-items: center;
    font-weight: 600;
}

.logo {
    flex: 20%;
    margin-left: 10%;
    /* border: 1px solid red; */
    text-align: left;
}

.logo img {
    width: 150px;
    margin-right: 5%;

}


.menu {
    flex: 70%;
    /* border: 1px solid red; */
    text-align: right;
    padding: 20px;
}

.menu a {
    color: rgb(255, 255, 255);
    text-decoration: none;
    font-size: 17px;
    padding: 20px 16px;


}

.menu a:hover {
    color: white;
    border-top: 4px solid white;
}

#FaleConosco {
    margin-right: 10%;
}

.header {
    background-color: rgb(255, 255, 255);
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;

}


body {
    margin: 0;
    font-family: "Montserrat", sans-serif;
}



.headeline {
    margin-left: 10%;
    flex: 40%;
    /* border: 1px solid red */
    text-align: center;
}

.headeline h2 {
    font-weight: 600;
    margin: 0%;
    padding: 0%;
    font-size: 50px;
    font-weight: bolder;
    color: black;
}

.headeline h3 {
    letter-spacing: 3px;
    color: black;
    margin-top: 10px;

}

.headeline p {
    text-align: left;
    color: gray;
    margin-left: 5%;

}

.contact-btn {
    display: inline-block;
    background-color: black;
    padding: 17px;
    color: white;
    border-radius: 10px;
    text-decoration: none;
    margin-top: 3%;
    font-weight: bold;

}

.contact-btn:hover {
    background-color: black;
}

.img-headeline {
    margin-right: 10%;
    flex: 40%;
    text-align: center;
}


/* Estilos gerais do container */
.container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    min-height: 100vh;
    padding: 2rem;
    box-sizing: border-box;
}

/* Logo */
.logo {
    margin-bottom: 2rem;
    text-align: center;
}

.logo-img {
    max-width: 200px;
    height: auto;
}

/* Menu de navegação */
.nav-menu {
    display: flex;
    gap: 1rem;
    margin-bottom: 2rem;
    width: 100%;
    max-width: 400px;
    justify-content: center;
}

.nav-button {
    padding: 0.8rem 1.5rem;
    border: none;
    background: none;
    color: #666;
    cursor: pointer;
    font-size: 1rem;
    position: relative;
}

.nav-button.active {
    color: #333;
    font-weight: bold;
}

.nav-button.active::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #333;
}

/* Ajuste do container do login/cadastro */
.login-cadastro {
    width: 100%;
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin: 2rem 0;
}

/* Container do card */
.card-containers {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1rem;
}

/* Card Container */
.card-container {
    max-width: 450px;
    perspective: 1000px;
    margin: 0 auto;
}

/* Card Flip */
.card-flip {
    position: relative;
    width: 450px;
    height: 500px;
    text-align: center;
    transition: transform 0.8s;
    transform-style: preserve-3d;
    margin: 0 auto;
}

.card-flip.flipped {
    transform: rotateY(180deg);
}

/* Card Faces */
.card-front,
.card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    background: white;
    padding: 2.5rem;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    box-sizing: border-box;
}

.card-back {
    transform: rotateY(180deg);
}

/* Formulário */
.form-group {
    margin-bottom: 1.5rem;
    text-align: left;
}

label {
    display: block;
    margin-bottom: 0.5rem;
    color: #333;
}

input {
    width: 100%;
    padding: 0.8rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-sizing: border-box;
}

.password-input {
    position: relative;
}

.toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    color: #666;
}

.btn {
    width: 100%;
    padding: 1rem;
    background-color: #333;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 1rem;
    margin-top: 1rem;
}

.btn:hover {
    background-color: #444;
}

/* Links */
a {
    color: #333;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* Responsividade */
@media (max-width: 768px) {
    .container {
        padding: 1rem;
    }

    .card-containers {
        padding: 0.5rem;
    }
    
    .card-flip {
        width: 100%;
        max-width: 450px;
    }

    .card-front,
    .card-back {
        padding: 2rem;
    }

    .nav-menu {
        width: 90%;
    }
}

@media (max-width: 480px) {
    .card-flip {
        width: 95%;
        max-width: none;
    }

    .card-front,
    .card-back {
        padding: 1.5rem;
    }
}


.sessao01 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: 80px;
    /* border: 1px solid black; */
    margin-left: 5%;
    margin-right: 5%;
    padding: 3%;
    text-align: center;
    margin-bottom: 100px;
}

.sessao01 h2 {
    width: 100%;
    font-size: 30px;
    margin: 0%;
    font-weight: bold;
    color: black;
    margin-bottom: 30px;
    text-transform: uppercase;

}

.sessao01 h4 {
    width: 100%;
    font-size: 20px;
    margin: 0%;
    font-weight: bold;
    color: black;
    margin-bottom: 5px;
    text-transform: uppercase;

}

.servicos {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: stretch;
}

.servicos h3 {
    text-transform: uppercase;
    font-size: 16px;
    color: black;
}



.card {
    display: inline-block;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 30%;
    padding: 20px;
    margin: 1%;
    border: 2px solid rgb(0, 0, 0);
    box-sizing: border-box;
    min-height: 300px;
    border-radius: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    margin-bottom: -100px;

}

.card:hover {
    background-color: black;
    color: white;
    border: none;
    transform: scale(1.05);
}

.card:hover h3 {
    color: white;
}

.card img {
    transition: opacity 0.3s ease;
    margin: 0 auto;
    width: 50px;
    /* Suaviza a transição de troca de imagem */
}

.card img.hover-icon {
    display: none;
    /* Esconde a imagem de hover por padrão */
}

.card:hover img.default-icon {
    display: none;
    /* Esconde a imagem padrão ao passar o mouse */
}

.card:hover img.hover-icon {
    display: block;
    /* Mostra a imagem de hover ao passar o mouse */
}

.sessionthree {
    padding: 20px;
}
.banner {
    text-align: center;
    padding: 20px;
    background-color: #ffffff;
}

.products {
    display: flex;
    justify-content: space-around;
    margin: 20px 0;
}
.product {
    text-align: center;
    max-width: 30%;
}
.product img {
    width: 80%;
    height: auto;
    border: 1px solid #ccc;
}
.product h3 {
    margin: 10px 0;
}
.product p {
    font-size: 14px;
    color: #555;
}

footer {
    text-align: center;
    padding: 10px;
    background: #ffffff;
    color: #333;
    font-size: 10px;
}
