:root {
    --bg: #fdfcf8;      /* Fundo Claro */
    --text: #1a1a1a;    /* Letras Pretas no Light Mode */
    --accent: #b08d57;
}

.dark-mode {
    --bg: #0a0a0a;      /* Fundo Escuro */
    --text: #fdfcf8;    /* Letras Brancas no Dark Mode */
}

body {
    background-color: var(--bg);
    color: var(--text);
    font-family: 'Montserrat', sans-serif;
    transition: background-color 0.4s ease, color 0.4s ease;
    overflow-x: hidden;
}

/* NAVBAR E LOGO */
#navbar {
    height: var(--nav-height);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 5%;
    position: fixed;
    top: 0; width: 100%; z-index: 1000;
    background: var(--bg);
    border-bottom: 1px solid rgba(176, 141, 87, 0.1);
}

/* 1. CONFIGURAÇÃO GLOBAL DO LOGO */
.logo img {
    height: 110px !important;
    width: auto;
    transition: all 0.4s ease-in-out !important;
    filter: none !important;          /* Remove qualquer inversão de cor */
    mix-blend-mode: normal !important; /* Mantém as cores originais */
}

/* 2. REMOÇÃO DE REGRAS ESPECÍFICAS DE MODO ESCURO PARA O LOGO */
/* Certifique-se de que NÃO existem estas linhas no seu ficheiro: */
.dark-mode .logo img, 
.dark-mode body .logo img {
    filter: none !important;
}

/* 4. ALINHAMENTO */
.logo {
    display: flex;
    align-items: center;
    background: transparent !important;
}

.logo img:hover {
    transform: scale(1.05);
}

.nav-links { display: flex; list-style: none; gap: 30px; }
.nav-links a { text-decoration: none; color: var(--text); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; }

/* SECCÃO ATELIER */
.atelier-container { padding: 180px 8% 100px; max-width: 1400px; margin: 0 auto; }
.atelier-content { display: flex; align-items: center; gap: 80px; flex-wrap: wrap; }
.atelier-text { flex: 1; min-width: 320px; }
.label { letter-spacing: 5px; color: var(--accent); font-size: 11px; text-transform: uppercase; }
.atelier-text h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 300; margin: 25px 0; }
.divider { width: 60px; height: 1px; background: var(--accent); margin: 30px 0; }
.atelier-badges { display: flex; gap: 30px; font-size: 10px; opacity: 0.6; }

.atelier-visual { flex: 1; min-width: 320px; }
.image-wrapper { position: relative; width: 90%; margin-left: auto; }
.image-wrapper img { width: 100%; height: 75vh; object-fit: cover; position: relative; z-index: 2; }
.decorative-frame { position: absolute; top: -20px; left: -20px; width: 100%; height: 100%; border: 1px solid var(--accent); z-index: 1; }

/* REVEAL ANIMATION */
.reveal { opacity: 0; transform: translateY(30px); transition: 1s ease; }
.reveal.active { opacity: 1; transform: translateY(0); }
/* --- CONTACTOS STYLES --- */

.contact-container {
    padding: 180px 8% 100px;
    max-width: 1300px;
    margin: 0 auto;
}

.contact-header {
    text-align: center;
    margin-bottom: 80px;
}

.contact-header h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 300;
    margin: 15px 0;
}

.subtitle {
    font-weight: 200;
    opacity: 0.7;
    max-width: 500px;
    margin: 0 auto;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 100px;
}

