/* Estilos gerais */

/* Reset básico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html {
    scroll-behavior: smooth;
}

body {
    font-family: "Poppins", sans-serif;
    margin: 0;
    padding: 0;
}


/* Navbar */
.navbar {
    background: white;
    padding: 30px 5%;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    position: sticky;
    top: 0;
    z-index: 1000;
}

/* Container */
.container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 1300px;
}

/* Logo */
.logo img {
    width: 100%;
}

/* Navegação */
.nav-links ul {
    list-style: none;
    display: flex;
    gap: 30px;
    margin: 0;
    padding: 0;
}

.nav-links ul li {
    position: relative;
}

.nav-links ul li a {
    text-decoration: none;
    color: #2E7D32;
    font-weight: 500;
    font-size: 1rem;
    transition: color 0.3s;
}

.nav-links ul li a:hover {
    color: #1B5E20;
}

/* Dropdown */
/* Esconder dropdown por padrão */
.dropdown-content {
    display: none;
    position: absolute;
    background: white;
    top: 100%;
    left: 0;
    min-width: 180px;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2);
    border-radius: 5px;
    padding: 10px 0;
    z-index: 999;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.dropdown:hover .dropdown-content {
    display: block;
    opacity: 1;
    transform: translateY(0);
}

.dropdown-content li {
    padding: 8px 15px;
}

.dropdown-content li a {
    color: #43A047;
    font-size: 0.9rem;
}

.dropdown-content li a:hover {
    color: #388E3C;
}

/* Botão "Parceiros" */
.btn-parceiros {
    background: #43A047;
    color: white;
    padding: 10px 20px;
    border-radius: 30px;
    font-weight: bold;
    text-decoration: none;
    transition: background 0.3s;
}

.btn-parceiros:hover {
    background: #388E3C;
}


/* Botão Hamburguer (Mobile) */
.menu-toggle {
    display: none;
    flex-direction: column;
    cursor: pointer;
}

.menu-toggle span {
    background: #003366;
    height: 3px;
    width: 30px;
    margin: 5px 0;
    transition: 0.3s;
}

/* Responsividade */
@media (max-width: 900px) {
    .container {
        flex-direction: row;
        justify-content: space-between;
    }

    /* Mostrar botão hamburguer */
    .menu-toggle {
        display: flex;
    }

    /* Esconder menu principal por padrão */
    .nav-links {
        display: none;
        position: absolute;
        top: 80px;
        left: 0;
        width: 100%;
        background-color: white;
        padding: 10px 0;
        box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
        flex-direction: column;
        text-align: center;
    }

    /* Mostrar menu quando ativado */
    .nav-links.active {
        display: flex;
    }

    .nav-links ul {
        flex-direction: column;
        gap: 10px;
    }

    .dropdown-content {
        position: static;
        width: 100%;
        text-align: center;
    }

    .parceiros {
        margin-top: 10px;
    }
}

/* Hero Section */
.hero {
    display: flex;
    align-items: center;
    justify-content: flex-start; /* Mantém o texto à esquerda */
    height: 100vh;
    background: url('../images/familia.jpg') no-repeat center center;
    background-size: cover;
    position: relative;
    color: white;
    padding: 0 10%; /* 🔥 Adicionado padding lateral para afastar o texto da borda */
}

/* 🔥 Adicionando um overlay para melhorar a legibilidade */
.hero::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); /* Ajuste de opacidade para melhor contraste */
}

/* Conteúdo da Hero */
.hero-content {
    max-width: 80%;
    position: relative;
    z-index: 10;
    opacity: 1 !important; /* 🔥 Testar se o texto fica visível */
    animation: fadeIn 1.5s forwards;
    padding-left: 20px; /* 🔥 Espaçamento extra para evitar que o texto encoste na borda */
}

/* Título */
.hero-content h1 {
    font-size: 2.5rem;
    font-weight: bold;
    margin-top: 15px;
    margin-bottom: 15px;
}

