/* ============================================================
   JGS Group — Blog Stylesheet
   Shared by /blog/ (listing) and /blog/<slug>/ (article).
   Builds on tokens defined in global.css.
   ============================================================ */

/* ── Listing: hero ──────────────────────────────────────────── */
.blog-hero {
  padding: 150px var(--pad-x) var(--sp-12);
  text-align: center;
  max-width: 760px;
  margin-inline: auto;
}
.blog-hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(38px, 6vw, 66px);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--navy);
  margin: 0 0 var(--sp-5);
}
.blog-hero__sub {
  font-size: 16px;
  line-height: 1.6;
  color: var(--muted);
  text-wrap: pretty;
  margin: 0;
}

/* ── Listing: post grid ─────────────────────────────────────── */
.post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--sp-6);
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x) var(--sp-24);
}
.post-card {
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform var(--t-mid) var(--ease), box-shadow var(--t-mid);
}
.post-card--live:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 50px -22px rgba(27,42,100,.35);
}
.post-card--soon { opacity: .62; }
.post-card__media {
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 100%);
  position: relative;
  overflow: hidden;
}
.post-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.post-card__tag {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: rgba(255,255,255,.92);
  color: var(--navy);
  padding: 5px 10px;
  border-radius: var(--r-pill);
}
.post-card__body { padding: var(--sp-6); display: flex; flex-direction: column; flex: 1; }
.post-card__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}
.post-card__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 21px;
  line-height: 1.25;
  letter-spacing: -.01em;
  color: var(--navy);
  margin: 0 0 var(--sp-3);
}
.post-card__excerpt {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--muted);
  margin: 0 0 var(--sp-5);
  flex: 1;
}
.post-card__more {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .06em;
  color: var(--orange);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.post-card--soon .post-card__more { color: var(--muted); }

/* ── Article: layout ────────────────────────────────────────── */
.article {
  max-width: 740px;
  margin: 0 auto;
  padding: 130px var(--pad-x) var(--sp-16);
}
.breadcrumb {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--muted);
  margin-bottom: var(--sp-6);
  text-transform: uppercase;
}
.breadcrumb a { color: var(--muted); }
.breadcrumb a:hover { color: var(--orange); }
.breadcrumb span { margin: 0 6px; opacity: .5; }

.article__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: var(--sp-4);
}
.article__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(30px, 5vw, 50px);
  line-height: 1.08;
  letter-spacing: -.02em;
  color: var(--navy);
  margin: 0 0 var(--sp-5);
}
.article__meta {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  padding-bottom: var(--sp-6);
  margin-bottom: var(--sp-8);
  border-bottom: 1px solid var(--line);
}
.article__hero {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: var(--r-lg);
  margin: 0 0 var(--sp-8);
  display: block;
}
.article__lead {
  font-size: 19px;
  line-height: 1.6;
  color: var(--ink);
  font-weight: 400;
  margin: 0 0 var(--sp-8);
}

/* ── Article: prose typography ──────────────────────────────── */
.prose h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(24px, 3.5vw, 32px);
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--navy);
  margin: var(--sp-12) 0 var(--sp-4);
}
.prose h3 {
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  margin: var(--sp-8) 0 var(--sp-3);
}
.prose p,
.prose li {
  font-size: 16.5px;
  line-height: 1.75;
  color: #28304f;
}
.prose p { margin: 0 0 var(--sp-5); }
.prose ul, .prose ol { padding-left: 22px; margin: 0 0 var(--sp-5); }
.prose li { margin-bottom: var(--sp-2); }
.prose a {
  color: var(--orange);
  text-decoration: none;
  border-bottom: 1px solid rgba(219,127,46,.4);
}
.prose a:hover { border-bottom-color: var(--orange); }
.prose strong { color: var(--navy); font-weight: 600; }

/* Callout — used for accuracy / proof notes */
.callout {
  background: rgba(27,42,100,.05);
  border-left: 3px solid var(--orange);
  border-radius: var(--r-sm);
  padding: var(--sp-5) var(--sp-6);
  margin: var(--sp-8) 0;
}
.callout p { margin: 0; font-size: 15.5px; color: #28304f; }
.callout strong { color: var(--navy); }

/* In-article CTA box */
.cta-box {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-2) 100%);
  color: #fff;
  border-radius: var(--r-lg);
  padding: var(--sp-10) var(--sp-8);
  margin: var(--sp-12) 0 var(--sp-8);
  text-align: center;
}
.cta-box h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(22px, 4vw, 30px);
  color: #fff;
  margin: 0 0 var(--sp-3);
}
.cta-box p { color: rgba(255,255,255,.82); font-size: 15.5px; line-height: 1.6; margin: 0 0 var(--sp-6); }
.cta-box__row { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }

/* Buttons live inside .prose, so override .prose a coloring */
.prose .btn { border-bottom: 0; }
.prose .btn--orange,
.prose .btn--primary,
.prose .btn--outline-white { color: #fff; }
.prose .btn--ghost { color: var(--ink); }

/* Related articles */
.related { max-width: 740px; margin: 0 auto; padding: 0 var(--pad-x) var(--sp-20); }
.related__head {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--sp-5);
}
.related__list { display: grid; gap: var(--sp-3); }
.related__item {
  display: block;
  padding: var(--sp-5) var(--sp-6);
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--navy);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 17px;
  transition: border-color var(--t-mid), transform var(--t-mid) var(--ease);
}
.related__item:hover { border-color: var(--orange); transform: translateX(4px); }

@media (max-width: 600px) {
  .blog-hero { padding-top: 120px; }
  .article { padding-top: 110px; }
}
