/* =========================================================
   PORTAL AMAMENTAÇÃO — PÁGINAS INTERNAS V3
   Estende home-v3.css com componentes de páginas internas.
   Carregado em todas as páginas que NÃO são front-page.
   ========================================================= */

/* Container e tokens já vêm de home-v3.css se ambos forem enfileirados.
   Mas em páginas internas só carregamos pages-v3.css → re-declaramos os tokens. */

:root {
  --terracota: #B5644E;
  --terracota-dark: #8B4A38;
  --terracota-soft: #D08A75;
  --mostarda: #E2A16D;
  --mostarda-soft: #F0BC8E;
  --verde: #649287;
  --verde-claro: #8BBEB9;
  --verde-mint: #B5D6D2;
  --creme: #FFE8AB;
  --creme-soft: #FFF1C9;
  --offwhite: #FFF6E2;
  --bege: #FAEBD0;
  --tinta: #3A2A22;
  --tinta-soft: #6B4A3D;

  --r-sm: 12px;
  --r-md: 20px;
  --r-lg: 32px;
  --r-pill: 999px;
  --shadow-soft: 0 12px 32px rgba(139, 74, 56, 0.12);
  --shadow-card: 0 18px 48px rgba(139, 74, 56, 0.14);
  --shadow-strong: 0 28px 70px rgba(139, 74, 56, 0.22);
}

/* Container compartilhado */
.h3-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 600px) {
  .h3-container { padding: 0 20px; }
}

/* Prevenção global de overflow de imagens */
img { max-width: 100%; height: auto; }

/* Tipografia compartilhada */
.h3-section-title {
  font-family: 'Nunito', 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.8rem, 3.6vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--terracota-dark);
  text-wrap: balance;
}
.h3-section-title em { font-style: normal; color: var(--mostarda); }
.h3-section-lead {
  font-size: 1.08rem;
  color: var(--tinta-soft);
  max-width: 60ch;
  margin-top: 14px;
  text-wrap: pretty;
}
.h3-section-header { margin-bottom: 40px; }
.h3-section-header > * + * { margin-top: 14px; }

/* Pills */
.h3-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 18px;
  border-radius: var(--r-pill);
  font-weight: 800;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.h3-pill--cream { background: var(--creme); color: var(--terracota-dark); }
.h3-pill--mint  { background: var(--verde-mint); color: var(--terracota-dark); }
.h3-pill--mustard { background: var(--mostarda); color: var(--tinta); }
.h3-pill--green { background: var(--verde); color: var(--tinta); }
.h3-pill--light { background: rgba(255, 246, 226, 0.25); color: var(--offwhite); }

/* Botões */
.h3-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: 'Nunito', 'Nunito Sans', system-ui, sans-serif;
  font-weight: 800;
  font-size: 0.98rem;
  padding: 14px 26px;
  border: none;
  border-radius: var(--r-pill);
  cursor: pointer;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}
