/* ============================================================
   DMR.agency — Design System
   Editorial / Swiss-modern. Cream + white canvas, single blue
   accent, Montserrat display, DM Sans body, hard 90° corners,
   hairline rules, section markers. Ported from the approved
   Claude Design handoff prototype and extended for all pages.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #ffffff;
  --bg2:       #f5f3ef;
  --bg3:       #eef6fb;
  --dark:      #181818;
  --blue:      #2e90c3;
  --blue2:     #1f7aaa;
  --blue-lt:   #eef6fb;
  --gold:      #ffc83a;
  --muted:     rgba(24,24,24,.55);
  --faint:     rgba(24,24,24,.1);
  --light:     rgba(24,24,24,.06);
  --d70:       rgba(24,24,24,.7);
  --grot:      'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --sans-body: 'DM Sans', 'Helvetica Neue', Arial, sans-serif;
  --serif:     Georgia, 'Times New Roman', serif;
  --fast:      0.12s ease;
  --base:      0.18s ease;
  --maxw:      1320px;
}

html { scroll-behavior: smooth; }
body {
  font-family: var(--sans-body);
  color: var(--dark);
  background: var(--bg);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
::selection { background: var(--dark); color: var(--bg); }
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg2); }
::-webkit-scrollbar-thumb { background: var(--dark); }
img { max-width: 100%; }
a { color: inherit; }

/* Fixed 4px blue top accent */
body::before {
  content: ''; display: block; height: 4px;
  background: var(--blue); width: 100%; position: fixed; top: 0; left: 0; z-index: 300;
}

/* Section horizontal padding scale */
.sx { padding-left: 24px; padding-right: 24px; }
@media (min-width: 640px)  { .sx { padding-left: 40px; padding-right: 40px; } }
@media (min-width: 1024px) { .sx { padding-left: 72px; padding-right: 72px; } }

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