/* Parágrafo */
.hero-content p {
    font-size: 1.2rem;
    margin: 20px 0;
    opacity: 1;
    animation: slideUp 1.5s 0.5s forwards;
    line-height: 1.6;
}

/* Botão CTA */
.cta-button {
    display: inline-block;
    background: #43A047;
    color: white;
    padding: 14px 30px;
    font-size: 1.1rem;
    text-decoration: none;
    border-radius: 8px;
    transition: background 0.3s, transform 0.2s;
    margin-top: 20px;
    font-weight: bold;
}

.cta-button:hover {
    background: #388E3C;
    transform: scale(1.05);
}

/* 🔥 Esconder a imagem separada caso não seja necessária */
.hero-image {
    display: none;
}

/* 🔥 Responsividade para ecrãs menores */
@media (max-width: 1024px) {
    .hero {
        justify-content: center;
        text-align: center;
        padding: 0 5%;
    }

    .hero-content {
        max-width: 80%;
        padding-left: 0; /* 🔥 Remover padding extra para centralizar melhor */
    }

    .hero-content h1 {
        font-size: 2.5rem;
    }

    .hero-content p {
        font-size: 1rem;
    }
}

@media (max-width: 768px) {
    .hero-content h1 {
        font-size: 2rem;
    }

    .hero-content p {
        font-size: 0.9rem;
    }

    .cta-button {
        padding: 10px 20px;
        font-size: 1rem;
    }
}


/* Container principal */
.seguros-container {
    width: 90%;
    max-width: 1300px;
    margin: 80px auto; /* 🔥 Aumentei a margem superior e inferior */
    display: flex;
    flex-direction: column;
    gap: 80px; /* 🔥 Aumentei o espaçamento entre os seguros */
}

/* Estilos comuns aos blocos de seguros */
.seguro {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px; /* 🔥 Mais espaçamento interno */
    padding: 50px; /* 🔥 Mais preenchimento interno */
    border-radius: 15px; /* 🔥 Borda arredondada para um design mais moderno */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); /* 🔥 Sombra suave */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Efeito de destaque ao passar o mouse */
.seguro:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}

/* Texto */
.seguro-texto {
    flex: 1;
    max-width: 500px;
}

.seguro-texto h2 {
    font-size: 24px;
    color: #444;
    margin-bottom: 10px;
}

.seguro-texto p {
    font-size: 16px;
    color: #666;
    line-height: 1.5;
    margin-bottom: 20px;
}

/* Botão */
.botao {
    display: inline-block;
    padding: 12px 25px;
    font-size: 18px;
    border: 2px solid #333;
    background: transparent;
    color: #333;
    cursor: pointer;
    transition: 0.3s;
    border-radius: 8px; /* 🔥 Borda arredondada */
    font-weight: bold;
}

.botao:hover {
    background: #444;
    color: white;
}

/* Imagem */
.seguro-imagem {
    flex: 1;
    display: flex;
    justify-content: center;
}

.seguro-imagem img {
    width: 100%;
    max-width: 500px; /* 🔥 Maior impacto visual */
    border-radius: 20px; /* 🔥 Borda menos redonda para um visual mais elegante */
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.15);
}

/* Alternância de layout (imagem à esquerda) */
.invertido {
    flex-direction: row-reverse;
}

/* Responsividade */
@media (max-width: 1024px) {
    .seguro {
        flex-direction: column;
        text-align: center;
        padding: 40px; /* 🔥 Ajustei o padding */
    }

    .invertido {
        flex-direction: column;
    }

    .seguro-texto {
        max-width: 90%;
    }

    .seguro-imagem img {
        max-width: 90%;
    }
}

@media (max-width: 768px) {
    .seguro {
        padding: 30px;
    }

    .seguro-texto h2 {
        font-size: 22px;
    }

    .seguro-texto p {
        font-size: 16px;
    }

    .botao {
        padding: 10px 20px;
        font-size: 16px;
    }
}

