/* ==========================================================
   ge-irpf.css — Checkup IRPF
   Template:
   - G-E core
   Função:
   - layout do guia estratégico
   - hero amplo
   - introdução
   - grid principal com conteúdo + sidebar
   - sumário sticky
   - CTA intermediário
   - páginas do cluster
   - FAQ final

   NÃO colocar aqui:
   - tokens de tema
   - footer
   - hubnav
   - office/recommended path ATD
   ========================================================== */

/* ==========================================================
   1) HERO G-E
   ========================================================== */
.rb-ge-hero {
  padding-top: var(--rb-space-6);
  padding-bottom: var(--rb-space-5);
}

.rb-ge-hero-card {
  display: grid;
  gap: var(--rb-space-5);
  padding: var(--rb-space-7);
  border: 1px solid var(--rb-border);
  border-radius: var(--rb-radius-xl);
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--rb-brand-1) 18%, transparent), transparent 42%),
    var(--rb-surface);
  box-shadow: var(--rb-shadow-md);
}

.rb-ge-hero-card h1 {
  max-width: 16ch;
  margin-bottom: var(--rb-space-2);
}

.rb-ge-hero-card .rb-lead {
  max-width: 66ch;
  margin-bottom: 0;
}

.rb-hero-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--rb-space-4);
}

.rb-hero-points .card {
  height: 100%;
}

/* ==========================================================
   2) INTRO
   ========================================================== */
.rb-ge-intro {
  padding-top: var(--rb-space-4);
  padding-bottom: var(--rb-space-5);
}

.rb-ge-intro .card {
  max-width: 920px;
}

/* ==========================================================
   3) LAYOUT PRINCIPAL
   ========================================================== */
.rb-ge-layout {
  padding-top: var(--rb-space-3);
  padding-bottom: var(--rb-space-7);
}

.rb-ge-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.75fr);
  gap: var(--rb-space-5);
  align-items: start;
}

.rb-ge-content {
  min-width: 0;
  display: grid;
  gap: var(--rb-space-5);
}

.rb-ge-sidebar {
  min-width: 0;
  position: sticky;
  top: 88px;
  align-self: start;
}

.rb-ge-sidebar-sticky {
  display: grid;
  gap: var(--rb-space-4);
}

/* ==========================================================
   4) SEÇÕES DO GUIA
   ========================================================== */
.rb-ge-section {
  scroll-margin-top: 100px;
}

.rb-ge-section p:last-child {
  margin-bottom: 0;
}

/* ==========================================================
   5) SUMÁRIO
   ========================================================== */
.rb-ge-toc {
  display: grid;
  gap: var(--rb-space-3);
}

.rb-ge-toc h2 {
  margin-bottom: 0;
}

/* ==========================================================
   6) CTA LATERAL
   ========================================================== */
.rb-ge-sidebar-cta {
  display: grid;
  gap: var(--rb-space-3);
}

.rb-ge-sidebar-cta h2,
.rb-ge-sidebar-cta p:last-child {
  margin-bottom: 0;
}

/* ==========================================================
   7) RELACIONADOS E FONTES NA SIDEBAR
   ========================================================== */
.rb-ge-sidebar-related,
.rb-ge-sources {
  display: grid;
  gap: var(--rb-space-3);
}

/* ==========================================================
   8) CTA INTERMEDIÁRIO
   ========================================================== */
.rb-ge-mid-cta {
  padding-top: var(--rb-space-2);
  padding-bottom: var(--rb-space-2);
}

.rb-ge-mid-cta .rb-cta-box {
  width: 100%;
}

/* ==========================================================
   9) PÁGINAS DO CLUSTER
   ========================================================== */
.rb-ge-cluster-pages {
  display: grid;
  gap: var(--rb-space-3);
}

/* ==========================================================
   10) FAQ
   ========================================================== */
.rb-ge-faq {
  padding-top: var(--rb-space-5);
  padding-bottom: var(--rb-space-7);
}

.rb-ge-faq .card {
  max-width: 920px;
}

/* ==========================================================
   11) TABLETS
   ========================================================== */
@media (max-width: 980px) {
  .rb-ge-hero-card {
    padding: var(--rb-space-6);
  }

  .rb-hero-points {
    grid-template-columns: 1fr;
  }

  .rb-ge-grid {
    grid-template-columns: 1fr;
  }

  .rb-ge-sidebar {
  position: static;
}
}

/* ==========================================================
   12) MOBILE
   ========================================================== */
@media (max-width: 640px) {
  .rb-ge-hero {
    padding-top: var(--rb-space-5);
  }

  .rb-ge-hero-card {
    padding: var(--rb-space-5);
    gap: var(--rb-space-4);
  }

  .rb-ge-hero-card h1 {
    max-width: none;
  }

  .rb-ge-content,
  .rb-ge-sidebar-sticky {
    gap: var(--rb-space-4);
  }

  .rb-ge-faq .card,
  .rb-ge-intro .card {
    max-width: 100%;
  }
}