/* Formulário Minimalista */
.luxury-form {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

.input-group {
    position: relative;
    border-bottom: 1px solid rgba(176, 141, 87, 0.3);
    padding: 5px 0;
}

.input-group input, 
.input-group textarea {
    width: 100%;
    background: transparent;
    border: none;
    color: var(--text);
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    padding: 10px 0;
    outline: none;
    letter-spacing: 1px;
}

.input-group label {
    position: absolute;
    left: 0;
    top: 15px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 2px;
    pointer-events: none;
    transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    opacity: 0.5;
}

/* Efeito do Label subir ao escrever */
.input-group input:focus ~ label,
.input-group input:not(:placeholder-shown) ~ label,
.input-group textarea:focus ~ label,
.input-group textarea:not(:placeholder-shown) ~ label {
    top: -15px;
    font-size: 9px;
    color: var(--accent);
    opacity: 1;
}

.btn-submit {
    background: transparent;
    border: 1px solid var(--accent);
    color: var(--text);
    padding: 20px;
    text-transform: uppercase;
    letter-spacing: 3px;
    font-size: 11px;
    cursor: pointer;
    transition: 0.4s;
    margin-top: 20px;
}

.btn-submit:hover {
    background: var(--accent);
    color: #fff;
}

/* Mapa e Info */
.map-wrapper {
    height: 400px;
    filter: saturate(0.8) contrast(1.1);
    border: 1px solid rgba(176, 141, 87, 0.2);
    margin-bottom: 40px;
    transition: filter 0.6s ease;
}

.

.info-details {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.info-block h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 400;
    margin-bottom: 5px;
}

.info-block p {
    font-size: 13px;
    font-weight: 200;
    opacity: 0.7;
}

.wa-direct {
    color: var(--accent);
    text-decoration: none;
    font-size: 11px;
    letter-spacing: 2px;
    font-weight: 400;
}

/* --- RESPONSIVIDADE GERAL (Navbar e Estrutura) --- */
@media (max-width: 1024px) {
    
    /* Corrige o posicionamento do Dark Mode e Hamburguer */
    #navbar {
        padding: 0 20px;
    }

    .nav-actions {
        order: 2; /* Dark mode no meio */
        margin-right: 15px;
        z-index: 1001;
    }

  
    .logo {
        order: 1;
        flex-grow: 1;
    }

    /* O menu lateral propriamente dito */
    .nav-links {
        position: fixed;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100vh;
        background-color: var(--bg);
        z-index: 1000;
        /* ... restantes estilos do menu ... */
    }
}

/* --- RESPONSIVIDADE ESPECÍFICA (Páginas) --- */
@media (max-width: 992px) {
    /* Mantenha isto! É o que impede o formulário de contactos de ficar "esmagado" */
    .contact-grid { 
        grid-template-columns: 1fr; 
        gap: 60px; 
    }
    
    .contact-container { 
        padding-top: 140px; 
    }
}

/* HERO SECTION - INDEX */
.hero-slider {
    height: 100vh;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--bg); /* Fundo alternativo se a imagem falhar */
    background-size: cover;
    background-position: center;
    position: relative;
}

.hero-content {
    text-align: center;
    z-index: 5;
    padding: 0 10%;
}

.hero-content span {
    display: block;
    letter-spacing: 5px;
    text-transform: uppercase;
    font-size: 11px;
    margin-bottom: 20px;
    color: var(--accent);
}

.hero-content h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.5rem, 8vw, 5rem);
    font-weight: 300;
    margin-bottom: 20px;
    line-height: 1.1;
}

.hero-content p {
    font-weight: 200;
    margin-bottom: 40px;
    opacity: 0.8;
}

.btn-luxury {
    display: inline-block;
    padding: 15px 40px;
    border: 1px solid var(--accent);
    text-decoration: none;
    color: var(--text);
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    transition: 0.4s;
}

.btn-luxury:hover {
    background: var(--accent);
    color: white;
}

/* CITAÇÃO */
.featured-quote {
    padding: 100px 10%;
    text-align: center;
}

.featured-quote p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem;
    font-style: italic;
    font-weight: 300;
    max-width: 800px;
    margin: 0 auto;
}

footer {
    width: 100%;
    text-align: center; /* Centra o texto */
    padding: 40px 0;    /* Dá espaço acima e abaixo */
    margin-top: 50px;   /* Afasta o footer do conteúdo principal */
    font-family: 'Montserrat', sans-serif; /* Mantém a identidade visual */
    font-size: 0.8rem;
    letter-spacing: 1px;
}

footer a {
    text-decoration: none;
    color: #000; /* Ou a cor de destaque do teu site */
    border-bottom: 1px solid #ccc; /* Um detalhe elegante */
    transition: 0.3s;
}

