/* ==========================================================
   blog.css — Blog index page styles
   ========================================================== */

main { padding: 46px 0 70px; }

.blog-hero {
  border: 1px solid var(--border);
  background: linear-gradient(180deg, var(--panel), rgba(255,255,255,.03));
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding: 22px;
}
.blog-hero h1 {
  margin: 0 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.blog-hero .lede {
  margin: 0;
  color: var(--muted);
  max-width: 70ch;
}

.grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  margin-top: 14px;
}

.blog-card {
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius2);
  padding: 18px;
  box-shadow: 0 10px 40px rgba(0,0,0,.25);
}

.list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}
.post {
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 16px;
  padding: 14px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.post:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.16);
}

.kicker  { font-size: 12px; color: var(--muted2); margin: 0 0 6px; }
.post-title { margin: 0 0 6px; font-size: 15px; }
.excerpt { margin: 0; color: var(--muted); font-size: 13px; }
.meta    { margin-top: 10px; display: flex; gap: 10px; flex-wrap: wrap; color: var(--muted2); font-size: 12px; }
.tag {
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
}

@media (max-width: 980px) {
  .grid { grid-template-columns: 1fr; }
  nav { display: none; }
}
