/* Variáveis de Cor baseadas no pedido e design */
:root {
    --bg-color: #0c0c0c;
    --text-color: #fafafa;
    --gold-accent: #a89278; /* Tom aproximado do logo */
    --gold-gradient: linear-gradient(90deg, #8a735a, #c4ae95);
    --card-bg: #121212;
    --input-bg: transparent;
    --border-color: #333;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Nunito Sans', sans-serif; /* Atualizado para Nunito Sans */
}

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    line-height: 1.6;
    overflow-x: hidden;
}

a {
    text-decoration: none;
    color: var(--text-color);
    transition: 0.3s;
}

/* --- Navbar: Base e Efeito Scroll --- */
.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center; /* Centra os links verticalmente */
    padding: 0 5%;
    height: 70px; /* Fixamos a altura da barra para criar o limite do fundo */
    position: fixed; 
    width: 100%;
    top: 0;
    z-index: 999;
    background: transparent; /* No topo, é transparente */
    transition: background 0.4s ease, backdrop-filter 0.4s ease;
}

/* Classe que será ativada via JavaScript quando deres scroll */
.navbar.scrolled {
    background: rgba(0, 0, 0, 0.5); /* Preto 50% transparente */
    backdrop-filter: blur(10px); /* Efeito Glassmorphism */
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05); /* Um brilho subtil para definir a barra */
}

/* --- Links da Nav --- */

/* --- ESTRUTURA GLOBAL DA NAV --- */
.nav-menu {
    display: flex;
    width: 100%;
    justify-content: space-between;
}

/* --- MENU HAMBURGER (Baseado no teu código) --- */
.menu-checkbox {
    display: none; /* Esconde sempre a caixa de seleção real */
}

.hamburger {
    display: none; /* Escondido no desktop */
    flex-direction: column;
    width: 32px; /* Reduzido para caber bem na navbar */
    cursor: pointer;
    position: absolute;
    right: 5%;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1001; /* Fica acima do menu quando ele abre */
}

.hamburger span {
    background: var(--text-color);
    border-radius: 10px;
    height: 3px; /* Espessura mais fina e elegante */
    margin: 4px 0;
    transition: .4s cubic-bezier(0.68, -0.6, 0.32, 1.6);
}

.hamburger span:nth-of-type(1) { width: 50%; }
.hamburger span:nth-of-type(2) { width: 100%; }
.hamburger span:nth-of-type(3) { width: 75%; }

/* Animação Hamburger ao Clicar (Valores adaptados para o novo tamanho) */
.menu-checkbox:checked ~ .hamburger span:nth-of-type(1) {
    transform-origin: bottom;
    transform: rotatez(45deg) translate(5px, 0px);
}
.menu-checkbox:checked ~ .hamburger span:nth-of-type(2) {
    transform-origin: top;
    transform: rotatez(-45deg);
}
.menu-checkbox:checked ~ .hamburger span:nth-of-type(3) {
    transform-origin: bottom;
    width: 50%;
    transform: translate(14px, -6px) rotatez(45deg);
}

.nav-links {
    list-style: none;
    display: flex;
    gap: 5rem; 
    flex: 1;
    margin-top: 0; /* Removido para ficarem bem centrados nos 80px da barra */
}

.left-links {
    justify-content: flex-end;
    margin-right: 10rem; /* Aumentado para o texto não ficar por trás do logo gigante */
}

.right-links {
    justify-content: flex-start;
    margin-left: 10rem; 
}

.nav-links a {
    font-size: 0.9rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.nav-links a.active, .nav-links a:hover {
    color: var(--gold-accent);
}

/* --- Logo "A Sair" da Barra --- */
.logo-container {
    position: absolute; /* Desprende o logótipo da barra */
    left: 50%;
    transform: translateX(-50%); /* Centra exatamente ao meio do ecrã */
    top: 5px; /* Distância do topo do ecrã */
    z-index: 1000;
}

.logo-container .logo {
    height: 120px; /* Como a barra tem 80px, o logo passa para baixo, criando o efeito da tua imagem! */
    object-fit: contain;
    filter: drop-shadow(0px 4px 6px rgba(0,0,0,0.5)); /* Sombreado para destacar a parte que sai da barra */
}

/* --- EFEITO DE HOVER GLOBAL (Para todos os botões .btn-gold) --- */
.btn-gold {
    display: inline-block;
    background: var(--gold-gradient);
    color: var(--bg-color);
    padding: 12px 30px;
    border-radius: 25px;
    font-weight: 600;
    font-size: 0.9rem;
    border: none;
    cursor: pointer;
    text-align: center;
    
    /* Transição suave para a escala */
    transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), background 0.3s;
    backface-visibility: hidden;
}

/* --- HOVER GLOBAL SUAVE --- */
.btn-gold:hover {
    /* Escala limpa sem conflito com keyframes de movimento */
    transform: scale(1.1) !important;
    opacity: 1;
    cursor: pointer;
}

/* Aplicar o mesmo efeito ao botão "Quero fazer parte" se ele tiver uma classe diferente */
.fizzy-button:hover, .btn-mini:hover {
    transform: scale(1.05);
    transition: transform 0.3s ease;
}

/* Hero Section */
.hero {
    position: relative;
    height: 100vh;
    display: flex;
    align-items: center;
    padding: 0 5%;
    overflow: hidden;
}