footer a:hover {
    border-bottom: 1px solid #000;
}
/* HERO SECTION - CORES EM BRANCO */
.hero-content h1 {
    color: #ffffff; /* Cor branca para o título "A Poesia do Metal" */
}

.hero-content p {
    color: #ffffff; /* Cor branca para o subtítulo */
    opacity: 0.9;   /* Aumentei ligeiramente a opacidade para facilitar a leitura */
}

.btn-luxury {
    color: #ffffff; /* Cor branca para o texto do botão "Ver Peças" */
    border-color: #ffffff; /* Opcional: muda a borda para branco também para combinar */
}

.btn-luxury:hover {
    background: #ffffff;
    color: #1a1a1a; /* Ao passar o rato, o fundo fica branco e o texto escuro */
}
/* Cor branca para o texto pequeno acima do título */
.hero-content span {
    color: #ffffff !important;
    opacity: 1; /* Garante que não fica transparente contra o fundo */
}
.hero-content {
    text-shadow: 0px 2px 10px rgba(0, 0, 0, 0.3);
}
/* Estado inicial: Invisível e ligeiramente abaixo */
.reveal-init {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 1.2s cubic-bezier(0.16, 1, 0.3, 1), 
                transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: transform, opacity;
}

/* Estado final: Visível e na posição correta */
.reveal-init.active {
    opacity: 1;
    transform: translateY(0);
}

/* Animação em cascata para grupos de itens (ex: links ou badges) */
.atelier-badges span, .nav-links li {
    opacity: 0;
    animation: fadeInText 0.8s ease forwards;
}

@keyframes fadeInText {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Delay progressivo para elementos na mesma linha */
.reveal-init:nth-child(2) { transition-delay: 0.2s; }
.reveal-init:nth-child(3) { transition-delay: 0.4s; }
/* --- LAYOUT COLEÇÕES (6 IMAGENS) --- */

.collection-grid {
    display: grid;
    /* Cria 3 colunas iguais */
    grid-template-columns: repeat(3, 1fr);
    /* Espaço entre as imagens (60px vertical, 40px horizontal) */
    gap: 60px 40px;
    max-width: 1200px;
    margin: 60px auto;
    padding: 0 5%;
}

.card {
    display: flex;
    flex-direction: column;
    text-align: center;
}

.img-container {
    width: 100%;
    /* Define uma proporção vertical elegante (tipo retrato) */
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background-color: rgba(176, 141, 87, 0.03); /* Fundo muito subtil */
    margin-bottom: 20px;
}

.img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Garante que a imagem preenche o espaço sem deformar */
    transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Efeito ao passar o rato na joia */
.card:hover .img-container img {
    transform: scale(1.08);
}

.card-info h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 400;
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}

.card-info p {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent); /* Cor bronze/gold */
}

/* Responsividade: No telemóvel passa para 1 coluna */
@media (max-width: 900px) {
    .collection-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .collection-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}
/* --- LAYOUT COLEÇÕES: 3 COLUNAS --- */
.collection-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 80px 40px;
    max-width: 1200px;
    margin: 0 auto 100px;
    padding: 0 5%;
}

.card {
    display: flex;
    flex-direction: column;
    text-align: center;
}

.img-container {
    width: 100%;
    aspect-ratio: 3 / 4; /* Formato vertical elegante */
    overflow: hidden;
    background-color: rgba(176, 141, 87, 0.03); 
    margin-bottom: 25px;
}

.img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Efeito de Zoom suave */
.card:hover .img-container img {
    transform: scale(1.08);
}

/* Tipografia das Legendas */
.card-info h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem;
    font-weight: 400;
    margin-bottom: 8px;
}

.card-info p {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent); /* Cor bronze/gold do site */
}

/* RESPONSIVIDADE */
@media (max-width: 900px) {
    .collection-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
    .collection-grid { grid-template-columns: 1fr; gap: 50px; }
}
/* --- LAYOUT DA COLECÇÃO (GRELHA DE 3 COLUNAS) --- */
.collection-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 80px 40px;
    max-width: 1200px;
    margin: 0 auto 100px;
    padding: 0 5%;
}

.card {
    display: flex;
    flex-direction: column;
    text-align: center;
}