.h3-btn svg { width: 18px; height: 18px; flex-shrink: 0; }
.h3-btn:hover { transform: translateY(-2px); }
.h3-btn--primary { background: var(--mostarda); color: var(--tinta); box-shadow: 0 8px 20px rgba(226,161,109,0.4); }
.h3-btn--secondary { background: var(--terracota-dark); color: var(--offwhite); box-shadow: 0 8px 20px rgba(139,74,56,0.3); }
.h3-btn--ghost { background: transparent; color: var(--terracota-dark); border: 2px solid var(--terracota-dark); }
.h3-btn--ghost:hover { background: var(--terracota-dark); color: var(--offwhite); }
.h3-btn--whatsapp { background: #25D366; color: #fff; }
.h3-btn--cream { background: var(--creme); color: var(--terracota-dark); }

/* =========================================================
   PAGE HERO (variantes: warm / mint / cream / neutral)
   ========================================================= */
.h3-page-hero {
  position: relative;
  padding: 80px 0 120px;
  overflow: hidden;
  isolation: isolate;
}
.h3-page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -2;
}
.h3-page-hero--warm::before { background: linear-gradient(135deg, #B5644E, #8B4A38); }
.h3-page-hero--mint::before { background: linear-gradient(135deg, #649287, #4F786E); }
.h3-page-hero--cream::before { background: linear-gradient(135deg, #E2A16D, #C8845A); }
.h3-page-hero--neutral::before { background: linear-gradient(135deg, #8B4A38, #6B3526); }

/* Wave divider no final do hero */
.h3-page-hero::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 80px;
  background: var(--offwhite);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 90' preserveAspectRatio='none'><path d='M0,40 C 240,80 480,0 720,30 C 960,60 1200,90 1440,50 L1440,90 L0,90 Z' fill='black'/></svg>") no-repeat center bottom/100% 100%;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 90' preserveAspectRatio='none'><path d='M0,40 C 240,80 480,0 720,30 C 960,60 1200,90 1440,50 L1440,90 L0,90 Z' fill='black'/></svg>") no-repeat center bottom/100% 100%;
}

/* Gotinhas decorativas no hero */
.h3-page-hero__drops {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}
.h3-page-hero__drop {
  position: absolute;
  background: var(--creme);
  opacity: 0.18;
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  transform: rotate(-25deg);
  animation: h3-drop-float 7s ease-in-out infinite;
}
.h3-page-hero__drop:nth-child(1) { top: 14%; left: 6%;  width: 60px; height: 76px; animation-delay: 0s; }
.h3-page-hero__drop:nth-child(2) { top: 52%; left: 18%; width: 32px; height: 42px; animation-delay: 1s; }
.h3-page-hero__drop:nth-child(3) { top: 22%; right: 16%; width: 44px; height: 56px; animation-delay: 2s; }
.h3-page-hero__drop:nth-child(4) { bottom: 28%; right: 8%; width: 70px; height: 88px; animation-delay: 3s; }
.h3-page-hero__drop:nth-child(5) { bottom: 14%; left: 38%; width: 26px; height: 34px; animation-delay: 1.5s; opacity: 0.12; }
@keyframes h3-drop-float {
  0%, 100% { transform: rotate(-25deg) translateY(0); }
  50% { transform: rotate(-20deg) translateY(-22px); }
}

/* ── Brilhos decorativos nos heroes de páginas ───────────────────────── */
.h3-page-hero__glows {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.h3-page-hero__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(2px);
  animation: h3-page-glow-drift 9s ease-in-out infinite;
}

/* Cor dos brilhos por variante de hero */
.h3-page-hero--warm  .h3-page-hero__glow,
.h3-page-hero--cream .h3-page-hero__glow { background: radial-gradient(circle, rgba(255,232,150,0.90), transparent 68%); }
.h3-page-hero--neutral  .h3-page-hero__glow { background: radial-gradient(circle, rgba(255,205,165,0.88), transparent 68%); }
.h3-page-hero--mint     .h3-page-hero__glow { background: radial-gradient(circle, rgba(165,232,218,0.88), transparent 68%); }
.h3-page-hero--mostarda .h3-page-hero__glow { background: radial-gradient(circle, rgba(255,240,140,0.90), transparent 68%); }

/* Posições */
.h3-page-hero__glow:nth-child(1) { top: 6%;     left: 4%;   width: 72px; height: 72px; opacity: 0.56; animation-delay: 0s;   }
.h3-page-hero__glow:nth-child(2) { top: 20%;    right: 38%; width: 34px; height: 34px; opacity: 0.42; animation-delay: 2.2s; }
.h3-page-hero__glow:nth-child(3) { top: 60%;    left: 14%;  width: 58px; height: 58px; opacity: 0.40; animation-delay: 3.8s; }
.h3-page-hero__glow:nth-child(4) { top: 8%;     right: 10%; width: 50px; height: 50px; opacity: 0.50; animation-delay: 1.4s; }
.h3-page-hero__glow:nth-child(5) { bottom: 28%; right: 5%;  width: 84px; height: 84px; opacity: 0.36; animation-delay: 5.2s; }
.h3-page-hero__glow:nth-child(6) { bottom: 18%; left: 30%;  width: 30px; height: 30px; opacity: 0.36; animation-delay: 2s;   }
.h3-page-hero__glow:nth-child(7) { top: 42%;    left: 46%;  width: 20px; height: 20px; opacity: 0.30; animation-delay: 4.5s; }

@keyframes h3-page-glow-drift {
  0%, 100% { transform: scale(0.82) translateY(0); }
  50%      { transform: scale(1.18) translateY(-10px); }
}

/* ── Forma SVG decorativa grande — diferencia visualmente cada hero ──── */
.h3-page-hero__shape {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  overflow: visible;
}
/* Quem Somos (cream): arco de círculo canto superior direito — solidez/tradição */
#quem-somos       .h3-page-hero__shape { top: -100px; right: -60px;  width: 560px; height: 560px; }
/* Quero Doar (mostarda): blob orgânico canto inferior direito — abundância */
#quero-doar       .h3-page-hero__shape { bottom: -50px; right: -50px; width: 620px; height: 520px; }
/* Preciso de Ajuda (mint): arcos concêntricos canto inferior direito — acolhimento */
#preciso-de-ajuda .h3-page-hero__shape { bottom: -30px; right: -30px; width: 640px; height: 640px; }
/* Contato (mint): dois círculos sobrepostos (Venn) — conexão/comunidade */
#contato          .h3-page-hero__shape { top: 50%; left: 50%; transform: translate(-50%, -50%); width: 480px; height: 480px; }
/* Mitos (neutral): anel/auréola canto superior esquerdo — questionamento/mistério */
#mitos-verdades   .h3-page-hero__shape { top: -80px; left: -80px; width: 580px; height: 580px; }

@media (max-width: 768px) {
  .h3-page-hero__glow:nth-child(3),
  .h3-page-hero__glow:nth-child(5),
  .h3-page-hero__glow:nth-child(7) { display: none; }
  .h3-page-hero__shape { display: none; }
}

.h3-page-hero__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.h3-page-hero__content { color: var(--offwhite); }
.h3-page-hero__content h1 {
  font-family: 'Nunito', 'Nunito Sans', system-ui, sans-serif;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 900;
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 18px 0;
  color: var(--offwhite);
  text-wrap: balance;
}
.h3-page-hero__content p {
  font-size: 1.1rem;
  line-height: 1.55;
  color: rgba(255, 246, 226, 0.92);
  max-width: 56ch;
  text-wrap: pretty;
}
.h3-page-hero__content .h3-pill { margin-bottom: 6px; }

.h3-page-hero__actions {
  display: flex;
  gap: 14px;
  margin-top: 28px;
  flex-wrap: wrap;
}
.h3-page-hero__actions .h3-btn--secondary {
  background: var(--offwhite);
  color: var(--terracota-dark);
}
.h3-page-hero__actions .h3-btn--ghost {
  color: var(--offwhite);
  border-color: rgba(255,246,226,0.5);
}
.h3-page-hero__actions .h3-btn--ghost:hover {
  background: rgba(255,246,226,0.15);
  color: var(--offwhite);
}

.h3-page-hero__art {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.h3-page-hero__mascot {
  width: 78%;
  max-width: 320px;
  filter: drop-shadow(0 24px 36px rgba(0,0,0,0.28));
  animation: h3-mascot-float 5s ease-in-out infinite;
}
@keyframes h3-mascot-float {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50% { transform: translateY(-14px) rotate(2deg); }
}
.h3-page-hero__badge {
  position: absolute;
  bottom: 6%;
  right: 4%;
  background: var(--offwhite);
  padding: 16px 22px;
  border-radius: 18px 18px 4px 18px;
  box-shadow: var(--shadow-card);
  max-width: 220px;
}
.h3-page-hero__badge strong {
  display: block;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  color: var(--terracota-dark);
  font-size: 1.1rem;
  line-height: 1.1;
}
.h3-page-hero__badge span {
  display: block;
  margin-top: 4px;
  font-size: 0.88rem;
  color: var(--tinta-soft);
}

@media (max-width: 880px) {
  .h3-page-hero { padding: 60px 0 100px; }
  .h3-page-hero__inner { grid-template-columns: 1fr; gap: 32px; text-align: center; }
  .h3-page-hero__content p { margin-left: auto; margin-right: auto; }
  .h3-page-hero__actions { justify-content: center; }
  .h3-page-hero__mascot { max-width: 240px; margin: 0 auto; }
  .h3-page-hero__badge { position: static; margin-top: -40px; max-width: 80%; }
  .h3-about-badges { justify-content: center; }
}

/* =========================================================
   PAGE SECTION
   ========================================================= */
.h3-page-section {
  padding: 80px 0;
  background: var(--offwhite);
  position: relative;
}
.h3-page-section--compact { padding: 56px 0; }
@media (max-width: 600px) {
  .h3-page-section         { padding: 48px 0; }
  .h3-page-section--compact { padding: 32px 0; }
}
.h3-page-section--cream { background: var(--bege); }
.h3-page-section--mint  { background: linear-gradient(180deg, var(--offwhite), #ecf8f2); }
.h3-page-section--warm  { background: linear-gradient(180deg, var(--offwhite), var(--bege)); }

/* Section header dentro de uma seção */
.h3-page-section .h3-section-header.center {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* =========================================================
   GRIDS DE CARDS
   ========================================================= */
.h3-card-grid {
  display: grid;
  gap: 28px;
}
.h3-card-grid--two   { grid-template-columns: repeat(2, 1fr); }
.h3-card-grid--three { grid-template-columns: repeat(3, 1fr); }
.h3-card-grid--four  { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 880px) {
  .h3-card-grid--two,
  .h3-card-grid--three,
  .h3-card-grid--four { grid-template-columns: 1fr; }
}

/* Feature card (com sombra e moldura forte) */
.h3-feature-card {
  background: var(--offwhite);
  border: 1px solid rgba(181, 100, 78, 0.12);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  box-shadow: var(--shadow-soft);
  position: relative;
  transition: transform 0.3s, box-shadow 0.3s;
}
.h3-feature-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.h3-feature-card h2, .h3-feature-card h3 {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  color: var(--terracota-dark);
  letter-spacing: -0.01em;
  margin-bottom: 12px;
  line-height: 1.15;
}
.h3-feature-card h2 { font-size: 1.5rem; }
.h3-feature-card h3 { font-size: 1.2rem; }
.h3-feature-card p {
  color: var(--tinta-soft);
  font-size: 0.98rem;
  line-height: 1.6;
}
.h3-feature-card .h3-pill { margin-bottom: 14px; }
.h3-feature-card--soft {
  background: linear-gradient(160deg, var(--bege), var(--creme-soft));
  border-color: rgba(226, 161, 109, 0.2);
}
.h3-feature-card--mint {
  background: linear-gradient(160deg, #ecf8f2, #d8efe8);
  border-color: rgba(100, 146, 135, 0.2);
}

/* Soft card (mais leve) */
.h3-soft-card {
  background: var(--bege);
  border: 1px solid rgba(226, 161, 109, 0.18);
  border-radius: var(--r-md);
  padding: 24px;
  transition: transform 0.3s;
}
.h3-soft-card:hover { transform: translateY(-3px); }
.h3-soft-card strong {
  display: block;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.05rem;
  color: var(--terracota-dark);
  margin-bottom: 8px;
}
.h3-soft-card p {
  color: var(--tinta-soft);
  font-size: 0.95rem;
  line-height: 1.55;
}
.h3-soft-card__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 12px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--terracota-dark);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  transition: opacity 0.2s;
}
.h3-soft-card__link:hover { opacity: 0.72; }

/* Stack (cards empilhados verticalmente) */
.h3-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* =========================================================
   LISTAS COM CHECK
   ========================================================= */
.h3-list-check {
  list-style: none;
  padding: 0;
  margin: 0;
}
.h3-list-check li {
  position: relative;
  padding: 10px 0 10px 36px;
  color: var(--tinta);
  font-size: 0.98rem;
  line-height: 1.5;
}
.h3-list-check li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--verde-claro);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 13 l4 4 l10 -10' fill='none' stroke='%238B4A38' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: 70%;
  background-position: center;
  background-repeat: no-repeat;
}

/* =========================================================
   CHIP LIST (valores institucionais, parceiros)
   ========================================================= */
.h3-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.h3-chip-list > span,
.h3-chip-list > a {
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  background: var(--offwhite);
  border: 1.5px solid var(--verde-claro);
  border-radius: var(--r-pill);
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--terracota-dark);
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
}
.h3-chip-list > a:hover {
  background: var(--verde-claro);
  transform: translateY(-2px);
}
.h3-chip-list--links > a {
  border-color: var(--mostarda);
}

/* =========================================================
   STEP GRID (passo a passo)
   ========================================================= */
.h3-step-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-top: 28px;
}
.h3-step-card {
  position: relative;
  background: var(--offwhite);
  border-radius: var(--r-lg);
  padding: 32px 24px 24px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.3s, box-shadow 0.3s;
}
.h3-step-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.h3-step-card::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 24px;
  right: 24px;
  height: 4px;
  border-radius: var(--r-pill);
  background: var(--mostarda);
}
.h3-step-card:nth-child(2)::before { background: var(--verde-claro); }
.h3-step-card:nth-child(3)::before { background: var(--terracota); }
.h3-step-card:nth-child(4)::before { background: var(--verde); }
.h3-step-card__number {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 2.6rem;
  line-height: 1;
  color: var(--mostarda);
  opacity: 0.3;
  letter-spacing: -0.04em;
}
.h3-step-card:nth-child(2) .h3-step-card__number { color: var(--verde); }
.h3-step-card:nth-child(3) .h3-step-card__number { color: var(--terracota); }
.h3-step-card:nth-child(4) .h3-step-card__number { color: var(--verde-claro); }
.h3-step-card strong {
  display: block;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.15rem;
  color: var(--terracota-dark);
  margin: 14px 0 8px;
}
.h3-step-card p {
  color: var(--tinta-soft);
  font-size: 0.92rem;
  line-height: 1.5;
}

@media (max-width: 1080px) { .h3-step-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .h3-step-grid { grid-template-columns: 1fr; } }

/* =========================================================
   ACCORDION
   ========================================================= */
.h3-accordion-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.h3-accordion-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 20px;
  align-items: start;
}
@media (max-width: 700px) {
  .h3-accordion-grid { grid-template-columns: 1fr; }
}
.h3-accordion {
  background: var(--offwhite);
  border: 1px solid rgba(181, 100, 78, 0.14);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: box-shadow 0.2s;
}
.h3-accordion[open] { box-shadow: var(--shadow-soft); }
.h3-accordion summary {
  list-style: none;
  padding: 20px 28px;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 800;
  font-size: 1.05rem;
  color: var(--terracota-dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  transition: background 0.2s;
}
.h3-accordion summary::-webkit-details-marker { display: none; }
.h3-accordion summary:hover { background: rgba(226, 161, 109, 0.08); }
.h3-accordion summary::after {
  content: '';
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  background: var(--terracota);
  clip-path: polygon(50% 70%, 0 25%, 14% 14%, 50% 50%, 86% 14%, 100% 25%);
  transition: transform 0.3s;
}
.h3-accordion[open] summary::after { transform: rotate(180deg); }
.h3-accordion__content {
  padding: 4px 28px 24px;
  color: var(--tinta-soft);
}
.h3-accordion__content p { font-size: 0.98rem; line-height: 1.6; }
.h3-accordion__intro { margin-bottom: 16px; color: var(--tinta); font-size: 0.97rem; line-height: 1.65; }
.h3-accordion__content > .h3-card-grid { margin-top: 16px; }

/* =========================================================
   LAYOUT COM ASIDE (sticky)
   ========================================================= */
.h3-layout-with-aside {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 32px;
  align-items: start;
}
.h3-page-aside {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
@media (max-width: 980px) {
  .h3-layout-with-aside { grid-template-columns: 1fr; }
  .h3-page-aside { position: static; }
}

/* =========================================================
   HIGHLIGHT GRID (3 destaques pequenos)
   ========================================================= */
.h3-highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 880px) { .h3-highlight-grid { grid-template-columns: 1fr; } }

/* =========================================================
   MITOS — FLIP CARDS
   ========================================================= */
.h3-myth-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 1080px) { .h3-myth-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .h3-myth-grid { grid-template-columns: 1fr; } }

.h3-myth-card {
  perspective: 1200px;
}
.h3-myth-card__button {
  all: unset;
  display: grid;
  width: 100%;
  cursor: pointer;
  transform-style: preserve-3d;
  transition: transform 0.6s;
  border-radius: var(--r-lg);
  box-sizing: border-box;
}
.h3-myth-card[aria-flipped="true"] .h3-myth-card__button,
.h3-myth-card.is-flipped .h3-myth-card__button {
  transform: rotateY(180deg);
}
/* Front e back ocupam a mesma célula do grid; o botão cresce até a maior das duas */
.h3-myth-card__front,
.h3-myth-card__back {
  grid-area: 1 / 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  min-height: 260px;
  padding: 28px 24px;
  border-radius: var(--r-lg);
  backface-visibility: hidden;
  box-shadow: var(--shadow-soft);
}
.h3-myth-card__back {
  transform: rotateY(180deg);
  align-items: flex-start;
  text-align: left;
  justify-content: center;
}

/* Tons rotativos */
.h3-myth-card--tone-1 .h3-myth-card__front { background: linear-gradient(160deg, var(--bege), var(--creme-soft)); }
.h3-myth-card--tone-2 .h3-myth-card__front { background: linear-gradient(160deg, #ecf8f2, var(--verde-mint)); }
.h3-myth-card--tone-3 .h3-myth-card__front { background: linear-gradient(160deg, var(--creme), #FFD876); }
.h3-myth-card--tone-4 .h3-myth-card__front { background: linear-gradient(160deg, var(--terracota-soft), var(--terracota)); color: var(--offwhite); }
.h3-myth-card--tone-4 .h3-myth-card__statement { color: var(--offwhite); }

/* question: primeira linha, topo centralizado */
.h3-myth-card__question {
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--terracota-dark);
  margin-top: 0;
  padding-bottom: 4px;
}
.h3-myth-card--tone-4 .h3-myth-card__question { color: rgba(255,246,226,0.9); }

/* statement: destaque máximo, ocupa o espaço central */
.h3-myth-card__statement {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.25rem, 2vw, 1.55rem);
  font-style: italic;
  color: var(--terracota-dark);
  line-height: 1.2;
  letter-spacing: -0.01em;
  text-wrap: balance;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  max-width: 18ch;
}
.h3-myth-card--tone-4 .h3-myth-card__statement { color: var(--offwhite); }

/* hint: empurrado para o fundo */
.h3-myth-card__hint {
  margin-top: auto;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--tinta-soft);
}
.h3-myth-card--tone-4 .h3-myth-card__hint { color: rgba(255,246,226,0.75); }

.h3-myth-card__back {
  background: var(--offwhite);
  border: 2px solid var(--verde-claro);
}
.h3-myth-card.is-true .h3-myth-card__back { border-color: var(--verde); }
.h3-myth-card__label {
  display: inline-block;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
  align-self: flex-start;
}
.h3-myth-card__label--myth  { background: var(--terracota); color: var(--offwhite); }
.h3-myth-card__label--truth { background: var(--verde); color: var(--offwhite); }
.h3-myth-card__back strong {
  display: block;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.1rem;
  color: var(--terracota-dark);
  margin-bottom: 8px;
}
.h3-myth-card__answer {
  font-size: 0.92rem;
  color: var(--tinta-soft);
  line-height: 1.5;
}

/* =========================================================
   QUEM SOMOS — Timeline da história
   ========================================================= */
.h3-history-panel {
  background: linear-gradient(160deg, var(--bege), var(--creme-soft));
  border: 1px solid rgba(226, 161, 109, 0.2);
  border-radius: var(--r-lg);
  padding: 40px;
  position: relative;
}
.h3-history-panel::before {
  content: '';
  position: absolute;
  top: -20px;
  left: 40px;
  width: 60px;
  height: 60px;
  background: var(--mostarda);
  border-radius: 50%;
  opacity: 0.15;
}
.h3-history-panel p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--tinta);
  text-wrap: pretty;
}

/* =========================================================
   QUEM SOMOS — Grid de equipe
   ========================================================= */
.h3-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 880px) { .h3-team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .h3-team-grid { grid-template-columns: 1fr; } }

.h3-team-card {
  background: var(--offwhite);
  border: 1px solid rgba(181, 100, 78, 0.12);
  border-radius: var(--r-md);
  padding: 24px;
  position: relative;
  transition: transform 0.3s;
}
.h3-team-card:hover { transform: translateY(-4px); }
.h3-team-card::before {
  content: '';
  display: block;
  width: 44px;
  height: 44px;
  background: var(--verde-claro);
  border-radius: 50%;
  margin-bottom: 16px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 12 a4 4 0 1 0 0 -8 a4 4 0 1 0 0 8 m-8 9 v-1 a8 8 0 0 1 16 0 v1' fill='none' stroke='%238B4A38' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: 60%;
  background-position: center;
  background-repeat: no-repeat;
}
.h3-team-card__role {
  display: block;
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.1rem;
  color: var(--terracota-dark);
  margin-bottom: 6px;
}
.h3-team-card p {
  color: var(--tinta-soft);
  font-size: 0.92rem;
  line-height: 1.5;
}

/* =========================================================
   AMAMENTAÇÃO — Cards de material (PDF/vídeo)
   ========================================================= */
.h3-material-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.h3-material-card .h3-btn { align-self: flex-start; }

/* =========================================================
   CONTATO — Card principal
   ========================================================= */
.h3-contact-card { padding: 36px; }
.h3-contact-card address {
  font-style: normal;
  margin: 18px 0;
  color: var(--tinta);
}
.h3-contact-card address p {
  font-size: 1rem;
  line-height: 1.55;
  margin: 0;
}
.h3-contact-card__hours {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  background: var(--bege);
  border-radius: var(--r-md);
  font-size: 0.95rem;
  color: var(--terracota-dark);
  font-weight: 600;
}
.h3-contact-card__hours-icon { color: var(--verde); display: grid; place-items: center; }
.h3-contact-card__actions {
  display: flex;
  gap: 12px;
  margin-top: 24px;
  flex-wrap: wrap;
}

/* =========================================================
   CONTATO — Card principal: split conteúdo | arte
   ========================================================= */
.h3-contact-card {
  display: flex;
  align-items: center;
  gap: 24px;
}
.h3-contact-card__body {
  flex: 1;
  min-width: 0;
}
.h3-contact-card__art {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
}
.h3-contact-card__art img {
  width: 200px;
  filter: drop-shadow(0 16px 28px rgba(181,100,78,0.18));
  animation: h3-mascot-float 5s ease-in-out infinite;
}
@media (max-width: 560px) {
  .h3-contact-card { flex-direction: column; }
  .h3-contact-card__art img { width: 100px; }
}

/* =========================================================
   CONTATO — Mapa
   ========================================================= */
.h3-map-section {
  padding: 0 0 80px;
  background: var(--offwhite);
}
.h3-map-embed {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  aspect-ratio: 16 / 9;
  background: var(--bege);
}
.h3-map-embed iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* =========================================================
   CONTATO — Lista da rede
   ========================================================= */
.h3-network-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 760px) { .h3-network-list { grid-template-columns: 1fr; } }

.h3-network-list li {
  background: var(--bege);
  border-radius: var(--r-md);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.h3-network-list li strong {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  color: var(--terracota-dark);
  font-size: 1rem;
  margin-bottom: 4px;
}
.h3-network-list li span { font-size: 0.92rem; color: var(--tinta-soft); }
.h3-network-list li a {
  color: var(--terracota-dark);
  text-decoration: none;
  font-weight: 700;
}
.h3-network-list li a:hover { text-decoration: underline; }

/* =========================================================
   COMO DOAR — Layout do formulário
   ========================================================= */
.h3-form-layout {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 40px;
  align-items: start;
}
.h3-form-layout__aside {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.h3-form-layout__aside h2 {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.5rem;
  color: var(--terracota-dark);
  line-height: 1.15;
}
.h3-form-layout__aside p {
  color: var(--tinta-soft);
  font-size: 0.98rem;
  line-height: 1.55;
}
.h3-form-layout__aside-mascot {
  width: 60%;
  margin: 0 auto;
  filter: drop-shadow(0 12px 20px rgba(0,0,0,0.15));
  animation: h3-mascot-float 5s ease-in-out infinite;
}
.h3-form-layout__tips {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 980px) {
  .h3-form-layout { grid-template-columns: 1fr; }
  .h3-form-layout__aside { position: static; }
  .h3-form-layout__aside-mascot { max-width: 200px; }
}

/* =========================================================
   COMO DOAR — Formulário
   ========================================================= */
.h3-donor-form {
  background: var(--offwhite);
  border: 1px solid rgba(181, 100, 78, 0.14);
  border-radius: var(--r-lg);
  padding: 40px;
  box-shadow: var(--shadow-soft);
}
@media (max-width: 480px) {
  .h3-donor-form { padding: 24px 16px; border-radius: var(--r-md); }
}
.h3-donor-form__trap { display: none; }
.h3-donor-form__fieldset {
  border: none;
  padding: 0;
  margin: 0 0 32px;
}
.h3-donor-form__fieldset legend {
  font-family: 'Nunito', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.2rem;
  color: var(--terracota-dark);
  padding: 0;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.h3-donor-form__fieldset legend::before {
  content: '';
  width: 6px;
  height: 28px;
  background: var(--mostarda);
  border-radius: var(--r-pill);
}

.h3-donor-form__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.h3-donor-form__grid--two { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 720px) {
  .h3-donor-form__grid--two { grid-template-columns: 1fr; }
}
.h3-donor-form__full { grid-column: 1 / -1; }

.h3-donor-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.h3-donor-form label > span {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--terracota-dark);
}
.h3-donor-form input[type="text"],
.h3-donor-form input[type="tel"],
.h3-donor-form input[type="email"],
.h3-donor-form input[type="date"],
.h3-donor-form select,
.h3-donor-form textarea {
  border: 1.5px solid rgba(181, 100, 78, 0.2);
  background: var(--bege);
  padding: 12px 16px;
  border-radius: var(--r-md);
  font-family: inherit;
  font-size: 0.98rem;
  color: var(--tinta);
  transition: border-color 0.2s, background 0.2s;
}
.h3-donor-form input:focus,
.h3-donor-form select:focus,
.h3-donor-form textarea:focus {
  outline: none;
  border-color: var(--mostarda);
  background: var(--offwhite);
}

.h3-donor-form__stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.h3-donor-form__question { display: flex; flex-direction: column; gap: 8px; }
.h3-donor-form__question > span { font-weight: 700; font-size: 0.95rem; color: var(--terracota-dark); }
.h3-donor-form__choices {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.h3-donor-form__choices--wrap { flex-wrap: wrap; gap: 10px; }
.h3-donor-form__choices label {
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--bege);
  border-radius: var(--r-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  font-size: 0.95rem;
  transition: border-color 0.2s, background 0.2s;
}
.h3-donor-form__choices label:has(input:checked) {
  border-color: var(--mostarda);
  background: var(--creme-soft);
}

.blh-donor-form__file-label {
  flex-direction: column;
  gap: 10px;
}
.blh-donor-form__file-help {
  font-size: 0.88rem;
  color: var(--tinta-soft);
  line-height: 1.6;
  display: block;
  background: var(--bege);
  border-radius: var(--r-md);
  padding: 12px 14px;
  border-left: 3px solid var(--mostarda);
}
.blh-donor-form__file-input {
  display: block;
  width: 100%;
  padding: 10px 12px;
  border: 1.5px dashed var(--mostarda);
  border-radius: var(--r-md);
  background: var(--offwhite);
  color: var(--tinta);
  font-size: 0.9rem;
  cursor: pointer;
  transition: border-color 0.2s;
}
.blh-donor-form__file-input:hover { border-color: var(--terracota); }

.h3-donor-form__footer {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 24px;
}
.h3-donor-form__consent {
  flex-direction: row;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.92rem;
  color: var(--tinta-soft);
  line-height: 1.5;
}
.h3-donor-form__consent input { margin-top: 4px; flex-shrink: 0; }
.h3-donor-form__consent span { flex: 1; }

.h3-donor-form__message {
  margin-top: 20px;
  padding: 16px 20px;
  border-radius: var(--r-md);
  font-weight: 600;
}
.h3-donor-form__message--success { background: #d8efe8; color: #2D5B53; border: 1px solid var(--verde); }
.h3-donor-form__message--error   { background: #FAE0D9; color: var(--terracota-dark); border: 1px solid var(--terracota); }

/* =========================================================
   ENTRADA ANIMADA
   ========================================================= */
.h3-reveal,
.blh-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.h3-reveal.is-visible,
.blh-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}


/* =========================================================
   COMPATIBILIDADE — aliases para templates com nomenclatura
   anterior e variantes de hero exclusivas
   ========================================================= */

/* Marcadores de seção (donate.php e archive.php) */
.h3-section-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: var(--r-pill);
  font-weight: 800;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.h3-tag-mustard { background: var(--mostarda);      color: var(--tinta); }
.h3-tag-green   { background: var(--verde);          color: var(--tinta); }
.h3-tag-cream   { background: var(--creme);          color: var(--terracota-dark); }
.h3-tag-terra   { background: var(--terracota-dark); color: var(--offwhite); }

/* Botões — aliases single-hyphen (donate.php, 404.php) */
.h3-btn-primary { background: var(--mostarda); color: var(--tinta); box-shadow: 0 10px 24px rgba(226,161,109,0.45); }
.h3-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(226,161,109,0.55); }
.h3-btn-secondary { background: var(--terracota-dark); color: var(--offwhite); box-shadow: 0 10px 24px rgba(139,74,56,0.4); }
.h3-btn-secondary:hover { transform: translateY(-2px); }
.h3-btn-ghost-dark {
  background: transparent;
  color: var(--terracota-dark);
  border: 2px solid var(--terracota-dark);
}
.h3-btn-ghost-dark:hover { background: var(--terracota-dark); color: var(--offwhite); }
.h3-btn-sm    { padding: 10px 20px; font-size: 0.92rem; }
.h3-btn-lg    { padding: 18px 32px; font-size: 1.05rem; }
.h3-btn-block { width: 100%; padding: 18px 28px; font-size: 1.05rem; }

/* Hero — variantes adicionais via ::before */
.h3-page-hero--mostarda::before { background: linear-gradient(135deg, var(--mostarda) 0%, var(--terracota) 100%); }
.h3-page-hero--terra::before    { background: var(--terracota); }
.h3-page-hero--verde::before    { background: var(--verde); }
.h3-page-hero--offwhite::before { background: linear-gradient(180deg, var(--offwhite) 0%, var(--bege) 100%); }

/* Texto claro para héros coloridos (variantes nossas) */
.h3-page-hero--mostarda .h3-page-hero__content,
.h3-page-hero--terra    .h3-page-hero__content,
.h3-page-hero--verde    .h3-page-hero__content { color: var(--offwhite); }
.h3-page-hero--offwhite .h3-page-hero__content    { color: var(--tinta); }
.h3-page-hero--offwhite .h3-page-hero__content h1 { color: var(--terracota-dark); }
.h3-page-hero--offwhite .h3-page-hero__content p  { color: var(--tinta-soft); }

/* Hero centrado (archive.php, single hero) */
.h3-page-hero__inner--center {
  grid-template-columns: 1fr;
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}

/* Esconde wave SVG inline — o ::after CSS gerencia a onda */
.h3-page-hero__wave { display: none; }

/* =========================================================
   COMPONENTES EXCLUSIVOS — breadcrumb, posts, 404, donate, single
   ========================================================= */
/* =========================================================
   BREADCRUMB
   ========================================================= */
.h3-breadcrumb {
  padding: 16px 0;
  background: var(--offwhite);
  border-bottom: 1px solid rgba(181,100,78,0.08);
}
.h3-breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  list-style: none;
  margin: 0; padding: 0;
  font-size: 0.85rem;
  color: var(--tinta-soft);
}
.h3-breadcrumb__list a {
  color: var(--terracota-dark);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s;
}
.h3-breadcrumb__list a:hover { color: var(--tinta); }
.h3-breadcrumb__sep { opacity: 0.4; font-size: 0.75rem; }
.h3-breadcrumb__current { color: var(--tinta-soft); font-weight: 700; }

/* =========================================================
   CONTEÚDO EDITORIAL (single.php)
   ========================================================= */
.h3-post-layout {
  padding: 72px 0 100px;
  background: var(--offwhite);
}
.h3-post-layout__inner {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 64px;
  align-items: start;
}
.h3-post-layout__inner--full {
  grid-template-columns: 1fr;
  max-width: 760px;
  margin: 0 auto;
}
.h3-post-main { min-width: 0; }

/* Cabeçalho do post */
.h3-post-header { margin-bottom: 40px; }
.h3-post-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 20px;
  font-size: 0.88rem;
  color: var(--tinta-soft);
}
.h3-post-meta .h3-section-tag { font-size: 0.75rem; padding: 5px 12px; }
.h3-post-meta__date, .h3-post-meta__read { font-weight: 600; }
.h3-post-meta__sep { opacity: 0.35; }
.h3-post-title {
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--terracota-dark);
  text-wrap: balance;
  margin-bottom: 20px;
}
.h3-post-excerpt {
  font-size: 1.15rem;
  color: var(--tinta-soft);
  line-height: 1.65;
  max-width: 60ch;
  padding-bottom: 32px;
  border-bottom: 2px solid var(--bege);
}

/* Thumbnail do post */
.h3-post-thumb {
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: 48px;
  background: var(--bege);
}
.h3-post-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Tipografia do conteúdo */
.h3-post-content {
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--tinta);
  max-width: 72ch;
}
.h3-post-content h2 {
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: var(--terracota-dark);
  margin: 48px 0 16px;
  letter-spacing: -0.01em;
}
.h3-post-content h3 {
  font-weight: 800;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  color: var(--terracota-dark);
  margin: 36px 0 12px;
}
.h3-post-content p { margin: 0 0 1.5em; }
.h3-post-content p:last-child { margin-bottom: 0; }
.h3-post-content strong { font-weight: 800; color: var(--tinta); }
.h3-post-content a { color: var(--terracota-dark); text-decoration: underline; text-underline-offset: 3px; }
.h3-post-content a:hover { color: var(--tinta); }
.h3-post-content ul, .h3-post-content ol {
  margin: 0 0 1.5em 1.5em;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.h3-post-content li::marker { color: var(--mostarda); }
.h3-post-content blockquote {
  margin: 32px 0;
  padding: 24px 28px;
  background: var(--bege);
  border-left: 4px solid var(--mostarda);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-size: 1.1rem;
  color: var(--tinta-soft);
  font-style: italic;
}
.h3-post-content blockquote cite {
  display: block;
  margin-top: 12px;
  font-size: 0.88rem;
  font-style: normal;
  font-weight: 700;
  color: var(--terracota-dark);
}
.h3-post-content figure {
  margin: 32px 0;
  border-radius: var(--r-md);
  overflow: hidden;
}
.h3-post-content figure img { width: 100%; height: auto; display: block; }
.h3-post-content figcaption {
  padding: 12px 16px;
  background: var(--bege);
  font-size: 0.85rem;
  color: var(--tinta-soft);
  font-style: italic;
}
.h3-post-content hr {
  border: none;
  height: 2px;
  background: var(--bege);
  margin: 40px 0;
  border-radius: 2px;
}

/* Sidebar do post */
.h3-post-sidebar { position: sticky; top: 100px; }
.h3-sidebar-card {
  background: var(--bege);
  border-radius: var(--r-lg);
  padding: 28px 24px;
  margin-bottom: 24px;
}
.h3-sidebar-card h4 {
  font-weight: 900;
  font-size: 0.92rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--terracota-dark);
  margin-bottom: 16px;
}