/* Responsividade */
@media (max-width: 768px) {
    .hero {
        flex-direction: column;
        text-align: center;
        padding: 10% 5%;
    }

    .hero-content {
        max-width: 100%;
    }

    .hero-image img {
        margin-top: 20px;
    }

    .seguro {
        flex-direction: column !important;
        text-align: center;
        padding: 20px;
    }

    .seguro-texto, .seguro-imagem {
        width: 100%;
    }

    .seguro-imagem {
        margin-top: 20px;
    }
}

.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease-in-out;
}

/* Conteúdo do Modal */
.modal-content {
    background-color: #E8F5E9; /* Verde claro */
    padding: 30px;
    border-radius: 12px;
    width: 90%;
    max-width: 450px;
    text-align: center;
    position: relative;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

/* Título */
.modal-content h2 {
    font-size: 24px;
    color: #1B5E20; /* Verde escuro */
    margin-bottom: 10px;
}

/* Texto */
.modal-content p {
    font-size: 14px;
    color: #388E3C; /* Verde médio */
    margin-bottom: 20px;
}

/* Ícone de Fechar */
.close {
    position: absolute;
    top: 12px;
    right: 15px;
    font-size: 26px;
    font-weight: bold;
    color: #1B5E20;
    cursor: pointer;
    transition: color 0.3s;
}

.close:hover {
    color: #388E3C; /* Verde médio */
}

/* Grupos de Inputs */
.form-group {
    margin-bottom: 15px;
    text-align: left;
}

/* Labels */
.form-group label {
    display: block;
    font-size: 14px;
    font-weight: bold;
    color: #1B5E20;
    margin-bottom: 5px;
}

/* Inputs e Textarea */
input, textarea {
    width: 100%;
    padding: 12px;
    border: 2px solid #A5D6A7; /* Verde claro */
    border-radius: 8px;
    background: white;
    color: #1B5E20; /* Texto escuro */
    font-size: 16px;
}

input::placeholder, textarea::placeholder {
    color: #81C784; /* Verde mais claro */
    font-size: 14px;
}

/* Botão de Envio */
.botao {
    display: inline-block;
    padding: 6px 16px;
    font-size: 16px;
    border: 2px solid #1B5E20; /* Verde escuro */
    background: #2E7D32; /* Verde médio */
    color: white;
    cursor: pointer;
    transition: background 0.3s, transform 0.2s;
    border-radius: 8px;
    font-weight: bold;
    margin-top: 10px;
}

.botao:hover {
    background: #1B5E20; /* Verde mais escuro */
    color: #fff; /* Verde mais escuro */
    transform: scale(1.05);
}

/* Responsividade */
@media (max-width: 768px) {
    .modal-content {
        width: 95%;
        padding: 25px;
    }

    .modal-content h2 {
        font-size: 22px;
    }

    .botao {
        padding: 10px 20px;
        font-size: 14px;
    }
}

/* MODAL SEGURO MULTIRISCOS */
.modal-multiriscos {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
}

/* Conteúdo do Modal */
.modal-multiriscos-content {
    background-color: #E8F5E9;
    padding: 30px;
    border-radius: 12px;
    width: 90%;
    max-width: 650px; /* 🔥 Modal mais esticado */
    text-align: center;
    position: relative;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

/* Fechar Modal */
.modal-multiriscos-close {
    position: absolute;
    top: 12px;
    right: 15px;
    font-size: 26px;
    font-weight: bold;
    color: #1B5E20;
    cursor: pointer;
    transition: color 0.3s;
}

.modal-multiriscos-close:hover {
    color: #388E3C;
}

/* Layout para campos lado a lado */
.modal-multiriscos-row {
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.modal-multiriscos-group {
    position: relative;
    margin-bottom: 20px;
    text-align: left;
    flex: 1;
}

/* Labels flutuantes */
.modal-multiriscos-group label {
    position: absolute;
    top: 50%;
    left: 12px;
    transform: translateY(-50%);
    font-size: 16px;
    color: #1B5E20;
    transition: 0.3s ease all;
    pointer-events: none;
    background: white;
    padding: 0 5px;
}

/* Inputs, Textarea */
.modal-multiriscos-group input,
.modal-multiriscos-group textarea {
    width: 100%;
    padding: 14px;
    border: 2px solid #A5D6A7;
    border-radius: 8px;
    background: white;
    color: #1B5E20;
    font-size: 16px;
    outline: none;
}

/* Animação das labels ao clicar */
.modal-multiriscos-group input:focus ~ label,
.modal-multiriscos-group input:valid ~ label,
.modal-multiriscos-group textarea:focus ~ label,
.modal-multiriscos-group textarea:valid ~ label {
    top: 5px;
    font-size: 12px;
    color: #388E3C;
}

/* Checkbox */
.checkbox-group {
    display: flex;
    align-items: center;
    text-align: left;
    gap: 10px; /* 🔥 Maior espaçamento */
}

.checkbox-group input {
    width: auto;
}

.checkbox-label {
    font-size: 14px;
    color: #1B5E20;
}

/* Botão */
.modal-multiriscos-botao {
    display: inline-block;
    padding: 12px 25px;
    font-size: 16px;
    border: 2px solid #1B5E20;
    background: #2E7D32;
    color: white;
    cursor: pointer;
    transition: background 0.3s, transform 0.2s;
    border-radius: 8px;
    font-weight: bold;
    margin-top: 15px;
    width: 100%;
}

.modal-multiriscos-botao:hover {
    background: #1B5E20;
    transform: scale(1.05);
}

/* Responsividade */
@media (max-width: 768px) {
    .modal-multiriscos-content {
        width: 95%;
        padding: 25px;
    }

    .modal-multiriscos-row {
        flex-direction: column; /* 🔥 Em mobile, os campos ficam um abaixo do outro */
    }

    .modal-multiriscos-botao {
        padding: 10px 20px;
        font-size: 14px;
    }
}

/* MODAL SEGURO VIDA CRÉDITO */
.modal-vida-habitacao {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
}

/* Conteúdo do Modal */
.modal-vida-content {
    background-color: #E8F5E9;
    padding: 30px;
    border-radius: 12px;
    width: 90%;
    max-width: 650px;
    text-align: center;
    position: relative;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

/* Fechar Modal */
.modal-vida-close {
    position: absolute;
    top: 12px;
    right: 15px;
    font-size: 26px;
    font-weight: bold;
    color: #1B5E20;
    cursor: pointer;
    transition: color 0.3s;
}

.modal-vida-close:hover {
    color: #388E3C;
}

/* Layout dos campos */
.modal-vida-row {
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.modal-vida-group {
    flex: 1;
    margin-bottom: 15px;
    text-align: left;
}

.modal-vida-group label {
    font-size: 14px;
    font-weight: bold;
    color: #1B5E20;
    margin-bottom: 5px;
    display: block;
}

/* Inputs */
.modal-vida-group input {
    width: 100%;
    padding: 12px;
    border: 2px solid #A5D6A7;
    border-radius: 8px;
    background: white;
    color: #1B5E20;
    font-size: 16px;
    outline: none;
}

/* Inputs somente leitura */
.modal-vida-group input[readonly] {
    background: #F1F8E9;
    font-weight: bold;
}

/* Botão */
.modal-vida-botao {
    display: inline-block;
    padding: 12px 25px;
    font-size: 16px;
    border: 2px solid #1B5E20;
    background: #2E7D32;
    color: white;
    cursor: pointer;
    transition: background 0.3s, transform 0.2s;
    border-radius: 8px;
    font-weight: bold;
    margin-top: 15px;
    width: 100%;
}

.modal-vida-botao:hover {
    background: #1B5E20;
    transform: scale(1.05);
}

/* Responsividade */
@media (max-width: 768px) {
    .modal-vida-content {
        width: 95%;
        padding: 25px;
    }

    .modal-vida-row {
        flex-direction: column;
    }

    .modal-vida-botao {
        padding: 10px 20px;
        font-size: 14px;
    }
}

/* Estilo do Simulador de Poupança */
.simulador-poupanca {
    background-color: #1B5E20; /* Verde escuro */
    color: white;
    padding: 30px;
    text-align: center;
    border-radius: 10px;
}

/* Título */
.simulador-poupanca h2 {
    font-size: 22px;
    margin-bottom: 20px;
}

/* Layout responsivo */
.simulador-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 900px;
    margin: 0 auto;
}

/* Grupo de inputs */
.simulador-group {
    text-align: left;
}

/* Labels */
.simulador-group label {
    display: block;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}

/* Inputs */
.simulador-group input {
    width: 100%;
    padding: 10px;
    border: 2px solid #A5D6A7;
    border-radius: 5px;
    font-size: 16px;
    color: #1B5E20;
}

/* Inputs somente leitura */
.simulador-group input[readonly] {
    background: #F1F8E9;
    font-weight: bold;
}

/* Responsividade */
@media (max-width: 768px) {
    .simulador-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .simulador-grid {
        grid-template-columns: 1fr;
    }
}

/* Estilo do Simulador de Crédito */
.simulador-credito {
    background-color: #1B5E20; /* Verde escuro */
    color: white;
    padding: 30px;
    text-align: center;
    border-radius: 10px;
}

.simulador-credito h2 {
    font-size: 22px;
    margin-bottom: 20px;
}

.simulador-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 900px;
    margin: 0 auto;
}

.simulador-group {
    text-align: left;
}

.simulador-group label {
    display: block;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}

.simulador-group input {
    width: 100%;
    padding: 10px;
    border: 2px solid #A5D6A7;
    border-radius: 5px;
    font-size: 16px;
    color: #1B5E20;
}

.simulador-group input[readonly] {
    background: #F1F8E9;
    font-weight: bold;
}

@media (max-width: 768px) {
    .simulador-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .simulador-grid {
        grid-template-columns: 1fr;
    }
}


/* Footer */
.footer {
    background-color: #1B5E20; /* Verde escuro */
    padding: 50px 10%;
    color: white;
}

.footer-container {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 40px;
}

/* Colunas do footer */
.footer-col {
    flex: 1;
    min-width: 250px;
}

.footer-col p {
    color: #A5D6A7; /* Verde claro */
    font-size: 14px;
    margin-bottom: 10px;
}

.footer-col ul {
    list-style: none;
    padding: 0;
}

.footer-col ul li {
    margin-bottom: 8px;
}

.footer-col ul li a {
    text-decoration: none;
    color: #C8E6C9; /* Verde mais claro */
    font-size: 14px;
    transition: color 0.3s;
}

.footer-col ul li a:hover {
    color: #E8F5E9; /* Tom mais claro ao passar o mouse */
}

/* Logo */
.logo {
    width: 200px;
}

/* Botão "AQUI" */
.botao-seguros {
    display: inline-block;
    padding: 12px 25px;
    font-size: 16px;
    border: 2px solid #1B5E20; /* Verde claro */
    background: transparent;
    color: #1B5E20;
    cursor: pointer;
    transition: 0.3s;
    border-radius: 8px;
    font-weight: bold;
    margin-top: 15px;
}

.botao-seguros:hover {
    background: #fff;
    color: #1B5E20; /* Verde escuro */
}

/* Ícones das redes sociais */
.social-icons {
    margin-top: 15px;
}

.social-icons a {
    text-decoration: none;
    font-size: 20px;
    color: #C8E6C9;
    margin-right: 15px;
    transition: color 0.3s;
}

.social-icons a:hover {
    color: #E8F5E9; /* Verde ainda mais claro */
}

/* Linha inferior no footer */
.footer-bottom {
    text-align: center;
    padding-top: 20px;
    font-size: 14px;
    color: #A5D6A7;
    border-top: 1px solid #2E7D32; /* Linha separadora verde médio */
    margin-top: 30px;
}

/* Responsividade */
@media (max-width: 768px) {
    .footer-container {
        flex-direction: column;
        text-align: center;
    }

    .social-icons {
        justify-content: center;
    }
}