.img-container {
    width: 100%;
    aspect-ratio: 3 / 4; /* Formato vertical sofisticado */
    overflow: hidden;
    background-color: rgba(176, 141, 87, 0.03); 
    margin-bottom: 25px;
}

.img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.card:hover .img-container img {
    transform: scale(1.08); /* Zoom suave ao passar o rato */
}

.card-info h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem;
    font-weight: 400;
    margin-bottom: 8px;
    color: var(--text);
}

.card-info p {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--accent);
}

/* Responsividade: Tablet e Telemóvel */
@media (max-width: 900px) {
    .collection-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
    .collection-grid { grid-template-columns: 1fr; gap: 50px; }
}
/* ICONE HAMBÚRGUER */
/* Localize e substitua por isto */


/* RESPONSIVIDADE PARA TELEMÓVEL */
@media (max-width: 1024px) {
    .menu-icon { display: flex; }

    .nav-links {
        position: fixed;
        top: 0;
        right: -100%; /* Escondido à direita */
        width: 100%;
        height: 100vh;
        background-color: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 30px;
        transition: 0.6s cubic-bezier(0.16, 1, 0.3, 1);
        z-index: 1500;
    }

    .nav-links.active {
        right: 0; /* Desliza para dentro */
    }

    /* Transformar Hambúrguer em "X" quando aberto */
    .menu-icon.active .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .menu-icon.active .bar:nth-child(2) { opacity: 0; }
    .menu-icon.active .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}
/* --- CORREÇÃO DA NAVBAR --- */
#navbar {
    display: flex;
    justify-content: space-between; /* Espalha os 3 blocos: logo, links, botão */
    align-items: center;
    padding: 0 5%;
    height: 120px;
}

.nav-links {
    display: flex;
    list-style: none;
    gap: 30px;
}

.nav-links li a {
    text-decoration: none;
    color: var(--text);
    font-size: 0.8rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: color 0.3s;
}

/* Esconder o ícone de telemóvel no PC */
/* Localize e substitua por isto */

/* --- RESPONSIVIDADE (Ajuste para Telemóvel) --- */
@media (max-width: 1024px) {
    .menu-icon {
        display: flex; /* Mostra o hambúrguer */
        order: 2; /* Coloca-o na posição certa */
    }

    .nav-actions {
        order: 3; /* Botão de modo por último */
    }

    .logo {
        order: 1; /* Logo primeiro */
    }

    .nav-links {
        position: fixed;
        top: 0;
        right: -100%; /* Esconde o menu fora do ecrã */
        width: 100%;
        height: 100vh;
        background-color: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        transition: 0.5s ease-in-out;
        z-index: 1000;
    }

    .nav-links.active {
        right: 0; /* Faz o menu aparecer */
    }
}


/* --- RESPONSIVIDADE (Ajuste para Telemóvel e Tablet) --- */
@media (max-width: 1024px) {
    #navbar {
        padding: 0 20px;
        height: 100px; /* Um pouco mais compacta em mobile */
    }

    .logo img {
        height: 80px !important;
    }

    /* Localize e substitua por isto */

    .nav-actions {
        display: flex !important;
        order: 2;      /* Dark Mode fica no centro-direita */
        margin-right: 15px;
        z-index: 1100; /* Garante que o clique funciona */
    }

    .logo {
        order: 1;      /* Logo à esquerda */
        flex: 1;
    }

    .nav-links {
        position: fixed;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100vh;
        background-color: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 1000; /* Abaixo dos ícones de ação */
    }

    .nav-links.active {
        right: 0;
    }

    .nav-links li {
        margin: 20px 0;
    }
}

/* --- AJUSTES ESPECÍFICOS (Páginas) --- */
@media (max-width: 992px) {
    .contact-grid { 
        grid-template-columns: 1fr; 
        gap: 40px; 
    }
    .contact-container { 
        padding-top: 140px; 
    }
}
#mode-toggle {
    order: 1; /* Garante que é o primeiro item no flexbox */
    background: transparent;
    border: 1px solid var(--accent);
    color: var(--text);
    cursor: pointer;
    padding: 5px 10px;
    font-size: 14px;
    transition: 0.3s;
    margin-right: 10px; /* Empurra o ícone do menu mais para a direita */
}