/* Posts relacionados */
.h3-related-posts {
  padding: 72px 0;
  background: var(--bege);
}
.h3-related-title {
  font-weight: 900;
  font-size: 1.6rem;
  color: var(--terracota-dark);
  margin-bottom: 32px;
}

@media (max-width: 900px) {
  .h3-post-layout__inner { grid-template-columns: 1fr; }
  .h3-post-layout .h3-post-sidebar { display: none; }
}
@media (max-width: 600px) {
  .h3-post-layout { padding: 48px 0 72px; }
  .h3-post-thumb { aspect-ratio: 16 / 9; margin-bottom: 32px; }
}

/* =========================================================
   CARDS DE POST (archive.php)
   ========================================================= */
.h3-archive {
  padding: 72px 0 100px;
  background: var(--offwhite);
}
.h3-archive-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 48px;
}
.h3-archive-count {
  font-size: 0.88rem;
  color: var(--tinta-soft);
  font-weight: 600;
}

.h3-posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.h3-post-card {
  background: var(--offwhite);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s var(--ease-spring), box-shadow 0.3s ease;
  text-decoration: none;
}
.h3-post-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); }

.h3-post-card__thumb {
  aspect-ratio: 16 / 9;
  background: var(--bege);
  overflow: hidden;
  flex-shrink: 0;
}
.h3-post-card__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.h3-post-card:hover .h3-post-card__thumb img { transform: scale(1.04); }