.bg-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: -2;
    transform: translateX(-50%) translateY(-50%);
    object-fit: cover;
}

.overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(12, 12, 12, 0.742);
    z-index: -1;
}

.hero-content {
    display: flex;
    justify-content: space-between;
    width: 100%;
    align-items: center;
    margin-top: 80px;
}

.hero-text {
    max-width: 50%;
}

.hero-text h1 {
    font-size: 3rem;
    margin-bottom: 2rem;
    line-height: 1.2;
}

/* Hero Stats - Localização das propriedades */
.hero-stats {
    display: flex;
    flex-direction: column; /* MUDA PARA 'row' SE QUISERES LADO A LADO */
    gap: 2rem;               /* ESPAÇO ENTRE OS DOIS STATS */
    text-align: center;
    margin-right: 8%;      /* DISTÂNCIA DA DIREITA (CONTROLAR POSIÇÃO HORIZONTAL) */
}

.stat h2 {
    font-size: 5.5rem;     /* TAMANHO DOS NÚMEROS (+300, +50) */
    color: var(--text-color);
    font-weight: 700;
    line-height: 1;
}

.stat p {
    font-size: 2.1rem;      /* TAMANHO DO TEXTO (CRÉDITOS, IMÓVEIS) */
    font-weight: 600;
    /* ABAIXO ESTÁ A COR EM GRADIENTE */
    background: var(--gold-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

/* --- Atualização Secção Quem Somos --- */

.quem-somos {
    position: relative;
    height: 100vh; /* Altura total do ecrã, igual ao Hero */
    display: flex;
    align-items: center;
    padding: 0 5%;
    overflow: hidden;
}

/* Forçar o vídeo a comportar-se como o do Hero */
.quem-somos .bg-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: -2; /* Fica atrás do conteúdo */
    transform: translate(-50%, -50%);
    object-fit: cover;
    opacity: 1 !important; /* Garante visibilidade total */
}

/* --- Atualização Secção Quem Somos --- */

.quem-somos {
    position: relative;
    height: 100vh; /* Ocupa 100% da altura do ecrã, igual ao Hero */
    display: flex;
    align-items: center;
    padding: 0 5%;
    overflow: hidden;
    background-color: transparent; /* Remove qualquer cor de fundo */
}

/* O vídeo passa a usar as mesmas propriedades do vídeo do Hero */
.quem-somos .bg-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: -2;
    transform: translateX(-50%) translateY(-50%);
    object-fit: cover;
    opacity: 1 !important; /* Força a visibilidade total, ignorando a classe video-opacidade */
    display: block !important; /* Garante que não é escondido acidentalmente */
}

/* --- Atualização Secção Quem Somos --- */

.quem-somos {
    position: relative;
    height: 100vh; /* Ocupa 100% da altura do ecrã */
    width: 100%;   /* Ocupa 100% da largura */
    display: flex;
    align-items: center;
    padding: 0 5%;
    overflow: hidden; /* Corta qualquer excesso para não gerar barras de scroll */
}

/* Nova forma mais limpa de preencher o ecrã com o vídeo */
.quem-somos .bg-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Faz o vídeo preencher a caixa perfeita sem distorcer */
    transform: none; /* Removemos o transform que estava a deslocar o vídeo */
    opacity: 1 !important; /* Visibilidade total */
    z-index: -2;
}

/* Esconde APENAS a div de fundo preto */
.quem-somos .overlay {
    display: none !important; 
}

/* Mantemos a caixa de texto exatamente onde estava */
.quem-somos-content {
    width: 100%;
    z-index: 1;
}

.quem-somos-content .text-box {
    max-width: 500px;
    background: rgba(12, 12, 12, 0.7); /* Fundo leve para o texto não se perder no vídeo */
    padding: 2rem;
    border: 1px solid var(--border-color);
    border-radius: 10px;
}

.quem-somos h2 {
    font-size: 1.5rem;
    color: var(--text-color);
    margin-bottom: 1.5rem;
}

.quem-somos p {
    margin-bottom: 1rem;
    font-size: 0.95rem;
    color: #ccc;
}

/* --- Efeito Marquee / Letreiro --- */
.marquee-section {
    width: 100%;
    overflow: hidden;
    /* Aumentei o 3º valor de 20px para 80px. É este valor que controla o espaço em baixo! */
    padding: 60px 0 100px 0; 
    background: var(--bg-color);
    display: flex;
}

.marquee-track {
    display: flex;
    white-space: nowrap;
    animation: scrollMarquee 20s linear infinite; /* 20s é a velocidade, podes ajustar */
}

.marquee-text {
    font-size: 130px; 
    font-weight: 800;
    text-transform: uppercase;
    padding-right: 20px; 
    word-spacing: -25px; 
    letter-spacing: 8px; /* Dá um pequeno respiro entre as letras gigantes */
    
    /* O TRUQUE PARA LETRAS VAZADAS PERFEITAS (DESKTOP) */
    color: var(--bg-color); /* Pinta o interior com a cor do fundo */
    -webkit-text-stroke: 0; /* Desliga o contorno com defeito */
    
    /* Cria um contorno perfeito de 2px usando sombras fundidas */
    text-shadow:
        -2px -2px 0 var(--border-color),
         2px -2px 0 var(--border-color),
        -2px  2px 0 var(--border-color),
         2px  2px 0 var(--border-color);
}