/* ── Keyframes ── */
@keyframes wordReveal { from { opacity:0; transform:translateY(110%); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeUp     { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
@keyframes ticker     { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ── Scroll reveal (gated under html.js so it degrades without JS) ── */
html.js .rev { opacity:0; transform:translateY(24px); transition: opacity .6s ease, transform .6s ease; }
html.js .rev.in { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.22s} .d3{transition-delay:.34s} .d4{transition-delay:.46s} .d5{transition-delay:.58s}

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 4px; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
  padding: 14px 40px; background: var(--bg);
  border-bottom: 1px solid var(--faint);
}
@media (max-width: 639px) { .nav { padding: 12px 24px; } }
.nav-logo { display:flex; align-items:center; gap:8px; text-decoration:none; flex-shrink:0; }
.nav-logo img { height:42px; width:auto; display:block; }
.nav-logo-text { line-height:1; }
.nav-logo-text b { display:block; font-family:var(--grot); font-size:15px; font-weight:900; letter-spacing:.03em; color:var(--dark); line-height:1; }
.nav-logo-text span { display:block; font-family:var(--grot); font-size:7px; letter-spacing:.28em; font-weight:700; color:var(--muted); text-transform:uppercase; margin-top:2px; }
.nav-right { display:flex; align-items:center; gap:20px; }
.nav-links { display:flex; align-items:center; gap:18px; }
.nav-link {
  font-family: var(--grot); font-weight:700; font-size:9px;
  letter-spacing:.16em; text-transform:uppercase;
  color: var(--muted); text-decoration:none; transition:color var(--fast);
  white-space:nowrap;
}
.nav-link:hover, .nav-link[aria-current="page"] { color:var(--dark); }
.nav-link[aria-current="page"] { color:var(--blue); }

/* Dropdown (Services) */
.nav-item { position:relative; display:flex; align-items:center; }
.nav-item > .nav-link { display:inline-flex; align-items:center; gap:5px; }
.nav-caret { font-size:7px; line-height:1; letter-spacing:0; }
.nav-menu {
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%);
  background:var(--bg); border:1.5px solid var(--dark);
  min-width:248px; padding:8px; display:none; flex-direction:column; gap:2px; z-index:210;
}
/* Invisible bridge over the gap between the link and the menu so hover isn't lost in transit */
.nav-menu::before { content:""; position:absolute; left:0; right:0; top:-16px; height:16px; }
.nav-item:hover .nav-menu, .nav-item:focus-within .nav-menu { display:flex; }
.nav-menu a {
  font-family:var(--grot); font-weight:700; font-size:9.5px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--d70); text-decoration:none; padding:11px 12px;
  transition:background var(--fast), color var(--fast); line-height:1.3;
}
.nav-menu a span { display:block; font-family:var(--sans-body); font-weight:400; font-size:11px; letter-spacing:0; text-transform:none; color:var(--muted); margin-top:3px; }
.nav-menu a:hover { background:var(--bg2); color:var(--blue); }

.btn-nav {
  display:inline-flex; align-items:center; gap:7px;
  padding:11px 18px; background:var(--blue); color:var(--bg);
  font-family:var(--grot); font-weight:800; font-size:9.5px;
  letter-spacing:.16em; text-transform:uppercase; text-decoration:none;
  transition:background var(--fast); white-space:nowrap;
}
.btn-nav:hover { background:var(--blue2); }

/* Hamburger */
.nav-toggle {
  display:none; background:none; border:none; cursor:pointer; padding:8px;
  flex-direction:column; gap:5px; margin-left:6px;
  /* WCAG 2.5.5 / iOS HIG: guarantee a ≥44px touch target, bars centred */
  min-width:44px; min-height:44px; align-items:center; justify-content:center;
  -webkit-tap-highlight-color:transparent;
}
.nav-toggle span { width:22px; height:2px; background:var(--dark); display:block; transition:transform var(--base), opacity var(--base); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width: 960px) {
  .nav-toggle { display:flex; }
  .nav-right {
    position:fixed; top:calc(4px + 63px); left:0; right:0;
    background:var(--bg); border-bottom:1.5px solid var(--dark);
    flex-direction:column; align-items:stretch; gap:0; padding:8px 24px 20px;
    transform:translateY(-130%); transition:transform .28s ease; z-index:190;
    max-height:calc(100vh - 67px); overflow-y:auto;
  }
  .nav-right.open { transform:translateY(0); }
  .nav-links { flex-direction:column; align-items:stretch; gap:0; }
  .nav-links > a, .nav-item > .nav-link { padding:15px 4px; font-size:11px; border-bottom:1px solid var(--faint); }
  .nav-item > .nav-link { display:flex; }
  .nav-menu { position:static; transform:none; border:none; border-bottom:1px solid var(--faint); padding:0 0 8px 12px; display:flex; min-width:0; }
  .nav-menu::before { content:none; }
  .nav-menu a { padding:11px 4px; }
  .btn-nav { margin-top:16px; justify-content:center; padding:15px 18px; font-size:10.5px; }
}

/* ============================================================
   BUTTONS (shared)
   ============================================================ */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px; background:var(--blue); color:var(--bg);
  font-family:var(--grot); font-weight:800; font-size:10.5px;
  letter-spacing:.16em; text-transform:uppercase; text-decoration:none;
  transition:background var(--fast); border:none; cursor:pointer;
}
.btn-primary:hover { background:var(--blue2); }
.btn-outline {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 28px; background:transparent; color:var(--dark);
  border:1.5px solid var(--dark);
  font-family:var(--grot); font-weight:700; font-size:10.5px;
  letter-spacing:.16em; text-transform:uppercase; text-decoration:none;
  transition:all var(--fast); cursor:pointer;
}
.btn-outline:hover { background:var(--dark); color:var(--bg); }
.btn-outline-light { color:#fff; border-color:rgba(255,255,255,.5); }
.btn-outline-light:hover { background:#fff; color:var(--dark); border-color:#fff; }
.btn-cta {
  display:inline-flex; align-items:center; gap:12px; padding:18px 34px;
  background:var(--blue); color:#fff; font-family:var(--grot); font-weight:900;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none;
  transition:background var(--fast); border:none; cursor:pointer;
}
.btn-cta:hover { background:var(--blue2); }

/* ============================================================
   SHARED SECTION PIECES
   ============================================================ */
.pill-blue {
  display:inline-block; padding:4px 9px 5px;
  background:var(--blue); color:var(--bg);
  font-family:var(--grot); font-weight:800; font-size:9.5px;
  letter-spacing:.16em; text-transform:uppercase;
}
.mast { display:flex; align-items:center; gap:14px; margin-bottom:52px; }
.mast-label { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); }
.hr-rule { height:1px; background:var(--faint); border:none; margin-bottom:56px; }

.eyebrow { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:var(--blue); }
.section-em { font-family:var(--sans-body); font-style:italic; text-transform:none; font-weight:600; letter-spacing:-.01em; }

/* Generic interior page hero */
.page-hero { background:var(--bg); padding:150px 72px 64px; border-bottom:1px solid var(--faint); }
@media (max-width:1023px){ .page-hero { padding:140px 40px 56px; } }
@media (max-width:639px){ .page-hero { padding:120px 24px 48px; } }
.page-hero.dark { background:var(--dark); border-bottom:none; position:relative; overflow:hidden; }
.page-hero-eyebrow { margin-bottom:18px; }
.page-hero h1 {
  font-family:var(--grot); font-weight:900; font-size:clamp(40px,7vw,92px);
  line-height:.92; letter-spacing:-.03em; text-transform:uppercase; color:var(--dark); max-width:14ch;
}
.page-hero.dark h1 { color:#fff; max-width:18ch; }
.page-hero h1 em, .page-hero h1 .section-em { color:var(--blue); }
.page-hero p.lead {
  font-family:var(--sans-body); font-size:clamp(16px,1.7vw,20px); line-height:1.6;
  color:var(--d70); max-width:620px; margin-top:28px;
}
.page-hero.dark p.lead { color:rgba(255,255,255,.6); }
.page-hero-actions { margin-top:40px; display:flex; gap:16px; flex-wrap:wrap; }
/* ---- Strategy Call trust row ---- */
.sc-trust { display:flex; justify-content:center; gap:32px; flex-wrap:wrap; }
.sc-trust-item { display:flex; align-items:center; gap:8px; font-family:var(--sans-body); font-size:14.5px; font-weight:600; color:var(--d70); letter-spacing:.01em; }
.sc-trust-icon { display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; border-radius:50%; background:var(--blue); color:#fff; font-size:11px; font-weight:700; flex-shrink:0; }

/* Section base */
.section { padding:96px 72px; }
@media (max-width:1023px){ .section { padding:80px 40px; } }
@media (max-width:639px){ .section { padding:64px 24px; } }
.section.bg2 { background:var(--bg2); }
.section.dark { background:var(--dark); color:#fff; }
.section.dark .mast-label { color:rgba(255,255,255,.4); }

.section-hed {
  font-family:var(--grot); font-weight:900; font-size:clamp(30px,4.4vw,58px);
  line-height:.95; letter-spacing:-.025em; text-transform:uppercase; color:var(--dark);
}
.section.dark .section-hed { color:#fff; }
.section-hed em, .section-hed .section-em { font-family:var(--sans-body); font-style:italic; text-transform:none; font-weight:600; color:var(--blue); }
.section-intro { font-family:var(--sans-body); font-size:16.5px; line-height:1.68; color:var(--d70); max-width:680px; margin-top:24px; }
.section.dark .section-intro { color:rgba(255,255,255,.65); }

/* ============================================================
   HOME — HERO
   ============================================================ */
.hero { min-height:100vh; min-height:100svh; background:var(--bg); display:flex; flex-direction:column; padding-top:72px; border-bottom:1px solid var(--faint); }
.hero-body { flex:1; display:flex; flex-direction:column; justify-content:center; padding:40px 72px 32px; }
@media (max-width:1023px){ .hero-body { padding:40px 40px 28px; } }
@media (max-width:639px){ .hero-body { padding:36px 24px 28px; } }
.hero-over { display:flex; align-items:center; gap:16px; margin-bottom:32px; }
html.js .hero-over { animation: fadeUp .45s ease .1s forwards; opacity:0; }
.hero-over-text { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); }
.hero-hed { font-family:var(--grot); font-weight:900; font-size:clamp(46px,8.5vw,118px); line-height:.91; letter-spacing:-.03em; text-transform:uppercase; color:var(--dark); }
.hero-hed .line { display:block; }
.hero-hed .w { display:inline-block; overflow:hidden; vertical-align:top; }
.hero-hed .wi { display:inline-block; }
html.js .hero-hed .wi { opacity:0; animation: wordReveal .6s cubic-bezier(.22,1,.36,1) forwards; }
.hero-hed .wi-blue { color:var(--blue); }
.hero-hed .line-serif { font-family:var(--serif); font-style:italic; font-weight:400; text-transform:none; letter-spacing:-.01em; font-size:.62em; color:var(--muted); }
.hero-sub { margin-top:28px; max-width:540px; }
html.js .hero-sub { animation: fadeUp .6s ease 1.45s forwards; opacity:0; }
.hero-sub p { font-family:var(--sans-body); font-style:italic; font-size:clamp(17px,1.8vw,22px); line-height:1.45; color:var(--muted); }
.hero-actions { margin-top:34px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
html.js .hero-actions { animation: fadeUp .6s ease 1.7s forwards; opacity:0; }
html.js .hero .ticker-wrap { animation: fadeUp .5s ease 2s forwards; opacity:0; }

/* ── TICKER ── */
.ticker-wrap { background:var(--dark); overflow:hidden; }
.ticker-track { display:flex; align-items:center; white-space:nowrap; animation: ticker 32s linear infinite; padding:15px 0; }
.ticker-track:hover { animation-play-state: paused; }
.ticker-item { font-family:var(--grot); font-weight:700; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.55); padding-right:24px; white-space:nowrap; }
.ticker-dot { display:inline-block; width:5px; height:5px; background:var(--blue); border-radius:50%; margin:0 24px 0 24px; vertical-align:middle; }

/* ── Pillars (home: Earn / Build / Drive) ── */
.pillars { display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:767px){ .pillars { grid-template-columns:1fr; } }
.pillar { padding:40px 36px 40px 0; border-bottom:1px solid var(--faint); }
@media (min-width:768px){ .pillar:not(:first-child){ padding-left:36px; border-left:1px solid var(--faint); } }
@media (max-width:767px){ .pillar { padding:30px 0; } }
.pillar-n { font-family:var(--sans-body); font-weight:600; font-size:40px; line-height:1; color:rgba(24,24,24,.1); display:block; margin-bottom:16px; }
.pillar h3 { font-family:var(--grot); font-weight:900; font-size:15px; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px; }
.pillar p { font-family:var(--sans-body); font-size:14.5px; line-height:1.55; color:var(--d70); }

/* ============================================================
   SERVICE CARD (home + service pages)
   ============================================================ */
.service-grid { display:grid; grid-template-columns:1.15fr .85fr; gap:72px; align-items:start; }
@media (max-width:900px){ .service-grid { grid-template-columns:1fr; gap:48px; } }
.svc-card { border:1.5px solid var(--dark); padding:36px; background:var(--bg2); }
.svc-badge { display:inline-block; padding:4px 10px 5px; background:var(--dark); color:var(--bg); font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:22px; }
.svc-title { font-family:var(--grot); font-weight:900; font-size:22px; letter-spacing:-.02em; text-transform:uppercase; line-height:1.05; margin-bottom:6px; }
.svc-sub { font-family:var(--sans-body); font-style:italic; font-size:15px; color:var(--muted); margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--faint); }
.svc-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:28px; }
.svc-list li { display:flex; align-items:flex-start; gap:12px; font-family:var(--sans-body); font-size:15px; line-height:1.45; color:var(--d70); }
.svc-bullet { width:12px; height:12px; flex-shrink:0; background:var(--blue); margin-top:4px; }
.svc-terms { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--faint); padding-top:20px; }
.svc-term { display:flex; justify-content:space-between; align-items:center; padding:9px 0; border-bottom:1px solid var(--light); gap:16px; }
.svc-term:last-child { border-bottom:none; }
.svc-term-lbl { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.svc-term-val { font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--dark); text-align:right; }
.svc-term-val.open { color:var(--blue); }

/* Two-offer split (home + about) */
.offers { display:flex; flex-direction:column; gap:0; border:1.5px solid var(--dark); }
.offers-top { display:grid; grid-template-columns:1fr 1fr; gap:0; border-bottom:1.5px solid var(--dark); }
@media (max-width:767px){ .offers-top { grid-template-columns:1fr; } }
.offer { padding:40px 36px; }
.offers-top .offer:first-child { border-right:1.5px solid var(--dark); }
@media (max-width:767px){ .offers-top .offer:first-child { border-right:none; border-bottom:1.5px solid var(--dark); } }
.offer-wide { border-top:0; }
.offer-tag { display:inline-block; padding:4px 10px 5px; background:var(--blue); color:#fff; font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:18px; }
.offer-tag.alt { background:var(--dark); }
.offer h3 { font-family:var(--grot); font-weight:900; font-size:24px; letter-spacing:-.02em; text-transform:uppercase; margin-bottom:12px; }
.offer p { font-family:var(--sans-body); font-size:15px; line-height:1.6; color:var(--d70); margin-bottom:22px; }
.offer .offer-meta { font-family:var(--sans-body); font-style:italic; font-size:13.5px; color:var(--muted); margin-bottom:22px; }

/* ============================================================
   PROOF / STATS
   ============================================================ */
.proof-hed { font-family:var(--grot); font-weight:900; font-size:clamp(26px,3.6vw,46px); line-height:.97; letter-spacing:-.02em; text-transform:uppercase; color:var(--dark); max-width:660px; margin-bottom:60px; }
.proof-hed em, .proof-hed .section-em { font-family:var(--sans-body); font-style:italic; text-transform:none; font-weight:600; }
.stats-3 { display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:700px){ .stats-3 { grid-template-columns:1fr; } }
.stat-cell { padding:44px 40px 44px 0; border-bottom:1px solid var(--faint); }
@media (min-width:701px){ .stat-cell:not(:first-child){ padding-left:40px; border-left:1px solid var(--faint); } }
@media (max-width:700px){ .stat-cell { padding:32px 0; } }
.stat-num { font-family:var(--sans-body); font-weight:600; font-size:clamp(46px,6.5vw,92px); line-height:1; letter-spacing:-.04em; color:var(--dark); border-bottom:2.5px solid var(--blue); display:inline-block; padding-bottom:6px; margin-bottom:16px; }
.stat-lbl { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
.stat-source { font-family:var(--sans-body); font-style:italic; font-size:13.5px; color:var(--muted); }

/* Big publication names — scrolling ticker */
.pub-block { margin-top:60px; padding-top:40px; border-top:1px solid var(--faint); }
.pub-block-lbl { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.28em; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.pub-ticker-wrap { overflow:hidden; border-top:1px solid var(--faint); border-bottom:1px solid var(--faint); }
.pub-ticker-track { display:flex; align-items:center; white-space:nowrap; animation:ticker 28s linear infinite; padding:18px 0; }
.pub-ticker-track:hover { animation-play-state:paused; }
.pub-ticker-item { font-family:var(--grot); font-weight:900; font-size:clamp(15px,2vw,26px); letter-spacing:.05em; text-transform:uppercase; color:var(--blue); white-space:nowrap; cursor:default; transition:color var(--fast); }
.pub-ticker-item:hover { color:var(--blue2); }
.pub-ticker-dot { color:rgba(24,24,24,.2); padding:0 18px; font-weight:400; font-size:.8em; }

/* ============================================================
   CLIENTS LOGO GRID (home)
   ============================================================ */
.logo-grid { display:grid; grid-template-columns:repeat(5,1fr); border-top:1px solid var(--faint); border-left:1px solid var(--faint); }
@media (max-width:900px){ .logo-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:500px){ .logo-grid { grid-template-columns:repeat(2,1fr); } }
.logo-cell { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:20px 18px; display:flex; align-items:center; justify-content:center; min-height:110px; transition:background var(--fast); }
.logo-cell:hover { background:var(--bg2); }
.logo-cell img { width:78%; max-height:80px; object-fit:contain; filter:grayscale(1); opacity:.7; transition:all var(--fast); }
.logo-cell:hover img { filter:grayscale(0); opacity:1; }
.logo-cell a { display:flex; align-items:center; justify-content:center; width:100%; height:100%; }
/* Logos with heavy whitespace in the source file — scale up individually */
.logo-cell img[src*="CURED"] { width:92%; transform:scale(2.1); }
.logo-cell img[src*="m-e1719"] { width:92%; transform:scale(1.45); }

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.process-top { display:grid; grid-template-columns:1fr 1fr; gap:64px; margin-bottom:56px; align-items:end; }
@media (max-width:767px){ .process-top { grid-template-columns:1fr; gap:20px; } }
.steps { display:grid; grid-template-columns:repeat(4,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:860px){ .steps { grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .steps { grid-template-columns:1fr; } }
.step { padding:32px 24px 32px 0; border-bottom:1px solid var(--faint); }
@media (min-width:861px){ .step:not(:first-child){ padding-left:24px; border-left:1px solid var(--faint); } }
@media (max-width:860px) and (min-width:481px){ .step:nth-child(2n){ padding-left:24px; border-left:1px solid var(--faint); } }
.step-n { font-family:var(--sans-body); font-weight:600; font-size:44px; line-height:1; color:rgba(24,24,24,.1); display:block; margin-bottom:14px; }
.section.dark .step { border-color:rgba(255,255,255,.1); }
.section.dark .step-n { color:rgba(255,255,255,.14); }
.step-title { font-family:var(--grot); font-weight:900; font-size:13.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--dark); margin-bottom:10px; }
.section.dark .step-title { color:#fff; }
.step-body { font-family:var(--sans-body); font-size:14.5px; line-height:1.55; color:var(--d70); }
.section.dark .step-body { color:rgba(255,255,255,.6); }
/* 7-step variant wraps to rows */
.steps.steps-7 { grid-template-columns:repeat(4,1fr); }
@media (max-width:860px){ .steps.steps-7 { grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .steps.steps-7 { grid-template-columns:1fr; } }

/* ============================================================
   TERMS (dark) — key/value table
   ============================================================ */
.terms-grid { display:grid; grid-template-columns:1.3fr .7fr; gap:80px; align-items:center; }
@media (max-width:860px){ .terms-grid { grid-template-columns:1fr; gap:48px; } }
.terms-hed { font-family:var(--grot); font-weight:900; font-size:clamp(40px,6.5vw,92px); line-height:.91; letter-spacing:-.035em; text-transform:uppercase; color:#fff; }
.terms-hed mark { background:var(--blue); color:#fff; padding:0 .06em; }
.terms-body { font-family:var(--sans-body); font-size:17px; line-height:1.65; color:rgba(255,255,255,.65); text-align:justify; margin-top:24px; }
.kv-table { border:1px solid rgba(255,255,255,.15); }
.kv-row { display:flex; justify-content:space-between; align-items:center; padding:17px 22px; gap:16px; border-bottom:1px solid rgba(255,255,255,.07); }
.kv-row:last-child { border-bottom:none; }
.kv-key { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.4); }
.kv-val { font-family:var(--grot); font-weight:900; font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:#fff; text-align:right; }
.kv-val.open { color:var(--blue); }
/* light variant */
.kv-table.light { border-color:var(--faint); }
.kv-table.light .kv-row { border-color:var(--light); }
.kv-table.light .kv-key { color:var(--muted); }
.kv-table.light .kv-val { color:var(--dark); }

/* ============================================================
   TESTIMONIAL CARD
   ============================================================ */
.testi-card { border:1.5px solid var(--dark); padding:52px; position:relative; max-width:940px; margin:0 auto; background:var(--bg2); }
@media (max-width:639px){ .testi-card { padding:48px 24px 36px; } }
.testi-qmark { font-family:var(--sans-body); font-weight:600; font-size:120px; line-height:.65; color:var(--blue); position:absolute; top:22px; left:36px; pointer-events:none; user-select:none; }
.testi-text { font-family:var(--sans-body); font-style:italic; font-size:clamp(18px,2.1vw,25px); line-height:1.52; color:var(--dark); text-align:justify; position:relative; z-index:1; padding-top:48px; margin-bottom:32px; }
.testi-text strong { font-style:normal; font-weight:700; color:var(--blue); }
.testi-attr { display:flex; align-items:center; gap:16px; border-top:1px solid var(--faint); padding-top:22px; }
.testi-avatar { width:50px; height:50px; border-radius:50%; object-fit:cover; filter:grayscale(.2); }
.testi-name { font-family:var(--grot); font-weight:800; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--dark); }
.testi-role { font-family:var(--sans-body); font-style:italic; font-size:13px; color:var(--muted); margin-top:3px; }

/* ============================================================
   APPLY / CTA (dark, watermark)
   ============================================================ */
.cta-dark { background:var(--dark); padding:120px 72px; text-align:center; position:relative; overflow:hidden; }
@media (max-width:1023px){ .cta-dark { padding:96px 40px; } }
@media (max-width:639px){ .cta-dark { padding:80px 24px; } }
.cta-wm { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:var(--grot); font-weight:900; font-size:clamp(80px,20vw,260px); letter-spacing:-.05em; text-transform:uppercase; color:rgba(255,255,255,.02); pointer-events:none; user-select:none; white-space:nowrap; }
.cta-badge { display:inline-block; padding:4px 12px 5px; background:var(--blue); color:#fff; font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.22em; text-transform:uppercase; margin-bottom:28px; position:relative; z-index:1; }
.cta-badge.gold { background:var(--gold); color:var(--dark); }
.cta-hed { font-family:var(--grot); font-weight:900; font-size:clamp(42px,8vw,104px); line-height:.91; letter-spacing:-.035em; text-transform:uppercase; color:#fff; margin-bottom:24px; position:relative; z-index:1; }
.cta-sub { font-family:var(--sans-body); font-style:italic; font-size:clamp(16px,1.8vw,21px); color:rgba(255,255,255,.5); margin-bottom:40px; position:relative; z-index:1; max-width:640px; margin-left:auto; margin-right:auto; }
.cta-actions { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }
.cta-note { margin-top:24px; font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.35); position:relative; z-index:1; }

/* ============================================================
   FOOTER
   ============================================================ */
footer.site-footer { background:var(--dark); border-top:1px solid rgba(255,255,255,.08); padding:56px 72px 28px; }
@media (max-width:1023px){ footer.site-footer { padding:48px 40px 28px; } }
@media (max-width:639px){ footer.site-footer { padding:40px 24px 24px; } }
.footer-top { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.08); }
@media (max-width:860px){ .footer-top { grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:480px){ .footer-top { grid-template-columns:1fr; } }
.footer-logo { display:flex; align-items:center; gap:10px; text-decoration:none; margin-bottom:16px; }
.footer-logo img { height:46px; width:auto; display:block; }
.footer-logo-text { line-height:1; }
.footer-logo-text b { display:block; font-family:var(--grot); font-size:18px; font-weight:900; letter-spacing:.03em; color:#fff; line-height:1; }
.footer-logo-text span { display:block; font-family:var(--grot); font-size:8px; letter-spacing:.28em; font-weight:700; color:rgba(255,255,255,.45); text-transform:uppercase; margin-top:3px; }
.footer-brand p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:rgba(255,255,255,.5); max-width:280px; }
.footer-col h4 { font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:16px; }
.footer-col a { display:block; font-family:var(--sans-body); font-size:13.5px; color:rgba(255,255,255,.7); text-decoration:none; padding:5px 0; transition:color var(--fast); }
.footer-col a:hover { color:#fff; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; padding-top:24px; }
.footer-copy { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.35); }
.footer-legal { display:flex; gap:22px; }
.footer-legal a { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.35); text-decoration:none; transition:color var(--fast); }
.footer-legal a:hover { color:#fff; }

/* ============================================================
   CASE STUDY DETAIL
   ============================================================ */
.cs-hero { background:var(--dark); padding:160px 72px 90px; position:relative; overflow:hidden; }
@media (max-width:1023px){ .cs-hero { padding:140px 40px 72px; } }
@media (max-width:639px){ .cs-hero { padding:120px 24px 64px; } }
.cs-hero-wm { position:absolute; bottom:-20px; right:-10px; font-family:var(--grot); font-weight:900; font-size:clamp(80px,18vw,220px); letter-spacing:-.05em; text-transform:uppercase; color:rgba(255,255,255,.03); pointer-events:none; user-select:none; line-height:1; }
.cs-breadcrumb { display:flex; align-items:center; gap:10px; margin-bottom:36px; flex-wrap:wrap; }
.breadcrumb-pill { display:inline-block; padding:3px 9px 4px; background:var(--blue); color:#fff; font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.18em; text-transform:uppercase; }
.breadcrumb-sep { color:rgba(255,255,255,.25); font-family:var(--grot); font-size:9px; }
.breadcrumb-text { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.4); }
.cs-label { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:20px; }
.cs-title { font-family:var(--grot); font-weight:900; font-size:clamp(34px,5.6vw,76px); line-height:.95; letter-spacing:-.03em; text-transform:uppercase; color:#fff; margin-bottom:28px; max-width:18ch; }
.cs-title span, .cs-title em { color:var(--blue); font-style:normal; }
.cs-desc { font-family:var(--sans-body); font-size:clamp(16px,1.6vw,19px); line-height:1.6; color:rgba(255,255,255,.65); max-width:640px; margin-bottom:48px; }
.cs-hero-stats { display:flex; gap:0; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,.1); }
.cs-hero-stat { padding:28px 48px 28px 0; flex:1; min-width:150px; }
.cs-hero-stat:not(:first-child){ padding-left:48px; border-left:1px solid rgba(255,255,255,.08); }
@media (max-width:639px){ .cs-hero-stat { padding:20px 0; border-left:none !important; flex:0 0 50%; border-top:1px solid rgba(255,255,255,.08); } }
.cs-hero-stat-num { font-family:var(--grot); font-weight:900; font-size:clamp(30px,4.2vw,52px); line-height:1; letter-spacing:-.03em; color:#fff; padding-bottom:6px; border-bottom:2px solid var(--gold); display:inline-block; margin-bottom:12px; }
.cs-hero-stat-lbl { font-family:var(--sans-body); font-size:12px; font-weight:500; letter-spacing:.04em; color:rgba(255,255,255,.45); }

/* info strip */
.info-strip { background:var(--bg2); border-bottom:1px solid var(--faint); padding:0 72px; display:grid; grid-template-columns:repeat(4,1fr); }
@media (max-width:1023px){ .info-strip { padding:0 40px; } }
@media (max-width:767px){ .info-strip { grid-template-columns:repeat(2,1fr); padding:0 24px; } }
@media (max-width:400px){ .info-strip { grid-template-columns:1fr; } }
.info-item { padding:28px 28px 24px 0; border-right:1px solid var(--faint); }
.info-item:not(:first-child){ padding-left:28px; }
.info-item:last-child { border-right:none; }
@media (max-width:767px){ .info-item:nth-child(2n){ border-right:none; } }
.info-key { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.info-val { font-family:var(--grot); font-weight:800; font-size:13px; letter-spacing:.04em; color:var(--dark); }

.cs-section { padding:80px 72px; }
@media (max-width:1023px){ .cs-section { padding:64px 40px; } }
@media (max-width:639px){ .cs-section { padding:52px 24px; } }
.cs-section.bg2 { background:var(--bg2); }
.cs-h2 { font-family:var(--grot); font-weight:900; font-size:clamp(26px,3.6vw,44px); line-height:.97; letter-spacing:-.02em; text-transform:uppercase; color:var(--dark); margin-bottom:24px; }
.cs-body { font-family:var(--sans-body); font-size:16.5px; line-height:1.7; color:var(--d70); max-width:760px; }
.cs-body + .cs-body { margin-top:16px; }
.cs-body strong { color:var(--dark); }
.cs-quote { border-left:3px solid var(--blue); padding-left:28px; font-family:var(--sans-body); font-style:italic; font-size:18px; line-height:1.6; color:var(--d70); margin-top:8px; }
.cs-quote strong { font-style:normal; font-weight:700; color:var(--dark); }
.cs-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; margin-top:44px; }
@media (max-width:860px){ .cs-grid-2 { grid-template-columns:1fr; gap:36px; } }

/* approach tactics */
.tactics { display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); margin-top:48px; }
@media (max-width:860px){ .tactics { grid-template-columns:1fr; } }
.tactic { padding:40px 32px 40px 0; border-bottom:1px solid var(--faint); }
@media (min-width:861px){ .tactic:not(:first-child){ padding-left:32px; border-left:1px solid var(--faint); } }
.tactic-n { font-family:var(--grot); font-weight:900; font-size:42px; line-height:1; color:rgba(24,24,24,.08); margin-bottom:16px; }
.tactic-title { font-family:var(--grot); font-weight:800; font-size:14px; letter-spacing:.08em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.tactic-body { font-family:var(--sans-body); font-size:15px; line-height:1.65; color:var(--d70); }
.tactic-pubs { display:flex; flex-wrap:wrap; gap:6px; margin-top:16px; }
.tactic-pub { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.12em; text-transform:uppercase; padding:4px 9px; background:var(--blue-lt); color:var(--blue2); }

/* results cards */
.results-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; margin-top:48px; }
@media (max-width:767px){ .results-grid { grid-template-columns:1fr; } }
.result-stack { display:flex; flex-direction:column; gap:24px; }
.result-card { border:1.5px solid var(--faint); padding:36px; position:relative; overflow:hidden; }
.result-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--blue); }
.result-card-big { background:var(--dark); border-color:var(--dark); }
.result-card-big::before { background:var(--gold); }
.result-num { font-family:var(--grot); font-weight:900; font-size:clamp(44px,6.5vw,84px); line-height:1; letter-spacing:-.04em; color:var(--dark); border-bottom:2.5px solid var(--blue); display:inline-block; padding-bottom:6px; margin-bottom:18px; }
.result-card-big .result-num { color:#fff; border-bottom-color:var(--gold); }
.result-lbl { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; }
.result-card-big .result-lbl { color:rgba(255,255,255,.45); }
.result-desc { font-family:var(--sans-body); font-size:14.5px; line-height:1.6; color:var(--d70); }
.result-card-big .result-desc { color:rgba(255,255,255,.65); }
.results-list { margin-top:48px; display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:700px){ .results-list { grid-template-columns:1fr; } }
.result-row { padding:28px 24px 28px 0; border-bottom:1px solid var(--faint); }
@media (min-width:701px){ .result-row:not(:first-child){ padding-left:24px; border-left:1px solid var(--faint); } }
.result-row-val { font-family:var(--grot); font-weight:900; font-size:clamp(24px,3vw,40px); letter-spacing:-.02em; color:var(--blue); margin-bottom:6px; }
.result-row-lbl { font-family:var(--sans-body); font-size:13px; color:var(--muted); }

/* data table (case study coverage) */
.data-table { width:100%; border-collapse:collapse; margin-top:32px; border-top:1.5px solid var(--dark); font-family:var(--sans-body); }
.data-table th { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); text-align:left; padding:14px 16px 14px 0; border-bottom:1px solid var(--faint); }
.data-table td { font-size:14.5px; color:var(--d70); padding:14px 16px 14px 0; border-bottom:1px solid var(--faint); vertical-align:top; }
.data-table td strong { color:var(--dark); font-weight:700; }
.data-table .num { font-family:var(--grot); font-weight:800; color:var(--dark); white-space:nowrap; }
.data-table tr:hover td { background:var(--bg2); }

/* more case studies */
.more-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:44px; }
@media (max-width:639px){ .more-grid { grid-template-columns:1fr; } }
.more-card { border:1px solid var(--faint); padding:32px; text-decoration:none; display:block; transition:border-color var(--fast), background var(--fast); }
.more-card:hover { border-color:var(--blue); background:var(--blue-lt); }
.more-card-tag { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin-bottom:12px; }
.more-card-result { font-family:var(--grot); font-weight:900; font-size:clamp(22px,3vw,36px); letter-spacing:-.02em; line-height:1; color:var(--dark); margin-bottom:8px; }
.more-card-title { font-family:var(--sans-body); font-size:14px; color:var(--muted); line-height:1.5; }
.more-card-arrow { font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-top:20px; display:block; }

/* ============================================================
   CASE STUDIES INDEX
   ============================================================ */
/* ---- Filter bar (reusable component — see src/templates/filterComponent.mjs) ---- */
.cs-index-page .page-hero { padding-bottom:36px; }
.cs-index-section { padding-top:24px; }
.cs-filterbar { display:flex; flex-wrap:wrap; align-items:center; gap:14px 32px; background:var(--dark); border-left:3px solid var(--gold); padding:18px 22px; margin-bottom:40px; }
.cs-filterbar[hidden] { display:none; }
#cs-sections[hidden], #cs-flat[hidden], #cs-empty[hidden], #cs-clear[hidden] { display:none; }
.cs-filter-group { display:flex; align-items:center; gap:10px; }
.cs-filter-lbl { font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.45); }
.cs-filter-select { position:relative; display:inline-block; }
.cs-filter-select select { appearance:none; -webkit-appearance:none; -moz-appearance:none; font-family:var(--grot); font-weight:700; font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:#fff; background:transparent; border:1px solid rgba(255,255,255,.25); padding:9px 32px 10px 12px; cursor:pointer; transition:border-color var(--fast), background var(--fast), color var(--fast); border-radius:0; }
.cs-filter-select select:hover, .cs-filter-select select:focus { border-color:#fff; outline:none; }
.cs-filter-select select.on { background:#fff; border-color:#fff; color:var(--dark); }
.cs-filter-select select option { color:var(--dark); background:#fff; }
.cs-filter-select::after { content:""; position:absolute; right:13px; top:50%; width:6px; height:6px; border-right:1.5px solid rgba(255,255,255,.55); border-bottom:1.5px solid rgba(255,255,255,.55); transform:translateY(-70%) rotate(45deg); pointer-events:none; }
.cs-filter-select:has(select.on)::after { border-right-color:var(--dark); border-bottom-color:var(--dark); }
.cs-filter-clear { margin-left:auto; font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); background:none; border:0; padding:0; cursor:pointer; }
.cs-filter-clear:hover { color:#fff; }
@media (max-width:700px){
  .cs-filterbar { flex-direction:column; align-items:stretch; gap:12px; }
  .cs-filter-group { justify-content:space-between; }
  .cs-filter-select select { width:100%; min-width:180px; }
  .cs-filter-clear { margin-left:0; text-align:left; }
}
.cs-filter-empty { font-family:var(--sans-body); font-size:14.5px; color:var(--muted); padding:32px 0; }
.cs-filter-empty a { color:var(--blue); font-weight:600; text-decoration:none; }
.cs-filter-empty a:hover { text-decoration:underline; }

.cs-cat { margin-top:56px; }
.cs-cat:first-of-type { margin-top:0; }
.cs-cat-head { display:flex; align-items:baseline; gap:14px; margin-bottom:24px; padding-bottom:14px; border-bottom:1.5px solid var(--dark); }
.cs-cat-head h2 { font-family:var(--grot); font-weight:900; font-size:clamp(20px,2.6vw,30px); letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); }
.cs-cat-head .count { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.cs-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-left:1px solid var(--faint); }
@media (max-width:900px){ .cs-cards { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .cs-cards { grid-template-columns:1fr; } }
.cs-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); border-top:1px solid var(--faint); padding:32px 28px; text-decoration:none; display:flex; flex-direction:column; transition:background var(--fast); position:relative; }
.cs-card:hover { background:var(--bg2); }
.cs-card.feature { background:var(--dark); }
.cs-card.feature:hover { background:#000; }
.cs-card-tag { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.cs-card h3 { font-family:var(--grot); font-weight:900; font-size:17px; line-height:1.15; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.cs-card.feature h3 { color:#fff; }
.cs-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.55; color:var(--d70); margin-bottom:20px; flex:1; }
.cs-card.feature p { color:rgba(255,255,255,.6); }
.cs-card-stats { display:flex; flex-wrap:wrap; gap:14px 22px; margin-bottom:18px; }
.cs-card-stat { }
.cs-card-stat b { display:block; font-family:var(--grot); font-weight:900; font-size:18px; letter-spacing:-.01em; color:var(--blue); }
.cs-card.feature .cs-card-stat b { color:var(--gold); }
.cs-card-stat span { font-family:var(--grot); font-weight:700; font-size:7.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.cs-card.feature .cs-card-stat span { color:rgba(255,255,255,.45); }
.cs-card-arrow { font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); }

/* ============================================================
   CLIENTS DIRECTORY
   ============================================================ */
.client-cat { margin-top:52px; }
.client-cat:first-of-type { margin-top:0; }
.client-cat-head { font-family:var(--grot); font-weight:900; font-size:clamp(18px,2.4vw,26px); letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:24px; padding-bottom:12px; border-bottom:1.5px solid var(--dark); }
.client-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-left:1px solid var(--faint); }
@media (max-width:860px){ .client-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .client-grid { grid-template-columns:1fr; } }
.client-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); border-top:1px solid var(--faint); padding:28px; display:flex; flex-direction:column; transition:background var(--fast); }
.client-card:hover { background:var(--bg2); }
.client-card-logo { height:40px; display:flex; align-items:center; margin-bottom:18px; }
.client-card-logo img { max-height:40px; max-width:150px; object-fit:contain; filter:grayscale(1); opacity:.6; transition:all var(--fast); }
.client-card:hover .client-card-logo img { filter:grayscale(0); opacity:1; }
.client-card-industry { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.18em; text-transform:uppercase; color:var(--blue); margin-bottom:6px; }
.client-card h3 { font-family:var(--grot); font-weight:900; font-size:16px; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:4px; }
.client-card .loc { font-family:var(--sans-body); font-style:italic; font-size:12.5px; color:var(--muted); margin-bottom:12px; }
.client-card .result { font-family:var(--grot); font-weight:900; font-size:15px; color:var(--blue); margin-bottom:12px; }
.client-card p { font-family:var(--sans-body); font-size:13px; line-height:1.55; color:var(--d70); flex:1; }
.client-card a.cs-link { font-family:var(--grot); font-weight:800; font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); text-decoration:none; margin-top:14px; }

/* ============================================================
   TESTIMONIALS LIST
   ============================================================ */
.testi-list { display:grid; grid-template-columns:1fr 1fr; gap:28px; }
@media (max-width:860px){ .testi-list { grid-template-columns:1fr; } }
.testi-item { border:1.5px solid var(--dark); padding:36px; background:var(--bg); display:flex; flex-direction:column; }
.testi-stars { color:var(--blue); font-size:14px; letter-spacing:2px; margin-bottom:18px; }
.testi-item-title { font-family:var(--grot); font-weight:900; font-size:15px; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:14px; }
.testi-item-text { font-family:var(--sans-body); font-size:14.5px; line-height:1.62; color:var(--d70); margin-bottom:24px; flex:1; }
.testi-item-text strong { color:var(--dark); font-weight:600; }
.testi-item-attr { display:flex; align-items:center; gap:14px; border-top:1px solid var(--faint); padding-top:18px; }
.testi-item-attr img { width:46px; height:46px; border-radius:50%; object-fit:cover; }
.testi-item-name { font-family:var(--grot); font-weight:800; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--dark); }
.testi-item-co { font-family:var(--sans-body); font-style:italic; font-size:12.5px; color:var(--muted); margin-top:2px; }
.testi-related { margin-top:16px; }
.testi-related a { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); text-decoration:none; display:inline-block; }

/* ============================================================
   ABOUT — timeline, team, press
   ============================================================ */
.timeline { border-left:1.5px solid var(--dark); margin-top:8px; }
.tl-item { padding:0 0 36px 32px; position:relative; }
.tl-item::before { content:''; position:absolute; left:-7px; top:4px; width:12px; height:12px; background:var(--blue); }
.tl-item:last-child { padding-bottom:0; }
.tl-year { font-family:var(--grot); font-weight:900; font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:var(--dark); margin-bottom:8px; }
.tl-body { font-family:var(--sans-body); font-size:15px; line-height:1.62; color:var(--d70); max-width:680px; }

.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); margin-top:44px; }
@media (max-width:767px){ .team-grid { grid-template-columns:1fr; } }
.team-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:32px; }
.team-card img { width:72px; height:72px; border-radius:50%; object-fit:cover; margin-bottom:18px; filter:grayscale(.3); }
.team-card h3 { font-family:var(--grot); font-weight:900; font-size:16px; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:4px; }
.team-card .role { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.team-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:var(--d70); margin-bottom:8px; }
.team-card p strong { color:var(--dark); }
.team-card a { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); text-decoration:none; }

