/*
Theme Name: TwentyTwenty Child
Template: twentytwenty
Version: 1.0
*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Open+Sans:ital,wght@0,300..800;1,300..800&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

body, button, input, select, textarea {
  font-family: 'Poppins', sans-serif !important;
}
body .entry-content > *:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.is-style-wide) {
  max-width: none;
  width: 100%;
}
.post-meta-edit-link-wrapper{
	display: none;
}
/* ========================= ============= ========================= */

/* =========================
   Definições: tamanhos de fonte (root)
   ========================= */
:root {
  --font5c-xs: 10px;
  --font5c-sm: 12px;
  --font5c-md: 14px;
  --font5c-normal: 16px;
  --font5c-lg: 18px;
  --font5c-xl: 20px;

  --font-h1: 22px;
  --font-h2: 20px;
  --font-h3: 18px;
  --font-h4: 16px;
  --font-h5: 14px;
  --font-h6: 12px;

  --font-p: 14px;
  --font-a: 14px;

  --space-heading-top: 0;      /* default margin-top para headings */
  --space-p-top: 0;            /* default margin-top para parágrafos */
}

/* =========================
   Classes utilitárias
   ========================= */
.font5c-xs { font-size: var(--font5c-xs); }
.font5c-sm { font-size: var(--font5c-sm); }
.font5c-md { font-size: var(--font5c-md); }
.font5c-normal { font-size: var(--font5c-normal); }
.font5c-lg { font-size: var(--font5c-lg); }
.font5c-xl { font-size: var(--font5c-xl); }

/* =========================
   Elementos semântico-tipográficos
   ========================= */
h1,
.heading-size-1 {
  font-size: var(--font-h1);
  font-weight: 800;
  line-height: 1.138888889;
	margin: 0 !important;
}

h2,
.heading-size-2 {
  font-size: var(--font-h2);
	margin: 0 !important;
}

h3,
.heading-size-3 {
  font-size: var(--font-h3);
	margin: 0 !important;
}

h4,
.heading-size-4 {
  font-size: var(--font-h4);
	margin: 0 !important;
}

h5,
.heading-size-5 {
  font-size: var(--font-h5);
	margin: 0 !important;
}

h6,
.heading-size-6 {
  font-size: var(--font-h6);
  letter-spacing: 0.03125em;
  text-transform: none;
	margin: 0 !important;
}

p {
  font-size: var(--font-p);
  line-height: 1.5;
  margin: 0 !important;
}

a {
  font-size: var(--font-a);
	text-decoration: none !important;
}
li {
	font-size: var(--font-p);
}
/* ========================= ============= ========================= */

/* ========================= HEADER ========================= */

/* Admin bar (logada) */
.admin-bar #site-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar #site-header { top: 46px; }
}

/* Ajuste header da página singular do TwentyTwenty */
.singular .entry-header { padding: 0; }

/* Header fixo - estado inicial: transparente */
#site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  width: 100%;
  z-index: 9999;
  background: transparent;
  border-bottom-color: transparent;
  box-shadow: none;
  display: flex;
  align-items: center;
  transition: background-color .2s ease, border-color .2s ease, box-shadow .2s ease;
}

/* Container interno */
header#site-header .header-inner{
  max-width: 1200px;
  padding: 0 16px !important;
  height: 90px;
  width: 100%;            /* corrigido: 100% (antes estava 100%px) */
  margin: 0 auto;
  display: flex;
  align-items: center;
}

/* Logo em “pílula” */
.header-logo-5c{
  width: 140px;
  min-height: 140px;
  height: 140px !important;
  background-color: #fff;
  border-radius: 0 0 10px 10px;
  border: 1px solid #36BCB5;
  align-content: center;
}
.site-logo img{ padding: 10px; }

/* Área do menu */
.header-menu-5c{
  width: 90%;
  display: flex;
  justify-content: center;
}

/* Wrapper do menu */
.menuprincipal{
  width: auto;
  display: flex;
}

/* Lista do menu (funciona com <ul class="menu"> ou apenas <ul>) */
.menuprincipal .menu,
.menuprincipal ul{
  list-style: none;
  display: flex;
  margin: 0 !important;
  padding: 0;
  gap: 20px;
}