/* Animação que faz o texto deslizar para a esquerda continuamente */
@keyframes scrollMarquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); } 
}

/* Reduzir o tamanho do marquee em mobile para não desformatar */
@media (max-width: 768px) {
    .marquee-text {
        font-size: 60px;
    }
}

/* Equipa Section */
.equipa-section {
    padding: 80px 5%;
    position: relative;
    text-align: center;
}

.bg-text {
    position: absolute;
    top: 10px;
    left: 0;
    width: 100%;
    font-size: 8rem;
    color: rgba(255, 255, 255, 0.03);
    white-space: nowrap;
    z-index: -1;
    overflow: hidden;
}

.equipa-intro {
    max-width: 800px;
    margin: 0 auto 50px auto;
    color: #ccc;
}

.equipa-grid {
    display: flex;
    justify-content: center;
    gap: 30px;
    align-items: flex-end;
}

/* --- ESTILO DOS CARTÕES DE EQUIPA (Todos Iguais) --- */
.membro {
    background: var(--card-bg);
    border-radius: 10px;
    overflow: hidden;
    width: 320px;
    height: 440px;
    position: relative;
    border: 1px solid var(--border-color); /* Todos têm a mesma borda subtil agora */
    
    /* TRUQUE PARA CORRIGIR O BUG DOS CANTOS CORTADOS NO HOVER */
    transform: translateZ(0); /* Força a aceleração de hardware */
    -webkit-mask-image: -webkit-radial-gradient(white, black); /* Força o Safari/Chrome a não ignorar o border-radius */
}

.membro img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.membro-hover-info {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%; 
    background: linear-gradient(to top, rgba(12,12,12,1) 0%, rgba(12,12,12,0.9) 70%, transparent 100%);
    display: flex;
    align-items: flex-end;
    padding: 20px;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    text-align: left;
}

/* Quando passas o rato (Desktop) OU quando tocas (Mobile) */
.membro:hover .membro-hover-info,
.membro.ativo .membro-hover-info {
    transform: translateY(0);
}

.membro:hover img,
.membro.ativo img {
    transform: scale(1.05);
}

.membro.destaque {
    /* Mantém as dimensões e adiciona a borda dourada */
    width: 320px;
    height: 440px;
    border: 1px solid var(--gold-accent);
}

.membro-info h3 {
    color: var(--gold-accent);
    font-size: 1.2rem;
    margin-bottom: 5px;
}

.membro-info p {
    font-size: 0.9rem;
    color: #ccc;
}

/* --- PORQUÊ TRABALHAR CONNOSCO (Caixas Corrigidas e Ícones Relevantes) --- */
.why-section {
    padding: 100px 5% 150px 5%; 
    text-align: center;
    background-color: var(--bg-color); /* Fundo preto/escuro */
}

/* Título com a fonte Montserrat e bold */
.why-section h2 {
    font-family: 'Montserrat', sans-serif; 
    font-size: 2.5rem;
    color: var(--text-color);
    margin-bottom: 70px;
    font-weight: 700;
}

.why-container {
    display: flex;
    justify-content: center;
}

/* GRID Moderna para organizar as 6 caixas de forma responsiva */
.why-cards {
    display: grid;
    /* Tenta colocar até 3 colunas de no mínimo 320px, adaptando ao espaço */
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); 
    gap: 40px; /* Espaço entre as caixas */
    max-width: 1200px; /* Largura máxima da secção */
    width: 100%;
}

.why-card {
    border: 1px solid #444; /* ADICIONADO: Borda à volta da caixa */
    border-radius: 20px;
    padding: 30px;
    transition: 0.3s ease;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: transparent; 
}

/* Pequeno efeito no hover para interação */
.why-card:hover {
    transform: translateY(-5px);
    background-color: rgba(168, 146, 120, 0.05); /* Fundo dourado muito subtil */
}

/* ESTILO PARA OS NOVOS ÍCONES SVG MODERNOS (Integrated) */
.why-icon-svg {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 25px;
    /* Removido o background-color branco e o border-radius */
}

/* Estilo do ícone em si */
.why-icon-svg svg {
    width: 60px; /* Tamanho do ícone */
    height: 60px;
    color: var(--gold-accent); /* Cor dourada do tema */
    transition: 0.3s ease;
}

/* O ícone apenas cresce ao passar o rato no card (sem tilt) */
.why-card:hover .why-icon-svg svg {
    transform: scale(1.15); /* Removido o rotate, aumentado o scale para um efeito suave */
}

.why-card h3 {
    font-size: 1.4rem;
    color: var(--text-color);
    margin-bottom: 15px;
    font-weight: 600;
}

.why-card p {
    font-size: 0.95rem;
    color: #aaa; /* Um cinza mais suave */
    line-height: 1.6;
}

/* CTA Section */
.cta-section {
    padding: 60px 5%;
}

.cta-box {
    background: linear-gradient(180deg, rgba(20,20,20,1) 0%, rgba(12,12,12,1) 100%);
    border: 1px solid #333;
    border-radius: 15px;
    padding: 50px;
    text-align: center;
}