.h3-post-card__body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.h3-post-card__cat {
  display: inline-block;
  padding: 4px 12px;
  background: var(--creme);
  color: var(--terracota-dark);
  border-radius: var(--r-pill);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  align-self: flex-start;
}
.h3-post-card__title {
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--terracota-dark);
  line-height: 1.3;
}
.h3-post-card__excerpt {
  font-size: 0.92rem;
  color: var(--tinta-soft);
  line-height: 1.6;
  flex: 1;
}
.h3-post-card__meta {
  display: flex;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--tinta-soft);
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--bege);
}
.h3-post-card__read-more {
  font-weight: 800;
  font-size: 0.88rem;
  color: var(--terracota-dark);
}

/* Placeholder sem imagem */
.h3-post-card__thumb--empty {
  background: linear-gradient(135deg, var(--bege), var(--creme-soft));
  display: flex;
  align-items: center;
  justify-content: center;
}
.h3-post-card__thumb--empty svg { width: 48px; height: 48px; opacity: 0.3; }

/* Estado vazio */
.h3-empty-state {
  text-align: center;
  padding: 80px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.h3-empty-state img {
  width: 180px;
  filter: drop-shadow(0 16px 32px rgba(0,0,0,0.1));
}
.h3-empty-state h3 { font-weight: 900; font-size: 1.5rem; color: var(--terracota-dark); }
.h3-empty-state p  { color: var(--tinta-soft); max-width: 40ch; }

/* Paginação */
.h3-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin-top: 56px;
  flex-wrap: wrap;
}
.h3-pagination a,
.h3-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 14px;
  border-radius: var(--r-pill);
  font-weight: 800;
  font-size: 0.92rem;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.h3-pagination a { color: var(--tinta-soft); background: var(--bege); }
