.vgz-wrap {
  --gap: 14px;
  --radius: 12px;
  --brand: #16404d;
  --font: var(--body-font, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif);
  display: grid;
  gap: var(--gap);
  font-family: var(--font);
}

.vgz-cols-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.vgz-cols-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.vgz-cols-4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
@media (max-width: 900px){ .vgz-cols-3, .vgz-cols-4 { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 560px){ .vgz-cols-2, .vgz-cols-3, .vgz-cols-4 { grid-template-columns: 1fr; } }

.vgz-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.vgz-thumb {
  display: block;
  background: #f9fafb;
  border-bottom: 1px solid #eef2f7;
}
.vgz-thumb img {
  width: 100%;
  height: 140px;
  object-fit: cover;        /* looks like a banner */
  display: block;
}
.vgz-thumb--placeholder {
  height: 140px;
  display: grid;
  place-items: center;
  font-weight: 700;
  color: #6b7280;
  background: #f3f4f6;
}

.vgz-body { padding: 12px; }
.vgz-title { margin: 0 0 4px; font-size: 16px; line-height: 1.3; }
.vgz-title a { color: #111827; text-decoration: none; }
.vgz-title a:hover { text-decoration: underline; }
.vgz-meta { font-size: 13px; color: #6b7280; margin-bottom: 10px; }

.vgz-actions { display: flex; gap: 8px; margin-top: auto; }
.vgz-btn {
  background: var(--brand);
  color: #fff;
  border: 1px solid var(--brand);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 14px;
  text-decoration: none;
}
.vgz-btn:hover { opacity: .92; }
.vgz-btn.outline {
  background: #fff;
  color: var(--brand);
  border: 1px solid var(--brand);
}

.vgz-empty { font-family: var(--font); color: #6b7280; }
