﻿@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Plus+Jakarta+Sans:wght@400;500;600&display=swap');


/* ============================================================
   PUPILAY BLOG — CSS v7.2
   Fix principal: largura da coluna (500px -> full-width)
   Outros fixes: pull-stat numero, TOC titulo, breadcrumb,
   meta data, step opacity, paragrafo final resultados
   ============================================================ */
:root {
  --navy:        #08111E;
  --navy-mid:    #0D1C2E;
  --gold:        #C9A84C;
  --gold-light:  #E2C882;
  --off-white:   #F7F4EF;
  --warm-100:    #EDE8DF;
  --gray-text:   #9C9080;
  --gray-border: #1E2F42;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:   'Plus Jakarta Sans', sans-serif;
  --max-prose:   720px;
  --max-wide:    1100px;
  --pad-x:       clamp(1.5rem, 5vw, 3rem);
}


/* ============================================================
   FIX CRITICO — quebrar o constraint do WordPress Global Styles
   O WP impoe max-width: 800px via .is-layout-constrained
   Atacamos todos os ancestrais do page-content para garantir
   que o container e 100% do viewport em todos os niveis
   ============================================================ */
/* Nivel 1: o proprio page-content e seus wrappers diretos */
body.single-post .is-layout-constrained > div.page-content,
body.single-post .is-layout-constrained > .page-content,
body.single-post div.page-content {
  max-width: 100% !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
  display: block !important;
  overflow: visible !important;
}
/* Nivel 2: article, main e site-content — remover qualquer padding/margin/max-width */
body.single-post article.hentry,
body.single-post main#content,
body.single-post .site-main,
body.single-post .entry-content,
body.single-post .post-content {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box !important;
}
/* Nivel 3: o wp-block-html que envolve faq, cta, footer, hero */
body.single-post div.page-content > .wp-block-html {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box !important;
}
/* Zerar o margin-block do WordPress nos filhos diretos do page-content */
body.single-post div.page-content > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}


/* ============================================================
   FIX — Quebra heranca Elementor Kit 5
   ============================================================ */
body.single-post h1,
body.single-post h2,
body.single-post h3,
body.single-post h4,
body.single-post h5,
body.single-post h6 {
  color: var(--off-white) !important;
  font-weight: 600 !important;
}


/* ============================================================
   BASE — fundo e reset geral
   ============================================================ */
body.single-post,
body.single-post #page,
body.single-post .site-content,
body.single-post .site-main,
body.single-post main,
body.single-post article {
  background: var(--navy) !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body.single-post .site-header,
body.single-post header.site-header,
body.single-post #masthead,
body.single-post .site-footer,
body.single-post footer.site-footer,
body.single-post #colophon {
  display: none !important;
}
body.single-post h1.entry-title,
body.single-post h1.post-title,
body.single-post .entry-header,
body.single-post .page-header {
  display: none !important;
}
body.single-post .entry-content,
body.single-post .post-content,
body.single-post .elementor-widget-theme-post-content .elementor-widget-container {
  padding: 0 !important;
  margin: 0 !important;
  background: var(--navy) !important;
  color: var(--gray-text) !important;
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
}


/* ============================================================
   FIX — Zerar margin/padding dos wrappers Gutenberg
   ============================================================ */
body.single-post .entry-content > .wp-block-html,
body.single-post .post-content > .wp-block-html,
body.single-post div.page-content > .wp-block-html,
body.single-post .entry-content > .wp-block-html > *,
body.single-post .post-content > .wp-block-html > *,
body.single-post div.page-content > .wp-block-html > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: block !important;
}
/* Schema JSON-LD invisivel */
body.single-post div.page-content > .wp-block-html:has(> script),
body.single-post .entry-content > .wp-block-html:has(> script) {
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}
body.single-post div.page-content > .wp-block-html:nth-child(2),
body.single-post .entry-content > .wp-block-html:nth-child(2) {
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}
/* Hero: zero gap abaixo */
body.single-post .article-hero-wrap {
  margin: 0 !important;
  padding-top: 92px !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  display: block !important;
}
body.single-post .entry-content > .wp-block-html:first-child,
body.single-post div.page-content > .wp-block-html:first-child {
  margin: 0 !important;
  padding: 0 !important;
}
body.single-post .entry-content > .wp-block-html:first-child > *,
body.single-post div.page-content > .wp-block-html:first-child > * {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}


