/* Praxis rich blocks + section rhythm for blog article bodies. Cowork 1 Jul 2026. */

/* ---- Section rhythm: give each H2 a marked start and generous vertical space ---- */
.praxis .article-content h2{
  position:relative;
  margin-top:78px;
  margin-bottom:22px;
  padding-top:30px;
  font-family:'Newsreader',Georgia,serif;
  font-weight:500;
  font-size:clamp(28px,3vw,38px);
  line-height:1.15;
  letter-spacing:-0.015em;
  color:#1A1714;
}
.praxis .article-content h2::before{
  content:"";position:absolute;top:0;left:0;width:34px;height:2px;background:#C75B22;
}
.praxis .article-content h2 em{font-style:italic;color:#C75B22;}
.praxis .article-content h3{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:24px;line-height:1.2;color:#1A1714;margin-top:44px;margin-bottom:12px;}
.praxis .article-content > p{font-size:18.5px;line-height:1.75;color:#4A453E;margin:0 0 22px;}
.praxis .article-content .drop-intro{font-family:'Newsreader',Georgia,serif;font-style:italic;font-size:23px;line-height:1.4;color:#1A1714;}
.praxis .article-content ul,.praxis .article-content ol{margin:6px 0 26px;padding-left:2px;}
.praxis .article-content ul li,.praxis .article-content ol li{font-size:18px;line-height:1.7;color:#4A453E;margin-bottom:12px;}

/* ---- GEO box "In short" (citable Q&A) ---- */
.article-content .geo{background:#FBF9F3;border-left:3px solid #C75B22;border-radius:12px;padding:30px 34px;margin:44px 0;}
.article-content .geo .g-label{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#1C7A57;display:block;margin-bottom:12px;}
.article-content .geo .g-q{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:25px;line-height:1.25;color:#1A1714;margin:0 0 14px;}
.article-content .geo .g-a{font-size:16.5px;line-height:1.68;color:#4A453E;margin:0;}

/* ---- Pull-quote callout ---- */
.article-content .pcallout{border-top:1px solid #DCD3C2;border-bottom:1px solid #DCD3C2;padding:28px 0;margin:48px 0;font-family:'Newsreader',Georgia,serif;font-size:26px;line-height:1.32;color:#1A1714;font-style:italic;}
.article-content .pcallout em{color:#C75B22;font-style:italic;}

/* ---- Diagram figure (dark, full-column) ---- */
.article-content .routefig{background:#211D17;border-radius:14px;padding:34px 34px 24px;margin:52px 0;}
.article-content .routefig svg{width:100%;height:auto;display:block;}
.article-content .routefig .rf-cap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:#9A8E7E;margin-top:16px;letter-spacing:.04em;}

/* ---- Stat band (destaque de numeros) ---- */
.article-content .statband{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:48px 0;padding:30px 0;border-top:1px solid #DCD3C2;border-bottom:1px solid #DCD3C2;}
.article-content .statband .st .n{font-family:'Newsreader',Georgia,serif;font-weight:500;font-size:42px;line-height:1;color:#C75B22;}
.article-content .statband .st .l{font-size:14.5px;line-height:1.4;color:#4A453E;margin-top:8px;}
@media(max-width:720px){.article-content .statband{grid-template-columns:1fr;gap:18px;}.article-content .geo .g-q,.article-content .pcallout{font-size:21px;}}

/* ---- Section width: match the home 1240px rail; readable text column + full-width rich blocks ---- */
.praxis .article-body{ max-width:1240px !important; padding-left:40px; padding-right:40px; }
.praxis .article-content{ max-width:none; }
.praxis .article-content > p,
.praxis .article-content > h2,
.praxis .article-content > h3,
.praxis .article-content > ul,
.praxis .article-content > ol,
.praxis .article-content > blockquote{
  max-width:760px; margin-left:0; margin-right:auto;
}
.praxis .article-content > .geo,
.praxis .article-content > .statband,
.praxis .article-content > .routefig,
.praxis .article-content > .pcallout,
.praxis .article-content > .cta-inline,
.praxis .article-content > figure,
.praxis .article-content > .author-card{
  max-width:1160px; margin-left:0; margin-right:auto;
}
@media(max-width:1000px){ .praxis .article-body{ padding-left:22px; padding-right:22px; } .praxis .article-content > p,.praxis .article-content > h2,.praxis .article-content > h3,.praxis .article-content > ul,.praxis .article-content > ol{ max-width:none; } }

/* Hero: match home 1240px rail so it aligns with the article body */
.praxis .article-hero .container{ max-width:1240px !important; padding-left:40px !important; padding-right:40px !important; }
.praxis .article-hero .container > *{ max-width:900px; }
