/* =========================================================
   ESL Search / Listing Pages
   Used by:
   - Knowledge products (blogs)
   - Projects
   ========================================================= */

/* -------------------------------
   Filters
   ------------------------------- */

#blogFilterForm .form-label,
#projectFilterForm .form-label {
  font-weight: 600;
}

/* -------------------------------
   Card base
   ------------------------------- */

.blog-card {
  border-radius: 14px;
  overflow: hidden; /* keeps rounded corners clean with images */
}

/* -------------------------------
   Card media (image)
   ------------------------------- */

.blog-card-media,
.blog-card-image-link {
  display: block;
  width: 100%;
  border-bottom: 1px solid var(--border-subtle, #e5e7eb);
  background: var(--surface-2, #f3f4f6);
}

.blog-card-img,
.blog-card-media img,
.blog-card-image-link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.2s ease;
}

/* Hover zoom (blog + project) */
.blog-card-media:hover img,
.blog-card-image-link:hover img {
  transform: scale(1.02);
}

/* -------------------------------
   Card body layout
   ------------------------------- */

.blog-card-body {
  padding: 1rem;
  min-height: 170px; /* keeps cards aligned */
  display: flex;
  flex-direction: column;
}

/* Smaller screens */
@media (max-width: 576px) {
  .blog-card-body {
    min-height: 155px;
  }
}

/* -------------------------------
   Title
   ------------------------------- */

.blog-card-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 2.6em; /* ~2 lines */
}

.blog-card-link {
  display: inline-block;
}

/* -------------------------------
   Date
   ------------------------------- */

.blog-card-date {
  min-height: 1.2rem;
}

/* -------------------------------
   Meta (groups / services / tags)
   ------------------------------- */

.blog-card-meta {
  margin-top: auto;
  min-height: 1.8rem; /* stabilizes card height */
}

/* Label (Groups:, Tags:, Services:) */
.blog-meta-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #212529;
  margin-right: 0.25rem;
}

/* Empty placeholder */
.blog-meta-empty {
  font-size: 0.85rem;
  color: #6c757d;
}

/* -------------------------------
   Badges
   ------------------------------- */

/* Group / Service badge */
.blog-badge-group {
  background: rgba(22, 163, 74, 0.08); /* ESL green tint */
  color: var(--brand);
  border: 1px solid rgba(22, 163, 74, 0.25);
  font-size: 0.7rem;
  font-weight: 600;
}

/* Tag badge */
.blog-badge-tag {
  background: var(--surface-2);
  color: var(--text-muted);
  border: 1px solid var(--border-subtle);
  font-size: 0.7rem;
}

/* Hover polish for clickable badges */
.blog-badge-group:hover,
.blog-badge-tag:hover {
  background: var(--brand);
  color: #ffffff;
  border-color: var(--brand);
}

.blog-card-meta a.badge:hover {
  filter: brightness(0.95);
  cursor: pointer;
}

/* -------------------------------
   Optional utility
   ------------------------------- */

/* Prevent badge rows from shifting layout */
.blog-meta-row {
  line-height: 1.2;
}