@media (max-width: 1024px) {
    .nav-actions {
        position: relative;
        right: 0;
        gap: 15px;
    }
    
    #mode-toggle {
        margin-right: 5px;
        font-size: 18px; /* Aumenta um pouco para facilitar o toque */
    }
}
/* --- AJUSTES GERAIS DA NAVBAR --- */
#navbar {
    height: 80px; /* 1. Reduzido de 120px para 80px para ser mais fina */
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 5%;
    position: fixed;
    top: 0; 
    width: 100%; 
    z-index: 1000;
    background: var(--bg);
    border-bottom: 1px solid rgba(176, 141, 87, 0.1);
}

.logo img {
    height: 60px !important; /* Ajustado para caber na barra mais fina */
    width: auto;
}

/* 2. CENTRALIZAR OS LINKS NO PC */
.nav-links {
    display: flex;
    list-style: none;
    position: absolute; /* Posicionamento absoluto em relação à navbar */
    left: 50%;
    transform: translateX(-50%); /* Técnica para centralizar perfeitamente */
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-left: auto; /* Empurra o toggle para a direita */
    z-index: 1100;
}



/* --- AJUSTES RESPONSIVOS (MOBILE) --- */
@media (max-width: 992px) {
    /* 1. Garante que o ícone do hambúrguer aparece */
   /* Localize e substitua por isto */

    /* 2. Menu lateral vindo da esquerda */
    .nav-links {
        display: flex !important; /* Garante que o flex funciona */
        position: fixed;
        top: 0;
        left: -100%; /* Começa escondido à esquerda */
        width: 280px; /* Largura fixa para parecer um menu lateral luxuoso */
        height: 100vh;
        background: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        padding-left: 40px;
        gap: 20px;
        transform: none;
        transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 15px 0 30px rgba(0,0,0,0.1);
        z-index: 1100;
    }

    /* 3. Quando o menu abre */
    .nav-links.active {
        left: 0; /* Desliza para dentro */
    }

    /* 4. Estilo do botão Dark Mode dentro do menu */
    .mobile-toggle-item {
        margin-top: 20px;
        list-style: none;
    }

    #mode-toggle {
        display: block !important;
        padding: 10px 20px;
        font-size: 1.2rem;
    }
}
/* --- FORÇAR APARIÇÃO DO HAMBÚRGUER --- */

/* --- MODO RESPONSIVO --- */
@media (max-width: 992px) {
    #navbar {
        height: 70px; /* Barra mais fina no mobile */
        justify-content: space-between;
        padding: 0 20px;
    }

    /* Localize e substitua por isto */


    /* O menu que desliza da ESQUERDA */
    .nav-links {
        position: fixed;
        top: 0;
        left: -100%; /* Escondido à esquerda */
        width: 280px;
        height: 100vh;
        background: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        padding-left: 40px;
        transition: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 1500;
        box-shadow: 10px 0 20px rgba(0,0,0,0.1);
        display: flex !important; /* Garante que os links existem dentro da caixa */
    }

    .nav-links.active {
        left: 0 !important; /* Mostra o menu */
    }

    /* Esconder os links centrais do desktop para não flutuarem no meio do ecrã */
    .nav-links:not(.active) {
        pointer-events: none;
    }
}
/* --- ESTILO DO HAMBURGUER --- */

.menu-icon {
    display: none; /* Escondido no PC */
    cursor: pointer;
    z-index: 2000 !important;
    padding: 15px; /* Aumenta a área de clique */
    background: transparent;
    border: none;
    /* Afasta o ícone da borda direita */
    margin-right: 20px !important; 
}

