/* ============================================================
   Thrucible — design system "Forge / Drawing sheet"
   Committed colour strategy: ember on warm iron-blacks.
   Anchors: ISO drawing sheet · hot-rolled steel · Haynes manual.
   ============================================================ */

@font-face { font-family: "Barlow Semi Condensed"; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/barlow-semi-condensed-600.woff2) format("woff2"); }
@font-face { font-family: "Barlow Semi Condensed"; font-style: normal; font-weight: 700; font-display: swap; src: url(/assets/fonts/barlow-semi-condensed-700.woff2) format("woff2"); }
@font-face { font-family: "Libre Franklin"; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/libre-franklin-400.woff2) format("woff2"); }
@font-face { font-family: "Libre Franklin"; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/libre-franklin-600.woff2) format("woff2"); }
@font-face { font-family: "Chivo Mono"; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/chivo-mono-400.woff2) format("woff2"); }
@font-face { font-family: "Chivo Mono"; font-style: normal; font-weight: 500; font-display: swap; src: url(/assets/fonts/chivo-mono-500.woff2) format("woff2"); }
@font-face { font-family: "FA Etch"; font-style: normal; font-weight: 900; font-display: block; src: url(/assets/fonts/fa-etch-subset.woff2) format("woff2"); }
@font-face { font-family: "FA Brands"; font-style: normal; font-weight: 400; font-display: block; src: url(/assets/fonts/fa-brands-subset.woff2) format("woff2"); }

:root {
  /* Iron neutrals: warm hue ~52, chroma rises slightly with lightness */
  --bg: oklch(15% 0.009 52);
  --surface: oklch(18% 0.011 52);
  --surface-2: oklch(21.5% 0.013 54);
  --line: oklch(31% 0.018 55);
  --line-soft: oklch(24% 0.014 53);
  --text: oklch(95% 0.01 80);
  --muted: oklch(82% 0.018 72);
  --quiet: oklch(67% 0.022 62);
  /* Ember: the one identity colour */
  --ember: oklch(68% 0.18 45);
  --ember-hot: oklch(77% 0.155 58);
  --ember-deep: oklch(36% 0.09 43);
  --ink: oklch(16% 0.022 45);
  /* Scorecard bands */
  --band-healthy: oklch(76% 0.14 140);
  --band-watch: oklch(82% 0.13 92);
  --band-risk: oklch(73% 0.15 62);
  --band-rescue: oklch(64% 0.2 32);

  --font-body: "Libre Franklin", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-display: "Barlow Semi Condensed", "Arial Narrow", sans-serif;
  --font-mono: "Chivo Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --max: 1180px;
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px; --s5: 24px; --s6: 32px; --s7: 48px; --s8: 64px; --s9: 96px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.6;
  letter-spacing: 0.011em; /* light-on-dark compensation */
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--s5); }
img { max-width: 100%; height: auto; }

/* Icon glyph helpers (annotation marks only, never decoration) */
.fa-etch { font-family: "FA Etch"; font-weight: 900; font-style: normal; line-height: 1; }
.fa-brands { font-family: "FA Brands"; font-weight: 400; font-style: normal; line-height: 1; }

/* Skip link */
.skip { position: absolute; left: -999px; top: auto; }
.skip:focus { left: var(--s4); top: var(--s4); z-index: 50; background: var(--text); color: var(--ink); padding: 10px 14px; }

/* Focus */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, .btn:focus-visible {
  outline: 2px solid var(--ember-hot);
  outline-offset: 3px;
}

/* ============ Type hierarchy ============ */
h1, h2, h3, p, ul, ol, dl { margin-top: 0; }
h1, h2 {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  text-wrap: balance;
}
h1 { font-size: clamp(3.2rem, 7vw, 5.4rem); line-height: 0.92; letter-spacing: 0.005em; margin: var(--s5) 0; }
h2 { font-size: clamp(1.9rem, 4vw, 3.2rem); line-height: 0.96; letter-spacing: 0.008em; margin: 0 0 var(--s4); }
h3 { font-size: 1.3rem; line-height: 1.25; font-weight: 600; letter-spacing: 0; margin-bottom: var(--s3); }
.sub, .lead { font-size: 1.25rem; line-height: 1.55; color: var(--muted); max-width: 65ch; }
.lead.small { font-size: 1.05rem; }
.prose { color: var(--muted); max-width: 65ch; }
.prose p { margin-bottom: var(--s4); text-wrap: pretty; }
.prose a, .legalpage a { text-decoration: underline; text-underline-offset: 3px; }
.prose strong, .lead strong { color: var(--text); }

