/*
 * layout.css — Rogério Paulo | Psicoterapia & Psicanálise
 * Navbar, footer, hero, seções, grids e FAQ accordion.
 * Depende de variables.css, base.css e components.css — carregue-os antes.
 */

/* ==========================================================
   NAVBAR
========================================================== */
#site-header,
.site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
  z-index: 1000;
  background: rgba(255, 255, 255, 1);
  box-shadow: var(--shadow-sm);
  box-sizing: border-box;
}

#site-header .container,
.site-header .container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  height: auto !important;
  min-height: unset !important;
  gap: var(--space-8);
}

/* Avatar circular da logo */
.site-logo-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}

/* Logo */
.site-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none;
}

.site-logo img,
.site-logo svg {
  height: 44px;
  width: auto;
}

/* Logo texto */
.site-logo-text {
  font-family: var(--font-heading) !important;
  font-size: 20px !important;
  font-weight: var(--fw-bold) !important;
  color: var(--color-primary) !important;
  transition: color var(--transition-fast);
}

.site-header.scrolled .site-logo-text {
  color: var(--color-text-heading) !important;
}

/* Nav central */
.site-nav {
  display: flex !important;
  align-items: center;
  gap: var(--space-8);
  list-style: none;
}

.site-nav a {
  font-family: var(--font-body);
  font-size: var(--text-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-body) !important;
  text-decoration: none !important;
  padding: var(--space-2) 0;
  border-bottom: 2px solid transparent;
  transition:
    color var(--transition-fast),
    border-color var(--transition-fast);
}

.site-nav a:hover,
.site-nav a.active {
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.site-nav a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 4px;
  border-radius: var(--radius-sm);
}

/* Botão CTA direita */
.site-header-cta {
  flex-shrink: 0;
}

/* Hamburger — mobile */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px !important;
  height: 40px !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  cursor: pointer;
  padding: 4px !important;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
  -webkit-appearance: none;
  appearance: none;
}

.hamburger:hover {
  background-color: var(--color-primary-light) !important;
}

.hamburger:focus,
.hamburger:focus-visible {
  outline: 2px solid var(--color-primary) !important;
  outline-offset: 2px;
  box-shadow: none !important;
}

.hamburger-line {
  display: block !important;
  width: 22px !important;
  height: 2px !important;
  background: var(--color-text-heading) !important;
  border-radius: var(--radius-full) !important;
  transition: transform var(--transition-base), opacity var(--transition-fast);
}

/* Hamburger sobre fundo escuro */
.site-header:not(.scrolled) .hamburger-line {
  background: var(--color-text-heading) !important;
}

/* Estado aberto */
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(2) {
  opacity: 0;
}
.hamburger[aria-expanded="true"] .hamburger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Menu mobile — drawer */
.site-nav-mobile {
  display: none;
  position: fixed;
  top: 72px;
  left: 0;
  right: 0;
  background: var(--color-white);
  border-top: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
  z-index: 999;
  padding: var(--space-6) 24px var(--space-8);
  flex-direction: column;
  gap: var(--space-2);
}

.site-nav-mobile.open {
  display: flex;
}

.site-nav-mobile a {
  font-family: var(--font-body);
  font-size: var(--text-body);
  font-weight: var(--fw-medium);
  color: var(--color-text-body);
  text-decoration: none;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
  transition: color var(--transition-fast);
}

.site-nav-mobile a:last-of-type {
  border-bottom: none;
}

.site-nav-mobile a:hover {
  color: var(--color-primary);
}

.site-nav-mobile .btn-primary {
  margin-top: var(--space-4);
  justify-content: center;
  text-align: center;
  color: var(--color-text-white) !important;
  opacity: 1 !important;
}

/* Botão hamburguer — estado aberto (X) sem borda */
.hamburger[aria-expanded="true"] {
  border: none !important;
  background: none !important;
  background-color: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

.hamburger[aria-expanded="true"] .hamburger-line {
  background: var(--color-text-heading) !important;
}

/* Hamburger — escondido por padrão no desktop */
.hamburger {
  display: none !important;
}

/* Responsivo — tablet/mobile */
@media (max-width: 768px) {
  .site-nav,
  .site-header-cta {
    display: none !important;
  }

  .hamburger {
    display: flex !important;
  }
}

/* ==========================================================
   SEÇÕES — ESTRUTURA BASE
========================================================== */
.section {
  padding-block: var(--section-padding-y);
}

.section--sm {
  padding-block: var(--space-16);
}

.section--white  { background: var(--color-bg); }
.section--alt    { background: var(--color-bg-section); }
.section--dark   {
  background: var(--color-bg-footer);
}

/* Wrapper de conteúdo interno */
.section-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.section-header {
  max-width: 640px;
}

.section-header--center {
  max-width: 640px;
  margin-inline: auto;
  text-align: center;
}

.section-header h2 {
  margin-top: var(--space-2);
}

.section-header p {
  margin-top: var(--space-4);
}

@media (max-width: 768px) {
  .section {
    padding-block: var(--section-padding-y-sm);
  }

  .section--sm {
    padding-block: var(--space-12);
  }
}

/* ==========================================================
   HERO — PÁGINA INICIAL
========================================================== */
.hero {
  position: relative;
  height: 900px !important;
  min-height: 700px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--color-bg-footer);
}