.press-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); margin-top:8px; }
@media (max-width:900px){ .press-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .press-grid { grid-template-columns:1fr; } }
.press-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:26px; }
.press-pub { font-family:var(--grot); font-weight:900; font-size:15px; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); }
.press-dr { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin:4px 0 12px; }
.press-headline { font-family:var(--sans-body); font-size:13px; line-height:1.5; color:var(--d70); margin-bottom:12px; }
.press-card a { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); text-decoration:none; }

/* logos strip (as featured in) */
.logos-strip { display:flex; flex-wrap:wrap; align-items:center; gap:36px; padding:36px 0; }
.logos-strip img { max-height:30px; max-width:120px; object-fit:contain; filter:grayscale(1); opacity:.45; transition:all var(--fast); }
.logos-strip img:hover { filter:grayscale(0); opacity:.9; }

/* ============================================================
   SERVICE PAGE EXTRAS — features, pricing, comparison, FAQ
   ============================================================ */
.feature-grid { display:grid; grid-template-columns:repeat(4,1fr); border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); }
@media (max-width:900px){ .feature-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .feature-grid { grid-template-columns:1fr; } }
.feature-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:30px; }
.feature-icon { font-size:24px; margin-bottom:16px; display:block; }
.feature-card h3 { font-family:var(--grot); font-weight:900; font-size:13.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--dark); margin-bottom:10px; }
.feature-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.55; color:var(--d70); }