/* ============================================================
   NAV — post do blog (v3 — alinhado pixel a pixel com /google-meu-negocio e /seo-local)
   Estilos scoped em body.single-post para não afetar outras páginas
   ============================================================ */
body.single-post .pupilay-nav {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 200 !important;
  padding: 28px var(--pad-x) !important;
  width: 100% !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border-bottom: 1px solid transparent !important;
  transition: padding .4s ease, background .4s ease, border-color .4s ease !important;
}
body.single-post .pupilay-nav.scrolled {
  padding: 18px var(--pad-x) !important;
  background: rgba(8,17,30,0.96) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-color: rgba(201,168,76,0.25) !important;
}
body.single-post .pupilay-nav-inner {
  max-width: var(--max-wide) !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}
body.single-post .pupilay-nav-logo {
  font-family: 'Cormorant SC', 'Cormorant Garamond', Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  color: #FFFFFF !important;
  text-decoration: none !important;
  background: transparent !important;
}
body.single-post .pupilay-nav-logo em {
  color: var(--gold) !important;
  font-style: normal !important;
}
body.single-post .pupilay-nav-links {
  display: flex !important;
  align-items: center !important;
  gap: 44px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.single-post .pupilay-nav-links a {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #D4CCBB !important;
  text-decoration: none !important;
  background: transparent !important;
  transition: color .2s !important;
}
body.single-post .pupilay-nav-links a:hover,
body.single-post .pupilay-nav-links a.active {
  color: #E2C882 !important;
  background: transparent !important;
}
body.single-post .pupilay-nav-cta {
  display: flex !important;
  align-items: center !important;
  gap: 20px !important;
}
body.single-post .pupilay-btn-nav-gold {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  border: 1px solid rgba(201,168,76,0.25) !important;
  padding: 12px 28px !important;
  text-decoration: none !important;
  background: transparent !important;
  cursor: pointer !important;
  transition: all .25s ease !important;
  border-radius: 0 !important;
  outline: none !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
body.single-post .pupilay-btn-nav-gold:hover {
  background: var(--gold) !important;
  background-color: var(--gold) !important;
  color: var(--navy) !important;
  border-color: var(--gold) !important;
}
body.single-post .pupilay-nav-hamburger {
  display: none !important;
  flex-direction: column !important;
  gap: 6px !important;
  cursor: pointer !important;
  padding: 4px !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  border-radius: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
body.single-post .pupilay-nav-hamburger span {
  display: block !important;
  width: 22px !important;
  height: 1px !important;
  background: #D4CCBB !important;
  transition: all .3s !important;
}
body.single-post .pupilay-mob-nav {
  display: none;
  position: fixed !important;
  top: 64px !important;
  left: 0 !important;
  right: 0 !important;
  background: rgba(8,17,30,0.97) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid rgba(201,168,76,0.25) !important;
  z-index: 190 !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  padding: 8px 0 16px !important;
}
body.single-post .pupilay-mob-nav.open { display: flex !important; }
body.single-post .pupilay-mob-nav a {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #D4CCBB !important;
  padding: 14px 28px !important;
  width: 100% !important;
  text-decoration: none !important;
  transition: color .2s, background .2s !important;
}
body.single-post .pupilay-mob-nav a:hover {
  color: #E2C882 !important;
  background: rgba(255,255,255,.03) !important;
}
body.single-post .pupilay-mob-nav .pupilay-mob-cta {
  margin: 8px 28px 0 !important;
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  border: 1px solid rgba(201,168,76,0.25) !important;
  padding: 11px 20px !important;
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  text-decoration: none !important;
}
@media (max-width: 768px) {
  body.single-post .pupilay-nav-links,
  body.single-post .pupilay-nav-cta { display: none !important; }
  body.single-post .pupilay-nav-hamburger { display: flex !important; }
  body.single-post .pupilay-nav { padding: 20px var(--pad-x) !important; background: rgba(8,17,30,0.92) !important; }
}


/* ============================================================
   HERO
   ============================================================ */
.article-hero-wrap {
  width: 100% !important;
  background: var(--navy-mid) !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}
.article-hero-inner {
  max-width: var(--max-prose) !important;
  margin: 0 auto !important;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 4vw, 2.5rem) !important;
  box-sizing: border-box !important;
}
/* Breadcrumb — separador / e texto correto (Inicio / Blog / Google Maps em BH) */
body.single-post .article-breadcrumb {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--gray-text) !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
body.single-post .article-breadcrumb a {
  color: var(--gold) !important;
  text-decoration: none !important;
}
body.single-post .article-breadcrumb a:hover { color: var(--gold-light) !important; }
body.single-post .article-breadcrumb span {
  color: var(--gray-border) !important;
  margin: 0 !important;
}
body.single-post .article-tag {
  display: block !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
body.single-post .article-tag-badge {
  display: inline-block !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  border: 1px solid rgba(201,168,76,0.35) !important;
  padding: 0.3em 0.8em !important;
  font-family: var(--font-body) !important;
}
body.single-post .hero-h1 {
  display: block !important;
  font-family: var(--font-display) !important;
  font-size: clamp(2rem, 5vw, 3.2rem) !important;
  font-weight: 500 !important;
  line-height: 1.15 !important;
  color: var(--off-white) !important;
  border: none !important;
  margin: 0 0 1.25rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
  max-width: 100% !important;
}
body.single-post .hero-h1 em {
  font-style: italic !important;
  color: var(--gold-light) !important;
}
body.single-post .article-lead {
  display: block !important;
  font-size: clamp(1rem, 2vw, 1.15rem) !important;
  line-height: 1.75 !important;
  color: var(--gray-text) !important;
  margin: 0 0 2rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
body.single-post .article-hero-inner p,
body.single-post .article-hero-inner .article-lead {
  font-size: clamp(1rem, 2vw, 1.15rem) !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 0 2rem 0 !important;
}
/* Meta — formato "18 de março de 2026" e "Leitura: 8 min" com bold no numero */
body.single-post .article-meta {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 0.5rem 1.5rem !important;
  font-size: 0.8rem !important;
  color: var(--gray-text) !important;
  border-top: 1px solid var(--gray-border) !important;
  border-bottom: none !important;
  padding: 1.5rem 0 0 !important;
  margin: 0 !important;
  background: transparent !important;
}
body.single-post .article-meta strong { color: var(--off-white) !important; font-weight: 500 !important; }
body.single-post .article-meta-sep {
  display: inline-block !important;
  margin: 0 0.25em !important;
  opacity: 0.35 !important;
}


/* ============================================================
   H2 NUCLEAR
   ============================================================ */
html body.single-post #post-7886 .entry-content h2,
html body.single-post #post-7886 .entry-content h2.wp-block-heading {
  font-family: var(--font-display) !important;
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  color: var(--off-white) !important;
  border-top: 1px solid var(--gray-border) !important;
  border-bottom: none !important;
  border-left: none !important;
  border-right: none !important;
  background: transparent !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  display: block !important;
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding: 1rem var(--pad-x) 0 !important;
  margin: 3.5rem auto 1.25rem !important;
  box-sizing: border-box !important;
}
body.single-post article.hentry .entry-content h2,
body.single-post article.hentry .entry-content h2.wp-block-heading,
body.single-post div.page-content > h2,
body.single-post div.page-content h2.wp-block-heading {
  font-family: var(--font-display) !important;
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  color: var(--off-white) !important;
  border-top: 1px solid var(--gray-border) !important;
  border-bottom: none !important;
  border-left: none !important;
  border-right: none !important;
  background: transparent !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  display: block !important;
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding: 1rem var(--pad-x) 0 !important;
  margin: 3.5rem auto 1.25rem !important;
  box-sizing: border-box !important;
}


/* ============================================================
   H3 NUCLEAR
   ============================================================ */
html body.single-post #post-7886 .entry-content h3,
html body.single-post #post-7886 .entry-content h3.wp-block-heading {
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--gold-light) !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  border: none !important;
  background: transparent !important;
  display: block !important;
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding: 0 var(--pad-x) !important;
  margin: 2.5rem auto 0.75rem !important;
  box-sizing: border-box !important;
}
body.single-post article.hentry .entry-content h3,
body.single-post article.hentry .entry-content h3.wp-block-heading,
body.single-post div.page-content > h3,
body.single-post div.page-content h3.wp-block-heading {
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--gold-light) !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  border: none !important;
  background: transparent !important;
  display: block !important;
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding: 0 var(--pad-x) !important;
  margin: 2.5rem auto 0.75rem !important;
  box-sizing: border-box !important;
}
html body.single-post .faq-section h2,
html body.single-post #faq-title {
  font-family: var(--font-display) !important;
  font-size: clamp(1.8rem, 3.5vw, 2.5rem) !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
  margin: 0 0 2.5rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  max-width: 100% !important;
  line-height: 1.15 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