/* Sentence segments in headings: wrap as units so text-wrap:balance
   can't break mid-phrase ("Named / budgets"). */
.seg { display: inline-block; }
/* One sentence per line: deliberate stacked composition in display headings. */
.line { display: block; }

/* Annotation layer: mono kickers with drawing index */
.kicker {
  font: 500 0.75rem/1.4 var(--font-mono);
  color: var(--ember);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  display: flex;
  align-items: center;
  gap: var(--s3);
  margin-bottom: var(--s4);
}
.kicker::after { content: ""; flex: 0 0 56px; height: 1px; background: var(--ember-deep); }
.kicker .knum { color: var(--quiet); }

/* Dimension rule: horizontal line with end ticks */
.dim { position: relative; border: 0; height: 1px; background: var(--line-soft); margin: var(--s7) 0; }
.dim::before, .dim::after {
  content: ""; position: absolute; top: -4px; width: 1px; height: 9px; background: var(--line);
}
.dim::before { left: 0; } .dim::after { right: 0; }

/* ============ Nav ============ */
.nav { position: sticky; top: 0; z-index: 20; background: var(--bg); border-bottom: 1px solid var(--line-soft); }
.navin { height: 72px; display: flex; align-items: center; justify-content: space-between; gap: var(--s5); }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; font-size: 1.35rem; text-transform: uppercase; letter-spacing: 0.03em; }
.mark {
  width: 32px; height: 32px; display: grid; place-items: center;
  background: var(--ember); color: var(--ink);
  font-family: var(--font-display); font-weight: 700; font-size: 1.2rem;
}
.links { display: flex; gap: var(--s5); color: var(--muted); font-size: 0.9rem; font-weight: 400; }
.links a:hover, .links a[aria-current] { color: var(--text); }
.links a[aria-current] { box-shadow: 0 2px 0 0 var(--ember); }
.menu { display: none; }

/* ============ Buttons ============ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s2);
  min-height: 44px; padding: 10px 18px;
  border: 1px solid var(--line); background: transparent; color: var(--text);
  font-family: var(--font-body); font-weight: 600; font-size: 0.95rem;
  cursor: pointer;
}
.btn:hover { border-color: var(--ember); color: var(--ember-hot); }
.btn.primary { background: var(--ember); border-color: var(--ember); color: var(--ink); }
.btn.primary:hover { background: var(--ember-hot); border-color: var(--ember-hot); color: var(--ink); }
.btn.big { min-height: 52px; padding: 14px 26px; font-size: 1.05rem; }
.btn .fa-etch { font-size: 0.85em; }

/* ============ Sections ============ */
.section { padding: var(--s8) 0; }
.section.tight { padding: var(--s6) 0; }
.pagehead { padding: var(--s8) 0 var(--s6); }
.pagehead h1 { max-width: 18ch; }
.pagehead h1.stack { max-width: none; font-size: clamp(2.4rem, 5.2vw, 4.2rem); }

.split { display: grid; grid-template-columns: 0.75fr 1.25fr; gap: var(--s7); }

/* Opinion interstitial */
.opinion { padding: var(--s4) 0 var(--s5); }
.opinion p {
  font-family: var(--font-display); font-weight: 600; text-transform: uppercase;
  font-size: clamp(1.6rem, 3.2vw, 2.6rem); line-height: 1.04; letter-spacing: 0.01em;
  color: var(--text); max-width: 1040px; text-wrap: balance; margin: 0;
}
.opinion p::before { content: "// "; color: var(--ember); }

/* ============ Hero ============ */
.hero { padding: var(--s7) 0 var(--s8); }
.hero h1 { font-size: clamp(2.6rem, 4.9vw, 3.9rem); }
.hero-lower { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 1fr); gap: var(--s7); align-items: start; margin-top: var(--s2); }
.eyebrow {
  font: 500 0.75rem/1.5 var(--font-mono); color: var(--quiet);
  text-transform: uppercase; letter-spacing: 0.16em;
}
.eyebrow strong { color: var(--ember); font-weight: 500; }
.actions { display: flex; gap: var(--s3); flex-wrap: wrap; margin: var(--s6) 0 var(--s4); }
.cta-sla { color: var(--quiet); font-size: 0.9rem; max-width: 58ch; margin: 0; }

