/* ==========================================================================
   1. RESET & BASE
   ========================================================================== */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; scroll-padding-top:var(--header-height); }
body { font-family:var(--fonte-corpo); background-color:var(--branco); color:var(--cinza-800); line-height:1.6; transition:background-color var(--transicao-media),color var(--transicao-media); }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; height:auto; display:block; }
.container { max-width:var(--max-width); margin:0 auto; padding:0 20px; }
h1,h2,h3,h4,h5,h6 { font-family:var(--fonte-titulo); color:var(--cinza-900); line-height:1.2; transition:color var(--transicao-media); }

/* ==========================================================================
   2. BUTTONS
   ========================================================================== */
.btn-primary { display:inline-block; padding:14px 28px; background-color:var(--verde-amazonico); color:var(--branco); font-weight:600; font-size:16px; border:2px solid var(--verde-amazonico); border-radius:4px; cursor:pointer; transition:background-color var(--transicao-media),transform var(--transicao-media),border-color var(--transicao-media); }
.btn-primary:hover { background-color:var(--verde-hover); border-color:var(--verde-hover); transform:translateY(-2px); }
.btn-secondary { display:inline-block; padding:14px 28px; background-color:transparent; color:var(--branco); font-weight:600; font-size:16px; border:2px solid var(--branco); border-radius:4px; cursor:pointer; transition:background-color var(--transicao-media),color var(--transicao-media),transform var(--transicao-media); }
.btn-secondary:hover { background-color:var(--branco); color:var(--verde-amazonico); transform:translateY(-2px); }
.btn-accent { display:inline-block; padding:12px 24px; background-color:var(--laranja); color:var(--branco); font-weight:600; font-size:15px; border:none; border-radius:4px; cursor:pointer; transition:background-color var(--transicao-media),transform var(--transicao-media); }
.btn-accent:hover { background-color:var(--laranja-hover); transform:translateY(-2px); }
.btn-back { display:inline-flex; align-items:center; gap:6px; color:var(--verde-amazonico); font-weight:600; font-size:15px; margin-bottom:20px; transition:color var(--transicao-media); }
.btn-back:hover { color:var(--laranja); }

/* ==========================================================================
   3. HEADER & NAV
   ========================================================================== */
.site-header { background-color:var(--branco); box-shadow:var(--sombra-suave); position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--header-height); transition:background-color var(--transicao-media); }
.header-container { max-width:var(--max-width); margin:0 auto; padding:0 20px; height:100%; display:flex; align-items:center; justify-content:space-between; }
.site-logo { display:flex; align-items:center; }
.site-logo img { height:50px; display:block; }
.main-navigation { display:flex; align-items:center; justify-content:center; flex:1; gap:30px; }
.menu-links { display:flex; align-items:center; gap:25px; }
.menu-links li { position:relative; }
.menu-links a { text-decoration:none; color:var(--cinza-800); font-weight:600; font-size:15px; padding:8px 0; position:relative; transition:color var(--transicao-media); white-space:nowrap; display:flex; align-items:center; }
.menu-links a::after { content:''; position:absolute; left:50%; bottom:0; width:0; height:2px; background-color:var(--verde-amazonico); transition:width var(--transicao-media),left var(--transicao-media); }
.menu-links a:hover,.menu-links a.active { color:var(--verde-amazonico); }
.menu-links a:hover::after,.menu-links a.active::after { width:100%; left:0; }
.lang-switcher { display:flex; gap:4px; }
.lang-btn { background:none; border:1px solid var(--cinza-200); border-radius:3px; padding:6px 8px; font-size:12px; font-weight:700; cursor:pointer; color:var(--cinza-600); transition:color var(--transicao-media),border-color var(--transicao-media),background-color var(--transicao-media); font-family:var(--fonte-corpo); line-height:1; }
.lang-btn:hover { color:var(--verde-amazonico); border-color:var(--verde-amazonico); background-color:rgba(31,77,58,0.05); }
.menu-toggle { display:none; flex-direction:column; justify-content:space-between; width:28px; height:20px; background:transparent; border:none; cursor:pointer; z-index:1001; }
.menu-toggle .bar { width:100%; height:3px; background-color:var(--verde-amazonico); border-radius:2px; transition:transform var(--transicao-media),opacity var(--transicao-media); }