.h3-pagination a:hover { background: var(--creme); color: var(--terracota-dark); }
.h3-pagination .current { background: var(--terracota); color: var(--offwhite); }
.h3-pagination .dots { background: transparent; color: var(--tinta-soft); min-width: auto; }

@media (max-width: 900px) {
  .h3-posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .h3-posts-grid { grid-template-columns: 1fr; }
  .h3-archive { padding: 48px 0 72px; }
}

/* =========================================================
   ARCHIVE HERO — mascotes + glows
   ========================================================= */
.h3-page-hero--offwhite .h3-page-hero__glow {
  background: radial-gradient(circle, rgba(181,100,78,0.18), transparent 68%);
}

.h3-page-hero--archive .h3-page-hero__shape {
  bottom: -60px;
  left: -60px;
  width: 520px;
  height: 520px;
}

.h3-page-hero__inner--archive {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 32px;
}

.h3-page-hero__inner--archive .h3-page-hero__content {
  flex: 1;
  min-width: 0;
  text-align: center;
}

.h3-archive-hero__mascot {
  display: block;
  flex-shrink: 0;
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,0.12));
}
.h3-archive-hero__mascot--left  { width: 110px; }
.h3-archive-hero__mascot--right { width: 100px; }

@media (max-width: 880px) {
  .h3-archive-hero__mascot { display: none; }
  .h3-page-hero__inner--archive { gap: 0; }
}