/* ============ Drawing sheet (hero artefact + reusable) ============ */
.sheet {
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: 0.85rem;
  position: relative;
}
.sheet::before, .sheet::after {
  content: ""; position: absolute; width: 14px; height: 14px; pointer-events: none;
}
.sheet::before { top: -7px; left: -7px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.sheet::after { bottom: -7px; right: -7px; border-left: 1px solid var(--line); border-top: 1px solid var(--line); }
.sheet-head {
  display: flex; justify-content: space-between; gap: var(--s3); align-items: baseline;
  padding: 12px 16px; border-bottom: 1px solid var(--line);
  font: 500 0.7rem/1.4 var(--font-mono); text-transform: uppercase; letter-spacing: 0.12em;
}
.sheet-head .num { color: var(--quiet); }
.sheet-head .ttl { color: var(--text); }
.sheet-head .rev { color: var(--ember); }
.sheet-table { width: 100%; border-collapse: collapse; }
.sheet-table th, .sheet-table td { text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
.sheet-table th {
  font: 500 0.65rem/1.4 var(--font-mono); text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--quiet); border-bottom: 1px solid var(--line);
}
.sheet-table td { color: var(--muted); font-size: 0.85rem; line-height: 1.45; }
.sheet-table td.opt { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: 1.05rem; color: var(--text); white-space: nowrap; }
.sheet-table td.cost { font-family: var(--font-mono); font-weight: 500; color: var(--ember-hot); white-space: nowrap; }
.sheet-foot {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 0;
}
.sheet-foot > div { padding: 12px 16px; }
.sheet-foot > div + div { border-left: 1px solid var(--line); }
.sheet-foot .fkey { display: block; font: 500 0.62rem/1.4 var(--font-mono); text-transform: uppercase; letter-spacing: 0.14em; color: var(--quiet); margin-bottom: 2px; }
.sheet-foot .fval { font-size: 0.82rem; color: var(--muted); line-height: 1.4; }
.sheet-foot .stamp {
  display: inline-block; margin-top: 4px;
  font: 500 0.72rem/1 var(--font-mono); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ember-hot); border: 1px solid var(--ember-deep); padding: 7px 10px;
  transform: rotate(-2deg);
}

/* ============ Parts list (replaces card grids) ============ */
.parts { border-top: 1px solid var(--line); }
.part {
  display: grid; grid-template-columns: 64px 200px minmax(0, 1fr) auto;
  gap: var(--s5); align-items: baseline;
  padding: var(--s5) 0; border-bottom: 1px solid var(--line-soft);
}
.part .pnum { font: 500 0.8rem/1.6 var(--font-mono); color: var(--quiet); }
.part .ptag { font: 500 0.7rem/1.6 var(--font-mono); color: var(--ember); text-transform: uppercase; letter-spacing: 0.12em; }
.part h3 { margin: 0 0 var(--s2); }
.part p { margin: 0; color: var(--muted); max-width: 60ch; }
.part .plink { font-weight: 600; font-size: 0.9rem; white-space: nowrap; color: var(--ember-hot); }
.part .plink:hover { color: var(--text); }

/* ============ Fit list / how we work ============ */
.fit-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0 var(--s7); margin: var(--s3) 0 0; padding: 0; list-style: none; }
.fit-list li { padding: var(--s5) 0; border-top: 1px solid var(--line-soft); color: var(--muted); line-height: 1.55; }
.fit-list li:nth-child(-n+2) { border-top: 0; padding-top: var(--s2); }
.fit-list li strong { display: block; color: var(--text); font-weight: 600; font-size: 1.2rem; margin-bottom: var(--s2); }
.fit-list .no { position: relative; padding-left: 28px; }
.fit-list .no::before {
  content: "\f00d"; font-family: "FA Etch"; font-weight: 900;
  color: var(--ember); font-size: 0.9rem;
  position: absolute; left: 0; top: calc(var(--s5) + 0.35em);
}
.fit-list li.no:nth-child(-n+2)::before { top: calc(var(--s2) + 0.35em); }

