/* ============================================================
   BABYLON HEALTH — "Warm Editorial Bento" design system v2
   A deliberate departure from the green-gradient/serif site.
   Light bone canvas · terracotta + sage · modern grotesque type.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700&family=Mulish:wght@400;500;600;700;800&display=swap');

:root{
  --bone:#f4eee2;
  --cream:#faf6ee;
  --paper:#ffffff;
  --ink:#23271f;
  --ink-soft:#4c5247;
  --muted:#7a7f72;
  --clay:#b85a3c;
  --clay-deep:#9a4730;
  --clay-soft:#f0ddd2;
  --sage:#5f7355;
  --sage-deep:#43543c;
  --sage-soft:#e0e7d7;
  --gold:#c2a049;
  --line:rgba(35,39,31,.14);
  --line-soft:rgba(35,39,31,.08);
  --shadow:0 22px 60px -28px rgba(35,39,31,.4);
  --shadow-sm:0 10px 26px -16px rgba(35,39,31,.3);
  --r:22px;
  --r-sm:14px;
  --display:'Bricolage Grotesque',system-ui,sans-serif;
  --sans:'Mulish',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.02em}
.eyebrow{font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--clay)}

.fu{opacity:0;transform:translateY(20px);animation:fu .85s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes fu{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.fu{animation:none;opacity:1;transform:none}}

/* buttons — pill, flat, confident */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:14.5px;padding:13px 24px;border-radius:50px;border:2px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn-clay{background:var(--clay);color:#fff}
.btn-clay:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn-sage{background:var(--sage);color:#fff}
.btn-sage:hover{background:var(--sage-deep);transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn-ghost{background:var(--paper);color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}

/* ---------- nav ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(244,238,226,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:18px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo .mark{width:42px;height:42px;border-radius:13px;background:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0OCA0OCIgcm9sZT0iaW1nIiBhcmlhLWxhYmVsPSJCYWJ5bG9uIEhlYWx0aCI+CiAgPGRlZnM+CiAgICA8bGluZWFyR3JhZGllbnQgaWQ9ImJobGciIHgxPSIwIiB5MT0iMCIgeDI9IjEiIHkyPSIxIj4KICAgICAgPHN0b3Agb2Zmc2V0PSIwIiBzdG9wLWNvbG9yPSIjNmY4NDYzIi8+CiAgICAgIDxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI2I4NWEzYyIvPgogICAgPC9saW5lYXJHcmFkaWVudD4KICA8L2RlZnM+CiAgPHJlY3QgeD0iMiIgeT0iMiIgd2lkdGg9IjQ0IiBoZWlnaHQ9IjQ0IiByeD0iMTMiIGZpbGw9InVybCgjYmhsZykiLz4KICA8cGF0aCBkPSJNMjQgMzUuNiBDIDEyLjQgMjcsIDkuNCAyMC43LCAxMy4yIDE2LjMgQyAxNi4yIDEyLjgsIDIxLjEgMTMuNiwgMjQgMTcuNCBDIDI2LjkgMTMuNiwgMzEuOCAxMi44LCAzNC44IDE2LjMgQyAzOC42IDIwLjcsIDM1LjYgMjcsIDI0IDM1LjYgWiIgZmlsbD0iI2ZmZmZmZiIvPgogIDxwYXRoIGQ9Ik0yNCAxNy40IEMgMjEuMSAxMy42LCAxNi4yIDEyLjgsIDEzLjIgMTYuMyBDIDExLjcgMTguMSwgMTEuNSAyMC4zLCAxMi4zIDIyLjYgQyAxNC45IDE3LjksIDE5LjQgMTYuNCwgMjQgMTcuNCBaIiBmaWxsPSIjZmZmZmZmIiBvcGFjaXR5PSIuMTgiLz4KPC9zdmc+Cg==") center/contain no-repeat;font-size:0;color:transparent;flex-shrink:0}
.logo b{font-family:var(--display);font-size:20px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.logo small{display:block;font-size:9.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:26px;font-size:14.5px;font-weight:600;color:var(--ink-soft)}
.nav-links a{transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--clay)}
.nav-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hamburger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;align-items:center;justify-content:center}
.hamburger svg{width:24px;height:24px;color:var(--ink)}
@media(max-width:1080px){.nav-links{display:none}.nav-cta .btn:not(.always){display:none}.hamburger{display:flex}}

.mobile-menu{display:none;position:fixed;inset:0;z-index:80;background:var(--bone)}
.mobile-menu.open{display:flex;flex-direction:column}
.mm-top{display:flex;align-items:center;justify-content:space-between;height:76px;padding:0 28px;border-bottom:1px solid var(--line)}
.mm-close{background:none;border:none;cursor:pointer;font-size:30px;color:var(--ink);line-height:1}
.mm-links{display:flex;flex-direction:column;padding:18px 28px;gap:2px}
.mm-links a{font-family:var(--display);font-size:26px;font-weight:600;color:var(--ink);padding:13px 0;border-bottom:1px solid var(--line-soft)}
.mm-links .btn{margin-top:20px;justify-content:center}

/* ---------- inner page header ---------- */
.page-head{padding:60px 0 50px;border-bottom:1px solid var(--line-soft)}
.page-head .crumbs{font-size:13px;color:var(--muted);margin-bottom:16px}
.page-head .crumbs a:hover{color:var(--clay)}
.page-head h1{font-size:clamp(38px,5.4vw,68px)}
.page-head h1 em{font-style:normal;color:var(--clay)}
.page-head p{font-size:18px;color:var(--ink-soft);max-width:560px;margin-top:18px}

section{padding:90px 0}
.center{max-width:680px;margin:0 auto 52px}
.center.mid{text-align:center}
.center h2{font-size:clamp(32px,4.2vw,50px);margin:14px 0}
.center p{font-size:17px;color:var(--ink-soft)}

/* placeholder image tiles */
.ph{background:var(--sage);display:flex;align-items:center;justify-content:center;position:relative;border-radius:var(--r);overflow:hidden;color:rgba(255,255,255,.6)}
.ph.clay{background:var(--clay)}
.ph.ink{background:var(--ink)}
.ph svg{width:48px;height:48px}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ph .cap{position:absolute;bottom:13px;left:15px;right:15px;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;font-weight:700;z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.5)}

/* ---------- HERO (asymmetric, light) ---------- */
.hero{padding:60px 0 30px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:46px;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:9px;background:var(--clay-soft);color:var(--clay-deep);font-size:12.5px;font-weight:700;padding:8px 16px;border-radius:50px;margin-bottom:24px;letter-spacing:.02em}
.hero h1{font-size:clamp(46px,6.4vw,82px);letter-spacing:-.03em}
.hero h1 .u{color:var(--clay)}
.hero p{font-size:19px;color:var(--ink-soft);max-width:480px;margin:26px 0 32px}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap}
.hero-art{position:relative;height:480px}
.hero-art .big{position:absolute;inset:0 0 70px 0;border-radius:var(--r)}
.hero-art .small{position:absolute;bottom:0;left:0;width:58%;height:150px;border:6px solid var(--bone)}
.hero-art .float{position:absolute;top:24px;right:-10px;background:var(--paper);border-radius:16px;box-shadow:var(--shadow);padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-art .float .n{font-family:var(--display);font-size:22px;font-weight:700;color:var(--ink);line-height:1}
.hero-art .float .l{font-size:11px;color:var(--muted)}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:34px}.hero-art{height:360px}}

