/* ============================================================
   Bebop · service page template (mobile-first, .desk reflow)
   Built on Bebop Design System tokens. Reuses shared primitives
   (.eyebrow, .btn, .lime, .ltr-tok, .contact-row) from styles.css.
   ============================================================ */

.svc { background: var(--bb-paper); color: var(--bb-fg-1); }

/* ---- breadcrumbs ---- */
.svc-crumbs {
  font-family: var(--bb-font-mono);
  font-size: 11px;
  color: var(--bb-fg-3);
  padding: 16px 20px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.svc-crumbs a { color: var(--bb-fg-3); text-decoration: none; }
.svc-crumbs a:hover { color: var(--bb-fg-1); }
.svc-crumbs .sep { opacity: 0.5; }
.svc-crumbs .cur { color: var(--bb-fg-1); }

/* ---- hero ---- */
.svc-hero { padding: 24px 20px 44px; }
.svc-hero .eyebrow { margin-bottom: 18px; }
.svc-h1 {
  font-family: var(--bb-font-hero);
  font-weight: 900;
  font-size: 40px;
  line-height: 1.0;
  letter-spacing: -0.025em;
  margin: 0 0 18px;
  text-wrap: balance;
}
.svc-h1 .lime { background: var(--bb-lime); padding: 0 8px 2px; border-radius: 4px; margin: 0 -2px; }
.svc-dek {
  font-size: 16.5px;
  line-height: 1.6;
  color: var(--bb-fg-2);
  margin: 0 0 26px;
  max-width: 540px;
  text-wrap: pretty;
}
.svc .cta-row { display: flex; flex-direction: column; gap: 12px; align-items: stretch; }

/* ---- generic section + headings ---- */
.svc-sec { padding: 48px 20px; border-top: 1px solid var(--bb-rule); }
.svc-sec > .eyebrow { margin-bottom: 16px; }
.svc-sec h2 {
  font-family: var(--bb-font-hero);
  font-weight: 900;
  font-size: 28px;
  line-height: 1.08;
  letter-spacing: -0.018em;
  margin: 0 0 20px;
  text-wrap: balance;
}
.svc-sec h2 .lime { color: var(--bb-fg-1); background: var(--bb-lime); padding: 0 6px; border-radius: 4px; }

/* ---- definition / who ---- */
.svc-def-lead { font-size: 17px; line-height: 1.65; color: var(--bb-fg-1); margin: 0 0 18px; max-width: 600px; }
.svc-audience {
  font-size: 15px; line-height: 1.6; color: var(--bb-fg-2);
  background: rgba(10,14,16,0.04);
  border-inline-start: 3px solid var(--bb-lime);
  border-radius: var(--mood-radius);
  padding: 14px 16px; margin: 0; max-width: 600px;
}

/* ---- what's included (cards) ---- */
.svc-cards { display: flex; flex-direction: column; gap: 12px; }
.svc-card {
  border: 1px solid var(--bb-rule);
  border-radius: var(--mood-radius);
  padding: 18px 18px;
  background: #fff;
}
.svc-card h3 { font-family: var(--bb-font-subhead); font-weight: 700; font-size: 17px; margin: 0 0 6px; }
.svc-card p { font-size: 14.5px; line-height: 1.55; color: var(--bb-fg-2); margin: 0; }

/* ---- how it works (steps) ---- */
.svc-steps { display: flex; flex-direction: column; gap: 4px; }
.svc-step { display: flex; gap: 16px; padding: 16px 0; border-top: 1px solid var(--bb-rule); }
.svc-step:first-child { border-top: 0; }
.svc-step .n {
  font-family: var(--bb-font-mono); font-size: 13px; font-weight: 500;
  color: var(--bb-fg-1); flex-shrink: 0; padding-top: 2px;
}
.svc-step h3 { font-family: var(--bb-font-subhead); font-weight: 700; font-size: 16.5px; margin: 0 0 4px; }
.svc-step p { font-size: 14.5px; line-height: 1.55; color: var(--bb-fg-2); margin: 0; }

/* ---- why bebop (dark band) ---- */
.svc-why { background: var(--bb-ink); color: var(--bb-on-dark-1); border-top: 0; }
.svc-why h2 { color: var(--bb-paper); }
.svc-why .eyebrow { color: var(--bb-on-dark-3); }
.svc-why-grid { display: flex; flex-direction: column; gap: 16px; }
.svc-why-item { border-top: 1px solid rgba(255,255,255,0.12); padding-top: 16px; }
.svc-why-item:first-child { border-top: 0; padding-top: 0; }
.svc-why-item h3 { font-family: var(--bb-font-subhead); font-weight: 700; font-size: 16.5px; color: var(--bb-paper); margin: 0 0 6px; }
.svc-why-item p { font-size: 14.5px; line-height: 1.6; color: var(--bb-on-dark-2); margin: 0; }

/* ---- related / internal links ---- */
.svc-related-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.svc-related-grid a {
  font-family: var(--bb-font-secondary); font-weight: 600; font-size: 14px;
  color: var(--bb-fg-1); text-decoration: none;
  border: 1px solid var(--bb-rule-strong); border-radius: var(--bb-radius-pill);
  padding: 9px 16px; transition: background var(--bb-dur-fast) var(--bb-ease-out);
}
.svc-related-grid a:hover { background: var(--bb-lime); border-color: var(--bb-lime); }

/* ---- FAQ ---- */
.svc-faq .qa { border-top: 1px solid var(--bb-rule); padding: 16px 0; }
.svc-faq .qa:first-of-type { border-top: 0; }
.svc-faq .q { font-family: var(--bb-font-subhead); font-weight: 700; font-size: 16px; margin: 0 0 8px; }
.svc-faq .a { font-size: 14.5px; line-height: 1.6; color: var(--bb-fg-2); margin: 0; }

/* ---- closing CTA (lime band) ---- */
.svc-final { background: var(--bb-lime); color: var(--bb-ink); padding: 44px 20px; text-align: center; }
.svc-final h2 {
  font-family: var(--bb-font-hero); font-weight: 900; font-size: 28px;
  line-height: 1.08; letter-spacing: -0.02em; margin: 0 0 20px; color: var(--bb-ink);
  text-wrap: balance;
}
.svc-final .btn-primary { background: var(--bb-ink); color: var(--bb-paper); }
.svc-final .cta-row { align-items: center; }
.svc-final .contact-row .btn { border-color: rgba(10,14,16,0.25); }

/* ============================================================
   DESKTOP reflow (.desk .svc) — centred to --cw via --pad
   ============================================================ */
.desk .svc-crumbs { padding-inline: var(--pad); padding-top: 28px; font-size: 12px; }
.desk .svc-hero { padding: 56px var(--pad) 64px; max-width: 1440px; }
.desk .svc-h1 { font-size: 60px; line-height: 0.98; max-width: 880px; }
.desk .svc-dek { font-size: 19px; max-width: 620px; }
.desk .svc .cta-row { flex-direction: row; flex-wrap: wrap; align-items: center; }
.desk .svc-sec { padding: 80px var(--pad); }
.desk .svc-sec h2 { font-size: 38px; max-width: 820px; }
.desk .svc-def-lead { font-size: 19px; max-width: 760px; }
.desk .svc-audience { font-size: 16px; max-width: 760px; }
.desk .svc-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.desk .svc-steps { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 48px; }
.desk .svc-step { border-top: 1px solid var(--bb-rule); }
.desk .svc-why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.desk .svc-why-item { border-top: 0; padding-top: 0; }
.desk .svc-final { padding: 96px var(--pad); }
.desk .svc-final h2 { font-size: 44px; max-width: 760px; margin-inline: auto; }
.desk .svc-faq .faqwrap { columns: 2; column-gap: 56px; }
.desk .svc-faq .qa { break-inside: avoid; }