/* ============ Proof: annotation rows ============ */
.proof-rows { border-top: 1px solid var(--line); }
.proof-row {
  display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: var(--s5);
  padding: var(--s4) 0; border-bottom: 1px solid var(--line-soft); align-items: baseline;
}
.proof-row dt { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: 1.5rem; letter-spacing: 0.01em; color: var(--text); }
.proof-row dd { margin: 0; color: var(--muted); font-size: 0.95rem; max-width: 70ch; }

/* Testimonial: full-border plate, no side-stripe */
.testimonial { padding: var(--s5) 0 var(--s8); }
.testimonial blockquote {
  margin: 0; padding: var(--s6) var(--s6) var(--s5);
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: clamp(1.25rem, 2.2vw, 1.6rem); line-height: 1.45; color: var(--text); text-wrap: balance;
}
.testimonial cite { display: block; margin-top: var(--s4); color: var(--quiet); font-size: 0.9rem; font-style: normal; font-family: var(--font-mono); letter-spacing: 0.04em; text-transform: uppercase; }
.testimonial cite strong { color: var(--text); margin-right: 6px; }

/* ============ Image cards (reference preview) ============ */
.image-cards { display: grid; gap: var(--s4); }
.image-cards.three { grid-template-columns: repeat(3, 1fr); }
.image-card { position: relative; display: block; overflow: hidden; border: 1px solid var(--line); background: var(--surface); }
.image-card img { display: block; width: 100%; aspect-ratio: 16/10; object-fit: cover; filter: saturate(0.92) contrast(1.04); }
.image-card span {
  display: flex; gap: 10px; align-items: baseline;
  padding: 12px 14px; border-top: 1px solid var(--line);
  font-size: 0.88rem; font-weight: 600; line-height: 1.35; background: var(--surface);
}
.image-card span .inum { font: 500 0.7rem/1.6 var(--font-mono); color: var(--ember); flex: 0 0 auto; }
.image-card:hover { border-color: var(--ember-deep); }
.image-card:hover span { color: var(--ember-hot); }
.section-head { max-width: 780px; margin-bottom: var(--s6); }
.section-action { margin-top: var(--s5); }

/* ============ CTA: drenched ember panel ============ */
.cta-forge { background: var(--ember); color: var(--ink); padding: var(--s8) 0; }
.cta-forge .kicker { color: var(--ink); }
.cta-forge .kicker::after { background: var(--ink); opacity: 0.4; }
.cta-forge h2 { color: var(--ink); max-width: 20ch; }
.cta-forge p { color: oklch(24% 0.05 45); max-width: 60ch; font-size: 1.1rem; }
.cta-forge .btn { background: var(--ink); border-color: var(--ink); color: var(--ember-hot); }
.cta-forge .btn:hover { background: oklch(22% 0.03 45); }
.cta-forge-grid { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--s6); align-items: center; }

/* ============ Footer title block ============ */
.titleblock { border-top: 1px solid var(--line); margin-top: var(--s8); background: var(--surface); }
.tb-grid { display: grid; grid-template-columns: 1.35fr repeat(3, 1fr); }
.tb-cell { padding: var(--s6) var(--s5) var(--s5) 0; }
.tb-cell + .tb-cell { border-left: 1px solid var(--line-soft); padding-left: var(--s5); }
.tb-cell a, .tb-cell p { display: block; color: var(--quiet); font-size: 0.9rem; margin: var(--s2) 0; }
.tb-cell a:hover { color: var(--ember-hot); }
.tb-label { font: 500 0.68rem/1.4 var(--font-mono); text-transform: uppercase; letter-spacing: 0.14em; color: var(--quiet); margin: 0 0 var(--s3); }
.footbrand { margin-bottom: var(--s3); color: var(--text); }
.tb-strip {
  display: flex; flex-wrap: wrap; gap: var(--s5);
  border-top: 1px solid var(--line); padding: var(--s4) 0 var(--s5);
  font: 400 0.78rem/1.5 var(--font-mono); color: var(--quiet);
}
.tb-key { color: var(--ember); text-transform: uppercase; letter-spacing: 0.1em; margin-right: 6px; font-weight: 500; }

