/* ============================================================
   Blog — supplemental styles
   Loaded after /assets/styles.css on /blog/* pages
   ============================================================ */

/* -------- Editorial hero (left-aligned, wider column) -------- */
.hero--editorial .hero__copy{position:relative;z-index:3;max-width:none}
.hero--editorial h1{
  max-width:22ch;
  font-size:clamp(36px,5.4vw,68px);
  line-height:1.06;
  letter-spacing:-.02em;
}
.hero--editorial .sub{max-width:62ch}

/* Smaller hero padding than the landing one */
.hero--editorial{padding-top:clamp(120px,14vw,160px);padding-bottom:clamp(48px,6vw,72px)}

/* -------- Article meta bar -------- */
.post-meta{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:18px 0;
  background:#fff;
}
.post-meta__row{
  display:flex;align-items:center;gap:clamp(18px,3vw,36px);
  flex-wrap:wrap;
  font-size:14px;color:var(--muted);letter-spacing:.01em;
}
.post-meta__item{display:inline-flex;align-items:center;gap:8px}
.post-meta__item svg{opacity:.6;flex-shrink:0}
.post-meta__sep{width:1px;height:14px;background:var(--line);display:inline-block}
.post-meta__tags{display:inline-flex;gap:8px;flex-wrap:wrap;margin-left:auto}
.post-tag{
  display:inline-flex;align-items:center;
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal);
  padding:5px 10px;
  border:1px solid var(--teal-line, rgba(0,188,156,.35));
  border-radius:4px;line-height:1;
  background:rgba(0,188,156,.06);
}
@media (max-width:720px){
  .post-meta__tags{margin-left:0;width:100%;margin-top:6px}
}

/* -------- Article body layout: TOC + reading column -------- */
.post-body{
  padding:clamp(56px,7vw,96px) 0;
}
.post-body__inner{
  display:grid;
  grid-template-columns:240px minmax(0,1fr);
  gap:clamp(40px,5vw,80px);
  align-items:start;
}
@media (max-width:1080px){
  .post-body__inner{grid-template-columns:1fr;gap:32px}
}

