/* =========================================================================
   Marcos Leite Advocacia - estilo do blog (child theme Hello Elementor)
   Paleta GRAFITE monocromatica + Geist. Extraida de site/index.html (NUNCA chutada).
   Titulo preto (#1a1a1a), badge grafite com texto branco. Mobile-responsivo/centralizado (G-06).
   Gerado pelo blog-theme-builder (etapa 7.7) - Posicione-see.
   ========================================================================= */

:root{
  --bg:#FFFFFF;
  --surface:#FFFFFF;
  --ink:#1E2226;
  --ink-on-dark:#FFFFFF;
  --muted:#6E7479;
  --muted-soft:#B9BEC2;
  --dark:#1E2226;
  --dark-2:#2B2F34;
  --accent:#2B2F34;            /* grafite - primaria/accent (monocromatica, sem cor cromatica) */
  --accent-soft:#EDEEEF;
  --border:rgba(30,34,38,0.12);
  --border-dark:rgba(255,255,255,0.12);
  --radius-lg:14px;
  --radius-md:10px;
  --radius-sm:6px;
  --container:1240px;
  --pad-x:20px;
  --title-black:#1a1a1a;       /* titulos: preto, NUNCA accent (regra dura) */
  --font:"Geist","Geist Placeholder",-apple-system,BlinkMacSystemFont,sans-serif;
}

/* Hello Elementor reset overrides leves */
.post-main, .archive-main{ background:var(--bg); color:var(--ink); font-family:var(--font); }
.post-main *, .archive-main *{ box-sizing:border-box; }
.container{ max-width:var(--container); margin:0 auto; padding:0 var(--pad-x); width:100%; }

/* ---------- Tipografia herdada do site (Geist peso 400, letter-spacing -.04em) ---------- */
.post-main h1,.post-main h2,.post-main h3,.post-main h4,
.archive-main h1,.archive-main h2,.archive-main h3{
  font-family:var(--font); font-weight:400; letter-spacing:-.04em; line-height:1.1;
  color:var(--title-black); text-wrap:balance; overflow-wrap:break-word;
}

/* ---------- Header SOLIDO ESCURO (igual ao topo da home: fundo grafite, texto branco) ---------- */
.site-header{ position:relative; top:0; left:0; right:0; z-index:50;
  width:100vw !important; max-width:100vw !important; margin-left:calc(50% - 50vw) !important; box-sizing:border-box !important; }
