/* ============================================================
   Modern — Blog · folha de estilo compartilhada
   Herda os MESMOS tokens da home (design system unico) e adiciona
   os componentes do blog. Nenhum 2o design system.
   ============================================================ */

:root{
  --caramelo:#946738; --caramelo-esc:#7C5530;
  --nude:#CB9E78; --nude-claro:#DCC0A6; --nude-prof:#B9895F;
  --nude-texto:#8C5D35; /* tom escuro só para texto pequeno sobre creme (AA 4.5:1) */
  --creme:#FAF7F4; --creme-tex:#F3EEE8; --creme-card:#FFFDFB;
  --texto:#473625; --texto-suave:#6E5A45;
  --linha:#E7DDD0; --linha-fina:#EFE7DC;
  --el-1:0 1px 2px rgba(124,85,48,.05);
  --el-2:0 2px 8px -2px rgba(124,85,48,.10),0 1px 2px rgba(124,85,48,.05);
  --el-3:0 8px 28px -10px rgba(124,85,48,.22),0 2px 6px -2px rgba(124,85,48,.08);
  --el-4:0 18px 48px -16px rgba(124,85,48,.30),0 4px 12px -4px rgba(124,85,48,.10);
  --el-float:0 30px 70px -28px rgba(80,52,25,.50),0 8px 20px -10px rgba(80,52,25,.20);
  --grad-rose:linear-gradient(135deg,var(--nude-claro) 0%,var(--nude) 48%,var(--nude-prof) 100%);
  --serif:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --tr-display:-.018em; --tr-eyebrow:.32em;
  --raio:18px; --raio-lg:26px; --maxw:1120px;
  --gut:clamp(20px,4.6vw,24px);
  --rhythm:clamp(64px,9vw,104px);
  --read:684px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-color:var(--nude-claro) transparent;scrollbar-width:thin;scroll-padding-top:76px}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--nude-claro);border-radius:100px;border:3px solid var(--creme);background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--nude)}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
body{font-family:var(--sans);background:var(--creme);color:var(--texto);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E")}
body::after{content:"";position:fixed;top:0;left:0;right:0;height:50vh;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 80% at 72% -10%,rgba(220,192,166,.28),transparent 60%)}

::selection{background:var(--nude-claro);color:var(--caramelo-esc)}
::-moz-selection{background:var(--nude-claro);color:var(--caramelo-esc)}
:focus-visible{outline:2px solid var(--caramelo);outline-offset:3px;border-radius:6px}
a:focus-visible,summary:focus-visible{outline-offset:4px}
:focus:not(:focus-visible){outline:none}
img{max-width:100%;height:auto;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* ---------- Tipografia base (igual a home) ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:300;color:var(--caramelo-esc);text-wrap:balance}
h1{font-size:clamp(2.1rem,5.6vw,3.5rem);line-height:1.07;letter-spacing:var(--tr-display)}
h2{font-size:clamp(1.62rem,3.4vw,2.2rem);line-height:1.16;letter-spacing:var(--tr-display)}
h3{font-size:1.24rem;line-height:1.3;letter-spacing:-.012em;font-weight:400}
p{color:var(--texto);text-wrap:pretty}
.lead{font-size:clamp(1.07rem,1.7vw,1.24rem);color:var(--texto-suave);line-height:1.62;text-wrap:pretty}
em{font-style:italic;color:var(--caramelo)}
strong{font-weight:600;color:var(--caramelo-esc)}
a{color:var(--caramelo);text-decoration-color:var(--nude-claro);text-underline-offset:3px}

/* fio de marca */
.rule{display:flex;align-items:center;justify-content:center;gap:18px;color:var(--nude);opacity:.9;margin:38px 0}
.rule::before,.rule::after{content:"";height:1px;width:min(120px,16vw);background:linear-gradient(90deg,transparent,var(--nude-claro))}
.rule::after{background:linear-gradient(90deg,var(--nude-claro),transparent)}
.rule i{width:7px;height:7px;background:var(--grad-rose);transform:rotate(45deg);border-radius:1px;flex:none}

/* grifo-marcador assinatura */
.mark{position:relative;white-space:nowrap;color:var(--caramelo-esc);z-index:0}
.mark::after{content:"";position:absolute;left:-.12em;right:-.12em;top:.1em;bottom:.02em;z-index:-1;
  background:var(--nude-claro);opacity:.72;border-radius:3px;transform:rotate(-.6deg)}

/* eyebrow */
.eyebrow{font-family:var(--sans);font-weight:500;font-size:.745rem;letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--caramelo-esc);display:inline-flex;align-items:center;gap:13px}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--nude));flex:none}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:24px;height:1px;background:linear-gradient(90deg,var(--nude),transparent);flex:none}