.platforms { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.platform-pill { font-family:var(--grot); font-weight:800; font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:9px 16px; border:1.5px solid var(--dark); color:var(--dark); }
.platform-pill span { display:block; font-family:var(--sans-body); font-weight:400; font-size:9px; letter-spacing:0; text-transform:none; color:var(--muted); margin-top:2px; }

/* Pricing card */
.pricing { display:grid; grid-template-columns:1.2fr .8fr; gap:32px; align-items:start; }
@media (max-width:860px){ .pricing { grid-template-columns:1fr; } }
.price-card { border:1.5px solid var(--dark); background:var(--bg2); padding:40px; position:relative; }
.price-popular { position:absolute; top:0; right:0; background:var(--blue); color:#fff; font-family:var(--grot); font-weight:800; font-size:8px; letter-spacing:.18em; text-transform:uppercase; padding:6px 12px; }
.price-name { font-family:var(--grot); font-weight:900; font-size:20px; letter-spacing:-.01em; text-transform:uppercase; margin-bottom:14px; }
.price-amount { font-family:var(--grot); font-weight:900; font-size:clamp(48px,8vw,80px); line-height:.9; letter-spacing:-.04em; color:var(--dark); }
.price-unit { font-family:var(--sans-body); font-size:14px; color:var(--muted); margin:8px 0 24px; }
.price-list { list-style:none; display:flex; flex-direction:column; gap:11px; margin-bottom:28px; }
.price-list li { display:flex; align-items:flex-start; gap:11px; font-family:var(--sans-body); font-size:14px; line-height:1.45; color:var(--d70); }
.price-list li::before { content:'✓'; color:var(--blue); font-weight:700; flex-shrink:0; }
.guarantee-box { border:1.5px solid var(--dark); padding:32px; background:var(--bg); }
.guarantee-box .gi { font-size:26px; margin-bottom:14px; display:block; }
.guarantee-box h3 { font-family:var(--grot); font-weight:900; font-size:14px; letter-spacing:.04em; text-transform:uppercase; margin-bottom:12px; }
.guarantee-box p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:var(--d70); margin-bottom:12px; }
.guarantee-box p:last-child { margin-bottom:0; }
.guarantee-box strong { color:var(--dark); }

/* Designed SVG feature icons (EMB — replaces emoji) */
.feature-icon-svg { color:var(--blue); }
.feature-icon-svg svg { display:block; }

/* EMB hero proof link + trust line */
.hero-proof { margin-top:20px; font-family:var(--sans-body); font-size:14px; color:rgba(255,255,255,.55); }
.hero-proof a { color:var(--blue); font-weight:600; text-decoration:none; border-bottom:1px solid var(--blue); transition:color var(--fast); }
.hero-proof a:hover { color:#fff; border-bottom-color:#fff; }
.hero-trust { margin-top:22px; font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.45); }
.hero-trust .star { color:var(--gold); letter-spacing:0; }
.hero-trust a { color:rgba(255,255,255,.8); text-decoration:none; }
.hero-trust a:hover { color:var(--blue); }

/* Transparency — static tracker table (recreation of the real client sheet) */
.tracker { margin-top:40px; overflow-x:auto; -webkit-overflow-scrolling:touch; border:1.5px solid var(--dark); background:var(--bg); }
.tracker table { width:100%; border-collapse:collapse; min-width:840px; }
.tracker th, .tracker td { text-align:left; padding:12px 16px; border-bottom:1px solid var(--faint); font-family:var(--sans-body); font-size:13px; color:var(--d70); white-space:nowrap; }
.tracker td:nth-child(3) { white-space:normal; min-width:240px; }
.tracker thead th { font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:#fff; background:var(--dark); border-bottom:1.5px solid var(--dark); }
.tracker tbody tr:last-child td { border-bottom:none; }
.tracker td.t-live { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); }
.tracker-cap { padding:10px 16px; border-top:1.5px solid var(--dark); background:var(--bg2); font-family:var(--sans-body); font-style:italic; font-size:12.5px; color:var(--muted); }

/* Transparency — sample sheet CTA below grid */
.sheet-cta { margin-top:44px; display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.sheet-cta span { font-family:var(--sans-body); font-style:italic; font-size:15px; color:var(--muted); }

/* Sample pitch email mockup */
.pitch-wrap { max-width:780px; margin-top:44px; }
.pitch-block { border:1.5px solid var(--dark); background:var(--bg); }
.pitch-head { display:flex; align-items:baseline; gap:12px; padding:16px 28px; border-bottom:1px solid var(--faint); background:var(--bg2); }
.pitch-head .k { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.pitch-head .v { font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace; font-weight:600; font-size:13px; color:var(--dark); }
.pitch-body { padding:28px; font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace; font-size:13px; line-height:1.7; color:var(--d70); }
.pitch-body p { margin-bottom:14px; }
.pitch-body p:last-child { margin-bottom:0; }
@media (max-width:639px){ .pitch-head, .pitch-body { padding-left:20px; padding-right:20px; } }
.pitch-note { margin-top:24px; font-family:var(--sans-body); font-size:14.5px; line-height:1.6; color:var(--d70); }
.pitch-note strong { color:var(--dark); }
.pitch-query, .pitch-result { border-left:3px solid var(--blue); background:var(--bg2); padding:18px 24px; margin-bottom:20px; }
.pitch-result { margin:20px 0 0; }
.pitch-query-lbl { display:block; font-family:var(--grot); font-weight:800; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin-bottom:8px; }
.pitch-query p, .pitch-result p { font-family:var(--sans-body); font-size:14.5px; line-height:1.6; color:var(--d70); font-style:italic; }
.pitch-result p { font-style:normal; }
.pitch-shot { display:block; margin-top:16px; border:1.5px solid var(--dark); }
.pitch-shot img { display:block; width:100%; height:auto; }
.pitch-annos { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--faint); border:1px solid var(--faint); margin-top:20px; }
.pitch-annos > div { background:var(--bg); padding:16px 20px; font-family:var(--sans-body); font-size:13px; line-height:1.55; color:var(--d70); }
.pitch-annos strong { display:block; color:var(--dark); margin-bottom:3px; }
@media (max-width:639px){ .pitch-annos { grid-template-columns:1fr; } }

/* Result-card client quotes (restored from live page) */
.result-quote { margin-top:18px; padding-top:16px; border-top:1px solid var(--faint); font-family:var(--sans-body); font-style:italic; font-size:13px; line-height:1.55; color:var(--muted); }
.result-quote-attr { display:block; margin-top:8px; font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.16em; text-transform:uppercase; font-style:normal; color:var(--dark); }

/* Full-width second-voice pull-quote (Centriq) */
.pull-quote { margin-top:52px; border-left:3px solid var(--blue); padding-left:28px; max-width:860px; }
.pull-quote blockquote { font-family:var(--sans-body); font-style:italic; font-size:clamp(16px,1.9vw,19px); line-height:1.6; color:var(--d70); }
.pull-quote figcaption { margin-top:14px; font-family:var(--grot); font-weight:800; font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--dark); }
.pull-quote figcaption span { display:block; font-family:var(--sans-body); font-weight:400; font-style:italic; font-size:12px; letter-spacing:0; text-transform:none; color:var(--muted); margin-top:4px; }

/* Step title note (speed claim in step 7) */
.step-note { display:block; font-family:var(--sans-body); font-style:italic; font-weight:400; font-size:11.5px; letter-spacing:0; text-transform:none; color:var(--blue2); margin-top:4px; }

/* Founder band (EMB "Who's Behind This") */
.founder-band { display:flex; align-items:center; gap:40px; border:1.5px solid var(--dark); background:var(--bg); padding:44px; }
.founder-band img { width:104px; height:104px; border-radius:50%; object-fit:cover; filter:grayscale(.3); flex-shrink:0; }
.founder-band h2 { font-family:var(--grot); font-weight:900; font-size:clamp(20px,2.6vw,30px); letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.founder-band p { font-family:var(--sans-body); font-size:15px; line-height:1.65; color:var(--d70); max-width:760px; }
.founder-band a { color:var(--blue); font-weight:600; text-decoration:none; }
.founder-band a:hover { text-decoration:underline; }
@media (max-width:639px){ .founder-band { flex-direction:column; align-items:flex-start; gap:24px; padding:32px 24px; } }

/* Dark CTA contact line ("Questions? Email us") */
.cta-contact { margin-top:26px; font-family:var(--sans-body); font-size:14px; color:rgba(255,255,255,.55); position:relative; z-index:1; }
.cta-contact a { color:var(--blue); text-decoration:none; }
.cta-contact a:hover { color:#fff; }

/* comparison table */
.compare { overflow-x:auto; margin-top:8px; }
.compare table { width:100%; border-collapse:collapse; min-width:640px; }
.compare th, .compare td { text-align:left; padding:16px 18px; border-bottom:1px solid var(--faint); font-family:var(--sans-body); font-size:13.5px; color:var(--d70); vertical-align:top; }
.compare thead th { font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--dark); border-bottom:1.5px solid var(--dark); }
.compare thead th.hl { color:var(--blue); }
.compare tbody td:first-child { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--dark); }
.compare .yes { color:var(--blue); font-weight:700; }
.compare .no { color:rgba(24,24,24,.4); }
.compare td.col-hl { background:var(--blue-lt); }

/* Responsive stacking — each row becomes a card on small screens
   (research §1d: 9-row table is unusable as a scroll-table on mobile) */
@media (max-width:680px){
  .compare { overflow-x:visible; }
  .compare table { min-width:0; }
  .compare thead { display:none; }
  .compare tbody tr { display:block; border:1px solid var(--faint); margin-bottom:14px; }
  .compare tbody td { display:block; padding:12px 16px; border-bottom:1px solid var(--light); }
  .compare tbody td:last-child { border-bottom:none; }
  .compare tbody td:first-child { background:var(--dark); color:#fff; border-bottom:none; }
  .compare tbody td:not(:first-child)::before { content:attr(data-label); display:block; font-family:var(--grot); font-weight:800; font-size:7.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
  .compare tbody td.col-hl::before { color:var(--blue); }
}

/* FAQ accordion */
.faq { border-top:1.5px solid var(--dark); margin-top:8px; }
.faq details { border-bottom:1px solid var(--faint); }
.faq summary { cursor:pointer; list-style:none; padding:22px 40px 22px 0; position:relative; font-family:var(--grot); font-weight:800; font-size:13px; letter-spacing:.02em; text-transform:uppercase; color:var(--dark); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:'+'; position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:22px; font-weight:400; color:var(--blue); transition:transform var(--base); }
.faq details[open] summary::after { content:'–'; }
.faq .faq-a { padding:0 40px 24px 0; font-family:var(--sans-body); font-size:14.5px; line-height:1.65; color:var(--d70); }
.faq .faq-a p { margin-bottom:12px; }
.faq .faq-a ul { margin:0 0 12px 18px; }
.faq .faq-a li { margin-bottom:6px; }
.faq .faq-a strong { color:var(--dark); }

/* EMOS tracks comparison */
.tracks { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:8px; }
@media (max-width:767px){ .tracks { grid-template-columns:1fr; } }
.track-card { border:1.5px solid var(--dark); padding:36px; display:flex; flex-direction:column; }
.track-card.accelerate { background:var(--dark); }
.track-name { font-family:var(--grot); font-weight:900; font-size:18px; letter-spacing:.02em; text-transform:uppercase; margin-bottom:8px; }
.track-card.accelerate .track-name { color:#fff; }
.track-price { font-family:var(--grot); font-weight:900; font-size:clamp(40px,6vw,64px); line-height:.9; letter-spacing:-.03em; color:var(--dark); }
.track-card.accelerate .track-price { color:var(--gold); }
.track-meta { font-family:var(--sans-body); font-size:13px; color:var(--muted); margin:8px 0 22px; }
.track-card.accelerate .track-meta { color:rgba(255,255,255,.5); }
.track-list { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:26px; flex:1; }
.track-list li { display:flex; gap:10px; font-family:var(--sans-body); font-size:13.5px; line-height:1.45; color:var(--d70); }
.track-list li::before { content:'✓'; color:var(--blue); font-weight:700; }
.track-card.accelerate .track-list li { color:rgba(255,255,255,.72); }
.track-card.accelerate .track-list li::before { color:var(--gold); }

/* ============================================================
   CAREERS — jobs, benefits, alumni
   ============================================================ */
.benefit-grid { display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); }
@media (max-width:860px){ .benefit-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .benefit-grid { grid-template-columns:1fr; } }
.benefit-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:32px; }
.benefit-card .bi { font-size:24px; display:block; margin-bottom:16px; }
.benefit-card h3 { font-family:var(--grot); font-weight:900; font-size:13.5px; letter-spacing:.05em; text-transform:uppercase; margin-bottom:10px; }
.benefit-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:var(--d70); }

/* Clickable service cards (used on case studies pages) */
a.benefit-card { display:block; text-decoration:none; color:inherit; background:var(--white); border:1.5px solid var(--dark); border-radius:4px; padding:32px; transition:box-shadow .18s ease, transform .18s ease; }
a.benefit-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.1); transform:translateY(-3px); text-decoration:none; }
a.benefit-card h3 { font-family:var(--grot); font-weight:900; font-size:14px; letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px; color:var(--dark); }
a.benefit-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:var(--d70); margin:0; }

