/* ============================================================
   RunLeanTools — shared design system
   Navy · Copper · Sand · warm off-white
   Type: Newsreader (display serif) + Hanken Grotesk (body)
   ============================================================ */
:root{
  --bg:#FAF8F3;
  --surface:#FFFFFF;
  --band:#F0E9DA;
  --band-2:#E8DEC9;
  --navy:#13293D;
  --navy-2:#1E3A5F;
  --navy-deep:#0E2031;
  --copper:#B56A3B;
  --copper-700:#9C5832;
  --copper-tint:#F3E7DC;
  --sand:#D9C7A3;
  --sand-soft:#EFE7D5;
  --ink:#111827;
  --muted:#6B7280;
  --line:#E7E0D2;
  --line-soft:#EFEADF;
  --maxw:1160px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Hanken Grotesk', system-ui, sans-serif;
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ margin:0; font-family:'Newsreader', Georgia, serif; font-weight:600; letter-spacing:-0.012em; line-height:1.05; color:var(--navy); }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.narrow{ max-width:880px; margin-left:auto; margin-right:auto; }
section{ position:relative; }

/* ---------- type helpers ---------- */
.eyebrow{ font-size:12.5px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); margin:0 0 22px; display:block; }
.eyebrow.center{ text-align:center; }
.eyebrow.copper{ color:var(--copper); }
.eyebrow.sand{ color:var(--sand); }
.h-sec{ font-size:52px; font-weight:600; letter-spacing:-0.018em; }
.h-sec em, .h-split em, .hero h1 em{ font-style:italic; color:var(--copper); }
.h-split{ font-size:46px; font-weight:600; letter-spacing:-0.015em; }
.lede{ font-size:19px; color:var(--muted); line-height:1.55; }
@media (max-width:760px){ .h-sec{ font-size:34px; } .h-split{ font-size:32px; } }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:16px;
  padding:15px 28px; border-radius:10px; cursor:pointer; border:1px solid transparent;
  font-family:'Hanken Grotesk', sans-serif; line-height:1; white-space:nowrap;
  transition:background .16s ease, transform .16s ease, color .16s ease, border-color .16s ease; }
