/* css/blog.css — Blog-specific styles */

.hero-section {
  padding-top: var(--space-3xl);
  padding-bottom: var(--space-2xl);
  background: var(--color-surface);
}

/* Blog index */
.blog-posts {
  padding-top: var(--space-xl);
  padding-bottom: var(--space-3xl);
}

.blog-posts .container {
  display: grid;
  gap: var(--space-xl);
  grid-template-columns: repeat(auto-fit, minmax(280px, 400px));
  justify-content: center;
}

.blog-post-preview {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: clamp(16px, 2.5vw, 28px);
  background: var(--color-surface);
  box-shadow: var(--shadow-subtle);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  max-width: 400px;
  max-height: 600px;
  overflow: hidden;
}

.blog-post-preview:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-medium);
}

.post-thumb {
  width: 100%;
  aspect-ratio: 1 / 1; /* square */
  border-radius: 10px;
  overflow: hidden;
  background: var(--color-background-subtle);
  border: 1px solid var(--color-border-subtle);
  margin-bottom: var(--space-md);
}

.post-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blog-post-preview header {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.blog-post-preview h2 {
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-snug);
}

.blog-post-preview h2 a {
  color: var(--color-text);
  text-decoration: none;
}

.blog-post-preview time {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.blog-post-preview p {
  color: var(--color-text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-post-preview .read-more {
  display: inline-block;
  margin-top: var(--space-md);
  color: var(--color-primary);
}

.blog-post-preview .read-more:hover {
  text-decoration: underline;
}

/* Single post */
.blog-post {
  max-width: 800px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-lg);
}

.post-hero {
  width: 100%;
  margin: 0 0 var(--space-xl);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border-subtle);
}

.post-hero img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.blog-post header {
  text-align: center;
}

.blog-post h1 {
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  line-height: var(--line-height-snug);
  margin-bottom: var(--space-sm);
}

.blog-post .subtitle {
  font-style: italic;
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xl);
}

.blog-meta {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-border-subtle);
}

.blog-post h2 { margin-top: var(--space-3xl); margin-bottom: var(--space-md); }
.blog-post h3 { margin-top: var(--space-2xl); margin-bottom: var(--space-sm); }
.blog-post p + p { margin-top: var(--space-md); }
.blog-post ul { padding-left: var(--space-xl); margin: var(--space-md) 0; }
.blog-post li { margin: 0 0 var(--space-sm); }

.blog-post pre {
  background: var(--color-background-subtle);
  padding: var(--space-lg);
  border-radius: 10px;
  overflow-x: auto;
  border: 1px solid var(--color-border);
  margin: var(--space-xl) 0;
}

.blog-post code {
  background: var(--color-background-subtle);
  padding: 0.15rem 0.35rem;
  border-radius: 6px;
  font-size: 0.95em;
}

.blog-post pre code { background: transparent; padding: 0; }

.architecture-diagram {
  text-align: center;
  margin: var(--space-xl) 0;
}

.architecture-diagram img { max-width: 100%; height: auto; }

.back-to-blog {
  display: inline-block;
  margin-bottom: var(--space-lg);
  color: var(--color-primary);
}

.back-to-blog:hover { text-decoration: underline; }

/* Blockquote (if used later) */
.blog-post blockquote {
  margin: var(--space-xl) 0;
  padding: var(--space-md) var(--space-lg);
  border-left: 4px solid var(--color-primary);
  background: var(--color-background-subtle);
}
