/*
 * Module: Service Cards
 *
 * 3-card grid with numbered cards, color variants, and hover effects.
 * Used on: Homepage
 * Dependencies: tokens.css, buttons.css
 */

.service-cards {
  text-align: center;
  max-width: var(--max-width);
  margin: 0 auto;
}
.service-cards__header {
  max-width: 928px; margin: 0 auto;
}
.service-cards__title {
  font-family: var(--font-heading); font-weight: 600; font-size: 40px;
  color: var(--color-navy); line-height: 1.15;
}
.service-cards__subtitle {
  margin-top: var(--space-sm); font-size: 22px; color: var(--color-text-dark);
  max-width: 668px; margin-left: auto; margin-right: auto;
}
.service-cards__grid {
  display: flex;
  margin-top: var(--space-xl); gap: var(--space-sm);
}

/* ── Card base ── */
.service-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 0 20px rgba(0,0,0,0.1);
  padding: 50px 37px 50px 21px;
  display: flex; flex-direction: column; justify-content: space-between;
  text-align: left;
  min-height: 450px;
  flex: 1;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
}

/* ── Color variants ── */
.service-card--blue  { border-bottom: 10px solid var(--color-primary); }
.service-card--green { border-bottom: 10px solid var(--color-success); }
.service-card--navy  { border-bottom: 10px solid var(--color-navy); }

.service-card__number {
  font-family: var(--font-body); font-weight: 900; font-size: 48px;
  line-height: 1; letter-spacing: -0.48px;
}
.service-card--blue .service-card__number  { color: var(--color-primary); }
.service-card--green .service-card__number { color: var(--color-success); }
.service-card--navy .service-card__number  { color: var(--color-navy); }

.service-card__label {
  margin-top: -4px;
  font-family: var(--font-heading); font-weight: 600; font-size: 24px;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--color-navy);
}
.service-card__desc {
  font-size: 18px; line-height: 28px; color: var(--color-text-dark);
  max-width: 318px;
}

/* ── Card buttons ── */
.service-card .wp-block-button__link {
  border-radius: var(--radius-pill);
  font-family: var(--font-heading); font-weight: 600; font-size: 18px;
  text-transform: uppercase; letter-spacing: 0.9px;
  padding: 15px 25px; height: 50px;
}
.service-card--blue .wp-block-button .wp-block-button__link  { background: var(--color-primary) !important; transition: background 0.2s ease; }
.service-card--green .wp-block-button .wp-block-button__link { background: var(--color-success) !important; transition: background 0.2s ease; }
.service-card--navy .wp-block-button .wp-block-button__link  { background: var(--color-navy) !important; transition: background 0.2s ease; }
.service-card--blue .wp-block-button .wp-block-button__link:hover  { background: #1B6AC0 !important; }
.service-card--green .wp-block-button .wp-block-button__link:hover { background: #029D6A !important; }
.service-card--navy .wp-block-button .wp-block-button__link:hover  { background: #1D1D48 !important; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .service-cards { padding: 0 24px; }
  .service-cards__grid { flex-wrap: wrap; }
  .service-card { min-width: 300px; min-height: auto; }
}
@media (max-width: 768px) {
  .service-cards { padding: 0 16px; text-align: left; }
  .service-cards__header { max-width: 100%; }
  .service-cards__title { font-size: 24px; text-align: left; text-wrap: balance; }
  .service-cards__subtitle { text-align: left; margin-left: 0; max-width: 100%; font-size: 18px; }
  .service-cards__grid { flex-direction: column; }
  .service-card { min-width: 0; min-height: 350px; padding-bottom: 30px; gap: 20px; }
}