.site-header--solid{ background:#1E2226; border-bottom:1px solid rgba(255,255,255,.08); }
.header-inner{ max-width:var(--container); margin:0 auto; padding:18px var(--pad-x);
  display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:8px; }
.brand-logo{ height:30px; width:auto; flex:0 0 auto; }
.site-header--solid .brand .brand-text{ color:#fff; font-size:19px; font-weight:600; letter-spacing:-.02em; }
.nav{ display:flex; align-items:center; gap:30px; }
.site-header--solid .nav a{ color:#fff; font-size:15px; opacity:.92; transition:opacity .2s; }
.site-header--solid .nav a:hover{ opacity:1; }
.nav .has-caret{ display:inline-flex; align-items:center; gap:6px; }
/* Dropdown Areas de atuacao (igual home) */
.nav-item{ position:relative; display:inline-flex; align-items:center; }
.nav-item.has-dropdown::after{ content:""; position:absolute; top:100%; left:0; right:0; height:16px; }
.nav-item.has-dropdown .dropdown-menu{ position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(6px); min-width:284px; background:#fff; border-radius:14px; box-shadow:0 20px 48px rgba(20,23,26,.20); padding:10px; display:flex; flex-direction:column; gap:2px; opacity:0; visibility:hidden; transition:opacity .22s ease, transform .22s ease, visibility .22s ease; z-index:1000; }
.nav-item.has-dropdown:hover .dropdown-menu, .nav-item.has-dropdown:focus-within .dropdown-menu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav-item.has-dropdown:hover .has-caret svg{ transform:rotate(180deg); }
.nav .has-caret svg{ transition:transform .22s ease; }
.nav-item.has-dropdown .dropdown-menu a{ color:#2B2F34; opacity:1; font-size:14.5px; font-weight:500; padding:11px 14px; border-radius:9px; white-space:nowrap; transition:background .15s ease; }
.nav-item.has-dropdown .dropdown-menu a:hover{ background:#f4f3f0; opacity:1; }
.header-cta{ display:flex; align-items:center; gap:14px; }
.btn{ display:inline-flex; align-items:center; gap:10px; font-size:15px; font-weight:500; letter-spacing:-.01em;
  padding:12px 20px; border-radius:var(--radius-sm); transition:transform .25s ease, background .25s ease; }
.btn-dark{ background:var(--accent); color:#fff; }
.btn-dark:hover{ transform:translateY(-2px); background:#3A3F45; }
.btn-white{ background:#fff; color:var(--ink); }
.btn-white:hover{ transform:translateY(-2px); background:#f1f1f1; }
.hamburger{ display:none; width:44px; height:44px; border:1px solid var(--border); border-radius:var(--radius-sm);
  background:#fff; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.hamburger span{ display:block; width:20px; height:1.5px; background:var(--ink); transition:.3s; }
.site-header--solid .hamburger{ border-color:var(--border-dark); background:rgba(255,255,255,.06); }
.site-header--solid .hamburger span{ background:#fff; }

/* ---------- Mobile menu canonico (overlay sobre o body, z-index alto) ---------- */
body.menu-open{ overflow:hidden; }
.mobile-menu{ position:fixed; inset:0; z-index:99999; background:var(--surface);
  display:flex; flex-direction:column; padding:80px 28px 40px;
  transform:translateY(-100%); transition:transform .45s cubic-bezier(.22,1,.36,1); visibility:hidden; }
.mobile-menu.open{ transform:translateY(0); visibility:visible; }
.mobile-menu .mm-close{ position:absolute; top:22px; right:24px; width:44px; height:44px;
  border:1px solid var(--border); border-radius:50%; background:var(--surface); color:var(--accent);
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s,transform .2s; }
.mobile-menu .mm-close:hover{ background:var(--accent-soft); transform:rotate(90deg); }
.mobile-menu .mm-close svg{ width:20px; height:20px; }
.mobile-menu a{ color:var(--accent); font-size:24px; font-weight:600; padding:16px 0;
  border-bottom:1px solid var(--border); letter-spacing:-.02em; transition:color .2s,padding-left .2s; }
.mobile-menu a:hover{ color:var(--ink); padding-left:6px; }
.mobile-menu .mm-cta{ margin-top:28px; }
.mobile-menu .mm-cta .btn{ width:100%; justify-content:center; }
.mobile-menu .mm-meta{ margin-top:auto; color:var(--muted); font-size:14px; line-height:1.6; }

/* ---------- Badge categoria (grafite + texto branco) ---------- */
.post-badge{ display:inline-block; background:var(--accent); color:#fff; font-size:12px; font-weight:600;
  letter-spacing:.05em; text-transform:uppercase; padding:7px 14px; border-radius:999px; }
.post-badge.sm{ font-size:11px; padding:5px 11px; }

/* ============================= SINGLE POST ============================= */
.post-article{ padding:48px 0 0; }
.post-head{ max-width:820px; padding-top:24px; }
.post-crumb{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; color:var(--muted);
  font-size:13px; margin-bottom:22px; }
.post-crumb a{ color:var(--muted); text-decoration:none; transition:color .2s; }
.post-crumb a:hover{ color:var(--ink); }
.post-title{ font-size:46px; letter-spacing:-.05em; margin:18px 0 22px; color:var(--title-black); }
.post-meta{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; color:var(--muted); font-size:15px; }
.post-meta .dot{ opacity:.6; }

.post-hero{ max-width:980px; margin:36px auto 0; }
.post-hero-img{ width:100%; height:auto; border-radius:var(--radius-lg); display:block; }
.post-hero-fallback{ aspect-ratio:16/8; border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#2B2F34 0%,#1E2226 55%,#3A3F45 100%);
  display:flex; align-items:center; justify-content:center; }
.post-hero-fallback svg{ width:72px; height:72px; }

/* Corpo do post - tipografia premium */
.post-body{ max-width:760px; margin:48px auto 0; }
.post-body p{ color:#33373B; font-size:18px; line-height:1.75; margin:0 0 22px; }
.post-body h2{ font-size:30px; letter-spacing:-.03em; margin:46px 0 16px; color:var(--title-black); }
.post-body h3{ font-size:22px; letter-spacing:-.02em; margin:32px 0 12px; color:var(--title-black); }
.post-body ul,.post-body ol{ margin:0 0 24px; padding-left:24px; }
.post-body li{ color:#33373B; font-size:17px; line-height:1.7; margin-bottom:10px; }
.post-body a{ color:var(--ink); text-decoration:underline; text-decoration-color:var(--accent);
  text-underline-offset:3px; text-decoration-thickness:2px; }
.post-body strong{ color:var(--ink); font-weight:600; }
.post-body blockquote{ margin:32px 0; padding:22px 26px; border-left:4px solid var(--accent);
  background:var(--accent-soft); border-radius:0 var(--radius-md) var(--radius-md) 0; }
.post-body blockquote p{ color:var(--ink); font-size:18px; line-height:1.7; font-style:normal; margin:0; }

/* Rodape do post */
.post-foot{ max-width:760px; margin:56px auto 0; padding-bottom:8px; }
.post-cta{ background:var(--dark); border-radius:var(--radius-lg); padding:40px 38px; text-align:center; }
.post-cta h3{ color:#fff; font-size:26px; letter-spacing:-.03em; margin-bottom:14px; }
.post-cta p{ color:rgba(255,255,255,.72); font-size:16px; line-height:1.65; max-width:520px; margin:0 auto 26px; }
.post-cta .btn-dark{ background:#fff; color:var(--ink); }
.post-cta .btn-dark:hover{ background:#f1f1f1; }
.post-cta-meta{ display:block; margin-top:20px; color:rgba(255,255,255,.55); font-size:13px; }
.post-back{ display:inline-block; margin-top:34px; color:var(--accent); font-size:15px; font-weight:600;
  text-decoration:none; transition:opacity .2s; }
.post-back:hover{ opacity:.7; }

/* ============================= ARCHIVE / BLOG ============================= */
.archive-main{ padding:48px 0 0; }
.archive-head{ max-width:760px; padding-top:36px; text-align:center; margin-bottom:10px; }
.archive-title{ font-size:48px; letter-spacing:-.05em; margin:18px 0 16px; color:var(--title-black); }
.archive-lead{ color:var(--muted); font-size:17px; line-height:1.6; max-width:600px; margin:0 auto; }
.archive-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:30px; margin-top:54px; }
.blog-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; display:flex; flex-direction:column; transition:transform .25s ease, box-shadow .25s ease; }
.blog-card:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(30,34,38,.10); }
.blog-card-media{ display:block; aspect-ratio:16/10; overflow:hidden; }
.blog-card-img{ width:100%; height:100%; object-fit:cover; display:block; }
.blog-card-fallback{ width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,#2B2F34 0%,#1E2226 55%,#3A3F45 100%); }
.blog-card-fallback svg{ width:60px; height:60px; }
.blog-card-body{ padding:26px 24px 28px; display:flex; flex-direction:column; gap:14px; flex:1; }
.blog-card-title{ font-size:21px; letter-spacing:-.02em; line-height:1.2; color:var(--title-black); }
.blog-card-title a{ color:inherit; text-decoration:none; }
.blog-card-title a:hover{ text-decoration:underline; text-decoration-color:var(--accent); text-underline-offset:3px; }
.blog-card-excerpt{ color:var(--muted); font-size:15px; line-height:1.6; flex:1; }
.blog-card-meta{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  color:var(--muted); font-size:13px; margin-top:auto; }
.blog-card-link{ color:var(--accent); font-weight:600; text-decoration:none; white-space:nowrap; }
.archive-empty{ grid-column:1/-1; text-align:center; color:var(--muted); font-size:17px; padding:40px 0; }
.archive-pag{ margin:48px auto 0; display:flex; justify-content:center; gap:8px; flex-wrap:wrap; }
.archive-pag a,.archive-pag span{ display:inline-flex; align-items:center; justify-content:center; min-width:42px; height:42px;
  padding:0 12px; border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--ink); font-size:14px; text-decoration:none; }
.archive-pag .current{ background:var(--accent); color:#fff; border-color:var(--accent); }

/* ============================= FOOTER (identidade) ============================= */
.endcap{ position:relative; background:var(--dark); overflow:hidden; margin-top:80px; }
.endcap-inner{ position:relative; z-index:2; max-width:var(--container); margin:0 auto; padding:0 var(--pad-x); }
.footer{ padding:64px 0 0; }
.footer-card{ background:#fff; border-radius:var(--radius-lg); padding:44px 46px;
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.footer-card .col h4{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); font-weight:600; margin-bottom:20px; }
.footer-card .col address{ font-style:normal; color:var(--muted); font-size:15px; line-height:1.7; margin-bottom:20px; }
.footer-card .col a{ display:block; color:var(--muted); font-size:15px; padding:6px 0; text-decoration:none; transition:color .2s; }
.footer-card .col a:hover{ color:var(--ink); }
.footer-card .col .col-note{ color:var(--muted); font-size:14px; line-height:1.65; margin-top:8px; margin-bottom:18px; }
.footer-social{ display:flex; gap:14px; margin-top:8px; }
.footer-social a{ width:20px; height:20px; color:var(--ink); }
.footer-social svg{ width:100%; height:100%; fill:currentColor; }
.footer-bar{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  padding:30px var(--pad-x); max-width:var(--container); margin:0 auto; color:rgba(255,255,255,.6); font-size:14px; }
.footer-bar .fb-brand{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.footer-bar .fb-brand .fb-name{ color:#fff; font-size:16px; font-weight:600; letter-spacing:-.02em; }
.footer-credit a{ color:#fff; text-decoration:underline; }

/* ---------- WhatsApp flutuante ---------- */
.whatsapp-float{ position:fixed; bottom:24px; right:24px; width:60px; height:60px; background:#25D366; color:#fff;
  border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(0,0,0,0.18),0 2px 8px rgba(37,211,102,0.32); z-index:999; transition:transform .25s ease; }
.whatsapp-float:hover{ transform:scale(1.06); }
.whatsapp-float svg{ width:32px; height:32px; fill:currentColor; }

/* ============================= RESPONSIVO (G-06: centralizado, sem overflow-X) ============================= */
@media (max-width:1024px){
  .nav, .header-cta .btn{ display:none; }
  .hamburger{ display:flex; }
  .footer-card{ grid-template-columns:1fr; gap:32px; text-align:center; }
  .footer-social{ justify-content:center; }
}
@media (max-width:640px){
  .post-article{ padding-top:28px; }
  .post-head{ text-align:center; }
  .post-crumb{ justify-content:center; }
  .post-meta{ justify-content:center; }
  .post-title{ font-size:32px; }
  .post-body{ margin-top:36px; }
  .post-body p{ font-size:17px; }
  .post-body h2{ font-size:25px; }
  .post-cta{ padding:32px 22px; }
  .post-cta h3{ font-size:22px; }
  .archive-title{ font-size:34px; }
  .archive-grid{ grid-template-columns:1fr; gap:24px; margin-top:40px; }
  .whatsapp-float{ width:54px; height:54px; bottom:18px; right:18px; }
  .whatsapp-float svg{ width:28px; height:28px; }
  .footer{ padding-top:48px; }
  .footer-card{ padding:32px 24px; }
}
