/* =====================================================================
   HEARTSTREAM — Blog
   Layered on top of styles.css. Reuses the same tokens (Pulse magenta +
   ink neutrals for chrome; the HR-zone spectrum ONLY for zone tags).
   ===================================================================== */

/* ---- Blog index ----------------------------------------------------- */
.blog-hero {
  max-width: 62ch;
}

.blog-hero h1 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
}

.blog-hero .section-heading__lede {
  margin-top: var(--sp-4);
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-4);
}

.blog-card {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--ink-800);
  transition:
    border-color var(--dur-fast) var(--ease-out),
    transform var(--dur-fast) var(--ease-out);
}

.blog-card:hover {
  border-color: var(--fg-3);
  transform: translateY(-2px);
}

.blog-card__link {
  display: grid;
  gap: var(--sp-3);
  padding: var(--sp-5);
}

.blog-card__link h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.01em;
}

.blog-card__link p {
  margin: 0;
  color: var(--fg-2);
  line-height: 1.6;
}

.blog-card__meta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  font-size: 0.76rem;
  letter-spacing: 0.02em;
}

/* ---- Zone tags (the ONLY place the zone spectrum appears in chrome) -- */
.zone-tag {
  justify-self: start;
  padding: 4px 12px;
  border-radius: var(--r-full);
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.zone-tag--pulse { background: var(--pulse-tint); color: var(--pulse-400); }
.zone-tag--z1 { background: var(--zone-1); color: var(--on-zone-1); }
.zone-tag--z2 { background: var(--zone-2); color: var(--on-zone-2); }
.zone-tag--z3 { background: var(--zone-3); color: var(--on-zone-3); }
.zone-tag--z4 { background: var(--zone-4); color: var(--on-zone-4); }
.zone-tag--z5 { background: var(--zone-5); color: var(--on-zone-5); }

/* ---- Single post ---------------------------------------------------- */
.post {
  max-width: 760px;
  margin: 0 auto;
}

.post__head {
  display: grid;
  gap: var(--sp-3);
  padding-bottom: var(--sp-5);
  margin-bottom: var(--sp-6);
  border-bottom: 1px solid var(--line);
}

.post__head h1 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-size: clamp(2rem, 4.5vw, 3rem);
}

.post__meta {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  font-size: 0.8rem;
}

/* Long-form reading column */
.post__body {
  color: var(--fg-1);
  font-size: 1.08rem;
  line-height: 1.7;
}

.post__body h2 {
  margin: var(--sp-7) 0 var(--sp-3);
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.01em;
}

.post__body h3 {
  margin: var(--sp-5) 0 var(--sp-2);
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
}

.post__body p {
  margin: 0 0 var(--sp-4);
  color: var(--fg-2);
}

.post__body strong {
  color: var(--fg-1);
  font-weight: 600;
}

.post__body a {
  color: var(--pulse-500);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.post__body ul,
.post__body ol {
  margin: 0 0 var(--sp-4);
  padding-left: var(--sp-5);
  color: var(--fg-2);
}

.post__body li {
  margin-bottom: var(--sp-2);
  line-height: 1.65;
}

.post__body li strong {
  color: var(--fg-1);
}

.post__body blockquote {
  margin: var(--sp-5) 0;
  padding: var(--sp-2) 0 var(--sp-2) var(--sp-4);
  border-left: 3px solid var(--pulse-500);
  color: var(--fg-1);
  font-style: italic;
}

.post__body hr {
  margin: var(--sp-6) 0;
  border: none;
  border-top: 1px solid var(--line);
}

.post__body em {
  color: var(--fg-3);
}

/* footnote / disclaimer paragraph after the final <hr> */
.post__body hr + p {
  color: var(--fg-3);
  font-size: 0.92rem;
}

/* End-of-post CTA */
.post__cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-7);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--line);
}

.post__cta .eyebrow {
  flex: 1 1 100%;
  margin: 0;
}

/* ---- Responsive ----------------------------------------------------- */
@media (max-width: 840px) {
  .blog-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .post__cta .button {
    width: 100%;
  }
}
