/* Building Teams — shared design system (Direction C: Authority / Proof-driven) */
:root{
  --brand:#64010a; --brand-2:#8c0f1c; --brand-bright:#b5172b;
  --ink:#15171c; --slate:#5a626e; --slate-2:#828b97;
  --paper:#ffffff; --mist:#F4F5F2; --mist-2:#EBEDE8;
  --line:#e2e4df;
  --good:oklch(0.62 0.15 150);
  --display:'Space Grotesk',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* newsletter band */
.newsletter{background:var(--mist);border:1px solid var(--line);border-radius:18px;padding:32px 36px;display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.newsletter .nl-copy .eyebrow{color:var(--brand-2)}
.newsletter .nl-copy h3{font-family:var(--display);font-weight:700;font-size:clamp(20px,2.4vw,26px);letter-spacing:-0.02em;line-height:1.1;margin:8px 0 8px}
.newsletter .nl-copy p{font-size:15px;color:var(--slate);max-width:42ch;margin:0}
.newsletter .nl-form{min-width:0}
/* tame the embedded HubSpot form to match our system */
.newsletter .hs-form-frame{font-family:'Archivo',sans-serif}
.newsletter form{display:flex;flex-wrap:wrap;gap:10px}
.newsletter .hs-form-field{flex:1;min-width:200px;margin:0}
.newsletter input[type=email],.newsletter input[type=text]{width:100%;font-family:'Archivo',sans-serif;font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px}
.newsletter input[type=email]:focus,.newsletter input[type=text]:focus{outline:none;border-color:var(--brand-2)}
.newsletter input[type=submit],.newsletter .hs-button{font-family:var(--display);font-weight:600;font-size:14px;background:var(--brand-2);color:#fff;border:0;border-radius:10px;padding:14px 22px;cursor:pointer;transition:.16s;white-space:nowrap}
.newsletter input[type=submit]:hover,.newsletter .hs-button:hover{background:var(--brand)}
.newsletter .hs-error-msg,.newsletter .hs_error_rollup{color:var(--brand-bright);font-size:12.5px;margin-top:4px}
.newsletter .legal-consent-container{font-size:11.5px;color:var(--slate-2);flex-basis:100%}
@media(max-width:760px){.newsletter{grid-template-columns:1fr;gap:18px;padding:26px 24px}}
body{background:var(--paper);color:var(--ink);font-family:'Archivo',system-ui,sans-serif;font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.disp{font-family:var(--display);font-weight:700;letter-spacing:-0.025em;line-height:1.0}
.mono{font-family:var(--display);font-weight:500;letter-spacing:0.02em}
.eyebrow{font-family:var(--display);font-size:12.5px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--brand-2)}
.wrap{max-width:1200px;margin:0 auto;padding:0 36px}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:0.01em;padding:14px 24px;border-radius:10px;border:1.5px solid transparent;cursor:pointer;transition:.16s;white-space:nowrap}
.btn-primary{background:var(--brand-2);color:#fff}
.btn-primary:hover{background:var(--brand);transform:translateY(-1px);box-shadow:0 10px 24px rgba(100,1,10,.22)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.arr{transition:transform .16s}.btn:hover .arr{transform:translateX(3px)}

header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,0.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:13px 36px;max-width:1280px;margin:0 auto}
.nav-logo{display:flex;align-items:center;gap:11px}
.nav-logo img{height:38px}
.nav-logo .wm{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-0.01em}
.nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px 0;box-shadow:0 18px 40px rgba(21,23,28,.12);z-index:60}
.nav-links.open{display:flex}
.nav-links a{font-size:16px;font-weight:500;color:var(--slate);padding:13px 36px}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--brand-2)}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-size:15px;font-weight:600;color:var(--brand-2);text-decoration:none;transition:.15s;white-space:nowrap}
.nav-phone:hover{color:var(--brand)}
.nav-phone svg{flex:none}
.nav-toggle{display:inline-flex;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px;margin-left:2px}
.nav-toggle svg{display:block}
@media(max-width:1000px){
  .nav-toggle{display:inline-flex}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px 0;box-shadow:0 18px 40px rgba(21,23,28,.12);z-index:60}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 36px;font-size:16px}
}
@media(max-width:560px){.nav-phone .np-num{display:none}}