/* ---------- Botoes (igual a home) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-family:var(--sans);font-weight:500;font-size:1.02rem;letter-spacing:.012em;color:#fff;text-decoration:none;cursor:pointer;border:none;padding:18px 34px;border-radius:100px;position:relative;isolation:isolate;background:linear-gradient(135deg,var(--caramelo) 0%,var(--caramelo-esc) 100%);box-shadow:0 14px 30px -12px rgba(124,85,48,.5),inset 0 1px 0 rgba(255,255,255,.18);transition:transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s cubic-bezier(.16,1,.3,1);overflow:hidden;text-shadow:0 1px 1px rgba(60,40,20,.4)}
.btn span{position:relative;z-index:1}
.btn::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,var(--caramelo-esc),#5e3f24);opacity:0;transition:opacity .45s}
.btn::before{content:"";position:absolute;top:0;bottom:0;left:-60%;width:45%;z-index:0;background:linear-gradient(100deg,transparent,rgba(255,255,255,.25),transparent);transform:skewX(-18deg);transition:left .65s cubic-bezier(.16,1,.3,1)}
.btn:hover{transform:translateY(-3px);box-shadow:0 24px 46px -14px rgba(124,85,48,.58),inset 0 1px 0 rgba(255,255,255,.24)}
.btn:hover::after{opacity:1}
.btn:hover::before{left:120%}
.btn:active{transform:translateY(-1px) scale(.992);transition-duration:.12s}
.btn .arrow{transition:transform .45s cubic-bezier(.16,1,.3,1);display:inline-block}
.btn:hover .arrow{transform:translateX(5px)}
.btn--ghost{background:transparent;color:var(--caramelo-esc);box-shadow:none;border:1px solid var(--linha);padding:13px 24px;font-size:.92rem;text-shadow:none}
.btn--ghost::before{display:none}
.btn--ghost::after{background:var(--creme-tex)}
.btn--ghost:hover{transform:none;border-color:var(--nude);color:var(--caramelo-esc)}
.btn--ghost:hover::after{opacity:1}

/* ---------- Topbar (igual a home) ---------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(250,247,244,.72);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color .5s,box-shadow .5s,background .5s}
.topbar.scrolled{background:rgba(250,247,244,.86);border-color:var(--linha-fina);box-shadow:0 8px 28px -18px rgba(124,85,48,.45)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;border-radius:8px;padding:5px 2px;margin:-5px -2px}
.nav{display:flex;align-items:center;gap:28px}
.nav .navlink{color:var(--texto-suave);text-decoration:none;font-size:.93rem;font-weight:500;transition:color .3s}
.nav .navlink:hover{color:var(--caramelo-esc)}
.nav .navlink[aria-current="page"]{color:var(--caramelo-esc)}
.topbar .btn{padding:12px 24px;font-size:.9rem}
.logo-img{height:27px;width:auto;display:block;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.brand:hover .logo-img{transform:scale(1.04)}
.navtoggle{display:none;width:42px;height:42px;flex:none;border:none;background:none;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:9px;-webkit-tap-highlight-color:transparent}
.navtoggle span{display:block;width:22px;height:2px;background:var(--caramelo-esc);border-radius:2px;transition:transform .35s cubic-bezier(.16,1,.3,1),opacity .3s}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.navtoggle[aria-expanded="true"] span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}
@media(max-width:760px){
  .topbar .wrap{position:relative}
  .navtoggle{display:flex}
  .nav{position:absolute;top:calc(100% + 1px);left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--creme-card);border-bottom:1px solid var(--linha);box-shadow:var(--el-3);padding:0 var(--gut);max-height:0;overflow:hidden;opacity:0;visibility:hidden;transition:max-height .35s cubic-bezier(.16,1,.3,1),opacity .3s,visibility .3s,padding .35s}
  .nav.open{max-height:82vh;opacity:1;visibility:visible;padding:8px var(--gut) 16px;overflow:auto}
  .nav .navlink{display:block;padding:14px 4px;font-size:1.04rem;border-bottom:1px solid var(--linha-fina);color:var(--caramelo-esc)}
  .topbar .btn{margin-top:12px;justify-content:center}
}

/* =================== BLOG INDEX =================== */
.blog-hero{padding:clamp(48px,8vw,96px) 0 clamp(20px,4vw,40px);text-align:center}
.blog-hero .eyebrow{margin-bottom:20px}
.blog-hero h1{margin:0 auto;max-width:16ch}
.blog-hero .lead{margin:22px auto 0;max-width:60ch}
.blog-hero--lush{position:relative;z-index:0}
.blog-hero--lush::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:100vw;height:128%;max-height:540px;background:url(/assets/hero-blog-bg.webp) top center / 100% auto no-repeat;opacity:.6;z-index:-1;pointer-events:none;-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 40%,transparent 86%);mask-image:linear-gradient(180deg,#000 0%,#000 40%,transparent 86%)}
@media(max-width:700px){.blog-hero--lush::before{background-image:url(/assets/hero-blog-bg-mobile.webp);max-height:380px;opacity:.66}}

.pillar-card{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,52px);align-items:center;
  background:var(--creme-card);border:1px solid var(--linha);border-radius:var(--raio-lg);box-shadow:var(--el-4);
  padding:clamp(28px,4vw,48px);margin:clamp(34px,5vw,56px) 0;position:relative;overflow:hidden}