.job-card { border:1.5px solid var(--dark); padding:40px; margin-bottom:24px; }
.job-head { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; flex-wrap:wrap; margin-bottom:24px; }
.job-title { font-family:var(--grot); font-weight:900; font-size:clamp(20px,3vw,30px); letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); }
.job-dept { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--blue); margin-top:6px; }
.job-meta { display:flex; gap:18px; flex-wrap:wrap; }
.job-meta span { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.job-section { margin-bottom:20px; }
.job-section h4 { font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.job-section p { font-family:var(--sans-body); font-size:14.5px; line-height:1.6; color:var(--d70); }
.job-section ul { margin:0 0 0 18px; }
.job-section li { font-family:var(--sans-body); font-size:14px; line-height:1.55; color:var(--d70); margin-bottom:7px; }
.job-perks { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:8px; }
@media (max-width:639px){ .job-perks { grid-template-columns:1fr 1fr; } }
.job-perk { border:1px solid var(--faint); padding:16px; }
.job-perk b { display:block; font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--dark); margin-bottom:4px; }
.job-perk span { font-family:var(--sans-body); font-size:12px; color:var(--muted); }

.alumni-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); }
@media (max-width:860px){ .alumni-grid { grid-template-columns:1fr; } }
.alumni-card { border-right:1px solid var(--faint); border-bottom:1px solid var(--faint); padding:32px; }
.alumni-card img { width:64px; height:64px; border-radius:50%; object-fit:cover; margin-bottom:16px; filter:grayscale(.3); }
.alumni-card h3 { font-family:var(--grot); font-weight:900; font-size:15px; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:4px; }
.alumni-card .now { font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.alumni-card p { font-family:var(--sans-body); font-size:13px; line-height:1.6; color:var(--d70); }
.alumni-card .quote { font-style:italic; color:var(--muted); margin-top:10px; font-size:12.5px; }
.alumni-tag { display:inline-block; font-size:7px; letter-spacing:.12em; text-transform:uppercase; font-weight:700; background:var(--faint); color:var(--muted); border-radius:3px; padding:2px 6px; margin-left:6px; vertical-align:middle; }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:64px; align-items:start; }
@media (max-width:860px){ .contact-grid { grid-template-columns:1fr; gap:44px; } }
.form-field { margin-bottom:22px; }
.form-field label { display:block; font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--dark); margin-bottom:9px; }
.form-field input, .form-field textarea, .form-field select {
  width:100%; padding:14px 16px; border:1.5px solid var(--dark); background:var(--bg);
  font-family:var(--sans-body); font-size:16px; color:var(--dark); border-radius:0;
}
.form-field textarea { min-height:130px; resize:vertical; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { outline:none; border-color:var(--blue); box-shadow:inset 0 0 0 1px var(--blue); }
.radio-group { display:flex; flex-direction:column; gap:10px; }
.radio-opt { display:flex; align-items:center; gap:11px; font-family:var(--sans-body); font-size:14.5px; color:var(--d70); cursor:pointer; }
.radio-opt input { width:auto; accent-color:var(--blue); }
.contact-aside { background:var(--bg2); border:1.5px solid var(--dark); padding:36px; }
.contact-aside h3 { font-family:var(--grot); font-weight:900; font-size:15px; letter-spacing:.02em; text-transform:uppercase; margin-bottom:18px; }
.contact-aside .step-n { color:var(--blue); }
.contact-detail { padding:16px 0; border-bottom:1px solid var(--faint); }
.contact-detail:last-child { border-bottom:none; }
.contact-detail .k { font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.contact-detail .v { font-family:var(--sans-body); font-size:14px; line-height:1.55; color:var(--dark); }
.contact-detail .v a { color:var(--blue); text-decoration:none; }
.form-note { font-family:var(--sans-body); font-size:12.5px; color:var(--muted); margin-top:14px; line-height:1.5; }

/* ---- Order form ---- */
.form-fieldset { border:none; padding:0; margin:0 0 40px; }
.form-legend { font-family:var(--grot); font-weight:900; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); margin-bottom:20px; display:block; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.form-label { font-family:var(--grot); font-weight:700; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--dark); }
.form-label .req { color:var(--blue); }
.form-input { font-family:var(--sans-body); font-size:15px; color:var(--dark); background:#fff; border:1.5px solid var(--dark); padding:12px 14px; width:100%; box-sizing:border-box; transition:border-color .15s, box-shadow .15s; }
.form-input:focus { outline:none; border-color:var(--blue); box-shadow:inset 0 0 0 1px var(--blue); }
textarea.form-input { resize:vertical; min-height:90px; }
.form-hint { font-family:var(--sans-body); font-size:12px; color:var(--muted); margin-top:4px; }
.form-section-note { font-family:var(--sans-body); font-size:14px; color:var(--d70); margin:-8px 0 18px; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:560px) { .form-row-2 { grid-template-columns:1fr; } }
.form-checkbox { display:flex; align-items:flex-start; gap:12px; font-family:var(--sans-body); font-size:14px; color:var(--dark); line-height:1.55; cursor:pointer; margin-top:12px; }
.form-checkbox input { width:18px; height:18px; flex:none; margin-top:2px; accent-color:var(--blue); cursor:pointer; }
.order-summary { border:1.5px solid var(--dark); margin-bottom:20px; }
.order-summary-row { display:flex; justify-content:space-between; padding:12px 18px; font-family:var(--sans-body); font-size:14px; border-bottom:1px solid var(--faint); }
.order-summary-row:last-child { border-bottom:none; }
.order-summary-total { font-family:var(--grot); font-weight:900; font-size:15px; background:var(--dark); color:#fff; }
.order-success { text-align:center; padding:80px 24px; }
.order-success-icon { font-size:48px; line-height:1; margin-bottom:20px; display:block; color:var(--blue); }
.order-success-hed { font-family:var(--grot); font-weight:900; font-size:clamp(32px,6vw,56px); letter-spacing:-.03em; text-transform:uppercase; color:var(--dark); margin-bottom:16px; }
.order-success-body { font-family:var(--sans-body); font-size:16px; color:var(--d70); line-height:1.65; max-width:420px; margin:0 auto; }

/* misc */
.center { text-align:center; }
.mt-cta { margin-top:48px; }
.split-line { font-family:var(--sans-body); font-size:15px; color:var(--d70); line-height:1.7; }
.split-line a { color:var(--blue); font-weight:600; text-decoration:none; }
.inline-note { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:40px; }
.inline-note a { color:var(--blue); text-decoration:none; }

/* responsive grid utilities (used instead of inline grid-template-columns,
   so media queries actually apply on mobile) */
.grid-stats-4 { display:grid; grid-template-columns:repeat(4,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:900px){ .grid-stats-4 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .grid-stats-4 { grid-template-columns:1fr; } }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:860px){ .grid-3 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .grid-3 { grid-template-columns:1fr; } }
.stage-grid { display:grid; grid-template-columns:repeat(3,1fr); border-top:1.5px solid var(--dark); }
@media (max-width:767px){ .stage-grid { grid-template-columns:1fr; } }
.grid-5 { display:grid; grid-template-columns:repeat(5,1fr); border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); }
@media (max-width:1000px){ .grid-5 { grid-template-columns:repeat(3,1fr); } }
@media (max-width:680px){ .grid-5 { grid-template-columns:repeat(2,1fr); } }
@media (max-width:460px){ .grid-5 { grid-template-columns:1fr; } }

/* ============================================================
   COLLAPSIBLE IDEA CARDS (case-study accordion)
   ============================================================ */
.idea-cards { margin-top:28px; display:grid; gap:12px; max-width:860px; }
.idea-card { border:1.5px solid var(--faint); background:var(--bg); }
.idea-card[open] { border-color:var(--dark); }
.idea-summary { list-style:none; cursor:pointer; display:flex; align-items:center; gap:18px; padding:22px 24px; -webkit-tap-highlight-color:transparent; }
.idea-summary::-webkit-details-marker { display:none; }
.idea-n { font-family:var(--grot); font-weight:800; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--blue); flex:none; }
.idea-title { font-family:var(--grot); font-weight:700; font-size:15px; line-height:1.35; flex:1; }
.idea-summary:hover .idea-title { color:var(--blue2); }
.idea-toggle { position:relative; width:16px; height:16px; flex:none; }
.idea-toggle::before, .idea-toggle::after { content:''; position:absolute; background:var(--dark); transition:transform var(--base); }
.idea-toggle::before { left:0; top:7px; width:16px; height:2px; }
.idea-toggle::after { left:7px; top:0; width:2px; height:16px; }
.idea-card[open] .idea-toggle::after { transform:scaleY(0); }
.idea-body { padding:2px 24px 28px 24px; border-top:1px solid var(--faint); font-size:15.5px; line-height:1.7; color:var(--d70); }
.idea-body > p:first-child { margin-top:20px; }
.idea-body p { margin:14px 0 0; }
.idea-body ul { margin:8px 0 0 20px; }
.idea-body li { margin:5px 0; }
.idea-body strong { color:var(--dark); }
.idea-body a { color:var(--blue2); }
.idea-body img { border:1px solid var(--faint); margin-top:16px; }
.idea-figcap { font-size:13px; color:var(--muted); margin-top:8px; }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  *, *::before, *::after { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  html.js .rev { opacity:1 !important; transform:none !important; }
  html.js .hero-hed .wi, html.js .hero-over, html.js .hero-sub, html.js .hero-actions, html.js .hero .ticker-wrap { opacity:1 !important; animation:none !important; }
  .ticker-track { animation:none !important; }
}

/* ============ Earned Media Engine page ============ */
.tracks.tracks-3 { grid-template-columns:repeat(3,1fr); }
@media (max-width:1000px){ .tracks.tracks-3 { grid-template-columns:1fr; } }
.offers.offers-3 { grid-template-columns:repeat(3,1fr); }
@media (max-width:900px){ .offers.offers-3 { grid-template-columns:1fr; } }
.grid-3.grid-2x2 { grid-template-columns:repeat(2,1fr); }
@media (max-width:680px){ .grid-3.grid-2x2 { grid-template-columns:1fr; } }
.result-card a.cs-link { display:inline-block; font-family:var(--grot); font-weight:800; font-size:8px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); text-decoration:none; margin-top:14px; }