/* ---------- marquee trust strip ---------- */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;padding:16px 0}
.marquee-in{display:flex;gap:48px;white-space:nowrap;animation:scroll 26s linear infinite;font-size:14px;font-weight:600}
.marquee span{display:inline-flex;align-items:center;gap:9px}
.marquee svg{width:16px;height:16px;color:var(--clay)}
@keyframes scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-in{animation:none;justify-content:center;flex-wrap:wrap;white-space:normal}}

/* ---------- BENTO grid ---------- */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(150px,auto);gap:16px}
.bento .cell{border-radius:var(--r);padding:26px;border:1px solid var(--line-soft);background:var(--paper);position:relative;overflow:hidden;transition:.2s ease}
.bento .cell:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.cell.x2{grid-column:span 2}
.cell.y2{grid-row:span 2}
.cell.clay{background:var(--clay);color:#fff;border-color:transparent}
.cell.sage{background:var(--sage);color:#fff;border-color:transparent}
.cell.ink{background:var(--ink);color:var(--cream);border-color:transparent}
.cell.bone{background:var(--cream)}
.cell .ic{font-size:26px;margin-bottom:12px}
.cell h3{font-size:21px;margin-bottom:7px;letter-spacing:-.02em}
.cell p{font-size:14px;opacity:.86;line-height:1.55}
.cell .more{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;margin-top:14px}
.cell.clay .more,.cell.sage .more,.cell.ink .more{color:#fff}
.cell:not(.clay):not(.sage):not(.ink) .more{color:var(--clay)}
.cell .more svg{width:14px;height:14px}
.cell .big-num{font-family:var(--display);font-size:54px;font-weight:700;line-height:1;letter-spacing:-.03em}
.cell .big-num span{color:var(--clay)}
.cell.clay .big-num span,.cell.sage .big-num span,.cell.ink .big-num span{color:#fff;opacity:.7}
@media(max-width:880px){.bento{grid-template-columns:1fr 1fr}.cell.x2{grid-column:span 2}.cell.y2{grid-row:auto}}
@media(max-width:560px){.bento{grid-template-columns:1fr}.cell.x2{grid-column:auto}}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split h2{font-size:clamp(30px,3.8vw,46px);margin:14px 0 20px}
.split p{color:var(--ink-soft);margin-bottom:16px}
.split .art{height:430px;position:relative}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:32px}.split .art{height:320px}}

/* tick list */
.tick{list-style:none;display:flex;flex-direction:column;gap:12px}
.tick li{display:flex;align-items:flex-start;gap:11px;font-size:15px;font-weight:500}
.tick li svg{width:20px;height:20px;color:var(--clay);flex-shrink:0;margin-top:3px}

/* ---------- two paths ---------- */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.path{border-radius:var(--r);padding:40px 34px;transition:.2s ease}
.path:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.path-care{background:var(--clay-soft)}
.path-work{background:var(--sage-soft)}
.path .pic{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:26px}
.path-care .pic{background:var(--clay);color:#fff}
.path-work .pic{background:var(--sage);color:#fff}
.path h3{font-size:26px;margin-bottom:10px}
.path p{color:var(--ink-soft);font-size:15px;margin-bottom:22px;max-width:330px}
@media(max-width:760px){.paths{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.cta{background:var(--ink);border-radius:var(--r);padding:64px 40px;text-align:center;color:var(--cream);position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:var(--clay);opacity:.18;top:-120px;right:-60px}
.cta h2{font-size:clamp(30px,4vw,46px);color:var(--cream);position:relative}
.cta p{font-size:17px;color:rgba(250,246,238,.8);max-width:520px;margin:16px auto 28px;position:relative}
.cta .hero-actions{justify-content:center;position:relative}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(250,246,238,.66);padding:62px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px;margin-bottom:42px}
.foot .logo b{color:var(--cream)}.foot .logo small{color:rgba(250,246,238,.55)}
.foot-brand p{font-size:14px;margin-top:16px;max-width:280px}
.foot-brand .reg{font-size:12.5px;margin-top:14px;color:rgba(250,246,238,.5)}
.foot-brand .reg a{color:rgba(250,246,238,.75);text-decoration:underline}
.foot-col h4{font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);margin-bottom:16px}
.foot-col a{display:block;font-size:14px;margin-bottom:10px}
.foot-col a:hover{color:var(--cream)}
.foot-badges{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;padding:22px 0;border-top:1px solid rgba(250,246,238,.12);border-bottom:1px solid rgba(250,246,238,.12);margin-bottom:24px;font-size:12.5px}
.foot-badges span{display:inline-flex;align-items:center;gap:7px}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px}
.foot-bot a{color:rgba(250,246,238,.8);text-decoration:underline}
@media(max-width:780px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ---------- legal / long-form content ---------- */
.legal{max-width:820px;margin:0 auto}
.legal .toc{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:22px 26px;margin-bottom:40px}
.legal .toc h4{font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.legal .toc ol{margin-left:18px;font-size:14px;line-height:2;color:var(--ink-soft)}
.legal .toc a:hover{color:var(--clay)}
.legal h2{font-size:25px;margin:38px 0 12px;scroll-margin-top:90px}
.legal h3{font-size:18px;margin:22px 0 8px;font-family:var(--sans);font-weight:700}
.legal p,.legal li{font-size:15.5px;color:var(--ink-soft);margin-bottom:12px}
.legal ul,.legal ol.body{margin:0 0 16px 22px}
.legal li{margin-bottom:7px}
.legal .note{background:var(--clay-soft);border-left:4px solid var(--clay);border-radius:8px;padding:14px 18px;font-size:14px;color:var(--clay-deep);margin:18px 0}
.legal .updated{font-size:13px;color:var(--muted);margin-bottom:6px}
.legal strong{color:var(--ink)}
.legal a{color:var(--clay);text-decoration:underline}

/* photo bento cells (Services) */
.cell.photo{padding:0;position:relative;overflow:hidden;min-height:210px;border:none}
.cell.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cell.photo .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:22px;background:linear-gradient(transparent 28%,rgba(35,39,31,.85))}
.cell.photo .ov h3{color:#fff;margin:0 0 4px}
.cell.photo .ov p{color:rgba(255,255,255,.92);margin:0}
