/* ============================================================
   RECLAIM — site.css
   Marketing site layout, components & motion on top of the
   design-system tokens (styles.css). Trusted Operator:
   paper-and-ink craft + engineering precision. No bounce,
   no glow, ease-out only. Honors prefers-reduced-motion.
   ============================================================ */

/* ---------- Layout primitives ---------- */
.wrap { max-width: var(--container-max); margin: 0 auto; padding-inline: 40px; }
.section { padding-block: var(--space-section); border-bottom: 1px solid var(--border-subtle); }
.section--tight { padding-block: 56px; }
.eyebrow {
  font-family: var(--font-mono); font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--clay); margin: 0;
}
.eyebrow--brass { color: var(--brass); }
.sec-head h2 {
  font-family: var(--font-display); font-weight: 500; font-size: clamp(30px, 4vw, 40px);
  line-height: 1.05; letter-spacing: -0.01em; color: var(--ink); margin: 14px 0 8px;
}
.sec-head p {
  font-family: var(--font-serif); font-size: 19px; color: var(--text-body);
  max-width: 620px; margin: 0 0 40px;
}

/* ---------- Buttons (mirrors DS Button) ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans); font-weight: 500; font-size: 14px; line-height: 1;
  padding: 13px 20px; border-radius: var(--radius-sm); border: 1px solid transparent;
  cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: background var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard),
              color var(--dur-base) var(--ease-standard);
}
.btn .ico { width: 16px; height: 16px; transition: transform var(--dur-base) var(--ease-out); }
.btn-primary { background: var(--clay); color: #fff; }
.btn-primary:hover { background: var(--clay-dk); color: #fff; }
.btn-primary:hover .ico { transform: translateX(3px); }
.btn-secondary { background: transparent; color: var(--ink); border-color: var(--border-strong); }
.btn-secondary:hover { border-color: var(--brass); color: var(--ink); }
.btn-ghost { background: transparent; color: var(--bone); border-color: rgba(184,145,80,.4); }
.btn-ghost:hover { border-color: var(--brass); }
.btn-sm { padding: 9px 15px; font-size: 13px; }

/* ---------- Inline icons (self-hosted SVG, no CDN) ---------- */
svg.ico {
  width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round; display: inline-block; vertical-align: middle;
}

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 40px; background: rgba(244,241,234,0); backdrop-filter: blur(0px);
  border-bottom: 1px solid transparent;
  transition: background var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard),
              backdrop-filter var(--dur-base) var(--ease-standard);
}
.nav.is-scrolled {
  background: rgba(244,241,234,0.85); backdrop-filter: blur(8px);
  border-bottom-color: var(--border-subtle);
}
.nav__logo { height: 30px; display: block; }
.nav__links { display: flex; align-items: center; gap: 30px; }
.nav__links a:not(.btn) {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-body); position: relative;
}
.nav__links a:not(.btn)::after {
  content: ""; position: absolute; left: 0; bottom: -5px; height: 1px; width: 0;
  background: var(--clay); transition: width var(--dur-base) var(--ease-out);
}
.nav__links a:not(.btn):hover { color: var(--ink); }
.nav__links a:not(.btn):hover::after { width: 100%; }
.nav__toggle { display: none; background: none; border: 0; cursor: pointer; color: var(--ink); }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--border-subtle); }
.hero__grid {
  display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 48px; align-items: center;
  max-width: var(--container-max); margin: 0 auto; padding: 88px 40px 84px;
}
.hero h1 {
  font-family: var(--font-display); font-weight: 600; font-size: clamp(40px, 6vw, 62px);
  line-height: 1.0; letter-spacing: -0.025em; margin: 16px 0 18px; color: var(--ink);
}
.hero h1 em { color: var(--clay); font-style: italic; font-weight: 400; }
.hero__lead {
  font-family: var(--font-serif); font-size: var(--fs-lead); line-height: var(--lh-lead);
  color: var(--text-body); max-width: 470px; margin: 0 0 28px;
}
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero__trust {
  display: flex; gap: 18px; margin-top: 32px; align-items: center; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.1em;
  color: var(--text-muted); text-transform: uppercase;
}
.hero__trust .dot { color: var(--brass); }

/* faint routed background behind the whole hero */
.hero__bg { position: absolute; inset: 0; opacity: .5; pointer-events: none; }