/* ============================================================
   MOBILE RESPONSIVENESS POLISH
   Additive, design-preserving refinements layered on top of the
   existing breakpoints. Only affects small screens / edge cases —
   desktop layout and the visual identity are untouched.
   ============================================================ */

/* 1 ── Display headings never force horizontal overflow.
   The big Montserrat-900 heads have clamp() floors (40–46px) that
   don't scale below their minimum, so a long unbroken uppercase word
   ("CONSIDERATION", "ATTENTION?") could clip / push the page wide on a
   narrow phone. break-word is a safety net; the ≤380px floor nudges
   below keep words intact on common devices so the net rarely triggers. */
.hero-hed, .cta-hed, .page-hero h1, .section-hed, .proof-hed,
.cs-title, .cs-h2, .terms-hed, .cs-cat-head h2, .cta-wm {
  overflow-wrap: break-word;
  word-break: normal;
}

@media (max-width: 380px) {
  .hero-hed     { font-size: clamp(36px, 11vw, 46px); }
  .cta-hed      { font-size: clamp(32px, 9.2vw, 42px); }
  .page-hero h1 { font-size: clamp(33px, 9.5vw, 40px); }
  .terms-hed    { font-size: clamp(34px, 9vw, 40px); }
  /* a touch more breathing room so big type isn't edge-to-edge */
  .hero-body { padding-left: 20px; padding-right: 20px; }
}

