/* ============================================================
   DiferenciAgro · Sistema de design "Verde Protagonista"
   Montserrat (títulos e rótulos) + Poppins (texto)
   Cores da marca: verde-escuro #1D5C31 · verde-vivo #2FA24C
   Assinatura visual: corte diagonal entre os dois verdes
   ============================================================ */

:root{
  /* Paleta da marca (nomes antigos mantidos por compatibilidade) */
  --pine:#1d5c31;        /* verde-escuro da marca */
  --pine-700:#174d28;    /* hover do escuro */
  --pine-600:#2a7a42;    /* verde intermediário */
  --pine-900:#123b1f;    /* verde profundo (rodapé) */
  --cherry:#2fa24c;      /* verde-vivo da marca (acento principal) */
  --cherry-700:#248a3d;  /* hover do vivo */
  --honey:#79d694;       /* verde-claro para detalhes sobre fundo escuro */
  --mist:#ffffff;        /* fundo geral: branco, clean */
  --mist-2:#f2f8f4;      /* tinta verde bem leve para seções alternadas */
  --paper:#ffffff;
  --ink:#14231a;         /* texto principal */
  --ink-soft:#5a6e61;    /* texto secundário */
  --line:#e1ebe4;        /* bordas no claro */
  --line-dark:rgba(255,255,255,.16); /* bordas no escuro */

  --serif:'Montserrat',system-ui,-apple-system,sans-serif; /* títulos */
  --sans:'Poppins',system-ui,-apple-system,sans-serif;      /* corpo */
  --mono:'Montserrat',system-ui,-apple-system,sans-serif;   /* rótulos */

  --wrap:1180px;
  --radius:12px;
  --diag:115deg; /* ângulo do corte diagonal da marca */
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--mist);
  line-height:1.65;
  font-size:16.5px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Tipografia base ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.2rem,5.2vw,3.7rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:clamp(1.15rem,1.9vw,1.4rem);font-weight:700}
p{max-width:64ch}
strong{font-weight:600}
em{font-style:normal;color:var(--cherry)}

/* ---------- Utilidades ---------- */
.container{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.eyebrow{
  font-family:var(--mono);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--cherry);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:22px;height:3px;background:var(--cherry);border-radius:2px;flex:none}
.eyebrow--honey{color:var(--honey)}
.eyebrow--honey::before{background:var(--honey)}
.eyebrow--light{color:var(--honey)}
.eyebrow--light::before{background:var(--honey)}
.annot{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.rule{height:1px;background:var(--line);border:0}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}
.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}

/* ---------- Botões (pílula, modernos) ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--serif);font-weight:700;font-size:.92rem;letter-spacing:.01em;
  padding:.95em 1.8em;border-radius:999px;border:2px solid transparent;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--cherry);color:#fff}
.btn--primary:hover{background:var(--cherry-700);box-shadow:0 10px 24px -10px rgba(47,162,76,.55)}
.btn--dark{background:var(--pine);color:#fff}
.btn--dark:hover{background:var(--pine-700)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--cherry);color:var(--cherry-700)}
.btn--ondark{background:transparent;color:#fff;border-color:var(--line-dark)}
.btn--ondark:hover{background:#fff;color:var(--pine)}

/* ---------- Cabeçalho / navegação ---------- */
.site-header{position:sticky;top:0;z-index:60;background:#fff;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--serif);font-weight:800;font-size:1.25rem;letter-spacing:-.02em;color:var(--pine)}
.brand__mark{width:38px;height:38px;flex:none}
.brand b{color:var(--cherry);font-weight:800}
.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{font-family:var(--serif);font-size:.9rem;font-weight:600;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--cherry-700)}
.nav-links a[aria-current="page"]{color:var(--pine);font-weight:700;box-shadow:inset 0 -3px 0 var(--cherry)}
.nav__cta{display:flex;align-items:center;gap:.8rem}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:10px;background:#fff;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;background:var(--ink);transition:.25s}
.nav-toggle span::before{transform:translateY(-6px)}
.nav-toggle span::after{transform:translateY(4px)}

@media(max-width:900px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;top:74px;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:#fff;border-bottom:1px solid var(--line);
    padding:.5rem 0;max-height:0;overflow:hidden;transition:max-height .3s ease;
  }
  .nav-links.open{max-height:60vh}
  .nav-links a{width:100%;padding:.9rem clamp(1.1rem,4vw,2rem)}
  .nav-links a[aria-current="page"]{box-shadow:inset 4px 0 0 var(--cherry)}
  .nav__cta .btn--ghost{display:none}
}

