/* Full-width blue gradient band with light text */
#services {
  /* full-bleed background on the section itself */
  background: linear-gradient(135deg, var(--blue-900) 0%, var(--blue-700) 45%, var(--blue-500) 100%);
  color: var(--gray-100);
}
#services .services__title { color: var(--gray-100); margin-bottom: 30px; }

#services .services__inner { padding: 32px 0 40px; }

/* Cards grid */
#services .services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

/* Cards (use variables only) */
#services .service-card {
  display: flex; flex-direction: column; gap: 8px;
  padding: 16px 16px 14px;
  border-radius: 12px;
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  box-shadow: 0 6px 14px color-mix(in srgb, var(--gray-900) 8%, transparent);
  color: var(--gray-900);
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
  outline: none;
}
#services .service-card:hover {
  transform: translateY(-2px);
  border-color: var(--blue-200);
  box-shadow: 0 10px 20px color-mix(in srgb, var(--gray-900) 14%, transparent);
}
#services .service-card:focus-visible {
  outline: 2px solid var(--blue-A200);
  outline-offset: 2px;
}
#services .service-card__title {
  font-weight: 600;
  color: var(--gray-900);
  font-size: clamp(18px, 2.6vw, 20px);
  line-height: 1.35;
}
#services .service-card__desc {
  color: var(--gray-700);
  font-size: clamp(0.95rem, 2.3vw, 1rem);
  line-height: 1.6;
}
#services .service-card__cta {
  margin-top: 6px;
  font-weight: 500;
  color: var(--blue-700);
  font-size: clamp(0.95rem, 2.2vw, 1rem);
}
#services .service-card__cta:hover,
#services .service-card__cta:focus-visible { color: var(--blue-A400); }

/* Responsive spacing */
/* 1 col: small phones */
@media (max-width: 599.98px) {
  #services .services-grid { grid-template-columns: 1fr; }
}

/* 2 cols: 600–767.98px */
@media (min-width: 600px) and (max-width: 767.98px) {
  #services .services-grid { grid-template-columns: repeat(2, minmax(240px, 1fr)); }
}

/* 3 cols: ≥768px (laptops/desktops) */
@media (min-width: 768px) {
  #services .services-grid { grid-template-columns: repeat(3, minmax(240px, 1fr)); }
}

/* Spacing tweaks for ≤768px (keep these here, but don't set columns) */
@media (max-width: 768px) {
  #services .services__inner { padding: 24px 0 28px; }
  #services .services-grid { gap: 12px; }      /* move gap here (not on .services__inner) */
  #services .service-card { padding: 14px 14px 12px; border-radius: 10px; }
}

/* Large desktop refinements */
@media (min-width: 1200px) {
  #services .services__inner { padding: 40px 0 56px; }
  #services .services-grid { gap: 20px; }
  #services .service-card { padding: 18px 18px 16px; border-radius: 14px; }
}