.pillar-card::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:radial-gradient(120% 90% at 100% 0,rgba(203,158,120,.16),transparent 58%)}
.pillar-card>*{position:relative;z-index:1}
.pillar-tag{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--caramelo);margin-bottom:14px}
.pillar-tag::before{content:"";width:7px;height:7px;background:var(--grad-rose);transform:rotate(45deg);border-radius:1px}
.pillar-card h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:14px}
.pillar-card p{color:var(--texto-suave);line-height:1.6;margin-bottom:22px}
.pillar-emblem{display:flex;align-items:center;justify-content:center;aspect-ratio:4/3;border-radius:var(--raio);
  background:linear-gradient(180deg,#fff,#F3EBE2);border:1px solid var(--linha);position:relative}
.pillar-emblem::after{content:"";position:absolute;inset:12px;border:1px solid var(--linha-fina);border-radius:calc(var(--raio) - 6px);pointer-events:none}
.pillar-emblem img{width:46%;position:relative;filter:drop-shadow(0 10px 20px rgba(124,85,48,.18))}
@media(max-width:720px){.pillar-card{grid-template-columns:1fr}.pillar-emblem{order:-1;max-width:300px;margin:0 auto}}

.cat-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:8px 0 30px}
.cat-chip{font-size:.82rem;font-weight:500;color:var(--texto-suave);padding:8px 16px;border:1px solid var(--linha);border-radius:100px;background:var(--creme-card);cursor:pointer}
a.cat-chip{text-decoration:none;transition:border-color .3s,color .3s,background .3s}
a.cat-chip:hover{border-color:var(--nude);color:var(--caramelo-esc);background:var(--creme-tex)}
.cat-lead{font-size:.85rem;color:var(--texto-suave);align-self:center;margin-right:4px}

.blog-grid-h{text-align:center;font-size:clamp(1.4rem,2.6vw,1.9rem);margin:clamp(22px,3.4vw,34px) 0 16px;color:var(--caramelo-esc)}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px;padding-bottom:clamp(40px,7vw,90px)}
.pcard{display:flex;flex-direction:column;background:var(--creme-card);border:1px solid var(--linha-fina);border-radius:var(--raio-lg);overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--el-2);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s,border-color .5s;position:relative;isolation:isolate}
.pcard::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-rose);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--el-4);border-color:var(--nude-claro)}
.pcard:hover::before{transform:scaleX(1)}
.pcard:focus-visible{transform:translateY(-5px);box-shadow:var(--el-4);border-color:var(--nude-claro);outline-offset:4px}
.pcard:focus-visible::before{transform:scaleX(1)}
.pillar-card:focus-visible{box-shadow:var(--el-float);border-color:var(--nude-claro);outline-offset:4px}
.pcard .pcard-body{padding:26px 26px 22px;display:flex;flex-direction:column;gap:12px;flex:1}
.pcard .pcat{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--nude-texto)}
.pcard h3{font-size:1.18rem;font-weight:400;line-height:1.3;color:var(--caramelo-esc)}
.pcard p{font-size:.95rem;color:var(--texto-suave);line-height:1.55;flex:1}
.pcard .pmeta{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--nude-texto);margin-top:4px}
.pcard .pmore{display:inline-flex;align-items:center;gap:7px;font-weight:500;font-size:.9rem;color:var(--caramelo)}
.pcard .pmore .arrow{transition:transform .4s}
.pcard:hover .pmore .arrow{transform:translateX(4px)}

/* =================== POST =================== */
.post-shell{max-width:1080px;margin:0 auto;padding:0 var(--gut)}
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:9px;font-size:.82rem;color:var(--texto-suave);padding:22px 0 0}
.breadcrumb a{color:var(--texto-suave);text-decoration:none;display:inline-block;padding:6px 3px;margin:-6px -3px;border-radius:6px}
.breadcrumb a:hover{color:var(--caramelo)}
.breadcrumb .sep{width:6px;height:6px;border-right:1.5px solid var(--nude);border-bottom:1.5px solid var(--nude);transform:rotate(-45deg);display:inline-block;opacity:.7}
.breadcrumb [aria-current]{color:var(--caramelo-esc);font-weight:500}

.post-hero{padding:clamp(26px,4vw,44px) 0 clamp(20px,3vw,32px);max-width:var(--read);margin:0 auto}
.post-hero .eyebrow{margin-bottom:18px}
.post-hero h1{font-size:clamp(1.95rem,4.6vw,3rem);line-height:1.08}
.byline{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;margin-top:24px;font-size:.86rem;color:var(--nude-texto)}
.byline .who{display:inline-flex;align-items:center;gap:9px;color:var(--texto-suave);font-weight:500}
.byline .who img{width:30px;height:30px;border-radius:50%;border:1px solid var(--linha)}
.byline .dot{width:3px;height:3px;border-radius:50%;background:var(--nude);opacity:.7}