/* ---------- Seções ---------- */
.section{padding:clamp(3.2rem,7.5vw,6rem) 0}
.section--pine{background:var(--pine);color:#eaf6ee}
.section--pine h2,.section--pine h3{color:#fff}
.section--pine p{color:#d5eadc}
.section--mist2{background:var(--mist-2)}
.section__head{max-width:58ch;margin-bottom:clamp(2rem,4vw,3rem)}
.section__head h2{margin:.7rem 0 .8rem}
.section__intro{font-size:1.08rem;color:var(--ink-soft)}
.section--pine .section__intro{color:#c5e2cf}
.section__head--center{margin-inline:auto;text-align:center}
.section__head--center .eyebrow{justify-content:center}

/* ---------- HERO (clean: branco com respiro) ---------- */
.hero{position:relative;padding:clamp(2.8rem,6vw,5rem) 0 clamp(2rem,5vw,3.5rem);overflow:hidden;background:linear-gradient(180deg,#ffffff,#f7fbf8)}
.hero::after{
  content:"";position:absolute;top:-25%;right:-12%;width:55vw;height:55vw;z-index:0;pointer-events:none;
  background:radial-gradient(circle, rgba(47,162,76,.09), transparent 62%);
}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.hero__title{margin:1.1rem 0 1.2rem}
.hero__title em{color:var(--cherry)}
.hero__lead{font-size:1.12rem;color:var(--ink-soft);max-width:48ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.8rem 0 1.4rem}
.hero__trust{font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:.5rem 1.2rem}
.hero__trust span{display:inline-flex;align-items:center;gap:.5em}
.hero__trust span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cherry)}

/* Cartão "caderno de campo" (assinatura), agora no verde da marca */
.fieldcard{
  background:var(--pine);color:#eaf6ee;border-radius:20px;
  padding:clamp(1.3rem,2.5vw,1.9rem);position:relative;overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(18,59,31,.5);
}
.fieldcard::before{ /* corte diagonal da marca no topo do cartão */
  content:"";position:absolute;top:0;left:0;right:0;height:7px;
  background:linear-gradient(90deg,var(--cherry) 0 55%,var(--honey) 55% 100%);
}
.fieldcard__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.4rem 0 .9rem;margin-bottom:1.1rem;border-bottom:1px dashed var(--line-dark)}
.fieldcard__label{font-family:var(--mono);font-size:.66rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--honey)}
.fieldcard__branch{width:32px;height:32px;color:var(--honey)}
.fieldrow{display:flex;justify-content:space-between;gap:1rem;font-family:var(--sans);font-size:.85rem;padding:.45rem 0;border-bottom:1px dotted var(--line-dark)}
.fieldrow:last-of-type{border-bottom:0}
.fieldrow dt{color:rgba(255,255,255,.65)}
.fieldrow dd{color:#fff;text-align:right;font-weight:500}
.fieldrow dd b{color:var(--honey);font-weight:700}
.fieldcard__note{margin-top:1.1rem;padding:.85rem 1rem;background:rgba(255,255,255,.08);border-left:3px solid var(--honey);border-radius:0 10px 10px 0}
.fieldcard__note p{font-size:.88rem;color:#eaf6ee;font-family:var(--sans);max-width:none}

@media(max-width:820px){
  .hero__inner{grid-template-columns:1fr}
  .fieldcard{max-width:460px}
}

/* ---------- Faixa de destaques (cards clean) ---------- */
.ledger{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;background:transparent;border-radius:0;overflow:visible;margin-top:clamp(1.75rem,4vw,3rem)}
.ledger__item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.3rem 1.4rem;transition:border-color .2s, box-shadow .2s}
.ledger__item:hover{border-color:var(--cherry);box-shadow:0 16px 32px -24px rgba(29,92,49,.35)}
.ledger__k{font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--cherry);display:block;margin-bottom:.4rem}
.ledger__v{font-family:var(--serif);font-weight:800;font-size:1.12rem;color:var(--pine);line-height:1.2}
@media(max-width:760px){.ledger{grid-template-columns:1fr 1fr}}

/* ---------- Problema / empatia ---------- */
.pain{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.pain__list{margin-top:1.4rem;display:flex;flex-direction:column;gap:.9rem}
.pain__list li{display:flex;gap:.8rem;align-items:flex-start;font-size:1rem}
.pain__list li::before{content:"✗";flex:none;width:1.7rem;height:1.7rem;border-radius:50%;background:#fcebe9;color:#c0392b;display:grid;place-items:center;font-size:.85rem;font-weight:700;margin-top:.1rem}
.pain__card{background:#fff;border:1px solid var(--line);border-top:4px solid var(--cherry);border-radius:16px;padding:clamp(1.3rem,2.5vw,2rem);box-shadow:0 24px 48px -32px rgba(29,92,49,.25)}
.pain__card .eyebrow{margin-bottom:.7rem}
.pain__card p{font-family:var(--serif);font-weight:600;font-size:1.15rem;line-height:1.5;color:var(--pine-900)}
@media(max-width:820px){.pain{grid-template-columns:1fr}}

/* ---------- Como trabalhamos (passos) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.step{position:relative;padding-top:1.3rem;border-top:3px solid rgba(255,255,255,.18)}
.section--pine .step{border-top-color:rgba(255,255,255,.18)}
.step__num{font-family:var(--mono);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--honey);margin-bottom:.7rem}
.step h3{margin-bottom:.5rem}
.step p{font-size:.95rem}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:1.6rem}}

/* ---------- 4 Fases (linha do tempo) ---------- */
.phases{display:flex;flex-direction:column;gap:0}
.phase{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1rem,3vw,2.4rem);align-items:start;padding:clamp(1.3rem,3vw,2rem) clamp(.6rem,1.5vw,1.2rem);border-top:1px solid var(--line);border-radius:14px;transition:background .2s}
.phase:last-child{border-bottom:1px solid var(--line)}
.phase__tag{font-family:var(--mono);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--cherry);white-space:nowrap;padding-top:.4rem}
.phase__body h3{margin-bottom:.4rem}
.phase__body p{font-size:.98rem;color:var(--ink-soft)}
.phase__meta{font-family:var(--mono);font-size:.64rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);text-align:right;white-space:nowrap;padding-top:.4rem;max-width:170px}
.phase__meta b{color:var(--pine);display:block;font-size:.85rem;margin-bottom:.2rem}
.phase:hover{background:var(--mist-2)}
@media(max-width:760px){
  .phase{grid-template-columns:1fr;gap:.5rem}
  .phase__meta{text-align:left;max-width:none}
}

/* ---------- Diferencial / motivos ---------- */
.reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.reason{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:clamp(1.3rem,2.5vw,1.8rem);transition:background .2s}
.reason:hover{background:rgba(255,255,255,.11)}
.reason__ic{width:40px;height:40px;color:var(--honey);margin-bottom:1rem}
.reason h3{color:#fff;margin-bottom:.5rem;font-size:1.15rem}
.reason p{color:#cfe7d8;font-size:.95rem}
@media(max-width:680px){.reasons{grid-template-columns:1fr}}

/* ---------- Manifesto ---------- */
.manifesto{max-width:44ch;margin-inline:auto;text-align:center}
.manifesto__q{font-family:var(--serif);font-weight:700;font-size:clamp(1.4rem,3.2vw,2.1rem);line-height:1.35;color:#fff}
.manifesto__by{font-family:var(--mono);font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--honey);margin-top:1.4rem}

/* ---------- Blog / posts ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.post{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .2s ease, box-shadow .2s ease, border-color .2s}
.post:hover{transform:translateY(-4px);border-color:var(--cherry);box-shadow:0 24px 44px -28px rgba(29,92,49,.35)}
.post__thumb{aspect-ratio:16/10;position:relative;display:flex;align-items:flex-end;padding:.9rem}
.post__thumb .annot{position:absolute;top:.9rem;right:1rem;color:rgba(255,255,255,.8)}
.post__cat{font-family:var(--mono);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.94);color:var(--pine);padding:.45em 1em;border-radius:999px}
.post__body{padding:1.2rem 1.3rem 1.4rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post__body h3{font-size:1.1rem;line-height:1.32}
.post__body h3 a:hover{color:var(--cherry-700)}
.post__excerpt{font-size:.92rem;color:var(--ink-soft);flex:1}
.post__meta{font-family:var(--mono);font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.post__more{font-family:var(--serif);font-weight:700;color:var(--cherry);font-size:.88rem}
@media(max-width:900px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.posts{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{max-width:800px}
.faq__item{border:1px solid var(--line);border-radius:14px;background:#fff;margin-bottom:.8rem;padding:0 1.3rem}
.faq__item summary{
  list-style:none;cursor:pointer;padding:1.1rem 0;
  font-family:var(--serif);font-weight:700;font-size:1rem;color:var(--ink);
  display:flex;justify-content:space-between;gap:1rem;align-items:center;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--sans);color:var(--cherry);font-size:1.5rem;font-weight:400;flex:none;transition:transform .2s}
.faq__item[open]{border-color:var(--cherry)}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{padding:0 0 1.2rem;color:var(--ink-soft);font-size:.96rem}

/* ---------- CTA final (corte diagonal da marca) ---------- */
.cta-final{
  background:linear-gradient(var(--diag),var(--pine) 0%,var(--pine) 62%,var(--cherry) 62.15%);
  color:#fff;border-radius:22px;
  padding:clamp(2.5rem,6vw,4rem) clamp(1.5rem,4vw,3rem);text-align:center;position:relative;overflow:hidden;
}
.cta-final__inner{position:relative;z-index:1}
.cta-final h2{color:#fff;margin-bottom:.7rem}
.cta-final p{color:rgba(255,255,255,.88);max-width:46ch;margin:0 auto 1.8rem;font-size:1.05rem}
.cta-final .btn--primary{background:#fff;color:var(--pine)}
.cta-final .btn--primary:hover{background:#eaf6ee;box-shadow:none}

/* ---------- Rodapé ---------- */
.site-footer{background:var(--pine-900);color:#bcd9c5;padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand{color:#fff;margin-bottom:1rem}
.footer-brand .brand b{color:var(--honey)}
.footer-brand p{font-size:.92rem;color:#9dbfa9;max-width:34ch}
.footer-col h4{font-family:var(--mono);font-size:.64rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#84ab92;margin-bottom:1.1rem}
.footer-col a,.footer-col p{display:block;font-size:.92rem;color:#cfe6d6;margin-bottom:.7rem;max-width:none}
.footer-col a:hover{color:var(--honey)}
.footer-bottom{padding-top:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#84ab92}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Página interna: banner com o corte diagonal ---------- */
.page-head{
  background:linear-gradient(var(--diag),var(--pine) 0%,var(--pine) 72%,var(--cherry) 72.15%);
  color:#fff;border-bottom:0;
  padding:clamp(3rem,6vw,4.5rem) 0 clamp(2.5rem,5vw,3.5rem);
}
.page-head h1{font-size:clamp(2rem,4.6vw,3.2rem);margin:.9rem 0 1rem;color:#fff;max-width:22ch}
.page-head p{font-size:1.08rem;color:rgba(255,255,255,.88);max-width:56ch}
.page-head .breadcrumb{color:rgba(255,255,255,.7)}
.page-head .breadcrumb a:hover{color:#fff}
.breadcrumb{font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--cherry-700)}

/* ---------- Artigo (post) ---------- */
.article{max-width:720px;margin-inline:auto}
.article h1{font-size:clamp(1.8rem,4vw,2.6rem)}
.article__meta{margin:1rem 0 1.6rem;display:flex;flex-wrap:wrap;gap:.5rem}
.article__meta span{font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pine);background:var(--mist-2);padding:.5em 1.1em;border-radius:999px}
.article__body{font-size:1.05rem}
.article__body h2{font-size:clamp(1.35rem,2.8vw,1.8rem);margin:2.4rem 0 .9rem}
.article__body h3{margin:1.8rem 0 .7rem}
.article__body p{margin-bottom:1.2rem;max-width:none}
.article__body ul,.article__body ol{margin:0 0 1.3rem 1.2rem;display:flex;flex-direction:column;gap:.5rem}
.article__body li{padding-left:.3rem}
.article__body ul li{list-style:none;position:relative;padding-left:1.4rem}
.article__body ul li::before{content:"";position:absolute;left:0;top:.62em;width:.5rem;height:.5rem;background:var(--cherry);border-radius:50%}
.article__body ol{list-style:decimal;margin-left:1.5rem}
.article__body blockquote{border-left:4px solid var(--cherry);padding:.4rem 0 .4rem 1.3rem;margin:1.6rem 0;font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--pine)}
.article__body strong{color:var(--ink);font-weight:600}
.callout{background:var(--mist-2);border:1px solid var(--line);border-left:4px solid var(--cherry);border-radius:0 12px 12px 0;padding:1.1rem 1.3rem;margin:1.6rem 0}
.callout p{margin:0;font-size:.98rem}

/* ---------- Tabela (artigos) ---------- */
.tbl{width:100%;border-collapse:collapse;margin:1.6rem 0;font-size:.95rem;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:.8rem 1rem;border-bottom:1px solid var(--line);vertical-align:top}
.tbl th{font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pine);background:var(--mist-2)}
.tbl td{color:var(--ink-soft)}
.tbl tr:last-child td{border-bottom:0}

/* ---------- Caixa do autor + CTA de post ---------- */
.author-box{display:flex;gap:1rem;align-items:center;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.author-box .av{width:52px;height:52px;border-radius:50%;background:var(--pine);flex:none;display:grid;place-items:center}
.author-box b{font-family:var(--serif);font-size:.95rem;display:block}
.author-box span{font-family:var(--mono);font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.post-cta{
  margin-top:2rem;padding:clamp(1.6rem,3vw,2.2rem);
  background:linear-gradient(var(--diag),var(--pine) 0%,var(--pine) 62%,var(--cherry) 62.15%);
  color:#fff;border-radius:18px;text-align:center;
}
.post-cta h3{color:#fff;margin-bottom:.6rem}
.post-cta p{color:rgba(255,255,255,.88);max-width:46ch;margin:0 auto 1.3rem}
.post-cta .btn--primary{background:#fff;color:var(--pine)}
.post-cta .btn--primary:hover{background:#eaf6ee;box-shadow:none}

/* ---------- Contato ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:clamp(1.4rem,3vw,2rem);display:flex;flex-direction:column;gap:1.1rem;box-shadow:0 24px 48px -36px rgba(29,92,49,.3)}
.contact-item{display:flex;gap:.9rem;align-items:flex-start}
.contact-item .ic{width:40px;height:40px;flex:none;color:var(--pine);background:var(--mist-2);border-radius:12px;display:grid;place-items:center}
.contact-item h4{font-family:var(--mono);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);margin-bottom:.2rem}
.contact-item a,.contact-item p{font-size:.98rem;color:var(--ink);font-weight:500}
.contact-item a:hover{color:var(--cherry-700)}
.form-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-field label{font-family:var(--mono);font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.form-field input,.form-field textarea{
  font-family:var(--sans);font-size:.98rem;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);width:100%;transition:border-color .2s;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--cherry)}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Acessibilidade / foco ---------- */
:focus-visible{outline:3px solid var(--cherry);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--pine);color:#fff;padding:.7rem 1rem;z-index:100}
.skip-link:focus{left:0}

/* ---------- Reduz movimento ---------- */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .post:hover{transform:none}
}

/* espaçamentos utilitários */
.stack-lg{margin-top:clamp(2rem,4vw,3.2rem)}
.center{text-align:center}
.mt-cta{margin-top:clamp(2.5rem,5vw,3.5rem)}

/* ---------- HERO com imagem de fundo ---------- */
.hero--image{padding:0;background:var(--pine-900)}
.hero--image::after{content:none}
.hero--image .hero__bg{
  position:absolute;inset:0;z-index:0;
  background-image:linear-gradient(92deg, rgba(11,35,20,.92) 0%, rgba(11,35,20,.7) 50%, rgba(11,35,20,.42) 100%), url("../assets/hero.jpg");
  background-size:cover;background-position:center;
}
.hero--image .hero__inner{position:relative;z-index:1;grid-template-columns:1fr;min-height:min(80vh,660px);align-items:center;padding-block:clamp(3rem,7vw,5rem)}
.hero--image .hero__text{max-width:660px}
.hero--image .eyebrow{color:var(--honey)}
.hero--image .eyebrow::before{background:var(--honey)}
.hero--image .hero__title{color:#fff}
.hero--image .hero__title em{color:var(--honey)}
.hero--image .hero__lead{color:rgba(255,255,255,.9)}
.hero--image .hero__trust{color:rgba(255,255,255,.82)}
.hero--image .hero__trust span::before{background:var(--honey)}
@media(max-width:820px){
  .hero--image .hero__bg{background-image:linear-gradient(180deg, rgba(11,35,20,.8), rgba(11,35,20,.94)), url("../assets/hero.jpg")}
}

/* ---------- Logo (imagem) ---------- */
.brand__logo{height:56px;width:auto;display:block}
.site-footer .brand__logo{height:64px}
@media(max-width:600px){.brand__logo{height:44px}}

/* ---------- Filtro do blog ---------- */
.blog-filter{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:clamp(1.6rem,3vw,2.6rem)}
.chip-filter{font:inherit;font-size:.9rem;font-weight:600;padding:.55rem 1.2rem;border-radius:999px;border:1.5px solid var(--line);background:var(--paper);color:var(--ink-soft);cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.chip-filter:hover{border-color:var(--pine);color:var(--pine)}
.chip-filter[aria-pressed="true"]{background:var(--pine);color:#fff;border-color:var(--pine)}
.chip-filter .count{opacity:.6;font-weight:500;margin-left:.35em}
.post[hidden]{display:none}

/* ---------- Imagem de destaque do artigo ---------- */
.article__hero{display:block;width:100%;height:auto;border-radius:12px;margin:.4rem 0 2rem;border:1px solid var(--line)}