html body.single-post .cta-strip h2,
html body.single-post #cta-title {
  font-family: var(--font-display) !important;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem) !important;
  font-weight: 500 !important;
  color: var(--off-white) !important;
  line-height: 1.2 !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  max-width: 100% !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}


/* ============================================================
   PROSA — paragrafos
   ============================================================ */
body.single-post div.page-content > p {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: var(--pad-x) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
  box-sizing: border-box !important;
  color: var(--gray-text) !important;
  font-family: var(--font-body) !important;
  font-size: clamp(0.95rem, 1.5vw, 1.05rem) !important;
  line-height: 1.85 !important;
  background: transparent !important;
  display: block !important;
}
body.single-post div.page-content > p strong {
  color: var(--off-white) !important;
  font-weight: 600 !important;
}


/* ============================================================
   LISTAS — bullets diamante
   ============================================================ */
html body.single-post #post-7886 div.page-content > ul,
html body.single-post #post-7886 div.page-content ul.wp-block-list,
body.single-post div.page-content > ul,
body.single-post div.page-content ul.wp-block-list {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: calc(var(--pad-x) + 1.5rem) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
  box-sizing: border-box !important;
  list-style: none !important;
  background: transparent !important;
}
html body.single-post #post-7886 div.page-content ul li,
html body.single-post #post-7886 div.page-content ul.wp-block-list > li,
body.single-post div.page-content ul li,
body.single-post div.page-content ul.wp-block-list > li {
  position: relative !important;
  padding-left: 0 !important;
  font-size: clamp(0.95rem, 1.5vw, 1.05rem) !important;
  color: var(--gray-text) !important;
  line-height: 1.8 !important;
  margin-bottom: 0.75rem !important;
  list-style: none !important;
  background: transparent !important;
}
html body.single-post #post-7886 div.page-content ul li::before,
body.single-post div.page-content ul.wp-block-list > li::before {
  content: '' !important;
  position: absolute !important;
  left: -1.5rem !important;
  top: 0.62em !important;
  width: 6px !important;
  height: 6px !important;
  background: var(--gold) !important;
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%) !important;
  display: block !important;
  border-radius: 0 !important;
}
html body.single-post #post-7886 div.page-content ul li::marker,
body.single-post div.page-content ul li::marker,
body.single-post div.page-content ul.wp-block-list li::marker {
  content: none !important;
  display: none !important;
  font-size: 0 !important;
}
body.single-post div.page-content ul li strong,
body.single-post div.page-content ul.wp-block-list li strong {
  color: var(--off-white) !important;
}