/* ============ Services ============ */
.service-list { display: grid; gap: 0; border-top: 1px solid var(--line); }
.service { display: grid; grid-template-columns: 280px 1fr; gap: var(--s5); align-items: start; padding: var(--s6) 0; border-bottom: 1px solid var(--line-soft); }
.service h2 { font-size: clamp(1.7rem, 2.6vw, 2.2rem); }
.service .tag { font: 500 0.7rem/1.6 var(--font-mono); color: var(--ember); text-transform: uppercase; letter-spacing: 0.12em; display: block; margin-bottom: var(--s3); }
.service p, .service ul { color: var(--muted); }
.service ul, .checklist { margin: var(--s3) 0 0; padding-left: 20px; }
.service li, .checklist li { margin: var(--s2) 0; }
.offer-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s4); }
.offer { border: 1px solid var(--line); background: var(--surface); padding: var(--s6); }
.offer .tag { font: 500 0.72rem/1.6 var(--font-mono); color: var(--ember); text-transform: uppercase; letter-spacing: 0.12em; display: inline-block; margin-bottom: var(--s4); }
.offer h2 { font-size: clamp(1.8rem, 3vw, 2.4rem); }
.offer p, .offer ul { color: var(--muted); }
.offer ul { padding-left: 20px; margin: var(--s3) 0; }
.guarantee-box { border: 1px solid var(--ember-deep); padding: var(--s4); color: var(--muted); margin-top: var(--s4); }
.guarantee-box strong { color: var(--ember-hot); }

/* ============ Portrait (about) ============ */
.portrait { display: block; margin-top: var(--s5); max-width: 280px; }
.portrait img { display: block; width: 100%; filter: saturate(0.92) contrast(1.04); }

/* ============ Forms (contact intake) ============ */
.hp { position: absolute; left: -9999px; }
.intake-shell { max-width: 880px; margin: 0 auto; border: 1px solid var(--line); background: var(--surface); padding: var(--s7) var(--s7) var(--s6); }
.intake-head { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); gap: var(--s6); align-items: end; padding-bottom: var(--s6); border-bottom: 1px solid var(--line-soft); margin-bottom: var(--s6); }
.intake-head h2 { font-size: clamp(1.8rem, 3.4vw, 2.6rem); margin: var(--s2) 0 var(--s3); }
.intake-direct { display: flex; flex-direction: column; align-items: flex-end; text-align: right; gap: 6px; padding: var(--s4); border: 1px dashed var(--line); }
.intake-direct:hover { border-color: var(--ember); }
.intake-direct-label { font: 500 0.66rem/1.4 var(--font-mono); color: var(--quiet); text-transform: uppercase; letter-spacing: 0.16em; }
.intake-direct-addr { color: var(--ember-hot); font-weight: 600; font-size: 0.95rem; }
.intake-fields { list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
.intake-field { display: grid; grid-template-columns: 48px minmax(0, 1fr); grid-template-rows: auto auto; column-gap: var(--s4); row-gap: var(--s2); padding: var(--s5) 0; border-top: 1px solid var(--line-soft); align-items: start; }
.intake-field:first-child { border-top: 0; padding-top: var(--s2); }
.intake-num { grid-column: 1; grid-row: 1 / span 2; font: 500 0.72rem/1 var(--font-mono); color: var(--ember); letter-spacing: 0.12em; padding-top: 6px; }
.intake-label { grid-column: 2; grid-row: 1; font-size: 0.9rem; font-weight: 600; color: var(--text); }
.intake-input {
  grid-column: 2; grid-row: 2; width: 100%; font: inherit; font-size: 1rem; line-height: 1.5;
  color: var(--text); background: transparent; border: 0; border-bottom: 1px solid var(--line);
  border-radius: 0; padding: 10px 0 12px; min-height: 48px;
}
.intake-input::placeholder { color: var(--quiet); }
.intake-input:focus { outline: 0; border-bottom-color: var(--ember); }
.intake-textarea { min-height: 140px; resize: vertical; }
.intake-submit { display: flex; flex-wrap: wrap; align-items: center; gap: var(--s4); margin-top: var(--s6); padding-top: var(--s5); border-top: 1px solid var(--line-soft); }
.intake-promise { margin: 0; color: var(--quiet); font-size: 0.85rem; max-width: 42ch; }
.form-status { margin: var(--s3) 0 0; font-size: 0.95rem; }
.form-status[data-state="error"] { color: var(--band-rescue); }
.form-status[data-state="ok"] { color: var(--band-healthy); }

/* ============ Insights ============ */
.insight-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--line); }
.insight-link { display: block; padding: var(--s6) 0; border-bottom: 1px solid var(--line-soft); }
.insight-meta { font: 500 0.72rem/1.4 var(--font-mono); color: var(--quiet); text-transform: uppercase; letter-spacing: 0.12em; margin: 0 0 var(--s3); }
.insight-title { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: clamp(1.6rem, 3vw, 2.4rem); line-height: 1; margin: 0 0 var(--s3); color: var(--text); }
.insight-deck { color: var(--muted); margin: 0 0 var(--s3); max-width: 70ch; }
.insight-cta { font-size: 0.9rem; font-weight: 600; color: var(--ember-hot); margin: 0; }
.insight-link:hover .insight-title { color: var(--ember-hot); }