/* =========================================================
   ARCHIVE — layout com sidebar
   ========================================================= */
.h3-archive-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 48px;
  align-items: start;
}
.h3-archive-main { min-width: 0; }
.h3-archive-sidebar { position: sticky; top: 100px; }

/* Sidebar CTA card */
.h3-sidebar-card--cta {
  text-align: center;
  background: linear-gradient(160deg, var(--creme) 0%, var(--bege) 100%);
}
.h3-sidebar-cta__mascot { margin: 0 auto 12px; display: block; }
.h3-sidebar-card--cta p { font-size: 0.88rem; color: var(--tinta-soft); line-height: 1.5; margin-bottom: 16px; }
.h3-sidebar-card--cta .h3-btn { width: 100%; justify-content: center; font-size: 0.88rem; }
.h3-sidebar-card p { font-size: 0.88rem; color: var(--tinta-soft); line-height: 1.55; margin-bottom: 12px; }
.h3-sidebar-link {
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--terracota);
  text-decoration: none;
}
.h3-sidebar-link:hover { color: var(--terracota-dark); }

@media (max-width: 960px) {
  .h3-archive-layout { grid-template-columns: 1fr; }
  .h3-archive-sidebar { display: none; }
}

/* =========================================================
   404
   ========================================================= */
.h3-404 {
  padding: 80px 0 100px;
  background: linear-gradient(180deg, var(--offwhite) 0%, var(--bege) 100%);
  min-height: 70vh;
  display: flex;
  align-items: center;
}
.h3-404__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center;
}
.h3-404__content { display: flex; flex-direction: column; gap: 20px; }
.h3-404__code {
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(6rem, 15vw, 10rem);
  line-height: 1;
  color: var(--mostarda);
  letter-spacing: -0.04em;
  opacity: 0.35;
}
.h3-404__title {
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  line-height: 1.1;
  color: var(--terracota-dark);
  letter-spacing: -0.02em;
  text-wrap: balance;
  margin-top: -24px; /* sobe para ficar próximo do código */
}
.h3-404__lead {
  font-size: 1.05rem;
  color: var(--tinta-soft);
  line-height: 1.65;
  max-width: 50ch;
}
.h3-404__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 8px;
}
.h3-404__mascot {
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
.h3-404__mascot img {
  width: 100%;
  max-width: 340px;
  filter: drop-shadow(0 24px 48px rgba(0,0,0,0.15));
  animation: h3p-mascot-float 5s ease-in-out infinite;
}

@media (max-width: 700px) {
  .h3-404__inner { grid-template-columns: 1fr; text-align: center; }
  .h3-404__content { align-items: center; }
  .h3-404__lead { max-width: none; }
  .h3-404__mascot { order: -1; }
  .h3-404__mascot img { max-width: 180px; }
}

/* =========================================================
   COMO DOAR — seções específicas
   ========================================================= */
.h3-steps-section {
  padding: 100px 0;
  background: var(--offwhite);
}

/* Timeline de passos */
.h3-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 56px;
  position: relative;
}
.h3-timeline::before {
  content: '';
  position: absolute;
  left: 28px;
  top: 28px;
  bottom: 28px;
  width: 2px;
  background: linear-gradient(to bottom, var(--mostarda), var(--terracota));
  opacity: 0.3;
}
.h3-timeline-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 28px;
  padding: 0 0 48px;
  position: relative;
}
.h3-timeline-step:last-child { padding-bottom: 0; }
.h3-timeline-num {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--mostarda);
  color: var(--offwhite);
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: 1.3rem;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: 0 8px 20px rgba(226,161,109,0.4);
  z-index: 1;
}
.h3-timeline-step:nth-child(2) .h3-timeline-num { background: var(--verde); box-shadow: 0 8px 20px rgba(100,146,135,0.4); }
.h3-timeline-step:nth-child(3) .h3-timeline-num { background: var(--terracota); box-shadow: 0 8px 20px rgba(181,100,78,0.4); }
.h3-timeline-step:nth-child(4) .h3-timeline-num { background: var(--mostarda); }
.h3-timeline-step:nth-child(5) .h3-timeline-num { background: var(--verde); }
.h3-timeline-body { padding-top: 10px; }
.h3-timeline-title {
  font-weight: 900;
  font-size: 1.25rem;
  color: var(--terracota-dark);
  margin-bottom: 8px;
}
.h3-timeline-text { color: var(--tinta-soft); font-size: 0.98rem; line-height: 1.65; }