/* ==========================================================================
   4. DROPDOWN
   ========================================================================== */
.submenu { position:absolute; top:100%; left:0; background-color:rgba(255,255,255,0.88); box-shadow:var(--sombra-media); padding:10px 0; min-width:220px; border-radius:4px; opacity:0; visibility:hidden; transform:translateY(10px); transition:opacity var(--transicao-media),transform var(--transicao-media),visibility var(--transicao-media),background-color var(--transicao-media); }
.submenu a { display:block; padding:10px 20px; font-weight:500; font-size:14px; }
.submenu a::after { display:none; }
.submenu a:hover { background-color:var(--off-white); color:var(--verde-amazonico); }
.dropdown:hover .submenu { opacity:1; visibility:visible; transform:translateY(0); }

/* ==========================================================================
   5. HERO BANNER
   ========================================================================== */
.hero-banner { position:relative; width:100%; min-height:100vh; overflow:hidden; display:flex; justify-content:center; align-items:center; text-align:center; background-color:var(--verde-escuro); }
.video-parallax-container { position:absolute; top:0; left:0; width:100%; height:100%; z-index:1; }
.bg-video { width:100%; height:100%; object-fit:cover; pointer-events:none; }
.banner-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(rgba(0,0,0,0.4),rgba(15,43,32,0.7)); z-index:2; }
.banner-content { position:relative; z-index:3; max-width:850px; padding:0 20px; color:var(--branco); }
.banner-content h1 { font-size:48px; font-weight:800; line-height:1.2; margin-bottom:20px; color:var(--branco); }
.banner-content p { font-size:18px; line-height:1.6; margin-bottom:35px; color:rgba(255,255,255,0.9); }
.banner-buttons { display:flex; justify-content:center; gap:20px; }

/* ==========================================================================
   6. PAGE HEADER
   ========================================================================== */
.page-header { background:linear-gradient(135deg,var(--verde-escuro),var(--verde-amazonico)); color:var(--branco); padding:80px 0 60px; text-align:center; }
.page-header h1 { font-size:42px; color:var(--branco); margin-bottom:10px; }
.page-header .page-subtitle { font-size:18px; color:rgba(255,255,255,0.85); font-family:var(--fonte-corpo); font-weight:400; }
.page-content { padding:60px 0; }

/* ==========================================================================
   7. SECTIONS
   ========================================================================== */
.section-title { font-size:36px; text-align:center; margin-bottom:15px; color:var(--verde-escuro); }
.section-subtitle { text-align:center; font-size:17px; color:var(--cinza-600); margin-bottom:50px; }
.card-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:30px; }
.card { background-color:var(--branco); border-radius:8px; overflow:hidden; box-shadow:var(--sombra-suave); transition:transform var(--transicao-media),box-shadow var(--transicao-media); }
.card:hover { transform:translateY(-4px); box-shadow:var(--sombra-media); }
.card-img { width:100%; height:200px; object-fit:cover; }
.card-body { padding:25px; }
.card-body h3 { font-size:20px; margin-bottom:10px; color:var(--verde-amazonico); }
.card-body p { font-size:15px; color:var(--cinza-600); line-height:1.6; }
.card-body .card-link { display:inline-flex; align-items:center; gap:6px; color:var(--laranja); font-weight:600; font-size:14px; margin-top:15px; transition:color var(--transicao-media); }
.card-body .card-link:hover { color:var(--laranja-hover); }
.card-status { display:inline-block; position:absolute; top:15px; left:15px; padding:4px 12px; border-radius:20px; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; z-index:2; }
.card-status.andamento { background-color:var(--laranja-claro); color:var(--laranja-hover); }
.card-status.concluido { background-color:#E8F5E9; color:#2E7D32; }
.card { position:relative; }
.card-img { width:100%; height:200px; object-fit:cover; }

/* ==========================================================================
   8. SEARCH & FILTER
   ========================================================================== */
.search-filter { display:flex; gap:15px; max-width:600px; margin:30px auto 0; }
.search-filter input,.search-filter select { flex:1; padding:12px 16px; border:1px solid var(--cinza-200); border-radius:4px; font-family:var(--fonte-corpo); font-size:15px; background-color:var(--branco); color:var(--cinza-800); transition:border-color var(--transicao-media),background-color var(--transicao-media),color var(--transicao-media); }
.search-filter input:focus,.search-filter select:focus { outline:none; border-color:var(--verde-amazonico); }

/* ==========================================================================
   9. TEAM GRID
   ========================================================================== */
.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:30px; }
.team-card { text-align:center; padding:30px 20px; background-color:var(--branco); border-radius:8px; box-shadow:var(--sombra-suave); transition:transform var(--transicao-media),box-shadow var(--transicao-media); }
.team-card:hover { transform:translateY(-4px); box-shadow:var(--sombra-media); }
.team-card img { width:120px; height:120px; border-radius:50%; object-fit:cover; margin:0 auto 15px; }
.team-card h3 { font-size:18px; margin-bottom:5px; color:var(--verde-amazonico); }
.team-card .cargo { font-size:14px; color:var(--cinza-600); font-weight:500; }
.team-card .bio { font-size:14px; color:var(--cinza-600); margin-top:10px; line-height:1.5; }

