/* Variáveis CSS para cores e sombras */
:root {
    --primary-color: #1A3763; /* Azul marinho, similar ao degradê do banner */
    --secondary-color: #0F1E3D; /* Azul marinho mais escuro para hover/detalhes */
    --accent-color: #FFC107; /* Amarelo */
    --background-color: #f4f4f4; /* Cinza claro */
    --text-color: #333; /* Texto principal */
    --light-text-color: #666; /* Texto secundário */
    --white: #fff;
    --shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

/* Reset básico e estilos globais */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    color: var(--text-color);
    background-color: var(--background-color);
}

/* O container principal não pode ter padding lateral em mobile, pois o menu overlay vai sobrepor. */
/* Mas como você já tinha padding de 20px, vamos manter para as seções, e o header terá seu próprio container flex. */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px; /* Ajuste para que o header possa controlar seu próprio padding */
}

/* Header e Navbar - ATUALIZADO PARA MENU HAMBÚRGUER */
.header {
    background-color: var(--primary-color); /* Azul marinho */
    color: var(--white);
    padding: 15px 0;
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.header .container {
    display: flex;
    justify-content: space-between; /* Alinha logo à esquerda e menu/hambúrguer à direita */
    align-items: center;
    max-width: 1200px; /* Largura máxima do seu conteúdo */
    margin: 0 auto;
    padding: 0 20px; /* Padding interno para o container do header */
}

.site-logo {
    color: white;
    text-decoration: none;
    font-size: 1.5em;
    font-weight: bold;
}

/* ----------------------------------- */
/* ESTILOS PARA MOBILE PRIMEIRO (menor que 768px) */
/* ----------------------------------- */

.main-nav {
    display: none; /* Oculta o menu de navegação por padrão em mobile */
    flex-direction: column;
    position: fixed; /* Fixa o menu para cobrir a tela */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(13, 44, 108, 0.95); /* Fundo semi-transparente do seu azul (var --secondary-color com transparência) */
    z-index: 1001; /* Garante que o menu esteja acima de outros elementos */
    justify-content: center;
    align-items: center;
    text-align: center;
    /* Transição para um efeito suave ao abrir/fechar */
    transition: transform 0.3s ease-in-out;
    transform: translateX(100%); /* Esconde o menu para a direita */
    -webkit-overflow-scrolling: touch; /* Melhora o scroll em iOS */
    overflow-y: auto; /* Permite scroll se o conteúdo for maior que a tela */
}

/* Classe JavaScript para quando o menu estiver aberto */
.main-nav.open {
    display: flex; /* Exibe o menu quando a classe 'open' é adicionada */
    transform: translateX(0); /* Move o menu para dentro da tela */
}

.main-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

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

.nav-link { /* Usamos nav-link para os itens do menu, já que eles já existiam */
    color: white;
    text-decoration: none;
    font-size: 1.8em; /* Tamanho maior para facilitar o clique em mobile */
    padding: 10px 20px;
    display: block;
    /* Remover estilos de hover que talvez não funcionem bem como overlay */
    background-color: transparent;
    border-radius: 0;
    transition: background-color 0.3s ease;
}

.nav-link:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
}


/* Estilos do Botão Hambúrguer */
.hamburger-menu {
    display: flex; /* Exibe o hambúrguer em mobile */
    flex-direction: column;
    justify-content: space-around;
    width: 30px;
    height: 25px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1002; /* Garante que o hambúrguer esteja acima do menu */
}

.hamburger-menu .bar {
    width: 100%;
    height: 3px;
    background-color: white;
    border-radius: 5px;
    transition: all 0.3s ease-in-out;
}

/* Animação do Hambúrguer para um "X" (opcional, mas legal) */
.hamburger-menu.active .bar:nth-child(1) {
    transform: rotate(45deg) translate(5px, 8px);
}
.hamburger-menu.active .bar:nth-child(2) {
    opacity: 0;
}
.hamburger-menu.active .bar:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -8px);
}


