.b-ngrid { padding: 16px 0 24px; }
.b-ngrid__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.b-ngrid__card {
  background: var(--color-surface);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition);
}
.b-ngrid__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.b-ngrid__media {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #F4EFE6;
}
.b-ngrid__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.b-ngrid__date {
  position: absolute; top: 12px; left: 12px;
  background: var(--color-surface);
  color: var(--color-navy-900);
  font-weight: 600; font-size: 13px;
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-card);
}
.b-ngrid__body { padding: 20px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.b-ngrid__title {
  font-family: var(--font-serif);
  font-size: 18px; line-height: 1.3;
  color: var(--color-navy-900);
  margin-bottom: 10px;
}
.b-ngrid__lead { color: var(--color-text-muted); font-size: 14px; flex: 1; margin-bottom: 16px; }
.b-ngrid__more {
  color: var(--color-navy-900);
  font-size: 14px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 6px;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.b-ngrid__more .icon { width: 16px; height: 16px; stroke: currentColor; }
.b-ngrid__empty { text-align: center; padding: 48px 0; color: var(--color-text-muted); }

@media (max-width: 1100px) { .b-ngrid__list { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 820px)  { .b-ngrid__list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .b-ngrid__list { grid-template-columns: 1fr; } }