/* ---------- Operator console (the live automation panel) ---------- */
.console {
  position: relative; background: var(--deep); border-radius: var(--radius-lg);
  padding: 22px 22px 20px; color: var(--bone); overflow: hidden;
  box-shadow: 0 24px 60px -28px rgba(19,32,30,.55);
}
.console__grid { position: absolute; inset: 0;
  background-image: radial-gradient(rgba(184,145,80,.16) 1.1px, transparent 1.1px);
  background-size: 30px 30px; }
.console__wash { position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 70% 0%, rgba(126,145,131,.18), transparent 60%); }
.console__inner { position: relative; }
.console__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.console__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--brass); }
.live { display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: #cdd4cf; }
.live__dot { width: 8px; height: 8px; border-radius: 999px; background: var(--ok); position: relative; }
.live__dot::after { content: ""; position: absolute; inset: 0; border-radius: 999px;
  background: var(--ok); animation: pulse 2.4s var(--ease-out) infinite; }
@keyframes pulse { 0% { transform: scale(1); opacity: .7; } 70%,100% { transform: scale(2.6); opacity: 0; } }

/* automation graph */
.graph { width: 100%; height: auto; display: block; margin: 4px 0 6px; }
.graph .route { fill: none; stroke: rgba(184,145,80,.34); stroke-width: 1.4; }
.graph .route--live { stroke: rgba(184,145,80,.5); }
.graph .chip { fill: rgba(244,241,234,.04); stroke: rgba(184,145,80,.32); }
.graph .chip-label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .04em; fill: #c8cfca; }
.graph .agent { fill: #16241F; stroke: var(--brass); stroke-width: 1.3; }
.graph .agent-ring { fill: none; stroke: var(--clay); stroke-width: 1.6; opacity: 0; }
.graph .agent-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: .16em; fill: var(--brass); text-anchor: middle; }
.graph .node-dot { fill: var(--sage); }
.packet { fill: var(--clay); }
.packet--brass { fill: var(--brass); }

/* metric strip */
.console__metrics { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 14px;
  border-top: 1px solid rgba(184,145,80,.28); margin-top: 12px; padding-top: 14px; }
.metric .m-val { font-family: var(--font-display); font-weight: 600; font-size: 30px; line-height: 1; color: #fff; }
.metric .m-val .u { font-family: var(--font-mono); font-size: 12px; color: #aeb6b1; margin-left: 4px; }
.metric .m-lab { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--brass); margin-top: 7px; }
.spark { display: block; margin-top: 4px; }
.spark path { fill: none; }

/* ---------- Live run-log strip ---------- */
.logstrip { background: var(--ink); color: #C4CAC4; }
.logstrip .wrap { display: flex; align-items: center; gap: 22px; padding-block: 16px; }
.logstrip__tag { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--brass); white-space: nowrap; display: inline-flex; gap: 9px; align-items: center; }
.logline { font-family: var(--font-mono); font-size: 13px; color: #d7ddd8; overflow: hidden; white-space: nowrap; }
.logline .ok { color: var(--ok); }
.logline .cur { color: var(--clay); }

/* ---------- Services ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.svc {
  position: relative; background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); padding: 24px; display: flex; flex-direction: column; gap: 12px;
  transition: border-color var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
  overflow: hidden;
}
.svc:hover { border-color: var(--brass); transform: translateY(-3px);
  box-shadow: 0 18px 36px -22px rgba(28,42,40,.45); }
.svc__top { display: flex; align-items: center; justify-content: space-between; }
.svc__icon { display: inline-flex; width: 40px; height: 40px; border-radius: var(--radius-sm);
  background: var(--clay-10); color: var(--clay-90); align-items: center; justify-content: center; }
.svc__icon .ico { width: 20px; height: 20px; }
.svc__n { font-family: var(--font-mono); font-size: 12px; color: var(--brass); letter-spacing: .12em; }
.svc h3 { font-family: var(--font-display); font-weight: 500; font-size: 21px; color: var(--ink); margin: 0; }
.svc p { font-family: var(--font-serif); font-size: 15px; color: var(--text-body); margin: 0; line-height: 1.55; }
/* routed accent that draws on hover */
.svc__route { position: absolute; right: 14px; bottom: 12px; width: 54px; height: 14px; opacity: .0;
  transition: opacity var(--dur-base) var(--ease-out); }
.svc:hover .svc__route { opacity: 1; }
.svc__route path { fill: none; stroke: var(--brass); stroke-width: 1.4;
  stroke-dasharray: 80; stroke-dashoffset: 80; }
.svc:hover .svc__route path { animation: draw 700ms var(--ease-out) forwards; }
@keyframes draw { to { stroke-dashoffset: 0; } }

/* ---------- Proof band ---------- */
.proof { background: var(--deep); color: var(--bone); position: relative; overflow: hidden; border: 0; }
.proof__grid { position: absolute; inset: 0;
  background-image: radial-gradient(rgba(184,145,80,.14) 1.1px, transparent 1.1px); background-size: 44px 44px; }
.proof .wrap { position: relative; padding-block: var(--space-section); }
.proof h2 { color: var(--bone); font-family: var(--font-display); font-weight: 500;
  font-size: clamp(30px,4vw,40px); line-height: 1.05; margin: 14px 0 40px; }
.cases { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.case { border-top: 2px solid var(--brass); padding-top: 18px; }
.case__metric { font-family: var(--font-display); font-weight: 600; font-size: 46px; line-height: 1; color: #fff; }
.case__metric .u { font-family: var(--font-mono); font-size: 15px; color: #aeb6b1; margin-left: 6px; }
.case__lab { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--brass); margin-top: 8px; }
.case__note { font-family: var(--font-serif); font-size: 15px; color: #C4CCC8; margin-top: 12px; line-height: 1.5; }
.case__client { font-family: var(--font-sans); font-size: 13px; color: var(--bone); margin-top: 14px; font-weight: 500; }
.pullquote { margin: 56px auto 0; max-width: 760px; text-align: center; }
.pullquote p { font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: clamp(22px,3vw,28px); line-height: 1.3; color: var(--bone); margin: 0; }
.pullquote footer { font-family: var(--font-mono); font-size: 12px; letter-spacing: .15em;
  text-transform: uppercase; color: var(--brass); margin-top: 18px; }

/* ---------- Approach pipeline (Design -> Build -> Operate) ---------- */
.pipeline { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: stretch; gap: 0; margin-top: 8px; }
.stage { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: 24px; }
.stage__n { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; color: var(--brass); }
.stage h3 { font-family: var(--font-display); font-weight: 500; font-size: 22px; color: var(--ink); margin: 10px 0 8px; }
.stage p { font-family: var(--font-serif); font-size: 15px; color: var(--text-body); margin: 0; line-height: 1.55; }
.connector { display: flex; align-items: center; justify-content: center; width: 56px; }
.connector svg { width: 56px; height: 20px; }
.connector path { fill: none; stroke: var(--brass); stroke-width: 1.6; stroke-dasharray: 4 4; }
.connector .head { fill: var(--clay); }

/* ---------- Closing CTA + footer ---------- */
.cta { text-align: center; }
.cta .kick { font-family: var(--font-mono); font-size: 13px; letter-spacing: .2em; text-transform: uppercase; color: var(--clay); margin: 0; }
.cta h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(34px,5vw,48px);
  line-height: 1.05; letter-spacing: -0.01em; margin: 16px 0 24px; color: var(--ink); }
.cta__form { display: flex; gap: 12px; justify-content: center; max-width: 460px; margin: 0 auto; flex-wrap: wrap; }
.field {
  width: 100%; font-family: var(--font-serif); font-size: 16px; color: var(--ink);
  background: var(--paper); border: 1px solid var(--border-strong); border-radius: var(--radius-sm);
  padding: 12px 14px; transition: border-color var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard);
}
.field:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px var(--ring); }
.cta__form .field { flex: 1 1 240px; width: auto; }

.site-footer { background: var(--ink); color: #C4CAC4; }
.site-footer .wrap { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; padding-block: 44px; }
.site-footer img { height: 28px; }
.site-footer .f-links { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; display: flex; gap: 24px; flex-wrap: wrap; }
.site-footer .f-links a { color: #C4CAC4; }
.site-footer .f-links a:hover { color: var(--bone); }
.site-footer .f-links a.brass { color: var(--brass); }

/* ---------- Reveal / stagger ---------- */
.reveal { opacity: 0; transform: translateY(16px); transition: var(--transition-reveal); }
.reveal.is-in { opacity: 1; transform: none; }
.stagger > * { opacity: 0; transform: translateY(16px); transition: var(--transition-reveal); }
.stagger.is-in > * { opacity: 1; transform: none; }
.stagger.is-in > *:nth-child(2) { transition-delay: 80ms; }
.stagger.is-in > *:nth-child(3) { transition-delay: 160ms; }
.stagger.is-in > *:nth-child(4) { transition-delay: 240ms; }
.stagger.is-in > *:nth-child(5) { transition-delay: 320ms; }
.stagger.is-in > *:nth-child(6) { transition-delay: 400ms; }

/* ---------- Page hero (interior pages) ---------- */
.phero { border-bottom: 1px solid var(--border-subtle); }
.phero .wrap { padding-block: 72px 56px; }
.phero h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(34px,5vw,52px);
  line-height: 1.02; letter-spacing: -0.02em; color: var(--ink); margin: 16px 0 16px; max-width: 16ch; }
.phero p { font-family: var(--font-serif); font-size: var(--fs-lead); color: var(--text-body); max-width: 60ch; margin: 0; }

/* prose (about / generic) */
.prose { max-width: var(--measure); }
.prose h2 { font-family: var(--font-display); font-weight: 500; font-size: 28px; color: var(--ink); margin: 40px 0 12px; }
.prose p { font-family: var(--font-serif); font-size: var(--fs-body); color: var(--text-body); line-height: var(--lh-body); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .wrap { padding-inline: 24px; }
  .nav { padding: 14px 24px; }
  .hero__grid { grid-template-columns: 1fr; gap: 36px; padding: 60px 24px 64px; }
  .svc-grid { grid-template-columns: 1fr 1fr; }
  .cases { grid-template-columns: 1fr; gap: 28px; }
  .pipeline { grid-template-columns: 1fr; }
  .connector { width: 100%; height: 36px; transform: rotate(90deg); }
}
@media (max-width: 600px) {
  .nav__links { display: none; }
  .nav__links.is-open { display: flex; position: absolute; top: 100%; right: 0; left: 0;
    flex-direction: column; align-items: flex-start; gap: 18px; padding: 20px 24px;
    background: var(--bone); border-bottom: 1px solid var(--border-subtle); }
  .nav__toggle { display: inline-flex; }
  .svc-grid { grid-template-columns: 1fr; }
  .logstrip .wrap { gap: 12px; }
  .console__metrics { grid-template-columns: 1fr 1fr; }
}

/* ---------- Services detail rows ---------- */
.svc-rows { display: grid; }
.svc-row { display: grid; grid-template-columns: 220px 1fr; gap: 40px; padding: 36px 0; border-top: 1px solid var(--border-subtle); }
.svc-rows .svc-row:last-child { border-bottom: 1px solid var(--border-subtle); }
.svc-row__head { display: flex; flex-direction: column; gap: 14px; }
.svc-row__num { font-family: var(--font-mono); font-size: 12px; letter-spacing: .16em; color: var(--brass); }
.svc-row__icon { width: 44px; height: 44px; border-radius: var(--radius-sm); background: var(--clay-10);
  color: var(--clay-90); display: inline-flex; align-items: center; justify-content: center; }
.svc-row__icon .ico { width: 22px; height: 22px; }
.svc-row h3 { font-family: var(--font-display); font-weight: 500; font-size: 26px; color: var(--ink); margin: 0; }
.svc-row__body > p { font-family: var(--font-serif); font-size: 17px; color: var(--text-body); margin: 0 0 16px; max-width: 62ch; }
.incl { display: flex; flex-wrap: wrap; gap: 8px; }
.incl span { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .03em; color: var(--slate);
  background: var(--bg-sunken); border: 1px solid var(--border-subtle); border-radius: var(--radius-xs); padding: 6px 10px; }

/* ---------- Work / case cards (light) ---------- */
.work-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.case-card { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md);
  padding: 28px; border-top: 3px solid var(--clay);
  transition: border-color var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-out); }
.case-card:hover { transform: translateY(-3px); border-color: var(--brass); border-top-color: var(--clay); }
.cc-metric { font-family: var(--font-display); font-weight: 600; font-size: 42px; color: var(--ink); line-height: 1; }
.cc-metric .u { font-family: var(--font-mono); font-size: 14px; color: var(--stone); margin-left: 6px; }
.cc-lab { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--brass); margin-top: 8px; }
.case-card h3 { font-family: var(--font-display); font-weight: 500; font-size: 20px; color: var(--ink); margin: 16px 0 8px; }
.case-card p { font-family: var(--font-serif); font-size: 15px; color: var(--text-body); margin: 0; line-height: 1.55; }
.case-card .who { font-family: var(--font-sans); font-size: 13px; font-weight: 500; color: var(--slate); margin-top: 14px; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.cform { display: flex; flex-direction: column; gap: 14px; max-width: 460px; }
.cform textarea.field { resize: vertical; min-height: 132px; }
.cform .btn { align-self: flex-start; }
.cform label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--stone); margin-bottom: -6px; }
.steps { display: flex; flex-direction: column; }
.step { display: grid; grid-template-columns: 36px 1fr; gap: 14px; padding: 18px 0; border-top: 1px solid var(--border-subtle); }
.step__n { font-family: var(--font-mono); font-size: 13px; color: var(--brass); }
.step h3 { font-family: var(--font-display); font-weight: 500; font-size: 18px; color: var(--ink); margin: 0 0 4px; }
.step p { font-family: var(--font-serif); font-size: 15px; color: var(--text-body); margin: 0; }
.direct { margin-top: 22px; font-family: var(--font-serif); font-size: 16px; color: var(--text-body); }
.direct a { color: var(--clay); border-bottom: 1px solid var(--clay-30); }