/* ----------------------------------- */
/* MEDIA QUERY PARA DESKTOP (maior que 768px) */
/* ----------------------------------- */
@media screen and (min-width: 768px) {
    .hamburger-menu {
        display: none; /* Oculta o hambúrguer em desktop */
    }

    .main-nav {
        display: flex; /* Exibe o menu completo em desktop */
        position: static; /* Volta à posição normal */
        background-color: transparent; /* Remove o fundo do overlay */
        width: auto;
        height: auto;
        transform: translateX(0); /* Garante que não haja transformação */
        overflow-y: visible; /* Restaura o overflow padrão */
    }

    .main-nav ul {
        display: flex; /* Itens do menu lado a lado */
    }

    .main-nav li {
        margin: 0 15px; /* Espaçamento entre os itens */
    }

    .nav-link { /* Usa nav-link novamente para os itens do menu */
        font-size: 1em; /* Tamanho normal para desktop */
        padding: 5px 10px;
    }

    .nav-link:hover {
        background-color: var(--secondary-color); /* Azul marinho mais escuro */
        border-radius: 4px;
    }
}

/* Estilo para evitar scroll da página quando o menu mobile está aberto */
body.no-scroll {
    overflow: hidden;
}


/* Seções gerais */
.section {
    padding: 60px 0;
    text-align: center;
}

.section:nth-of-type(even) { /* Estilo para seções pares */
    background-color: var(--white);
}

p {
    margin-bottom: 15px;
    font-size: 1.1em;
}

/* Botões */
.btn {
    display: inline-block;
    background-color: var(--accent-color);
    color: var(--white);
    padding: 12px 25px;
    text-decoration: none;
    border-radius: 5px;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin-top: 20px;
}

.btn:hover {
    background-color: #e6b000; /* Um pouco mais escuro */
    transform: translateY(-2px);
}

/* Estilos específicos para a seção Hero (home) */
.hero {
    background-image: url('/static/img/hero_background.jpg'); /* Adicione uma imagem de fundo se desejar */
    background-size: cover;
    background-position: center;
    color: var(--white); /* Este é o estilo geral da seção hero */
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5);
    padding: 80px 20px;
}

/* Cor específica para a frase de destaque abaixo do título principal da home */
/* Isso seleciona o primeiro parágrafo que é filho direto de .container dentro de .hero */
/* Onde as cores dos textos 'Uma Nova Jornada para o Gabriel' e 'Juntos podemos reconstruir a vida do Gabriel após um acidente devastador' são controladas: */
/* 'Uma Nova Jornada para o Gabriel' (H1) é controlado por .banner-heading h1 { color: #FFFFFF; } */
/* 'Juntos podemos reconstruir a vida do Gabriel após um acidente devastador.' (parágrafo abaixo do H1) é controlado por .hero .container > p:first-of-type { color: #444; } */
.hero .container > p:first-of-type {
    color: #444; /* Um cinza escuro para contraste */
    text-shadow: none; /* Remove a sombra do texto se houver para melhor contraste no fundo claro */
}


/* Estilo para a faixa do cabeçalho (H1 e H2) */
.banner-heading {
    width: 100%; /* Largura total */
    max-width: 900px; /* Limite a largura para melhor visualização em telas grandes */
    margin: 30px auto; /* Centraliza a faixa e adiciona espaçamento vertical */
    padding: 15px 20px; /* Preenchimento interno */
    border-radius: 10px; /* Bordas arredondadas, como na imagem original */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra sutil para dar profundidade */
    display: flex;
    align-items: center; /* Centraliza o texto verticalmente */
    justify-content: center; /* Centraliza o texto horizontalmente */
    text-align: center; /* Garante que o texto dentro seja centralizado */

    /* Degradê azul marinho */
    background: linear-gradient(to right, #0F1E3D, #1A3763); /* Do azul marinho escuro para um pouco mais claro */
}

/* Estilo para o texto H1 dentro da faixa */
.banner-heading h1 {
    color: #FFFFFF; /* Texto branco */
    font-family: 'Luckiest Guy', cursive, sans-serif; /* Fonte principal, com fallbacks */
    font-size: 3.2em; /* Tamanho maior para H1 */
    text-transform: uppercase; /* Todas as letras maiúsculas */
    margin: 0; /* Remove margem padrão do H1 */
    line-height: 1.2; /* Altura da linha */
    text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.3); /* Sombra no texto para destacá-lo */
    letter-spacing: 2px; /* Espaçamento entre letras */
}