/* ==========================================================================
   10. GALLERY
   ========================================================================== */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }
.gallery-item { position:relative; border-radius:8px; overflow:hidden; cursor:pointer; }
.gallery-item img { width:100%; height:220px; object-fit:cover; transition:transform var(--transicao-media); }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-item .gallery-overlay { position:absolute; bottom:0; left:0; right:0; padding:20px; background:linear-gradient(transparent,rgba(0,0,0,0.7)); color:var(--branco); font-weight:600; opacity:0; transition:opacity var(--transicao-media); }
.gallery-item:hover .gallery-overlay { opacity:1; }

/* ==========================================================================
   11. CONTACT
   ========================================================================== */
.contato-grid { display:grid; grid-template-columns:1fr 1fr; gap:50px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; margin-bottom:6px; font-weight:600; font-size:14px; color:var(--cinza-800); }
.form-group input,.form-group textarea { width:100%; padding:12px 16px; border:1px solid var(--cinza-200); border-radius:4px; font-family:var(--fonte-corpo); font-size:15px; background-color:var(--branco); color:var(--cinza-800); transition:border-color var(--transicao-media),background-color var(--transicao-media),color var(--transicao-media); }
.form-group input:focus,.form-group textarea:focus { outline:none; border-color:var(--verde-amazonico); }
.contato-info { padding:30px; background-color:var(--off-white); border-radius:8px; }
.contato-info p { font-size:16px; margin-bottom:20px; color:var(--cinza-800); line-height:1.6; }

/* ==========================================================================
   12. MIDIA
   ========================================================================== */
.midia-list { display:grid; gap:20px; }
.midia-item { display:flex; align-items:center; gap:20px; padding:20px; background-color:var(--branco); border-radius:8px; box-shadow:var(--sombra-suave); transition:transform var(--transicao-media); }
.midia-item:hover { transform:translateX(6px); }
.midia-item img.midia-logo { height:50px; width:auto; opacity:0.7; }
.midia-item .midia-info h3 { font-size:17px; margin-bottom:4px; color:var(--verde-amazonico); }
.midia-item .midia-info span { font-size:14px; color:var(--cinza-600); }

/* ==========================================================================
   13. PUBLICATIONS
   ========================================================================== */
