/* ==========================================================================
   BLOG PAGE
   ========================================================================== */
.blog-grid { grid-template-columns: repeat(3, 1fr); }
.blog-card {
  background: var(--bg-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--dur-base) var(--ease-out-expo), border-color var(--dur-base), box-shadow var(--dur-base);
}
.blog-card:hover {
  transform: translateY(-8px);
  border-color: var(--accent);
  box-shadow: 0 24px 60px -24px var(--accent-glow), var(--shadow-lg);
}
.blog-card-media {
  position: relative;
  display: block;
  overflow: hidden;
}
.blog-card-cover {
  aspect-ratio: 16/10;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: #08090a;
  transition: transform 0.6s var(--ease-out-expo);
}
.blog-card:hover .blog-card-cover {
  transform: scale(1.08) rotate(1deg);
}
.cover-1 { background: linear-gradient(135deg, var(--accent), #9fc700); }
.cover-2 { background: linear-gradient(135deg, var(--accent-2), #b8291a); color: #fff; }
.cover-3 { background: linear-gradient(135deg, #4ade80, #1f8a4c); color: #fff; }
.blog-card-media .chip { position: absolute; top: var(--space-sm); left: var(--space-sm); z-index: 2; }
.blog-card-body { padding: var(--space-lg); display: flex; flex-direction: column; gap: var(--space-2xs); }
.blog-meta { font-size: var(--fs-micro); color: var(--text-tertiary); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.blog-card-body h3 { font-size: var(--fs-h4); margin: 4px 0; transition: color var(--dur-fast); }
.blog-card:hover .blog-card-body h3,
.blog-card-body h3 a:hover { color: var(--accent); }
.blog-card-body p { font-size: var(--fs-small); margin-bottom: var(--space-sm); }
.blog-card-body .view-link i { transition: transform var(--dur-fast) var(--ease-out-soft); }
.blog-card:hover .view-link i { transform: translate(3px, -3px); }

@media (max-width: 1000px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* Blog post detail page */
.post-header { max-width: var(--container-narrow); margin-inline: auto; text-align: center; }
.post-header .blog-meta { justify-content: center; display: flex; gap: 12px; }
.post-cover {
  max-width: var(--container-max);
  margin: var(--space-2xl) auto 0;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 21/9;
}
.post-content {
  max-width: var(--container-narrow);
  margin: var(--space-3xl) auto 0;
}
.post-content h2 { margin-top: var(--space-2xl); margin-bottom: var(--space-sm); }
.post-content p { margin-bottom: var(--space-md); font-size: var(--fs-body-lg); line-height: var(--lh-relaxed); }
.post-content ul { margin: var(--space-md) 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.post-content ul li { padding-left: var(--space-lg); position: relative; color: var(--text-secondary); }
.post-content ul li::before { content: ""; position: absolute; left: 0; top: 0.6em; width: 8px; height: 8px; border-radius: 2px; background: var(--accent); }
.post-content blockquote {
  border-left: 3px solid var(--accent);
  padding-left: var(--space-lg);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  margin: var(--space-xl) 0;
  color: var(--text-primary);
}
.post-share {
  max-width: var(--container-narrow);
  margin: var(--space-2xl) auto 0;
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