/* Estilo para o texto H2 dentro da faixa */
.banner-heading h2 {
    color: #FFFFFF; /* Texto branco */
    font-family: 'Luckiest Guy', cursive, sans-serif; /* Fonte principal, com fallbacks */
    font-size: 2.2em; /* Tamanho menor para H2 */
    text-transform: uppercase; /* Todas as letras maiúsculas */
    margin: 0; /* Remove margem padrão do H2 */
    line-height: 1.2; /* Altura da linha */
    text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.3); /* Sombra no texto para destacá-lo */
    letter-spacing: 1.5px; /* Espaçamento entre letras */
}


/* NOVIDADE: Layout de duas colunas para a seção Home */
.home-content-wrapper {
    display: flex;
    flex-wrap: wrap; /* Permite que as colunas quebrem para a próxima linha em telas menores */
    gap: 30px; /* Espaço entre as colunas */
    align-items: flex-start; /* Alinha os itens ao topo */
    margin-top: 40px;
    justify-content: center; /* Centraliza as colunas se houver espaço */
}

.home-carousel-column {
    flex: 2; /* O carrossel ocupa 2/3 do espaço */
    min-width: 300px; /* Largura mínima para o carrossel */
    max-width: 700px;
}

.home-fundraising-column {
    flex: 1; /* O painel de arrecadação ocupa 1/3 do espaço */
    min-width: 280px; /* Largura mínima para o painel */
    max-width: 400px;
}

/* Estilos para o Painel de Arrecadação na Home */
.fundraising-panel {
    background-color: var(--white);
    border-radius: 8px;
    box-shadow: var(--shadow);
    padding: 30px;
    text-align: center;
    height: 100%; /* Garante que o painel ocupe a altura disponível na coluna */
    display: flex;
    flex-direction: column;
    justify-content: space-between; /* Distribui o conteúdo verticalmente */
}

.panel-amount-raised {
    font-size: 2.5em;
    font-weight: bold;
    color: var(--primary-color); /* Agora usa o novo azul marinho */
    margin-bottom: 5px;
}

.panel-supporters {
    font-size: 1.1em;
    color: var(--light-text-color);
    margin-bottom: 20px;
}

.panel-progress-bar-container {
    width: 100%;
    background-color: #e0e0e0;
    border-radius: 10px;
    height: 20px;
    margin: 15px 0;
    overflow: hidden; /* Garante que a barra de progresso não vaze */
}

.panel-progress-bar {
    height: 100%;
    background-color: var(--primary-color); /* Agora usa o novo azul marinho */
    border-radius: 10px;
    text-align: center;
    color: var(--white);
    font-weight: bold;
    line-height: 20px; /* Centraliza o texto verticalmente */
    transition: width 0.8s ease-out; /* Animação para o preenchimento */
}

.panel-percentage {
    font-size: 1.5em;
    font-weight: bold;
    color: var(--primary-color); /* Agora usa o novo azul marinho */
    margin-bottom: 10px;
}

.panel-goal-amount {
    font-size: 1em;
    color: var(--light-text-color);
    margin-bottom: 30px;
}

/* Ajuste específico para o botão "Ajude o Gabriel" */
.panel-btn-donate {
    width: 100%; /* Ocupa toda a largura do painel */
    margin-top: auto; /* Empurra o botão para o final do flex container */
    background-color: #4CAF50; /* Cor verde original */
}

.panel-btn-donate:hover {
    background-color: #388E3C; /* Cor verde mais escura para o hover */
    transform: translateY(-2px);
}


/* Carrossel (ajustado para caber nas colunas) */
.carousel-container {
    position: relative;
    max-width: 100%; /* Agora ocupa 100% da largura da sua coluna */
    height: 700px;    /* Altura fixa para o carrossel */
    margin: 0 auto; /* Removido margin-top/bottom para flexbox gerenciar */
    overflow: hidden;
    border-radius: 8px;
    box-shadow: var(--shadow);
}