/* Checklist de elegibilidade */
.h3-eligibility-section {
  padding: 80px 0;
  background: var(--bege);
}
.h3-eligibility-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 48px;
}
.h3-eligibility-col {
  background: var(--offwhite);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  box-shadow: var(--shadow-soft);
}
.h3-eligibility-col h3 {
  font-weight: 900;
  font-size: 1.1rem;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.h3-eligibility-col--can h3 { color: var(--verde); }
.h3-eligibility-col--cant h3 { color: var(--terracota-dark); }
.h3-check-list {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.h3-check-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.95rem;
  color: var(--tinta-soft);
  line-height: 1.5;
}
.h3-check-list li::before {
  content: '';
  width: 20px;
  height: 20px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 1px;
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
}
.h3-eligibility-col--can  li::before { background-color: var(--verde);     background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.h3-eligibility-col--cant li::before { background-color: var(--terracota); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M3 3l6 6M9 3l-6 6' stroke='%23fff' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E"); }

/* FAQ Accordion */
.h3-faq-section {
  padding: 80px 0 100px;
  background: var(--offwhite);
}
.h3-faq-list {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 760px;
}

/* Grid 2 colunas — página de doação */
.h3-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 24px;
  margin-top: 48px;
  align-items: start;
}
@media (max-width: 700px) {
  .h3-faq-grid { grid-template-columns: 1fr; }
}
.h3-faq-item--overflow { display: none; }
.h3-faq-grid.is-expanded .h3-faq-item--overflow { display: block; }

/* Botão "Ver todas / Mostrar menos" */
.h3-faq-more {
  display: flex;
  justify-content: center;
  margin-top: 28px;
}
.h3-faq-toggle-icon {
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
.h3-faq-item {
  background: var(--bege);
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1.5px solid transparent;
  transition: border-color 0.2s;
}
.h3-faq-item.is-open { border-color: var(--mostarda); }
.h3-faq-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px;
  border: none;
  background: transparent;
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: var(--tinta);
  text-align: left;
  cursor: pointer;
  transition: color 0.2s;
}
.h3-faq-trigger:hover { color: var(--terracota); }
.h3-faq-item.is-open .h3-faq-trigger { color: var(--terracota-dark); }
.h3-faq-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--offwhite);
  display: grid;
  place-items: center;
  transition: transform 0.3s var(--ease-spring), background 0.2s;
}
.h3-faq-item.is-open .h3-faq-icon { transform: rotate(45deg); background: var(--mostarda); color: var(--tinta); }
.h3-faq-icon svg { width: 14px; height: 14px; }
.h3-faq-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--ease-spring);
}
.h3-faq-item.is-open .h3-faq-body { max-height: 600px; }
.h3-faq-body__inner {
  padding: 0 24px 24px;
  font-size: 0.98rem;
  color: var(--tinta-soft);
  line-height: 1.7;
}

@media (max-width: 700px) {
  .h3-eligibility-grid { grid-template-columns: 1fr; }
  .h3-timeline::before { display: none; }
}

/* =========================================================
   CTA FINAL DE PÁGINA (doação)
   ========================================================= */
.h3-page-cta {
  padding: 80px 0;
  background: linear-gradient(135deg, var(--mostarda), var(--terracota));
  position: relative;
  overflow: hidden;
  text-align: center;
}
.h3-page-cta::before { display: none; }

/* Coração decorativo SVG */
.h3-cta-heart {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 580px;
  height: 490px;
  pointer-events: none;
  z-index: 0;
}

/* Brilhos no CTA */
.h3-cta-glows { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.h3-cta-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(3px);
  background: radial-gradient(circle, rgba(255,232,150,0.55), transparent 68%);
  animation: h3-page-glow-drift 9s ease-in-out infinite;
}
.h3-cta-glow:nth-child(1) { top: 8%;  left: 6%;   width: 72px; height: 72px; opacity: 0.45; animation-delay: 0s;   }
.h3-cta-glow:nth-child(2) { top: 12%; right: 8%;  width: 48px; height: 48px; opacity: 0.38; animation-delay: 2.2s; }
.h3-cta-glow:nth-child(3) { bottom: 20%; left: 22%; width: 56px; height: 56px; opacity: 0.32; animation-delay: 4s;   }
.h3-cta-glow:nth-child(4) { bottom: 15%; right: 18%;width: 36px; height: 36px; opacity: 0.28; animation-delay: 3s;   }
.h3-page-cta__inner { position: relative; z-index: 1; max-width: 680px; margin: 0 auto; }
.h3-page-cta__title {
  font-family: 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--offwhite);
  letter-spacing: -0.02em;
  text-wrap: balance;
  margin-bottom: 16px;
}
.h3-page-cta__title em { font-style: normal; color: var(--creme); }
.h3-page-cta__lead { color: rgba(255,246,226,0.9); font-size: 1.05rem; margin-bottom: 32px; }
.h3-page-cta .h3-btn-primary {
  background: var(--offwhite);
  color: var(--terracota-dark);
  box-shadow: 0 12px 24px rgba(0,0,0,0.15);
}
.h3-page-cta__tag {
  display: inline-block;
  padding: 6px 18px;
  border-radius: var(--r-pill);
  background: rgba(255,232,171,0.25);
  color: var(--offwhite);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}
.h3-page-cta__actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 32px;
}

.h3-cta-layout {
  display: flex;
  align-items: center;
  gap: 32px;
  position: relative;
  z-index: 1;
}
.h3-cta-layout .h3-page-cta__inner { flex: 1; }
.h3-cta-mascot {
  display: block;
  flex-shrink: 0;
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,0.22));
}
.h3-cta-mascot--left  { width: 165px; animation: h3-cta-float-left  5s ease-in-out infinite; }
.h3-cta-mascot--right { width: 220px; animation: h3-cta-float-right 6s ease-in-out infinite 0.6s; }

