/* =================================================================
 * Services page.
 * ================================================================= */

/* ========== HERO ========== */
.services-hero {
  padding-block: clamp(var(--vq-space-9), 10vw, var(--vq-space-12));
  text-align: center;
  background: var(--vq-color-bg);
}
.services-hero__inner { display: flex; flex-direction: column; align-items: center; gap: var(--vq-space-5); }
.services-hero__title {
  font-size: clamp(2.25rem, 5.5vw, 4.5rem);
  font-weight: var(--vq-weight-bold);
  letter-spacing: -0.02em;
  line-height: 1.0;
  color: var(--vq-color-secondary);
  margin: 0;
  max-width: 22ch;
}
.services-hero__title em { font-style: normal; color: var(--vq-color-primary); }
.services-hero__lead {
  font-size: var(--vq-text-lg);
  color: var(--vq-color-muted);
  max-width: 60ch;
  margin: 0;
}
.services-hero__lead strong { color: var(--vq-color-ink); }
.services-hero__actions { display: flex; gap: var(--vq-space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--vq-space-3); }

/* ========== GRID ========== */
.services-grid__header { text-align: center; margin-bottom: var(--vq-space-8); }
.services-grid__title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--vq-weight-bold);
  letter-spacing: -0.01em;
  line-height: 1.05;
  color: var(--vq-color-secondary);
  margin: 0 0 var(--vq-space-3);
}
.services-grid__title em { font-style: normal; color: var(--vq-color-primary); }
.services-grid__lead {
  font-size: var(--vq-text-lg);
  color: var(--vq-color-muted);
  max-width: 56ch;
  margin: 0 auto;
}

.services-grid__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(280px, auto);
  gap: var(--vq-space-5);
}
.service-card {
  background: var(--vq-color-bg);
  border: 1px solid var(--vq-color-border);
  border-radius: var(--vq-radius-lg);
  padding: var(--vq-space-6);
  display: flex;
  flex-direction: column;
  transition: transform var(--vq-duration) var(--vq-ease),
              border-color var(--vq-duration) var(--vq-ease),
              box-shadow var(--vq-duration) var(--vq-ease);
}
.service-card:hover {
  transform: translateY(-3px);
  border-color: var(--vq-color-primary);
  box-shadow: var(--vq-shadow-md);
}
.service-card--featured {
  grid-column: span 2;
  flex-direction: row;
  gap: var(--vq-space-7);
  align-items: center;
  background: var(--vq-color-secondary);
  border-color: var(--vq-color-secondary);
  color: #fff;
}
.service-card--featured .service-card__icon {
  flex-shrink: 0;
  width: 96px;
  height: 96px;
  border-radius: var(--vq-radius-lg);
}
.service-card--featured .service-card__icon svg { width: 40px; height: 40px; }
.service-card--featured .service-card__title { color: #fff; }
.service-card--featured .service-card__desc { color: #CBD5E1; }
.service-card--featured .service-card__tag { color: #93C5FD; }
.service-card--featured .service-card__link { color: #fff; border-bottom-color: #fff; }

.service-card__body { flex-grow: 1; display: flex; flex-direction: column; }

.service-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: var(--vq-radius-md);
  margin-bottom: var(--vq-space-4);
}
.service-card__icon--blue   { background: #DBEAFE; color: #2563EB; }
.service-card__icon--purple { background: #EDE9FE; color: #7C3AED; }
.service-card__icon--pink   { background: #FCE7F3; color: #DB2777; }
.service-card__icon--green  { background: #D1FAE5; color: #059669; }
.service-card__icon--orange { background: #FFEDD5; color: #EA580C; }
.service-card__icon--sky    { background: #E0F2FE; color: #0284C7; }
.service-card__icon--yellow { background: #FEF3C7; color: #D97706; }
.service-card__icon--teal   { background: #CCFBF1; color: #0D9488; }

.service-card__tag {
  font-family: var(--vq-font-display);
  font-size: var(--vq-text-xs);
  font-weight: var(--vq-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--vq-color-primary);
  margin: 0 0 var(--vq-space-2);
}
.service-card__title {
  font-size: var(--vq-text-xl);
  font-weight: var(--vq-weight-bold);
  letter-spacing: -0.005em;
  color: var(--vq-color-ink);
  margin: 0 0 var(--vq-space-3);
}
.service-card__desc {
  font-size: var(--vq-text-sm);
  color: var(--vq-color-muted);
  line-height: var(--vq-leading-base);
  margin: 0 0 var(--vq-space-4);
}
.service-card__desc em { font-style: normal; color: var(--vq-color-ink); font-weight: var(--vq-weight-medium); }
.service-card__bullets {
  list-style: none;
  margin: 0 0 var(--vq-space-5);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--vq-space-2);
}
.service-card__bullets li {
  font-size: var(--vq-text-sm);
  color: var(--vq-color-muted);
  padding-left: 22px;
  position: relative;
}
.service-card__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 8px;
  height: 8px;
  background: var(--vq-color-primary);
  border-radius: 50%;
}
.service-card--featured .service-card__bullets li { color: #CBD5E1; }
.service-card--featured .service-card__bullets li::before { background: #93C5FD; }

.service-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--vq-space-2);
  margin-top: auto;
  font-family: var(--vq-font-display);
  font-size: var(--vq-text-sm);
  font-weight: var(--vq-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--vq-color-ink);
  border-bottom: 1px solid var(--vq-color-ink);
  padding-bottom: 3px;
  align-self: flex-start;
}
.service-card__link:hover { color: var(--vq-color-primary); border-color: var(--vq-color-primary); }

@media (max-width: 1000px) {
  .services-grid__cards { grid-template-columns: repeat(2, 1fr); }
  .service-card--featured { grid-column: span 2; flex-direction: column; gap: var(--vq-space-4); align-items: flex-start; }
}
@media (max-width: 640px) {
  .services-grid__cards { grid-template-columns: 1fr; }
  .service-card--featured { grid-column: 1; }
}