.cta-box h2 {
    font-size: 2rem;
    margin-bottom: 10px;
}

.cta-box p {
    color: #aaa;
    margin-bottom: 30px;
}

.cta-buttons {
    display: flex;
    justify-content: center;
    gap: 20px;
}

/* Recrutamento Section */
.recrutamento-section {
    padding: 80px 5%;
}

.recrutamento-container {
    display: flex;
    background: var(--card-bg);
    border-radius: 15px;
    overflow: hidden;
    border: 1px solid #222;
}

.recrutamento-container .img-box {
    flex: 1;
}

.recrutamento-container .img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.recrutamento-container .text-box {
    flex: 1;
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.recrutamento-container h2 {
    font-size: 2rem;
    margin-bottom: 20px;
}

.recrutamento-container p {
    color: #ccc;
    margin-bottom: 20px;
    font-size: 0.95rem;
}

/* --- PÁGINA CONTACTOS --- */

.contact-page {
    padding-top: 150px;
    padding-bottom: 80px;
    padding-left: 5%;
    padding-right: 5%;
}

.contact-header {
    margin-top: 100px; /* ADICIONA ESTA LINHA: Aumenta para 80px ou 100px para descer mais */
    margin-bottom: 50px;
}

.contact-header h1 {
    font-size: 2.5rem;
    color: var(--gold-accent);
    margin-bottom: 15px;
}

.contact-header p {
    font-size: 1.1rem;
    color: #ccc;
}

.contact-container {
    display: flex;
    gap: 50px;
}

.contact-form-section {
    flex: 1;
    margin-top: 50px; /* ADICIONA ESTA LINHA: Aumenta este valor se quiseres que desça ainda mais */
}

.contact-info-section {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin-top: -200px;
}

/* Formulário */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-size: 0.9rem;
    color: var(--text-color);
}

/* Estilo comum para Inputs e Textarea */
.form-group input,
.form-group textarea {
    width: 100%;
    background: var(--input-bg);
    border: 1px solid #444;
    border-radius: 25px;
    padding: 12px 20px;
    color: var(--text-color);
    font-size: 0.9rem;
    outline: none;
    transition: 0.3s;
}


/* CAIXA DE SELEÇÃO MAIS BONITA (Integrated Select Style) */
.form-group select {
    width: 100%;
    background-color: #1a1a1a; 
    border: 1px solid #444;
    
    /* CANTOS ARREDONDADOS AQUI (Forçados para garantir) */
    border-radius: 25px !important; 
    
    padding: 14px 20px; 
    color: var(--text-color);
    font-size: 0.9rem;
    outline: none;
    transition: 0.3s;
    cursor: pointer;

    /* Esconder setas e estilos feios do navegador */
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;

    /* Seta minimalista dourada */
    background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23a89278"><path d="M7 10l5 5 5-5z"/></svg>');
    background-repeat: no-repeat;
    background-position: right 18px center; 
    background-size: 18px; 
    padding-right: 45px; 
}

/* Tenta forçar as cores na lista de opções (funciona em alguns browsers) */
.form-group select option {
    background-color: #1a1a1a; 
    color: var(--text-color);
    padding: 10px;
}

/* Estilo para a opção placeholder ("Selecione uma opção...") */
.form-group select option[value=""][disabled] {
    color: #777;
}

.form-group textarea {
    border-radius: 15px;
    resize: vertical;
}

.form-group input:focus, 
.form-group select:focus, 
.form-group textarea:focus {
    border-color: var(--gold-accent);
}

/* --- Checkboxes Personalizadas Lado a Lado --- */
.checkbox-group {
    display: flex;
    flex-direction: row; 
    flex-wrap: wrap;     
    gap: 10px;           /* REDUZIDO: de 30px para 10px para ganhar espaço */
    margin-bottom: 25px;
}

.checkbox-group label {
    display: flex;
    align-items: center; 
    font-size: 0.75rem;  /* REDUZIDO: Letra um pouco mais pequena para caberem as duas */
    color: #aaa;
    cursor: pointer;
    margin-bottom: 0;
}

/* Esconder a checkbox normal e desenhar a nova */
.checkbox-group input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid #555;
    border-radius: 4px;
    margin-right: 10px; /* Distância entre a caixa e o texto */
    background-color: transparent;
    cursor: pointer;
    display: grid;
    place-content: center;
    transition: 0.3s ease;
    flex-shrink: 0; /* Impede a caixa de encolher */
}

/* Quando passa o rato */
.checkbox-group input[type="checkbox"]:hover {
    border-color: var(--gold-accent);
}

/* Quando está selecionada (Checked) */
.checkbox-group input[type="checkbox"]:checked {
    background-color: var(--gold-accent);
    border-color: var(--gold-accent);
}