/* ---------- Founder note ---------- */
.founder { display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: start; max-width: 780px; }
.founder__avatar { width: 72px; height: 72px; border-radius: var(--radius-xl); background: var(--deep);
  color: var(--brass); display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 600; font-size: 26px; letter-spacing: .02em;
  border: 1px solid var(--border-strong); flex: none; }
.founder__note > p { font-family: var(--font-serif); font-size: 18px; line-height: 1.6; color: var(--text-body); margin: 0 0 16px; }
.founder__note .founder__signature { font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: 30px; color: var(--clay); margin: 16px 0 2px; line-height: 1; }
.founder__note .founder__role { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--stone); margin: 0; }
@media (max-width: 600px) { .founder { grid-template-columns: 1fr; gap: 16px; } }

/* ---------- Pricing ---------- */
.ladder-note { margin-top: 40px; padding: 22px 26px; background: var(--bg-sunken);
  border-left: var(--border-accent) solid var(--brass); border-radius: var(--radius-md); max-width: 820px; }
.ladder-note p { font-family: var(--font-serif); font-size: 17px; color: var(--text-body); margin: 0; }
.ladder-note strong { color: var(--ink); font-weight: 600; }
.tiers { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 8px; }
.tier { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md);
  padding: 30px; display: flex; flex-direction: column; }