/* ============================================================
   TOC — "NESTE ARTIGO" em display Cormorant grande
   ============================================================ */
.toc-block {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: var(--pad-x) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
  box-sizing: border-box !important;
  background: transparent !important;
}
.toc-block > div {
  background: rgba(201,168,76,0.06) !important;
  border: 1px solid rgba(201,168,76,0.2) !important;
  border-left: 3px solid var(--gold) !important;
  padding: 1.75rem 2rem !important;
}
/* TOC titulo: Cormorant Garamond display grande — igual à referência */
html body.single-post .toc-block h2,
html body.single-post .entry-content .toc-block h2,
html body.single-post div.page-content .toc-block h2 {
  font-family: var(--font-display) !important;
  font-size: clamp(1.4rem, 2.5vw, 1.8rem) !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
  border: none !important;
  border-top: none !important;
  max-width: 100% !important;
  background: transparent !important;
  display: block !important;
  line-height: 1.1 !important;
}
html body.single-post .toc-block .toc-list,
body.single-post .toc-block ol.toc-list {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  list-style-type: none !important;
  counter-reset: toc !important;
}
html body.single-post .toc-block .toc-list > li,
body.single-post .toc-block .toc-list > li {
  counter-increment: toc !important;
  display: flex !important;
  align-items: baseline !important;
  gap: 0.75rem !important;
  padding: 0.35rem 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.04) !important;
  margin: 0 !important;
  background: transparent !important;
  list-style: none !important;
  list-style-type: none !important;
}
html body.single-post .toc-block .toc-list > li:last-child,
body.single-post .toc-block .toc-list > li:last-child {
  border-bottom: none !important;
}
/* Numero do TOC: decimal simples (1, 2, 3...) via counter */
html body.single-post .toc-block .toc-list > li::before,
body.single-post .toc-block .toc-list > li::before {
  content: counter(toc) !important;
  display: inline-block !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: var(--gold) !important;
  opacity: 0.7 !important;
  flex-shrink: 0 !important;
  min-width: 1rem !important;
  font-family: var(--font-body) !important;
  line-height: 1 !important;
  font-variant-numeric: tabular-nums !important;
}
html body.single-post .toc-block .toc-list > li::marker,
body.single-post .toc-block .toc-list > li::marker {
  content: none !important;
  display: none !important;
  font-size: 0 !important;
}
/* Esconde o .toc-num manual (agora usamos counter CSS) */
body.single-post .toc-num {
  display: none !important;
}
.toc-list a {
  font-size: 0.9rem !important;
  color: var(--off-white) !important;
  text-decoration: none !important;
  font-family: var(--font-body) !important;
  line-height: 1.4 !important;
}
.toc-list a:hover { color: var(--gold) !important; }


