/* --- VARIAVEIS DE CORES LEVE E JARDIM SUAVE --- */
:root {
    --verde-floresta: #627D5E; /* Tom Verde principal para destaque e botões */
    --rosa-antigo: #C79E8B; /* Rosa mais suave e pêssego/antigo para detalhes */
    --branco-creme: #FAF7F4; /* Fundo principal, super leve */
    --bege-claro: #F5EFE9; /* Fundo do card principal, quase branco */
    --verde-esmeralda: #3C4A3C; /* Cor principal do texto (Escuro, mas com tom verde) */
    --fundo-contagem: #F0E6E1; /* Fundo da contagem regressiva, Rosa Claro/Pêssego */
    --quadrado-contagem: #F5EFE9; /* NOVO: Fundo suave para os quadradinhos do timer */
}

/* Padding no body para compensar a navbar fixa */
body {
    font-family: 'Lato', sans-serif;
    background-color: var(--branco-creme);
    color: var(--verde-esmeralda); 
    padding-top: 65px;
}

h1, h2, h3, h4, .names-title, .countdown-title {
    font-family: 'Playfair Display', serif;
    font-weight: 500; 
}

/* --- HERO SECTION (Maior e Flutuante) --- */
.hero-section {
    min-height: 100vh;
    background-color: var(--branco-creme); 
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem;
    position: relative; /* CRÍTICO: Para posicionar as flores absolutamente dentro dela */
    overflow: hidden; /* Garante que as flores não "vazem" */
}

/* --- ESTILO PARA AS FLORES DE CANTO --- */
/* --- HERO SECTION (Certifique-se de que o position: relative está aqui) --- */
.hero-section {
    min-height: 100vh;
    /* ... outras propriedades ... */
    position: relative; /* Mantenha! */
    overflow: hidden; /* Mantenha! Se quiser que elas "invadam" fora do scroll, pode remover, mas pode gerar barra de rolagem horizontal */
}

/* --- ESTILO PARA AS FLORES DE CANTO (Regras ajustadas para serem grandes e estendidas) --- */
.flower-corner {
    position: absolute;
    width: 500px; /* MUITO MAIOR: Ajuste o tamanho para ser bem grande */
    height: 600px; /* MUITO MAIOR: Ajuste o tamanho */
    background-size: contain; 
    background-repeat: no-repeat;
    pointer-events: none; 
    z-index: 5; 
}

.top-left {
    top: 0px; /* Valor negativo para "sair" para cima, seguindo a linha amarela */
    left: 0px; /* Valor negativo para "sair" para a esquerda, seguindo a linha amarela */
    background-image: url('ramosfundo.png'); 
}

.top-right {
    top: -100px; /* Valor negativo para "sair" para cima */
    right: -150px; /* Valor negativo para "sair" para a direita */
    /* *** SUBSTITUA PELA SUA IMAGEM DE FLORES DIREITA (PNG TRANSPARENTE)! *** */
    background-image: url('');
    transform: scaleX(-1); 
}


/* Card central flutuante */
.hero-content {
    background-color: var(--bege-claro); 
    border-radius: 15px;
    padding: 60px 40px; 
    max-width: 700px; 
    width: 90%; 
    text-align: center;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); 
    transition: transform 0.3s ease;
    z-index: 10; /* Garante que o conteúdo fique acima das flores */
    position: relative; 
}

.hero-content:hover {
    transform: translateY(-2px); 
}

.save-the-date-title {
    font-family: 'Lato', sans-serif;
    color: var(--rosa-antigo); 
    font-size: 1rem; 
    letter-spacing: 6px; 
    margin-bottom: 1rem;
    text-transform: uppercase;
    font-weight: 400; 
}

.names-title {
    font-family: 'Playfair Display', serif;
    color: var(--verde-floresta); 
    font-size: 5.5rem; 
    line-height: 1.1;
    margin-bottom: 1.5rem;
    font-weight: 400;
}

.names-title .ampersand {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-size: 0.6em; 
    vertical-align: middle;
    padding: 0 10px;
    color: var(--rosa-antigo); 
}

.date-text {
    font-family: 'Lato', sans-serif;
    color: var(--verde-esmeralda); 
    font-size: 1.8rem; 
    font-weight: 300; 
    margin-top: 0.8rem;
    letter-spacing: 3px;
}

.hero-content .lead {
    color: var(--verde-esmeralda);
    font-size: 1rem; 
    margin-top: 1.5rem;
    margin-bottom: 2rem;
}

/* Botão na hero section */
.hero-section .custom-btn-color {
    background-color: var(--verde-floresta) !important;
    border-color: var(--verde-floresta) !important;
    color: white !important;
    font-weight: 500;
    padding: 12px 30px; 
    font-size: 1rem;
    border-radius: 50px;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.hero-section .custom-btn-color:hover {
    background-color: var(--rosa-antigo) !important; 
    border-color: var(--rosa-antigo) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}


/* --- SEÇÃO HISTÓRIA --- */
#historia {
    padding-top: 5rem;
    padding-bottom: 5rem;
}
#historia h2 {
    color: var(--verde-floresta); 
    margin-bottom: 3rem;
    font-weight: 600;
}
#historia h3 {
    color: var(--rosa-antigo); 
    font-weight: 400;
}
#historia a.custom-btn-color {
    background-color: var(--rosa-antigo) !important; 
    border-color: var(--rosa-antigo) !important;
    color: white !important;
    font-weight: 500;
    border-radius: 50px;
}
#historia a.custom-btn-color:hover {
    background-color: var(--verde-floresta) !important; 
    border-color: var(--verde-floresta) !important;
}

