/* =====================================================================
   Services page — extends concept.css with stage + plan-card components.
   Uses the same tokens (--ink, --accent, --rule, --bg-soft, --serif/--sans)
   so it sits inside the concept design system. Promote to concept.css when
   the rest of the subpages are unified.
   ===================================================================== */

/* Intro */
.svc-intro { padding-top: 26vh; }
.svc-intro .display { font-size: clamp(40px, 6.5vw, 84px); max-width: 15ch; }
.svc-intro .body-line { margin-top: 30px; max-width: 46ch; }
@media (max-width: 720px) { .svc-intro { padding-top: 20vh; } }

/* Stages (Consult / Build / Manage) */
.svc-stage {
    display: grid;
    grid-template-columns: 0.8fr 1.2fr;
    gap: clamp(32px, 6vw, 88px);
    padding: clamp(48px, 7vh, 84px) 0;
    border-top: 1px solid var(--rule);
    align-items: start;
}
.svc-stage:first-child { border-top: none; padding-top: 0; }
.svc-stage .eyebrow { margin-bottom: 14px; }
.svc-stage-title { font-size: clamp(30px, 4.2vw, 52px); }
.svc-stage-body { display: flex; flex-direction: column; gap: 28px; padding-top: 6px; }
.svc-stage-body .body-line { max-width: 50ch; }
.svc-incl {
    list-style: none; margin: 0; padding: 0;
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px 28px;
}
.svc-incl li {
    font-family: var(--sans); font-size: 14px; letter-spacing: 0.01em;
    color: var(--ink); opacity: 0.82;
    display: flex; gap: 11px; align-items: baseline;
}
.svc-incl li::before {
    content: ''; flex: 0 0 auto; width: 5px; height: 5px; margin-top: 7px;
    border-radius: 50%; background: var(--accent);
}
@media (max-width: 720px) {
    .svc-stage { grid-template-columns: 1fr; gap: 22px; padding: 40px 0; }
    .svc-incl { grid-template-columns: 1fr; }
}

/* Managed plans */
.plans-head .display { font-size: clamp(32px, 4.6vw, 60px); max-width: 18ch; }
.plans-head .body-line { margin-top: 26px; max-width: 52ch; }
.plans-row {
    display: flex; flex-wrap: wrap;
    gap: clamp(20px, 2.4vw, 28px);
    margin-top: 56px;
}
.plan-card {
    flex: 1 1 280px; max-width: 380px;
    display: flex; flex-direction: column; gap: 16px;
    padding: 32px 30px;
    border: 1px solid var(--rule); border-radius: 22px;
    background: var(--bg-soft);
    font-family: var(--sans);
}
.plan-card.featured { border-color: var(--accent); }
.plan-tag {
    font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--accent); margin: 0;
}
.plan-name {
    font-family: var(--serif); font-weight: 300;
    font-size: clamp(26px, 3vw, 34px); letter-spacing: -0.02em;
    line-height: 1; margin: 0; color: var(--ink);
}
.plan-for { margin: 0; font-size: 14.5px; line-height: 1.6; color: var(--ink); opacity: 0.82; }
.plan-list { list-style: none; margin: 4px 0 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.plan-list li {
    font-size: 13.5px; line-height: 1.5; color: var(--ink); opacity: 0.78;
    display: flex; gap: 10px; align-items: baseline;
}
.plan-list li::before {
    content: ''; flex: 0 0 auto; width: 5px; height: 5px; margin-top: 7px;
    border-radius: 50%; background: var(--accent);
}
.plan-cta { margin-top: auto; align-self: flex-start; }
@media (max-width: 720px) {
    .plan-card { flex: 1 1 100%; max-width: none; }
}
