/* GP Inventory Solutions, "Navy & Silver", component + subpage CSS.
   site.css carries nav/hero/section shells; this file defines the card
   internals (hand-built from the DS components) and the Services / About /
   Contact subpage layouts. Tokens come from the design-system bundle. */

/* ---------- page routing ---------- */
.page { display: none; }
.page.active { display: block; animation: pagein .42s var(--ease) both; }
@keyframes pagein { from { transform: translateY(10px); } to { transform: none; } }

/* ---------- brand lockup (refine site.css: clean single-line wordmark + divider) ---------- */
.brand { display: flex; align-items: center; cursor: pointer; }
.lockup { display: flex; align-items: center; gap: 12px; }
.lockup .mono { height: 34px; width: auto; display: block; padding-right: 12px; border-right: 1px solid var(--silver-line); }
.lockup .wm { flex-direction: row; align-items: baseline; gap: .32em; line-height: 1; }
.lockup .wm b { font-family: var(--font-display); font-weight: 400; font-size: 1.02rem; letter-spacing: .03em; color: #fff; text-transform: uppercase; }
.lockup .wm i { font-family: var(--font-display); font-style: normal; font-weight: 400; font-size: 1.02rem; letter-spacing: .03em; color: #fff; text-transform: uppercase; }
footer.foot .lockup .mono { height: 38px; }
footer.foot .lockup .wm b, footer.foot .lockup .wm i { font-size: 1.1rem; }

/* nav brand: silver plate carrying the GP mark, with a periodic gloss swoosh */
.navmark { position: relative; overflow: hidden; display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #E8F0F3 0%, #C7CED6 48%, #A3A6AD 100%);
  border-radius: 8px; padding: 6px 10px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55), 0 2px 9px rgba(4,9,58,.30); }
.lockup .navmark .mono { height: 30px; width: auto; display: block; padding: 0; border: 0; position: relative; z-index: 1; }
.navmark-shine { position: absolute; top: -25%; left: 0; height: 150%; width: 42%; z-index: 2; pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.85), transparent);
  transform: translateX(-260%) skewX(-18deg);
  animation: gp-nav-shine 5.5s cubic-bezier(.3,.6,.3,1) 1.2s infinite both; }
.brand:hover .navmark-shine { animation: gp-nav-shine 1.3s cubic-bezier(.3,.6,.3,1) 0s 1 both; }
@keyframes gp-nav-shine { 0% { transform: translateX(-260%) skewX(-18deg); } 22%, 100% { transform: translateX(520%) skewX(-18deg); } }
@media (prefers-reduced-motion: reduce) { .navmark-shine { display: none; } }

/* nav CTA shown only inside the open mobile menu */
.menu-cta { display: none; }
/* keep nav links on one line each */
header.nav nav a { white-space: nowrap; }