/* Links do menu */
.menuprincipal li{
	list-style: none;
}
.menuprincipal .menu li a,
.header-menu-5c .menuprincipal ul li a{
  text-decoration: none !important;
  font-size: 16px;
  color: #E76608;
  transition: .3s;
}
.menuprincipal .menu li a:hover,
.menuprincipal ul li a:hover{
  color: #36BCB5;
}

/* CTA lateral (desktop) */
.header-btn-lateral{ align-content: center; margin-left: 30px; }
.header-btn-doe-agora{
  text-decoration: none;
  border: 1px solid #E76608;
  font-size: 16px;
  border-radius: 50px;
  padding: 8px 30px;
  transition: .3s;
  color: #E76608;
}
.header-btn-doe-agora:hover{
  border: 1px solid #36BCB5;
  color: #36BCB5;
}

/* Estado ao rolar: branco + sombra */
body.is-scrolled-5c #site-header{
  background: #fff;
  border-bottom: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 6px 24px rgba(0,0,0,.06);
}

/* ========== Mobile: hambúrguer + overlay + off-canvas ========== */

/* Hambúrguer (aparece só no mobile) */
.nav-toggle-5c{
  display: none;
  background: transparent; border: 0;
  width: 44px; height: 44px; padding: 0; cursor: pointer;
}
.nav-toggle-5c .bar{
  display: block; width: 24px; height: 2px; background: #E76608; margin: 6px auto;
  transition: transform .2s ease, opacity .2s ease;
}
.is-nav-open-5c .nav-toggle-5c .bar:nth-child(1){ transform: translateY(8px) rotate(45deg); }
.is-nav-open-5c .nav-toggle-5c .bar:nth-child(2){ opacity: 0; }
.is-nav-open-5c .nav-toggle-5c .bar:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }
/* Wrapper do gatilho (leva tudo para a direita) */
.nav-trigger-5c{
  display: none;              /* será exibido só no mobile */
  margin-left: auto;          /* empurra o bloco para a direita */
  align-items: center;
  gap: 8px;                   /* espaço entre "MENU" e o ícone */
}
@media (max-width: 1024px){
	.nav-trigger-5c{ display: inline-flex; }
  .nav-toggle-5c{ display: inline-block; }
  .header-menu-5c{
    width: auto;       /* em vez de 90% */
    flex: 0 0 auto;    /* não “rouba” espaço do hambúrguer */
  }

  /* Se precisar, pode reduzir um pouco o gap entre label e ícone */
  .nav-trigger-5c{
    gap: 6px;          /* opcional */
  }
	
.menuprincipal{
    position: fixed;
    background: #fff;          /* garante contraste */
	padding-top: 60px !important;
    padding-bottom: 220px;     /* espaço para a marca d'água não cobrir links */
  }

  .menuprincipal::after{
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 220px;             /* ajuste conforme a arte */
    background: url('https://5ccentrocultural.org.br/wp-content/uploads/2025/08/logo-5c.png')
                no-repeat center bottom / contain;
    opacity: .12;              /* transparência de “marca d’água” */
    pointer-events: none;      /* não bloqueia cliques nos links */
    z-index: 0;
  }

  /* Garante que o conteúdo do menu fique acima da marca d'água */
  .menuprincipal > *{
    position: relative;
    z-index: 1;
  }
}

/* Texto “MENU” discreto */
.nav-label-5c{
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  opacity: .7;                /* discreto */
  line-height: 1;
}

/* Ícone hambúrguer (sem auto-margin agora) */
.nav-toggle-5c{
  display: none;
  background: transparent; border: 0;
  width: 44px; height: 44px; padding: 0; cursor: pointer;
}

/* barras do ícone — permanece igual */
.nav-toggle-5c .bar{
  display: block; width: 24px; height: 2px; background: #E76608; margin: 6px auto;
  transition: transform .2s ease, opacity .2s ease;
}
.footer-info-section {
	text-align: center;
}

/* Mostrar no mobile */
@media (max-width: 1024px){
  .nav-trigger-5c{ display: inline-flex; }
  .nav-toggle-5c{ display: inline-block; }
}