/* 2 ── Wide data tables scroll horizontally instead of forcing the
   page wide (matches the existing .tracker / .compare pattern). */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
@media (max-width: 639px) {
  .data-table { min-width: 520px; }
  .data-table th, .data-table td { padding-right: 14px; font-size: 13.5px; }
}

/* 3 ── Thumb-friendly tap targets on mobile (WCAG ~44px).
   Footer link rows are tight at desktop sizing; give them real height
   on touch screens without changing how they look on desktop. */
@media (max-width: 639px) {
  .footer-col a { padding: 9px 0; }
  .footer-legal { gap: 18px; row-gap: 10px; flex-wrap: wrap; }
  .footer-legal a { padding: 6px 0; }
  .nav-logo img { height: 38px; }
}

/* 4 ── Smoother, lighter motion on small screens.
   Shorten the hero entrance so content is readable sooner on phones,
   and ease scroll-reveal travel so nothing feels janky on slower GPUs. */
@media (max-width: 639px) {
  html.js .rev { transition-duration: .45s; }
  html.js .hero-sub { animation-delay: .9s; }
  html.js .hero-actions { animation-delay: 1.05s; }
  html.js .hero .ticker-wrap { animation-delay: 1.25s; }
}

/* 5 ── Belt-and-suspenders: media never exceeds its column. */
img, svg, video, iframe { max-width: 100%; }
.testi-text, .terms-body, .cs-body { overflow-wrap: break-word; }