/* mobile menu toggle */
.navtoggle { display: none; background: none; border: 1px solid var(--silver-line); border-radius: var(--radius-sm);
  width: 44px; height: 40px; color: #fff; cursor: pointer; align-items: center; justify-content: center; }
.navtoggle svg { width: 20px; height: 20px; }

/* ---------- buttons (mirror DS Button.jsx) ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55em;
  font-family: var(--font-body); font-weight: 700; font-size: .86rem; letter-spacing: .04em; text-transform: uppercase;
  background: var(--blue); color: #fff; border: 1px solid var(--blue); padding: .85em 1.4em;
  border-radius: var(--radius-md); cursor: pointer; white-space: nowrap; box-shadow: var(--shadow-sm);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur), border-color var(--dur), color var(--dur); }
.btn:hover { transform: translateY(-1px); background: var(--blue-bright); box-shadow: var(--shadow-md); }
.btn:active { transform: none; background: var(--blue-dk); }
.btn .arr { transition: transform var(--dur) var(--ease); }
.btn:hover .arr { transform: translateX(3px); }
.btn--ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--silver-3); box-shadow: none; }
.btn--ghost:hover { background: transparent; border-color: var(--blue); color: var(--blue); }
.btn--dark { background: transparent; color: var(--on-navy); border: 1.5px solid rgba(232,240,243,.4); box-shadow: none; }
.btn--dark:hover { background: transparent; border-color: var(--blue-bright); color: #fff; }
.btn--lg { padding: 1.02em 1.7em; font-size: .95rem; }
.btn[disabled] { opacity: .55; pointer-events: none; }

/* ---------- hero market-ledger card ---------- */
.copy { position: relative; z-index: 1; }
.ledgercard { position: relative; background: var(--navy-2); border: 1px solid var(--silver-line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); padding: clamp(20px,2.6vw,28px); }
.ledgercard .lh { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 14px; border-bottom: 1px solid var(--silver-line); margin-bottom: 4px; }
.ledgercard .lh .t { font-family: var(--font-display); text-transform: uppercase; letter-spacing: .01em; font-size: 1.15rem; color: #fff; }
.ledgercard .lh .d { font-family: var(--font-body); font-weight: 700; font-size: .64rem; letter-spacing: .1em; color: var(--on-navy-dim); }
.ledgercard .li { display: flex; align-items: baseline; gap: 10px; padding: 13px 0; border-bottom: 1px solid var(--silver-line); }
.ledgercard .li .lab { font-family: var(--font-body); font-weight: 600; font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; color: var(--on-navy-dim); white-space: nowrap; }
.ledgercard .li .lead { flex: 1; border-bottom: 1px dotted var(--silver-line); transform: translateY(-4px); min-width: 16px; }
.ledgercard .li .val { font-family: var(--font-display); letter-spacing: .01em; font-variant-numeric: tabular-nums; white-space: nowrap; font-size: 1.5rem; color: var(--blue-bright); }
.ledgercard .li .val .u { color: var(--on-navy-dim); font-family: var(--font-body); font-weight: 700; font-size: .5em; margin-left: 3px; text-transform: uppercase; letter-spacing: .04em; }
.ledgercard .li.bleed .val { color: var(--neg-on-navy); }
.ledgercard .li:last-of-type { border-bottom: none; }
.ledgercard .lf { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--silver-line); font-family: var(--font-body); font-size: .64rem; letter-spacing: .02em; color: var(--on-navy-dim); text-align: center; }
.stamp { position: absolute; top: -14px; right: 18px; transform: rotate(6deg); border: 2px solid var(--blue-bright); color: var(--blue-bright); background: var(--navy);
  font-family: var(--font-body); font-weight: 700; font-size: .6rem; letter-spacing: .16em; padding: 5px 10px; border-radius: var(--radius-sm); text-transform: uppercase; }

/* ---------- brand days-supply bars (problem section) ---------- */
.brandbars { margin-top: 8px; display: grid; gap: 12px; }
.bb { display: grid; grid-template-columns: 132px 1fr 54px; gap: 16px; align-items: center; }
.bb .bn { font-family: var(--font-body); font-weight: 700; font-size: .82rem; color: var(--on-navy); white-space: nowrap; }
.bb.gp .bn { color: #fff; }
.bb .bt { height: 22px; background: var(--navy-2); border: 1px solid var(--silver-line); border-radius: var(--radius-sm); overflow: hidden; }
.bb .bf { height: 100%; width: 0; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; transition: width 1.1s var(--ease); }
.bb .bv { font-family: var(--font-display); font-size: 1.25rem; letter-spacing: .01em; font-variant-numeric: tabular-nums; text-align: right; }

/* ---------- process steps (how it works) ---------- */
.pstep { background: var(--white); border: 1px solid var(--border-default); border-top: 4px solid var(--blue); border-radius: var(--radius-lg);
  padding: 26px 24px 28px; box-shadow: var(--shadow-sm); transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.pstep:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.pstep .top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.pstep .no { font-family: var(--font-display); font-size: 2.6rem; line-height: .8; color: var(--blue); letter-spacing: .01em; }
.pstep .ic { width: 30px; height: 30px; color: var(--blue); }
.pstep h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.35rem; letter-spacing: .005em; color: var(--ink); }
.pstep p { margin-top: 9px; color: var(--ink-mut); font-size: .96rem; }

/* ---------- service cards ---------- */
.svc .card { background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 30px 28px;
  box-shadow: var(--shadow-sm); transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.svc .card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.svc .card .n { font-family: var(--font-display); font-size: 1.1rem; color: var(--blue); letter-spacing: .04em; }
.svc .card h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.45rem; letter-spacing: .005em; margin-top: 8px; color: var(--ink); }
.svc .card > p { color: var(--ink-mut); margin: 10px 0 18px; font-size: .97rem; }
.svc .card ul { list-style: none; margin: 0; padding: 16px 0 0; border-top: 1px solid var(--border-default); display: grid; gap: 11px; }
.svc .card li { display: flex; gap: 11px; align-items: baseline; font-size: .92rem; color: var(--text-body); }
.svc .card li svg { flex: 0 0 auto; width: 16px; height: 16px; color: var(--blue); transform: translateY(2px); }

/* ---------- testimonials ---------- */
.quotes .tq { background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 28px 26px;
  display: flex; flex-direction: column; box-shadow: var(--shadow-sm); }
.quotes .tq .mk { font-family: var(--font-display); font-size: 3rem; line-height: .4; height: .4em; color: var(--blue); }
.quotes .tq p { font-size: 1rem; margin: 18px 0 20px; color: var(--text-body); }
.quotes .tq .by { margin-top: auto; display: flex; align-items: center; gap: 13px; padding-top: 16px; border-top: 1px solid var(--border-default); }
.quotes .tq .av { flex: 0 0 auto; width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--plate); border: 1px solid var(--silver-3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55); display: grid; place-items: center; font-family: var(--font-display); font-size: 1rem; color: var(--ink); }
.quotes .tq .by b { display: block; font-family: var(--font-body); font-weight: 700; font-size: .92rem; color: var(--ink); }
.quotes .tq .by span { font-family: var(--font-body); font-size: .76rem; color: var(--ink-mut); }

/* ---------- KPI / stat cells ---------- */
.kpi { background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 28px; text-align: center; box-shadow: var(--shadow-sm); }
.kpi.placeholder { border-style: dashed; border-color: var(--silver-3); background: var(--mist); }
.kpi .v { font-family: var(--font-display); font-size: clamp(2.2rem,4vw,2.9rem); color: var(--ink); letter-spacing: .01em; line-height: 1; }
.kpi.placeholder .v { color: var(--silver-3); }
.kpi .k { font-family: var(--font-body); font-weight: 600; font-size: .72rem; letter-spacing: .06em; color: var(--ink-mut); margin-top: 10px; text-transform: uppercase; }

/* ---------- calculator fields ---------- */
.field { margin-bottom: 22px; }
.field:last-of-type { margin-bottom: 0; }
.field .top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 11px; }
.field label { font-family: var(--font-body); font-weight: 600; font-size: .8rem; letter-spacing: .02em; color: var(--ink); }
.field .out { font-family: var(--font-display); font-size: 1.3rem; letter-spacing: .01em; font-variant-numeric: tabular-nums; color: var(--ink); }
.field .out.g { color: var(--blue); }

