/* ============================================================
   Inga page components — layered on the OC design system.
   Reuses tokens + base/nav/band/footer from style.css.
   Palette: paper #f7f4ef · navy #0f1729 · amber #e89b1c.
   ============================================================ */

/* ---- page hero (lighter than the homepage video hero) ---- */
.inga-hero { padding: calc(var(--nav-h) + 84px) 0 84px; }
.inga-hero h1 { font-size: 3.4rem; max-width: 15ch; }
.inga-hero .lead { max-width: 32em; }
.hero-creds {
  display: flex; flex-wrap: wrap; gap: 0.5rem 1.7rem; margin-top: 2.2rem;
  font-family: 'DM Sans', sans-serif; font-size: 0.7rem; font-weight: 500;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-soft);
}
.hero-creds span { position: relative; }
.hero-creds span + span::before { content: "·"; position: absolute; left: -1rem; color: var(--amber); }

/* ---- symptom checklist ---- */
.checklist { list-style: none; padding: 0; margin: 1.6rem 0 0; display: grid; gap: 0.7rem; max-width: 46em; }
.checklist li { position: relative; padding-left: 2rem; color: var(--ink-soft); }
.checklist li::before { content: ""; position: absolute; left: 0; top: 0.62em; width: 11px; height: 11px;
  border: 1.5px solid var(--amber); border-radius: 2px; }
.note { font-style: italic; color: var(--ink-soft); margin-top: 1.6rem; }

/* ---- split: bio + outcomes card ---- */
.split { display: grid; grid-template-columns: 1fr; gap: clamp(1.8rem, 4vw, 3.4rem); align-items: start; }
@media (min-width: 900px) { .split { grid-template-columns: 1.35fr 1fr; } }
.bio-card { background: var(--paper-2); border: 1px solid var(--line); border-radius: 4px; padding: clamp(1.6rem, 3vw, 2.2rem); }
.bio-card h3 { margin-top: 0; }
.bio-card p { color: var(--ink-soft); }
.outcomes { list-style: none; padding: 0; margin: 1.2rem 0 0; }
.outcomes li { position: relative; padding: 0.68rem 0 0.68rem 1.9rem; line-height: 1.5; color: var(--ink); }
.outcomes li + li { border-top: 1px solid var(--line); }
.outcomes li::before { content: "✓"; position: absolute; left: 0; top: 0.68rem; color: var(--amber-deep);
  font-weight: 700; font-family: 'DM Sans', sans-serif; }

/* ---- service cards ---- */
.cards { display: grid; gap: 1.2rem; margin-top: 2.4rem; }
@media (min-width: 760px) { .cards { grid-template-columns: 1fr 1fr; } }
.card { background: var(--paper); border: 1px solid var(--line); border-radius: 4px; padding: clamp(1.5rem, 2.6vw, 2rem);
  display: flex; flex-direction: column; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(15,23,41,.09); border-color: var(--amber); }
.card .when { font-family: 'DM Sans', sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--amber-deep); margin: 0 0 0.5rem; }
.card h3 { margin: 0.1rem 0 0.5rem; }
.card > p { color: var(--ink-soft); margin: 0 0 0.6rem; max-width: none; }
.card .lab { font-family: 'DM Sans', sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.09em; color: var(--ink); margin: 0.7rem 0 0.4rem; }
.card ul { margin: 0; padding-left: 1.1rem; color: var(--ink-soft); }
.card ul li { margin-bottom: 0.28rem; }

/* ---- principles grid (3-up) ---- */
.principles { display: grid; gap: 1.2rem; margin-top: 1.4rem; }
@media (min-width: 720px) { .principles { grid-template-columns: repeat(3, 1fr); } }
.principle { background: var(--paper); border: 1px solid var(--line); border-radius: 4px; padding: 1.3rem 1.4rem;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.principle:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(15,23,41,.08); border-color: var(--amber); }
.principle h3 { font-size: 1.12rem; margin: 0 0 0.4rem; }
.principle p { color: var(--ink-soft); margin: 0; max-width: none; }

/* ---- social-impact callout ---- */
.callout { margin-top: 2.8rem; background: var(--paper-2); border: 1px solid var(--line);
  border-left: 3px solid var(--amber); border-radius: 4px; padding: clamp(1.6rem, 3vw, 2.2rem); }
.callout h3 { margin: 0.2rem 0 0.5rem; }
.callout p { color: var(--ink-soft); max-width: 48em; }
.callout .price { font-family: 'Playfair Display', serif; font-size: 1.5rem; color: var(--ink); margin: 0.6rem 0; }

/* ---- proof stats (on the dark band) — board-style B612 Mono counters ---- */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 2.4rem; max-width: 42em; }
.stat .num { font-family: 'B612 Mono', ui-monospace, monospace; font-weight: 700; font-variant-numeric: tabular-nums;
  font-size: clamp(2rem, 4vw, 2.9rem); line-height: 1; color: #fff; }
.stat .num .plus { color: var(--amber); }
.stat .lab { font-family: 'DM Sans', sans-serif; font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--cream-soft); margin-top: 0.5rem; }

/* ---- practice items (dark band) ---- */
.practice { display: grid; gap: 1.8rem; margin-top: 2.8rem; }
@media (min-width: 760px) { .practice { grid-template-columns: 1fr 1fr; gap: 2.6rem; } }
.practice .item { border-left: 2px solid var(--amber); padding-left: 1.4rem; }
.practice .item h3 { color: #fff; margin: 0 0 0.5rem; }
.practice .item p { color: var(--cream-soft); margin: 0; max-width: none; }

/* ---- quotes (dark band) ---- */
.quotes { display: grid; gap: 1.4rem; margin-top: 2.6rem; }
@media (min-width: 760px) { .quotes { grid-template-columns: 1fr 1fr; } }
.quote { background: rgba(247,244,239,0.05); border: 1px solid var(--line-dark); border-radius: 4px; padding: 1.6rem 1.7rem;
  transition: transform .25s ease, border-color .25s ease, background .25s ease; }
.quote:hover { transform: translateY(-3px); border-color: rgba(232,155,28,.5); background: rgba(247,244,239,0.08); }
.quote p { font-family: 'Playfair Display', serif; font-style: italic; font-size: 1.1rem; line-height: 1.5;
  color: #fff; margin: 0 0 0.9rem; max-width: none; }
.quote cite { font-family: 'DM Sans', sans-serif; font-style: normal; font-size: 0.74rem; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--amber); }

/* ---- reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  .card, .principle, .quote { transition: none; }
  .card:hover, .principle:hover, .quote:hover { transform: none; }
}
