/* ===========================================================
   Rachel Rudo Consulting — shared design system
   Warm paper · Newsreader / Hanken Grotesk · cornflower blue
   =========================================================== */
:root{
  --accent: #2f4ad0;
  --accent-deep: #2338a4;
  --accent-soft: #eaecfb;
  --ink: #14171e;
  --ink-2: #3a4150;
  --ink-3: #6b7280;
  --line: #e7e3da;
  --paper: #faf8f3;
  --paper-2: #f3efe6;
  --card: #ffffff;
  --dark: #12151c;
  --dark-2: #1b1f29;
  --on-dark: #eceef3;
  --on-dark-mute: #9aa1b1;
  --display: 'Newsreader', Georgia, serif;
  --sans: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --maxw: 1200px;
  --radius: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
h1,h2,h3,h4{ font-family:var(--display); font-weight:500; letter-spacing:-.01em; line-height:1.05; margin:0; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
img{ display:block; }
::selection{ background:var(--accent); color:#fff; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 32px; }
.eyebrow{ font-family:var(--sans); font-weight:700; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); }
.eyebrow.muted{ color:var(--ink-3); }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in, .reveal[data-in]{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:600; font-size:15px; white-space:nowrap;
  border-radius:999px; padding:12px 22px; border:1px solid transparent; transition:transform .2s var(--ease), background .2s, box-shadow .2s, color .2s, border-color .2s; }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 1px 0 rgba(0,0,0,.04); }
.btn-primary:hover{ background:var(--accent-deep); box-shadow:0 10px 24px -10px color-mix(in srgb,var(--accent) 70%, transparent); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); }
.btn-light{ background:#fff; color:var(--ink); }
.btn-light:hover{ background:#f1eee6; }
.btn-on-dark{ background:transparent; color:#fff; border-color:rgba(255,255,255,.25); }
.btn-on-dark:hover{ border-color:#fff; background:rgba(255,255,255,.06); }
.btn-arrow{ transition:transform .2s var(--ease); display:inline-flex; }
.btn:hover .btn-arrow{ transform:translateX(3px); }

/* ---------- Nav ---------- */
.nav{ position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(10px);
  background:color-mix(in srgb, var(--paper) 82%, transparent); border-bottom:1px solid transparent; transition:border-color .3s, background .3s; }
.nav.scrolled{ border-bottom:1px solid var(--line); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.logo-mark{ height:42px; width:auto; display:block; }
.brand-name{ font-family:var(--display); font-size:19px; font-weight:600; letter-spacing:-.01em; line-height:1.05; white-space:nowrap; }
.brand-sub{ font-family:var(--sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); display:block; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-size:15px; font-weight:500; color:var(--ink-2); position:relative; padding:4px 0; }
.nav-links a::after{ content:''; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--accent); transition:width .25s var(--ease); }
.nav-links a:hover{ color:var(--ink); } .nav-links a:hover::after{ width:100%; }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{ width:100%; }
.menu-btn{ display:none; background:none; border:0; padding:8px; color:var(--ink); }

/* ---------- Mobile drawer ---------- */
.drawer{ position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:var(--paper); z-index:60;
  transform:translateX(100%); transition:transform .4s var(--ease); box-shadow:-30px 0 60px -30px rgba(0,0,0,.3); padding:26px; display:flex; flex-direction:column; }
.drawer.open{ transform:none; }
.scrim{ position:fixed; inset:0; background:rgba(10,12,18,.4); opacity:0; pointer-events:none; transition:opacity .4s; z-index:55; }
.scrim.open{ opacity:1; pointer-events:auto; }
.drawer a{ font-family:var(--display); font-size:26px; font-weight:500; padding:14px 0; border-bottom:1px solid var(--line); color:var(--ink); }
.drawer a.active{ color:var(--accent); }

/* ---------- Section scaffolding ---------- */
section.block{ padding:96px 0; }
.sec-head{ max-width:680px; margin-bottom:48px; }
.sec-head h2{ font-size:clamp(32px,3.6vw,46px); margin-top:14px; }
.sec-head p{ font-size:18.5px; color:var(--ink-2); margin-top:18px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* ---------- Page hero (sub-pages) ---------- */
.page-hero{ padding:64px 0 18px; }
.page-hero .ph-inner{ max-width:820px; }
.page-hero h1{ font-size:clamp(40px,5vw,68px); letter-spacing:-.025em; margin-top:16px; }
.page-hero h1 em{ font-style:italic; color:var(--accent); }
.page-hero .lede{ font-size:20px; color:var(--ink-2); margin-top:24px; max-width:46ch; }
.breadcrumb{ font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--ink-3); display:flex; gap:8px; align-items:center; }
.breadcrumb a:hover{ color:var(--accent); }
.breadcrumb .sep{ color:var(--line); }

/* ---------- Home hero ---------- */
.hero{ position:relative; padding:74px 0 70px; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center; }
.hero h1{ font-size:clamp(44px,5.4vw,76px); letter-spacing:-.025em; }
.hero h1 em{ font-style:italic; color:var(--accent); }
.hero-lede{ font-size:20px; color:var(--ink-2); max-width:34ch; margin-top:26px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.hero-trust{ display:flex; align-items:center; gap:16px; margin-top:38px; color:var(--ink-3); font-size:14.5px; max-width:42ch; }
.hero-trust .dot{ width:5px; height:5px; border-radius:50%; background:var(--accent); flex:none; }
.portrait{ position:relative; aspect-ratio:4/5; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
  background:repeating-linear-gradient(135deg, #efeadf 0 14px, #f5f1e8 14px 28px);
  box-shadow:0 30px 70px -40px rgba(20,23,30,.55); }
.portrait img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 32%; }
.portrait .badge{ position:absolute; top:18px; left:18px; background:var(--ink); color:#fff; border-radius:10px; padding:10px 14px; }
.portrait .badge b{ font-family:var(--display); font-size:24px; font-weight:600; display:block; line-height:1; }
.portrait .badge span{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--on-dark-mute); }

/* ---------- Industries strip ---------- */
.strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--paper-2); }
.strip-inner{ display:flex; align-items:center; gap:38px; padding:22px 0; flex-wrap:wrap; }
.strip-label{ font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:700; }
.strip-items{ display:flex; gap:30px; flex-wrap:wrap; flex:1; }
.strip-items span{ font-family:var(--display); font-size:18px; color:var(--ink-2); font-weight:500; }

/* ---------- Positioning (dark) ---------- */
.position{ background:var(--dark); color:var(--on-dark); }
.position .quote{ font-family:var(--display); font-size:clamp(28px,3.3vw,44px); line-height:1.18; letter-spacing:-.01em; max-width:18ch; }
.position .quote em{ font-style:italic; color:#fff; }
.position-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.position-body p{ color:var(--on-dark-mute); font-size:18px; }
.position-body p + p{ margin-top:18px; }
.stat-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:46px; border-top:1px solid rgba(255,255,255,.12); padding-top:30px; }
.stat b{ font-family:var(--display); font-size:clamp(34px,3.4vw,46px); font-weight:500; display:block; }
.stat span{ color:var(--on-dark-mute); font-size:14.5px; display:block; margin-top:6px; }

/* ---------- Service preview cards (home + how-i-help index) ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.svc{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:34px 32px; transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; position:relative; overflow:hidden; display:flex; flex-direction:column; }
.svc:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -28px rgba(20,23,30,.32); border-color:transparent; }
.svc .num{ font-family:ui-monospace,monospace; font-size:13px; color:var(--accent); letter-spacing:.1em; }
.svc h3{ font-size:22px; margin:14px 0 10px; }
.svc p{ color:var(--ink-2); font-size:16px; }
.svc ul.svc-list{ list-style:none; padding:0; margin:22px 0 0; border-top:1px solid var(--line); display:block; }
.svc ul.svc-list li{ font-size:14.5px; line-height:1.55; color:var(--ink-2); padding:11px 0; border-bottom:1px solid var(--line); text-wrap:pretty; }
.svc ul.svc-list li:last-child{ border-bottom:none; padding-bottom:0; }
.svc ul.svc-list li strong{ color:var(--ink); font-weight:650; }
.svc .glyph{ width:46px; height:46px; border-radius:11px; background:var(--accent-soft); display:grid; place-items:center; color:var(--accent); }
.svc .svc-more{ margin-top:auto; padding-top:20px; font-weight:600; font-size:14px; color:var(--accent); display:inline-flex; align-items:center; gap:7px; }

/* ---------- Service detail blocks (how-i-help) ---------- */
.svc-detail{ display:grid; grid-template-columns:.42fr .58fr; gap:50px; align-items:start; padding:56px 0; border-top:1px solid var(--line); }
.svc-detail:first-of-type{ border-top:0; }
.svc-detail .sd-head .glyph{ width:54px; height:54px; border-radius:13px; background:var(--accent-soft); display:grid; place-items:center; color:var(--accent); margin-bottom:22px; }
.svc-detail .sd-num{ font-family:ui-monospace,monospace; font-size:13px; color:var(--accent); letter-spacing:.12em; }
.svc-detail h3{ font-size:clamp(26px,2.6vw,34px); margin:10px 0 16px; }
.svc-detail .sd-lede{ color:var(--ink-2); font-size:17px; }
.sd-items{ display:grid; grid-template-columns:1fr 1fr; gap:0 36px; }
.sd-items .sd-item{ padding:18px 0; border-top:1px solid var(--line); }
.sd-items .sd-item:nth-child(1), .sd-items .sd-item:nth-child(2){ border-top:0; padding-top:0; }
.sd-items .sd-item h4{ font-size:17px; margin-bottom:6px; }
.sd-items .sd-item p{ font-size:14.5px; color:var(--ink-2); }

/* ---------- Value delivered ---------- */
.value{ background:var(--paper-2); }
.vp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.vp-item{ background:var(--card); border:1px solid var(--line); border-radius:12px; padding:22px 24px;
  font-family:var(--display); font-size:20px; font-weight:500; color:var(--ink); display:flex; align-items:center; gap:14px; }
.vp-item .vk{ width:10px; height:10px; border-radius:50%; background:var(--accent); flex:none; }

/* ---------- Mission band ---------- */
.mission{ background:var(--accent-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); text-align:center; }
.mission blockquote{ font-family:var(--display); font-size:clamp(26px,3.2vw,40px); line-height:1.25; letter-spacing:-.01em; color:var(--ink); max-width:30ch; margin:0 auto; font-weight:500; }
.mission blockquote em{ font-style:italic; color:var(--accent); }
.mission cite{ display:block; margin-top:22px; font-style:normal; font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }

/* ---------- Approach (4 E's + method) ---------- */
.approach{ background:var(--paper-2); }
.e-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:10px; }
.e-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px 24px; transition:transform .3s var(--ease); }
.e-card:hover{ transform:translateY(-4px); }
.e-card .e-mark{ font-family:var(--display); font-size:44px; color:var(--accent); line-height:1; }
.e-card h4{ font-size:21px; margin:16px 0 8px; }
.e-card p{ font-size:15px; color:var(--ink-2); }
.method{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; margin-top:64px; padding-top:56px; border-top:1px solid var(--line); }
.method-steps{ display:flex; flex-direction:column; gap:0; }
.mstep{ display:flex; gap:18px; padding:20px 0; border-bottom:1px solid var(--line); }
.mstep:last-child{ border-bottom:0; }
.mstep .mi{ font-family:ui-monospace,monospace; font-size:13px; color:var(--accent); width:34px; flex:none; padding-top:3px; }
.mstep h4{ font-size:19px; margin-bottom:5px; }
.mstep p{ font-size:15px; color:var(--ink-2); }

/* ---------- About / Story ---------- */
.about-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:center; }
.about-photo{ aspect-ratio:1/1.12; border-radius:var(--radius); border:1px solid var(--line); position:relative; overflow:hidden;
  background:repeating-linear-gradient(135deg,#efeadf 0 14px,#f5f1e8 14px 28px); }
.about-photo > img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 22%; }
.about-photo .cap{ position:absolute; inset:auto 0 0 0; font-family:var(--sans); font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#fff; padding:34px 18px 16px; background:linear-gradient(transparent, rgba(10,12,18,.82)); }
.about h2{ font-size:clamp(30px,3.4vw,44px); }
.about .role{ margin-top:6px; color:var(--accent); font-weight:600; font-size:15px; letter-spacing:.02em; }
.about p{ color:var(--ink-2); font-size:18px; margin-top:22px; }
.creds{ display:flex; gap:30px; flex-wrap:wrap; margin-top:30px; padding-top:26px; border-top:1px solid var(--line); }
.creds div b{ font-family:var(--display); font-size:17px; display:block; }
.creds div span{ font-size:13.5px; color:var(--ink-3); }

/* story narrative */
.story-narrative{ display:grid; grid-template-columns:repeat(12,1fr); gap:40px; }
.story-narrative .lead{ grid-column:1 / span 5; }
.story-narrative .lead p{ font-family:var(--display); font-size:clamp(22px,2.3vw,28px); line-height:1.3; color:var(--ink); }
.story-narrative .body{ grid-column:7 / span 6; }
.story-narrative .body p{ color:var(--ink-2); font-size:17px; }
.story-narrative .body p + p{ margin-top:18px; }
/* belief / values list */
.beliefs{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.belief{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:30px; }
.belief .bn{ font-family:ui-monospace,monospace; font-size:13px; color:var(--accent); letter-spacing:.12em; }
.belief h4{ font-size:21px; margin:12px 0 8px; }
.belief p{ font-size:15.5px; color:var(--ink-2); }

/* ---------- Insights ---------- */
.ins-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.ins{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--card); transition:transform .3s var(--ease), box-shadow .3s; }
.ins:hover{ transform:translateY(-4px); box-shadow:0 24px 50px -28px rgba(20,23,30,.3); }
.ins .thumb{ aspect-ratio:16/10; background:repeating-linear-gradient(135deg,#eae4d8 0 12px,#f1ece1 12px 24px); position:relative; }
.ins .thumb .tag{ position:absolute; top:14px; left:14px; background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:5px 12px; font-size:12px; font-weight:700; letter-spacing:.04em; color:var(--accent); }
.ins .body{ padding:24px; flex:1; display:flex; flex-direction:column; }
.ins .ins-date{ font-size:12.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.ins h3{ font-size:21px; line-height:1.18; }
.ins p{ font-size:15px; color:var(--ink-2); margin-top:10px; }
.ins .read{ margin-top:auto; padding-top:18px; font-weight:600; font-size:14px; color:var(--accent); display:inline-flex; align-items:center; gap:7px; }
.ins:hover .read .btn-arrow{ transform:translateX(3px); }

/* ---------- Fractional HR ---------- */
.frac-intro{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.frac-intro .fi-body p{ color:var(--ink-2); font-size:18px; }
.frac-intro .fi-body p + p{ margin-top:18px; }
.frac-panel{ background:var(--ink); color:var(--on-dark); border-radius:var(--radius); padding:40px; }
.frac-panel h4{ color:#fff; font-size:22px; }
.frac-panel .fp-list{ list-style:none; padding:0; margin:22px 0 0; }
.frac-panel .fp-list li{ display:flex; gap:13px; align-items:flex-start; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.1); color:var(--on-dark); font-size:15.5px; }
.frac-panel .fp-list li:last-child{ border-bottom:0; }
.frac-panel .fp-list .ck{ width:22px; height:22px; border-radius:50%; background:var(--accent); display:grid; place-items:center; flex:none; margin-top:1px; }
/* who it's for */
.fit-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.fit{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; }
.fit .glyph{ width:46px; height:46px; border-radius:11px; background:var(--accent-soft); display:grid; place-items:center; color:var(--accent); margin-bottom:18px; }
.fit h4{ font-size:20px; margin-bottom:9px; }
.fit p{ font-size:15px; color:var(--ink-2); }
/* engagement models */
.model-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.model{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:32px 30px; display:flex; flex-direction:column; }
.model.feature{ background:var(--dark); color:var(--on-dark); border-color:transparent; }
.model .m-tag{ font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.model.feature .m-tag{ color:color-mix(in srgb,var(--accent) 60%, #fff); }
.model h4{ font-size:24px; margin:12px 0 6px; }
.model.feature h4{ color:#fff; }
.model .m-sub{ font-size:14.5px; color:var(--ink-3); }
.model.feature .m-sub{ color:var(--on-dark-mute); }
.model ul{ list-style:none; padding:0; margin:22px 0 0; display:flex; flex-direction:column; gap:11px; }
.model ul li{ font-size:14.5px; color:var(--ink-2); display:flex; gap:10px; align-items:flex-start; }
.model.feature ul li{ color:var(--on-dark); }
.model ul li .dotk{ width:6px; height:6px; border-radius:50%; background:var(--accent); flex:none; margin-top:8px; }
/* engagement flow */
.flow{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:flow; }
.flow .fstep{ position:relative; padding-top:26px; }
.flow .fstep .fnum{ font-family:var(--display); font-size:40px; color:var(--accent); line-height:1; }
.flow .fstep h4{ font-size:19px; margin:12px 0 8px; }
.flow .fstep p{ font-size:14.5px; color:var(--ink-2); }

/* ---------- CTA / Contact ---------- */
.cta{ background:var(--dark); color:var(--on-dark); }
.cta-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.cta h2{ font-size:clamp(34px,3.8vw,52px); color:#fff; }
.cta h2 em{ font-style:italic; color:color-mix(in srgb,var(--accent) 55%, #fff); }
.cta p{ color:var(--on-dark-mute); font-size:18px; margin-top:20px; max-width:40ch; }
.cta-points{ list-style:none; padding:0; margin:30px 0 0; display:flex; flex-direction:column; gap:14px; }
.cta-points li{ display:flex; gap:12px; align-items:center; color:var(--on-dark); font-size:16px; }
.cta-points .ck{ width:22px; height:22px; border-radius:50%; background:var(--accent); display:grid; place-items:center; flex:none; }
.form{ background:var(--dark-2); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:32px; }
.form.on-paper{ background:var(--card); border-color:var(--line); }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--on-dark-mute); margin-bottom:7px; }
.form.on-paper .field label{ color:var(--ink-3); }
.field input, .field textarea, .field select{ width:100%; background:#0e1118; border:1px solid rgba(255,255,255,.12); border-radius:10px;
  padding:13px 14px; color:#fff; font-family:var(--sans); font-size:15px; transition:border-color .2s, box-shadow .2s; }
.form.on-paper .field input, .form.on-paper .field textarea, .form.on-paper .field select{ background:var(--paper); border-color:var(--line); color:var(--ink); }
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 30%, transparent); }
.field.err input, .field.err textarea{ border-color:#e0607a; }
.field .msg{ font-size:12.5px; color:#e0607a; margin-top:6px; }
.form .btn-primary{ width:100%; justify-content:center; padding:15px; font-size:16px; }
.form-success{ text-align:center; padding:30px 10px; }
.form-success .ok{ width:58px; height:58px; border-radius:50%; background:var(--accent); display:grid; place-items:center; margin:0 auto 18px; }
.form-success h3{ font-size:26px; color:#fff; } .form-success p{ color:var(--on-dark-mute); margin-top:10px; }
.form.on-paper .form-success h3{ color:var(--ink); } .form.on-paper .form-success p{ color:var(--ink-2); }

/* contact detail list */
.contact-detail{ display:flex; flex-direction:column; gap:0; margin-top:34px; }
.cd-row{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.12); }
.cd-row:first-child{ border-top:1px solid rgba(255,255,255,.12); }
.cd-row .cd-ic{ color:var(--accent); flex:none; margin-top:2px; }
.cd-row .cd-k{ font-size:12.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--on-dark-mute); }
.cd-row .cd-v{ font-size:16px; color:#fff; margin-top:3px; }
.cd-row .cd-v a{ border-bottom:1px solid var(--accent); }

/* faq */
.faq{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px 40px; }
.faq .qa h4{ font-size:18px; margin-bottom:8px; }
.faq .qa p{ font-size:15px; color:var(--ink-2); }

/* ---------- Footer ---------- */
footer{ background:var(--paper); border-top:1px solid var(--line); padding:64px 0 36px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr; gap:40px; }
.foot-grid h5{ font-family:var(--sans); font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:700; margin-bottom:16px; }
.foot-grid a{ display:block; color:var(--ink-2); font-size:15px; padding:5px 0; transition:color .2s; }
.foot-grid a:hover{ color:var(--accent); }
.foot-grid .sub{ display:flex; gap:8px; margin-top:14px; }
.foot-grid .sub input{ flex:1; border:1px solid var(--line); background:#fff; border-radius:10px; padding:11px 13px; font-family:var(--sans); font-size:14px; }
.foot-grid .sub input:focus{ outline:none; border-color:var(--accent); }
.foot-grid .sub button{ border:0; }
.social{ display:flex; gap:10px; margin-top:16px; }
.social a{ width:40px; height:40px; border:1px solid var(--line); border-radius:10px; display:grid; place-items:center; color:var(--ink-2); padding:0; transition:all .2s; }
.social a:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.foot-base{ display:flex; justify-content:space-between; align-items:center; margin-top:54px; padding-top:24px; border-top:1px solid var(--line); color:var(--ink-3); font-size:13.5px; flex-wrap:wrap; gap:12px; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .nav-links{ display:none; } .menu-btn{ display:block; }
  .nav .nav-cta{ display:none; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .portrait{ max-width:420px; }
  .position-grid, .method, .about-grid, .cta-grid, .frac-intro{ grid-template-columns:1fr; gap:34px; }
  .about-photo{ max-width:430px; aspect-ratio:1/1; }
  .svc-grid{ grid-template-columns:1fr; }
  .vp-grid{ grid-template-columns:1fr 1fr; }
  .e-grid{ grid-template-columns:1fr 1fr; }
  .ins-grid{ grid-template-columns:1fr 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .svc-detail{ grid-template-columns:1fr; gap:26px; padding:44px 0; }
  .story-narrative{ grid-template-columns:1fr; gap:24px; }
  .story-narrative .lead, .story-narrative .body{ grid-column:auto; }
  .beliefs{ grid-template-columns:1fr; }
  .fit-grid, .model-grid{ grid-template-columns:1fr; }
  .flow{ grid-template-columns:1fr 1fr; }
  .faq{ grid-template-columns:1fr; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  section.block{ padding:64px 0; }
  .hero{ padding:48px 0 50px; }
  .stat-row{ grid-template-columns:1fr; gap:20px; }
  .e-grid, .vp-grid, .ins-grid, .sd-items, .flow{ grid-template-columns:1fr; }
  .sd-items .sd-item:nth-child(2){ border-top:1px solid var(--line); padding-top:18px; }
  .foot-grid{ grid-template-columns:1fr; }
  .brand-sub{ display:none; }
}