/* ---------- subpage header ---------- */
.pagehead { background: var(--navy); color: var(--on-navy); border-bottom: 1px solid var(--silver-line); position: relative; overflow: hidden;
  padding-top: clamp(50px,6.5vw,92px); padding-bottom: clamp(46px,6vw,76px); }
.pagehead::before { content: ""; position: absolute; right: -10%; top: -40%; width: 55%; height: 180%;
  background: radial-gradient(closest-side, rgba(10,86,250,.2), transparent 70%); pointer-events: none; }
.pagehead .wrap { position: relative; z-index: 1; }
.pagehead .crumb { font-family: var(--font-body); font-weight: 700; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--on-navy-dim); margin-bottom: 18px; }
.pagehead .crumb b { color: var(--blue-bright); }
.pagehead h1 { font-family: var(--font-display); font-size: var(--fs-h1); text-transform: uppercase; letter-spacing: .005em; line-height: .96; color: #fff; max-width: 16ch; }
.pagehead h1 .em { display: block; color: var(--blue-bright); }
.pagehead .sub { font-size: var(--fs-lead); font-weight: 500; color: var(--on-navy); max-width: 58ch; margin-top: 22px; }
.pagehead .meta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.pagehead .meta .m { border: 1px solid var(--silver-line); border-left: 3px solid var(--blue-bright); border-radius: var(--radius-md); padding: 14px 20px; background: var(--navy-2); }
.pagehead .meta .m .v { font-family: var(--font-display); font-size: 1.7rem; color: var(--blue-bright); letter-spacing: .01em; font-variant-numeric: tabular-nums; line-height: 1; }
.pagehead .meta .m .k { font-family: var(--font-body); font-weight: 600; font-size: .64rem; letter-spacing: .08em; text-transform: uppercase; color: var(--on-navy-dim); margin-top: 7px; }

/* ---------- services detail ---------- */
.svcstack { margin-top: clamp(40px,6vw,60px); display: grid; gap: clamp(18px,2.6vw,26px); }
.svcrow { display: grid; grid-template-columns: 1.05fr .95fr; border: 1px solid var(--border-default); border-radius: var(--radius-lg); overflow: hidden; background: var(--white); box-shadow: var(--shadow-sm); }
.svcrow .info { padding: clamp(26px,3vw,40px); }
.svcrow .no { font-family: var(--font-body); font-weight: 700; font-size: .68rem; letter-spacing: .14em; color: var(--blue); text-transform: uppercase; }
.svcrow h3 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(1.5rem,2.4vw,2rem); letter-spacing: .005em; margin-top: 10px; color: var(--ink); }
.svcrow .info > p { color: var(--ink-mut); margin-top: 13px; font-size: 1rem; max-width: 46ch; }
.svcrow .forwho { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
.svcrow .forwho .chip { color: var(--ink-mut); border-color: var(--border-default); }
.svcrow .deliver { padding: clamp(24px,3vw,36px); background: var(--mist); border-left: 1px solid var(--border-default); display: flex; flex-direction: column; }
.svcrow .deliver .dh { font-family: var(--font-body); font-weight: 700; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-mut); padding-bottom: 14px; border-bottom: 1px solid var(--border-default); margin-bottom: 4px; }
.svcrow .deliver ul { list-style: none; margin: 0; padding: 0; }
.svcrow .deliver li { display: flex; gap: 11px; align-items: baseline; font-size: .95rem; padding: 13px 0; border-bottom: 1px solid var(--border-default); color: var(--text-body); }
.svcrow .deliver li:last-child { border-bottom: none; }
.svcrow .deliver li svg { flex: 0 0 auto; width: 16px; height: 16px; color: var(--blue); transform: translateY(2px); }
.svcrow .deliver .out { margin-top: auto; padding-top: 18px; }
.svcrow .deliver .out .lab { font-family: var(--font-body); font-weight: 600; font-size: .64rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-mut); }
.svcrow .deliver .out .val { font-family: var(--font-body); font-weight: 700; font-size: 1rem; color: var(--ink); margin-top: 5px; }