/* split hero (image + copy) */
.hero{padding:74px 0 64px;background:linear-gradient(180deg,var(--mist),var(--paper))}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(38px,5.2vw,66px);letter-spacing:-0.03em;line-height:1.04;margin:16px 0 20px}
.hero h1 em{font-style:normal;color:var(--brand-2)}
.hero-sub{font-size:19.5px;color:var(--slate);max-width:50ch;margin-bottom:28px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.trust-inline{display:flex;align-items:center;gap:10px;margin-top:26px;font-size:13.5px;color:var(--slate)}
.trust-inline .stars{color:var(--brand-bright);letter-spacing:1px}
.hero-media{position:relative}
.hero-media .main{width:100%;height:480px;object-fit:cover;border-radius:16px}
.stat-float{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:0 18px 40px rgba(21,23,28,0.12)}
.stat-float b{font-family:var(--display);font-weight:700;font-size:28px;display:block;color:var(--brand);line-height:1}
.stat-float span{font-size:12px;color:var(--slate);font-weight:500}
.sf-1{left:-24px;top:40px}
.sf-2{right:-20px;bottom:40px}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.hero-media .main{height:340px}.stat-float{display:none}}

/* breadcrumb */
.crumb{font-family:var(--display);font-size:12.5px;letter-spacing:0.04em;color:var(--slate-2);display:flex;gap:9px;align-items:center;margin-bottom:6px}
.crumb a:hover{color:var(--brand-2)}
.crumb span{opacity:.5}

/* outcomes */
.out{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.out-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:8px}
.out-item .ln{width:30px;height:3px;background:var(--brand-2);border-radius:3px;margin-bottom:15px}
.out-item h3{font-family:var(--display);font-weight:700;font-size:19px;margin-bottom:6px}
.out-item p{font-size:14px;color:var(--slate)}
@media(max-width:820px){.out-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.out-grid{grid-template-columns:1fr}}

/* metric bar */
.metrics{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.metrics-in{display:grid;grid-template-columns:repeat(4,1fr)}
.metric{padding:30px 26px;border-left:1px solid var(--line)}
.metric:first-child{border-left:none}
.metric b{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.4vw,42px);color:var(--ink);line-height:1;letter-spacing:-0.02em}
.metric b em{font-style:normal;color:var(--brand-2)}
.metric span{display:block;font-size:13.5px;color:var(--slate);margin-top:7px}
@media(max-width:780px){.metrics-in{grid-template-columns:1fr 1fr}.metric:nth-child(3){border-left:none}}

/* logos */
.logos{padding:48px 0 8px;text-align:center}
.logos .cap{font-family:var(--display);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--slate-2)}
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;margin-top:24px}
.logo-row span{font-family:var(--display);font-weight:700;font-size:clamp(16px,2vw,24px);color:var(--ink);opacity:0.34;transition:.2s}
.logo-row span:hover{opacity:.85;color:var(--brand-2)}

section{padding:90px 0}
.sec-head{max-width:720px;margin-bottom:46px}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.8vw,46px);letter-spacing:-0.025em;line-height:1.05;margin:12px 0}
.sec-head p{font-size:18px;color:var(--slate)}