/* TOC */
.post-toc{
  position:sticky;top:96px;
  font-size:14px;
}
.post-toc__lbl{
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.post-toc__lbl::after{content:"";flex:1;height:1px;background:var(--line)}
.post-toc__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.post-toc__list li{margin:0;padding:0;border:0}
.post-toc__list a{
  display:block;padding:9px 0 9px 14px;
  border-left:2px solid var(--line);
  color:var(--muted);font-size:14px;line-height:1.4;
  transition:color .15s, border-color .15s;
}
.post-toc__list a:hover{color:var(--navy);border-left-color:var(--teal-line)}
.post-toc__list a.is-active{color:var(--navy);border-left-color:var(--teal);font-weight:600}
@media (max-width:1080px){
  .post-toc{position:static;display:none}
}

/* Article reading column */
.post-content{max-width:68ch;color:var(--ink)}
.post-content > *:first-child{margin-top:0}
.post-content > *:last-child{margin-bottom:0}

.post-content .lede{
  font-size:clamp(18px,1.6vw,22px);
  line-height:1.55;color:var(--navy);font-weight:500;
  margin:0 0 32px;letter-spacing:-.005em;
}

.post-content h2{
  font-size:clamp(24px,2.4vw,32px);
  font-weight:600;letter-spacing:-.015em;line-height:1.18;
  color:var(--navy);
  margin:48px 0 18px;
  scroll-margin-top:96px;
}
.post-content h2:first-child{margin-top:0}
.post-content h3{
  font-size:clamp(18px,1.6vw,21px);
  font-weight:600;letter-spacing:-.005em;line-height:1.3;
  color:var(--navy);margin:32px 0 10px;
}
.post-content p{
  font-size:17px;line-height:1.7;
  margin:0 0 18px;color:#2a334d;
}
.post-content strong{color:var(--navy);font-weight:600}
.post-content a{color:var(--teal);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.post-content a:hover{text-decoration-thickness:2px}

.post-content ul,.post-content ol{
  margin:0 0 22px;padding-left:22px;
  font-size:17px;line-height:1.7;color:#2a334d;
}
.post-content li{margin:0 0 8px}
.post-content li::marker{color:var(--teal)}

.post-content blockquote{
  margin:32px 0;
  padding:24px 28px;
  border-left:3px solid var(--teal);
  background:var(--bg, #f6f7fb);
  border-radius:0 8px 8px 0;
  font-size:clamp(17px,1.5vw,19px);
  font-weight:500;line-height:1.55;color:var(--navy);
  letter-spacing:-.005em;font-style:normal;
}
.post-content blockquote p:last-child{margin-bottom:0}
.post-content blockquote cite{
  display:block;margin-top:14px;
  font-size:14px;color:var(--muted);font-weight:500;font-style:normal;
  letter-spacing:.01em;
}
.post-content blockquote cite strong{color:var(--navy);font-weight:600}

/* Callout boxes */
.post-callout{
  margin:32px 0;
  padding:22px 24px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  display:flex;gap:16px;align-items:flex-start;
}
.post-callout__icon{
  flex-shrink:0;width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,188,156,.10);color:var(--teal);
  border-radius:6px;
}
.post-callout__body{font-size:15.5px;line-height:1.55;color:#2a334d}
.post-callout__body strong{color:var(--navy)}
.post-callout__body :last-child{margin-bottom:0}

/* Stats row inside an article */
.post-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin:36px 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.post-stats__item{
  padding:22px 24px;
  border-right:1px solid var(--line);
}
.post-stats__item:last-child{border-right:0}
.post-stats__num{
  font-size:clamp(24px,2.6vw,32px);font-weight:600;color:var(--teal);
  letter-spacing:-.01em;line-height:1;margin-bottom:8px;
}
.post-stats__lbl{font-size:14px;color:var(--muted);line-height:1.4}
@media (max-width:720px){
  .post-stats{grid-template-columns:1fr}
  .post-stats__item{border-right:0;border-bottom:1px solid var(--line)}
  .post-stats__item:last-child{border-bottom:0}
}

/* Tags chip list (inline) */
.post-content .post-chips{
  display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 22px;
}
.post-content .post-chips .post-chip{
  display:inline-flex;align-items:center;
  font-size:13px;font-weight:500;
  color:var(--navy);background:var(--bg);
  border:1px solid var(--line);
  padding:7px 12px;border-radius:6px;letter-spacing:.01em;
}

/* ============================================================
   Blog INDEX page
   ============================================================ */

.blog-section{padding:clamp(56px,7vw,96px) 0}
.blog-section--tight{padding:clamp(32px,4vw,56px) 0}
.blog-section + .blog-section:not([style*="background"]){padding-top:0}

.blog-section__head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
  margin:0 0 clamp(28px,3vw,40px);
  padding-bottom:clamp(18px,2vw,24px);
  border-bottom:1px solid var(--line);
}
.blog-section__head h2{
  font-size:clamp(22px,2.4vw,30px);
  font-weight:600;letter-spacing:-.015em;color:var(--navy);
  margin:0;
}
.blog-section__head p{
  margin:6px 0 0;font-size:15px;color:var(--muted);max-width:60ch;
}
.blog-section__lbl{
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);margin-bottom:10px;display:block;
}

/* -------- Featured post (large card) -------- */
.blog-featured{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:0;
  border:1px solid var(--line);
  border-radius:10px;overflow:hidden;
  background:#fff;
  transition:border-color .2s, box-shadow .2s;
}
.blog-featured:hover{
  border-color:var(--teal-line, rgba(0,188,156,.35));
  box-shadow:0 12px 40px -12px rgba(1,24,72,.18);
}
.blog-featured__media{
  position:relative;min-height:380px;
  background:var(--navy) center/cover no-repeat;
  overflow:hidden;
}
.blog-featured__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(1,24,72,.55) 0%, rgba(1,24,72,.15) 60%, rgba(1,24,72,0) 100%);
}
.blog-featured__badge{
  position:absolute;top:18px;left:18px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--navy);background:rgba(255,255,255,.95);
  padding:7px 12px;border-radius:4px;line-height:1;
}
.blog-featured__badge::before{content:"";width:6px;height:6px;background:var(--teal);border-radius:50%}
.blog-featured__body{
  padding:clamp(32px,3.5vw,48px);
  display:flex;flex-direction:column;justify-content:center;gap:14px;
}
.blog-featured__meta{
  display:flex;gap:14px;font-size:13px;color:var(--muted);align-items:center;flex-wrap:wrap;
}
.blog-featured__meta .post-meta__sep{height:12px}
.blog-featured__title{
  font-size:clamp(24px,2.6vw,34px);font-weight:600;
  letter-spacing:-.015em;line-height:1.18;color:var(--navy);
  margin:0;
}
.blog-featured__title a{color:inherit;text-decoration:none}
.blog-featured__title a:hover{color:var(--teal)}
.blog-featured__excerpt{
  font-size:16px;line-height:1.55;color:#2a334d;
  margin:0;max-width:54ch;
}
.blog-featured__cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;letter-spacing:.05em;
  color:var(--teal);margin-top:8px;
}
.blog-featured__cta svg{transition:transform .2s ease}
.blog-featured__cta:hover svg{transform:translateX(4px)}
.blog-featured__tags{display:flex;gap:8px;flex-wrap:wrap}