/* Long-form article */
.article { max-width: 72ch; }
.article h2 { font-size: clamp(1.6rem, 3vw, 2.3rem); margin-top: var(--s7); }
.article p, .article li { color: var(--muted); }
.article strong { color: var(--text); }

/* ============ Scorecard ============ */
.scorecard { max-width: 880px; margin: 0 auto; }
.score-list { list-style: none; padding: 0; margin: 0 0 var(--s6); border-top: 1px solid var(--line); }
.score-q { position: relative; padding: var(--s5) 0; border-bottom: 1px solid var(--line-soft); }
.score-num { position: absolute; top: var(--s5); right: 0; font: 500 0.72rem/1 var(--font-mono); color: var(--quiet); letter-spacing: 0.1em; margin: 0; }
.score-prompt { color: var(--text); line-height: 1.55; margin: 0 64px var(--s4) 0; max-width: 64ch; }
.score-scale { border: 0; padding: 0; margin: 0; display: flex; gap: var(--s2); flex-wrap: wrap; align-items: center; }
.score-legend { display: block; width: 100%; color: var(--quiet); font-size: 0.82rem; margin: 0 0 var(--s3); padding: 0; }
.score-scale label { position: relative; cursor: pointer; }
.score-scale input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.score-scale span { display: grid; place-items: center; width: 48px; height: 48px; border: 1px solid var(--line); color: var(--muted); font-family: var(--font-mono); font-size: 1rem; }
.score-scale label:hover span { border-color: var(--ember); color: var(--text); }
.score-scale input:checked + span { background: var(--ember); border-color: var(--ember); color: var(--ink); font-weight: 500; }
.score-scale input:focus-visible + span { outline: 2px solid var(--ember-hot); outline-offset: 2px; }
.score-result { position: sticky; bottom: var(--s4); padding: var(--s6); border: 1px solid var(--line); background: var(--surface-2); text-align: center; }
.score-progress { margin: 0; color: var(--muted); font-size: 0.95rem; font-family: var(--font-mono); }
.score-total { font-family: var(--font-display); font-weight: 700; font-size: clamp(3rem, 7vw, 4.5rem); line-height: 1; margin: var(--s2) 0; color: var(--text); }
.score-of { font-size: 0.4em; color: var(--quiet); margin-left: 6px; }
.score-band { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: 1.4rem; margin: 0 0 var(--s2); }
.score-band[data-band="healthy"] { color: var(--band-healthy); }
.score-band[data-band="watch-list"] { color: var(--band-watch); }
.score-band[data-band="risk-register"] { color: var(--band-risk); }
.score-band[data-band="rescue-territory"] { color: var(--band-rescue); }
.score-band-desc { color: var(--muted); max-width: 56ch; margin: 0 auto var(--s5); font-size: 0.95rem; }
.score-actions { display: flex; justify-content: center; gap: var(--s3); flex-wrap: wrap; }

/* ============ Reference cards ============ */
.reference-grid { display: grid; gap: var(--s6); }
.reference-card { border: 1px solid var(--line); background: var(--surface); }
.reference-card .ref-media { display: block; border-bottom: 1px solid var(--line); }
.reference-card .ref-media img { display: block; width: 100%; aspect-ratio: 21/9; object-fit: cover; filter: saturate(0.92) contrast(1.04); }
.reference-card .ref-body { padding: var(--s6); }
.reference-card .ref-body h2 { font-size: clamp(1.8rem, 3.4vw, 2.8rem); max-width: 28ch; }
.reference-card .ref-body > p { color: var(--muted); max-width: 75ch; margin: 0 0 var(--s5); }
.reference-card dl { display: grid; gap: 0; margin: 0; border-top: 1px solid var(--line); }
.reference-card dl > div { padding: var(--s4) 0; border-bottom: 1px solid var(--line-soft); display: grid; grid-template-columns: 200px minmax(0, 1fr); gap: var(--s5); align-items: start; }
.reference-card dl > div:last-child { border-bottom: 0; }
.reference-card dt { font: 500 0.68rem/1.5 var(--font-mono); color: var(--ember); letter-spacing: 0.14em; text-transform: uppercase; margin-top: 2px; }
.reference-card dd { margin: 0; color: var(--muted); font-size: 0.95rem; line-height: 1.55; }
.reference-card dd strong { color: var(--text); }