.tier--feature { border-color: var(--brass); border-top: var(--border-accent) solid var(--clay);
  box-shadow: 0 18px 40px -26px rgba(28,42,40,.4); }
.tier__badge { align-self: flex-start; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--clay-90); background: var(--clay-10); border-radius: var(--radius-xs);
  padding: 5px 9px; margin-bottom: 14px; }
.tier__name { font-family: var(--font-display); font-weight: 500; font-size: 24px; color: var(--ink); margin: 0 0 6px; }
.tier__price { font-family: var(--font-display); font-weight: 600; font-size: 34px; color: var(--ink); line-height: 1; margin: 8px 0 2px; }
.tier__price .per { font-family: var(--font-mono); font-size: 13px; color: var(--stone); margin-left: 6px; font-weight: 400; }
.tier__sub { font-family: var(--font-serif); font-size: 15px; color: var(--text-body); margin: 8px 0 20px; }
.tier__list { list-style: none; padding: 0; margin: 0 0 26px; display: flex; flex-direction: column; gap: 11px; }
.tier__list li { font-family: var(--font-serif); font-size: 15px; color: var(--text-body);
  display: grid; grid-template-columns: 18px 1fr; gap: 10px; align-items: start; line-height: 1.5; }
.tier__list .ck { color: var(--ok); margin-top: 2px; }
.tier .btn { align-self: flex-start; margin-top: auto; }
@media (max-width: 900px) { .tiers { grid-template-columns: 1fr; } }