.admin-bar .hero {
  height: 900px !important;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(10, 20, 11, 0.85) 0%,
    rgba(10, 20, 11, 0.50) 45%,
    rgba(10, 20, 11, 0.10) 100%
  );
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 600px;
  display: flex;
  flex-direction: column;
  padding-top: 72px; /* compensa navbar fixa */
}

.hero-content .overline {
  margin-bottom: var(--space-2);
}

.hero-content h1 {
  color: var(--color-text-white);
  font-size: var(--text-display);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-5);
}

.hero-content .lead {
  color: rgba(255, 255, 255, 0.80);
  margin-bottom: var(--space-8);
}

.hero-content .btn-group {
  margin-top: 0;
}

@media (max-width: 768px) {
  .hero-content h1 {
    font-size: var(--text-display-mobile);
  }

  .hero-overlay {
    background: rgba(26, 43, 28, 0.75);
  }
}

/* ==========================================================
   HERO — PÁGINAS INTERNAS (sem imagem de fundo)
========================================================== */
.page-hero {
  background: var(--color-bg-footer);
  padding-top: calc(80px + var(--section-padding-y));
  padding-bottom: var(--section-padding-y);
}

.page-hero h1 {
  color: var(--color-text-white);
  max-width: 700px;
}

.page-hero .lead {
  color: rgba(255, 255, 255, 0.75);
  max-width: 580px;
  margin-top: var(--space-4);
}

/* ==========================================================
   GRID — 2 COLUNAS (texto + imagem)
========================================================== */
.grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}

.grid-2col--img-right .col-img { order: 2; }
.grid-2col--img-right .col-text { order: 1; }

.grid-2col--img-left .col-img { order: 1; }
.grid-2col--img-left .col-text { order: 2; }

/* Imagem sticky no desktop — fixa enquanto o texto scrolla */
@media (min-width: 901px) {
  .grid-2col .col-img {
    position: sticky;
    top: calc(72px + var(--space-10)); /* altura do navbar fixo + respiro */
    align-self: start;
  }
}

.col-img img {
  width: 100%;
  height: 100%;
  max-height: 520px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: none;
  display: block;
}

.col-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.col-text h2 {
  margin-top: var(--space-2);
}

.col-text p + p {
  margin-top: 0;
}

@media (max-width: 900px) {
  .grid-2col {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .grid-2col--img-right .col-img,
  .grid-2col--img-left .col-img {
    order: 0;
  }

  .grid-2col--img-right .col-text,
  .grid-2col--img-left .col-text {
    order: 1;
  }

  .col-img img {
    max-height: 360px;
  }
}

/* ==========================================================
   GRID — 3 COLUNAS (cards)
========================================================== */
.grid-3col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

@media (max-width: 900px) {
  .grid-3col {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .grid-3col {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================
   SEÇÃO CITAÇÃO — FULL WIDTH
========================================================== */
.section-quote {
  position: relative;
  background-color: var(--color-bg-footer);
  background-image: url('../assets/caquito-background.webp');
  background-size: cover;
  background-position: center;
  padding-block: var(--section-padding-y);
  text-align: center;
}

.section-quote::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(26, 43, 28, 0.82);
}

.section-quote .container {
  position: relative;
  z-index: 1;
  max-width: var(--container-narrow);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.section-quote blockquote {
  background: none !important;
  border-left: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: var(--text-h2) !important;
  color: var(--color-text-white) !important;
  font-style: italic;
}

.section-quote blockquote::before {
  display: none;
}

.section-quote blockquote cite {
  color: var(--color-primary-mid) !important;
  margin-top: var(--space-4);
  font-size: var(--text-small) !important;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.section-quote > .container > p {
  color: var(--color-text-footer);
  font-size: var(--text-lead);
}

@media (max-width: 768px) {
  .section-quote blockquote {
    font-size: var(--text-h3);
  }
}

/* ==========================================================
   SEÇÃO CTA FINAL — FULL WIDTH
========================================================== */
.section-cta {
  position: relative;
  background-color: var(--color-bg-footer);
  background-image: url('../assets/caquito-background.webp');
  background-size: cover;
  background-position: center;
  padding-block: var(--section-padding-y);
  text-align: center;
}

.section-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(26, 43, 28, 0.82);
}

.section-cta .container {
  position: relative;
  z-index: 1;
  max-width: 900px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}

.section-cta h2,
.section-cta p {
  margin: 0;
}

.section-cta .btn-group {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
}

.section-cta .btn-group a {
  display: inline-flex !important;
  width: auto !important;
  padding: 18px 36px !important;
  font-size: 17px !important;
}

.section-cta h2 {
  color: var(--color-text-white);
}

.section-cta p {
  color: var(--color-text-footer);
  font-size: var(--text-lead);
}

/* ==========================================================
   SEÇÃO — GRUPO TERAPÊUTICO (hero com imagem de fundo)
========================================================== */
.section-group-hero {
  position: relative;
  padding-block: var(--section-padding-y);
  overflow: hidden;
  background: var(--color-bg-footer);
}

.section-group-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.section-group-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26, 43, 28, 0.80);
}

.section-group-hero .container {
  position: relative;
  z-index: 1;
}

.section-group-hero h2 {
  color: var(--color-text-white);
}

.section-group-hero p {
  color: rgba(255, 255, 255, 0.80);
}

.section-group-hero h3 {
  color: var(--color-text-white);
  font-size: var(--text-h4);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}

/* ==========================================================
   FAQ — ACCORDION
========================================================== */
.faq-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}

.faq-intro {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  position: sticky;
  top: calc(72px + var(--space-8));
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--color-border);
}

