/* Blog styles — extends landing.css. Editorial typography for long-form. */

.blog-hero {
  padding: 80px 32px 60px;
  background: var(--landing-cream);
  text-align: center;
}
.blog-hero-inner { max-width: 720px; margin: 0 auto; }
.blog-hero h1 {
  font-family: var(--serif);
  font-size: clamp(48px, 7vw, 80px);
  font-weight: 700;
  letter-spacing: -1px;
  color: var(--landing-text);
  margin: 0 0 18px;
  line-height: 1.05;
}
.blog-hero p {
  font-size: 18px;
  color: var(--landing-text-muted);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.6;
}

.blog-section { padding: 40px 32px 80px; background: var(--landing-cream); }
.blog-section-inner { max-width: 1100px; margin: 0 auto; }
.blog-section h2 {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 700;
  color: var(--landing-text);
  margin: 24px 0 8px;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.blog-card {
  display: flex;
  flex-direction: column;
  background: white;
  border: 1px solid var(--landing-border);
  border-radius: 12px;
  padding: 24px;
  text-decoration: none;
  color: var(--landing-text);
  transition: transform 0.12s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.blog-card:hover {
  text-decoration: none;
  transform: translateY(-2px);
  border-color: var(--landing-sage);
  box-shadow: 0 8px 24px rgba(40, 40, 20, 0.08);
}
.blog-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.blog-card-tags span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--landing-sage);
  background: rgba(61, 90, 58, 0.08);
  padding: 3px 9px;
  border-radius: 50px;
}
.blog-card h3 {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--landing-text);
  margin: 0 0 10px;
  line-height: 1.2;
}
.blog-card p {
  font-size: 14px;
  color: var(--landing-text-muted);
  line-height: 1.55;
  margin: 0 0 16px;
  flex: 1;
}
.blog-card-read {
  font-size: 14px;
  font-weight: 700;
  color: var(--landing-sage);
}

/* ============================================================
   ARTICLE TYPOGRAPHY
   ============================================================ */
.blog-post {
  background: var(--landing-cream);
  padding: 60px 32px 80px;
}
.blog-post-inner {
  max-width: 720px;
  margin: 0 auto;
}
.blog-meta {
  font-size: 13px;
  margin-bottom: 24px;
}
.blog-meta a {
  color: var(--landing-text-muted);
  text-decoration: none;
}
.blog-meta a:hover { color: var(--landing-sage); }

.blog-h1 {
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 52px);
  font-weight: 700;
  letter-spacing: -0.5px;
  line-height: 1.1;
  color: var(--landing-text);
  margin: 0 0 16px;
}

.blog-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 36px;
}
.blog-tags .tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--landing-sage);
  background: rgba(61, 90, 58, 0.08);
  padding: 3px 9px;
  border-radius: 50px;
}

.blog-content {
  font-size: 18px;
  line-height: 1.7;
  color: var(--landing-text);
}
.blog-content p {
  margin: 0 0 22px;
}
.blog-content h2 {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--landing-text);
  margin: 44px 0 16px;
  letter-spacing: -0.3px;
}
.blog-content h3 {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--landing-text);
  margin: 32px 0 12px;
}
.blog-content ul {
  margin: 0 0 22px;
  padding-left: 22px;
}
.blog-content ul li { margin-bottom: 8px; }
.blog-content a {
  color: var(--landing-sage);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.blog-content strong { font-weight: 700; }

.blog-cta-section {
  background: var(--landing-cream-warm);
}