/* ---------- FAQ accordion (native <details>) ---------- */
.faq { max-width: 820px; }
.faq details { border-top: 1px solid var(--border-subtle); }
.faq details:last-of-type { border-bottom: 1px solid var(--border-subtle); }
.faq summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between;
  align-items: center; gap: 20px; padding: 22px 0; font-family: var(--font-display); font-weight: 500;
  font-size: 20px; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary:hover { color: var(--clay); }
.faq .pm { flex: none; width: 22px; height: 22px; position: relative; color: var(--clay);
  transition: transform var(--dur-base) var(--ease-out); }
.faq details[open] .pm { transform: rotate(45deg); }
.faq .pm::before, .faq .pm::after { content: ""; position: absolute; background: currentColor; }
.faq .pm::before { left: 1px; right: 1px; top: 10px; height: 2px; }
.faq .pm::after { top: 1px; bottom: 1px; left: 10px; width: 2px; }
.faq details p { font-family: var(--font-serif); font-size: 16px; line-height: 1.6;
  color: var(--text-body); margin: 0 0 22px; max-width: 72ch; }

/* ---------- Testimonials ---------- */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.qcard { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md);
  padding: 26px; display: flex; flex-direction: column; }
.qcard .mark { font-family: var(--font-display); font-weight: 600; font-size: 44px; line-height: .5;
  color: var(--brass); height: 20px; }