/* engagement timeline */
.timeline { margin-top: 48px; border-top: 2px solid var(--silver-2); }
.tlrow { display: grid; grid-template-columns: 132px 1fr; gap: clamp(14px,3vw,40px); align-items: baseline; padding: 28px 4px; border-bottom: 1px solid var(--border-default); }
.tlrow .when { font-family: var(--font-body); font-weight: 700; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--blue); }
.tlrow h4 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.3rem; letter-spacing: .005em; color: var(--ink); }
.tlrow p { color: var(--ink-mut); margin-top: 8px; font-size: .98rem; max-width: 64ch; }

/* ---------- about ---------- */
.bio { display: grid; grid-template-columns: 320px 1fr; gap: clamp(28px,4vw,56px); align-items: start; }
.bioportrait { border: 1px solid var(--border-default); border-radius: var(--radius-lg); background: var(--white); box-shadow: var(--shadow-md); padding: 16px; }
.bioportrait .frame { aspect-ratio: 4/5; border: 1px dashed var(--silver-3); border-radius: var(--radius-md); display: grid; place-items: center; text-align: center; color: var(--ink-mut); background: var(--mist); }
.bioportrait .frame svg { width: 60px; height: 60px; opacity: .45; margin-bottom: 12px; }
.bioportrait .frame .ph { font-family: var(--font-body); font-weight: 600; font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; line-height: 1.7; }
.bioportrait .frame.has-photo { border-style: solid; border-color: var(--silver-2); overflow: hidden; padding: 0; background: var(--mist); }
.bioportrait .frame.has-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 18%; display: block; }
.bioportrait .cap { font-family: var(--font-body); font-weight: 600; font-size: .62rem; letter-spacing: .04em; color: var(--ink-mut); margin-top: 13px; text-align: center; text-transform: uppercase; }
.bio .who h2 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(1.9rem,3.4vw,2.7rem); letter-spacing: .005em; }
.bio .who .role { font-family: var(--font-body); font-weight: 700; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); margin-top: 10px; }
.bio .who p { color: var(--ink-mut); margin-top: 18px; max-width: 60ch; }
.bio .who p + p { margin-top: 14px; }
.bio .who .chips { margin-top: 20px; }
.bio .who .chips .chip { color: var(--ink-mut); border-color: var(--border-default); }

