/* ============================================================
   PESE — Prestação Eleitoral Sem Erro
   Design system documental claro (creme + azul-marinho + âmbar)
   Fontes: Archivo (títulos) + Source Sans 3 (corpo). Sans-serif.
   ============================================================ */

:root{
  /* Paleta da marca */
  --cream:        #F2EAD9;
  --paper:        #FBF8F0;  /* fundo de página, creme claro */
  --paper-2:      #F4EEE0;  /* alternância de seção */
  --cream-line:   #E4D8BF;  /* hairline em tom quente */
  --navy:         #102A43;  /* institucional, texto, header */
  --navy-2:       #1B3A57;  /* gradiente de faixas escuras */
  --sage:         #3D4A3F;
  --moss:         #2E3B2C;  /* fundo de CTA escuro */
  --amber:        #D99A29;
  --amber-deep:   #B8801C;

  /* Texto */
  --ink:          #13212E;  /* títulos */
  --text:         #2C3B47;  /* corpo */
  --text-soft:    #5C6B77;  /* secundário */
  --on-dark:      #F2EAD9;
  --on-dark-soft: rgba(242,234,217,.80);
  --on-dark-line: rgba(242,234,217,.16);

  /* Forma */
  --radius:    4px;
  --radius-lg: 8px;
  --maxw:      1120px;
  --maxw-prose: 720px;

  /* Sombra (escala de cinza, sem cor) */
  --shadow-sm: 0 1px 2px rgba(16,42,67,.05), 0 1px 3px rgba(16,42,67,.05);
  --shadow:    0 6px 22px rgba(16,42,67,.09);

  --fs-display: clamp(1.85rem, 1.2rem + 2.2vw, 2.85rem);
  --fs-h2:      clamp(1.6rem, 1.15rem + 1.9vw, 2.35rem);
  --fs-h3:      clamp(1.18rem, 1.05rem + 0.6vw, 1.4rem);
}

*{ box-sizing: border-box; }

html{ scroll-behavior: smooth; }

body{
  margin: 0;
  font-family: "Source Sans 3", system-ui, -apple-system, sans-serif;
  color: var(--text);
  background: var(--paper);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Textura sutil de papel no fundo */
body::before{
  content:"";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .5;
  background:
    radial-gradient(circle at 20% 10%, rgba(217,154,41,.04), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(16,42,67,.035), transparent 45%);
}

h1,h2,h3,h4{
  font-family: "Archivo", system-ui, sans-serif;
  color: var(--ink);
  line-height: 1.12;
  letter-spacing: -0.01em;
  margin: 0 0 .5em;
  font-weight: 800;
}

p{ margin: 0 0 1rem; }

a{ color: var(--navy); text-decoration: none; }
a:hover{ color: var(--amber-deep); }

img{ max-width: 100%; display: block; }

.wrap{ width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; position: relative; z-index: 1; }

section{ position: relative; z-index: 1; }

/* ---------- Utilitários documentais ---------- */

.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:"Archivo", sans-serif;
  font-weight:700; font-size:.72rem; letter-spacing:.18em;
  text-transform:uppercase; color: var(--amber-deep);
  margin: 0 0 1rem;
}
.eyebrow::before{
  content:""; width:34px; height:2px; background: var(--amber); display:inline-block;
}
.eyebrow.on-dark{ color: var(--amber); }

.amber-rule{ width:60px; height:3px; background: var(--amber); border:0; margin:1.25rem 0; }
.amber-rule.center{ margin-inline:auto; }

.lede{ font-size:1.16rem; color: var(--text-soft); }