/* services / format cards */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.services.cols-3{grid-template-columns:repeat(3,1fr)}
.svc{border:1px solid var(--line);border-radius:14px;padding:26px 24px;transition:.18s;background:#fff}
.svc:hover{border-color:var(--brand-2);box-shadow:0 14px 32px rgba(21,23,28,0.07);transform:translateY(-3px)}
.svc .tag{font-family:var(--display);font-weight:600;font-size:12px;color:var(--brand-2);letter-spacing:0.04em}
.svc h3{font-size:19px;font-weight:700;margin:14px 0 8px}
.svc p{font-size:14px;color:var(--slate)}
.svc a{margin-top:14px;display:inline-flex;gap:6px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--brand-2)}
@media(max-width:900px){.services,.services.cols-3{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.services,.services.cols-3{grid-template-columns:1fr}}

/* steps */
.steps{background:var(--mist);border-radius:20px;padding:54px 50px}
.step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:34px}
.step .no{font-family:var(--display);font-weight:700;font-size:15px;color:#fff;background:var(--brand-2);width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step h3{font-size:19px;font-weight:700;margin-bottom:7px}
.step p{font-size:14.5px;color:var(--slate)}
@media(max-width:780px){.step-grid{grid-template-columns:1fr;gap:22px}.steps{padding:40px 30px}}

/* split feature (text + image) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split.flip .media{order:2}
.split .media img{width:100%;height:440px;object-fit:cover;border-radius:16px}
.split h2{font-family:var(--display);font-weight:700;font-size:clamp(26px,3.4vw,40px);letter-spacing:-0.02em;line-height:1.06;margin:12px 0 16px}
.split p{font-size:17px;color:var(--slate);margin-bottom:14px}
.checks{list-style:none;display:grid;gap:12px;margin-top:18px}
.checks li{display:grid;grid-template-columns:24px 1fr;gap:12px;font-size:15.5px}
.checks li b{font-weight:600}
.checks .ck{width:22px;height:22px;border-radius:6px;background:color-mix(in oklch,var(--brand-2) 14%,#fff);color:var(--brand-2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin-top:1px}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:30px}.split.flip .media{order:0}.split .media img{height:300px}}

/* experiences */
.exp{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ex{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;transition:.18s}
.ex:hover{box-shadow:0 18px 40px rgba(21,23,28,0.1);transform:translateY(-4px)}
.ex .ph{height:210px;overflow:hidden}
.ex .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ex:hover .ph img{transform:scale(1.05)}
.ex .b{padding:24px 24px 26px}
.ex .k{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:var(--brand-2)}
.ex h3{font-size:20px;font-weight:700;margin:8px 0 8px}
.ex p{font-size:14px;color:var(--slate)}
@media(max-width:900px){.exp{grid-template-columns:1fr}}

/* impact band */
.impact{background:var(--brand);color:#fff;border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1.1fr 0.9fr;align-items:center}
.impact .t{padding:56px 52px}
.impact .t h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.6vw,42px);letter-spacing:-0.02em;line-height:1.05;margin-bottom:16px}
.impact .t p{font-size:17px;color:#f0cfd2;max-width:46ch}
.impact .stat-row{display:flex;gap:40px;margin-top:30px;flex-wrap:wrap}
.impact .stat-row b{font-family:var(--display);font-weight:700;font-size:40px;display:block;line-height:1}
.impact .stat-row span{font-size:13px;color:#f0cfd2}
.impact .img{height:100%;min-height:380px;position:relative}
.impact .img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:880px){.impact{grid-template-columns:1fr}.impact .t{padding:40px 32px}.impact .img{min-height:280px}}

/* testimonials */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tc{border:1px solid var(--line);border-radius:14px;padding:28px 26px;display:flex;flex-direction:column;background:#fff}
.tc .stars{color:var(--brand-bright);letter-spacing:1.5px;margin-bottom:13px}
.tc .q{font-size:16px;line-height:1.5;flex:1;margin-bottom:18px}
.tc .who{font-weight:700;font-size:14.5px}
.tc .role{font-size:13px;color:var(--slate)}
@media(max-width:900px){.tcards{grid-template-columns:1fr}}

/* faq */
.faq{max-width:860px;margin:0 auto}
details{border:1px solid var(--line);border-radius:12px;padding:20px 24px;margin-bottom:12px;background:#fff}
summary{font-family:var(--display);font-weight:600;font-size:18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px}
summary::-webkit-details-marker{display:none}
summary .pm{color:var(--brand-2);transition:.2s}
details[open] summary .pm{transform:rotate(45deg)}
details p{color:var(--slate);font-size:16px;margin-top:13px;max-width:74ch}

/* cta */
.cta{background:var(--ink);color:#fff;border-radius:22px;padding:72px 56px;display:grid;grid-template-columns:1.2fr 0.8fr;gap:40px;align-items:center}
.cta h2{font-family:var(--display);font-weight:700;font-size:clamp(32px,4.6vw,56px);letter-spacing:-0.025em;line-height:1.02;margin-bottom:14px}
.cta p{font-size:18px;color:#b9bec7;max-width:44ch}
.cta .panel{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);border-radius:16px;padding:28px}
.cta .panel .lbl{font-family:var(--display);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:#8b929c}
.cta .panel .ph{font-family:var(--display);font-weight:700;font-size:26px;margin:6px 0 18px}
.cta .panel .btn{width:100%;justify-content:center}
.cta .panel .btn-primary{background:#fff;color:var(--brand)}
@media(max-width:820px){.cta{grid-template-columns:1fr;padding:48px 32px}}

footer{border-top:1px solid var(--line);padding:56px 0 44px;background:var(--mist)}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.foot img{height:40px;margin-bottom:8px}
.foot .wm{font-family:var(--display);font-weight:700;font-size:20px;margin:6px 0 10px}
.foot p{font-size:14px;color:var(--slate);max-width:32ch}
.foot h4{font-family:var(--display);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--slate-2);margin-bottom:14px}
.foot ul{list-style:none;display:grid;gap:10px}
.foot ul a{font-size:14.5px;color:var(--ink);opacity:.82}
.foot ul a:hover{opacity:1;color:var(--brand-2)}
.legal{margin-top:44px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--display);font-size:12.5px;color:var(--slate)}
@media(max-width:820px){.foot{grid-template-columns:1fr 1fr}}
/* keep reading / related cards */
.morecs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.morecs a{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;background:#fff;padding:24px;transition:.18s;text-decoration:none}
.morecs a:hover{border-color:var(--brand-2);transform:translateY(-4px);box-shadow:0 14px 32px rgba(21,23,28,.08)}
.morecs .k{font-family:var(--display);font-weight:600;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-2)}
.morecs h3{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;line-height:1.15;margin:10px 0 8px;color:var(--ink)}
.morecs p{font-size:14px;color:var(--slate);flex:1}
.morecs .go{margin-top:14px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--brand-2)}
@media(max-width:760px){.morecs{grid-template-columns:1fr}}
/* city local-knowledge block */
.localk{background:var(--ink);color:#fff;border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1.1fr 0.9fr;align-items:stretch}
.localk .t{padding:48px 46px;display:flex;flex-direction:column;justify-content:center}
.localk .eyebrow{color:#ff9b88}
.localk h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,3vw,36px);letter-spacing:-0.02em;line-height:1.06;margin:10px 0 14px}
.localk p{font-size:16px;color:#c4c9d1;line-height:1.6;margin-bottom:12px;max-width:52ch}
.localk .spots{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.localk .spots span{font-family:var(--display);font-weight:600;font-size:12.5px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);border-radius:100px;padding:6px 13px}
.localk .img{position:relative;min-height:320px}
.localk .img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.localk{grid-template-columns:1fr}.localk .img{min-height:220px;order:-1}.localk .t{padding:34px 28px}}

/* client logo wall */
.logo-wall{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-top:26px}
.logo-wall .lw{width:94px;height:94px;border:1px solid var(--line);border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:.2s}
.logo-wall .lw:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(21,23,28,.09);border-color:var(--brand-2)}
.logo-wall img{width:100%;height:100%;object-fit:cover}

/* city map */
.citymap{display:grid;grid-template-columns:1fr 1.25fr;gap:30px;align-items:center;background:var(--mist);border:1px solid var(--line);border-radius:20px;padding:34px}
.citymap-info h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,3vw,34px);letter-spacing:-0.02em;line-height:1.06;margin:10px 0 12px}
.citymap-info p{font-size:16px;color:var(--slate);margin-bottom:18px}
.citymap-frame{position:relative;aspect-ratio:16/10;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.citymap-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.25)}
@media(max-width:820px){.citymap{grid-template-columns:1fr;padding:24px}}