@media (max-width:880px){
  .blog-featured{grid-template-columns:1fr}
  .blog-featured__media{min-height:240px}
}

/* -------- Lead magnets -------- */
.lead-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:980px){.lead-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.lead-grid{grid-template-columns:1fr}}

/* Count variants — all span the full content width. 3-up and 2-up are equal
   columns (media keeps its 16:9 ratio, no distortion). A single resource
   becomes a full-width horizontal "feature" card so it never looks sparse. */
.lead-grid.lead-grid--3{grid-template-columns:repeat(3,1fr)}
.lead-grid.lead-grid--2{grid-template-columns:repeat(2,1fr)}
.lead-grid.lead-grid--1{grid-template-columns:1fr}

/* Single card → horizontal feature layout, full width */
.lead-grid--1 .lead-card{flex-direction:row;align-items:stretch}
.lead-grid--1 .lead-card__media{
  flex:0 0 56%;
  aspect-ratio:auto;          /* fill the card height instead of 16:9 */
  min-height:340px;
  border-bottom:0;
  border-right:1px solid var(--line);
}
.lead-grid--1 .lead-card__body{
  flex:1;justify-content:center;
  padding:clamp(28px,3.2vw,48px);
  gap:12px;
}
.lead-grid--1 .lead-card__title{font-size:clamp(20px,2vw,26px)}
.lead-grid--1 .lead-card__excerpt{font-size:15.5px;max-width:54ch}

@media (max-width:980px){
  .lead-grid.lead-grid--3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  /* stack the feature card and restore a normal 16:9 media on top */
  .lead-grid--1 .lead-card{flex-direction:column}
  .lead-grid--1 .lead-card__media{
    flex:auto;aspect-ratio:16/9;min-height:0;
    border-right:0;border-bottom:1px solid var(--line);
  }
}
@media (max-width:640px){
  .lead-grid.lead-grid--3,.lead-grid.lead-grid--2{grid-template-columns:1fr}
}

.lead-card{
  display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  background:#fff;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.lead-card:hover{
  border-color:var(--teal-line, rgba(0,188,156,.35));
  box-shadow:0 12px 32px -14px rgba(1,24,72,.2);
  transform:translateY(-2px);
}
.lead-card__media{
  position:relative;
  aspect-ratio:16/9;
  background:var(--navy) center/cover no-repeat;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.lead-card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(1,24,72,0) 30%, rgba(1,24,72,.55) 100%);
}
/* Product shot (e.g. report covers on transparent bg): show the whole image,
   never crop — contain on a branded navy field, no darkening overlay. */
.lead-card__media--shot{
  background-color:#e8ecf2;
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.lead-card__media--shot::after{display:none}
.lead-grid--1 .lead-card__media--shot{background-size:contain}
.lead-card__kind{
  position:absolute;top:14px;left:14px;z-index:2;
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;background:rgba(0,188,156,.92);
  padding:5px 10px;border-radius:4px;line-height:1;
}
.lead-card__file{
  position:absolute;bottom:12px;right:12px;z-index:2;
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;background:rgba(1,24,72,.7);backdrop-filter:blur(4px);
  padding:5px 10px;border-radius:4px;line-height:1;
}
.lead-card__body{
  padding:22px 22px 24px;
  display:flex;flex-direction:column;flex:1;gap:8px;
}
.lead-card__title{
  font-size:18px;font-weight:600;letter-spacing:-.005em;line-height:1.3;
  color:var(--navy);margin:0;
}
.lead-card__excerpt{
  font-size:14.5px;line-height:1.5;color:var(--muted);
  margin:0;flex:1;
}
.lead-card__cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;
  font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--teal);
}
.lead-card__cta svg{transition:transform .2s ease}
.lead-card:hover .lead-card__cta svg{transform:translateY(2px)}