.faq-item {
  border-bottom: 1px solid var(--color-border);
}

.faq-question {
  width: 100% !important;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) 0 !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body) !important;
  font-size: var(--text-body) !important;
  font-weight: var(--fw-semibold) !important;
  color: var(--color-text-heading) !important;
  transition: color var(--transition-fast);
  box-shadow: none !important;
}

.faq-question:hover {
  color: var(--color-primary) !important;
  background: none !important;
}

.faq-question:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.faq-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  background: var(--color-primary-light);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-size: 16px;
  font-weight: var(--fw-bold);
  transition: transform var(--transition-base), background var(--transition-fast);
  line-height: 1;
}

.faq-item.open .faq-icon {
  transform: rotate(45deg);
  background: var(--color-primary);
  color: var(--color-white);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.faq-item.open .faq-answer {
  max-height: 400px;
}

.faq-answer-inner {
  padding-bottom: var(--space-5);
  font-size: var(--text-body);
  color: var(--color-text-body);
  line-height: var(--lh-body);
}

@media (max-width: 900px) {
  .faq-section {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }

  .faq-intro {
    position: static;
  }
}

/* ==========================================================
   NEWSLETTER — INLINE FORM
========================================================== */
.newsletter-form {
  display: flex;
  gap: var(--space-3);
  max-width: 480px;
  margin-inline: auto;
}

.newsletter-form .form-input {
  flex: 1;
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--color-text-body);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 13px 16px;
  outline: none;
  transition:
    border-color var(--transition-base),
    box-shadow var(--transition-base);
  appearance: none;
}

.newsletter-form .form-input::placeholder {
  color: var(--color-text-light);
}

.newsletter-form .form-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-focus);
}

.newsletter-form .btn-primary,
.newsletter-form button[type="submit"] {
  background: var(--color-primary) !important;
  background-color: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: 2px solid var(--color-primary) !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-body) !important;
  font-size: var(--text-body) !important;
  font-weight: var(--fw-semibold) !important;
  padding: 13px 24px !important;
  cursor: pointer !important;
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1 !important;
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.newsletter-form .btn-primary:hover,
.newsletter-form button[type="submit"]:hover {
  background: var(--color-primary-dark) !important;
  background-color: var(--color-primary-dark) !important;
  border-color: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
}

@media (max-width: 540px) {
  .newsletter-form {
    flex-direction: column;
  }

  .newsletter-form .btn-primary,
  .newsletter-form button[type="submit"] {
    justify-content: center;
    width: 100%;
  }
}

/* ==========================================================
   SINGLE POST — LAYOUT
========================================================== */

/* Meta do post (data · autor) */
.post-meta {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-top: var(--space-4);
}

/* Área de conteúdo do post */
.post-single-content {
  padding-top: var(--section-padding-y);
  padding-bottom: var(--section-padding-y);
}

/* Coluna de texto centralizada e legível */
.post-body {
  max-width: 720px;
  margin-inline: auto;
}

/* Tipografia interna do post */
.post-body p {
  margin-bottom: var(--space-6);
  line-height: 1.75;
}

