/* ==========================================================================
   Standalone blog post page — /blog/<slug>.html
   Reuses resources.css for hero (.post-hero) and body copy (.pm-content)
   classes so visuals stay in lock-step with the modal viewer.
   ========================================================================== */

.bp-wrap {
  background: var(--parchment);
  color: var(--on-parch);
  min-height: 100vh;
}

/* Thin bar at top of article body, mirroring the modal's .pm-modal__bar */
.bp-bar {
  max-width: 860px;
  margin: 0 auto;
  padding: 40px 56px 0;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--muted-parch);
}
.bp-bar a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(8,15,28,0.2);
  padding-bottom: 2px;
  transition: color 0.15s, border-color 0.15s;
}
.bp-bar a:hover {
  color: var(--void);
  border-bottom-color: var(--void);
}

.bp-article {
  max-width: 860px;
  margin: 0 auto;
  padding: 48px 56px 96px;
}

/* Category chip */
.bp-cat {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 18px;
}

.bp-title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(32px, 4vw, 48px); line-height: 1.12;
  letter-spacing: -0.018em;
  color: var(--on-parch);
  margin: 0 0 18px;
  text-wrap: balance;
}

.bp-sub {
  font-size: 19px; line-height: 1.5;
  color: rgba(8, 15, 28, 0.72);
  margin: 0 0 28px;
  max-width: 680px;
}

.bp-meta {
  display: flex; flex-wrap: wrap; gap: 16px 24px;
  padding: 16px 0;
  border-top: 1px solid var(--parchment-300);
  border-bottom: 1px solid var(--parchment-300);
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--muted-parch);
  margin-bottom: 40px;
}
.bp-meta strong {
  color: var(--on-parch);
  font-weight: 500;
}

/* Cross-sell / related strip at the bottom */
.bp-footer-strip {
  max-width: 860px;
  margin: 0 auto;
  padding: 56px 56px 96px;
  border-top: 1px solid var(--parchment-300);
}
.bp-footer-strip__label {
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--muted-parch);
  margin-bottom: 24px;
}
.bp-footer-strip__title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: 28px; line-height: 1.2;
  color: var(--on-parch);
  margin: 0 0 28px;
  letter-spacing: -0.01em;
}
.bp-footer-strip__cta {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--arc-teal-text);
  text-decoration: none;
  border-bottom: 1px solid var(--arc-teal-text);
  padding-bottom: 4px;
  transition: gap 0.15s;
}
.bp-footer-strip__cta:hover { gap: 16px; }
.bp-footer-strip__cta svg { flex-shrink: 0; }

/* Responsive */
@media (max-width: 720px) {
  .bp-bar { padding: 32px 24px 0; }
  .bp-article { padding: 32px 24px 72px; }
  .bp-footer-strip { padding: 48px 24px 72px; }
  .bp-meta { gap: 10px 18px; font-size: 10.5px; }
}