.values { display: grid; grid-template-columns: repeat(2,1fr); margin-top: 48px; border: 1px solid var(--border-default); border-radius: var(--radius-lg); overflow: hidden; background: var(--white); box-shadow: var(--shadow-sm); }
.valcell { padding: 32px; border-right: 1px solid var(--border-default); border-bottom: 1px solid var(--border-default); }
.valcell:nth-child(2n) { border-right: none; }
.valcell:nth-child(n+3) { border-bottom: none; }
.valcell .vn { font-family: var(--font-body); font-weight: 700; font-size: .66rem; letter-spacing: .12em; color: var(--blue); text-transform: uppercase; }
.valcell h4 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.3rem; letter-spacing: .005em; margin-top: 10px; color: var(--ink); }
.valcell p { color: var(--ink-mut); margin-top: 11px; font-size: .96rem; }

.pledge { margin-top: 8px; background: var(--navy); color: var(--on-navy); border: 1px solid var(--silver-line); border-radius: var(--radius-lg); padding: clamp(30px,4vw,48px); position: relative; overflow: hidden; }
.pledge::before { content: ""; position: absolute; right: -10%; top: -50%; width: 50%; height: 200%; background: radial-gradient(closest-side, rgba(10,86,250,.18), transparent 70%); pointer-events: none; }
.pledge .k { font-family: var(--font-body); font-weight: 700; font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--blue-bright); position: relative; }
.pledge p { font-family: var(--font-display); font-size: clamp(1.5rem,2.8vw,2.2rem); text-transform: uppercase; letter-spacing: .005em; line-height: 1.02; color: #fff; margin-top: 18px; max-width: 30ch; position: relative; }
.pledge p .em { color: var(--blue-bright); }

/* ---------- contact ---------- */
.contactgrid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(22px,3vw,40px); margin-top: clamp(36px,5vw,52px); align-items: start; }
.form-sheet { background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.form-sheet .sh { display: flex; justify-content: space-between; align-items: center; padding: 16px 24px; border-bottom: 1px solid var(--border-default); background: var(--mist); }
.form-sheet .sh .t { font-family: var(--font-body); font-weight: 700; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); }
.form-sheet .sh .d { font-family: var(--font-body); font-weight: 700; font-size: .62rem; letter-spacing: .1em; color: var(--blue); }
.form-sheet .bd { padding: clamp(22px,2.6vw,30px); }
.frow { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.ffield { margin-bottom: 18px; }
.ffield.full { grid-column: 1 / -1; }
.ffield label { display: block; font-family: var(--font-body); font-weight: 600; font-size: .72rem; letter-spacing: .04em; text-transform: uppercase; color: var(--ink); margin-bottom: 8px; }
.ffield label .req { color: var(--neg); }
.ffield input, .ffield select, .ffield textarea {
  width: 100%; font-family: var(--font-body); font-size: .98rem; color: var(--ink);
  background: var(--white); border: 1px solid var(--silver-2); border-radius: var(--radius-sm);
  padding: 12px 13px; outline: none; transition: border-color .18s, box-shadow .18s; }
.ffield textarea { min-height: 118px; resize: vertical; line-height: 1.55; }
.ffield input:focus, .ffield select:focus, .ffield textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-050); }
.ffield.err input, .ffield.err select, .ffield.err textarea { border-color: var(--neg); background: var(--neg-050); }
.ffield .msg { font-family: var(--font-body); font-weight: 600; font-size: .68rem; letter-spacing: .02em; color: var(--neg); margin-top: 6px; min-height: .9em; display: none; }
.ffield.err .msg { display: block; }
.form-foot { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; margin-top: 4px; padding-top: 20px; border-top: 1px solid var(--border-default); }
.form-foot .note { font-family: var(--font-body); font-size: .72rem; color: var(--ink-mut); line-height: 1.6; max-width: 34ch; }
.form-foot .formerror:empty { display: none; }
.form-foot .formerror { flex-basis: 100%; order: 3; font-family: var(--font-body); font-size: .82rem; font-weight: 600; color: var(--neg); line-height: 1.5; }