.qcard p { font-family: var(--font-serif); font-size: 16px; line-height: 1.55; color: var(--text-body); margin: 16px 0 18px; }
.qcard .who { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--stone); margin-top: auto; }
.qcard--placeholder { border-style: dashed; background: transparent; }
.qcard--placeholder p { color: var(--text-muted); font-style: italic; }
@media (max-width: 900px) { .quotes { grid-template-columns: 1fr; } }

/* ---------- Case study ---------- */
.cs-block { max-width: 760px; }
.cs-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.cs-metric { border-top: var(--border-rule) solid var(--brass); padding-top: 14px; }
.cs-metric .v { font-family: var(--font-display); font-weight: 600; font-size: 38px; color: var(--ink); line-height: 1; }
.cs-metric .v .u { font-family: var(--font-mono); font-size: 13px; color: var(--stone); margin-left: 4px; font-weight: 400; }
.cs-metric .l { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--brass); margin-top: 8px; }
.cs-meta { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 22px; font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); }
.cs-meta b { color: var(--brass); font-weight: 500; }
@media (max-width: 900px) { .cs-metrics { grid-template-columns: 1fr 1fr; } }

/* ---------- What we won't claim ---------- */
.wont { max-width: 900px; }
.wont__row { display: grid; grid-template-columns: auto 1fr; gap: 18px; padding: 22px 0; align-items: start; border-top: 1px solid var(--border-subtle); }
.wont .wont__row:last-child { border-bottom: 1px solid var(--border-subtle); }
.wont__x { width: 28px; height: 28px; border-radius: var(--radius-sm); background: var(--clay-10); color: var(--clay-90);
  display: inline-flex; align-items: center; justify-content: center; flex: none; }
.wont__x .ico { width: 16px; height: 16px; }
.wont__no { font-family: var(--font-display); font-weight: 500; font-size: 20px; color: var(--ink); margin: 0 0 5px; }
.wont__yes { font-family: var(--font-serif); font-size: 16px; color: var(--text-body); margin: 0; line-height: 1.55; }
.wont__yes b { color: var(--ink); font-weight: 600; }

/* ---------- How we measure (provenance note) ---------- */
.method { border: 1px solid var(--border-subtle); border-left: var(--border-accent) solid var(--brass);
  border-radius: var(--radius-md); padding: 20px 24px; max-width: 760px; }
.method__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--brass); margin: 0 0 8px; }
.method p:last-child { font-family: var(--font-serif); font-size: 15px; line-height: 1.6; color: var(--text-body); margin: 0; }
.method--dark { border-color: rgba(184,145,80,.28); border-left-color: var(--brass); }
.method--dark p:last-child { color: #C4CCC8; }

@media (max-width: 900px) {
  .svc-row { grid-template-columns: 1fr; gap: 16px; }
  .work-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .reveal, .stagger > * { opacity: 1 !important; transform: none !important; transition: none !important; }
  .live__dot::after { animation: none; }
  .svc:hover .svc__route path { animation: none; stroke-dashoffset: 0; }
  html { scroll-behavior: auto; }
}