.carousel-slide {
    display: flex;
    height: 100%;
    /* REMOVIDA A TRANSIÇÃO CSS AQUI. O JS vai controlar a transição no swipe */
    /* transition: transform 0.5s ease-in-out; */
}

.carousel-image {
    width: 100%;
    height: 100%;
    flex-shrink: 0;
    display: block;
    object-fit: cover;
    object-position: center;
}

.carousel-dots {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
}

.dot {
    width: 10px;
    height: 10px;
    background-color: rgba(255, 255, 255, 0.7);
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.dot.active {
    background-color: var(--primary-color); /* Agora usa o novo azul marinho */
}

/* Estilos para os botões de navegação do carrossel */
.carousel-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5); /* Fundo semi-transparente */
    color: var(--white);
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 10; /* Acima das imagens */
    border-radius: 50%; /* Botão redondo */
    display: flex; /* Para centralizar o SVG */
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s ease;
}

.carousel-button:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.carousel-button.prev {
    left: 10px;
}

.carousel-button.next {
    right: 10px;
}

.carousel-button svg {
    width: 20px; /* Tamanho do ícone SVG */
    height: 20px;
    stroke: var(--white); /* Cor do ícone */
}

/* Estilos para a imagem centralizada na seção */
.centered-image-wrapper {
    text-align: center;
    margin: 30px auto;
    max-width: 600px; /* Largura máxima para a imagem */
}

.section-image {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: var(--shadow);
    margin-bottom: 10px; /* Espaço entre a imagem e a legenda */
}

.image-caption {
    font-style: italic;
    color: var(--light-text-color);
    font-size: 0.9em;
    text-align: center;
}

/* Seção de Doação */
.donate .qr-code-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    margin-top: 30px;
}

.qr-code {
    width: 200px;
    height: 200px;
    border: 5px solid var(--primary-color); /* Agora usa o novo azul marinho */
    border-radius: 8px;
}

.donate p {
    font-size: 1.1em;
}

