/* ============================================================
   page-blog-post.css
   Individual blog post pages — /blogs/[slug]
   ============================================================ */

/* ============================================================
   Post layout shell
   ============================================================ */

.blog-post {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--ac-page-pad);
}

/* Wide container — hero image + section dividers span wider */
.blog-post-wide {
  max-width: var(--ac-max-width);
  margin: 0 auto;
  padding: 0 var(--ac-page-pad);
}

/* ============================================================
   Post header
   ============================================================ */

.blog-post-header {
  margin-top: var(--ac-sp-7);
  margin-bottom: var(--ac-sp-7);
}

.blog-post-eyebrow {
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
  margin-bottom: var(--ac-sp-4);
}

.blog-post-title {
  font-size: var(--ac-text-h1);
  font-weight: 300;
  line-height: var(--ac-lh-h1);
  letter-spacing: var(--ac-ls-h1);
  color: var(--ac-ink);
  margin-bottom: var(--ac-sp-5);
}

.blog-post-meta {
  display: flex;
  align-items: center;
  gap: var(--ac-sp-3);
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  color: var(--ac-muted);
  flex-wrap: wrap;
}

.blog-post-meta__sep {
  color: var(--ac-hair);
  user-select: none;
}

/* ============================================================
   Hero image
   ============================================================ */

.blog-post-hero {
  margin-bottom: var(--ac-sp-8);
  border: 1px solid var(--ac-hair);
  background-color: var(--ac-paper);
}

.blog-post-hero img {
  width: 100%;
  height: auto;
  display: block;
}

/* ============================================================
   Audio narration player
   ============================================================ */

.blog-post-audio {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ac-sp-3);
  padding: var(--ac-sp-5) 0 var(--ac-sp-6);
  border-bottom: 1px solid var(--ac-hair);
  margin-bottom: var(--ac-sp-6);
}

.blog-post-audio__label {
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
}

.blog-post-audio__player {
  width: 100%;
  accent-color: var(--ac-accent);
}

/* ============================================================
   Post body — prose
   ============================================================ */

.blog-post-body {
  display: flex;
  flex-direction: column;
  gap: var(--ac-sp-5);
}

.blog-post-body p {
  font-size: var(--ac-text-body);
  line-height: var(--ac-lh-body);
  color: var(--ac-muted);
  margin: 0;
}

.blog-post-body h2 {
  font-size: var(--ac-text-h2);
  font-weight: 400;
  line-height: var(--ac-lh-h2);
  letter-spacing: var(--ac-ls-h2);
  color: var(--ac-ink);
  margin-top: var(--ac-sp-4);
  margin-bottom: 0;
}

.blog-post-body h3 {
  font-size: var(--ac-text-h3);
  font-weight: 400;
  line-height: var(--ac-lh-h3);
  letter-spacing: var(--ac-ls-h3);
  color: var(--ac-ink);
  margin-top: var(--ac-sp-3);
  margin-bottom: 0;
}

.blog-post-body h4 {
  font-size: var(--ac-text-body);
  font-weight: 600;
  color: var(--ac-ink);
  margin-top: var(--ac-sp-3);
  margin-bottom: 0;
}

/* Prose lists — exclude CTA perks which have their own style */
.blog-post-body ul:not(.blog-post-cta__perks),
.blog-post-body ol {
  padding-left: var(--ac-sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--ac-sp-3);
}

.blog-post-body li {
  font-size: var(--ac-text-body);
  line-height: var(--ac-lh-body);
  color: var(--ac-muted);
}

.blog-post-body ol {
  list-style: decimal;
}

.blog-post-body ul:not(.blog-post-cta__perks) {
  list-style: disc;
}

.blog-post-body strong {
  font-weight: 600;
  color: var(--ac-ink);
}

/* Prose links — exclude buttons so button design system styles are not overridden */
.blog-post-body a:not(.ac-btn) {
  color: var(--ac-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 180ms var(--ac-ease);
}

.blog-post-body a:not(.ac-btn):hover {
  color: var(--ac-accent);
}

/* Inline image (within body) */
.blog-post-body img {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid var(--ac-hair);
}

/* Section divider */
.blog-post-body hr {
  border: none;
  border-top: 1px solid var(--ac-hair);
  margin: var(--ac-sp-3) 0;
}

/* ============================================================
   Pull quote / blockquote
   ============================================================ */

.blog-post-body blockquote {
  border-left: 3px solid var(--ac-accent);
  margin: var(--ac-sp-3) 0;
  padding: var(--ac-sp-4) var(--ac-sp-6);
  background-color: var(--ac-paper);
}

.blog-post-body blockquote p {
  font-size: var(--ac-text-body-lg);
  font-style: italic;
  color: var(--ac-ink);
  line-height: var(--ac-lh-body);
}

.blog-post-body blockquote footer {
  margin-top: var(--ac-sp-3);
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
  font-style: normal;
}

/* ============================================================
   CTA block — Unlock All 15
   ============================================================ */

.blog-post-cta {
  border: 1px solid var(--ac-hair);
  background-color: var(--ac-paper);
  padding: var(--ac-sp-7) var(--ac-sp-7);
  display: flex;
  flex-direction: column;
  gap: var(--ac-sp-5);
  margin-top: var(--ac-sp-4);
}

.blog-post-cta__eyebrow {
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
}

.blog-post-cta__headline {
  font-size: var(--ac-text-h3);
  font-weight: 400;
  color: var(--ac-ink);
  line-height: var(--ac-lh-h3);
  letter-spacing: var(--ac-ls-h3);
  margin: 0;
}

.blog-post-cta__perks {
  display: flex;
  flex-direction: column;
  gap: var(--ac-sp-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.blog-post-cta__perks li {
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
}

.blog-post-cta__perks li::before {
  content: "· ";
  color: var(--ac-muted);
}

.blog-post-cta__action {
  display: flex;
  align-items: center;
  gap: var(--ac-sp-4);
  flex-wrap: wrap;
}

/* ============================================================
   Post footer
   ============================================================ */

.blog-post-footer {
  border-top: 1px solid var(--ac-hair);
  margin-top: var(--ac-sp-8);
  padding-top: var(--ac-sp-6);
  padding-bottom: var(--ac-sp-9);
}

.blog-post-footer__back {
  font-family: var(--ac-font-mono);
  font-size: var(--ac-text-label);
  font-weight: 500;
  letter-spacing: var(--ac-ls-label);
  text-transform: uppercase;
  color: var(--ac-muted);
  text-decoration: none;
  transition: color 180ms var(--ac-ease);
}

.blog-post-footer__back:hover {
  color: var(--ac-ink);
}

/* ============================================================
   Responsive
   ============================================================ */

@media (max-width: 768px) {
  .blog-post-title {
    font-size: var(--ac-text-h2);
  }

  .blog-post-cta {
    padding: var(--ac-sp-6) var(--ac-sp-5);
  }
}

@media (max-width: 480px) {
  .blog-post-cta {
    padding: var(--ac-sp-5) var(--ac-sp-4);
  }
}
