/**
 * Section: Services Grid
 * Variants: [data-variant="light"] (default), [data-variant="dark"], [data-variant="muted"]
 *
 * Header (eyebrow + h2 + subtext) over a 4-card grid: 4 cols on desktop,
 * 2x2 on tablet, single column on mobile. Each card has an icon, title,
 * body paragraph, and a small footnote. Optional centered closer line below.
 *
 * Hover: shadow + accent border, no translateY (still card on hover).
 */

.services-grid {
  background: var(--color-bg);
  padding-block: var(--section-py);
}

.services-grid[data-variant="muted"] { background: var(--color-bg-subtle); }
.services-grid[data-variant="dark"]  { background: var(--color-bg-dark); color: var(--color-text-on-dark); }

/* ─── Header ───────────────────────────────────── */

.services-grid__header {
  max-width: 760px;
  margin: 0 auto var(--space-14);
  text-align: center;
}

.services-grid__heading {
  color: var(--color-text);
  margin: var(--space-3) 0 var(--space-4);
}

.services-grid[data-variant="dark"] .services-grid__heading {
  color: var(--color-text-on-dark);
}

.services-grid__subtext {
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  margin: 0;
}

.services-grid[data-variant="dark"] .services-grid__subtext {
  color: rgba(255, 255, 255, 0.65);
}

/* ─── Grid ─────────────────────────────────────── */

.services-grid__items {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}

/* ─── Card ─────────────────────────────────────── */

.services-card {
  padding: var(--space-7) var(--space-6);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition:
    box-shadow var(--transition-fast),
    border-color var(--transition-fast);
}

.services-card:hover {
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-accent);
}

.services-grid[data-variant="muted"] .services-card {
  background: var(--color-bg);
}

.services-grid[data-variant="dark"] .services-card {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}

.services-grid[data-variant="dark"] .services-card:hover {
  border-color: var(--color-accent);
  /* --shadow-card-hover bakes in --color-primary (forest green), which
     vanishes on near-black bg. Override with a brighter brand-cast lift. */
  box-shadow: 0 12px 28px color-mix(in srgb, var(--color-accent) 25%, transparent);
}

/* ─── Card icon ────────────────────────────────── */

.services-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--color-accent-light);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
  flex-shrink: 0;
}

.services-card__icon svg { width: 22px; height: 22px; display: block; }

.services-grid[data-variant="dark"] .services-card__icon {
  background: color-mix(in srgb, var(--color-accent) 14%, transparent);
  color: var(--color-accent);
}

/* ─── Card body ────────────────────────────────── */

.services-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}

.services-grid[data-variant="dark"] .services-card__title {
  color: var(--color-text-on-dark);
}

.services-card__body {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  margin: 0;
  flex-grow: 1;
}

.services-grid[data-variant="dark"] .services-card__body {
  color: rgba(255, 255, 255, 0.7);
}

.services-card__foot {
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  color: var(--color-text-subtle);
  margin: var(--space-3) 0 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

.services-grid[data-variant="dark"] .services-card__foot {
  color: rgba(255, 255, 255, 0.5);
  border-top-color: rgba(255, 255, 255, 0.08);
}

/* ─── Closer ───────────────────────────────────── */

.services-grid__closer {
  max-width: 820px;
  margin: var(--space-12) auto 0;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-subtle);
  text-align: center;
}

.services-grid[data-variant="dark"] .services-grid__closer {
  color: rgba(255, 255, 255, 0.55);
}

/* ─── Responsive ───────────────────────────────── */

@media (max-width: 1199px) {
  .services-grid__items {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

@media (max-width: 809px) {
  .services-grid { padding-block: var(--section-py-sm); }
  .services-grid__header { margin-bottom: var(--space-10); }
  .services-grid__items {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .services-card { padding: var(--space-6) var(--space-5); }
  .services-grid__closer { margin-top: var(--space-10); }
}