@keyframes h3-cta-float-left {
  0%, 100% { transform: translateY(0)    rotate(-2deg); }
  50%       { transform: translateY(-14px) rotate(2deg);  }
}
@keyframes h3-cta-float-right {
  0%, 100% { transform: translateY(0)    rotate(2deg);  }
  50%       { transform: translateY(-18px) rotate(-2deg); }
}

@media (prefers-reduced-motion: reduce) {
  .h3-cta-mascot--left,
  .h3-cta-mascot--right { animation: none; }
}
@media (max-width: 880px) {
  .h3-cta-layout { display: block; }
  .h3-cta-mascot { display: none; }
}

/* =========================================================
   NAVEGAÇÃO ENTRE POSTS (single.php)
   ========================================================= */
.h3-post-nav {
  margin-top: 64px;
  padding-top: 40px;
  border-top: 2px solid var(--bege);
}
.h3-post-nav__inner {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.h3-post-nav__item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-decoration: none;
  max-width: 48%;
}
.h3-post-nav__item--next { align-items: flex-end; margin-left: auto; }
.h3-post-nav__dir {
  font-size: 0.8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--terracota-dark);
}
.h3-post-nav__title {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--tinta-soft);
  line-height: 1.4;
  transition: color 0.2s;
}
.h3-post-nav__item:hover .h3-post-nav__title { color: var(--terracota-dark); }
@media (max-width: 560px) {
  .h3-post-nav__item { max-width: 100%; }
  .h3-post-nav__item--next { align-items: flex-start; }
}

/* =========================================================
   FORMULÁRIO DE PRÉ-CADASTRO (donate.php)
   ========================================================= */
.h3-form-section {
  padding: 80px 0 100px;
  background: var(--bege);
}
.h3-form-layout {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 64px;
  align-items: start;
}
.h3-form-aside { position: sticky; top: 100px; }
.h3-form-tips {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 32px;
}
.h3-form-tip {
  background: var(--offwhite);
  border-radius: var(--r-md);
  padding: 20px 20px;
  border-left: 4px solid var(--mostarda);
}
.h3-form-tip strong {
  display: block;
  font-weight: 800;
  font-size: 0.92rem;
  color: var(--terracota-dark);
  margin-bottom: 6px;
}
.h3-form-tip p {
  font-size: 0.9rem;
  color: var(--tinta-soft);
  line-height: 1.55;
  margin: 0;
}

/* Card do formulário em si */
.h3-donor-form {
  background: var(--offwhite);
  border-radius: var(--r-lg);
  padding: 40px 36px;
  box-shadow: var(--shadow-card);
}

.h3-steps-header { margin-bottom: 0; }

@media (max-width: 1000px) {
  .h3-form-layout { grid-template-columns: 1fr; gap: 40px; }
  .h3-form-aside { position: static; }
}
@media (max-width: 600px) {
  .h3-form-section { padding: 56px 0 72px; }
  .h3-donor-form { padding: 28px 20px; }
}

/* =========================================================
   QUEM SOMOS V3 — Badges institucionais no hero
   ========================================================= */
.h3-about-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}
.h3-about-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgba(255, 246, 226, 0.18);
  border: 1px solid rgba(255, 246, 226, 0.3);
  border-radius: var(--r-pill);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--offwhite);
}
.h3-about-badge svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* =========================================================
   QUEM SOMOS V3 — Soft cards com ícone (missão / visão)
   ========================================================= */
.h3-soft-card--icon {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.h3-soft-card__icon-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.h3-soft-card__icon-dot {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.h3-soft-card__icon-dot svg {
  width: 20px;
  height: 20px;
}
.h3-soft-card--icon .h3-soft-card__icon-row strong {
  margin-bottom: 0;
}

/* =========================================================
   QUEM SOMOS V3 — História split (texto + mascote)
   ========================================================= */
.h3-history-split {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 56px;
  align-items: center;
}
.h3-history-split__content {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.h3-history-split__art {
  display: flex;
  justify-content: center;
  align-items: center;
}
.h3-history-split__art img {
  width: 100%;
  max-width: 240px;
  filter: drop-shadow(0 16px 32px rgba(0,0,0,0.15));
  animation: h3-mascot-float 5s ease-in-out infinite;
}
@media (max-width: 760px) {
  .h3-history-split { grid-template-columns: 1fr; gap: 32px; }
  .h3-history-split__art { order: -1; }
  .h3-history-split__art img { max-width: 160px; }
}

/* =========================================================
   QUEM SOMOS V3 — Checklist 2 colunas
   ========================================================= */
.h3-list-check--grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 40px;
}
@media (max-width: 600px) {
  .h3-list-check--grid { grid-template-columns: 1fr; }
}

/* =========================================================
   QUEM SOMOS V3 — Banda "Por que importa"
   ========================================================= */
.h3-why-band {
  background: linear-gradient(135deg, var(--verde) 0%, #4F786E 100%);
  padding: 72px 0;
  overflow: hidden;
  position: relative;
}
.h3-why-band__inner {
  display: flex;
  align-items: center;
  gap: 32px;
  position: relative;
}
.h3-why-band__quote {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: clamp(7rem, 16vw, 12rem);
  line-height: 0.85;
  color: rgba(255, 246, 226, 0.15);
  flex-shrink: 0;
  user-select: none;
  pointer-events: none;
}
.h3-why-band__body { flex: 1; }
.h3-why-band__body h2 {
  font-family: 'Nunito', 'Nunito Sans', system-ui, sans-serif;
  font-weight: 900;
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--offwhite);
  text-wrap: balance;
  margin-bottom: 16px;
}
.h3-why-band__body p {
  font-size: 1.05rem;
  line-height: 1.65;
  color: rgba(255, 246, 226, 0.88);
  max-width: 56ch;
  text-wrap: pretty;
}
.h3-why-band__mascot {
  flex-shrink: 0;
  width: 160px;
  filter: drop-shadow(0 16px 24px rgba(0,0,0,0.22));
  animation: h3-mascot-float 5s ease-in-out infinite;
}
@media (max-width: 760px) {
  .h3-why-band { padding: 56px 0; }
  .h3-why-band__inner { flex-wrap: wrap; gap: 20px; }
  .h3-why-band__quote { display: none; }
  .h3-why-band__mascot { width: 100px; }
  .h3-why-band__body { flex: 1 0 100%; }
}

/* =========================================================
   QUEM SOMOS V3 — Split equipe (header | card)
   ========================================================= */
.h3-team-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.h3-team-split .h3-section-header { margin-bottom: 0; }
@media (max-width: 760px) {
  .h3-team-split { grid-template-columns: 1fr; gap: 28px; }
}

/* =========================================================
   QUEM SOMOS V3 — Card único de equipe
   ========================================================= */
.h3-team-statement {
  background: linear-gradient(160deg, var(--bege), var(--creme-soft));
  border: 1px solid rgba(226, 161, 109, 0.2);
  border-radius: var(--r-lg);
  padding: 48px 40px;
  display: flex;
  align-items: flex-start;
  gap: 28px;
  box-shadow: var(--shadow-soft);
}
.h3-team-statement__icon {
  width: 64px;
  height: 64px;
  background: var(--verde-claro);
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--terracota-dark);
}
.h3-team-statement__icon svg {
  width: 36px;
  height: 36px;
}
.h3-team-statement p {
  font-size: 1.08rem;
  line-height: 1.7;
  color: var(--tinta);
  text-wrap: pretty;
  flex: 1;
  margin: 0;
  padding-top: 10px;
}
@media (max-width: 600px) {
  .h3-team-statement { flex-direction: column; padding: 32px 24px; gap: 20px; }
  .h3-team-statement p { padding-top: 0; }
}
