
@font-face { font-family:'Larken'; src:url('assets/larken-regular.otf') format('opentype'); font-weight:400; font-display:optional; }
@font-face { font-family:'Larken'; src:url('assets/larken-italic.otf') format('opentype'); font-weight:400; font-style:italic; font-display:optional; }
@font-face { font-family:'Larken'; src:url('assets/larken-bold.otf') format('opentype'); font-weight:700; font-display:optional; }
@font-face { font-family:'Sailec'; src:url('assets/sailec-regular.otf') format('opentype'); font-weight:400; font-display:optional; }
@font-face { font-family:'Sailec'; src:url('assets/sailec-medium.otf') format('opentype'); font-weight:500 600; font-display:optional; }
@font-face { font-family:'Sailec'; src:url('assets/sailec-bold.otf') format('opentype'); font-weight:700; font-display:optional; }
:root { --white:#fff; --gray:#F2F1F4; --gray-shade:#D7D3DD; --navy:#1B224B; --navy-soft:rgba(27,34,75,.72); --blue:#005DF8; --blue-8:#ECF2FD; --blue-20:#CFDDFB; --serif:'Larken',Georgia,serif; --sans:'Sailec','Helvetica Neue',Helvetica,Arial,sans-serif; }
* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--white); color:var(--navy); font-family:var(--sans); font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
.wrap { max-width:1140px; margin:0 auto; padding:0 28px; }
nav:not(.cs-pager) { position:sticky; top:0; z-index:60; background:rgba(255,255,255,.92); backdrop-filter:blur(10px); box-shadow:0 1px 0 var(--gray-shade); }
.nav-inner { max-width:1140px; margin:0 auto; padding:18px 28px; display:flex; justify-content:space-between; align-items:center; }
.brand img { height:30px; display:block; }
.nav-links { display:flex; gap:28px; align-items:center; font-size:15px; font-weight:500; }
.nav-links a { color:var(--navy-soft); }
.nav-links a:hover { color:var(--blue); }
.nav-links a.cta { color:var(--navy); border:1.5px solid rgba(27,34,75,.4); border-radius:999px; padding:9px 22px; display:inline-flex; align-items:center; line-height:1; }
.nav-links a.cta:hover { background:var(--navy); border-color:var(--navy); color:#fff; }
.eyebrow { font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); }
header.page { padding:84px 0 48px; }
header.page h1 { font-family:var(--serif); font-weight:700; font-size:clamp(34px,5vw,56px); line-height:1.06; letter-spacing:-.012em; margin-top:14px; max-width:20em; }
header.page.post-head h1 { max-width:720px; font-size:clamp(31px,4.2vw,46px); text-wrap:pretty; }
header.page .meta { margin-top:14px; color:var(--navy-soft); font-size:15px; }
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; padding-bottom:96px; }
.card { background:var(--white); border:1px solid var(--gray-shade); border-radius:14px; padding:26px; display:flex; flex-direction:column; gap:10px; box-shadow:0 10px 24px rgba(27,34,75,.05); }
.card:hover { box-shadow:0 16px 36px rgba(27,34,75,.12); transform:translateY(-3px); }
.card, .card * { transition:all .2s ease; }
.card .thumb { width:calc(100% + 52px); margin:-26px -26px 8px; aspect-ratio:3/2; object-fit:cover; border-radius:13px 13px 0 0; }
.card .thumb-ph { display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#1B224B 0%,#005DF8 100%); }
.card .thumb-ph img { width:auto; height:34px; margin:0; opacity:.92; }
.card .k { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); }
.card h2 { font-family:var(--serif); font-weight:700; font-size:21px; line-height:1.18; }
.card p { font-size:14.5px; color:var(--navy-soft); }
.card .go { margin-top:auto; font-weight:600; font-size:14px; color:var(--blue); }
.prose { max-width:720px; padding-bottom:110px; font-size:15px; line-height:1.65; }
.prose h1,.prose h2,.prose h3,.prose h4 { font-family:var(--serif); font-weight:700; line-height:1.15; margin:1.6em 0 .5em; letter-spacing:-.01em; }
.prose h2 { font-size:25px; } .prose h3 { font-size:20px; } .prose h4 { font-size:17px; }
.art-prose h2, .art-prose h3 { color:var(--blue); margin-top:2.3em; }  /* #82 blue subheaders + #84-100 more section spacing */
.art-prose p:has(> strong:only-child) { margin-top:1.85em; }  /* #85/86/94/96/99/100: more space between Q&A questions */
.prose p { margin:1em 0; color:rgba(27,34,75,.85); }
.prose a { color:var(--blue); border-bottom:1px solid var(--blue-20); }
.prose a.rec-lead { font-weight:700; font-style:italic; }
.prose .rec-c { color:var(--blue); font-weight:700; font-style:italic; }
.prose img { max-width:100%; height:auto; border-radius:12px; margin:1.4em 0; }
.prose blockquote { border-left:3px solid var(--blue); padding-left:24px; font-family:var(--serif); font-style:italic; font-size:1.15em; margin:1.6em 0; }
.prose ol { margin:1em 0 1em 1.4em; }
.prose ul { list-style:none; margin:1em 0; padding-left:1.35em; }
.prose ul > li { position:relative; }
.prose ul > li::before { content:""; position:absolute; left:-1.35em; top:.62em; width:6px; height:6px; background:var(--blue); }
.prose li { margin:.55em 0; }
.art-prose p > strong:first-child, .art-prose li > strong:first-child { display:block; margin-bottom:.12em; }
.pq { margin:1.9em 0; padding-left:24px; border-left:3px solid var(--blue); }
.pq blockquote { margin:0; border:0; padding:0; font-family:var(--serif); font-style:italic; font-weight:400; font-size:1.18em; line-height:1.46; color:var(--navy); }
.pq figcaption { margin-top:9px; font-family:var(--sans); font-style:normal; font-size:13.5px; font-weight:600; color:var(--navy-soft); }
.prose figure { margin:1.4em 0; }
.prose > h2:first-child, .prose > h3:first-child, .prose > p:first-child { margin-top:0; }
.feature-wrap { width:min(50vw - 50% + 720px, 100vw); margin:30px 0 0; margin-left:calc(50% - 50vw); border-radius:0 14px 14px 0; overflow:hidden; }
.feature { width:100%; height:clamp(260px,34vw,440px); object-fit:cover; display:block; }
/* Case-study redesign: uniform spacing, uppercase section labels, standout Results */
.cs-lead { font-family:var(--serif); font-weight:700; font-size:clamp(21px,2.3vw,27px); line-height:1.32; letter-spacing:-.01em; color:var(--navy); margin:.1em 0 1.7em; max-width:none; }
.cs-prose .cs-sublead { font-size:clamp(15.5px,1.5vw,17.5px); font-weight:400; color:rgba(27,34,75,.62); line-height:1.55; margin:.3em 0 1.9em; }
.cs-prose .cs-subhead { margin:1.7em 0 .35em; }
.cs-prose .cs-subhead strong { color:var(--navy); font-weight:700; }
.cs-results .cs-subhead strong { color:#fff; }
.cs-quote { margin:3.4em 0; padding:.1em 0 .1em 26px; border-left:3px solid var(--blue); }
.cs-quote blockquote { margin:0; border-left:none; padding-left:0; font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.1vw,25px); line-height:1.42; letter-spacing:-.01em; color:var(--navy); }
.cs-quote-by { margin-top:14px; font-family:var(--sans); font-style:normal; font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); }
.cs-sec { margin:0 0 2em; }
.cs-label { font-family:var(--sans); font-size:12.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue); margin:0 0 .7em; }
.cs-prose p { margin:0 0 1em; line-height:1.72; color:rgba(27,34,75,.85); }
.cs-results { background:var(--blue); border-radius:16px; padding:34px 38px; margin:2.8em 0 3.4em; box-shadow:0 18px 44px rgba(0,93,248,.22); }
.cs-results .cs-label { color:#CFDDFB; margin:0 0 14px; }
.cs-results .cs-statgrid { margin:0 0 18px; gap:24px; }
.cs-results > p:first-of-type, .cs-results .cs-statgrid + p { margin-top:0; }
.cs-results .cs-stat { border-top:2px solid rgba(255,255,255,.34); padding-top:12px; }
.cs-results .cs-stat-n { color:#fff; font-size:clamp(34px,4.6vw,50px); }
.cs-results .cs-stat-l { color:rgba(255,255,255,.82); font-size:13px; }
.cs-results p { margin:0 0 .8em; color:rgba(255,255,255,.92); font-size:16px; line-height:1.7; }
.cs-results p:last-child { margin-bottom:0; }
.cs-results li, .cs-results .cs-list li { color:rgba(255,255,255,.92); }
.cs-results .cs-list li::marker { color:rgba(255,255,255,.55); }
.cs-results .cs-list li::before { background:rgba(255,255,255,.7); }
.cs-results a { color:#fff; text-decoration:underline; text-underline-offset:2px; }
.cs-results strong, .cs-results .cs-subhead strong { color:#fff; }
.cs-results .cs-subhead { color:#fff; }
/* Case-study layout: consistent text column + full-bleed photo banner */
header.page.cs-head { padding:80px 0 0; }
header.page.cs-head h1 { text-wrap:balance; max-width:820px; }
.cs-banner { width:min(50vw - 50% + 820px, 100vw); margin-top:34px; margin-bottom:40px; margin-left:calc(50% - 50vw); }
.cs-banner img { width:100%; height:clamp(260px,34vw,440px); object-fit:cover; display:block; border-radius:0 14px 14px 0; }
.cs-prose { max-width:820px; padding-bottom:0; }
.cs-pager-row { display:flex; justify-content:space-between; gap:24px; max-width:820px; border-top:1px solid rgba(27,34,75,.12); padding-top:34px; margin-top:36px; }
.cs-pager--narrow .cs-pager-row { max-width:720px; }
.cs-pager { padding-bottom:90px; }
.cs-pager a { display:block; max-width:47%; }
.cs-next { text-align:right; margin-left:auto; }
.cs-pg-dir { display:block; font-family:var(--sans); font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); margin-bottom:6px; }
.cs-pg-title { display:block; font-family:var(--serif); font-size:18px; line-height:1.3; color:var(--navy); }
.cs-pager a:hover .cs-pg-title { color:var(--blue); }
.cs-igrow { max-width:820px; margin:2.6em 0 .5em; }
.cs-ig-label { font-family:var(--sans); font-size:12.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.cs-ig-cards { display:flex; flex-wrap:wrap; gap:14px; }
.cs-ig { display:inline-flex; align-items:center; gap:11px; padding:12px 16px; border:1px solid rgba(27,34,75,.16); border-radius:12px; color:var(--navy); transition:border-color .15s, background .15s; }
.cs-ig:hover { border-color:var(--blue); background:rgba(0,93,248,.05); }
.cs-ig svg { color:var(--blue); flex:none; }
.cs-ig-tx { display:flex; flex-direction:column; line-height:1.25; }
.cs-ig-t { font-family:var(--sans); font-size:14px; font-weight:600; }
.cs-ig-h { font-family:var(--sans); font-size:12.5px; color:var(--navy-soft); }
.cs-list { margin:.3em 0 1em; padding-left:1.1em; }
.cs-list li { margin:0 0 .4em; line-height:1.6; color:rgba(27,34,75,.85); }
.cs-tags { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 1.7em; }
.cs-tag { font-family:var(--sans); font-size:12px; font-weight:600; letter-spacing:.03em; color:var(--blue); background:#ECF2FD; border-radius:999px; padding:5px 13px; }
.cs-statgrid { display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:20px; margin:4px 0 20px; }
.cs-stat-n { font-family:var(--serif); font-weight:700; font-size:clamp(30px,4vw,42px); line-height:1; color:var(--blue); }
.cs-stat-l { font-family:var(--sans); font-size:12.5px; color:var(--navy-soft); margin-top:7px; line-height:1.35; }
.tcard .portrait { width:calc(100% + 52px); margin:-26px -26px 10px; aspect-ratio:4/4.6; object-fit:cover; border-radius:13px 13px 0 0; }
.prose img { max-height: 620px; object-fit: contain; }
.prose .instagram-media { margin: 1.6em auto !important; min-width: 320px !important; max-width: 540px !important; }
.signup { background: var(--blue-8); border: 1px solid var(--blue-20); border-radius: 14px; padding: 30px 32px; margin: 2.4em 0 0; }
.signup .k { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); }
.signup h3 { font-family: var(--serif); font-weight: 700; font-size: 23px; line-height: 1.2; margin: 10px 0 18px; }
.signup-form { display: flex; gap: 10px; flex-wrap: wrap; }
.signup-form input { flex: 1; min-width: 220px; font-family: var(--sans); font-size: 15.5px; padding: 13px 18px; border: 1px solid var(--gray-shade); border-radius: 999px; background: var(--white); color: var(--navy); outline-color: var(--blue); }
.signup-form button { font-family: var(--sans); font-size: 15px; font-weight: 600; padding: 13px 30px; border: none; border-radius: 999px; background: var(--blue); color: #fff; cursor: pointer; }
.signup-form button:hover { background: var(--navy); }
footer { border-top:1px solid var(--gray-shade); padding:32px 0 44px; }
.foot { display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; font-size:14px; color:var(--navy-soft); }
.foot a:hover { color:var(--blue); }
/* about page */
.lede { margin-top:22px; font-size:16.5px; color:var(--navy-soft); max-width:58ch; text-wrap:pretty; }
.wb-video { margin:6px 0 4px; }
.wb-video video { width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:16px; background:#000; display:block; box-shadow:0 18px 44px rgba(27,34,75,.18); }
.wb-speakers { margin-top:44px; padding-top:30px; border-top:1px solid var(--gray-shade); }
.wb-spk-h { font-family:var(--sans); font-size:12.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin:0 0 20px; }
.wb-spk-row { display:flex; flex-wrap:wrap; gap:22px 48px; }
.wb-spk { display:flex; flex-direction:column; gap:3px; }
.wb-spk-n { font-family:var(--serif); font-weight:700; font-size:21px; line-height:1.15; color:var(--navy); }
.wb-spk-t { font-family:var(--sans); font-size:14px; color:var(--navy-soft); }
.about-lede { max-width:none; }
.vals { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; padding:16px 0 96px; }
.val { border:1px solid var(--gray-shade); border-radius:16px; padding:30px 32px; background:var(--white); box-shadow:0 10px 24px rgba(27,34,75,.05); }
.val .n { font-family:var(--serif); font-size:15px; color:var(--blue); font-weight:700; letter-spacing:.08em; }
.val h3 { font-family:var(--serif); font-size:23px; margin:10px 0 8px; }
.val p { font-size:15.5px; color:var(--navy-soft); }
.conv { position:relative; overflow:hidden; background:var(--navy); color:#fff; padding:150px 0; }
.conv .cbg { position:absolute; inset:0; }
.conv .cbg img { width:100%; height:100%; object-fit:cover; object-position:50% 8%; filter:saturate(.7); }
.conv .cbg::after { content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(27,34,75,.93), rgba(15,12,46,.9)); }
.conv .wrap { position:relative; }
.a-mosaic { display:grid; grid-template-columns:0.92fr 1.08fr; grid-template-rows:336px 336px; gap:14px; margin-top:64px; }
.a-mosaic img { width:100%; height:100%; object-fit:cover; border-radius:14px; box-shadow:0 16px 36px rgba(27,34,75,.12); }
.a-mosaic .m-l1 { grid-column:1; grid-row:1; }
.a-mosaic .m-l2 { grid-column:1; grid-row:2; }
.a-mosaic .m-tall { grid-column:2; grid-row:1 / 3; object-position:50% 40%; }
.conv p { font-family:var(--serif); font-size:clamp(24px,3.4vw,38px); line-height:1.32; max-width:24em; }
.sec-pad { padding:88px 0 96px; } #why{scroll-margin-top:14px} #team{scroll-margin-top:32px} #careers{scroll-margin-top:58px}
.sec-h { font-family:var(--serif); font-weight:700; font-size:clamp(30px,4vw,44px); line-height:1.1; letter-spacing:-.012em; margin-top:12px; max-width:24em; }
.beliefs { display:grid; grid-template-columns:repeat(3,1fr); gap:46px 44px; margin-top:48px; }
.belief::before { content:""; display:block; width:30px; height:3px; background:var(--blue); border-radius:2px; margin-bottom:14px; }
.belief h3 { font-family:var(--serif); font-size:24px; }
.belief p { margin-top:8px; font-size:14.5px; color:var(--navy-soft); max-width:34ch; }
.plist { margin-top:34px; max-width:840px; }
.prow { display:flex; gap:22px; padding:19px 0; border-bottom:1px solid var(--gray-shade); }
.prow:first-child { border-top:1px solid var(--gray-shade); }
.prow .pn { font-family:var(--serif); color:var(--blue); font-size:17px; font-weight:700; min-width:34px; padding-top:2px; }
.prow p { font-size:16px; color:rgba(27,34,75,.85); }
.prow b { color:var(--navy); }
.a-feat { margin:10px 0 10px 0; margin-right:calc(50% - 50vw); max-width:none; width:auto; overflow:hidden; border-radius:18px 0 0 18px; box-shadow:0 22px 50px rgba(27,34,75,0.14); }
.a-feat img { width:100%; height:clamp(300px,38vw,520px); object-fit:cover; object-position:center 22%; display:block; }
.a-feat figcaption { margin-top:13px; text-align:center; font-family:var(--sans); font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--navy-soft); }
.a-thesis { max-width:820px; margin:56px auto 8px; text-align:center; font-family:var(--serif); font-weight:700; font-size:clamp(22px,2.6vw,30px); line-height:1.4; letter-spacing:-.01em; color:var(--navy); }
.photo-band { margin:0; width:100%; }
.photo-band img { width:100%; height:clamp(320px,42vw,520px); object-fit:cover; object-position:center 42%; display:block; }
.a-pq { max-width:780px; margin:6px auto 64px; text-align:center; }
.a-qsplit { display:grid; grid-template-columns:0.92fr 1.08fr; gap:48px; align-items:center; max-width:1080px; margin:10px auto 64px; }
.a-qphoto img { width:100%; aspect-ratio:3/2; object-fit:cover; border-radius:18px; display:block; }
.a-qsplit .a-pq { max-width:none; margin:0; text-align:left; }
.a-qsplit .a-pq blockquote { font-size:clamp(19px,2vw,25px); }
.a-qsplit .a-pq blockquote::before { margin-bottom:14px; }
@media (max-width:820px){ .a-qsplit { grid-template-columns:1fr; gap:26px; } }
.a-pq blockquote { margin:0; font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(21px,2.5vw,29px); line-height:1.42; color:var(--navy); }
.a-pq blockquote::before { content:"“"; display:block; font-family:var(--serif); font-size:62px; line-height:0.4; color:var(--blue); margin-bottom:20px; }
.a-pq figcaption { margin-top:28px; }
.a-pq figcaption b { display:block; font-family:var(--sans); font-weight:700; font-size:15px; color:var(--navy); }
.a-pq figcaption span { display:block; margin-top:3px; font-family:var(--sans); font-size:13.5px; color:var(--navy-soft); }
.team-sec { background:var(--gray); padding:52px 0 56px; margin-bottom:56px; }
.tgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:42px; }
.tcardx { background:var(--white); border:1px solid var(--gray-shade); border-radius:16px; overflow:hidden; box-shadow:0 10px 24px rgba(27,34,75,.05); }
.tcardx img { width:100%; aspect-ratio:1/1.04; object-fit:cover; display:block; background:var(--blue-8); }
.tcardx .ti { padding:16px 18px 18px; }
.tcardx h3 { font-family:var(--serif); font-size:20px; }
.tcardx .role { margin-top:3px; font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); }
.tcardx .loc { margin-top:2px; font-size:13px; color:var(--navy-soft); }
a.tcardx { display:block; text-decoration:none; color:inherit; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
a.tcardx:hover { transform:translateY(-4px); box-shadow:0 18px 38px rgba(27,34,75,.12); border-color:var(--blue-20); }
a.tcardx:hover h3 { color:var(--blue); }
a.tcardx h3 { transition:color .18s ease; }
/* Individual bio pages */
header.bio { padding:40px 0 72px; }
.bio-grid { display:grid; grid-template-columns:360px 1fr; gap:56px; align-items:start; }
.bio-photo img { width:100%; aspect-ratio:1/1.04; object-fit:cover; border-radius:18px; background:var(--blue-8); box-shadow:0 18px 40px rgba(27,34,75,.10); }
.bio-back { display:inline-block; margin-bottom:18px; font-family:var(--sans); font-size:13px; font-weight:600; letter-spacing:.04em; color:var(--navy-soft); text-decoration:none; }
.bio-back:hover { color:var(--blue); }
.bio-main h1 { font-family:var(--serif); font-weight:700; font-size:clamp(34px,4.4vw,48px); line-height:1.05; letter-spacing:-.012em; }
.bio-role { margin-top:12px; font-family:var(--sans); font-size:13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); }
.bio-loc { margin-top:5px; font-size:14px; color:var(--navy-soft); }
.bio-text { margin-top:26px; }
.bio-text p { font-size:16.5px; line-height:1.7; color:var(--navy-soft); margin:0 0 16px; max-width:60ch; }
.bio-main .btn-blue { margin-top:14px; }
@media (max-width:760px) { .bio-grid { grid-template-columns:1fr; gap:28px; } .bio-photo img { max-width:320px; } }
.careers-band { margin-top:48px; background:var(--white); border:1px solid var(--gray-shade); border-radius:16px; padding:38px 40px; display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; }
.careers-band h3 { font-family:var(--serif); font-size:26px; }
.careers-band p { margin-top:6px; color:var(--navy-soft); max-width:48ch; }
.btn-blue { display:inline-block; background:var(--blue); color:#fff; font-weight:600; font-size:15px; padding:14px 30px; border-radius:999px; white-space:nowrap; }
.btn-blue:hover { background:var(--navy); }
.explore { padding:0 28px; }
.cl-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:30px; align-items:center; padding:10px 0 56px; }
.cl-cell { display:flex; align-items:center; justify-content:center; }
.cl-cell img { width:100%; height:auto; object-fit:contain; }
.cl-cell:last-child { grid-column:4; }
.explore .card { padding:20px; }
.explore .card .thumb { width:calc(100% + 40px); margin:-20px -20px 6px; aspect-ratio:16/9; }
.explore .card:nth-child(1) .thumb { object-position:18% 50%; }
.explore .card:nth-child(2) .thumb { object-position:0% 50%; }
.explore .card:nth-child(3) .thumb { object-position:12% 50%; }
.explore .card h2 { font-size:19px; }
.explore .card p { font-size:13.5px; }
.explore .card .go { font-size:13.5px; }
.nav-drop { position: relative; }
.nav-drop > a::after { content: " ▾"; font-size: 11px; }
.nav-drop::before { content: ""; position: absolute; left: -10px; right: -10px; top: 100%; height: 14px; }
.nav-drop .menu { position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%); background: var(--white); border: 1px solid var(--gray-shade); border-radius: 12px; box-shadow: 0 18px 40px rgba(27,34,75,.16); padding: 8px; min-width: 190px; display: none; z-index: 70; }
.nav-drop:hover .menu, .nav-drop:focus-within .menu { display: block; }
.nav-drop .menu a { display: block !important; padding: 9px 14px; border-radius: 8px; font-size: 14.5px; color: var(--navy) !important; font-weight: 500; }
.nav-drop .menu a:hover { background: var(--blue-8); color: var(--blue) !important; }
.ct-split { display:grid; grid-template-columns:0.95fr 1.05fr; min-height:82vh; }
.ct-left { background:var(--blue); color:#fff; position:relative; overflow:hidden; display:flex; flex-direction:column; justify-content:space-between; gap:48px; padding:56px 52px 48px; }
.ct-left svg.rings { position:absolute; inset:0; width:100%; height:100%; }
.ct-left > * { position:relative; }
.ct-left > div:first-of-type { margin: auto 0; }
.ct-left h1 { font-family:var(--serif); font-weight:700; font-size:clamp(34px,3.6vw,52px); line-height:1.08; letter-spacing:-.012em; max-width:11em; }
.ct-left .tag { margin-top:18px; font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--blue-20); }
.ct-meta { font-size:14.5px; color:rgba(255,255,255,.85); display:grid; gap:6px; }
.ct-meta a { color:#fff; font-weight:600; }
.ct-meta a:hover { text-decoration:underline; }
.ct-right { padding:84px 64px; display:flex; align-items:center; background:var(--white); }
.ct-form { width:100%; max-width:460px; display:grid; gap:16px; }
.ct-form-msg { font-size:14.5px; color:var(--blue); font-weight:600; min-height:1.4em; margin:0; }
.ct-form .lede2 { font-size:16.5px; color:var(--navy-soft); margin-bottom:10px; }
.ct-form label { font-size:13.5px; font-weight:700; display:grid; gap:7px; }
.ct-form input, .ct-form textarea { font-family:var(--sans); font-size:15.5px; padding:13px 16px; border:1px solid var(--gray-shade); border-radius:12px; background:var(--white); color:var(--navy); outline-color:var(--blue); resize:vertical; }
.ct-form .btn-blue { border:none; cursor:pointer; justify-self:start; }
.g-foot { background: var(--gray); padding: 72px 0 34px; }
.g-foot .f-cta { display: flex; justify-content: space-between; align-items: center; gap: 28px; flex-wrap: wrap; padding-bottom: 44px; border-bottom: 1px solid var(--gray-shade); }
.g-foot .f-cta h2 { font-family: var(--serif); font-weight: 700; font-size: clamp(26px, 3.6vw, 40px); letter-spacing: -0.01em; }
.g-foot .f-cta h2 em { font-style: normal; color: var(--blue); }
.g-foot .f-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 36px; padding: 48px 0 42px; }
.g-foot .f-logo { height: 30px; display: block; }
.g-foot .f-brand p { margin-top: 16px; font-size: 15px; color: var(--navy-soft); max-width: 30ch; }
.g-foot .f-social { margin-top: 18px; display: flex; gap: 16px; font-size: 14px; font-weight: 600; }
.g-foot .f-social a:hover { color: var(--blue); }
.g-foot .f-badge { height: 77px; margin-top: 24px; display: block; background: var(--navy); border-radius: 12px; padding: 11px 14px; box-sizing: border-box; }
.g-foot .fcol-h { font-size: 12.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue); margin: 0 0 14px; }
.g-foot .f-col a { display: block; font-size: 15px; color: var(--navy-soft); padding: 4px 0; }
.g-foot .f-col a:hover { color: var(--blue); }
.g-foot .f-news { border-top: 1px solid var(--gray-shade); padding: 32px 0 36px; display: flex; gap: 24px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.g-foot .f-news h3 { font-family: var(--serif); font-size: 21px; font-weight: 700; max-width: 32ch; }
.g-foot .f-news form { display: flex; gap: 10px; flex-wrap: wrap; }
.g-foot .f-news input { font-family: var(--sans); font-size: 15px; padding: 12px 18px; border: 1px solid var(--gray-shade); border-radius: 999px; background: var(--white); color: var(--navy); min-width: 240px; outline-color: var(--blue); }
.g-foot .f-news button { font-family: var(--sans); font-size: 14.5px; font-weight: 600; padding: 12px 26px; border: none; border-radius: 999px; background: var(--blue); color: #fff; cursor: pointer; }
.g-foot .f-news button:hover { background: var(--navy); }
.g-foot .f-bottom { border-top: 1px solid var(--gray-shade); padding-top: 24px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: 13.5px; color: var(--navy-soft); }
.g-foot .f-bottom a:hover { color: var(--blue); }
.prose .svc-callout { margin:34px 0 10px; padding:22px 26px; background:var(--blue-8); border:1px solid var(--blue-20); border-radius:14px; }
.prose .svc-callout .eyebrow { display:block; color:var(--blue); font-family:var(--sans); font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.prose .svc-callout h3 { font-family:var(--serif); font-weight:700; font-size:20px; color:var(--navy); margin:8px 0 8px; }
.prose .svc-callout p { font-size:14.5px; line-height:1.6; color:var(--navy-soft); margin:0 0 9px; max-width:none; }
.prose .svc-callout p:last-child { margin-bottom:0; }
.prose .svc-callout strong { color:var(--navy); font-weight:700; }
.svc-hero { position:relative; overflow:hidden; background:var(--blue); }
.svc-hero-art { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:74% 50%; }
.svc-hero .scrim { position:absolute; inset:0; background:linear-gradient(90deg, rgba(0,93,248,.95) 0%, rgba(0,93,248,.7) 42%, rgba(0,93,248,0) 72%); }
.svc-hero .inner { position:relative; padding-top:92px; padding-bottom:88px; }
.svc-hero .eyebrow { color:var(--blue-20); }
.svc-hero h1 { font-family:var(--serif); font-weight:700; font-size:clamp(34px,4.6vw,54px); line-height:1.07; letter-spacing:-.012em; color:#fff; margin-top:14px; max-width:14em; }
.svc-hero .lede { color:rgba(255,255,255,.9); }
.svc-list { list-style:none; columns:2; column-gap:26px; margin:14px 0 8px; padding:0; }
.svc-list li { position:relative; padding:1px 0 1px 17px; font-size:14px; font-weight:500; margin:0 0 4px; break-inside:avoid; }
.svc-list li::before { content:""; position:absolute; left:0; top:calc(0.75em - 2px); width:5px; height:5px; background:var(--blue); }
.svc-pr h2:first-of-type { font-size:clamp(23px,2.4vw,29px); line-height:1.2; max-width:26em; }
/* Richer rhythm for the re-copied (longer) service pages: blue numbered sub-headers, lead paragraph, hairline separators */
.svc-rich { counter-reset:svcnum; }
.svc-rich > h2 { counter-reset:svcnum; }
.svc-rich > h2:first-of-type + p { font-size:15px; line-height:1.65; color:rgba(27,34,75,.85); }
.svc-rich > h3 { counter-increment:svcnum; color:var(--blue); margin-top:2.1em; padding-top:17px; border-top:1px solid rgba(0,93,248,.16); }
.svc-rich > h3::before { content:counter(svcnum,decimal-leading-zero); margin-right:.72em; font-family:var(--sans); font-size:.56em; font-weight:700; letter-spacing:.08em; color:var(--blue); opacity:.5; vertical-align:3px; }
/* Bright-blue services callout (Rob 2026-06-30): pull the numbered services out of the GEO copy so readers find them fast. Option B = white headers + white body on Guardian blue. */
.svc-pr .svc-block { background:#005DF8; border-radius:18px; padding:32px 40px 38px; margin:46px 0; box-shadow:0 18px 44px rgba(0,93,248,.22); counter-reset:svcnum; }
.svc-pr .svc-block > h2 { color:#fff; margin-top:0; font-size:clamp(24px,2.3vw,28px); }
.svc-pr .svc-block > h3 { counter-increment:svcnum; color:#fff; margin-top:1.6em; padding-top:18px; border-top:1px solid rgba(255,255,255,.22); }
.svc-pr .svc-block > h3:first-of-type { border-top:none; margin-top:1.3em; }
.svc-pr .svc-block > h3::before { content:counter(svcnum,decimal-leading-zero); margin-right:.72em; font-family:var(--sans); font-size:.56em; font-weight:700; letter-spacing:.08em; color:rgba(255,255,255,.6); vertical-align:3px; }
.svc-pr .svc-block p { color:rgba(255,255,255,.9); }
.svc-pr .svc-block li { color:rgba(255,255,255,.9); }
.svc-pr .svc-block .svc-list li::before { background:rgba(255,255,255,.6); }
/* GEO FAQ section */
.faq { margin-top:64px; }
.faq > h2 { font-size:clamp(22px,2.2vw,27px); margin-bottom:6px; }
.faq-item { padding:18px 0; border-top:1px solid rgba(0,93,248,.16); }
.faq-q { font-family:var(--serif); font-size:18px; line-height:1.3; color:var(--blue); margin:0 0 7px; }
.faq-a { margin:0; color:rgba(27,34,75,.85); font-size:15px; line-height:1.6; }
.lg-img { width:100%; max-width:560px; border-radius:14px; margin:28px 0 8px; display:block; }
.lg-pair { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:24px 0 8px; max-width:520px; }
.lg-pair img { width:100%; height:160px; object-fit:cover; border-radius:12px; }
.lg-lede { font-family:var(--sans); font-size:16.5px; line-height:1.55; font-weight:500; color:var(--blue); max-width:54ch; margin:16px 0 0; }
.lg-rule { height:2px; width:88px; background:var(--blue); margin:24px 0 28px; }
.lg-trio { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:26px 0 8px; max-width:560px; }
.lg-trio img { width:100%; height:135px; object-fit:cover; border-radius:12px; }
.prose .lg-statement { font-family:var(--serif); font-weight:700; font-size:clamp(23px,2.5vw,31px); line-height:1.18; letter-spacing:-.012em; color:var(--blue); max-width:17em; margin:1.5em 0 .55em; }
.prose .lg-numbered { display:grid; grid-template-columns:repeat(2,1fr); gap:0 44px; list-style:none; margin:20px 0 12px; padding:0; counter-reset:lgnum; }
.prose .lg-numbered li { position:static; display:flex; gap:14px; align-items:baseline; padding:14px 0; border-top:1px solid #ECEFF5; font-size:15.5px; font-weight:600; color:var(--navy); margin:0; counter-increment:lgnum; }
.prose .lg-numbered li::before { content:counter(lgnum,decimal-leading-zero); position:static; flex:0 0 20px; width:auto; height:auto; background:none; font-family:var(--sans); font-size:12px; font-weight:700; color:var(--blue); letter-spacing:.06em; }
@media (max-width:600px){ .prose .lg-numbered { grid-template-columns:1fr; } }
.svc-tabs { display:flex; gap:6px; border-bottom:1px solid var(--gray-shade); margin:56px 0 0; }
.svc-tab { font-family:var(--sans); font-size:15px; font-weight:600; color:var(--navy-soft); background:none; border:none; padding:14px 20px; cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-1px; }
.svc-tab.active { color:var(--blue); border-bottom-color:var(--blue); }
.svc-tab:hover { color:var(--blue); }
.svc-cta { margin:64px 0 96px; }
.svc-grid { display:grid; grid-template-columns:minmax(0,1fr) 432px; gap:48px; align-items:start; }
.svc-rail { position:sticky; top:92px; display:grid; gap:18px; }
.svc-rail .svc-related { margin-top:0; }
.svc-related { background:var(--white); border-radius:24px; box-shadow:0 3px 20px rgba(0,0,0,.16); padding:24px 28px; margin-top:46px; max-width:720px; }
.svc-railcta { background:#005DF8; border-radius:24px; padding:24px 28px; margin:0 0 46px; max-width:720px; box-shadow:0 18px 44px rgba(0,93,248,.22); }
.svc-railcta .eyebrow { display:block; color:rgba(255,255,255,.72); font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.svc-railcta h3 { font-family:var(--serif); font-weight:700; font-size:20px; color:#fff; margin:7px 0 10px; }
.svc-railcta p { font-size:14px; line-height:1.5; color:rgba(255,255,255,.92); margin:0; }
.svc-stats { background:var(--white); border-radius:24px; box-shadow:0 3px 20px rgba(0,0,0,.16); padding:24px 28px; margin:0 0 46px; max-width:720px; }
.svc-stats h3 { font-family:var(--serif); font-weight:700; font-size:19px; color:var(--navy); margin:0 0 16px; }
.svc-stats ul { list-style:none; margin:0; padding:0; }
.svc-stats li { margin:0 0 16px; font-size:14px; line-height:1.45; color:var(--navy-soft); }
.svc-stats li:last-child { margin-bottom:0; }
.svc-stats li b { display:block; font-family:var(--serif); font-weight:700; font-size:30px; color:var(--blue); line-height:1; margin-bottom:4px; }
.svc-stats li a { display:inline-block; margin-top:4px; font-size:11.5px; color:var(--navy-soft); text-decoration:underline; letter-spacing:.02em; }
.svc-stats li a:hover { color:var(--blue); }
.svc-related h3 { font-family:var(--sans); font-size:11.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin:0 0 4px; }
.svc-related .sr-p { font-size:15px; color:var(--navy-soft); margin:8px 0 4px; }
.svc-quote { max-width:24em; text-align:center; }
.prose blockquote.svc-quote { margin:84px auto 8px; border-left:none; padding-left:0; transform:translateX(-14px); }
@media (max-width:1000px) { .prose blockquote.svc-quote { transform:none; } }
.svc-quote p { font-family:var(--serif); font-style:italic; font-size:clamp(17px,1.8vw,20px); line-height:1.5; color:var(--navy); margin:0; text-wrap:balance; }
.svc-quote p::before { content:"“"; display:block; font-size:36px; line-height:0.6; color:var(--blue); font-style:normal; margin-bottom:10px; }
.svc-quote cite { display:block; margin-top:14px; font-style:normal; font-size:14px; font-weight:600; color:var(--navy-soft); }
.svc-related h4 { margin:20px 0 6px; font-size:12px; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--blue); }
.svc-related ul { list-style:none; margin:10px 0 0; padding:0; }
.svc-related li { position:relative; margin:0 0 6px; padding:0 0 0 15px; font-size:13px; line-height:1.45; }
.svc-related li::before { content:""; position:absolute; left:0; top:0.5em; width:5px; height:5px; background:var(--blue); }
.svc-related a { color:var(--blue); font-weight:400; }
.svc-related a:hover { text-decoration:underline; }
.svc-related .sr-p { font-size:13px; color:rgba(27,34,75,.85); margin:9px 0 0; }
@media (max-width:920px) { .svc-hero .scrim { background:rgba(0,93,248,.85); } .cards { grid-template-columns:1fr; } .ct-split { grid-template-columns:1fr; } .ct-left { min-height:380px; } .ct-right { padding:48px 28px; } .nav-links a:not(.cta) { display:none; } .vals,.beliefs { grid-template-columns:1fr; } .svc-grid { grid-template-columns:1fr; } .svc-rail { position:static; } .a-mosaic { grid-template-columns:1fr; grid-template-rows:auto; } .a-mosaic img { height:230px; } .a-mosaic .m-tall { grid-row:auto; height:320px; } .tgrid { grid-template-columns:repeat(2,1fr); } .cl-grid { grid-template-columns:repeat(3,1fr); } .careers-band { display:block; } .svc-list { columns:1; } .svc-banner img { height:200px; } .careers-band .btn-blue { margin-top:18px; } .a-feat { margin-right:0; } .a-feat img { height:240px; border-radius:14px; } }