/* Desenhar o V (Checkmark) invisível */
.checkbox-group input[type="checkbox"]::before {
    content: "";
    width: 10px;
    height: 10px;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    background-color: var(--bg-color);
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

/* Mostrar o V quando selecionado */
.checkbox-group input[type="checkbox"]:checked::before {
    transform: scale(1);
}

/* Info Contactos */
.contact-logo {
    width: 250px;
    align-self: center;
    margin-bottom: 20px;
}

.info-details {
    text-align: center;
}

.info-details h3 {
    font-size: 1rem;
    color: var(--text-color);
    margin-bottom: 5px;
}

.info-details p {
    font-size: 0.9rem;
    color: #aaa;
}

.info-item.central {
    margin-bottom: 20px;
}

.info-row {
    display: flex;
    justify-content: space-around;
}

/* Footer Global */
.footer {
    padding: 60px 5% 20px;
    background: var(--bg-color);
}

.footer.border-top {
    border-top: 1px solid #222;
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-bottom: 40px;
}

.footer-col h4 {
    font-size: 0.8rem;
    color: var(--text-color);
    margin-bottom: 15px;
    letter-spacing: 1px;
}

.footer-col p, .footer-col a {
    color: #888;
    font-size: 0.85rem;
    line-height: 2;
}

.footer-col a:hover {
    color: var(--gold-accent);
}

.footer-col ul {
    list-style: none;
}

.social-col {
    display: flex;
    gap: 30px; /* Aumenta o espaço entre os ícones para ficarem como na imagem */
    align-items: center; /* Centra os ícones verticalmente em relação ao texto das outras colunas */
    justify-content: center; /* Mantém-nos no centro da coluna deles */
    height: 100%; /* Garante que ocupam a altura total disponível para o alinhamento perfeito */
}

.social-icon {
    width: 40px; /* Aumenta o tamanho dos ícones (antes estava 24px) */
    height: 40px;
    opacity: 0.6;
    transition: 0.3s;
}

.social-icon:hover {
    opacity: 1;
}

.footer-bottom {
    text-align: center;
    border-top: 1px solid #222;
    padding-top: 20px;
    font-size: 0.75rem;
    color: #666;
}

/* ========================================= */
/* --- RESPONSIVO PARA LAPTOPS (Até 1440px) - */
/* ========================================= */
@media (max-width: 1440px) {
    
    /* --- 1. NAVBAR (O "Buraco" perfeito para o logótipo) --- */
    .nav-links { 
        gap: 2rem; /* Reduz ligeiramente o espaço entre Início <-> Contactos */
    }
    .left-links { 
        margin-right: 7rem; /* Abre um espaço de segurança à esquerda do logo */
    }
    .right-links { 
        margin-left: 7rem; /* Abre um espaço de segurança à direita do logo */
    }
    
    .logo-container .logo { 
        height: 120px; /* Mantemos o tamanho luxuoso do logo */
    }

    /* --- 2. HERO E CONTEÚDO --- */
    .hero-text h1 {
        font-size: 2.8rem; /* Mantém a grandiosidade da letra */
    }
    
    /* --- 3. EQUIPA --- */
    .equipa-grid {
        gap: 20px; 
    }
    .membro {
        width: 320px; 
    }
}

/* ========================================= */
/* --- RESPONSIVO PARA TABLETS E LAPTOPS --- */
/* ========================================= */
@media (max-width: 1024px) {
    
    /* --- 1. NAVBAR (Menu Hamburguer ativado mais cedo) --- */
    .hamburger { display: flex; }
    .logo-container .logo { height: 90px; } 

    .nav-menu {
        position: fixed;
        top: 0; 
        left: 0;
        width: 100%;
        height: 100vh; 
        background: rgba(12, 12, 12, 0.98); 
        backdrop-filter: blur(15px);
        -webkit-backdrop-filter: blur(15px);
        
        /* FORÇAR CENTRO VERTICAL E HORIZONTAL */
        display: flex !important;
        flex-direction: column !important; 
        justify-content: center !important; 
        align-items: center !important;
        
        padding-top: 0 !important; /* Remove o empurrão de 160px que tinhas */
        transform: translateX(100%);
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        z-index: 998; 
    }

    .menu-checkbox:checked ~ .nav-menu {
        transform: translateX(0);
    }

    /* Ajuste das listas para não herdarem margens do desktop */
    .nav-links {
        display: flex !important; 
        flex-direction: column !important;
        gap: 2.5rem !important; /* Espaço entre links */
        text-align: center !important;
        margin: 0 !important; 
        padding: 0 !important;
        width: auto !important;
        flex: none !important; /* Remove o 'flex: 1' que estica a lista */
    }

    .left-links {
        margin-bottom: 2.5rem !important; /* Tem de ser IGUAL ao gap definido acima */
    }

    .right-links {
        margin-left: 0 !important;
        margin-top: 0 !important;
    }

    .nav-links li {
        list-style: none;
        width: 100%;
    }

    .nav-links a {
        font-size: 1.8rem !important;
        font-weight: 600;
        letter-spacing: 2px;
        display: block;
    }

    /* --- 2. HERO --- */
    .hero-content { 
        flex-direction: column; 
        text-align: center; 
        gap: 40px; 
        margin-top: 0; 
    }
    .hero-text { 
        max-width: 90%; 
        margin: 0 auto; 
    }
    .hero-text h1 { 
        font-size: 2.5rem; 
    }
    .hero-stats { 
        flex-direction: row; 
        justify-content: center; 
        width: 100%; 
        margin-right: 0; 
        gap: 50px;
    }

    /* --- 3. EQUIPA --- */
    .equipa-grid { 
        flex-wrap: wrap; 
        justify-content: center; 
    }

    /* --- 4. RECRUTAMENTO --- */
    .recrutamento-container { 
        flex-direction: column; 
    }
    .recrutamento-container .img-box {
        height: 300px; 
    }
    .recrutamento-container .text-box { 
        padding: 40px; 
        align-items: center; 
        text-align: center; 
    }

    /* --- 5. FOOTER --- */
    .footer-grid { 
        grid-template-columns: repeat(2, 1fr); 
        gap: 40px; 
    }

    /* --- 6. PÁGINA DE CONTACTOS --- */
    .contact-container { 
        flex-direction: column; 
        gap: 60px;
    }
    .contact-form-section {
        margin-top: 0;
    }
    .contact-info-section { 
        margin-top: 0; 
    }
    .map-container iframe {
        width: 100% !important; 
    }

    
}

/* AJUSTES MOBILE */
@media (max-width: 768px) {
    /* 1. Ativa o botão hamburguer e ajusta o logo */
    .hamburger { display: flex; }
    .logo-container .logo { height: 90px; } /* Logo ligeiramente menor no telemóvel */

    /* 2. Transforma o contentor num ecrã escuro que ocupa TUDO */
    .nav-menu {
        position: fixed;
        top: 0; 
        left: 0;
        width: 100%;
        height: 100vh; 
        background: rgba(12, 12, 12, 0.98); 
        backdrop-filter: blur(15px);
        -webkit-backdrop-filter: blur(15px);
        
        /* FORÇAR CENTRO VERTICAL E HORIZONTAL */
        display: flex !important;
        flex-direction: column !important; 
        justify-content: center !important; 
        align-items: center !important;
        
        padding-top: 0 !important; /* Remove o empurrão de 160px que tinhas */
        transform: translateX(100%);
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        z-index: 998; 
    }

    /* 3. Quando a checkbox for clicada, o menu entra no ecrã! */
    .menu-checkbox:checked ~ .nav-menu {
        transform: translateX(0);
    }

    /* Ajuste das listas para não herdarem margens do desktop */
    .nav-links {
        display: flex !important; 
        flex-direction: column !important;
        gap: 2.5rem !important; /* Espaço entre links */
        text-align: center !important;
        margin: 0 !important; 
        padding: 0 !important;
        width: auto !important;
        flex: none !important; /* Remove o 'flex: 1' que estica a lista */
    }

    .left-links {
        margin-bottom: 2.5rem !important; /* Tem de ser IGUAL ao gap definido acima */
    }

    .right-links {
        margin-left: 0 !important;
        margin-top: 0 !important;
    }

    .nav-links li {
        list-style: none;
        width: 100%;
    }

    .nav-links a {
        font-size: 1.8rem !important;
        font-weight: 600;
        letter-spacing: 2px;
        display: block;
    }
    
    /* Mantém o resto das tuas regras mobile que já cá estavam... */
    .contact-container, .recrutamento-container { flex-direction: column; }
    .vantagens-grid, .footer-grid { grid-template-columns: 1fr; }
    .equipa-grid { flex-direction: column; align-items: center; }

    /* --- 5. AJUSTES DOS TAMANHOS GIGANTES (HERO E EQUIPA) --- */
    
    /* Título principal do Hero */
    .hero-text h1 {
        font-size: 2.2rem; 
        margin-bottom: 1.5rem;
        line-height: 1.3;
    }

    /* Colocar os contadores lado a lado no telemóvel para poupar espaço */
    .hero-stats {
        flex-direction: row; 
        gap: 30px;
        margin-right: 0; 
        justify-content: center;
        width: 100%;
        margin-top: 20px;
    }

    /* Os números gigantes (+300 e +50) */
    .stat h2 {
        font-size: 3.2rem; 
    }

    /* O texto por baixo dos números (CRÉDITOS, IMÓVEIS) */
    .stat p {
        font-size: 1.5rem; 
    }

    /* O texto gigante de fundo "EQUIPA" */
    .bg-text {
        font-size: 3.5rem; 
        top: 25px; 
    }

    /* --- AJUSTE DO VÍDEO "QUEM SOMOS" NO MOBILE --- */
    .quem-somos .bg-video {
        object-position: 80% center; 
    }

    .quem-somos-content .text-box {
        background: rgba(12, 12, 12, 0.6) !important; /* Fundo um pouco mais transparente */
        backdrop-filter: blur(12px) !important;        /* O efeito de desfoque real */
        -webkit-backdrop-filter: blur(10px) !important; /* Suporte para Safari/iOS */
        
        border: 1px solid rgba(168, 146, 120, 0.3) !important; /* Borda dourada subtil e transparente */
        padding: 1.5rem !important;
        width: 90% !important;
        margin: 0 auto !important;
    }

    /* --- CORREÇÃO DO LETREIRO "EQUIPA" NO MOBILE --- */
    .marquee-section {
        padding: 40px 0 50px 0; /* Reduz o espaço gigante em cima e em baixo */
    }

    .marquee-text {
    font-size: 110px; 
    font-weight: 700;
    text-transform: uppercase;
    padding-right: 20px; 
    word-spacing: -25px; 
    
    /* O TRUQUE PARA LETRAS VAZADAS PERFEITAS */
    color: var(--bg-color); /* Pinta o interior da letra da cor do fundo do site */
    -webkit-text-stroke: 0; /* Desliga o contorno com defeito */
    
    /* Cria um contorno de 2px à volta usando sombras fundidas */
    text-shadow:
        -2px -2px 0 var(--border-color),
         2px -2px 0 var(--border-color),
        -2px  2px 0 var(--border-color),
         2px  2px 0 var(--border-color);
}

    /* --- BOTÃO "VER INFO" REAL (TABLET & MOBILE) --- */
    .btn-ver-info {
        position: absolute;
        bottom: 20px;
        right: 20px;
        background: var(--gold-gradient);
        color: var(--bg-color);
        padding: 8px 16px;
        border-radius: 20px;
        font-size: 0.8rem;
        font-weight: 700;
        box-shadow: 0 4px 10px rgba(0,0,0,0.5);
        z-index: 2;
        cursor: pointer;
        transition: opacity 0.3s ease;
    }

    /* Esconde o botão quando a aba de informação sobe */
    .membro.ativo .btn-ver-info {
        opacity: 0;
        pointer-events: none; /* Desativa o botão quando está invisível */
    }

    /* --- CORREÇÃO DOS BOTÕES ESPREMIDOS NO MOBILE --- */
    
    /* 1. Impede o texto de qualquer botão dourado de se empilhar */
    .btn-gold {
        white-space: nowrap; /* Proíbe a quebra de linha no texto */
        font-size: 0.8rem; /* Reduz ligeiramente a letra para caber perfeitamente */
        padding: 14px 20px; /* Ajusta as margens internas */
        width: 100%; /* Força o botão a esticar a toda a largura (Estilo App) */
        box-sizing: border-box;
    }

    /* 2. Coloca os botões da CTA um por baixo do outro em vez de lado a lado */
    .cta-buttons {
        flex-direction: column; 
        gap: 15px;
        width: 100%;
    }

    /* --- CORREÇÃO DA CAIXA CTA E BOTÕES IGUAIS NO MOBILE --- */
    
    /* 1. Reduzir as margens laterais gigantes da caixa preta */
    .cta-box {
        padding: 40px 15px; /* Passa de 50px para 15px nas laterais */
    }

    /* 2. Garantir que os botões ficam em coluna e ocupam o espaço todo */
    .cta-buttons {
        flex-direction: column; 
        gap: 15px;
        width: 100%;
    }

    /* 3. Estilo "App Nativa" para os botões da CTA */
    .cta-buttons .btn-gold {
        white-space: normal; /* Permite que o texto faça 2 linhas de forma bonita, se necessário */
        width: 100%;
        min-height: 60px; /* Força os dois botões a terem uma altura generosa e IGUAL */
        display: flex; /* Transforma o botão numa flexbox para centrar o texto */
        align-items: center; /* Centra verticalmente */
        justify-content: center; /* Centra horizontalmente */
        line-height: 1.3;
        padding: 10px;
    }

    /* --- AJUSTE FINO DO HERO NO MOBILE --- */
    
    /* 1. Subir o conteúdo do Hero um pouco */
    .hero-content {
        margin-top: 0px; /* No computador tem 80px. Colocar a 0px ou -20px faz o bloco subir perfeitamente no telemóvel */
        gap: 30px; /* Reduzi um pouco o espaço entre o texto e os números para ficar mais compacto */
    }

    /* 2. Aumentar os números dos contadores */
    .stat h2 {
        font-size: 4rem; /* Estava a 3.2rem. Aumentámos para 4rem para dar mais impacto sem partir o ecrã */
    }

    /* --- CORREÇÃO DA PÁGINA CONTACTOS NO MOBILE --- */
    
    /* 1. Remove a margem negativa para impedir a sobreposição */
    .contact-info-section {
        margin-top: 40px; /* Volta a dar um espaço normal e empurra a caixa para baixo do formulário */
    }

    /* 2. Força o mapa do Google a caber no ecrã do telemóvel */
    .map-container iframe {
        width: 100% !important; /* Ignora os 800px do HTML e ajusta à largura do telemóvel */
        height: 450px; /* Fica com uma altura mais amigável para mobile */
    }

    /* 3. Empilhar as informações de contacto (Email e Telefone) */
    .info-row {
        flex-direction: column; /* Passa de linha para coluna */
        gap: 25px; /* Adiciona um espaço de respiro muito elegante entre o Email e o Telefone */
    }

    /* --- CORREÇÃO DA CAIXA DE SELEÇÃO NO MOBILE --- */
    .form-group select {
        max-width: 100%; /* Proíbe a caixa de ser maior que o ecrã */
        overflow: hidden; /* Esconde o que tentar sair fora */
        text-overflow: ellipsis; /* Adiciona "..." se o texto for demasiado longo */
        white-space: nowrap; /* Evita que a caixa se desformate */
    }

    /* --- CORREÇÃO DO CLIQUE NA IMAGEM (Desativar o hover "falso" do telemóvel) --- */
    
    /* 1. Impede a aba de subir quando se toca apenas na foto */
    .membro:hover .membro-hover-info {
        transform: translateY(100%); 
    }
    
    /* 2. Impede a foto de fazer zoom ao ser tocada por engano */
    .membro:hover img {
        transform: scale(1); 
    }

    /* 3. A aba e o zoom AGORA SÓ ACONTECEM quando o botão é clicado (classe ativo) */
    .membro.ativo .membro-hover-info {
        transform: translateY(0) !important;
    }
    
    .membro.ativo img {
        transform: scale(1.05) !important;
    }

    .legal-container {
        margin-top: 100px; /* Navbar mobile é mais baixa */
        padding: 0 20px;
    }

    .legal-container h1 {
        font-size: 1.8rem;
    }

    .legal-container h2 {
        font-size: 1.2rem;
    }

}

/* Nota legal do telefone */
.nota-telefone {
    font-size: 0.65rem; /* Deixa o texto bem pequeno */
    color: #777; /* Um cinza mais escuro para ser discreto */
    display: inline-block;
    margin-top: 2px; /* Dá um pequeno respiro entre o número e o texto */
    font-weight: 400;
}

/* --- Mensagens de Erro Personalizadas do Formulário --- */
.error-text {
    color: #d9534f; /* Vermelho suave para não ser demasiado agressivo */
    font-size: 0.75rem;
    margin-top: 5px;
    display: block;
    animation: fadeIn 0.3s ease;
}

/* Pinta a borda do campo de vermelho quando há erro */
.input-error {
    border-color: #d9534f !important;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 1; transform: translateY(0); }
}

/* --- ANIMAÇÕES DE SCROLL --- */
.anima-fade {
    opacity: 0;
    transition: opacity 0.8s ease-out;
}

.anima-slide-up {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.anima-slide-left {
    opacity: 0;
    transform: translateX(50px);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.anima-slide-right {
    opacity: 0;
    transform: translateX(-50px);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.mostrar {
    opacity: 1 !important;
    transform: translate(0, 0) !important;
}

/* --- ANIMAÇÕES DO HERO GARANTIDAS (CSS PURO 100% FLUIDO) --- */
/* Título com Blur Cinemático */
.hero-text h1 {
    opacity: 0; /* Começa invisível */
    animation: cinematicReveal 1.5s cubic-bezier(0.25, 1, 0.5, 1) forwards;
    animation-delay: 0.2s; /* Dá 0.2s de respiro para o vídeo começar */
}

@keyframes cinematicReveal {
    0% {
        opacity: 0;
        transform: translateY(40px) scale(1.05);
        filter: blur(12px); /* Começa desfocado */
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
        filter: blur(0); /* Foca no final */
    }
}

.hero-text .btn-gold {
    opacity: 0;
    /* Movemos o botão para baixo inicialmente */
    transform: translateY(30px) scale(1);
    
    /* A animação trata apenas de aparecer */
    animation: fadeInHero 1.2s ease-out forwards;
    animation-delay: 0.8s;

    /* A transição trata de TUDO o que for movimento (suavidade total) */
    transition: transform 0.5s cubic-bezier(0.2, 1, 0.3, 1), opacity 0.5s ease;
}

/* Estado que o JS ou o browser vai assumir logo após o load */
.hero-text .btn-gold {
    /* Forçamos o botão a subir suavemente via transform em vez de keyframe */
    transform: translateY(0) scale(1);
}

/* --- AJUSTE DO BOTÃO HERO PARA ACEITAR HOVER --- */

@keyframes fadeInHero {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes elasticPop {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* --- POPUP DE SUCESSO (MODAL) --- */
.modal-overlay {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease;
}

.modal-overlay.mostrar {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background: var(--card-bg);
    border: 1px solid var(--gold-accent);
    padding: 40px;
    border-radius: 15px;
    text-align: center;
    max-width: 400px;
    width: 90%;
    transform: translateY(30px) scale(0.95);
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    box-shadow: 0 15px 40px rgba(0,0,0,0.6);
}

.modal-overlay.mostrar .modal-content {
    transform: translateY(0) scale(1);
}

.modal-icon {
    font-size: 3.5rem;
    color: var(--gold-accent);
    margin-bottom: 10px;
    line-height: 1;
}

.modal-content h3 {
    font-size: 1.5rem;
    margin-bottom: 15px;
    color: var(--text-color);
}

.modal-content p {
    color: #ccc;
    font-size: 0.95rem;
    margin-bottom: 25px;
    line-height: 1.6;
}

.modal-content .btn-gold {
    width: 100%;
}

/* --- CORREÇÃO DE CORTE DE TEXTO (CHOQUE) --- */
.legal-container, 
.legal-container * {
    max-width: 100% !important;
    overflow-wrap: break-word !important; /* Força palavras longas a quebrarem */
    word-wrap: break-word !important;
    box-sizing: border-box !important;
}

.legal-container {
    width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    overflow-x: hidden !important; /* Impede o scroll lateral */
}

/* Se tiveres tabelas de termos, isto torna-as seguras para mobile */
.legal-container table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.legal-container h1 {
    font-size: 11vw !important; /* Ajusta o tamanho da letra com base na largura do ecrã */
    hyphens: auto;
}

/* Impedir o balanço lateral em todo o site */
html, body {
    max-width: 100%;
    overflow-x: hidden;
    position: relative;
}

/* Forçar os elementos da página de contactos a respeitarem o limite */
.contact-page, 
.contact-container, 
.contact-info-section, 
.map-container iframe {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* O culpado costuma ser o Google Maps, esta linha corrige-o */
.map-container iframe {
    width: 100% !important;
}