.post-grid-layout{display:grid;grid-template-columns:228px minmax(0,var(--read));gap:clamp(28px,4vw,56px);justify-content:center;align-items:stretch;padding:14px 0 clamp(40px,6vw,80px)}
.post-grid-layout>aside{height:100%}
.toc{position:sticky;top:80px;background:var(--creme-card);border:1px solid var(--linha-fina);border-radius:var(--raio);padding:8px 4px;box-shadow:var(--el-1)}
.toc summary{cursor:pointer;list-style:none;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--caramelo-esc);padding:12px 16px;display:flex;align-items:center;gap:8px}
.toc summary::-webkit-details-marker{display:none}
.toc summary::before{content:"";width:7px;height:7px;background:var(--grad-rose);transform:rotate(45deg);border-radius:1px}
.toc ol{list-style:none;padding:0 8px 8px;display:flex;flex-direction:column;gap:1px}
.toc a{display:block;font-size:.88rem;line-height:1.35;color:var(--texto-suave);text-decoration:none;padding:8px 12px;border-radius:9px;border-left:2px solid transparent;transition:background .3s,color .3s,border-color .3s}
.toc a:hover{background:var(--creme-tex);color:var(--caramelo-esc);border-left-color:var(--nude)}

/* corpo do artigo */
.prose{max-width:var(--read);font-size:clamp(1.07rem,0.99rem + 0.42vw,1.18rem);line-height:1.72;color:var(--texto);text-align:left;font-feature-settings:'kern' 1,'liga' 1;font-kerning:normal}
.prose>p{margin:0 0 1.15em}
.prose .lead{font-size:clamp(1.12rem,1.9vw,1.3rem);color:var(--texto-suave);margin:0 0 26px}
.prose h2{margin:clamp(40px,6vw,64px) 0 16px;scroll-margin-top:76px;position:relative}
.prose h2::after{content:"";display:block;width:42px;height:2px;background:var(--grad-rose);border-radius:2px;margin-top:14px;opacity:.8}
.prose h3{margin:38px 0 10px;color:var(--caramelo);scroll-margin-top:76px}
.prose a{color:var(--caramelo);font-weight:500;text-decoration:underline;text-decoration-color:var(--nude-claro);text-underline-offset:3px;transition:text-decoration-color .3s}
.prose a:hover{text-decoration-color:var(--caramelo)}
.prose ul.ul-check,.prose ol.ol-step{list-style:none;margin:6px 0 24px;display:flex;flex-direction:column;gap:12px}
.prose ul.ul-check li{position:relative;padding-left:30px;line-height:1.6}
.prose ul.ul-check li::before{content:"";position:absolute;left:0;top:.28em;width:17px;height:17px;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23946738' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.prose ol.ol-step{counter-reset:s}
.prose ol.ol-step li{position:relative;padding-left:46px;line-height:1.6;min-height:32px}
.prose ol.ol-step li::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:-.1em;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1rem;color:var(--caramelo-esc);background:linear-gradient(180deg,#fff,#F3EBE2);border:1px solid var(--linha);border-radius:50%}
.prose strong{color:var(--caramelo-esc)}
.callout{background:linear-gradient(180deg,var(--creme-card),#FBF6F0);border:1px solid var(--linha);border-left:3px solid var(--nude);border-radius:14px;padding:22px 24px;margin:26px 0;box-shadow:var(--el-1)}
.callout p{margin:0;font-size:1.08rem;color:var(--caramelo-esc);line-height:1.55}
.tldr{background:linear-gradient(180deg,var(--creme-card),#FBF6F0);border:1px solid var(--linha);border-left:3px solid var(--caramelo);border-radius:14px;padding:22px 26px;margin:0 0 30px;box-shadow:var(--el-1)}
.tldr-label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--caramelo);margin-bottom:13px}
.tldr-label::before{content:"";width:7px;height:7px;background:var(--grad-rose);transform:rotate(45deg);border-radius:1px;flex:none}
.tldr ul{list-style:none;margin:0;display:flex;flex-direction:column;gap:10px}
.tldr li{position:relative;padding-left:27px;font-size:.99rem;line-height:1.5;color:var(--texto)}
.tldr li::before{content:"";position:absolute;left:0;top:.2em;width:16px;height:16px;background:no-repeat center/contain url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23946738' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.tbl-wrap{margin:24px 0;overflow-x:auto;border:1px solid var(--linha);border-radius:14px;box-shadow:var(--el-1)}
.prose table{width:100%;border-collapse:collapse;font-size:.96rem;background:var(--creme-card);min-width:440px}
.prose thead th{background:var(--creme-tex);color:var(--caramelo-esc);font-weight:600;text-align:left;padding:14px 18px;font-size:.9rem;border-bottom:1px solid var(--linha)}
.prose tbody td{padding:13px 18px;border-bottom:1px solid var(--linha-fina);color:var(--texto);vertical-align:top}
.prose tbody tr:last-child td{border-bottom:none}
.prose tbody tr:nth-child(even){background:rgba(243,238,232,.45)}
.prose figure{margin:28px 0}
.prose figure svg{display:block;width:100%;height:auto;border-radius:var(--raio);border:1px solid var(--linha-fina);background:var(--creme-card)}
.prose figcaption{font-size:.84rem;color:var(--nude-texto);text-align:center;margin-top:10px}

/* card da autora */
.author-card{display:flex;gap:20px;align-items:center;max-width:var(--read);margin:44px auto 0;padding:26px;background:var(--creme-card);border:1px solid var(--linha);border-radius:var(--raio-lg);box-shadow:var(--el-2)}
.author-card .ava{width:74px;height:74px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#F3EBE2);border:1px solid var(--linha);overflow:hidden}
.author-card .ava img{width:100%;height:100%;object-fit:cover}
.author-card .ava img.sym{width:54%;height:auto;object-fit:contain}
.author-card .who-name{font-family:var(--serif);font-size:1.2rem;color:var(--caramelo-esc)}
.author-card .who-role{font-size:.82rem;letter-spacing:.04em;color:var(--nude-texto);text-transform:uppercase;margin:3px 0 9px;font-weight:500}
.author-card .who-bio{font-size:.95rem;color:var(--texto-suave);line-height:1.55}
.author-card .who-bio a{color:var(--caramelo);font-weight:500;text-decoration:none}

/* mini-faq (reusa .qa da home) */
.post-faq{max-width:var(--read);margin:48px auto 0}
.post-faq h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:20px}
.faq{display:flex;flex-direction:column;gap:12px}
.qa{background:var(--creme-card);border:1px solid var(--linha-fina);border-radius:16px;overflow:hidden;transition:box-shadow .45s,border-color .45s}
.qa:hover{border-color:var(--linha)}
.qa[open]{box-shadow:var(--el-3);border-color:var(--nude-claro)}
.qa summary{padding:22px 24px;cursor:pointer;font-family:var(--serif);font-size:1.08rem;color:var(--caramelo-esc);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px}
.qa summary::-webkit-details-marker{display:none}
.qa:hover summary{color:var(--caramelo)}
.qa summary .pl{width:22px;height:22px;flex:none;position:relative;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.qa summary .pl::before,.qa summary .pl::after{content:"";position:absolute;background:var(--nude-prof);border-radius:2px}
.qa summary .pl::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%)}
.qa summary .pl::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);transition:opacity .35s}
.qa[open] summary .pl{transform:rotate(180deg)}
.qa[open] summary .pl::after{opacity:0}
.qa .a{padding:2px 24px 24px;color:var(--texto-suave);font-size:1rem;line-height:1.7}
.qa .a a{color:var(--caramelo);font-weight:500}

/* CTA suave */
.cta-soft{max-width:var(--read);margin:48px auto 0;text-align:center;background:linear-gradient(135deg,#7C5530,#946738);border-radius:var(--raio-lg);padding:clamp(34px,5vw,52px) clamp(24px,4vw,44px);position:relative;overflow:hidden;box-shadow:var(--el-4)}
.cta-soft::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(90% 120% at 80% 0,rgba(220,192,166,.32),transparent 60%)}
.cta-soft>*{position:relative;z-index:1}
.cta-soft .eyebrow{color:#FAF0E4;justify-content:center}
.cta-soft .eyebrow::before{background:linear-gradient(90deg,transparent,var(--nude-claro))}
.cta-soft .eyebrow.center::after{background:linear-gradient(90deg,var(--nude-claro),transparent)}
.cta-soft h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem);margin:14px 0 10px}
.cta-soft .mark{color:#fff}
.cta-soft .mark::after{background:rgba(220,192,166,.24)}
.cta-soft p{color:#FBF2E9;max-width:46ch;margin:0 auto 24px;line-height:1.6}
.cta-soft .btn{background:#fff;color:var(--caramelo-esc);text-shadow:none}
.cta-soft .btn::after{background:#F3EBE2}
.cta-soft small{display:block;margin-top:14px;font-size:.82rem;color:#FAF0E4}

/* related posts */
.related{max-width:1080px;margin:0 auto;padding:clamp(40px,6vw,72px) var(--gut) 0}
.related h2{text-align:center;font-size:clamp(1.4rem,2.6vw,1.9rem);margin-bottom:8px}
.related .sub{text-align:center;color:var(--texto-suave);margin-bottom:30px}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}

/* ---------- Footer (igual a home) ---------- */
footer{background:linear-gradient(180deg,var(--creme-tex),#EDE4D9);border-top:1px solid var(--linha);padding:clamp(46px,7vw,76px) 0 36px;text-align:center;margin-top:clamp(50px,8vw,90px)}
footer .brand{justify-content:center;margin-bottom:18px}
footer .logo-img{height:30px;margin:0 auto}
footer>.wrap>p{max-width:52ch;margin:0 auto;color:var(--texto-suave);font-size:.97rem;line-height:1.6}
.fsocial{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin:24px 0}
.fsocial a{color:var(--caramelo-esc);text-decoration:none;font-size:.92rem;font-weight:500;display:inline-block;padding:6px 4px;margin:-6px -4px;border-radius:6px}
.fsocial a:hover{color:var(--caramelo-esc)}
.fleg{font-size:.82rem;color:var(--nude-texto);margin-top:8px}

@media(max-width:900px){
  .post-grid-layout{grid-template-columns:minmax(0,var(--read))}
  .toc{position:static;margin:0 auto 8px;width:100%}
  .toc summary::after{content:"";width:8px;height:8px;border-right:1.6px solid var(--nude);border-bottom:1.6px solid var(--nude);transform:rotate(45deg);margin-left:auto;transition:transform .3s}
  .toc[open] summary::after{transform:rotate(-135deg)}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
}

/* ===== Upgrades visuais classe-mundial (indice do blog) ===== */
.hero-emblem{display:flex;justify-content:center;margin:0 auto 22px;width:clamp(54px,9vw,72px);height:clamp(54px,9vw,72px);filter:drop-shadow(0 8px 16px rgba(124,85,48,.16))}
.hero-emblem svg{width:100%;height:auto;display:block}
.hero-emblem .lz{fill:var(--nude)}
@media(prefers-reduced-motion:no-preference){
  .hero-emblem .ch1{stroke-dasharray:120;stroke-dashoffset:120;animation:chDraw 1.1s cubic-bezier(.16,1,.3,1) .15s forwards}
  .hero-emblem .ch2{stroke-dasharray:120;stroke-dashoffset:120;animation:chDraw 1.1s cubic-bezier(.16,1,.3,1) .32s forwards}
  .hero-emblem .lz{opacity:0;animation:lzIn .6s ease .9s forwards}
}
@keyframes chDraw{to{stroke-dashoffset:0}}
@keyframes lzIn{to{opacity:1}}
@media(max-width:480px){.hero-emblem{width:48px}}
.pcard .pcard-body{position:relative}
.pcard .pidx{position:absolute;top:0;right:2px;font-family:var(--serif);font-weight:300;font-size:.9rem;letter-spacing:.14em;color:var(--nude-claro);transition:color .5s}
.pcard:hover .pidx{color:var(--nude)}
.pcard .pcard-body::after{content:"";position:absolute;right:22px;bottom:18px;width:26px;height:20px;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .5s,transform .5s cubic-bezier(.16,1,.3,1);
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 64' fill='none'%3E%3Cg stroke='%23CB9E78' stroke-width='5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 18 L40 48 L70 18'/%3E%3Cpath d='M10 34 L40 64 L70 34'/%3E%3C/g%3E%3C/svg%3E")}
.pcard:hover .pcard-body::after,.pcard:focus-visible .pcard-body::after{opacity:.5;transform:none}
.pillar-emblem{overflow:hidden}
.pillar-emblem::before{content:"";position:absolute;right:-18%;bottom:-22%;width:78%;height:78%;z-index:0;pointer-events:none;opacity:.4;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 64' fill='none'%3E%3Cg stroke='%23DCC0A6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 18 L40 50 L72 18'/%3E%3Cpath d='M8 32 L40 64 L72 32'/%3E%3C/g%3E%3C/svg%3E")}
.pillar-emblem .pe-stamp{position:absolute;top:14px;right:14px;z-index:3;width:clamp(58px,17%,70px);height:clamp(58px,17%,70px);border-radius:50%;
  border:1px solid var(--nude-claro);background:rgba(255,253,251,.72);display:flex;align-items:center;justify-content:center;text-align:center;
  font-size:.54rem;line-height:1.16;letter-spacing:.1em;text-transform:uppercase;color:var(--nude-texto);font-weight:600;transform:rotate(-9deg)}
.index-author{margin-top:clamp(20px,3vw,30px)}
@media(max-width:560px){.index-author{flex-direction:column;text-align:center}.index-author .ava{margin:0 auto}}

/* ===== cartao-pilar com foto editorial ===== */
.pillar-emblem--photo{background:var(--creme-tex);width:100%}
.pillar-emblem--photo::before{display:none}
.pillar-emblem--photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%;filter:none}
.pillar-emblem--photo .pe-stamp{background:rgba(255,253,251,.82);backdrop-filter:saturate(150%) blur(2px);-webkit-backdrop-filter:saturate(150%) blur(2px)}

/* ===== miniatura no card + imagem-herói do post (fotos editoriais) ===== */
.pthumb{aspect-ratio:3/2;overflow:hidden;background:var(--creme-tex);border-bottom:1px solid var(--linha-fina)}
.pthumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.pcard:hover .pthumb img{transform:scale(1.045)}
.post-cover{max-width:var(--read);margin:8px auto 2px;border-radius:var(--raio-lg);overflow:hidden;box-shadow:var(--el-3);border:1px solid var(--linha-fina);background:var(--creme-tex)}
.post-cover img{width:100%;height:auto;display:block;aspect-ratio:3/2;object-fit:cover}

/* =========================================================
   UX overhaul — orientacao, leitura, distribuicao (todas as paginas)
   ========================================================= */
html{hanging-punctuation:first last}

/* skip-link (a11y) */
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--caramelo-esc);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;font-weight:500;font-size:.9rem;text-decoration:none}
.skip:focus{left:0}

/* barra de progresso de leitura */
.read-progress{position:fixed;left:0;right:0;top:0;height:2px;z-index:60;background:transparent;pointer-events:none}
.read-progress i{display:block;height:100%;width:0;background:var(--grad-rose);transform-origin:left}

/* scroll-spy: secao ativa no TOC */
.toc a[aria-current]{background:var(--creme-tex);color:var(--caramelo-esc);border-left-color:var(--nude);font-weight:500}

/* compartilhar */
.share{display:flex;flex-wrap:wrap;align-items:center;gap:10px;max-width:var(--read);margin:0 auto}
.share--hero{margin-top:22px}
.share--end{margin:38px auto 0;padding-top:26px;border-top:1px solid var(--linha-fina)}
.share-label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--nude-texto);margin-right:2px}
.share a,.share button{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:.85rem;font-weight:500;color:var(--texto-suave);background:var(--creme-card);border:1px solid var(--linha-fina);border-radius:100px;padding:9px 16px;cursor:pointer;text-decoration:none;transition:border-color .3s,color .3s,background .3s}
.share a:hover,.share button:hover,.share a:focus-visible,.share button:focus-visible{border-color:var(--nude);color:var(--caramelo-esc);background:var(--creme-tex)}
.share svg{width:16px;height:16px;flex:none;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.sh-native{order:-1}
@media(min-width:769px){.sh-native{display:none!important}}

/* voltar ao topo */
.to-top{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:55;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--creme-card);border:1px solid var(--linha);box-shadow:var(--el-3);color:var(--caramelo);cursor:pointer;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .4s,transform .4s cubic-bezier(.16,1,.3,1),border-color .3s,color .3s}
.to-top.is-on{opacity:1;pointer-events:auto;transform:none}
.to-top:hover{border-color:var(--nude);color:var(--caramelo-esc)}
.to-top svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* anterior / proximo */
.pager{max-width:var(--read);margin:0 auto;padding:clamp(30px,5vw,46px) 0 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pager a{display:flex;flex-direction:column;gap:7px;padding:18px 22px;border:1px solid var(--linha-fina);border-radius:var(--raio);background:var(--creme-card);text-decoration:none;transition:border-color .3s,transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s}
.pager a:hover{border-color:var(--nude-claro);transform:translateY(-3px);box-shadow:var(--el-2)}
.pager .pg-dir{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--nude-texto);display:flex;align-items:center;gap:7px}
.pager .pg-dir .arrow{transition:transform .4s}
.pager a:hover .pg-dir .arrow{transform:translateX(3px)}
.pager .pg-prev:hover .pg-dir .arrow{transform:translateX(-3px)}
.pager .pg-next{text-align:right;align-items:flex-end}
.pager .pg-title{font-family:var(--serif);font-weight:400;color:var(--caramelo-esc);line-height:1.32;font-size:1.02rem}
@media(max-width:560px){.pager{grid-template-columns:1fr}.pager .pg-next{text-align:left;align-items:flex-start}}

/* pull-quote editorial (frase puxada do texto) */
.pquote{max-width:var(--read);margin:clamp(34px,5vw,50px) auto;padding-left:clamp(20px,4vw,34px);border-left:2px solid var(--nude)}
.pquote p{font-family:var(--serif);font-weight:300;font-size:clamp(1.34rem,3vw,1.85rem);line-height:1.3;letter-spacing:-.012em;color:var(--caramelo-esc);text-wrap:balance;margin:0}

/* CTA inline contextual (1 por artigo longo) */
.inline-cta{max-width:var(--read);margin:clamp(34px,5vw,46px) auto;background:linear-gradient(180deg,#F5EFE8,#F1E9DF);border:1px solid var(--linha-fina);border-left:3px solid var(--caramelo);border-radius:12px;padding:clamp(20px,3vw,26px) clamp(22px,3.5vw,30px)}
.inline-cta p{margin:0 0 10px;color:var(--texto-suave);line-height:1.55}
.inline-cta a{font-weight:600;color:var(--caramelo);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.inline-cta a .arrow{transition:transform .4s}
.inline-cta a:hover .arrow{transform:translateX(4px)}

/* ancora copiavel nos H2 */
.head-anchor{position:absolute;left:-30px;top:.42em;display:inline-flex;opacity:0;color:var(--nude);transition:opacity .3s,color .3s;text-decoration:none;padding:2px}
.head-anchor svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.prose h2:hover .head-anchor,.head-anchor:focus-visible{opacity:1}
.head-anchor:hover{color:var(--caramelo)}
@media(max-width:1180px){.head-anchor{position:static;opacity:.45;margin-left:9px;vertical-align:middle}.head-anchor svg{width:15px;height:15px}}

/* grifo de termos no corpo (separado do .mark de titulo) */
.prose mark,.prose .hl{background:linear-gradient(180deg,transparent 58%,rgba(203,158,120,.34) 58%);color:inherit;padding:0 .04em;border-radius:2px;white-space:normal;-webkit-box-decoration-break:clone;box-decoration-break:clone}

/* primeira linha do corpo em versalete */
.prose>p.opening::first-line{font-variant-caps:small-caps;letter-spacing:.03em;color:var(--caramelo-esc)}

/* mini-TOC sticky (mobile) */
.toc-mini{display:none}
@media(max-width:900px){
  .post-grid-layout>aside{display:none}
  .toc-mini{display:block;position:sticky;top:var(--tbh,72px);z-index:40;margin:0 calc(-1 * var(--gut));background:rgba(250,247,244,.94);backdrop-filter:saturate(160%) blur(10px);-webkit-backdrop-filter:saturate(160%) blur(10px);border-top:1px solid var(--linha-fina);border-bottom:1px solid var(--linha-fina)}
  .toc-mini-btn{width:100%;display:flex;align-items:center;gap:11px;padding:12px var(--gut);background:none;border:none;cursor:pointer;text-align:left}
  .toc-mini-btn .tm-tag{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--nude-texto);flex:none}
  .toc-mini-btn .tm-label{flex:1;font-size:.9rem;color:var(--caramelo-esc);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--sans)}
  .toc-mini-btn .tm-chev{width:9px;height:9px;border-right:1.6px solid var(--nude);border-bottom:1.6px solid var(--nude);transform:rotate(45deg);transition:transform .3s;flex:none;margin-bottom:2px}
  .toc-mini-btn[aria-expanded="true"] .tm-chev{transform:rotate(-135deg);margin-bottom:-2px}
  .toc-mini-panel{max-height:0;overflow:hidden;transition:max-height .32s cubic-bezier(.16,1,.3,1);background:var(--creme-card)}
  .toc-mini-panel.is-open{max-height:62vh;overflow:auto;border-top:1px solid var(--linha-fina)}
  .toc-mini-panel ol{list-style:none;padding:8px var(--gut) 14px;display:flex;flex-direction:column;gap:1px;counter-reset:tm}
  .toc-mini-panel a{display:block;font-size:.9rem;line-height:1.35;color:var(--texto-suave);text-decoration:none;padding:10px 12px;border-radius:9px;border-left:2px solid transparent}
  .toc-mini-panel a[aria-current]{background:var(--creme-tex);color:var(--caramelo-esc);border-left-color:var(--nude);font-weight:500}
  html{scroll-padding-top:calc(var(--tbh,72px) + 52px)}
}
@media(max-width:560px){.prose{hyphens:auto}}

/* grifo do H1 do post: multilinha-safe (sem nowrap -> sem overflow no mobile) */
.post-hero h1 .mark{white-space:normal;color:var(--caramelo-esc);background:linear-gradient(180deg,transparent 56%,rgba(220,192,166,.72) 56%);border-radius:2px;padding:0 .05em;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.post-hero h1 .mark::after{display:none}

/* leaf wash sutil no topo do post (coesao com indice/categorias; some antes da capa) */
.post-top{position:relative;z-index:0}
.post-top::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:100vw;height:120%;max-height:360px;background:url(/assets/hero-blog-bg.webp) top center / 100% auto no-repeat;opacity:.4;z-index:-1;pointer-events:none;-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 28%,transparent 74%);mask-image:linear-gradient(180deg,#000 0%,#000 28%,transparent 74%)}
@media(max-width:700px){.post-top::before{background-image:url(/assets/hero-blog-bg-mobile.webp);max-height:300px;opacity:.46}}

/* alvos de toque mais generosos no mobile (>=40px) */
@media(max-width:560px){
  .share a,.share button{padding:12px 18px}
  .cat-chip{padding:11px 17px}
}

/* filtro de categoria no indice */
.cat-chip.is-active{border-color:var(--nude);color:var(--caramelo-esc);background:var(--creme-tex);font-weight:600}
.cat-jump{text-align:center;margin:-8px 0 30px}
.cat-jump a{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;color:var(--caramelo);text-decoration:none}
.cat-jump a .arrow{transition:transform .4s}
.cat-jump a:hover .arrow{transform:translateX(4px)}

/* capa de marca (posts ainda sem foto editorial) */
.pthumb--brand{position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--creme-card),var(--creme-tex))}
.pthumb--brand::after{content:"";position:absolute;inset:0;z-index:0;background:url(/assets/hero-blog-bg.webp) top center/cover no-repeat;opacity:.4;pointer-events:none}
.pthumb--brand img{width:32%;max-width:88px;height:auto;position:relative;z-index:1;opacity:.92;filter:drop-shadow(0 8px 16px rgba(124,85,48,.18))}
.post-cover--brand{position:relative;aspect-ratio:3/2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:linear-gradient(160deg,var(--creme-card),var(--creme-tex))}
.post-cover--brand::after{content:"";position:absolute;inset:0;z-index:0;background:url(/assets/hero-blog-bg.webp) top center/cover no-repeat;opacity:.42;pointer-events:none}
.post-cover--brand img{width:118px;height:auto;position:relative;z-index:1;opacity:.94;filter:drop-shadow(0 14px 26px rgba(124,85,48,.22))}
.post-cover--brand .pcb-cat{position:relative;z-index:1;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--nude-texto)}
