/* Summit Ridge Solutions — Shared Design System
   Fonts: Bricolage Grotesque (headings) · Geist (body) · Geist Mono (labels)
   Accent: #C8963C (gold) */

/* ── Tokens ──────────────────────────────────────── */
:root {
  --bg:        #F9F8F5;
  --bg-2:      #F0EEE8;
  --ink:       #141210;
  --ink-2:     #2C2A26;
  --muted:     #3C3830;
  --muted-2:   #4A4540;
  --rule:      #BAB0A6;
  --card:      #FFFFFF;
  --accent:    #C8963C;
  --accent-lo: rgba(200,150,60,0.12);
  --dark:      #09090F;
  --dark-2:    #111120;
  --dark-rule: #1E1E2E;
  --dark-muted:#9898B2;
  --r:         14px;
  --r-lg:      22px;
  --maxw:      1400px;
  --pad:       clamp(20px,5vw,60px);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Geist',ui-sans-serif,system-ui,sans-serif;
  font-size:17px; line-height:1.65;
  color:var(--ink); background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; border:0; }

/* grain overlay */
body::before {
  content:""; position:fixed; inset:0; z-index:9999;
  pointer-events:none; opacity:0.028;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='512' height='512' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:200px;
}

.wrap { max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

/* ── Typography ────────────────────────────────────── */
h1,h2,h3,h4 {
  font-family:'Bricolage Grotesque',ui-sans-serif,sans-serif;
  letter-spacing:-0.035em; line-height:1.05; font-weight:700;
}
.display {
  font-size:clamp(48px,7.5vw,108px);
  line-height:0.96; font-weight:800; letter-spacing:-0.045em;
}
.display-md {
  font-size:clamp(38px,5vw,70px);
  font-weight:700; letter-spacing:-0.04em; line-height:1.02;
}
.display-sm {
  font-size:clamp(30px,3.5vw,48px);
  font-weight:700; letter-spacing:-0.03em; line-height:1.08;
}
.mono { font-family:'Geist Mono',ui-monospace,monospace; }
.accent-text { color:var(--accent); }
.reveal-d1 { transition-delay:.08s; }
.reveal-d2 { transition-delay:.16s; }
.reveal-d3 { transition-delay:.24s; }
.label {
  font-family:'Geist Mono',monospace;
  font-size:11.5px; font-weight:500;
  letter-spacing:0.07em; text-transform:uppercase;
  color:var(--muted);
}

/* ── Sections ──────────────────────────────────────── */
section { padding:clamp(72px,9vw,120px) 0; }
section.tight { padding:clamp(52px,5.5vw,72px) 0; }
section.dark { background:var(--dark); color:#F4F2EE; }

/* ── Buttons ───────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:12px;
  height:52px; padding:0 8px 0 24px;
  border-radius:999px; border:0;
  font-family:'Geist',sans-serif; font-size:16px; font-weight:500;
  letter-spacing:-0.01em; cursor:pointer;
  background:var(--accent); color:#fff;
  transition:transform .15s ease, box-shadow .15s ease;
}
.btn:hover { transform:translateY(-1px); box-shadow:0 8px 28px rgba(200,150,60,.38); }
.btn .arr {
  width:34px; height:34px; border-radius:999px;
  background:rgba(255,255,255,.22); display:grid; place-items:center;
  flex-shrink:0;
}
.btn-ghost { background:transparent; color:var(--ink); border:1.5px solid var(--rule); }
.btn-ghost:hover { box-shadow:0 4px 18px rgba(0,0,0,.09); transform:translateY(-1px); }
.btn-ghost .arr { background:var(--ink); color:#fff; }
.btn-dark { background:var(--ink); color:#fff; }
.btn-dark:hover { box-shadow:0 8px 28px rgba(0,0,0,.32); }
.btn-dark .arr { background:rgba(255,255,255,.15); }

/* ── Navigation ────────────────────────────────────── */
.nav {
  position:sticky; top:0; z-index:100;
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  background:rgba(249,248,245,.86);
  border-bottom:1px solid rgba(227,222,214,.65);
  transition:transform 0.32s cubic-bezier(0.16,1,0.3,1);
}
.nav.nav-hidden { transform:translateY(-100%); }
.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  height:68px; gap:16px;
}
.brand {
  display:flex; align-items:center; gap:9px;
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700; font-size:18px; letter-spacing:-0.025em;
  flex-shrink:0;
}
.brand-mark { width:30px; height:30px; color:var(--accent); flex-shrink:0; }
.nav-links { display:flex; gap:2px; }
.nav-links a {
  padding:7px 15px; border-radius:8px;
  font-size:15px; font-weight:500; color:var(--muted);
  transition:color .15s,background .15s; white-space:nowrap;
}
.nav-links a:hover { color:var(--ink); background:var(--bg-2); }
.nav-links a.active { color:var(--ink); font-weight:600; }
.nav-cta { display:flex; gap:8px; align-items:center; flex-shrink:0; }

/* ── Footer ────────────────────────────────────────── */
.foot { background:var(--dark); color:#F4F2EE; padding:clamp(52px,6vw,80px) 0 32px; }
.foot-top {
  display:grid; grid-template-columns:1.6fr 1fr 1fr;
  gap:clamp(32px,5vw,56px); padding-bottom:40px;
  border-bottom:1px solid var(--dark-rule);
}
.foot-tagline {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(28px,3vw,48px); font-weight:700;
  letter-spacing:-.03em; line-height:1.08; color:#fff; max-width:16ch;
}
.foot-email-cta {
  display:inline-flex; align-items:center; gap:10px;
  color:#fff; font-size:16px; font-weight:500; margin-top:20px;
  border-bottom:1px solid rgba(255,255,255,.25); padding-bottom:6px;
  transition:border-color .15s, color .15s;
}
.foot-email-cta:hover { border-color:var(--accent); color:var(--accent); }
.foot-col-lbl {
  font-family:'Geist Mono',monospace; font-size:11px;
  letter-spacing:.07em; text-transform:uppercase;
  color:var(--dark-muted); margin-bottom:14px;
}
.foot-links { display:flex; flex-direction:column; gap:9px; }
.foot-links a { font-size:15px; color:rgba(255,255,255,.82); transition:color .15s; }
.foot-links a:hover { color:#fff; }
.foot-contact-lbl {
  color:var(--dark-muted); font-family:'Geist Mono',monospace;
  font-size:11px; letter-spacing:.07em; text-transform:uppercase;
}
.foot-contact-val { margin-top:6px; font-size:16px; line-height:1.65; color:rgba(255,255,255,.88); }
.foot-cols { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.foot-bottom {
  padding-top:28px; display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px; color:var(--dark-muted); font-size:14px;
}
.foot-brand {
  display:flex; align-items:center; gap:8px;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:17px; font-weight:700; letter-spacing:-.02em; color:#fff;
}
.foot-brand svg { width:24px; height:24px; color:var(--accent); }
.foot-legal { display:flex; gap:20px; }
.foot-legal a { transition:color .15s; }
.foot-legal a:hover { color:#fff; }
.socials { display:flex; gap:8px; }
.socials a {
  width:30px; height:30px; border-radius:999px;
  background:rgba(255,255,255,.07); display:grid; place-items:center;
  color:rgba(255,255,255,.65); transition:background .15s,color .15s;
}
.socials a:hover { background:var(--accent); color:#fff; }

/* ── Service cards ─────────────────────────────────── */
.svc-card {
  background:var(--card); border:1.5px solid var(--rule);
  border-radius:var(--r); overflow:hidden;
  transition:box-shadow .3s ease, transform .3s ease, border-color .3s ease;
}
.svc-card:hover { box-shadow:0 20px 56px rgba(0,0,0,.1); transform:translateY(-2px); border-color:rgba(200,150,60,.55); }
.svc-media { aspect-ratio:16/10; position:relative; overflow:hidden; }
.svc-meta {
  padding:18px 22px 22px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.svc-meta h3 {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:20px; font-weight:600; letter-spacing:-0.02em;
}
.svc-badge {
  font-family:'Geist Mono',monospace; font-size:10.5px;
  letter-spacing:.05em; text-transform:uppercase;
  color:var(--muted); background:var(--bg-2);
  padding:4px 10px; border-radius:999px; white-space:nowrap; flex-shrink:0;
}

/* ── Why cards ─────────────────────────────────────── */
.why-card {
  background:rgba(255,255,255,.055); border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:18px 22px;
  display:grid; grid-template-columns:38px 1fr; gap:14px; align-items:start;
  transition:background .2s,border-color .2s;
}
.why-card:hover { background:rgba(255,255,255,.09); border-color:rgba(200,150,60,.3); }
.why-ico {
  width:38px; height:38px; border-radius:10px;
  background:rgba(200,150,60,.15); display:grid; place-items:center;
  color:var(--accent);
}
.why-card h4 {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:16px; font-weight:600; letter-spacing:-.01em; color:#fff;
}
.why-card p { font-size:14px; line-height:1.62; color:rgba(255,255,255,.75); margin-top:4px; }

/* ── FAQ ───────────────────────────────────────────── */
.faq-item {
  border-top:1px solid var(--rule); padding:22px 0;
  display:grid; grid-template-columns:52px 1fr 1fr;
  gap:24px; align-items:start; cursor:pointer;
}
.faq-item:last-of-type { border-bottom:1px solid var(--rule); }
.faq-num {
  width:30px; height:30px; border-radius:999px;
  border:1.5px solid var(--rule); background:transparent;
  display:grid; place-items:center;
  font-family:'Geist Mono',monospace; font-size:13px; color:var(--muted-2);
  transition:background .2s,border-color .2s,color .2s;
}
.faq-item.open .faq-num { background:var(--accent); border-color:var(--accent); color:#fff; }
.faq-q {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:19px; font-weight:600; letter-spacing:-.015em;
}
.faq-a {
  font-size:16px; line-height:1.65; color:var(--muted);
  max-height:0; overflow:hidden; opacity:0;
  transition:max-height .42s cubic-bezier(.16,1,.3,1), opacity .28s ease .06s;
}
.faq-item.open .faq-a {
  max-height:600px; opacity:1;
  transition:max-height .42s cubic-bezier(.16,1,.3,1),opacity .32s ease;
}

/* ── Contact form ──────────────────────────────────── */
.cf-layout { display:grid; grid-template-columns:1fr 1.5fr; gap:clamp(40px,6vw,80px); align-items:start; }
.cf-left { position:sticky; top:84px; }
.cf-lede { margin-top:20px; color:var(--muted); font-size:17px; line-height:1.65; max-width:36ch; }
.cf-promises { margin-top:32px; display:flex; flex-direction:column; gap:12px; }
.cf-promise { display:flex; align-items:center; gap:12px; color:var(--muted); font-size:15px; }
.cf-check { width:22px; height:22px; border-radius:999px; background:var(--accent); color:#fff; display:grid; place-items:center; flex-shrink:0; }
.cf-card { background:var(--card); border:1.5px solid var(--rule); border-radius:var(--r-lg); padding:clamp(28px,4vw,44px); }
.cf-form { display:flex; flex-direction:column; gap:22px; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.cf-field { display:flex; flex-direction:column; gap:7px; }
.cf-label {
  font-family:'Geist Mono',monospace; font-size:11px; font-weight:500;
  letter-spacing:.06em; text-transform:uppercase; color:var(--ink);
}
.cf-req { color:var(--accent); }
.cf-opt { color:var(--muted-2); font-weight:400; text-transform:none; letter-spacing:0; font-family:'Geist',sans-serif; font-size:11px; }
.cf-input {
  height:48px; padding:0 16px;
  border:1.5px solid var(--rule); border-radius:12px;
  background:var(--bg); color:var(--ink); font:inherit; font-size:16px;
  outline:none; width:100%;
  transition:border-color .15s,box-shadow .15s;
}
.cf-input:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(200,150,60,.12); }
.cf-input::placeholder { color:var(--muted-2); }
.cf-textarea { height:auto; padding:14px 16px; resize:vertical; min-height:120px; line-height:1.62; }
.cf-pills { display:flex; flex-wrap:wrap; gap:8px; }
.cf-pill {
  height:38px; padding:0 16px; border-radius:999px;
  border:1.5px solid var(--rule); background:transparent;
  color:var(--ink); font:inherit; font-size:14px; font-weight:500;
  cursor:pointer; transition:all .14s;
}
.cf-pill:hover { background:var(--bg-2); }
.cf-pill.on { background:var(--ink); border-color:var(--ink); color:#fff; }
.cf-field-err .cf-input,
.cf-field-err .cf-pills { outline:1.5px solid #d94b35; outline-offset:2px; border-radius:12px; }
.cf-field-err .cf-label { color:#d94b35; }
.cf-submit-error {
  font-size:15px; color:#d94b35; padding:14px 16px;
  background:rgba(217,75,53,.05); border:1px solid rgba(217,75,53,.18);
  border-radius:12px; line-height:1.55;
}
.cf-success {
  text-align:center; padding:56px 32px;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.cf-success-icon {
  width:56px; height:56px; border-radius:999px;
  background:var(--accent); display:grid; place-items:center;
  margin-bottom:12px;
}
.cf-success h3 { font-size:28px; font-weight:600; letter-spacing:-0.02em; }
.cf-success p { color:var(--muted); font-size:17px; max-width:38ch; }
.cf-loading { opacity:.72; pointer-events:none; }
.cf-spinner {
  width:34px; height:34px; border-radius:999px;
  background:rgba(255,255,255,.22); display:grid; place-items:center;
  position:relative;
}
.cf-spinner::after {
  content:""; width:13px; height:13px; border-radius:999px;
  border:2px solid rgba(255,255,255,.3); border-top-color:#fff;
  animation:cf-spin .65s linear infinite;
}
@keyframes cf-spin { to { transform:rotate(360deg); } }

/* ── Brand tiles ───────────────────────────────────── */
.brand-row { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:14px; }
.brand-tile {
  background:var(--card); border:1.5px solid var(--rule); border-radius:12px;
  height:72px; display:flex; align-items:center; justify-content:center; gap:9px;
  font-weight:600; font-size:16px; color:var(--muted-2); letter-spacing:-.01em;
}
.brand-tile.muted { background:var(--bg-2); }

/* ── Testimonials ──────────────────────────────────── */
.tst {
  display:grid; grid-template-columns:260px 1fr;
  gap:64px; align-items:start;
  border-top:1px solid var(--rule); padding-top:40px; margin-top:16px;
}
.tst-label { color:var(--muted); font-size:14px; line-height:1.55; max-width:22ch; }
.tst-pct {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(60px,7vw,96px); font-weight:800;
  letter-spacing:-.055em; line-height:1; margin-top:20px;
}
.tst-pct sup { color:var(--accent); font-size:.55em; }
.tst-pct-lbl { color:var(--muted); font-size:15px; margin-top:10px; }
.tst-quote {
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(23px,2.4vw,34px); font-weight:500;
  letter-spacing:-.02em; line-height:1.38;
}
.tst-foot { display:flex; align-items:center; justify-content:space-between; margin-top:32px; gap:16px; }
.tst-author { display:flex; align-items:center; gap:14px; }
.avatar {
  width:44px; height:44px; border-radius:999px;
  background:linear-gradient(135deg,var(--accent),#E6B86A); flex-shrink:0;
}
.tst-name { font-weight:600; font-size:15px; }
.tst-role { color:var(--muted); font-size:14px; }
.soc-btn {
  width:40px; height:40px; border-radius:999px;
  border:1.5px solid var(--rule); background:transparent; color:var(--ink);
  display:grid; place-items:center;
  transition:background .15s,color .15s,border-color .15s; flex-shrink:0;
}
.soc-btn:hover { background:var(--ink); color:#fff; border-color:var(--ink); }

/* ── Final CTA ─────────────────────────────────────── */
.final {
  background:var(--dark); border-radius:var(--r-lg);
  overflow:hidden; display:grid; grid-template-columns:1fr 1fr; min-height:280px;
}
.final-left {
  padding:clamp(40px,5vw,60px);
  display:flex; flex-direction:column; justify-content:space-between; gap:24px;
}
.final-left h2 { color:#fff; }
.final-left p { color:rgba(255,255,255,.80); font-size:17px; margin-top:14px; }
.final-right {
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse at 80% 28%, rgba(200,150,60,.28) 0%, transparent 62%),
    linear-gradient(135deg, #0D0D18 0%, #181430 55%, #241A50 100%);
}
.final-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(200,150,60,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,150,60,.07) 1px, transparent 1px);
  background-size:48px 48px;
  animation:grid-drift 32s linear infinite;
}
@keyframes grid-drift { from{background-position:0 0,0 0} to{background-position:48px 48px,48px 48px} }
.final-window {
  position:absolute; right:-8%; bottom:-8%;
  width:72%; height:68%; border-radius:14px;
  background:linear-gradient(180deg,#F9F8F5 0%,#F9F8F5 11%,#fff 11%);
  background-image:
    radial-gradient(circle at 14px 14px,#ff5f57 5px,transparent 6px),
    radial-gradient(circle at 34px 14px,#febc2e 5px,transparent 6px),
    radial-gradient(circle at 54px 14px,#28c840 5px,transparent 6px),
    linear-gradient(180deg,#F9F8F5 0%,#F9F8F5 11%,#fff 11%);
  background-repeat:no-repeat;
  box-shadow:0 40px 80px rgba(0,0,0,.45);
}

/* ── Scroll reveal ─────────────────────────────────── */
.reveal { opacity:0; transform:translateY(18px); transition:opacity .58s cubic-bezier(.2,.7,.2,1),transform .58s cubic-bezier(.2,.7,.2,1); will-change:opacity,transform; }
.reveal.in { opacity:1; transform:none; }

/* ── Page hero (inner pages) ───────────────────────── */
.page-hero { padding:clamp(56px,7vw,96px) 0 clamp(48px,5vw,72px); border-bottom:1px solid var(--rule); }
.page-hero-inner { max-width:52ch; }

/* ── Service card mocks ────────────────────────────── */
.wm-mock { position:absolute; inset:0; overflow:hidden; }
.wm-bg {
  position:absolute; inset:0;
  background:linear-gradient(180deg,#D6E3EC 0%,#B6C0C8 38%,#8A9483 55%,#6B7A4F 72%,#4F5D36 100%);
}
.wm-card-overlay {
  position:absolute; left:18px; right:18px; top:18px; bottom:18px;
  background:rgba(16,14,32,.52); border-radius:10px; backdrop-filter:blur(1px); padding:16px 18px;
}
.wm-row { display:flex; align-items:center; justify-content:space-between; }
.wm-bname { color:#fff; font-size:13px; font-weight:600; letter-spacing:-.01em; }
.wm-nav-links { display:flex; gap:16px; font-size:11px; color:rgba(255,255,255,.7); }
.wm-cta-sm {
  height:24px; padding:0 6px 0 12px; background:#141210; color:#fff;
  border-radius:999px; font-size:11px; display:flex; align-items:center; gap:6px;
}
.wm-cta-arr { width:16px; height:16px; border-radius:999px; background:rgba(255,255,255,.18); display:grid; place-items:center; }
.wm-headline {
  color:#fff; font-family:'Bricolage Grotesque',sans-serif;
  font-size:26px; font-weight:800; line-height:1; letter-spacing:-.04em; margin-top:32px;
}
.wm-sub { color:rgba(255,255,255,.6); font-size:10px; margin-top:6px; }
.wm-cursor {
  position:absolute; width:12px; height:12px;
  border:1.5px solid rgba(255,255,255,.8); border-radius:50%;
  pointer-events:none; z-index:20;
  transform:translate(-50%,-50%); opacity:0;
  transition:opacity .3s;
}
.wm-cursor::after {
  content:''; position:absolute; inset:-5px; border-radius:50%;
  background:rgba(255,255,255,.07);
}
.wf-wrap { position:absolute; inset:0; background:#ECE6DC; padding:14px; display:flex; }
.wf-browser {
  flex:1; background:#FBF8F3; border-radius:10px;
  box-shadow:0 6px 20px rgba(0,0,0,.07); overflow:hidden; display:flex; flex-direction:column;
}
.wf-chrome { display:flex; align-items:center; gap:8px; padding:8px 12px; background:#F0EBE2; border-bottom:1px solid rgba(0,0,0,.06); }
.wf-dots { display:flex; gap:5px; }
.wf-dots span { width:8px; height:8px; border-radius:999px; display:block; }
.wf-url {
  flex:1; max-width:55%; margin:0 auto; background:#fff; border-radius:999px;
  font-family:'Geist Mono',monospace; font-size:10px; color:#7a756c;
  height:20px; display:flex; align-items:center; padding:0 10px;
}
.wf-stage { flex:1; padding:10px; overflow:hidden; }
.wf-svg { width:100%; height:100%; }
.wf-node { opacity:0; transform:translateY(7px); transition:opacity .45s ease, transform .45s ease; }
.wf-node.wf-visible { opacity:1; transform:translateY(0); }

/* ── Mobile nav ────────────────────────────────────── */
.nav-menu-btn {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:44px; height:44px; background:transparent; padding:10px;
  border-radius:8px; transition:background .15s; flex-shrink:0;
}
.nav-menu-btn:hover { background:var(--bg-2); }
.nav-menu-btn span {
  display:block; height:1.5px; background:var(--ink);
  border-radius:2px;
  transition:transform .22s ease, opacity .22s ease, width .22s ease;
  transform-origin:center;
}
.nav-menu-btn.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-menu-btn.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-menu-btn.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.nav-drawer {
  position:fixed; top:68px; left:0; right:0; z-index:99;
  background:rgba(249,248,245,.97);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(227,222,214,.65);
  padding:16px var(--pad) 24px;
  display:flex; flex-direction:column; gap:0;
  opacity:0; pointer-events:none; transform:translateY(-8px);
  transition:opacity .22s ease, transform .22s ease;
}
.nav-drawer.open { opacity:1; pointer-events:auto; transform:none; }
.nav-drawer > a {
  padding:14px 4px; font-size:17px; font-weight:500; color:var(--muted);
  border-bottom:1px solid var(--rule); transition:color .15s;
}
.nav-drawer > a:hover, .nav-drawer > a.active { color:var(--ink); }
.nav-drawer .btn { margin-top:18px; align-self:flex-start; }
body.nav-open { overflow:hidden; }

/* ── Responsive ────────────────────────────────────── */
@media (max-width:960px) {
  section { padding:64px 0; }
  .nav-links { display:none; }
  .nav-menu-btn { display:flex; }
  .nav-cta .btn { display:none; }
  .tst { grid-template-columns:1fr; gap:32px; }
  .final { grid-template-columns:1fr; }
  .final-right { min-height:200px; }
  .foot-top { grid-template-columns:1fr; gap:28px; }
  .brand-row { grid-template-columns:1fr 1fr; }
  .faq-item { grid-template-columns:40px 1fr; }
  .faq-item .faq-a { grid-column:1 / -1; }
  .cf-layout { grid-template-columns:1fr; }
  .cf-left { position:static; }
}
@media (max-width:600px) {
  :root { --pad:20px; }
  .cf-row { grid-template-columns:1fr; }
  .faq-item { grid-template-columns:28px 1fr; gap:12px; }
  .faq-item .faq-a { grid-column:1 / -1; }
}