/* ---------- Botões ---------- */

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:"Archivo", sans-serif; font-weight:700; font-size:1rem;
  padding:.95rem 1.7rem; border-radius: var(--radius); border:2px solid transparent;
  cursor:pointer; transition: transform .15s ease, background .2s ease, box-shadow .2s ease;
  text-align:center; line-height:1.1;
}
.btn-amber{ background: var(--amber); color: var(--navy); }
.btn-amber:hover{ background: var(--amber-deep); color:#fff; transform: translateY(-2px); box-shadow: var(--shadow); }
.btn-navy{ background: var(--navy); color: var(--cream); }
.btn-navy:hover{ background: var(--navy-2); color:#fff; transform: translateY(-2px); }
.btn-ghost{ background: transparent; color: var(--navy); border-color: var(--cream-line); }
.btn-ghost:hover{ border-color: var(--navy); color: var(--navy); }
.btn-block{ width:100%; }
.btn .material-symbols-outlined{ font-size:1.2em; }

/* ---------- Header ---------- */

.site-header{
  position: sticky; top:0; z-index: 50;
  background: rgba(251,248,240,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--cream-line);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:88px; gap:1rem;
}
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand img{
  height:58px; width:auto; background:#fff;
  padding:6px 11px; border-radius:8px; border:1px solid var(--cream-line);
}
.nav{ display:flex; align-items:center; gap:2rem; }
.nav a{
  font-family:"Archivo", sans-serif; font-weight:600; font-size:.97rem; color: var(--navy);
  position: relative; padding:.3rem 0;
}
.nav a:hover, .nav a.active{ color: var(--amber-deep); }
.nav a.active::after{
  content:""; position:absolute; left:0; bottom:-2px; width:100%; height:2px; background: var(--amber);
}
.header-cta{ display:flex; align-items:center; gap:1rem; }
.nav-toggle{
  display:none; background:none; border:0; cursor:pointer; color: var(--navy);
}
.nav-toggle .material-symbols-outlined{ font-size:1.9rem; }

/* ---------- Hero ---------- */

.hero{ background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%); padding: 2.8rem 0 3rem; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap: 3rem; align-items:center; }
.hero h1{ font-size: var(--fs-display); }
.hero h1 em{ font-style:normal; color: var(--amber-deep); }
.hero .lede{ max-width: 38ch; margin-top: 1rem; font-size:1.08rem; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin-top:1.4rem; font-size:.9rem; color: var(--text-soft); }
.hero-meta span{ display:inline-flex; align-items:center; gap:.4rem; }
.hero-meta .material-symbols-outlined{ font-size:1.15rem; color: var(--sage); }
.hero-text, .hero-visual{ min-width:0; }
.hero-actions{ margin-top:1.5rem; }
.hero-actions .btn{ font-size:1.05rem; padding:1rem 1.9rem; }
.hero-visual{ position:relative; }
.hero-visual .app-preview{ margin:0; }
.hero-visual .browser{ max-width:100%; }
.hero-visual .app-preview figcaption{ color: var(--text-soft); font-weight:500; }

/* Faixa de pré-cadastro */
.form-band .form-card{ max-width:560px; margin-inline:auto; }
.form-band .section-head{ margin-bottom:2rem; }

/* ---------- Form card ---------- */

.form-card{
  background:#fff; border:1px solid var(--cream-line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); padding: 1.6rem 1.7rem 1.7rem; position:relative;
}
.form-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:5px;
  background: var(--amber); border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.form-status{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:"Archivo",sans-serif; font-weight:700; font-size:.74rem;
  letter-spacing:.05em; text-transform:uppercase; color: var(--amber-deep);
  margin:0 0 .7rem;
}
.form-status .dot{
  width:9px; height:9px; border-radius:50%; background: var(--amber);
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot{
  0%{ box-shadow:0 0 0 0 rgba(217,154,41,.5); }
  70%{ box-shadow:0 0 0 8px rgba(217,154,41,0); }
  100%{ box-shadow:0 0 0 0 rgba(217,154,41,0); }
}
.form-card h3{ font-size:1.3rem; margin-bottom:.35rem; }
.form-card .form-sub{ font-size:.92rem; color: var(--text-soft); margin-bottom:1.1rem; }
.field{ margin-bottom:.7rem; }
.field label{
  display:block; font-family:"Archivo",sans-serif; font-weight:600; font-size:.82rem;
  letter-spacing:.02em; color: var(--navy); margin-bottom:.3rem; text-transform:uppercase;
}
.field input, .field select{
  width:100%; padding:.68rem .85rem; font-size:.98rem; font-family:inherit;
  color: var(--text); background: var(--paper); border:1.5px solid var(--cream-line);
  border-radius: var(--radius); transition: border-color .15s ease, box-shadow .15s ease;
}
.field input:focus, .field select:focus{
  outline:none; border-color: var(--navy); box-shadow: 0 0 0 3px rgba(16,42,67,.08);
}
.form-note{ font-size:.82rem; color: var(--text-soft); margin-top:.9rem; text-align:center; }
.form-success{
  display:none; text-align:center; padding:1.5rem .5rem;
}
.form-success .material-symbols-outlined{ font-size:3rem; color: var(--sage); }
.form-success h3{ margin:.6rem 0 .3rem; }
.form-card.is-sent form{ display:none; }
.form-card.is-sent .form-success{ display:block; }

/* ---------- Faixa de dado (escura) ---------- */

.stat-band{ background: var(--navy); color: var(--on-dark); padding: 3.5rem 0; }
.stat-band .wrap{ max-width: 880px; text-align:center; }
.stat-band .stat-number{
  font-family:"Archivo",sans-serif; font-weight:800; color: var(--cream);
  font-size: clamp(1.55rem, 1rem + 2.6vw, 2.6rem); line-height:1.2;
}
.stat-band .stat-number b{ color: var(--amber); font-weight:800; }
.stat-band p{ color: var(--on-dark-soft); font-size:1.08rem; margin:1.2rem auto 0; max-width: 54ch; }

/* ---------- Seções genéricas ---------- */

.section{ padding: 4.5rem 0; }
.section.alt{ background: var(--paper-2); border-top:1px solid var(--cream-line); border-bottom:1px solid var(--cream-line); }
.section-head{ max-width: 640px; margin-bottom: 2.6rem; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head h2{ font-size: var(--fs-h2); }
.section-head p{ color: var(--text-soft); font-size:1.1rem; }

/* ---------- Cards de problema ---------- */

.grid-2{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
.doc-card{
  background:#fff; border:1px solid var(--cream-line); border-left:3px solid var(--amber);
  border-radius: var(--radius); padding: 1.6rem 1.7rem; box-shadow: var(--shadow-sm);
  transition: transform .15s ease, box-shadow .2s ease;
}
.doc-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow); }
.doc-card .ico{
  width:46px; height:46px; border-radius: var(--radius); display:grid; place-items:center;
  background: var(--cream); color: var(--navy); margin-bottom:1rem;
}
.doc-card .ico .material-symbols-outlined{ font-size:1.6rem; }
.doc-card h3{ font-size:1.18rem; margin-bottom:.4rem; }
.doc-card p{ font-size:.98rem; color: var(--text-soft); margin:0; }

/* ---------- Fluxo / passos ---------- */

.flow{ display:grid; grid-template-columns: repeat(4, 1fr); gap:1.2rem; counter-reset: step; }
.flow-step{
  position:relative; background: var(--paper); border:1px solid var(--cream-line);
  border-radius: var(--radius); padding: 1.7rem 1.4rem 1.5rem;
}
.flow-step .num{
  font-family:"Archivo",sans-serif; font-weight:800; font-size:1.05rem;
  color: var(--amber-deep); letter-spacing:.05em; display:block; margin-bottom:.7rem;
}
.flow-step h3{ font-size:1.08rem; margin-bottom:.4rem; }
.flow-step p{ font-size:.94rem; color: var(--text-soft); margin:0; }
.flow-note{ margin-top:1.8rem; font-size:.95rem; color: var(--text-soft); }
.flow-note b{ color: var(--navy); }

/* ---------- Público (cargos) ---------- */

.audience{ display:grid; grid-template-columns: repeat(4, 1fr); gap:1.1rem; }
.aud-card{ text-align:center; background:#fff; border:1px solid var(--cream-line); border-radius:var(--radius); padding:1.6rem 1rem; }
.aud-card .material-symbols-outlined{ font-size:2.1rem; color: var(--sage); }
.aud-card h3{ font-size:1.05rem; margin:.7rem 0 .3rem; }
.aud-card p{ font-size:.88rem; color: var(--text-soft); margin:0; }

/* ---------- Citações validadas ---------- */

.quotes{ display:grid; grid-template-columns: repeat(3,1fr); gap:1.4rem; }
.quote{
  background: var(--paper-2); border-radius: var(--radius); padding:1.7rem 1.6rem;
  border-top:3px solid var(--amber);
}
.quote p{ font-family:"Archivo",sans-serif; font-weight:600; font-size:1.08rem; color: var(--ink); line-height:1.4; margin:0; }

/* ---------- Faixa do sistema (escura) ---------- */

.system-band{ background: var(--navy); color: var(--on-dark); padding: 4.5rem 0; }
.system-band .section-head{ max-width: 680px; }
.system-band h2{ color: var(--cream); font-size: var(--fs-h2); }
.system-band .section-head p{ color: var(--on-dark-soft); font-size:1.1rem; }
/* Prévia do sistema (browser mockup) */
.app-preview{ margin:0 0 2.8rem; }
.browser{
  max-width:920px; margin-inline:auto; background:#fff;
  border:1px solid var(--on-dark-line); border-radius:12px; overflow:hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,.20);
}
.browser-bar{
  display:flex; align-items:center; gap:.45rem;
  padding:.6rem .9rem; background:#16273a; border-bottom:1px solid rgba(255,255,255,.06);
}
.b-dot{ width:11px; height:11px; border-radius:50%; background: rgba(242,234,217,.28); }
.browser-url{
  margin-left:.6rem; flex:1; max-width:330px;
  font-size:.76rem; color: rgba(242,234,217,.6);
  background: rgba(255,255,255,.06); border-radius:6px; padding:.32rem .8rem;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.browser-tag{
  margin-left:auto; flex-shrink:0;
  font-family:"Archivo",sans-serif; font-weight:700; font-size:.66rem;
  letter-spacing:.08em; text-transform:uppercase; color: var(--navy);
  background: var(--amber); padding:.22rem .6rem; border-radius:4px;
}
.browser img{ display:block; width:100%; height:auto; }
.app-preview figcaption{ text-align:center; margin-top:1rem; font-size:.88rem; color: var(--on-dark-soft); }

.modulos{ margin-top: .5rem; }
.modulo-card{
  display:flex; gap:1.1rem; align-items:flex-start;
  background: rgba(242,234,217,.05); border:1px solid var(--on-dark-line);
  border-radius: var(--radius-lg); padding:1.5rem 1.6rem;
  transition: transform .15s ease, background .2s ease;
}
.modulo-card:hover{ background: rgba(242,234,217,.09); transform: translateY(-3px); }
.modulo-card .m-ico{
  flex-shrink:0; width:48px; height:48px; border-radius:10px; display:grid; place-items:center;
  background: rgba(217,154,41,.14); color: var(--amber);
}
.modulo-card .m-ico .material-symbols-outlined{ font-size:1.6rem; }
.modulo-card h3{ color: var(--cream); font-size:1.12rem; margin-bottom:.3rem; }
.modulo-card p{ color: var(--on-dark-soft); font-size:.95rem; margin:0; }
.system-note{ text-align:center; margin-top:2.2rem; color: var(--on-dark-soft); font-size:1.02rem; }
.system-note a{ color: var(--amber); font-family:"Archivo",sans-serif; font-weight:700; }
.system-note a:hover{ color:#fff; }

/* ---------- Faixa CTA escura ---------- */

.cta-band{ background: var(--moss); color: var(--on-dark); padding: 4.5rem 0; }
.cta-band .wrap{ max-width: 760px; text-align:center; }
.cta-band h2{ color: var(--cream); font-size: var(--fs-h2); }
.cta-band p{ color: var(--on-dark-soft); font-size:1.12rem; margin-bottom:1.8rem; }
.cta-band .form-card{ text-align:left; margin-top:2.2rem; }

/* ---------- Footer ---------- */

.site-footer{ background: var(--navy); color: var(--on-dark-soft); padding: 3.5rem 0 2rem; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:2.5rem; }
.site-footer img{ height:48px; width:auto; margin-bottom:1rem; background:#fff; padding:.4rem .7rem; border-radius: var(--radius); }
.site-footer h4{ color: var(--cream); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a{ color: var(--on-dark-soft); display:block; padding:.25rem 0; font-size:.96rem; }
.site-footer a:hover{ color: var(--amber); }
.footer-about p{ font-size:.95rem; max-width: 36ch; }
.footer-bottom{
  margin-top:2.6rem; padding-top:1.5rem; border-top:1px solid var(--on-dark-line);
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-size:.85rem; color: rgba(242,234,217,.6);
}
.footer-bottom a{ display:inline; }

/* ---------- Blog index ---------- */

.page-hero{ background: var(--cream); padding: 3.5rem 0 3rem; border-bottom:1px solid var(--cream-line); }
.page-hero .wrap{ max-width: 760px; }
.page-hero h1{ font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem); }
.page-hero p{ color: var(--text-soft); font-size:1.15rem; max-width: 52ch; }

.filterbar{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.8rem; }
.chip{
  font-family:"Archivo",sans-serif; font-weight:600; font-size:.85rem;
  padding:.4rem .9rem; border-radius:100px; border:1.5px solid var(--cream-line);
  background:#fff; color: var(--navy); cursor:pointer; transition: all .15s ease;
}
.chip:hover{ border-color: var(--navy); }
.chip.active{ background: var(--navy); color: var(--cream); border-color: var(--navy); }

.post-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:1.6rem; }
.post-card{
  display:flex; flex-direction:column; background:#fff; border:1px solid var(--cream-line);
  border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-sm);
  transition: transform .15s ease, box-shadow .2s ease;
}
.post-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow); }
.post-cover{
  aspect-ratio: 16/9; position:relative; overflow:hidden; background: var(--navy);
}
.post-cover img{ width:100%; height:100%; object-fit:cover; display:block; }
.post-cat{
  position:absolute; top:.9rem; left:.9rem;
  font-family:"Archivo",sans-serif; font-weight:700; font-size:.72rem; letter-spacing:.1em;
  text-transform:uppercase; color: var(--navy); background: var(--amber);
  padding:.28rem .65rem; border-radius:3px; box-shadow: var(--shadow-sm);
}
.post-body{ padding:1.3rem 1.4rem 1.5rem; display:flex; flex-direction:column; flex:1; }
.post-body h3{ font-size:1.18rem; line-height:1.25; margin-bottom:.5rem; }
.post-body h3 a{ color: var(--ink); }
.post-body h3 a:hover{ color: var(--amber-deep); }
.post-body p{ font-size:.96rem; color: var(--text-soft); flex:1; }
.post-meta{
  margin-top:1rem; padding-top:.9rem; border-top:1px solid var(--cream-line);
  display:flex; justify-content:space-between; align-items:center;
  font-size:.84rem; color: var(--text-soft);
}
.post-meta .read{ font-family:"Archivo",sans-serif; font-weight:700; color: var(--amber-deep); display:inline-flex; align-items:center; gap:.25rem; }

/* ---------- Artigo ---------- */

.article-hero{ background: var(--cream); padding: 3.2rem 0 2.6rem; border-bottom:1px solid var(--cream-line); }
.article-hero .wrap{ max-width: var(--maxw-prose); }
.breadcrumb{ font-size:.88rem; color: var(--text-soft); margin-bottom:1.2rem; }
.breadcrumb a{ color: var(--amber-deep); }
.article-tag{
  font-family:"Archivo",sans-serif; font-weight:700; font-size:.72rem; letter-spacing:.1em;
  text-transform:uppercase; color: var(--navy); background: var(--amber);
  padding:.3rem .7rem; border-radius:3px; display:inline-block; margin-bottom:1rem;
}
.article-hero h1{ font-size: clamp(1.9rem, 1.3rem + 2.4vw, 2.8rem); }
.article-info{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin-top:1.2rem; font-size:.9rem; color: var(--text-soft); }
.article-info span{ display:inline-flex; align-items:center; gap:.35rem; }
.article-info .material-symbols-outlined{ font-size:1.1rem; }

.article-body{ padding: 3rem 0 1rem; }
.article-body .wrap{ max-width: var(--maxw-prose); }
.article-body h2{ font-size: 1.55rem; margin: 2.4rem 0 .8rem; }
.article-body h3{ font-size: 1.22rem; margin: 1.8rem 0 .6rem; }
.article-body p{ font-size: 1.1rem; line-height:1.78; margin-bottom:1.3rem; }
.article-body ul, .article-body ol{ font-size:1.1rem; line-height:1.7; margin:0 0 1.4rem; padding-left:1.3rem; }
.article-body li{ margin-bottom:.6rem; }
.article-body strong{ color: var(--ink); }
.article-body .lead-p{ font-size:1.22rem; color: var(--text); }

.pullquote{
  border-left:4px solid var(--amber); background: var(--paper-2);
  padding:1.3rem 1.6rem; margin:2rem 0; border-radius: 0 var(--radius) var(--radius) 0;
}
.pullquote p{ font-family:"Archivo",sans-serif; font-weight:600; font-size:1.2rem; color: var(--navy); margin:0; line-height:1.4; }

.callout{
  background: var(--navy); color: var(--on-dark); border-radius: var(--radius-lg);
  padding:1.6rem 1.7rem; margin:2.2rem 0;
}
.callout h3{ color: var(--cream); font-size:1.15rem; margin-bottom:.5rem; }
.callout p{ color: var(--on-dark-soft); margin:0; font-size:1.02rem; }

.doc-checklist{ list-style:none; padding:0; margin:1.4rem 0; }
.doc-checklist li{
  display:flex; gap:.7rem; align-items:flex-start; padding:.7rem 0;
  border-bottom:1px dashed var(--cream-line); font-size:1.05rem;
}
.doc-checklist li .material-symbols-outlined{ color: var(--sage); font-size:1.4rem; flex-shrink:0; }

.article-cta{ padding: 2.5rem 0 4.5rem; }
.article-cta .wrap{ max-width: var(--maxw-prose); }
.article-cta-inner{
  background: var(--moss); color: var(--on-dark); border-radius: var(--radius-lg);
  padding: 2.4rem 2rem; text-align:center;
}
.article-cta-inner h2{ color: var(--cream); font-size:1.5rem; }
.article-cta-inner p{ color: var(--on-dark-soft); max-width: 46ch; margin:.6rem auto 1.6rem; }

.more-posts{ background: var(--paper-2); border-top:1px solid var(--cream-line); padding:3.5rem 0; }

/* ---------- Sobre ---------- */

.about-block{ display:grid; grid-template-columns: 1fr 1fr; gap:3rem; align-items:center; }
.about-block.reverse .about-text{ order:2; }
.about-text h2{ font-size: var(--fs-h2); }
.about-figure{
  background: linear-gradient(150deg, var(--navy), var(--moss)); border-radius: var(--radius-lg);
  aspect-ratio: 4/3; display:grid; place-items:center; color: rgba(242,234,217,.5);
  border:1px solid var(--cream-line); text-align:center; padding:1.5rem;
}
.about-figure .material-symbols-outlined{ font-size:3.5rem; }
.about-figure.photo{
  background:none; border:0; padding:0; aspect-ratio:auto; display:block;
  max-width:380px; margin-inline:auto;
}
.about-figure.photo img{
  width:100%; height:auto; border-radius: var(--radius-lg);
  border:1px solid var(--cream-line); box-shadow: var(--shadow); display:block;
}
.figure-caption{ margin-top:1rem; }
.figure-caption strong{ display:block; font-family:"Archivo",sans-serif; color: var(--ink); font-size:1.05rem; }
.figure-caption span{ display:block; margin-top:.2rem; font-size:.92rem; color: var(--text-soft); }
.placeholder-note{
  border:1.5px dashed var(--amber); background: rgba(217,154,41,.06);
  border-radius: var(--radius); padding:1rem 1.2rem; font-size:.95rem; color: var(--text-soft);
  margin:1.2rem 0;
}
.placeholder-note b{ color: var(--amber-deep); }

.values{ display:grid; grid-template-columns: repeat(3,1fr); gap:1.4rem; margin-top:1rem; }
.value h3{ font-size:1.1rem; display:flex; align-items:center; gap:.5rem; }
.value h3 .material-symbols-outlined{ color: var(--amber-deep); }
.value p{ font-size:.97rem; color: var(--text-soft); }

.timeline{ margin-top:1.5rem; }
.timeline-item{ display:flex; gap:1.2rem; padding:1rem 0; border-bottom:1px solid var(--cream-line); }
.timeline-date{ font-family:"Archivo",sans-serif; font-weight:800; color: var(--amber-deep); min-width:120px; }
.timeline-item p{ margin:0; }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Acessibilidade. respeita quem desativa animações ---------- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal{ opacity: 1 !important; transform: none !important; }
}

