/* --- CSS para o Cabeçalho --- */

/* Variáveis para cores (opcional, mas bom para organização) */
:root {
    --cor-verde-escuro: #2a4b33;
    --cor-dourado: #D4AF37;
    --cor-branco: #FFFFFF;
    --cor-cinza-claro: #E0E0E0; /* Para a data */
    --cor-sombra-texto: rgba(0,0,0,0.3);
}

header {
    /* Fundo: Usamos uma imagem de folhagem repetida.
       Você precisará baixar uma imagem de folhagem sutil e colocá-la na pasta 'imagens' ou em outro local.
       Por exemplo, salve como 'folhagem-padrao.png'
       Se não tiver uma imagem, você pode usar uma URL de exemplo ou remover 'url()' */
    background: var(--cor-verde-escuro) url('imagens/leaves.png') repeat;
    /* Ajuste o 'leaves.png' para o caminho da sua imagem de folhagem, se a usar localmente (ex: url('../imagens/folhagem-padrao.png')) */

    color: var(--cor-branco);
    text-align: center;
    padding: 60px 20px; /* Mais padding para a parte superior e inferior para um visual mais espaçoso */
    box-shadow: 0 4px 8px rgba(0,0,0,0.1); /* Sombra sutil na parte inferior do cabeçalho */
    position: relative; /* Necessário se quiser adicionar um overlay de cor por cima do padrão */
    overflow: hidden; /* Para garantir que o pseudo-elemento não vaze */
    background-blend-mode: multiply;
}

/* Overlay para dar um tom mais uniforme e escurecer a imagem de fundo, como na imagem */
header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(45, 73, 52, 0.85); /* Verde escuro com transparência, para escurecer o padrão */
    z-index: -1; /* Garante que o overlay fique abaixo do texto */
}

header::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 5px; /* Ajuste a altura conforme necessário */
    background-color: var(--cor-dourado);
    z-index: 3;
}

/* Os textos do cabeçalho precisam de um z-index maior para ficarem acima do overlay */
header h1, header p {
    position: relative;
    z-index: 2;
}


/* --- Estilo para o Título "Dona Maura" --- */
header h1 {
    font-family: 'Great Vibes', cursive; /* A fonte cursiva que já está importada no HTML */
    font-size: 5rem; /* Tamanho grande para um impacto visual */
    margin: 0; /* Remove margem padrão */
    background: -webkit-linear-gradient(45deg, var(--cor-dourado), #F0E68C);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 2px 2px 5px var(--cor-sombra-texto); /* Sombra de texto mais pronunciada */
    letter-spacing: 2px; /* Adiciona um pequeno espaçamento entre as letras para um toque de elegância */
    line-height: 1.2; /* Ajusta a altura da linha, se o título tiver mais de uma */
}

/* Estilo para o subtítulo "Uma celebração de 80 anos..." */
header p:nth-of-type(1) { /* Seleciona o primeiro parágrafo depois do h1 */
    font-family: 'Great Vibes', cursive; /* Usando a mesma fonte cursiva para o subtítulo */
    font-size: 1.8rem; /* Tamanho ligeiramente maior para o subtítulo */
    margin: 15px 0 0; /* Mais margem superior para espaçamento */
    color: var(--cor-branco); /* Cor branca para contraste */
    text-shadow: 1px 1px 3px var(--cor-sombra-texto);
}

/* Estilo para a data do aniversário */
header .data-aniversario {
    font-family: 'Great Vibes', cursive; /* Mantém a cursiva */
    font-size: 1.5rem; /* Tamanho um pouco maior */
    font-style: italic; /* Em itálico, como na imagem */
    margin-top: 20px; /* Margem superior para separar do subtítulo */
    color: var(--cor-cinza-claro); /* Cor cinza claro para suavidade */
    text-shadow: 1px 1px 2px rgba(0,0,0,0.2);
}

/* --- Estilos Gerais (Manter do original, mas verificar compatibilidade) --- */
body {
    font-family: 'Helvetica Neue', sans-serif; /* Fonte para o restante do texto */
    margin: 0;
    padding: 0;
    background-color: #F8F8F8;
    color: #333;
}

main {
    padding: 40px 20px;
    text-align: center;
}

main h2 {
    font-family: 'Great Vibes', cursive;
    font-size: 3rem;
    color: #4B6C54; /* Verde */
    margin-bottom: 40px;
}

.gallery-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
    max-width: 1200px;
    margin: 0 auto;
}

.gallery-item {
    display: flex;
    flex-direction: column;
    background-color: #FFFFFF;
    border: 5px solid #FFFFFF;
    border-radius: 8px;
    box-shadow: 0 6px 12px rgba(0,0,0,0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    padding-bottom: 15px;
}

.gallery-item:hover {
    transform: scale(1.05);
    box-shadow: 0 10px 20px rgba(0,0,0,0.2);
}

.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: pointer;
}

footer {
    background: var(--cor-verde-escuro) url('imagens/leaves.png') repeat;
    color: var(--cor-branco);
    text-align: center;
    padding: 60px 20px;
    position: relative;
    overflow: hidden;
    background-blend-mode: multiply;
    margin-top: 40px;
}

footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(45, 73, 52, 0.85);
    z-index: 1;
}

footer::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background-color: var(--cor-dourado);
    z-index: 3;
}

footer p {
    position: relative;
    z-index: 2;
    font-family: 'Great Vibes', cursive;
    font-size: 1.5rem;
    margin: 5px 0;
    color: #D4AF37; /* Dourado */
}

/* Lightbox Styles */
.lightbox {
    display: none; /* Hidden by default */
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    justify-content: center;
    align-items: center;
    display: flex; /* Use flexbox for centering */
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.lightbox.show {
    visibility: visible;
    opacity: 1;
}

.lightbox-content {
    max-width: 85%;
    max-height: 85%;
    border-radius: 8px;
    transition: transform 0.3s ease;
    transform: scale(0.95);
}

.lightbox.show .lightbox-content {
    transform: scale(1);
}

.close-btn {
    position: absolute;
    top: 20px;
    right: 35px;
    color: #fff;
    font-size: 45px;
    font-weight: bold;
    cursor: pointer;
    transition: color 0.2s ease;
}

.close-btn:hover {
    color: #D4AF37; /* Dourado on hover */
}

.download-btn {
    margin: 15px auto 0;
    display: block;
}

.btn-custom {
    background-color: #D4AF37;
    color: #FFFFFF;
    border-color: #D4AF37;
}

.btn-custom:hover {
    background-color: #b38f29;
    color: #FFFFFF;
    border-color: #b38f29;
}