.form-success { display: none; padding: clamp(28px,4vw,46px); }
.form-success.on { display: block; animation: pagein .4s var(--ease) both; }
.form-success .seal { width: 56px; height: 56px; border-radius: 50%; background: var(--blue); color: #fff; display: grid; place-items: center; margin-bottom: 22px; }
.form-success .seal svg { width: 28px; height: 28px; }
.form-success h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.7rem; letter-spacing: .005em; color: var(--ink); }
.form-success p { color: var(--ink-mut); margin-top: 12px; max-width: 46ch; }
.form-success .recap { font-family: var(--font-body); font-size: .82rem; color: var(--ink-mut); background: var(--mist); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 14px 16px; margin-top: 22px; line-height: 1.7; }
.form-success .recap b { color: var(--ink); }

/* contact sidebar */
.contactside .panel { border: 1px solid var(--border-default); border-radius: var(--radius-lg); background: var(--white); box-shadow: var(--shadow-sm); padding: clamp(22px,2.6vw,28px); }
.contactside .panel.navy { background: var(--navy); border-color: var(--silver-line); color: var(--on-navy); }
.contactside .panel + .panel { margin-top: 20px; }
.contactside .panel h4 { font-family: var(--font-body); font-weight: 700; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--blue); margin-bottom: 18px; }
.contactside .panel.navy h4 { color: var(--blue-bright); }
.nextstep { display: flex; gap: 14px; align-items: baseline; padding: 13px 0; border-bottom: 1px solid var(--border-default); }
.nextstep:last-child { border-bottom: none; padding-bottom: 0; }
.nextstep .sn { font-family: var(--font-display); font-size: 1.05rem; color: var(--blue); }
.nextstep b { font-family: var(--font-body); font-weight: 700; font-size: .96rem; color: var(--ink); }
.nextstep p { color: var(--ink-mut); font-size: .86rem; margin-top: 4px; }
.contactside .line { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; padding: 11px 0; border-bottom: 1px solid var(--silver-line); }
.contactside .line:last-of-type { border-bottom: none; }
.contactside .line .k { font-family: var(--font-body); font-weight: 600; font-size: .64rem; letter-spacing: .08em; text-transform: uppercase; color: var(--on-navy-dim); }
.contactside .line .v { font-family: var(--font-body); font-weight: 700; font-size: .9rem; color: #fff; }

/* ---------- FAQ / objection handling ---------- */
.faqgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: clamp(34px,4vw,46px); }
.faq { background: var(--white); border: 1px solid var(--border-default); border-top: 3px solid var(--blue); border-radius: var(--radius-lg); padding: 28px 26px; box-shadow: var(--shadow-sm); }
.faq h4 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.18rem; letter-spacing: .005em; color: var(--ink); }
.faq p { color: var(--ink-mut); margin-top: 12px; font-size: .96rem; }
.faq p b { color: var(--ink); font-weight: 700; }