.btn .arr{ transition:transform .18s ease; }
.btn:hover .arr{ transform:translateX(3px); }
.btn-primary{ background:var(--copper); color:#fff; }
.btn-primary:hover{ background:var(--copper-700); }
.btn-navy{ background:var(--navy); color:#fff; }
.btn-navy:hover{ background:var(--navy-2); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--navy); color:var(--navy); }
.btn-cream{ background:var(--bg); color:var(--navy); }
.btn-cream:hover{ background:#fff; }
.btn-sm{ padding:12px 22px; font-size:15px; }
.textlink{ font-weight:600; font-size:15.5px; color:var(--ink); display:inline-flex; align-items:center; gap:7px; border-bottom:1.5px solid var(--copper); padding-bottom:2px; }
.textlink:hover{ color:var(--copper); }
.pill{ font-size:14.5px; font-weight:500; color:var(--muted); background:var(--surface); border:1px solid var(--line); padding:9px 20px; border-radius:999px; }

/* ---------- nav ---------- */
header.nav{ position:sticky; top:0; z-index:60; background:rgba(250,248,243,.86);
  backdrop-filter:saturate(160%) blur(12px); border-bottom:1px solid var(--line-soft); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:78px; gap:24px; }
.wm{ font-family:'Newsreader', serif; font-weight:600; font-size:24px; letter-spacing:-0.01em; color:var(--navy); }
.wm em{ font-style:normal; color:var(--copper); }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ font-size:15px; font-weight:500; color:var(--muted); transition:color .15s; }
.nav-links a:hover, .nav-links a.active{ color:var(--navy); }
@media (max-width:900px){ .nav-links{ display:none; } }

/* ---------- sections ---------- */
.sec{ padding:108px 0; }
.sec.band{ background:var(--band); border-top:1px solid var(--band-2); border-bottom:1px solid var(--band-2); }
.sec.navy{ background:var(--navy); color:var(--bg); }
.sec.navy .head-c h2, .sec.navy .head-c .h-sec, .sec.navy .head-c h3, .sec.navy .ctaband h2{ color:var(--bg); }
.sec.navy .head-c .h-sec em, .sec.navy .head-c h2 em{ color:var(--sand); }
.sec.navy .lede{ color:#A9B6C4; }
.sec.navy .eyebrow{ color:#8FA1B2; }
.sec.navy .eyebrow.copper{ color:#E0A576; }
.sec.navy .eyebrow.sand{ color:var(--sand); }
.rule-copper{ height:3px; width:54px; background:var(--copper); border-radius:3px; }
.head-c{ text-align:center; max-width:760px; margin:0 auto; }
@media (max-width:760px){ .sec{ padding:74px 0; } }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
@media (max-width:920px){ .split{ grid-template-columns:1fr; gap:48px; } }
.split p.lede{ margin-top:22px; } .split .cta-row{ margin-top:34px; display:flex; gap:16px; align-items:center; flex-wrap:wrap; }

/* ============================================================
   WORKFLOW DIAGNOSTIC
   ============================================================ */
.pmap{ background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:26px 26px 24px;
  box-shadow:0 44px 84px -56px rgba(19,41,61,.45); }
.pmap.on-navy{ background:#173247; border-color:#244257; box-shadow:none; }
.pmap-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.pmap-top .pt{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); }
.pmap.on-navy .pmap-top .pt{ color:#8FA1B2; }
.pmap-top .pbadge{ font-size:12px; font-weight:600; color:var(--copper); background:var(--copper-tint); padding:5px 12px; border-radius:999px; }
.pmap.on-navy .pmap-top .pbadge{ background:rgba(181,106,59,.2); color:#E0A576; }
.pnode{ display:flex; align-items:center; gap:14px; padding:16px 18px; border-radius:12px; background:var(--bg); border:1px solid var(--line-soft); }
.pmap.on-navy .pnode{ background:#1B3B52; border-color:#264a63; }
.pdot{ width:10px; height:10px; border-radius:50%; background:var(--navy-2); flex-shrink:0; }
.pmap.on-navy .pdot{ background:#5E7C95; }
.pn{ font-size:16px; font-weight:600; color:var(--ink); }
.pmap.on-navy .pn{ color:#E7EDF3; }
.pn small{ display:block; font-weight:400; font-size:12.5px; color:var(--muted); margin-top:2px; }
.pmeta{ margin-left:auto; font-size:12.5px; color:var(--muted); font-weight:500; }
.pconn{ display:flex; justify-content:center; padding:6px 0; }
.pconn svg{ width:18px; height:18px; color:#B9B09C; }
.pmap.on-navy .pconn svg{ color:#3E5A72; }
.pnode.flag{ background:var(--copper-tint); border-color:#E7C9AE; }
.pmap.on-navy .pnode.flag{ background:rgba(181,106,59,.16); border-color:rgba(181,106,59,.5); }
.pnode.flag .pdot{ background:var(--copper); }
.pflag{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; color:var(--copper); }
.pmap.on-navy .pnode.flag .pn{ color:#F0DCC9; }
.pmap.on-navy .pflag{ color:#E0A576; }
.pnode.good{ background:rgba(30,58,95,.06); border-color:#CBD6E0; }
.pmap.on-navy .pnode.good{ background:rgba(217,199,163,.1); border-color:rgba(217,199,163,.36); }
.pnode.good .pdot{ background:var(--navy); }
.pmap.on-navy .pnode.good .pdot{ background:var(--sand); }
.pnode.good .pmeta{ color:var(--navy); }
.pmap.on-navy .pnode.good .pmeta{ color:var(--sand); }
.pmap-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:22px; padding-top:20px; border-top:1px solid var(--line-soft); }
.pmap.on-navy .pmap-foot{ border-top-color:#264a63; }
.pmap-foot .pfk{ font-size:13px; color:var(--muted); }
.pmap.on-navy .pmap-foot .pfk{ color:#8FA1B2; }
.pmap-foot .pfv{ font-family:'Newsreader',serif; font-size:30px; font-weight:600; color:var(--copper); letter-spacing:-0.02em; }
.pmap.on-navy .pmap-foot .pfv{ color:var(--sand); }
.pgroup-label{ font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin:18px 0 12px; }
.pmap.on-navy .pgroup-label{ color:#7E92A4; }

/* ============================================================
   SCORECARD / REPORT
   ============================================================ */
.report{ background:var(--surface); border:1px solid var(--line); border-radius:18px; overflow:hidden;
  box-shadow:0 50px 90px -56px rgba(19,41,61,.5); }
.report-bar{ display:flex; align-items:center; gap:8px; padding:15px 20px; background:var(--band); border-bottom:1px solid var(--line); }
.report-bar i{ width:11px; height:11px; border-radius:50%; background:#D2C9B4; display:block; }
.report-bar i:first-child{ background:var(--copper); }
.report-bar .rb-name{ margin-left:10px; font-size:13px; color:var(--muted); letter-spacing:0.02em; }
.report-body{ padding:34px 38px 38px; }
.report-top{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.report-top .rt-eyebrow{ font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
.report-top h3{ font-size:30px; font-weight:600; margin-top:8px; letter-spacing:-0.015em; }
.report-top .rt-meta{ font-size:13.5px; color:var(--muted); margin-top:8px; }
.report-top .rt-meta b{ color:var(--ink); font-weight:600; }
.report-grade{ text-align:center; flex-shrink:0; }
.report-grade .g{ font-family:'Newsreader',serif; font-size:56px; font-weight:600; color:var(--copper); line-height:1; }
.report-grade .gk{ font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin-top:4px; }
.report-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:30px 0; }
.rstat{ background:var(--bg); border:1px solid var(--line-soft); border-radius:12px; padding:18px 20px; }
.rstat .v{ font-family:'Newsreader',serif; font-size:38px; font-weight:600; letter-spacing:-0.02em; line-height:1; color:var(--navy); }
.rstat .v small{ font-size:17px; color:var(--muted); margin-left:3px; }
.rstat .v.copper{ color:var(--copper); }
.rstat .k{ font-size:13px; color:var(--muted); margin-top:8px; }
.rrows-h{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.rrow{ display:flex; align-items:center; gap:16px; padding:13px 0; border-top:1px solid var(--line-soft); }
.rrow:first-of-type{ border-top:none; }
.rrow .rl{ font-size:15px; font-weight:500; width:210px; flex-shrink:0; }
.rtrack{ flex:1; height:9px; background:var(--band); border-radius:6px; overflow:hidden; }
.rtrack span{ display:block; height:100%; border-radius:6px; background:var(--navy-2); }
.rtrack span.copper{ background:var(--copper); }
.rrow .rtag{ font-size:12px; font-weight:600; width:74px; text-align:right; color:var(--muted); }
.rrow .rtag.hot{ color:var(--copper); }
@media (max-width:680px){ .report-body{ padding:24px; } .rrow .rl{ width:130px; font-size:13.5px; } }

/* ---------- includes checklist ---------- */
.incard{ background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:34px 36px; }
.sec.band .incard{ background:var(--bg); }
.incard .ic-h{ font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.ic-row{ display:flex; align-items:center; gap:16px; padding:18px 0; border-bottom:1px solid var(--line); font-size:16.5px; font-weight:500; }
.ic-row:last-child{ border-bottom:none; padding-bottom:0; }
.ic-check{ width:28px; height:28px; border-radius:8px; background:var(--navy); color:#fff; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.ic-check svg{ width:16px; height:16px; }

/* ---------- problem leaks ---------- */
.leaks{ display:grid; grid-template-columns:repeat(4,1fr); margin-top:54px; border-top:1px solid var(--line); }
@media (max-width:820px){ .leaks{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .leaks{ grid-template-columns:1fr; } }
.leak{ padding:30px 26px 30px 0; border-bottom:1px solid var(--line); }
.leak .lk-n{ font-family:'Newsreader',serif; font-size:20px; font-weight:600; color:var(--copper); }
.leak h3{ font-size:21px; font-weight:600; margin-top:14px; letter-spacing:-0.01em; }
.leak p{ font-size:14.5px; color:var(--muted); margin-top:8px; line-height:1.5; }

/* ---------- how it works ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; margin-top:56px; }
@media (max-width:820px){ .steps{ grid-template-columns:1fr 1fr; gap:36px 26px; } }
@media (max-width:480px){ .steps{ grid-template-columns:1fr; } }
.step .sbar{ height:3px; background:var(--line); border-radius:3px; position:relative; overflow:hidden; margin-bottom:20px; }
.step .sbar::after{ content:''; position:absolute; inset:0; background:var(--copper); border-radius:3px; }
.step:nth-child(1) .sbar::after{ opacity:1; }
.step:nth-child(2) .sbar::after{ opacity:.7; }
.step:nth-child(3) .sbar::after{ opacity:.45; }
.step:nth-child(4) .sbar::after{ opacity:.25; }
.step .sn{ font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--copper); font-weight:600; }
.step h3{ font-size:21px; font-weight:600; margin-top:12px; letter-spacing:-0.01em; }
.step p{ font-size:14.5px; color:var(--muted); margin-top:9px; line-height:1.5; }

/* ---------- timeline ---------- */
.timeline{ margin-top:8px; }
.tlrow{ display:flex; gap:20px; padding-bottom:30px; position:relative; }
.tlrow:last-child{ padding-bottom:0; }
.tlrow::before{ content:''; position:absolute; left:18px; top:40px; bottom:-2px; width:2px; background:var(--line); }
.tlrow:last-child::before{ display:none; }
.tlnum{ width:38px; height:38px; border-radius:50%; background:var(--navy); color:#fff; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:'Newsreader',serif; font-size:17px; font-weight:600; z-index:1; }
.tlrow h4{ font-size:18px; font-weight:600; margin:6px 0 0; font-family:'Newsreader',serif; }
.tlrow p{ font-size:14.5px; color:var(--muted); margin-top:5px; line-height:1.45; }

/* ============================================================
   DELIVERABLE CARDS
   ============================================================ */
.dgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:54px; }
@media (max-width:880px){ .dgrid{ grid-template-columns:1fr; } }
.dcard{ background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:30px 28px; }
.sec.band .dcard{ background:var(--bg); }
.dcard h3{ font-size:21px; font-weight:600; letter-spacing:-0.01em; margin-bottom:24px; }

.imatrix{ display:grid; grid-template-columns:14px 1fr; grid-template-rows:1fr 14px; gap:9px; }
.im-y{ grid-column:1; grid-row:1; writing-mode:vertical-rl; transform:rotate(180deg); align-self:center; justify-self:center; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); }
.im-x{ grid-column:2; grid-row:2; text-align:center; font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); }
.im-grid{ grid-column:2; grid-row:1; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:10px; }
.im-cell{ background:var(--bg); border:1px solid var(--line-soft); border-radius:11px; padding:14px 13px; min-height:88px; display:flex; flex-direction:column; gap:5px; }
.im-cell.hot{ background:var(--copper-tint); border-color:#E7C9AE; }
.im-name{ font-family:'Newsreader',serif; font-size:16px; font-weight:600; line-height:1.1; }
.im-cell.hot .im-name{ color:var(--copper); }
.im-cell.muted .im-name, .im-cell.muted .im-sub{ color:#A9A492; }
.im-sub{ font-size:11px; color:var(--muted); line-height:1.3; }

.tstack{ display:flex; flex-direction:column; gap:18px; }
.tsr{ display:flex; align-items:center; gap:16px; }
.tsn{ font-family:'Newsreader',serif; font-size:22px; font-weight:600; color:var(--copper); width:16px; }
.tsm{ width:42px; height:42px; border-radius:11px; background:var(--bg); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; color:var(--navy); flex-shrink:0; }
.tst{ font-size:16px; font-weight:600; } .tst small{ display:block; font-weight:400; font-size:13px; color:var(--muted); margin-top:1px; }

.dplan{ display:flex; flex-direction:column; gap:18px; }
.dpr{ display:flex; align-items:flex-start; gap:13px; font-size:15.5px; color:var(--muted); line-height:1.4; }
.dpb{ width:19px; height:19px; border-radius:5px; border:1.6px solid var(--navy); flex-shrink:0; margin-top:2px; display:flex; align-items:center; justify-content:center; }
.dpb svg{ width:12px; height:12px; color:var(--navy); }
.dpr b{ font-weight:600; color:var(--ink); }

/* ---------- stat band ---------- */
.stats4{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center; }
@media (max-width:760px){ .stats4{ grid-template-columns:1fr 1fr; gap:42px 24px; } }
.stat-b .sv{ font-family:'Newsreader',serif; font-size:58px; font-weight:600; color:var(--sand); letter-spacing:-0.02em; line-height:1; }
.stat-b .sk{ font-size:14px; color:#A9B6C4; margin-top:12px; }
@media (max-width:760px){ .stat-b .sv{ font-size:44px; } }

/* ============================================================
   PRICING OFFER
   ============================================================ */
.offer{ background:var(--surface); border:1.5px solid var(--navy); border-radius:20px; padding:42px 40px; position:relative; overflow:hidden; }
.sec.band .offer{ background:var(--bg); }
.offer::after{ content:''; position:absolute; top:-70px; right:-70px; width:220px; height:220px; border-radius:50%; background:var(--sand-soft); }
.offer-eyebrow{ font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); position:relative; }
.offer-price{ font-family:'Newsreader',serif; font-size:66px; font-weight:600; letter-spacing:-0.02em; line-height:1; margin-top:16px; position:relative; color:var(--navy); }
.offer-price small{ font-family:'Hanken Grotesk',sans-serif; font-size:17px; font-weight:500; color:var(--muted); margin-left:8px; letter-spacing:0; }
.offer-list{ list-style:none; margin:28px 0 32px; padding:0; position:relative; }
.offer-list li{ display:flex; align-items:flex-start; gap:13px; font-size:16px; padding:8px 0; line-height:1.4; }
.offer-list svg{ width:19px; height:19px; color:var(--copper); flex-shrink:0; margin-top:2px; }
.offer .delivery{ position:relative; display:flex; gap:24px; margin:0 0 30px; padding-top:24px; border-top:1px solid var(--line); }
.offer .delivery div .dv{ font-family:'Newsreader',serif; font-size:24px; font-weight:600; color:var(--ink); }
.offer .delivery div .dk{ font-size:12.5px; color:var(--muted); margin-top:2px; }

/* ============================================================
   FINDINGS
   ============================================================ */
.findings{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:54px; }
@media (max-width:820px){ .findings{ grid-template-columns:1fr; } }
.finding{ background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:28px 28px; }
.sec.band .finding{ background:var(--bg); }
.finding-top{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:16px; }
.finding-top h3{ font-size:20px; font-weight:600; letter-spacing:-0.01em; }
.sev{ font-size:11.5px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; padding:5px 11px; border-radius:999px; }
.sev.crit{ background:var(--copper-tint); color:var(--copper); }
.sev.high{ background:var(--copper-tint); color:var(--copper); }
.sev.med{ background:var(--sand-soft); color:#8A7B57; }
.finding .fmeta{ display:flex; gap:28px; margin-bottom:16px; }
.finding .fmeta .fm-v{ font-family:'Newsreader',serif; font-size:26px; font-weight:600; color:var(--navy); line-height:1; }
.finding .fmeta .fm-v.copper{ color:var(--copper); }
.finding .fmeta .fm-k{ font-size:12px; color:var(--muted); margin-top:5px; }
.finding .frec{ font-size:14.5px; color:var(--muted); line-height:1.5; padding-top:16px; border-top:1px solid var(--line-soft); }
.finding .frec b{ color:var(--ink); font-weight:600; }

/* ============================================================
   LARGE IMPACT vs EFFORT MATRIX
   ============================================================ */
.matrix-wrap{ max-width:780px; margin:54px auto 0; }
.matrix{ display:grid; grid-template-columns:26px 1fr; grid-template-rows:1fr 26px; gap:12px; }
.mx-y{ grid-column:1; grid-row:1; writing-mode:vertical-rl; transform:rotate(180deg); align-self:center; justify-self:center; font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.mx-x{ grid-column:2; grid-row:2; text-align:center; font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.mx-grid{ grid-column:2; grid-row:1; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:16px; }
.mx-cell{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:22px 22px; min-height:180px; display:flex; flex-direction:column; }
.sec.band .mx-cell{ background:var(--bg); }
.mx-cell.hot{ background:var(--copper-tint); border-color:#E7C9AE; }
.mx-cell .mx-name{ font-family:'Newsreader',serif; font-size:22px; font-weight:600; }
.mx-cell.hot .mx-name{ color:var(--copper); }
.mx-cell .mx-sub{ font-size:12px; color:var(--muted); margin-top:4px; letter-spacing:0.02em; }
.mx-items{ margin-top:16px; display:flex; flex-direction:column; gap:8px; }
.mx-item{ font-size:13.5px; color:var(--ink); display:flex; align-items:center; gap:9px; }
.mx-item::before{ content:''; width:7px; height:7px; border-radius:50%; background:var(--navy-2); flex-shrink:0; }
.mx-cell.hot .mx-item::before{ background:var(--copper); }
.mx-cell.muted .mx-name, .mx-cell.muted .mx-item{ color:#A9A492; }
.mx-cell.muted .mx-item::before{ background:#C9C2B0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ max-width:860px; margin:48px auto 0; }
details.faq{ border-bottom:1px solid var(--line); }
details.faq summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:26px 4px; font-family:'Newsreader',serif; font-size:21px; font-weight:600; color:var(--ink); }
details.faq summary::-webkit-details-marker{ display:none; }
.fq-chev{ width:22px; height:22px; flex-shrink:0; color:var(--copper); transition:transform .22s ease; }
details.faq[open] .fq-chev{ transform:rotate(180deg); }
details.faq .fq-a{ padding:0 4px 28px; font-size:16px; color:var(--muted); line-height:1.6; max-width:64ch; }

/* ============================================================
   BOOKING
   ============================================================ */
.bookcard{ max-width:1000px; margin:50px auto 0; background:var(--surface); border:1px solid var(--line); border-radius:22px; display:grid; grid-template-columns:1fr 1fr; overflow:hidden; box-shadow:0 44px 84px -56px rgba(19,41,61,.4); }
@media (max-width:820px){ .bookcard{ grid-template-columns:1fr; } }
.book-col{ padding:36px 36px; }
.book-col + .book-col{ border-left:1px solid var(--line); }
@media (max-width:820px){ .book-col + .book-col{ border-left:none; border-top:1px solid var(--line); } }
.book-h{ font-size:18px; font-weight:600; font-family:'Newsreader',serif; margin-bottom:24px; }
.cal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.cal-head .cm{ font-size:15.5px; font-weight:600; }
.cal-nav{ width:30px; height:30px; border-radius:8px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--muted); cursor:pointer; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; text-align:center; }
.cal-grid .dow{ font-size:11.5px; color:var(--muted); padding:6px 0; font-weight:600; }
.cal-grid .day{ font-size:14px; padding:9px 0; border-radius:8px; color:var(--ink); cursor:pointer; }
.cal-grid .day.mut{ color:#BEB6A4; }
.cal-grid .day.sel{ background:var(--navy); color:#fff; font-weight:600; }
.cal-grid .day:not(.mut):not(.sel):hover{ background:var(--band); }
.field{ margin-bottom:18px; } .field.row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field label{ display:block; font-size:13px; color:var(--muted); margin-bottom:7px; font-weight:500; }
.field input, .field textarea{ width:100%; font-family:inherit; font-size:15px; color:var(--ink); background:var(--bg); border:1px solid var(--line); border-radius:10px; padding:12px 14px; outline:none; }
.field input:focus, .field textarea:focus{ border-color:var(--navy); }
.book-submit{ width:100%; justify-content:center; margin-top:4px; }

/* ---------- dark CTA ---------- */
.ctaband{ text-align:center; max-width:760px; margin:0 auto; }
.ctaband h2{ font-size:54px; font-weight:600; letter-spacing:-0.02em; color:var(--bg); }
.ctaband h2 em{ font-style:italic; color:var(--sand); }
.ctaband p{ font-size:19px; color:#A9B6C4; margin-top:20px; line-height:1.55; }
.ctaband .btn-row{ margin-top:36px; display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }
@media (max-width:760px){ .ctaband h2{ font-size:36px; } }

/* ---------- footer ---------- */
footer.ft{ background:var(--navy-deep); color:var(--bg); padding:64px 0 36px; }
.ft-top{ display:block; }
.ft .wm{ color:var(--bg); } .ft .wm em{ color:var(--sand); }
.ft-tag{ font-size:14.5px; color:#8FA1B2; margin-top:16px; max-width:44ch; line-height:1.55; }
.ft-col h5{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:#5E7589; margin:0 0 16px; font-weight:600; }
.ft-col a{ display:block; font-size:15px; color:#B7C2CE; margin-bottom:12px; transition:color .15s; }
.ft-col a:hover{ color:var(--sand); }
.ft-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-top:48px; padding-top:26px; border-top:1px solid #23394C; font-size:13px; color:#5E7589; }
@media (max-width:540px){ .ft-bottom{ flex-direction:column; align-items:flex-start; gap:6px; } }

/* ============================================================
   DIAGNOSTIC TILES
   ============================================================ */
.diag-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:50px; }
@media (max-width:760px){ .diag-grid{ grid-template-columns:1fr; } }
.diag{ background:#173247; border:1px solid #264a63; border-radius:16px; padding:26px 28px; display:flex; gap:20px; align-items:flex-start; }
.diag .dn{ font-family:'Newsreader',serif; font-size:22px; font-weight:600; color:var(--sand); width:30px; flex-shrink:0; line-height:1.3; }
.diag .dbody{ flex:1; }
.diag .dbody h3{ font-size:20px; font-weight:600; color:#EAF0F5; letter-spacing:-0.01em; }
.diag .dbody p{ font-size:14.5px; color:#9FB0C0; margin-top:8px; line-height:1.5; }
.diag .bar{ height:6px; background:#0F2536; border-radius:4px; margin-top:16px; overflow:hidden; max-width:200px; }
.diag .bar span{ display:block; height:100%; background:var(--copper); border-radius:4px; }
.diag .dtag{ flex-shrink:0; text-align:right; }
.diag .dtag .dv{ font-family:'Newsreader',serif; font-size:24px; font-weight:600; color:#E0A576; line-height:1; }
.diag .dtag .dk{ font-size:10.5px; color:#7E92A4; letter-spacing:0.1em; text-transform:uppercase; margin-top:5px; }

/* ============================================================
   PROCESS-MAP STEP RIBBON
   ============================================================ */
.flowsteps{ display:flex; justify-content:space-between; gap:20px; margin-top:62px; position:relative; }
.flowsteps::before{ content:''; position:absolute; left:9%; right:9%; top:28px; height:2px; background:var(--line); z-index:0; }
.fstep{ flex:1; text-align:center; position:relative; z-index:1; }
.fstep .fc{ width:56px; height:56px; border-radius:50%; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; font-family:'Newsreader',serif; font-size:22px; font-weight:600; margin:0 auto 20px; border:5px solid var(--bg); }
.sec.band .fstep .fc{ border-color:var(--band); }
.fstep:last-child .fc{ background:var(--copper); }
.fstep h3{ font-size:20px; font-weight:600; letter-spacing:-0.01em; }
.fstep p{ font-size:14px; color:var(--muted); margin-top:9px; max-width:24ch; margin-inline:auto; line-height:1.5; }
@media (max-width:760px){ .flowsteps{ flex-direction:column; gap:30px; } .flowsteps::before{ display:none; } }

/* ============================================================
   RESULTS SCORECARD TILES
   ============================================================ */
.out-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
@media (max-width:760px){ .out-grid{ grid-template-columns:1fr 1fr; } }
.outc{ background:var(--navy); border-radius:16px; padding:30px 26px; color:#fff; }
.outc .ov{ font-family:'Newsreader',serif; font-size:46px; font-weight:600; color:var(--sand); letter-spacing:-0.02em; line-height:1; }
.outc .ov small{ font-size:18px; color:#9FB0C0; margin-left:2px; }
.outc .ok{ font-size:13.5px; color:#9FB0C0; margin-top:12px; line-height:1.4; }
.outc.accent .ov{ color:#E0A576; }

/* ============================================================
   REPORT CONTENTS CHIPS
   ============================================================ */
.rchips{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:26px auto 0; max-width:680px; }
.rchip{ font-size:13px; color:#CBD6E0; border:1px solid #2A4760; border-radius:999px; padding:7px 16px; }
.rchip b{ color:var(--sand); font-weight:600; }

/* ============================================================
   NAVY-SECTION CARD OVERRIDES
   ============================================================ */
.sec.navy .ic-row{ border-color:#264a63; color:#EAF0F5; }
.sec.navy .ic-check{ background:var(--copper); }
.sec.navy .finding{ background:#173247; border-color:#264a63; }
.sec.navy .finding-top h3{ color:#EAF0F5; }
.sec.navy .finding .fmeta .fm-v{ color:#EAF0F5; }
.sec.navy .finding .fmeta .fm-v.copper{ color:#E0A576; }
.sec.navy .finding .fmeta .fm-k{ color:#7E92A4; }
.sec.navy .finding .frec{ color:#9FB0C0; border-top-color:#264a63; }
.sec.navy .finding .frec b{ color:#EAF0F5; }
.sec.navy .stackcard{ background:#173247; border-color:#264a63; }
.sec.navy .stackcard h3{ color:#EAF0F5; }
.sec.navy .stackcard p{ color:#9FB0C0; }
.sec.navy .stackcard .sm{ background:var(--sand); color:var(--navy); }
.sec.navy .stackcard .eg{ color:#E0A576; }
.sec.navy .offer{ background:var(--bg); border-color:var(--sand); }
.sec.navy .pricenote{ color:#8FA1B2; }

/* ============================================================
   SMALL-PHONE REFINEMENTS  (≤ 480px / ≤ 400px / ≤ 360px)
   ============================================================ */

/* Tighten horizontal gutter on very small phones */
@media (max-width:400px){ .wrap{ padding:0 18px; } }

/* Further compress section vertical rhythm */
@media (max-width:480px){ .sec{ padding:56px 0; } }

/* Nav CTA: shrink text & hide arrow so it fits at 320 px */
@media (max-width:360px){
  .nav-inner .btn-sm{ padding:10px 14px; font-size:13.5px; }
  .nav-inner .btn-sm .arr{ display:none; }
}

/* ---------- reveal ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
  .reveal.in{ opacity:1; transform:none; }
}