/* --- SEÇÃO EVENTO --- */
#evento h2 {
    color: var(--verde-floresta);
    font-weight: 600;
}
#evento h3 {
    color: var(--rosa-antigo);
    font-weight: 400;
}

/* --- NAVBAR --- */
.navbar-light .navbar-nav .nav-link {
    color: var(--verde-esmeralda); 
    font-weight: 400;
    margin: 0 12px;
    transition: color 0.3s;
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
}

.navbar-light .navbar-nav .nav-link:hover {
    color: var(--rosa-antigo); 
}

/* --- CONTAGEM REGRESSIVA (SUAVE) --- */
.countdown-section {
    background-color: var(--fundo-contagem); 
    color: var(--verde-esmeralda); 
    padding: 3rem 0;
}

.countdown-title {
    color: var(--verde-floresta); 
    font-size: 2rem;
    margin-bottom: 1.5rem;
    font-weight: 600; 
}

.time-box {
    background-color: var(--quadrado-contagem); /* Fundo suave para os quadradinhos */
    border-radius: 8px;
    padding: 10px 15px;
    margin: 0 5px;
    min-width: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.time-number {
    font-family: 'Playfair Display', serif;
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 1;
    color: var(--verde-esmeralda); /* Números em Verde Esmeralda */
}

.time-label {
    font-family: 'Lato', sans-serif;
    font-size: 0.7rem;
    margin-top: 5px;
    letter-spacing: 0.5px;
    font-weight: 300;
    text-transform: uppercase;
    color: var(--verde-esmeralda); 
}

/* --- LISTA DE PRESENTES --- */
/* Garante que o preço use a cor principal do tema, ignorando o text-success do Bootstrap */
#presentes .card-text.fw-bold { 
    color: var(--verde-floresta) !important; 
}
.presente-card {
    border: 1px solid var(--bege-claro);
    border-radius: 10px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.presente-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.08);
}

.presente-card .card-img-top {
    height: 180px;
    object-fit: cover;
}

.btn-presentear {
    background-color: var(--rosa-antigo); 
    border-color: var(--rosa-antigo);
    color: white;
    font-weight: 500;
    border-radius: 50px;
    transition: background-color 0.3s;
}

.btn-presentear:hover {
    background-color: var(--verde-floresta); 
    border-color: var(--verde-floresta);
    color: white;
}

/* --- RSVP --- */
#rsvp {
    background-color: var(--verde-floresta); 
}
#rsvp .custom-btn-color-text {
    background-color: var(--branco-creme) !important;
    border-color: var(--branco-creme) !important;
    color: var(--verde-floresta) !important; 
    font-weight: bold;
    border-radius: 50px;
    transition: background-color 0.3s;
}
#rsvp .custom-btn-color-text:hover {
    background-color: var(--rosa-antigo) !important; 
    border-color: var(--rosa-antigo) !important;
    color: white !important;
}

/* --- MODAL PIX --- */
.modal-content {
    border-radius: 10px;
}
.btn-copy {
    background-color: var(--verde-floresta);
    color: white;
    border-color: var(--verde-floresta);
}
.btn-copy:hover {
    background-color: var(--rosa-antigo);
    color: white;
    border-color: var(--rosa-antigo);
}

/* --- RESPONSIVIDADE --- */
@media (max-width: 500px) {
    
    /* 1. ESCONDER O MENU DE DESKTOP E AS FLORES (Conforme pedido anterior) */
    .navbar { 
        display: none !important; /* Esconde o menu de DESKTOP (se essa for a classe) */
    }
    .flower-corner {
        display: none !important;
    }
    
    /* 2. AJUSTE PARA O MENU HAMBÚRGUER (SE ESTIVER VISÍVEL) */
    /* Se o menu hambúrguer estiver sendo mostrado, ele geralmente está dentro de uma DIV ou <nav> 
       que pode precisar de menos padding. */
    .navbar-toggler {
        /* Reduz o padding (preenchimento) para diminuir a altura do botão */
        padding: 5px 10px !important; 
        line-height: 1; /* Garante que o ícone do hambúrguer não force a altura */
    }
    
    /* Se você tem um container que envolve o menu do celular, ajuste o padding dele. */
    .container-fluid {
        padding-top: 10px; /* Reduz o espaço acima do menu */
        padding-bottom: 10px; /* Reduz o espaço abaixo do menu */
    }

    /* 3. Reduz o padding da própria tag de navegação se ela for a responsável pela altura */
    /* Se a sua tag <nav> for visível em mobile, use: */
    nav.navbar-mobile {
        padding-top: 5px; 
        padding-bottom: 5px;
    }
    
    /* Outros ajustes que já fizemos: */
    .hero-section {
        padding-top: 20px;
    }
}