/* ============ Legal pages ============ */
.legalpage h2 { font-size: 1.5rem; margin-top: var(--s6); }
.legalpage { color: var(--muted); max-width: 72ch; }

/* ============ Responsive ============ */
@media (max-width: 980px) {
  .split, .intake-head, .cta-forge-grid, .hero-lower { grid-template-columns: 1fr; }
  .part { grid-template-columns: 48px minmax(0, 1fr); grid-template-rows: auto auto auto; }
  .part .ptag { grid-column: 2; }
  .part .pbody { grid-column: 2; }
  .part .plink { grid-column: 2; justify-self: start; }
  .image-cards.three { grid-template-columns: 1fr; }
  .image-card img { aspect-ratio: 16/9; }
  .fit-list { grid-template-columns: 1fr; }
  .fit-list li:nth-child(2) { border-top: 1px solid var(--line-soft); padding-top: var(--s5); }
  .proof-row { grid-template-columns: 1fr; gap: var(--s2); }
  .service { grid-template-columns: 1fr; }
  .offer-grid { grid-template-columns: 1fr; }
  .tb-grid { grid-template-columns: 1fr 1fr; }
  .tb-cell:nth-child(odd) { border-left: 0; padding-left: 0; }
  .links, .navcta { display: none; }
  .menu {
    display: inline-flex; min-height: 44px; border: 1px solid var(--line);
    background: transparent; color: var(--text); padding: 10px 16px;
    font: 600 0.9rem var(--font-body); cursor: pointer;
  }
  .nav.open .links {
    display: flex; position: absolute; left: var(--s5); right: var(--s5); top: 72px;
    flex-direction: column; padding: var(--s4) var(--s5); gap: var(--s2);
    background: var(--surface-2); border: 1px solid var(--line);
  }
  .nav.open .links a { padding: var(--s2) 0; }
  .reference-card dl > div { grid-template-columns: 1fr; gap: var(--s1); }
}
@media (max-width: 620px) {
  .wrap { padding: 0 var(--s4); }
  .hero { padding: var(--s7) 0; }
  .section { padding: var(--s7) 0; }
  h1 { font-size: clamp(2.8rem, 13vw, 3.4rem); }
  .sub, .lead { font-size: 1.1rem; }
  .sheet-table th:nth-child(2), .sheet-table td:nth-child(2) { display: none; }
  .sheet-foot { grid-template-columns: 1fr; }
  .sheet-foot > div + div { border-left: 0; border-top: 1px solid var(--line); }
  .intake-shell { padding: var(--s5) var(--s4); }
  .intake-direct { align-items: flex-start; text-align: left; }
  .tb-grid { grid-template-columns: 1fr; }
  .tb-cell { padding: var(--s4) 0; }
  .tb-cell + .tb-cell { border-left: 0; border-top: 1px solid var(--line-soft); padding-left: 0; }
  .score-scale span { width: 42px; height: 42px; }
  .testimonial blockquote { padding: var(--s5); font-size: 1.15rem; }
  .reference-card .ref-body { padding: var(--s5) var(--s4); }
}

/* ============ Motion (state feedback only) ============ */
@media (prefers-reduced-motion: no-preference) {
  .btn, .links a, .image-card, .image-card span, .insight-title, .score-scale span {
    transition: color 0.16s cubic-bezier(0.22, 1, 0.36, 1), background-color 0.16s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.16s cubic-bezier(0.22, 1, 0.36, 1);
  }
}

/* Cal.com inline embed shell */
.cal-inline { min-height: 560px; margin-top: 1.5rem; }
.cal-inline .cal-fallback { padding: 1rem 0; }

/* Scorecard sheet download */
.score-bring { margin-top: .75rem; color: var(--dim, #8c8276); }