.post-body h2 {
  margin-top: var(--space-12);
  margin-bottom: var(--space-4);
}

.post-body h3 {
  margin-top: var(--space-10);
  margin-bottom: var(--space-3);
}

.post-body img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  margin-block: var(--space-8);
  box-shadow: none !important;
}

.post-body ul,
.post-body ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-6);
}

.post-body li {
  margin-bottom: var(--space-2);
  line-height: 1.75;
}


/* ==========================================================
   FOOTER
========================================================== */
.site-footer {
  background: var(--color-bg-footer) !important;
  padding-top: var(--space-20) !important;
  padding-bottom: var(--space-10) !important;
  width: 100% !important;
  max-width: none !important;
}

.site-footer .container {
  background: transparent;
}

.site-footer-grid {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--space-12);
  padding-bottom: var(--space-12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  align-items: start;
  width: 100%;
}

/* Coluna logo + descrição */
.site-footer .footer-brand {
  background: transparent !important;
}

.footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-brand a {
  display: inline-flex;
  align-items: center;
  width: fit-content;
}

.footer-brand img,
.footer-brand svg {
  width: 180px;
  height: auto;
  max-width: 100%;
}

.footer-brand p {
  font-size: var(--text-small);
  color: var(--color-text-footer);
  line-height: var(--lh-body);
  margin: 0;
}

/* Coluna nav + contatos */
.footer-col-title {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  margin-bottom: var(--space-4);
}

.footer-nav-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
}

.footer-nav-list a {
  font-size: var(--text-small);
  color: var(--color-text-footer);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-nav-list a:hover {
  color: var(--color-primary-mid);
}

.footer-nav-list a:focus-visible {
  outline: 2px solid var(--color-primary-mid);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* Contatos */
.footer-contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
}

.footer-contact-list li {
  font-size: var(--text-small);
  color: var(--color-text-footer);
  line-height: 1.5;
}

.footer-contact-list a {
  color: var(--color-text-footer);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-contact-list a:hover {
  color: var(--color-primary-mid);
}

/* Bottom bar */
.site-footer-bottom {
  padding-top: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: center;
}

.site-footer-bottom small {
  font-size: var(--text-xs);
  color: var(--color-text-footer);
  opacity: 0.6;
  text-align: center;
  line-height: 1.6;
}

@media (max-width: 900px) {
  .site-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
  }

  .footer-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  .site-footer-grid {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .footer-brand {
    grid-column: auto;
  }
}

/* ==========================================================
   ORDERED LIST — COMO FUNCIONA (seções de serviço)
========================================================== */
.steps-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  list-style: none;
  counter-reset: steps;
}

.steps-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  font-size: var(--text-body);
  color: var(--color-text-body);
  line-height: var(--lh-body);
  counter-increment: steps;
}

.steps-list li::before {
  content: counter(steps);
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: var(--text-small);
  font-weight: var(--fw-bold);
  margin-top: 2px;
}

.bg-dark .steps-list li,
.section-group-hero .steps-list li {
  color: rgba(255, 255, 255, 0.90);
}

.bg-dark .steps-list li::before,
.section-group-hero .steps-list li::before {
  background: var(--color-primary-mid);
}

/* ==========================================================
   LISTA CURRICULAR (ul com marcador verde)
========================================================== */
.curriculum-list {
  display: flex;
  flex-direction: column;
  list-style: none;
}

.curriculum-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  font-size: var(--text-body);
  color: var(--color-text-body);
  line-height: var(--lh-body);
  padding-block: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.curriculum-list li:first-child {
  padding-top: 0;
}

.curriculum-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.curriculum-list li::before {
  content: '✓';
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: var(--color-primary);
  color: var(--color-text-white);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: var(--fw-bold);
  font-family: var(--font-body);
  margin-top: 2px;
}

/* ==========================================================
   PÁGINA — PADDING TOP (compensa navbar fixa)
========================================================== */
.page-content {
  padding-top: 72px;
}

/* ==========================================================
   ANIMAÇÕES DE ENTRADA (IntersectionObserver)
========================================================== */
.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity var(--transition-slow),
    transform var(--transition-slow);
}

.fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger nos grids */
.grid-3col .fade-in:nth-child(2) { transition-delay: 80ms; }
.grid-3col .fade-in:nth-child(3) { transition-delay: 160ms; }


/* ==========================================================
   UTILITÁRIOS DE LAYOUT
========================================================== */
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mt-section { margin-top: var(--space-10); }
.mb-section { margin-bottom: var(--space-10); }

.divider {
  width: 100%;
  height: 1px;
  background: var(--color-border);
  margin-block: var(--space-8);
}

.bg-dark .divider {
  background: rgba(255, 255, 255, 0.08);
}