/* ============================================================
   ANSWER BOX
   ============================================================ */
.answer-box {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: var(--pad-x) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 2.5rem !important;
  margin-bottom: 2.5rem !important;
  box-sizing: border-box !important;
  background: transparent !important;
}
.answer-box > div {
  background: rgba(201,168,76,0.07) !important;
  border: 1px solid rgba(201,168,76,0.25) !important;
  padding: 1.75rem 2rem !important;
  display: block !important;
}
.answer-box-label {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin-bottom: 0.75rem !important;
}
.answer-box p,
.answer-box > div > p {
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  color: var(--off-white) !important;
  line-height: 1.7 !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
  background: transparent !important;
}


/* ============================================================
   PULL STAT — numero em Plus Jakarta Sans 2.5rem (nao Cormorant)
   ============================================================ */
.pull-stat {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: var(--pad-x) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 2.5rem !important;
  margin-bottom: 2.5rem !important;
  box-sizing: border-box !important;
  background: transparent !important;
}
.pull-stat > div {
  background: var(--navy-mid) !important;
  border: 1px solid var(--gray-border) !important;
  border-left: 3px solid var(--gold) !important;
  padding: 1.75rem 2rem !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 1.5rem !important;
}
.pull-stat-number {
  font-family: var(--font-body) !important;
  font-size: 2.5rem !important;
  font-weight: 600 !important;
  color: var(--gold) !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  min-width: 4rem !important;
}
.pull-stat-text {
  font-size: 0.95rem !important;
  color: var(--gray-text) !important;
  line-height: 1.6 !important;
  font-family: var(--font-body) !important;
}
.pull-stat-text strong { color: var(--off-white) !important; }


/* ============================================================
   STEPS GRID
   ============================================================ */
.steps-grid {
  max-width: var(--max-prose) !important;
  width: 100% !important;
  padding-left: var(--pad-x) !important;
  padding-right: var(--pad-x) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 2.5rem !important;
  margin-bottom: 2.5rem !important;
  box-sizing: border-box !important;
  background: transparent !important;
  display: block !important;
}
.step-item {
  display: grid !important;
  grid-template-columns: 3rem 1fr !important;
  gap: 1.25rem !important;
  align-items: start !important;
  padding: 1.5rem 0 !important;
  border-bottom: 1px solid var(--gray-border) !important;
  background: transparent !important;
}
.step-item:last-child { border-bottom: none !important; }
.step-num {
  font-family: var(--font-body) !important;
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
  opacity: 0.5 !important;
  line-height: 1 !important;
  padding-top: 0.1rem !important;
}
.step-content h4 {
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--off-white) !important;
  margin: 0 0 0.4rem 0 !important;
  padding: 0 !important;
}
.step-content p {
  font-size: 0.9rem !important;
  color: var(--gray-text) !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.65 !important;
  max-width: 100% !important;
  background: transparent !important;
}


/* ============================================================
   FAQ + CTA
   ============================================================ */