/* ---------- helpers ---------- */
/* scroll reveal (JS toggles .in; watchdog forces visible if timeline frozen) */
.r { opacity: 0; transform: translateY(16px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.r.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .r { opacity: 1; transform: none; transition: none; } }
.btn-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.section-foot-note { font-family: var(--font-body); font-size: .74rem; letter-spacing: .02em; color: var(--ink-mut); margin-top: 28px; max-width: 70ch; }
.ondark .section-foot-note { color: var(--on-navy-dim); }

/* Nav collapses to hamburger earlier (≤1180) so the link row never crowds the
   phone + CTA on small laptops. Also hides the DS nav links + phone above 960. */
@media (max-width: 1180px) {
  .navtoggle { display: inline-flex; }
  .nav nav { display: none; }
  .phone { display: none; }
  /* keep the primary CTA in the header; shrink it a touch so it fits beside the toggle */
  .nav .right .btn { padding: .72em 1.05em; font-size: .8rem; }
  header.nav.open nav { display: flex; position: absolute; top: 100%; right: var(--container-pad); left: auto;
    width: min(300px, calc(100vw - 2 * var(--container-pad))); flex-direction: column;
    align-items: stretch; gap: 2px; background: var(--navy); border: 1px solid var(--silver-line); border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md); padding: 8px 16px 16px; box-shadow: var(--shadow-md); }
  header.nav.open nav a { padding: 12px 0; font-size: 1rem; }
  header.nav.open nav a::after { display: none; }
  header.nav.open .menu-cta { display: inline-flex; align-items: center; justify-content: center; margin-top: 12px;
    font-family: var(--font-body); font-weight: 700; font-size: .9rem; letter-spacing: .04em; text-transform: uppercase;
    background: var(--blue); color: #fff !important; border-radius: var(--radius-md); padding: .9em 1.2em; }
}

@media (max-width: 960px) {
  .faqgrid { grid-template-columns: 1fr; }
  .svcrow, .bio, .values, .contactgrid { grid-template-columns: 1fr; }
  .svcrow .deliver { border-left: none; border-top: 1px solid var(--border-default); }
  .valcell { border-right: none !important; border-bottom: 1px solid var(--border-default) !important; }
  .valcell:last-child { border-bottom: none !important; }
  .tlrow { grid-template-columns: 1fr; gap: 6px; }
  .frow { grid-template-columns: 1fr; }
  .bb { grid-template-columns: 104px 1fr 44px; gap: 10px; }
}

/* phones: header has only logo + toggle (CTA lives in the dropdown) */
@media (max-width: 620px) {
  .nav .right .btn { display: none; }
}