.menu-icon .bar {
    width: 28px;
    height: 2px;
    background-color: var(--text) !important;
    margin: 6px 0;
    transition: 0.4s;
    display: block;
}
@media (max-width: 992px) {
    #navbar {
        height: 70px !important;
        /* O padding-right aqui é o que impede o ícone de ficar "de fora" */
        padding: 0 30px 0 20px !important; 
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        box-sizing: border-box !important;
    }

    .logo img {
        height: 45px !important;
    }

    .menu-icon {
        display: block !important;
        /* Garante que ele não herda posições absolutas anteriores */
        position: relative !important; 
        right: auto !important;
    }

    /* Menu lateral vindo da ESQUERDA */
    .nav-links {
        position: fixed;
        top: 0;
        left: -100%; 
        width: 280px;
        height: 100vh;
        background: var(--bg);
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        padding-left: 40px;
        transition: 0.5s ease;
        z-index: 1500;
        box-shadow: 10px 0 20px rgba(0,0,0,0.1);
        display: flex !important;
        transform: none !important;
    }

    .nav-links.active {
        left: 0 !important;
    }

    .nav-links li {
        margin: 15px 0;
        opacity: 1 !important;
        transform: none !important;
    }

    .mobile-toggle-item {
        margin-top: 30px;
        display: block !important;
    }
}
/* Garante que o corpo do site não tem margens escondidas */
body, html {
    margin: 0 !important;
    padding: 0 !important;
    width: 100%;
    overflow-x: hidden;
}

/* Faz a imagem preencher tudo */
.hero-slider {
    width: 100vw;          /* 100% da largura da janela */
    height: 100vh;         /* 100% da altura da janela */
    margin: 0;             /* Remove qualquer margem que cause a borda branca */
    background-size: cover; /* Faz a imagem esticar sem distorcer */
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
}
#navbar {
    position: fixed;       /* Fixa no topo */
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    background: transparent; /* Podes mudar para rgba(253, 252, 248, 0.8) se quiseres cor */
    box-sizing: border-box;  /* Impede que o padding empurre a barra para fora */
}
.hero-content h1 {
    font-weight: 700 !important; /* Força o negrito */
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5); /* Sombra suave para leitura */
    font-size: clamp(2.5rem, 8vw, 4.5rem); /* Tamanho responsivo */
    margin-bottom: 20px;
}

.hero-content p {
    font-weight: 500;
    text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5);
    font-size: 1.2rem;
}
.logo img {
    height: 80px !important; /* Aumentado (ajusta conforme preferires) */
    width: auto;
    transition: transform 0.3s ease;
    /* Adiciona uma sombra subtil ao redor do logo para ele saltar do fundo */
    filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.3)) !important; 
}

/* No mobile, podemos mantê-lo um pouco mais contido */
@media (max-width: 992px) {
    .logo img {
        height: 60px !important;
    }
}
/* Foca na legibilidade do texto no modo escuro */
.dark-mode .nav-links li a {
    color: #fdfcf8 !important; /* Branco pérola para máximo contraste */
    font-weight: 500 !important; /* Engrossa um pouco a letra */
    text-shadow: 0 0 8px rgba(255, 255, 255, 0.2); /* Brilho subtil nas letras */
    letter-spacing: 2px;
}

/* Garante que o link ativo ou ao passar o rato também se veja */
.dark-mode .nav-links li a:hover {
    color: var(--accent) !important; /* Dourado ao passar o rato */
}

.dark-mode h1, 
.dark-mode .hero-content h1 {
    color: #fdfcf8 !important;
    font-weight: 700 !important; /* Bem negrito */
    text-shadow: 2px 2px 15px rgba(255, 255, 255, 0.1), 0 0 20px rgba(0,0,0,0.8) !important;
}
/* Links da Navbar sempre brancos */
.nav-links li a {
    color: #ffffff !important;
    font-weight: 500;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5); /* Sombra para ler bem sobre fotos claras */
    text-decoration: none;
    letter-spacing: 2px;
    transition: color 0.3s ease;
}

/* Cor das barras do hambúrguer sempre brancas */
.menu-icon .bar {
    background-color: #ffffff !important;
}

/* Quando o menu mobile abre, as letras continuam brancas */
@media (max-width: 992px) {
    .nav-links {
        background-color: #000000; /* Fundo preto no menu mobile para as letras brancas brilharem */
    }
    
    .nav-links li a {
        color: #ffffff !important;
    }
}
.logo img {
    height: 85px !important; /* Tamanho maior que pediste */
    width: auto;
    filter: none !important; /* Garante que não há filtros */
    mix-blend-mode: normal !important;
}