.faq-section {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  background: var(--warm-100) !important;
  padding: clamp(3rem, 6vw, 5rem) var(--pad-x) !important;
  margin-top: 4rem !important;
  display: block !important;
}
.faq-inner { max-width: var(--max-prose) !important; margin: 0 auto !important; }
.faq-eyebrow {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 0 0.75rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
.faq-item {
  border-top: 1px solid rgba(8,17,30,0.12) !important;
  background: transparent !important;
}
.faq-item:last-child { border-bottom: 1px solid rgba(8,17,30,0.12) !important; }
.faq-item summary {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 1rem !important;
  padding: 1.25rem 0 !important;
  cursor: pointer !important;
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
  list-style: none !important;
  background: transparent !important;
}
.faq-item summary::-webkit-details-marker { display: none !important; }
.faq-icon {
  flex-shrink: 0 !important;
  width: 22px !important;
  height: 22px !important;
  border: 1px solid rgba(8,17,30,0.2) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1rem !important;
  color: var(--gold) !important;
  transition: transform 0.25s !important;
  line-height: 1 !important;
}
details[open] .faq-icon { transform: rotate(45deg) !important; }
.faq-answer {
  padding: 0 0 1.5rem !important;
  font-family: var(--font-body) !important;
  font-size: 0.9rem !important;
  color: #4A4035 !important;
  line-height: 1.75 !important;
  background: transparent !important;
  margin: 0 !important;
}
.cta-strip {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  background: var(--navy-mid) !important;
  border-top: 1px solid var(--gray-border) !important;
  padding: clamp(3rem, 6vw, 5rem) var(--pad-x) !important;
  text-align: center !important;
  display: block !important;
  margin: 0 !important;
}
.cta-strip-inner { max-width: 600px !important; margin: 0 auto !important; }
.cta-eyebrow {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
.cta-text {
  font-family: var(--font-body) !important;
  font-size: 0.95rem !important;
  color: var(--gray-text) !important;
  margin: 0 0 2rem 0 !important;
  padding: 0 !important;
  background: transparent !important;
}
.cta-buttons {
  display: flex !important;
  gap: 0.75rem !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}
.btn-gold {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-family: var(--font-body) !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  padding: 1rem 2rem !important;
  border: none !important;
}
.btn-gold:hover { background: var(--gold-light) !important; color: var(--navy) !important; }
.btn-ghost {
  display: inline-flex !important;
  align-items: center !important;
  background: transparent !important;
  color: var(--gold) !important;
  font-family: var(--font-body) !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  padding: 1rem 2rem !important;
  border: 1px solid rgba(201,168,76,0.4) !important;
}
.btn-ghost:hover { border-color: var(--gold) !important; color: var(--gold-light) !important; }


/* ============================================================
   FOOTER + WHATSAPP FLUTUANTE
   ============================================================ */
.pupilay-footer {
  background: var(--navy) !important;
  border-top: 1px solid var(--gray-border) !important;
  padding: 2.5rem var(--pad-x) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.pupilay-footer-inner {
  max-width: var(--max-wide) !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
}
.pupilay-footer-copy {
  font-size: 0.78rem !important;
  color: var(--gray-text) !important;
  font-family: var(--font-body) !important;
}
.pupilay-footer-copy a { color: var(--gold) !important; text-decoration: none !important; }
.pupilay-footer-links {
  display: flex !important;
  gap: 1.5rem !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.pupilay-footer-links a {
  font-size: 0.78rem !important;
  color: var(--gray-text) !important;
  text-decoration: none !important;
  font-family: var(--font-body) !important;
}
.pupilay-footer-links a:hover { color: var(--gold) !important; }
.pupilay-float-wa {
  position: fixed !important;
  bottom: 1.5rem !important;
  right: 1.5rem !important;
  z-index: 999 !important;
  width: 52px !important;
  height: 52px !important;
  background: #25D366 !important;
  border-radius: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4) !important;
  text-decoration: none !important;
  transition: transform 0.2s !important;
}
.pupilay-float-wa:hover { transform: scale(1.08) !important; }
.pupilay-float-wa svg { width: 28px !important; height: 28px !important; fill: white !important; }


/* ============================================================
   FIX ESPACAMENTO — transicoes entre blocos nativos e customizados
   ============================================================ */
/* Espaco generoso antes do FAQ */
body.single-post .faq-section {
  margin-top: 5rem !important;
}
.faq-item summary:hover { color: var(--gold) !important; }
.faq-item[open] summary { color: var(--gold) !important; }


/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 600px) {
  .pull-stat > div { flex-direction: column !important; gap: 0.75rem !important; }
  .cta-buttons { flex-direction: column !important; }
  .btn-gold, .btn-ghost { width: 100% !important; justify-content: center !important; }
  .step-item { grid-template-columns: 2.5rem 1fr !important; }
  .pupilay-footer-inner { flex-direction: column !important; align-items: flex-start !important; }
}


/* ============================================================
   PUPILAY BLOG INDEX — v1.0
   Adicionar ABAIXO do CSS atual (v7.2), sem remover nada.
   Escopo: body.blog e body.archive
   ============================================================ */


/* ============================================================
   FIX CRÍTICO — largura 500px (mesmo problema do post)
   ============================================================ */
/* Nível 1: fundo e reset base */
body.blog,
body.blog #page,
body.blog .site-content,
body.blog .site-main,
body.blog main,
body.blog article,
body.archive,
body.archive #page,
body.archive .site-content,
body.archive .site-main,
body.archive main,
body.archive article {
  background: var(--navy) !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
/* Nível 2: ocultar header e footer nativos do tema */
body.blog .site-header,
body.blog header.site-header,
body.blog #site-header,
body.blog .site-footer,
body.blog footer.site-footer,
body.blog #site-footer,
body.archive .site-header,
body.archive header.site-header,
body.archive #site-header,
body.archive .site-footer,
body.archive footer.site-footer,
body.archive #site-footer {
  display: none !important;
}
/* Nível 3: ocultar page-header nativo ("Arquivos") */
body.blog .page-header,
body.blog .page-title,
body.archive .page-header,
body.archive .page-title {
  display: none !important;
}
/* Nível 4: quebrar constraint do WordPress Global Styles */
body.blog .is-layout-constrained > *,
body.blog .is-layout-constrained,
body.archive .is-layout-constrained > *,
body.archive .is-layout-constrained {
  max-width: 100% !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}
/* Padding lateral zero nos containers */
body.blog .site-content,
body.blog .site-main,
body.blog main#content,
body.archive .site-content,
body.archive .site-main,
body.archive main#content {
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}


/* ============================================================
   BLOCO HTML CUSTOMIZADO — wrapper geral
   O wp-block-html do Gutenberg que envolve nav, hero, cards, footer
   ============================================================ */
body.blog .wp-block-html,
body.archive .wp-block-html {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  display: block !important;
}
body.blog .wp-block-html > *,
body.archive .wp-block-html > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}