/* 6 ── In-page anchor jumps (e.g. the rewritten cal.com → #book-a-call
   links) must clear the fixed nav + 4px accent bar, or the section title
   lands hidden behind the header. Applies on every device. */
html { scroll-padding-top: 88px; }
@media (max-width: 639px) { html { scroll-padding-top: 76px; } }

/* 7 ── When the mobile menu is open, lock the page behind it so the
   background doesn't scroll under the overlay (toggled by main.js). */
body.nav-open { overflow: hidden; }

/* ============================================================
   FREE TOOLS — hub grid + Domain Rating Checker
   Reuses existing tokens, button, feature-card, and section pieces.
   ============================================================ */

/* ── Tools hub: card grid ── */
.tool-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1.5px solid var(--dark); border-left:1px solid var(--faint); }
@media (max-width:900px){ .tool-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .tool-grid { grid-template-columns:1fr; } }
.tool-card {
  position:relative; display:block; text-decoration:none; color:inherit;
  padding:32px 30px 30px; border-right:1px solid var(--faint); border-bottom:1px solid var(--faint);
  background:var(--bg); transition:background var(--fast);
}
a.tool-card:hover { background:var(--bg3); }
.tool-card-soon { opacity:.62; }
.tool-card-badge {
  display:inline-block; padding:3px 9px 4px; background:var(--blue); color:#fff;
  font-family:var(--grot); font-weight:800; font-size:8px; letter-spacing:.2em; text-transform:uppercase;
}
.tool-card-badge.soon { background:transparent; color:var(--muted); border:1px solid var(--faint); }
.tool-card-tag { display:block; font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin:18px 0 10px; }
.tool-card h3 { font-family:var(--grot); font-weight:900; font-size:18px; line-height:1.12; letter-spacing:-.01em; text-transform:uppercase; color:var(--dark); margin-bottom:12px; }
.tool-card-beta { font-size:9px; font-weight:800; letter-spacing:.12em; color:var(--muted); vertical-align:middle; }
.tool-card p { font-family:var(--sans-body); font-size:13.5px; line-height:1.6; color:var(--d70); }
.tool-card-arrow { display:block; margin-top:20px; font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); }
.tool-card-arrow.muted { color:var(--muted); }
.tool-grid-note { font-family:var(--sans-body); font-style:italic; font-size:14px; color:var(--muted); margin-top:28px; }
.tool-grid-note a { color:var(--blue); text-decoration:none; }

/* ── DR Checker: input form (sits high in the hero) ── */
.dr-form { margin-top:36px; max-width:620px; }
.dr-form-label { display:block; font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--dark); margin-bottom:10px; }
.dr-form-row { display:flex; gap:0; border:1.5px solid var(--dark); background:#fff; }
.dr-form-row input {
  flex:1 1 auto; min-width:0; font-family:var(--sans-body); font-size:16px; color:var(--dark);
  background:transparent; border:none; padding:15px 16px;
}
.dr-form-row input:focus { outline:none; box-shadow:inset 0 0 0 2px var(--blue); }
.dr-form-row .btn-primary { flex:0 0 auto; border-radius:0; }
.dr-hint { font-family:var(--sans-body); font-size:12.5px; color:var(--muted); margin-top:10px; }
@media (max-width:520px){
  .dr-form-row { flex-direction:column; }
  .dr-form-row .btn-primary { justify-content:center; }
}

/* ── DR Checker: result / loading / error ── */
.dr-result { margin-top:30px; max-width:620px; }
.dr-card { border:1.5px solid var(--dark); background:#fff; padding:30px 30px 26px; }
.dr-card-domain { font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; word-break:break-all; }
.dr-score { display:flex; align-items:baseline; gap:8px; }
.dr-score-num { font-family:var(--grot); font-weight:900; font-size:clamp(52px,12vw,84px); line-height:.9; letter-spacing:-.04em; color:var(--blue); }
.dr-score-max { font-family:var(--grot); font-weight:800; font-size:16px; letter-spacing:.06em; color:var(--muted); }
.dr-band { display:inline-block; margin-top:6px; font-family:var(--grot); font-weight:800; font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--dark); }
.dr-bar { position:relative; height:12px; background:var(--bg2); border:1px solid var(--faint); margin-top:18px; overflow:hidden; }
.dr-bar-fill { position:absolute; top:0; left:0; height:100%; width:0; background:var(--blue); transition:width .9s cubic-bezier(.2,.7,.2,1); }
.dr-scale { display:flex; justify-content:space-between; margin-top:7px; font-family:var(--grot); font-weight:700; font-size:8px; letter-spacing:.14em; color:var(--muted); }
.dr-attr { display:inline-block; margin-top:20px; font-family:var(--grot); font-weight:700; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); text-decoration:none; }
.dr-attr:hover { color:var(--blue2); text-decoration:underline; }
.dr-attr::before { content:"↗ "; }
.dr-card-foot { font-family:var(--sans-body); font-size:12px; color:var(--muted); margin-top:8px; }
.dr-static-attr { margin-top:18px; font-family:var(--grot); font-weight:700; font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.dr-static-attr a { color:var(--blue); text-decoration:none; }
.dr-static-attr a:hover { color:var(--blue2); text-decoration:underline; }
/* loading + error share the bordered card frame */
.dr-msg { border:1.5px solid var(--dark); background:#fff; padding:24px 28px; font-family:var(--sans-body); font-size:15px; line-height:1.55; color:var(--dark); }
.dr-msg.err { border-color:#c0392b; color:#a5281b; }
.dr-msg.loading { color:var(--muted); display:flex; align-items:center; gap:12px; }
.dr-spinner { width:16px; height:16px; flex:none; border:2px solid var(--faint); border-top-color:var(--blue); border-radius:50%; animation:dr-spin .7s linear infinite; }
@keyframes dr-spin { to { transform:rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .dr-spinner { animation:none; } .dr-bar-fill { transition:none; } }

/* ── DR explainer: balance the 4-up feature grid to 2 columns ── */
.feature-grid.dr-explain-grid { grid-template-columns:repeat(2,1fr); }
@media (max-width:640px){ .feature-grid.dr-explain-grid { grid-template-columns:1fr; } }
.dr-explain-grid .feature-card p strong { color:var(--dark); }
.dr-explain-grid .feature-card p em { font-style:italic; }