/* Overlay */
.mobile-scrim-5c{
  position: fixed; inset: 0; background: rgba(0,0,0,.45);
  opacity: 0; pointer-events: none; transition: opacity .2s ease; z-index: 9998;
}
.is-nav-open-5c .mobile-scrim-5c{ opacity: 1; pointer-events: auto; }

/* Off-canvas (preserva sua estrutura atual) */
@media (max-width: 1024px){
  .nav-toggle-5c{ display: inline-block; }
  .header-btn-lateral{ display: none; } /* CTA do topo some no mobile */

  .menuprincipal{
    position: fixed; top: 0; right: 0;
    height: 100vh; width: 78vw; max-width: 360px;
    background: #fff; border-left: 1px solid rgba(0,0,0,.06);
    box-shadow: -24px 0 48px rgba(0,0,0,.18);
    padding: 24px 20px;
    display: block; /* vertical */
    transform: translateX(100%);
    transition: transform .25s ease;
    z-index: 9999;
  }
  .is-nav-open-5c .menuprincipal{ transform: translateX(0); }

  /* Links em coluna, alvos maiores */
  .menuprincipal .menu,
  .menuprincipal ul{
    display: block !important;
    margin: 0 !important;
    padding: 0;
  }
  .menuprincipal li a{
    display: block; padding: 12px 6px; font-size: 17px; color: #0E0E0E;
    border-bottom: 1px solid rgba(0,0,0,.06);
  }
  .menuprincipal li:last-child a{ border-bottom: 0; }
}

/* Oculta modal mobile padrão do TwentyTwenty (se estiver atrapalhando) */
@media (max-width: 1024px){
  .menu-modal{ display: none !important; }
}

/* (Opcional) cores claras quando header transparente */
@media (min-width: 1025px){
  body:not(.is-scrolled-5c) .menuprincipal li a { color:#fff; }
}
@media (max-width: 1024px){
  .is-nav-open-5c .menuprincipal li a { color:#0E0E0E !important; }
}
body:not(.is-scrolled-5c) .nav-toggle-5c .bar   { background:#fff; }
body:not(.is-scrolled-5c) .header-btn-doe-agora { color:#fff; border-color:#fff; }
/* >>> Deixa o texto "MENU" branco quando o header está transparente */
body:not(.is-scrolled-5c) .nav-label-5c { color: #fff; opacity: .85; }
/* (opcional) força a cor padrão quando o header fica branco ao rolar */
body.is-scrolled-5c .nav-label-5c { color: #0E0E0E; }

/* ========================= ============= ========================= */

/* ========================= FOOTER ========================= */
#site-footer.header-footer-group{
	display: flex;
	justify-content: center;
	border: none !important;
	padding-top: 80px;
	padding-bottom: 0;
}
#site-footer .site-logo{
	display: flex;
	justify-content: center;
}
#site-footer .site-logo a img{
	max-height: 13rem;
	margin: 0;
}
footer .footer-section-inner {
	width: 1200px;
	height: auto;
}
.footer-content-section{
	padding-bottom: 40px;
}
#site-footer .localizacao {
	padding-left: 40px;
	display: grid;
	gap: 8px;
}
#site-footer .localizacao svg{
	align-self: self-start;
	margin-top: 2px;
	margin-left: -4px;
    margin-right: 10px;
}
#site-footer .localizacao .endereco-1 {
	margin-bottom: 0;
}
.footer-info-section{
	padding: 25px 0;
	border-top: 1px solid #d9d9d9;
}
.footer-section-inner .menu-rodape-container ul{
	margin: 0;
	padding: 0;
}
.footer-section-inner .menu-rodape-container ul li{
	list-style: none;
	margin-left: 0;
	margin-top: 1.5rem;
}
.footer-map-embed{
	margin-right: 15px;
}
@media (max-width: 767px){
	#site-footer .localizacao {
		margin-top: 30px;
	}
	#site-footer .site-menu-footer {
		padding-left: 40px !important;
		padding-right: 40px !important;
		margin-top: 30px;
	}
	.footer-info-section{
		padding-left: 40px;
		padding-right: 40px;
		text-align: center;
	}
	.footer-map-embed{
		margin-left: -40px;
	}
}
/* ========================= ============= ========================= */