.publication-item { display:flex; gap:25px; padding:25px; background-color:var(--branco); border-radius:8px; box-shadow:var(--sombra-suave); margin-bottom:20px; transition:transform var(--transicao-media); }
.publication-item:hover { transform:translateY(-2px); }
.publication-item .pub-thumb { width:150px; height:200px; object-fit:cover; border-radius:4px; }
.publication-item .pub-info h3 { font-size:20px; margin-bottom:8px; color:var(--verde-amazonico); }
.publication-item .pub-info p { font-size:15px; color:var(--cinza-600); margin-bottom:15px; }
.pub-download { display:inline-flex; align-items:center; gap:8px; padding:8px 16px; background-color:var(--laranja-claro); color:var(--laranja-hover); font-weight:600; font-size:14px; border-radius:4px; transition:background-color var(--transicao-media),color var(--transicao-media); }
.pub-download:hover { background-color:var(--laranja); color:var(--branco); }
.pub-downloads { display:flex; flex-wrap:wrap; gap:10px; }

/* ==========================================================================
   14. TEMAS GRID
   ========================================================================== */
.temas-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:25px; }
.tema-card { position:relative; padding:40px 30px; background-color:var(--branco); border-radius:8px; box-shadow:var(--sombra-suave); text-align:center; cursor:pointer; transition:transform var(--transicao-media),box-shadow var(--transicao-media); border-top:4px solid var(--laranja); }
.tema-card:hover { transform:translateY(-6px); box-shadow:var(--sombra-forte); }
.tema-card .tema-icon { font-size:48px; margin-bottom:15px; display:block; }
.tema-card h3 { font-size:22px; color:var(--verde-amazonico); margin-bottom:10px; }
.tema-card p { font-size:15px; color:var(--cinza-600); line-height:1.6; }



/* ==========================================================================
   16. TEMA CARD COM IMAGEM (escopo)
   ========================================================================== */
.tema-card-img { position:relative; border-radius:8px; overflow:hidden; cursor:pointer; height:300px; box-shadow:var(--sombra-suave); transition:transform var(--transicao-media),box-shadow var(--transicao-media); }
.tema-card-img:hover { transform:translateY(-4px); box-shadow:var(--sombra-media); }
.tema-card-img img { width:100%; height:100%; object-fit:cover; transition:transform var(--transicao-lenta); }
.tema-card-img:hover img { transform:scale(1.08); }
.tema-card-img .tema-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(15,43,32,0.85) 0%,rgba(15,43,32,0.3) 60%,transparent 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:30px; transition:background var(--transicao-media); }
.tema-card-img:hover .tema-overlay { background:linear-gradient(to top,rgba(15,43,32,0.9) 0%,rgba(31,77,58,0.5) 70%,transparent 100%); }
.tema-card-img .tema-overlay h3 { font-size:22px; color:var(--branco); margin-bottom:8px; font-family:var(--fonte-titulo); }
.tema-card-img .tema-overlay p { font-size:14px; color:rgba(255,255,255,0.85); margin-bottom:15px; line-height:1.5; display:none; }
.tema-card-img:hover .tema-overlay p { display:block; }
.tema-card-img .tema-overlay .tema-saiba-mais { display:inline-block; padding:8px 16px; background-color:var(--laranja); color:var(--branco); font-weight:600; font-size:13px; border-radius:4px; border:none; cursor:pointer; transition:background-color var(--transicao-media); align-self:flex-start; }
.tema-card-img .tema-overlay .tema-saiba-mais:hover { background-color:var(--laranja-hover); }

/* ==========================================================================
   17. PARTNERS & FINANCIADORES
   ========================================================================== */
.partners-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:30px; align-items:center; }
.partner-item { display:flex; justify-content:center; align-items:center; padding:20px; background-color:var(--branco); border-radius:8px; box-shadow:var(--sombra-suave); height:100px; transition:transform var(--transicao-media); }
.partner-item:hover { transform:translateY(-2px); }
.partner-item img { max-width:100%; max-height:60px; width:auto; height:auto; filter:grayscale(30%); opacity:0.7; transition:opacity var(--transicao-media),filter var(--transicao-media); }
.partner-item:hover img { opacity:1; filter:grayscale(0%); }

/* ==========================================================================
   18. SECTION HIGHLIGHT (bg claro)
   ========================================================================== */
.section-highlight { background-color:var(--fundo-claro); }
.section-highlight .section-title { color:var(--verde-escuro); }

/* ==========================================================================
   19. HERO LOGO (sobre nome)
   ========================================================================== */
