@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* ---------------------------------------------------
   TOKENS
--------------------------------------------------- */
:root{
  --navy-deep:#071427;
  --navy:#0B1E3B;
  --navy-soft:#132A4E;
  --gold:#C6A15B;
  --gold-light:#E4CFA0;
  --teal:#2F6F68;
  --bg:#F4F6F9;
  --panel:#FFFFFF;
  --ink:#12202F;
  --slate:#576473;
  --slate-light:#8592A1;
  --line:#DEE4EC;
  --line-strong:#C7D0DB;

  --display: 'Space Grotesk', sans-serif;
  --body: 'Inter', sans-serif;
  --mono: 'IBM Plex Mono', monospace;

  --maxw: 1180px;
  --radius: 2px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  line-height:1.15;
  margin:0;
  letter-spacing:-0.01em;
}
p{margin:0;}
button{font-family:inherit;cursor:pointer;}

:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; transition-duration:0.001ms !important;}
  html{scroll-behavior:auto;}
}

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 32px;
}

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";
  width:22px;
  height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.on-light{ color:var(--teal); }

.section{
  padding:96px 0;
  border-bottom:1px solid var(--line);
}
.section.tight{padding:64px 0;}
.section-head{
  max-width:640px;
  margin-bottom:56px;
}
.section-head h2{
  font-size:clamp(28px,3.4vw,40px);
  margin-bottom:18px;
}
.section-head p{
  color:var(--slate);
  font-size:17px;
  max-width:560px;
}

