/* ============================================
   ELEVATED THOUGHTS — Blog Post
   ============================================ */

.page-header {
  padding-top: calc(var(--nav-height) + var(--space-20));
  padding-bottom: var(--space-16);
  position: relative;
  overflow: hidden;
}

.page-header::before {
  content: '';
  position: absolute;
  top: -40%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 120%;
  background: radial-gradient(
    ellipse 50% 60% at 50% 20%,
    var(--accent-glow) 0%,
    rgba(217, 123, 0, 0.05) 40%,
    transparent 70%
  );
  opacity: 0.4;
  pointer-events: none;
}

.page-header h1 {
  font-size: var(--text-hero);
  line-height: 1.1;
  padding-bottom: 0.1em;
  letter-spacing: -0.03em;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.95) 0%,
    rgba(255, 255, 255, 0.65) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  max-width: 20ch;
  margin-inline: auto;
}

@media (max-width: 640px) {
  .page-header h1 {
    font-size: var(--text-3xl);
  }
}

.blog-post__meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
}

/* ===================
   HERO IMAGE
   =================== */

.blog-post__hero-image {
  padding-bottom: var(--space-8);
}

.blog-post__hero-img {
  width: 100%;
  max-width: 680px;
  margin-inline: auto;
  display: block;
  border-radius: var(--radius-lg);
  aspect-ratio: 1200 / 630;
  object-fit: cover;
}

/* ===================
   ARTICLE BODY
   =================== */

.blog-post__body {
  max-width: 680px;
  margin-inline: auto;
  font-size: var(--text-lg);
  line-height: 1.8;
  color: var(--text-secondary);
}

.blog-post__body p {
  margin-bottom: var(--space-6);
}

.blog-post__body h2 {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  margin-top: var(--space-12);
  margin-bottom: var(--space-4);
  letter-spacing: -0.02em;
}

.blog-post__body h3 {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
  margin-top: var(--space-10);
  margin-bottom: var(--space-3);
}

.blog-post__body strong {
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
}

.blog-post__body em {
  font-style: italic;
}

.blog-post__body a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--duration-fast) var(--ease-smooth);
}

.blog-post__body a:hover {
  color: var(--accent-hover);
}

.blog-post__body blockquote {
  border-left: 3px solid var(--accent);
  padding-left: var(--space-6);
  margin: var(--space-8) 0;
  color: var(--text-muted);
  font-style: italic;
}

.blog-post__body ul,
.blog-post__body ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-6);
}

.blog-post__body li {
  margin-bottom: var(--space-2);
}

.blog-post__body hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--space-10) 0;
}

.blog-post__body img {
  width: 100%;
  border-radius: var(--radius-lg);
  margin: var(--space-8) 0;
}

/* First paragraph — slightly larger */
.blog-post__body > p:first-child {
  font-size: var(--text-xl);
  color: var(--text-primary);
  line-height: 1.7;
}

/* ===================
   POST FOOTER
   =================== */

.blog-post__footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-8);
  max-width: 680px;
  margin-inline: auto;
  padding-bottom: var(--space-10);
}

@media (max-width: 640px) {
  .blog-post__footer {
    flex-direction: column;
    gap: var(--space-6);
  }
}

.blog-post__author-block {
  flex: 1;
}

.blog-post__author-name {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
  margin-top: var(--space-1);
}

.blog-post__author-bio {
  font-size: var(--text-sm);
  line-height: 1.6;
  margin-top: var(--space-2);
  max-width: 380px;
}

.blog-post__share {
  flex-shrink: 0;
}

.blog-post__share-links {
  display: flex;
  gap: var(--space-2);
}

.blog-post__share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  color: var(--text-muted);
  background: transparent;
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-smooth),
              border-color var(--duration-fast) var(--ease-smooth);
}

.blog-post__share-btn:hover {
  color: var(--accent);
  border-color: var(--accent);
}

/* ===================
   LISTEN CTA
   =================== */

.blog-post__cta {
  max-width: 680px;
  margin-inline: auto;
  padding: var(--space-10) 0;
}

.blog-post__cta h3 {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  letter-spacing: -0.02em;
}

.blog-post__cta-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* ===================
   BACK LINK
   =================== */

.blog-post__back {
  transition: color var(--duration-fast) var(--ease-smooth);
}

.blog-post__back:hover {
  color: var(--text-primary);
}

/* ===================
   MOBILE READING EXPERIENCE
   =================== */

/* Optimize for comfortable phone reading */
@media (max-width: 479px) {
  /* Reduce page header padding on mobile */
  .page-header {
    padding-top: calc(var(--nav-height) + var(--space-12));
    padding-bottom: var(--space-10);
  }

  .page-header h1 {
    font-size: var(--text-2xl);
    max-width: 100%;
    line-height: 1.2;
  }

  /* Blog post body - optimized line length and size for phone */
  .blog-post__body {
    font-size: var(--text-base);
    line-height: 1.75;
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }

  .blog-post__body > p:first-child {
    font-size: var(--text-lg);
    line-height: 1.7;
  }

  /* Tighter heading margins on mobile */
  .blog-post__body h2 {
    font-size: var(--text-xl);
    margin-top: var(--space-8);
    margin-bottom: var(--space-3);
  }

  .blog-post__body h3 {
    font-size: var(--text-lg);
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
  }

  /* Blockquote - reduce indent for mobile */
  .blog-post__body blockquote {
    padding-left: var(--space-4);
    margin: var(--space-6) 0;
    font-size: var(--text-base);
  }

  /* Lists - tighter for mobile */
  .blog-post__body ul,
  .blog-post__body ol {
    padding-left: var(--space-4);
    margin-bottom: var(--space-4);
  }

  /* Images - full bleed on mobile */
  .blog-post__body img {
    margin-left: calc(-1 * var(--space-2));
    margin-right: calc(-1 * var(--space-2));
    width: calc(100% + var(--space-4));
    max-width: calc(100% + var(--space-4));
    border-radius: 0;
  }

  /* Hero image - full bleed */
  .blog-post__hero-img {
    border-radius: 0;
    max-width: 100vw;
    margin-left: calc(-1 * var(--gutter));
    margin-right: calc(-1 * var(--gutter));
    width: calc(100% + var(--gutter) * 2);
  }

  /* HR - tighter spacing */
  .blog-post__body hr {
    margin: var(--space-6) 0;
  }

  /* Footer - stack vertically, reduce padding */
  .blog-post__footer {
    padding: var(--space-6);
    padding-bottom: var(--space-8);
  }

  .blog-post__share-btn {
    min-width: 44px;
    min-height: 44px;
  }

  /* CTA section - tighter */
  .blog-post__cta {
    padding: var(--space-6) 0;
  }

  .blog-post__cta h3 {
    font-size: var(--text-xl);
  }
}

/* Tablet breakpoint adjustments */
@media (min-width: 480px) and (max-width: 767px) {
  .blog-post__body {
    font-size: var(--text-base);
    line-height: 1.8;
  }

  .page-header h1 {
    font-size: var(--text-2xl);
  }
}