.hero-logo { height:80px; margin-bottom:20px; filter:brightness(0) invert(1); }

/* ==========================================================================
   20. MODAL
   ========================================================================== */
.modal-overlay { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.6); z-index:2000; justify-content:center; align-items:center; padding:20px; }
.modal-overlay.open { display:flex; }
.modal-content { background-color:var(--branco); border-radius:8px; max-width:600px; width:100%; max-height:80vh; overflow-y:auto; padding:40px; position:relative; animation:slideUp 0.3s ease; }
.modal-close { position:absolute; top:15px; right:15px; background:none; border:none; font-size:28px; cursor:pointer; color:var(--cinza-600); transition:color var(--transicao-media); }
.modal-close:hover { color:var(--cinza-900); }
.modal-content h2 { font-size:28px; color:var(--verde-amazonico); margin-bottom:15px; }
.modal-content p { font-size:16px; color:var(--cinza-600); line-height:1.6; }

/* ==========================================================================
   17. EMPTY STATE
   ========================================================================== */
.empty-state { text-align:center; padding:60px 20px; color:var(--cinza-400); }
.empty-state p { font-size:18px; }

/* ==========================================================================
    21. CTA SECTION
    ========================================================================== */
.cta-section {
    background-image: url('../img/home/junte-se-a-nos-agora.webp');
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
    isolation: isolate;
}
.cta-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: rgba(31, 77, 58, 0.65);
    z-index: 0;
}
.cta-section > * {
    position: relative;
    z-index: 1;
}

/* ==========================================================================
    22. RESPONSIVE
    ========================================================================== */
@media (max-width:768px) {
    .menu-toggle { display:flex; order:2; }
    .lang-switcher { order:1; }
    .main-navigation { justify-content:flex-end; gap:15px; }
    .menu-links { position:fixed; right:-100%; top:0; width:280px; height:100vh; background-color:var(--branco); box-shadow:-4px 0 10px rgba(0,0,0,0.08); flex-direction:column; padding:100px 30px 30px; gap:25px; transition:right 0.3s ease; }
    .menu-links.active { right:0; }
    #site-header .menu-links.active a,
    #site-header .menu-links.active .submenu a { color:var(--verde-amazonico); }
    .menu-links a::after { display:none; }
    #site-header .submenu { position:relative; top:0; box-shadow:none; background-color:var(--cinza-100); padding-left:15px; margin-top:5px; display:none; opacity:1; visibility:visible; transform:none; }
    #site-header.site-header--transparent .submenu { background-color:var(--cinza-100); }
    #site-header .dropdown.open .submenu { display:block; }
    .menu-toggle.open { position:fixed; top:30px; right:15px; }
    #site-header .menu-toggle.open .bar { background-color:var(--verde-amazonico); }
    .menu-toggle.open .bar:nth-child(1) { transform:translateY(9px) rotate(45deg); }
    .menu-toggle.open .bar:nth-child(2) { opacity:0; }
    .menu-toggle.open .bar:nth-child(3) { transform:translateY(-9px) rotate(-45deg); }
    .hero-banner { min-height:85vh; }
    .banner-content h1 { font-size:30px; }
    .banner-content p { font-size:15px; }
    .banner-buttons { flex-direction:column; gap:12px; }
    .page-header { padding:60px 0 40px; }
    .page-header h1 { font-size:30px; }

    .contato-grid { grid-template-columns:1fr; gap:30px; }
    .publication-item { flex-direction:column; }
    .publication-item .pub-thumb { width:100%; height:auto; max-height:250px; }
    .search-filter { flex-direction:column; gap:10px; }
    .card-grid { grid-template-columns:1fr; }
    .team-grid { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
    .temas-grid { grid-template-columns:1fr; }
    .tema-card-img { height:250px; }
    .midia-item { flex-direction:column; text-align:center; }
    .partners-grid { grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:15px; }
    .partner-item { height:80px; padding:15px; }
    .hero-logo { height:50px; }
    .header-container { padding:0 15px; }
    .site-logo img { height:40px; }
}
