/* ═══════════════════════════════════════════════════════════════
   18 · BLOG PREVIEW
   3 article cards · editorial style
   ═══════════════════════════════════════════════════════════════ */

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 56px;
}

.post-card {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.post-card__img-wrap {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin-bottom: 22px;
  border-radius: var(--radius);
}
.post-card__img {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform 0.7s var(--ease);
}
.post-card:hover .post-card__img { transform: scale(1.07); }

.post-card__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gold-600);
  margin-bottom: 14px;
}
.post-card__meta__date {
  color: var(--ink-soft);
  font-weight: 500;
  letter-spacing: 0.06em;
}

.post-card__title {
  font-family: 'DM Sans', sans-serif;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--navy-800);
  margin: 0 0 14px;
  transition: color 0.2s;
}
.post-card:hover .post-card__title { color: var(--amber-500); }

.post-card__excerpt {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 18px;
}

.post-card__more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--navy-800);
  border-bottom: 1px solid var(--gold-500);
  padding-bottom: 4px;
  align-self: flex-start;
  transition: gap 0.25s;
}
.post-card:hover .post-card__more { gap: 12px; }