/* ========================= INSTITUCIONAIS: HERO BANNER ========================= */
.c-hero {
    position: relative;
    width: 100%;
    min-height: 770px;               /* altura desktop */
    display: flex;
    align-items: center;
    justify-content: center;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
	  --font-h1: clamp(32px, 6vw, 60px); /* título responsivo */
  	--font-p: clamp(16px, 2.5vw, 18px); /* subtítulo responsivo */
  }
  .c-hero::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(to bottom,
      rgba(0,0,0,0) 0%,
      rgba(0,0,0,0.65) 65%,
      rgba(0,0,0,0.85) 100%
    );
    pointer-events: none;
  }
  .c-hero__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    padding: 0 24px;
    text-align: center;
    color: #fff;
  }
  .c-hero__title {
    font-weight: 700;
    line-height: 1.1;
    margin: 0;
  }
  .c-hero__subtitle {
    --space-heading-to: 36px;
    font-weight: 500;
    line-height: 1.6;
  }

  /* alturas menores em tablets/mobiles */
  @media (max-width: 1024px) { .c-hero { min-height: 560px; } }
  @media (max-width: 768px)  { .c-hero { min-height: 480px; } }

  .c-container {
    width: 100%;
    max-width: 1200px;
    padding: 40px 24px;
    margin: 0 auto;
  }

/* ========================= ============= ========================= */

/* ========================= SECTION - FAÇA PARTE DA TRANSFORMAÇÃO ========================= */

.transformacao-hero{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  background-size:cover;
  background-position:center;
  background-attachment:scroll; /* fundo fixo */
  background-repeat: no-repeat !important;
  padding:0 1rem;
}
.transformacao-hero__overlay{
  position:absolute; inset:0;
  background:#000;
  pointer-events:none;
}
.transformacao-hero__inner{
  position:relative;
  max-width: 1000px;
}
.transformacao-hero__title{
  margin:0 0 .5rem 0;
  font-weight:800;
  line-height:1.15;
  font-size: clamp(22px, 3vw, 36px);
  color: #fff !important;
}
.transformacao-hero__text{
  margin:0 auto 1rem auto;
  font-size: var(--font5c-normal);
  line-height:1.6;
  max-width: 700px;
}
.transformacao-hero__btn{
  display:inline-flex;
  align-items:center;
  padding:15px 35px;
  border-radius:50px;
  gap:0.5rem; /* espaço entre texto e ícone */
  text-decoration:none;
  background:#36BCB5; /* ajuste para a paleta do seu site */
  color:#fff;
  font-weight:500;
  transition: transform .15s ease, opacity .15s ease;
}
.transformacao-hero__btn:hover{
  transform: translateY(-1px);
  opacity:.95;
}
.transformacao-hero__btn svg {
  width: 1em;
  height: 1em;
  fill: currentColor; /* herda a cor do texto */
}

/* ========================= ============= ========================= */

/* ========================= HOME - ELEMENTOR ========================= */
.background-blur{
  position: relative; /* necessário para o overlay funcionar */
  overflow: hidden !important;
}
.background-blur::before {
  content: "";
  position: absolute;
  inset: 0; /* cobre toda a seção */
  background: inherit; /* pega o mesmo background da seção */
  filter: blur(80px) brightness(1.2); /* intensidade do blur na imagem */
  transform: scale(1.2); /* evita bordas duras do blur */
  z-index: 0;
}

.background-blur > * {
  position: relative;
  z-index: 1; /* mantém texto/botões na frente */
}

/* ========================= FORMS ========================= */ 
.wpcf7-form {
	gap: 15px;
	display: grid;
}
.wpcf7-form input[type:'text']{
	width: 100% !important;
}
.wpcf7 input,
.wpcf7 select,
.wpcf7 textarea {
  border: 1px solid #ddd;
  border-radius: 6px;
}
.form-row {
	gap: 15px;
}
.wpcf7 .form-col{
	width: 100%;
}
select.wpcf7-form-control {
	width: 100%;
	padding: 15px 18px;
}
.wpcf7 .wpcf7-form input[type='submit']{
	width: 200px;
	background-color: #36BCB5 !important;
	border: none;
	border-radius: 50px;
	text-decoration: none;
	text-transform: none !important;
}
/* Section - Hero Banner */
#carouselExampleIndicators {
	margin-top: 116px;
}

.hero-item-slider {
	height: auto;
}