/* ============================================================
   Apollo — 31 services (capability index by business outcome + service modal)
   ============================================================ */

.services-page { padding-top: clamp(120px, 18vh, 200px); }
.services-page .section-head { margin-inline: auto; text-align: center; }
.services-page .section-head .lead { margin-inline: auto; }

.svc-group { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.svc-group-head { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.5rem 1.5rem; padding-bottom: 1.25rem; margin-bottom: 1.25rem; border-bottom: 1px solid var(--line-strong); }
.svc-group-head h3 { font-size: clamp(1.5rem, 2.4vw, 2rem); }
.svc-group-head p { color: var(--muted); max-width: 46ch; }

.svc-list { display: grid; gap: 0.75rem; }
.svc-row { display: flex; align-items: center; gap: 1.5rem; padding: 1.5rem 1.75rem; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--surface); cursor: pointer; transition: transform var(--dur) var(--ease-out), border-color var(--dur) ease, box-shadow var(--dur) var(--ease-out); }
.svc-row:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--shadow); }
.svc-row:focus-visible { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--shadow); outline: 2px solid var(--accent); outline-offset: 3px; }
.svc-row-main { flex: 1; min-width: 0; }
.svc-row-main h4 { font-size: 1.3rem; margin-bottom: 0.4rem; }
.svc-row-main p { color: var(--muted); margin-bottom: 0.8rem; max-width: 62ch; }
.svc-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.svc-tags span { font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted); padding: 0.25rem 0.6rem; border: 1px solid var(--line); border-radius: var(--r-pill); }
.svc-row-arrow { font-size: 1.4rem; color: var(--accent); font-weight: 700; transition: transform var(--dur) var(--ease-out); }
.svc-row:hover .svc-row-arrow { transform: translateX(5px); }

.services-cta { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.8rem; margin-top: clamp(2rem, 4vw, 3.5rem); }

/* Service modal body */
.svc-modal-body { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(1.25rem, 3vw, 2rem); margin-top: 1.5rem; }
.svc-modal-visual { min-width: 0; }
.svc-modal-copy { display: flex; flex-direction: column; gap: 1rem; }
.svc-modal-copy > p { color: var(--text); }
.svc-modal-case { background: var(--bg-tint); border: 1px solid var(--line); border-radius: var(--r); padding: 1rem 1.25rem; }
.svc-modal-case b { display: block; font-size: 0.8rem; color: var(--accent); margin-bottom: 0.35rem; }
.svc-modal-case p { color: var(--ink); font-size: 0.95rem; }
.svc-modal-copy .btn { align-self: flex-start; }

@media (max-width: 720px) {
  .svc-row { flex-direction: row; align-items: flex-start; padding: 1.25rem; }
  .svc-modal-body { grid-template-columns: 1fr; }
}

/* Trim the oversized top gap under the fixed nav on phones (18vh ~= 146px). */
@media (max-width: 640px) {
  .services-page { padding-top: clamp(92px, 13dvh, 120px); }
}
