/* blog.css */
.blog-header {
  padding: calc(var(--nav-h) + 4rem) 0 3rem;
  border-bottom: 1px solid var(--border);
}
.blog-header h1 { margin-top: 0.75rem; }
.blog-header-sub {
  font-size: 1rem; color: var(--warm-grey);
  font-style: italic; margin-top: 0.5rem;
}
.filter-bar {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--border);
  background: var(--parchment);
  position: sticky; top: var(--nav-h); z-index: 10;
}
.filter-inner {
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
}
.filter-label {
  font-family: var(--sans); font-size: 0.72rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--warm-grey);
}
.filter-pills { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.filter-pill {
  font-family: var(--sans); font-size: 0.78rem;
  font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 0.45rem 1rem;
  border: 1px solid var(--border);
  background: none; color: var(--warm-grey);
  cursor: pointer; transition: all 0.2s;
}
.filter-pill:hover { border-color: var(--ink); color: var(--ink); }
.filter-pill.active { background: var(--ink); color: var(--parchment); border-color: var(--ink); }

.blog-posts-section { padding: 4rem 0 7rem; }
.blog-posts-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 3rem 2rem;
}
.no-posts {
  text-align: center; padding: 5rem 0;
  font-family: var(--sans); color: var(--warm-grey);
  font-size: 0.95rem;
}
@media (max-width: 900px) { .blog-posts-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .blog-posts-grid { grid-template-columns: 1fr; } }