/* -------- Article cards grid (latest articles) -------- */
.blog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px 24px;
}
@media (max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.blog-grid{grid-template-columns:1fr}}

.blog-card{
  display:flex;flex-direction:column;
  background:#fff;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.blog-card:hover{
  border-color:var(--teal-line, rgba(0,188,156,.35));
  box-shadow:0 10px 28px -14px rgba(1,24,72,.18);
  transform:translateY(-2px);
}
.blog-card__media{
  position:relative;
  aspect-ratio:16/10;
  background:var(--navy) center/cover no-repeat;
  border-bottom:1px solid var(--line);
}
.blog-card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(1,24,72,.05) 0%, rgba(1,24,72,.45) 100%);
}
.blog-card__cat{
  position:absolute;top:14px;left:14px;z-index:2;
  display:inline-flex;align-items:center;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--navy);background:rgba(255,255,255,.95);
  padding:5px 10px;border-radius:4px;line-height:1;
}
.blog-card__body{
  padding:22px 22px 24px;
  display:flex;flex-direction:column;flex:1;gap:10px;
}
.blog-card__meta{
  font-size:12.5px;color:var(--muted);letter-spacing:.02em;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
}
.blog-card__meta .post-meta__sep{height:11px}
.blog-card__title{
  font-size:18px;font-weight:600;letter-spacing:-.005em;line-height:1.32;
  color:var(--navy);margin:0;
}
.blog-card__title a{color:inherit;text-decoration:none}
.blog-card__title a:hover{color:var(--teal)}
.blog-card__excerpt{
  font-size:14.5px;line-height:1.55;color:var(--muted);
  margin:0;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.blog-card__foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:6px;
}
.blog-card__cta{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--teal);
}
.blog-card__cta svg{transition:transform .2s ease}
.blog-card:hover .blog-card__cta svg{transform:translateX(3px)}
.blog-card__time{font-size:12.5px;color:var(--muted)}

/* -------- Topic pills (filter row) -------- */
.blog-topics{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-bottom:clamp(28px,3vw,40px);
}
.blog-topic{
  font-size:13px;font-weight:500;
  padding:8px 14px;border-radius:6px;
  border:1px solid var(--line);background:#fff;color:var(--navy);
  letter-spacing:.01em;cursor:pointer;
  transition:border-color .15s, color .15s, background .15s;
}
.blog-topic:hover{border-color:var(--teal-line, rgba(0,188,156,.35));color:var(--teal)}
.blog-topic.is-active{
  background:var(--navy);color:#fff;border-color:var(--navy);
}

/* Pagination */
.blog-pager{
  display:flex;justify-content:center;gap:6px;
  margin-top:clamp(40px,5vw,56px);
}
.blog-pager a, .blog-pager span{
  min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:6px;
  font-size:14px;font-weight:500;color:var(--navy);background:#fff;
  text-decoration:none;letter-spacing:.02em;padding:0 10px;
}
.blog-pager a:hover{border-color:var(--teal-line);color:var(--teal)}
.blog-pager .is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.blog-pager .is-disabled{opacity:.4;pointer-events:none}

/* Article footer (back to blog + share) */
.post-footer{
  border-top:1px solid var(--line);
  margin-top:clamp(40px,5vw,64px);padding-top:clamp(28px,3vw,40px);
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.post-footer__back{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;letter-spacing:.04em;
  color:var(--teal);
}
.post-footer__back svg{transition:transform .2s ease}
.post-footer__back:hover svg{transform:translateX(-3px)}

.post-share{
  display:flex;align-items:center;gap:12px;
  font-size:13px;color:var(--muted);
}
.post-share__lbl{letter-spacing:.04em}
.post-share__btns{display:flex;gap:6px}
.post-share__btn{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:6px;
  color:var(--muted);transition:border-color .15s, color .15s, background .15s;
  background:#fff;
}
.post-share__btn:hover{border-color:var(--teal-line);color:var(--teal);background:rgba(0,188,156,.04)}
.post-share__btn svg{width:14px;height:14px}