/* Estilos para o botão de copiar CPF e feedback */
.btn-copy-pix {
    background-color: var(--primary-color); /* Usa a cor primária do tema */
    color: var(--white);
    padding: 8px 15px;
    margin-top: -5px; /* Ajuste para aproximar do texto do CPF */
    font-size: 0.9em;
    cursor: pointer;
    border: none;
    border-radius: 5px;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.btn-copy-pix:hover {
    background-color: var(--secondary-color); /* Cor mais escura no hover */
    transform: translateY(-1px);
}

.copy-feedback {
    display: block;
    margin-top: 5px;
    font-size: 0.9em;
    color: green; /* Cor para indicar sucesso */
    min-height: 1.2em; /* Reserva espaço para evitar shift de layout */
    visibility: hidden; /* Escondido por padrão */
}

.copy-feedback.show {
    visibility: visible; /* Visível quando a classe 'show' é adicionada */
}


/* Seção de Metas */
.goals {
    background-color: var(--background-color);
}

.progress-container {
    max-width: 800px;
    margin: 40px auto;
    padding: 20px;
    background-color: var(--white);
    border-radius: 8px;
    box-shadow: var(--shadow);
}

.current-raised-text {
    font-size: 1.4em;
    font-weight: bold;
    color: var(--primary-color); /* Agora usa o novo azul marinho */
    margin-bottom: 20px;
}

.goal-item {
    margin-bottom: 25px;
    text-align: left;
}

.goal-item h3 {
    color: var(--text-color);
    font-size: 1.2em;
    margin-bottom: 10px;
}

.progress-bar-container {
    width: 100%;
    background-color: #e0e0e0;
    border-radius: 10px;
    height: 20px;
    margin-bottom: 10px;
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    background-color: var(--accent-color); /* Mantido amarelo para diferenciação */
    border-radius: 10px;
    text-align: center;
    color: var(--white);
    font-weight: bold;
    line-height: 20px;
    transition: width 0.8s ease-out;
    position: relative; /* Para posicionar o texto de progresso */
}

.progress-text {
    position: absolute;
    right: 5px; /* Ajuste a posição do texto dentro da barra */
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.8em;
    white-space: nowrap; /* Evita quebra de linha */
    text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.goal-details {
    display: flex;
    justify-content: space-between;
    font-size: 0.95em;
    color: var(--light-text-color);
}

.remaining-text {
    font-size: 1.2em;
    font-weight: bold;
    color: var(--primary-color); /* Agora usa o novo azul marinho */
    margin-top: 30px;
}

/* Footer */
.footer {
    background-color: var(--text-color);
    color: var(--white);
    padding: 20px 0;
    text-align: center;
    font-size: 0.9em;
}

/* NOVO: Estilos para a seção Acompanhe */
.social-links {
    margin-top: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.social-links a {
    color: var(--primary-color); /* Cor principal para o ícone */
    text-decoration: none;
    transition: transform 0.3s ease;
}

.social-links a:hover {
    transform: translateY(-5px);
}

.social-links svg {
    width: 48px; /* Tamanho do ícone */
    height: 48px;
    fill: none;
    stroke: var(--primary-color); /* Cor da linha do ícone */
    stroke-width: 2;
    transition: stroke 0.3s ease;
}

.social-links a:hover svg {
    stroke: var(--secondary-color); /* Cor mais escura no hover */
}


/* Media Queries para Responsividade (EXISTENTES) */
@media (max-width: 768px) {
    /* As regras de menu responsivo já estão acima, na seção de header */

    .hero h1 {
        font-size: 2.2em;
    }

    .hero p {
        font-size: 1em;
    }

    /* Colunas da home se empilham em telas menores */
    .home-content-wrapper {
        flex-direction: column;
        align-items: center; /* Centraliza os itens empilhados */
    }

    .home-carousel-column,
    .home-fundraising-column {
        width: 100%;
        max-width: 400px; /* Limita a largura para não esticar demais em celulares */
    }

    .carousel-container {
        height: 400px; /* Ajusta a altura do carrossel para telas menores */
    }

    /* Mantém os botões de navegação visíveis no mobile */
    .carousel-button {
        padding: 8px; /* Diminui um pouco o botão no mobile */
    }
    .carousel-button svg {
        width: 16px; /* Diminui um pouco o ícone no mobile */
        height: 16px;
    }


    .fundraising-panel {
        padding: 20px;
    }

    .panel-amount-raised {
        font-size: 2em;
    }

    .panel-supporters {
        font-size: 1em;
    }

    .panel-percentage {
        font-size: 1.2em;
    }

    /* Responsividade para faixas de cabeçalho */
    .banner-heading {
        margin: 20px auto;
        padding: 10px 15px;
        border-radius: 8px;
    }
    .banner-heading h1 {
        font-size: 2.5em;
        letter-spacing: 1.5px;
    }
    .banner-heading h2 {
        font-size: 1.8em;
        letter-spacing: 1px;
    }

    /* Ajuste para a frase de destaque no mobile */
    .hero .container > p:first-of-type {
        color: #444; /* Mantém a cor escura no mobile */
    }

    /* Ajustes para o botão de copiar em mobile */
    .btn-copy-pix {
        width: auto; /* Permite que o botão se ajuste ao conteúdo */
        max-width: 150px; /* Limita a largura para não ficar muito grande */
    }
}

@media (max-width: 480px) {
    /* As regras de menu responsivo já estão acima, na seção de header */

    .banner-heading {
        margin: 15px auto;
        padding: 8px 10px;
        border-radius: 6px;
    }
    .banner-heading h1 {
        font-size: 1.8em;
        letter-spacing: 1px;
    }
    .banner-heading h2 {
        font-size: 1.4em;
        letter-spacing: 0.8px;
    }

    /* Ajuste para a frase de destaque no mobile pequeno */
    .hero .container > p:first-of-type {
        color: #444; /* Mantém a cor escura no mobile */
    }
}