/* ============================================================
   NAV — reusar classes do post (.pupilay-nav já existe)
   Adicionar apenas o ajuste para o blog (sem link "voltar")
   ============================================================ */
body.blog .pupilay-nav,
body.archive .pupilay-nav {
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
}


/* ============================================================
   HERO DO BLOG INDEX
   ============================================================ */
.blog-hero {
  width: 100% !important;
  background: var(--navy-mid) !important;
  box-sizing: border-box !important;
  padding: clamp(3rem, 6vw, 5rem) var(--pad-x) !important;
  border-bottom: 1px solid var(--gray-border) !important;
}
.blog-hero-inner {
  max-width: var(--max-wide) !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}
.blog-hero-eyebrow {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
}
.blog-hero-h1 {
  font-family: var(--font-display) !important;
  font-size: clamp(2rem, 5vw, 3.2rem) !important;
  font-weight: 500 !important;
  line-height: 1.15 !important;
  color: var(--off-white) !important;
  margin: 0 0 1.25rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  max-width: 700px !important;
}
.blog-hero-lead {
  font-family: var(--font-body) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  color: var(--gray-text) !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: 560px !important;
}


/* ============================================================
   GRID DE CARDS DOS POSTS
   ============================================================ */
.blog-posts-section {
  width: 100% !important;
  background: var(--navy) !important;
  box-sizing: border-box !important;
  padding: clamp(3rem, 6vw, 5rem) var(--pad-x) !important;
}
.blog-posts-inner {
  max-width: var(--max-wide) !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}
/* Ocultar os article.post nativos do WordPress — vamos renderizar os cards via HTML customizado */
body.blog article.post,
body.archive article.post {
  display: none !important;
}
/* Cards customizados */
.blog-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 2px !important;
}
.blog-card {
  background: var(--navy-mid) !important;
  border: 1px solid var(--gray-border) !important;
  padding: clamp(1.5rem, 3vw, 2.5rem) !important;
  box-sizing: border-box !important;
  text-decoration: none !important;
  display: block !important;
  transition: border-color 0.2s, background 0.2s !important;
  position: relative !important;
}
.blog-card:hover {
  border-color: rgba(201,168,76,0.4) !important;
  background: #0f2035 !important;
}
.blog-card-category {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
}
.blog-card-title {
  display: block !important;
  font-family: var(--font-display) !important;
  font-size: clamp(1.4rem, 2.5vw, 1.9rem) !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  color: var(--off-white) !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}