/* ---------------------------------------------------
   HEADER / NAV
--------------------------------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(244,246,249,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:80px;
}
.brand{
  font-family:var(--display);
  font-weight:700;
  font-size:19px;
  letter-spacing:0.02em;
  display:flex;
  align-items:center;
  gap:10px;
}
.brand .mark{
  width:11px;height:11px;
  background:var(--gold);
  display:inline-block;
  transform:rotate(45deg);
}
.brand small{
  display:block;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.16em;
  color:var(--slate);
  font-weight:400;
  margin-top:2px;
}
nav.main-nav ul{
  display:flex;
  gap:38px;
}
nav.main-nav a{
  font-size:14px;
  font-weight:500;
  color:var(--slate);
  position:relative;
  padding:4px 0;
}
nav.main-nav a:hover, nav.main-nav a.active{color:var(--navy);}
nav.main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;bottom:-2px;
  width:100%;height:2px;
  background:var(--gold);
}
.nav-cta{
  background:var(--navy);
  color:#fff !important;
  padding:11px 22px;
  font-size:13px;
  font-weight:600;
  border-radius:var(--radius);
  letter-spacing:0.01em;
}
.nav-cta:hover{background:var(--navy-soft);}
.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:8px;
}
.nav-toggle span{width:22px;height:2px;background:var(--ink);display:block;}

@media (max-width:860px){
  nav.main-nav{
    position:absolute;
    top:80px;left:0;right:0;
    background:var(--panel);
    border-bottom:1px solid var(--line);
    display:none;
    flex-direction:column;
    padding:24px 32px 32px;
  }
  nav.main-nav.open{display:flex;}
  nav.main-nav ul{flex-direction:column;gap:20px;}
  .nav-cta{display:inline-block;width:fit-content;}
  .nav-toggle{display:flex;}
}

/* ---------------------------------------------------
   HERO
--------------------------------------------------- */
.hero{
  position:relative;
  min-height:640px;
  display:flex;
  align-items:flex-end;
  color:#fff;
  overflow:hidden;
  background:linear-gradient(180deg,#0d2a4d 0%, var(--navy-deep) 75%);
}
.hero.short{min-height:420px;}
.hero-visual{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-visual svg{
  position:absolute;
  bottom:0;left:0;
  width:100%;
  height:100%;
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(7,20,39,0.35) 0%, rgba(7,20,39,0.72) 55%, var(--navy-deep) 100%);
  z-index:1;
}
.hero-inner{
  position:relative;
  z-index:2;
  padding:120px 0 72px;
  width:100%;
}
.hero-tier{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.12em;
  color:var(--gold-light);
  text-transform:uppercase;
}
.hero h1{
  font-size:clamp(44px,7vw,84px);
  margin:18px 0 22px;
  color:#fff;
}
.hero .lede{
  font-size:19px;
  max-width:560px;
  color:rgba(255,255,255,0.82);
  margin-bottom:36px;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 26px;
  font-size:14px;
  font-weight:600;
  border-radius:var(--radius);
  border:1px solid transparent;
  transition:background .15s ease, color .15s ease, border-color .15s ease;
}
.btn-gold{background:var(--gold);color:var(--navy-deep);}
.btn-gold:hover{background:var(--gold-light);}
.btn-outline{border-color:rgba(255,255,255,0.4);color:#fff;}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,0.08);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-soft);}
.btn-line{border-color:var(--line-strong);color:var(--navy);}
.btn-line:hover{border-color:var(--navy);}

/* tier strip under hero */
.tier-strip{
  background:var(--navy-deep);
  color:var(--gold-light);
  border-top:1px solid rgba(255,255,255,0.08);
}
.tier-strip .wrap{
  display:flex;
  flex-wrap:wrap;
  gap:0;
  padding-top:0;padding-bottom:0;
}
.tier-strip .tier{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.08em;
  padding:16px 26px 16px 0;
  margin-right:26px;
  border-right:1px solid rgba(255,255,255,0.12);
  white-space:nowrap;
}
.tier-strip .tier:last-child{border-right:none;}
.tier-strip .tier b{color:#fff;font-weight:500;}

/* ---------------------------------------------------
   WHAT IS THE BOARD - two column
--------------------------------------------------- */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:start;
}
@media (max-width:860px){.split{grid-template-columns:1fr;gap:40px;}}

.check-list li{
  display:flex;
  gap:14px;
  padding:16px 0;
  border-top:1px solid var(--line);
  font-size:15.5px;
  color:var(--ink);
}
.check-list li:last-child{border-bottom:1px solid var(--line);}
.check-list li .n{
  font-family:var(--mono);
  font-size:12px;
  color:var(--gold);
  padding-top:2px;
  min-width:22px;
}

.panel-card{
  background:var(--navy);
  color:#fff;
  padding:40px;
  border-radius:var(--radius);
}
.panel-card h3{
  font-size:15px;
  color:var(--gold-light);
  font-family:var(--mono);
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:24px;
}
.op-item{
  display:flex;
  gap:16px;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,0.12);
}
.op-item:first-of-type{border-top:none;}
.op-item .dot{
  width:6px;height:6px;
  border-radius:50%;
  background:var(--gold);
  margin-top:8px;
  flex-shrink:0;
}
.op-item strong{display:block;font-size:14.5px;margin-bottom:4px;font-family:var(--display);font-weight:600;}
.op-item span{font-size:13.5px;color:rgba(255,255,255,0.68);line-height:1.55;}

/* ---------------------------------------------------
   SECTOR INDEX (signature ledger)
--------------------------------------------------- */
.sector-index{
  border-top:1px solid var(--line-strong);
  border-left:1px solid var(--line-strong);
  display:grid;
  grid-template-columns:repeat(3,1fr);
}
@media (max-width:760px){.sector-index{grid-template-columns:1fr;}}
.sector-row{
  border-right:1px solid var(--line-strong);
  border-bottom:1px solid var(--line-strong);
  padding:22px 24px;
  display:flex;
  align-items:baseline;
  gap:16px;
  background:var(--panel);
  transition:background .15s ease;
}
.sector-row:hover{background:var(--navy);}
.sector-row:hover .sector-name{color:#fff;}
.sector-row:hover .sector-num{color:var(--gold);}
.sector-num{
  font-family:var(--mono);
  font-size:13px;
  color:var(--slate-light);
  flex-shrink:0;
}
.sector-name{
  font-size:14.5px;
  font-weight:500;
  color:var(--ink);
  transition:color .15s ease;
}

/* ---------------------------------------------------
   IMPACT STRIP
--------------------------------------------------- */
.impact{
  background:var(--navy-deep);
  color:#fff;
  padding:88px 0;
}
.impact .kicker{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.14em;
  color:var(--gold);
  text-transform:uppercase;
  margin-bottom:20px;
}
.impact h2{
  font-size:clamp(24px,3vw,34px);
  color:#fff;
  max-width:680px;
  margin-bottom:32px;
  font-weight:500;
}
.impact .triad{
  display:flex;
  gap:40px;
  flex-wrap:wrap;
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:0.06em;
  color:var(--gold-light);
  text-transform:uppercase;
}

/* ---------------------------------------------------
   FOUNDER TEASER
--------------------------------------------------- */
.founder-teaser{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:40px;
  align-items:center;
}
@media (max-width:700px){.founder-teaser{grid-template-columns:1fr;}}
.monogram{
  width:150px;height:150px;
  background:var(--navy);
  color:var(--gold);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-size:44px;
  font-weight:600;
  border-radius:50%;
  border:1px solid var(--gold);
}
.monogram.small{width:96px;height:96px;font-size:28px;}

/* ---------------------------------------------------
   CTA BANNER
--------------------------------------------------- */
.cta-banner{
  background:var(--panel);
  border:1px solid var(--line-strong);
  padding:56px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:32px;
  flex-wrap:wrap;
}
.cta-banner h3{font-size:24px;max-width:420px;}
.cta-banner .actions{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------------------------------------------------
   FOOTER
--------------------------------------------------- */
footer{
  background:var(--navy-deep);
  color:rgba(255,255,255,0.6);
  padding:64px 0 32px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
@media (max-width:700px){.footer-grid{grid-template-columns:1fr;}}
footer .brand{color:#fff;margin-bottom:14px;}
footer .brand small{color:rgba(255,255,255,0.5);}
footer p{font-size:14px;line-height:1.7;max-width:320px;}
footer h4{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold-light);
  margin-bottom:18px;
}
footer ul li{margin-bottom:10px;}
footer ul a{font-size:14px;color:rgba(255,255,255,0.65);}
footer ul a:hover{color:#fff;}
.footer-bottom{
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-size:12.5px;
  color:rgba(255,255,255,0.4);
}

/* ---------------------------------------------------
   GENERIC PAGE HEADER (non-home hero variant)
--------------------------------------------------- */
.page-head{
  padding:64px 0 40px;
  border-bottom:1px solid var(--line);
}
.page-head h1{
  font-size:clamp(32px,4.4vw,48px);
  margin-top:14px;
}
.page-head .lede{
  color:var(--slate);
  font-size:17px;
  max-width:600px;
  margin-top:16px;
}
.breadcrumb{
  font-family:var(--mono);
  font-size:12px;
  color:var(--slate-light);
  letter-spacing:0.04em;
}
.breadcrumb a{color:var(--slate);}
.breadcrumb a:hover{color:var(--navy);}

/* ---------------------------------------------------
   PROFILE / ABOUT
--------------------------------------------------- */
.profile-head{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:48px;
  align-items:start;
}
@media (max-width:760px){.profile-head{grid-template-columns:1fr;}}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.tag{
  font-family:var(--mono);
  font-size:11.5px;
  padding:7px 12px;
  border:1px solid var(--line-strong);
  color:var(--slate);
  border-radius:20px;
}
.pull-quote{
  border-left:3px solid var(--gold);
  padding:6px 0 6px 28px;
  font-family:var(--display);
  font-size:22px;
  font-weight:500;
  color:var(--navy);
  margin:36px 0;
  max-width:680px;
}
.prose p{margin-bottom:18px;color:var(--ink);font-size:16px;line-height:1.75;}
.prose p:last-child{margin-bottom:0;}
.stat-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line-strong);
  border:1px solid var(--line-strong);
  margin:40px 0;
}
@media (max-width:700px){.stat-row{grid-template-columns:1fr;}}
.stat{
  background:var(--panel);
  padding:28px;
}
.stat .num{
  font-family:var(--display);
  font-size:32px;
  font-weight:700;
  color:var(--navy);
}
.stat .label{
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--slate);
  margin-top:6px;
}

/* ---------------------------------------------------
   PROGRAM PAGE — steps / role scope / notice
--------------------------------------------------- */
.two-col-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
}
@media (max-width:760px){.two-col-list{grid-template-columns:1fr;}}
.scope-card{
  border:1px solid var(--line-strong);
  padding:32px;
  background:var(--panel);
}
.scope-card h3{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.scope-card.yes h3{color:var(--teal);}
.scope-card.no h3{color:#A6472F;}
.scope-card li{
  font-size:14.5px;
  padding:10px 0;
  border-top:1px solid var(--line);
  display:flex;
  gap:10px;
  color:var(--ink);
}
.scope-card li:first-of-type{border-top:none;}
.scope-card.yes li::before{content:"+";color:var(--teal);font-weight:600;}
.scope-card.no li::before{content:"–";color:#A6472F;font-weight:600;}

.steps{
  counter-reset:step;
  border-top:1px solid var(--line);
}
.step{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:24px;
  padding:28px 0;
  border-bottom:1px solid var(--line);
}
.step .num{
  counter-increment:step;
  font-family:var(--mono);
  font-size:13px;
  color:var(--gold);
}
.step .num::before{content: "0" counter(step);}
.step h4{font-size:16.5px;margin-bottom:6px;}
.step p{color:var(--slate);font-size:14.5px;max-width:560px;}

.notice{
  background:#FBF6EC;
  border:1px solid var(--gold-light);
  border-left:3px solid var(--gold);
  padding:28px 32px;
  font-size:14.5px;
  color:var(--ink);
  line-height:1.7;
}
.notice strong{color:var(--navy);}

/* ---------------------------------------------------
   FORMS
--------------------------------------------------- */
.form-shell{
  background:var(--panel);
  border:1px solid var(--line-strong);
  padding:48px;
}
@media (max-width:600px){.form-shell{padding:28px;}}
fieldset{
  border:none;
  padding:0;
  margin:0 0 44px;
}
fieldset:last-of-type{margin-bottom:0;}
legend{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--teal);
  padding:0 0 18px;
  border-bottom:1px solid var(--line);
  width:100%;
  margin-bottom:26px;
}
.field-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
@media (max-width:640px){.field-grid{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1/-1;}
.field label{
  font-size:13px;
  font-weight:500;
  color:var(--ink);
}
.field .hint{font-size:12.5px;color:var(--slate-light);}
input[type=text],
input[type=email],
input[type=tel],
select,
textarea{
  font-family:var(--body);
  font-size:14.5px;
  padding:12px 14px;
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  background:#fff;
  color:var(--ink);
  width:100%;
}
input:focus, select:focus, textarea:focus{
  border-color:var(--navy);
}
textarea{resize:vertical;min-height:110px;}
.radio-row, .check-row{display:flex;gap:22px;flex-wrap:wrap;margin-top:4px;}
.radio-row label, .check-row label{
  font-size:14px;
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:400;
}
.check-single{
  display:flex;
  gap:12px;
  align-items:flex-start;
  font-size:14px;
  color:var(--ink);
  padding:14px 0;
  border-top:1px solid var(--line);
}
.check-single input{margin-top:3px;}
.ref-pair{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:16px;
  padding:18px 0;
  border-top:1px solid var(--line);
}
@media (max-width:700px){.ref-pair{grid-template-columns:1fr;}}
.submit-row{
  display:flex;
  align-items:center;
  gap:20px;
  margin-top:8px;
  flex-wrap:wrap;
}
.form-note{
  font-size:12.5px;
  color:var(--slate-light);
  max-width:420px;
}
.form-success{
  display:none;
  background:#EFF6F3;
  border:1px solid var(--teal);
  color:#1F4B45;
  padding:20px 24px;
  font-size:14.5px;
  margin-top:24px;
}
.form-success.show{display:block;}

/* small helpers */
.mt-64{margin-top:64px;}
.center-copy{max-width:680px;}

/* ---------------------------------------------------
   ENGAGEMENTS / SERVICES
--------------------------------------------------- */
.engagement-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
}
@media (max-width:860px){.engagement-grid{grid-template-columns:1fr;}}
.engagement-card{
  border:1px solid var(--line-strong);
  background:var(--panel);
  padding:44px;
  display:flex;
  flex-direction:column;
}
.engagement-card h3{font-size:25px;margin:14px 0 16px;}
.engagement-card .desc{color:var(--slate);font-size:15px;line-height:1.7;margin-bottom:28px;}
.engagement-card .meta{margin-bottom:30px;}
.engagement-card .meta li{
  font-size:13.5px;
  padding:12px 0;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:110px 1fr;
  gap:10px;
  color:var(--ink);
}
.engagement-card .meta li:first-child{border-top:none;}
.engagement-card .meta li b{
  font-family:var(--mono);
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--teal);
  font-weight:500;
}
.engagement-card .cta-row{margin-top:auto;display:flex;gap:12px;flex-wrap:wrap;}

.btn-wa{
  background:var(--navy);
  color:#fff;
}
.btn-wa:hover{background:var(--navy-soft);}
.btn-wa svg{flex-shrink:0;}

.locations-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line-strong);
  border:1px solid var(--line-strong);
}
@media (max-width:700px){.locations-list{grid-template-columns:1fr;}}
.locations-list li{
  background:var(--panel);
  padding:26px 28px;
  font-size:14.5px;
  color:var(--ink);
  display:flex;
  gap:14px;
}
.locations-list li .pin{
  font-family:var(--mono);
  color:var(--gold);
  flex-shrink:0;
}

.alert{
  background:#FBEFEA;
  border:1px solid #E3B9A8;
  border-left:3px solid #A6472F;
  padding:30px 34px;
  font-size:14.5px;
  color:var(--ink);
  line-height:1.75;
}
.alert strong{color:#8C3B27;}
.alert-number{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--mono);
  font-size:15px;
  color:var(--navy);
  background:#fff;
  border:1px solid var(--line-strong);
  padding:10px 18px;
  margin-top:16px;
}