@media (max-width: 992px) {
    .logo img {
        height: 65px !important; /* Ajuste para telemóvel */
    }
}
h1, .hero-content h1 {
    color: #ffffff !important;
    font-weight: 700 !important;
    text-shadow: 2px 2px 15px rgba(0, 0, 0, 0.6) !important;
}
/* 1. Cores base da Navbar (Respeitam o Dark/Light Mode) */
#navbar {
    background-color: var(--bg); /* Fundo dinâmico */
    transition: background 0.3s ease;
}

.nav-links li a {
    color: var(--text) !important; /* Texto dinâmico: preto no light, branco no dark */
    font-weight: 500;
    transition: all 0.3s ease;
}

.menu-icon .bar {
    background-color: var(--text) !important; /* Barras dinâmicas */
}

/* 2. EXCEPÇÃO: Estilo para quando a imagem ocupa o ecrã todo (Hero) */
/* Adicionamos esta classe apenas onde a imagem é o fundo principal */
.on-hero .nav-links li a,
.on-hero .menu-icon .bar {
    color: #ffffff !important;
    background-color: #ffffff !important;
    text-shadow: 1px 1px 10px rgba(0,0,0,0.5);
}

.on-hero #navbar {
    background: transparent !important;
    border-bottom: none !important;
}
.logo img {
    height: 85px !important;
    width: auto;
    filter: none !important; 
}

@media (max-width: 992px) {
    .logo img { height: 60px !important; }
    
    /* No mobile, o menu lateral deve ter sempre fundo para ler bem */
    .nav-links {
        background-color: var(--bg) !important;
    }
}
/* Links da Navbar */
.nav-links li a {
    color: var(--menu-txt) !important;
    font-weight: 600;
    text-shadow: 1px 1px 5px rgba(0,0,0,0.2); /* Sombra leve para ler branco no fundo claro */
}

/* Barras do Hambúrguer */
.menu-icon .bar {
    background-color: var(--menu-txt) !important;
}

/* No Mobile: O fundo do menu tem de mudar para o texto se ver */
@media (max-width: 992px) {
    .nav-links {
        background-color: var(--menu-bg) !important;
    }
}
h1, .hero-content h1 {
    color: var(--menu-txt) !important;
    font-weight: 700;
    /* Adicionamos uma sombra quando a letra é branca para não "sumir" no fundo pérola */
    text-shadow: var(--menu-txt) == #ffffff ? 2px 2px 10px rgba(0,0,0,0.2) : none;
}
footer {
    background-color: var(--bg);
    color: var(--text) !important; /* Segue a troca de cores */
    padding: 60px 5%;
    border-top: 1px solid rgba(176, 141, 87, 0.1);
}

footer a, footer p, footer h4 {
    color: var(--text) !important; /* Garante que tudo no footer muda */
}
/* Links da Navbar e Botão Toggle */
.nav-links li a, 
#mode-toggle {
    color: var(--text) !important; 
    border-color: var(--text);
    background: transparent;
    transition: all 0.3s ease;
}

/* Barras do Hambúrguer */
.menu-icon .bar {
    background-color: var(--text) !important;
}

/* No Mobile: O menu lateral precisa de fundo dinâmico */
@media (max-width: 992px) {
    .nav-links {
        background-color: var(--bg) !important; /* Fundo preto no dark, pérola no light */
    }
}
.hero-content h1, 
.hero-content p {
    color: #ffffff !important; /* Sempre branco no slider para leitura */
    text-shadow: 2px 2px 10px rgba(0,0,0,0.5);
}
/* Links da Navbar: Sempre Brancos em qualquer modo */
.nav-links li a {
    color: #ffffff !important; 
    font-weight: 500;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5); /* Essencial para ler no fundo pérola */
    text-decoration: none;
    letter-spacing: 2px;
    transition: all 0.3s ease;
}

/* Garante que o efeito de passar o rato (hover) funciona */
.nav-links li a:hover {
    color: var(--accent) !important;
}
/* Texto geral, Footer e Toggle seguem a lógica do botão */
body, p, h4, footer, footer a, #mode-toggle {
    color: var(--text) !important;
    border-color: var(--text);
}