/* ============================================================
   Responsivo
   ============================================================ */
@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; gap:2.4rem; }
  .hero .lede{ max-width: none; }
  .flow{ grid-template-columns: repeat(2,1fr); }
  .audience{ grid-template-columns: repeat(2,1fr); }
  .quotes{ grid-template-columns: 1fr; }
  .post-grid{ grid-template-columns: repeat(2,1fr); }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:2rem; }
  .footer-about{ grid-column: 1 / -1; }
  .about-block{ grid-template-columns: 1fr; gap:1.6rem; }
  .about-block.reverse .about-text{ order:0; }
  .values{ grid-template-columns: 1fr; }
}

@media (max-width: 640px){
  body{ font-size:16px; }
  .nav{
    position:fixed; inset:88px 0 auto 0; flex-direction:column; align-items:stretch;
    gap:0; background: var(--paper); border-bottom:1px solid var(--cream-line);
    padding:.5rem 0; box-shadow: var(--shadow); transform: translateY(-120%);
    transition: transform .25s ease; visibility:hidden;
  }
  .nav.open{ transform:none; visibility:visible; }
  .nav a{ padding:.9rem 24px; border-bottom:1px solid var(--cream-line); }
  .nav a.active::after{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .header-cta .btn{ display:none; }
  .grid-2{ grid-template-columns: 1fr; }
  .flow{ grid-template-columns: 1fr; }
  .audience{ grid-template-columns: 1fr; }
  .post-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
  .section{ padding:3.2rem 0; }
  .article-body .wrap, .hero{ padding-left:0; padding-right:0; }
}