.blog-card:hover .blog-card-title {
  color: var(--gold-light) !important;
}
.blog-card-excerpt {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.88rem !important;
  line-height: 1.7 !important;
  color: var(--gray-text) !important;
  margin: 0 0 1.5rem 0 !important;
  padding: 0 !important;
}
.blog-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 1rem !important;
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  color: var(--gray-text) !important;
  border-top: 1px solid var(--gray-border) !important;
  padding-top: 1rem !important;
  margin-top: auto !important;
}
.blog-card-meta-dot {
  width: 3px !important;
  height: 3px !important;
  background: var(--gray-border) !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}
.blog-card-arrow {
  position: absolute !important;
  bottom: clamp(1.5rem, 3vw, 2.5rem) !important;
  right: clamp(1.5rem, 3vw, 2.5rem) !important;
  font-size: 1rem !important;
  color: var(--gold) !important;
  opacity: 0 !important;
  transition: opacity 0.2s, transform 0.2s !important;
}
.blog-card:hover .blog-card-arrow {
  opacity: 1 !important;
  transform: translateX(4px) !important;
}


/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 680px) {
  .blog-grid {
    grid-template-columns: 1fr !important;
  }
  .blog-card {
    border-left: none !important;
    border-right: none !important;
    border-bottom: none !important;
    border-top: 1px solid var(--gray-border) !important;
    padding: 2rem 0 !important;
    background: transparent !important;
  }
  .blog-card:hover {
    background: transparent !important;
  }
}


/* ============================================================
   BLOG INDEX — refinamentos v1.1
   Adicionar após o bloco do blog index no CSS Adicional
   ============================================================ */
/* Card único: largura total até ter 2 posts */
body.blog .blog-grid,
body.archive .blog-grid {
  grid-template-columns: 1fr !important;
  max-width: 680px !important;
}
/* Quando tiver 2+ cards: voltar para 2 colunas */
body.blog .blog-grid:has(.blog-card:nth-child(2)),
body.archive .blog-grid:has(.blog-card:nth-child(2)) {
  grid-template-columns: repeat(2, 1fr) !important;
  max-width: 100% !important;
}
/* Meta separadores — corrigir cor dos dots */
body.blog .blog-card-meta-dot,
body.archive .blog-card-meta-dot {
  background: var(--gray-text) !important;
  opacity: 0.4 !important;
  display: inline-block !important;
  width: 3px !important;
  height: 3px !important;
  border-radius: 50% !important;
  vertical-align: middle !important;
  flex-shrink: 0 !important;
}
/* Hero — ampliar container para H1 não quebrar tanto */
body.blog .blog-hero-h1,
body.archive .blog-hero-h1 {
  max-width: 860px !important;
}
/* Blog hero — padding-top para compensar nav fixa */
body.blog .blog-hero,
body.archive .blog-hero {
  padding-top: clamp(6rem, 10vw, 8rem) !important;
}


/* ============================================================
   HERO DO ARTIGO — layout 2 colunas (texto | imagem)
   ============================================================ */
.article-hero-inner {
  max-width: var(--max-wide) !important;
  display: grid !important;
  grid-template-columns: 1fr 420px !important;
  gap: clamp(2rem, 4vw, 4rem) !important;
  align-items: center !important;
}
/* Coluna esquerda: todo o conteúdo textual já existente */
.article-hero-text {
  display: flex !important;
  flex-direction: column !important;
}
/* Coluna direita: imagem de destaque */
.article-hero-image {
  width: 100% !important;
  aspect-ratio: 4/3 !important;
  overflow: hidden !important;
}
.article-hero-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}
/* Responsivo — empilha em mobile */
@media (max-width: 768px) {
  .article-hero-inner {
    grid-template-columns: 1fr !important;
  }
  .article-hero-image {
    aspect-ratio: 16/9 !important;
  }
}
/* Breadcrumb — links (Início / Blog) */
body.single-post .article-breadcrumb a {
  color: var(--gold-light) !important;
}
/* Breadcrumb — item atual (Google Maps em BH) e separadores */
body.single-post .article-breadcrumb span {
  color: var(--gray-text) !important;
}
.article-hero-image img {
  object-position: right center !important;
}