/* Os títulos (H1) também mudam conforme o modo */
h1 {
    color: var(--text) !important;
    transition: 0.3s;
}
/* Coloca isto logo no início do teu CSS */
html, body {
    margin: 0 !important;
    padding: 0 !important;
    width: 100%;
    overflow-x: hidden; /* Impede que o site balance para os lados */
}
.hero-slider {
    width: 100vw;          /* Largura total do ecrã */
    height: 100vh;         /* Altura total do ecrã */
    margin: 0 !important;  /* Garante que não há espaço em volta */
    padding: 0 !important;
    background-size: cover;    /* Estica a imagem sem distorcer */
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* --- REGRA PARA AS PÁGINAS NORMAIS (Ética, Contactos, etc.) --- */
/* Segue o botão: Preto no Light / Branco no Dark */
.nav-links li a {
    color: var(--text) !important;
    font-weight: 500;
    transition: 0.3s;
}

/* --- REGRA EXCLUSIVA PARA A PÁGINA INICIAL --- */
/* Se a Nav tiver a classe 'home-page', as letras são SEMPRE brancas */
#navbar.home-page .nav-links li a,
#navbar.home-page .menu-icon .bar {
    color: #ffffff !important;
    background-color: #ffffff !important; /* para as barras do hamburguer */
    text-shadow: 1px 1px 10px rgba(0,0,0,0.5) !important;
}

/* Garante que o fundo da nav na home é transparente para ver a imagem */
#navbar.home-page {
    background: transparent !important;
    border-bottom: none !important;
}
/* Imagem total na Home */
.hero-slider {
    width: 100vw;
    height: 100vh;
    margin: 0 !important;
}

/* Footer inteligente: muda com o botão */
footer, footer p, footer a, #mode-toggle {
    color: var(--text) !important;
    border-color: var(--text);
}
/* Limpeza Geral dos Links da Navbar */
.nav-links li a {
    background-color: transparent !important; /* Remove qualquer fundo por trás das letras */
    padding: 10px 15px;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.3s ease;
    display: inline-block;
}

/* --- ESTILO PARA AS PÁGINAS COM FUNDO LISO (Coleção, Ética, etc.) --- */
/* Letras Pretas no Light Mode / Brancas no Dark Mode */
#navbar .nav-links li a {
    color: var(--text) !important;
}

/* --- ESTILO EXCLUSIVO PARA A PÁGINA INICIAL (Sobre a Imagem) --- */
/* Forçamos letras brancas sem fundo, apenas com sombra para leitura */
#navbar.home-page .nav-links li a {
    color: #ffffff !important;
    background: transparent !important; /* Garante que não há caixas brancas */
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5); /* Sombra suave para destacar da foto */
}
/* Remove qualquer margem que esteja a empurrar a imagem */
body, html {
    margin: 0 !important;
    padding: 0 !important;
}

.hero-slider {
    width: 100vw;
    height: 100vh;
    margin-top: -85px; /* Puxa a imagem para trás da navbar se ela for fixa */
    background-size: cover;
}
/* 1. REMOVER LINHA APENAS NA HOME */
#navbar.home-page {
    border-bottom: none !important;
    box-shadow: none !important;
}

/* 2. CORES NO MODO RESPONSIVO (Mobile) */
@media (max-width: 992px) {
    /* Força o fundo do menu lateral a seguir o tema */
    .nav-links {
        background-color: var(--bg) !important;
    }

    /* Força as letras a serem PRETAS no Light Mode e BRANCAS no Dark Mode */
    /* Mesmo que seja na página inicial, no telemóvel o menu precisa de contraste */
    #navbar.home-page .nav-links li a,
    .nav-links li a {
        color: var(--text) !important;
        text-shadow: none !important; /* Remove sombra no mobile para ficar limpo */
        background: transparent !important;
    }

    /* Ajusta o ícone do hambúrguer para ser visível conforme o fundo da página */
    /* Na home (sobre a foto) ele continua branco, nas outras segue o tema */
    #navbar:not(.home-page) .menu-icon .bar {
        background-color: var(--text) !important;
    }
}
