:root{
  --ink:#0b1220;
  --navy:#0a1428;
  --ivory:#f6f2ea;
  --paper:#ffffff;
  --muted:#5b6473;
  --line:rgba(11,18,32,.12);
  --shadow:0 10px 30px rgba(11,18,32,.08);
  --radius:16px;
  --max:1160px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:linear-gradient(180deg,var(--ivory) 0%, #fff 55%, #fff 100%);
}
a{color:inherit; text-decoration:none}
a:hover{opacity:.92}
.container{max-width:var(--max); margin:0 auto; padding:0 24px}
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(246,242,234,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.brand{
  display:inline-flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  line-height:1.05;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:650;
  font-size: 15px;
}
.brand-line2{
  font-size: 12px;
  font-weight:600;
  opacity:.78;
  letter-spacing:.14em;
}
.mark{
  width:14px; height:14px; border:2px solid var(--navy);
  transform: rotate(45deg);
}
.menu{display:flex; gap:18px; align-items:center; font-size:14px; color:var(--muted)}
.menu a{padding:8px 10px; border-radius:10px}
.menu a.active{background:rgba(10,20,40,.08); color:var(--ink)}
.pills{display:flex; gap:10px; align-items:center}
.pill{
  border:1px solid rgba(10,20,40,.22);
  padding:10px 14px; border-radius:999px;
  font-size:13px; background:rgba(255,255,255,.65);
}


/* Audience switcher (segmented control) */
.audienceSwitch{
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:3px;
  border-radius:999px;
  border:1px solid rgba(10,20,40,.18);
  background:rgba(255,255,255,.55);
}
.audienceSeg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:12.5px;
  line-height:1;
  letter-spacing:-0.01em;
  color:rgba(11,18,32,.72);
  white-space:nowrap;
}
.audienceSeg:hover{
  background:rgba(10,20,40,.06);
  color:var(--ink);
}
.audienceSeg.active{
  background:var(--navy);
  color:var(--ivory);
}
.audienceSeg.active:hover{
  background:#0b1730;
}
@media (max-width: 780px){
  .audienceSwitch{padding:2px}
  .audienceSeg{padding:7px 10px; font-size:12px}
}
.pill.sm{
  padding:7px 10px;
  font-size:12px;
  border-color: rgba(10,20,40,.18);
  background: rgba(255,255,255,.78);
}
.pill.primary{
  background:var(--navy); color:var(--ivory);
  border-color:var(--navy);
}
.hero{padding:70px 0 34px}
.hero.heroLanding{padding:102px 0 66px}
.heroLanding{
  position: relative;
}
.heroLanding::before{
  content:"";
  position:absolute;
  inset:-28px -28px 0 -28px;
  /* Institutional material + light: subtle, premium, readable */
  background-image:
    radial-gradient(1200px 650px at 28% 26%,
      rgba(255,255,255,0.55) 0%,
      rgba(255,255,255,0.10) 55%,
      rgba(255,255,255,0.00) 100%
    ),
    linear-gradient(180deg,
      rgba(10, 18, 32, 0.06) 0%,
      rgba(10, 18, 32, 0.10) 55%,
      rgba(10, 18, 32, 0.14) 100%
    ),
    url("../img/hero/landing-hero.svg");
  background-size:cover;
  background-position:center;
  opacity:1;
  filter: contrast(1.04) saturate(.90) brightness(.96);
  pointer-events:none;
  z-index:-1;
}

@media (max-width:768px){
  /* Keep hero expansive but avoid pushing key content too far down on mobile */
  .hero.heroLanding{padding:90px 0 60px}
  .heroLanding::before{inset:-18px -18px 0 -18px}
}
.proofNote{
  margin-top:10px;
  opacity:.8;
}

.kicker{font-size:12px; color:var(--muted); letter-spacing:.18em; text-transform:uppercase}
h1{
  margin:10px 0 14px;
  font-size:46px; line-height:1.05;
  letter-spacing:-.02em;
}
.subhead{
  font-size:18px; line-height:1.55; color:rgba(11,18,32,.75);
  max-width:760px;
}
.heroActions{margin-top:22px; display:flex; gap:12px; flex-wrap:wrap}
.proofbar{
  margin-top:26px;
  display:grid; grid-template-columns: repeat(5, minmax(0,1fr));
  gap:14px;
}
.proof{
  background:rgba(255,255,255,.75);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px 18px;
  box-shadow: 0 1px 0 rgba(11,18,32,.03);
}
.proof .num{font-size:20px; font-weight:700}
.proof .lbl{font-size:13px; color:var(--muted); margin-top:2px}

/* Home proof cards (v7) */
.proofbar.proofCards{
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.proofCard{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  padding:18px 20px;
  box-shadow: 0 1px 0 rgba(11,18,32,.04);
}
.proofValue{
  font-size:16px;
  line-height:1.15;
  font-weight:600;
  letter-spacing:-.02em;
  color:var(--ink);
}
.proofLabel{
  margin-top:8px;
  font-size:12.5px;
  line-height:1.35;
  color:rgba(11,18,32,.62);
  font-weight:500;
}
.section{padding:44px 0}
.sectionHead{
  display:flex; align-items:flex-end; justify-content:space-between; gap:24px;
  margin-bottom:18px;
}
.sectionHead h2{margin:0; font-size:22px; letter-spacing:-.01em}
.sectionHead p{margin:0; color:var(--muted); max-width:680px; font-size:14px; line-height:1.55}
.grid2{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px}
.grid3{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px}
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.card h3{margin:0 0 8px; font-size:16px}
.card p{margin:0 0 14px; color:var(--muted); font-size:14px; line-height:1.55}
.homePortfolioCard{display:flex; flex-direction:column; min-height:160px}
.homePortfolioCard .meta{margin-top:auto}
.meta{display:flex; gap:8px; flex-wrap:wrap}
.tag{
  font-size:12px; padding:7px 10px; border-radius:999px;
  border:1px solid rgba(10,20,40,.18);
  background:rgba(246,242,234,.5);
  color:rgba(11,18,32,.8);
}
.hr{height:1px; background:var(--line); margin:22px 0}
.small{font-size:12px; color:var(--muted); line-height:1.55}
.footer{
  padding:34px 0 44px;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, #fff 0%, rgba(246,242,234,.65) 100%);
}
.footerGrid{
  display:grid; grid-template-columns: 2fr 1fr 1fr; gap:16px;
}
.footer h4{margin:0 0 10px; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:rgba(11,18,32,.78)}
.footer a{display:block; padding:5px 0; font-size:13px; color:rgba(11,18,32,.78)}
.notice{
  margin-top:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.7);
  border-radius:var(--radius);
  padding:14px 16px;
}
.notice strong{display:block; margin-bottom:6px; font-size:13px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:12px;
  border:1px solid rgba(10,20,40,.22);
  background:rgba(255,255,255,.75);
  font-size:13px;
}
.btn.primary{
  background:var(--navy);
  color:var(--ivory);
  border-color:var(--navy);
}
.btn.ghost{
  background:transparent;
}
.table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:rgba(255,255,255,.85);
}
.table th,.table td{
  padding:12px 12px;
  border-bottom:1px solid var(--line);
  font-size:13px;
  text-align:left;
  vertical-align:top;
}
.table th{color:rgba(11,18,32,.75); font-weight:650; background:rgba(246,242,234,.55)}
.table tr:last-child td{border-bottom:none}
.filters{
  display:flex; flex-wrap:wrap; gap:10px; margin-bottom:14px
}
select, input[type="search"]{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(10,20,40,.18);
  background:rgba(255,255,255,.8);
  font-size:13px;
}
.banner{
  background:radial-gradient(900px 250px at 10% 20%, rgba(10,20,40,.09) 0%, transparent 60%),
             radial-gradient(900px 250px at 80% 40%, rgba(10,20,40,.07) 0%, transparent 60%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
@media (max-width: 900px){
  h1{font-size:38px}
  .proofbar{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
  .menu{display:none}
  .navMobile{display:block}

}

@media (max-width: 560px){
  .proofbar.proofCards{grid-template-columns:1fr}
  .proofCard{padding:22px 22px; border-radius:22px}
  .proofValue{font-size:20px}
  .proofLabel{font-size:13px}
}
@media print{
  .topbar,.footer .links,.heroActions,.menu,.pills{display:none !important}
  body{background:#fff}
  .card{box-shadow:none}
}

/* Team page (data-driven groups) */
.groupNav{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }

.groupSection { margin-top: 18px; padding:18px; border:1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.02); }
.groupHeader { margin-bottom: 12px; }
.groupTitle { margin:0; font-size:16px; letter-spacing:.2px; }
.groupSubtitle { margin-top:6px; opacity:.78; font-size:12px; }

.teamList { display:grid; gap:14px; }
.teamCard{
  display:flex;
  gap:18px;
  padding:16px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.03);
  align-items:flex-start;
}
.teamPhoto{
  width:92px; height:92px;
  border-radius:14px;
  object-fit:cover;
  flex:0 0 92px;
  border:1px solid rgba(255,255,255,.10);
}
.teamName{ font-weight:600; font-size:15px; letter-spacing:.2px; }
.teamTitle{ opacity:.86; margin-top:2px; font-size:13px; }
.teamTags{ margin-top:8px; display:flex; flex-wrap:wrap; gap:8px; }
.pillTag{
  font-size:11px; opacity:.86;
  border:1px solid rgba(255,255,255,.14);
  padding:4px 8px; border-radius:999px;
  background: rgba(255,255,255,.02);
}
.teamBio{ margin-top:10px; opacity:.92; line-height:1.55; max-width:70ch; }
.teamLink{ margin-top:10px; display:inline-block; font-size:12px; opacity:.92; text-decoration:underline; }

@media (max-width:720px){
  .teamCard{ flex-direction:column; }
  .teamPhoto{ width:110px; height:110px; }
}


/* Signup form (Blackstone-inspired) */
.signup{margin-top:10px}
.signup .input{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,.75);
  font-size:13px;
  margin-top:8px;
}
.signup .btn{width:100%; margin-top:10px}
.small.muted{opacity:.85}

.bigNum{font-size:34px; letter-spacing:-.02em; font-weight:700; margin-top:6px}
.bullets{margin:10px 0 0 18px; color:rgba(11,18,32,.82); line-height:1.6}
.bullets li{margin:6px 0}
.table{width:100%; border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--line); padding:10px 12px; text-align:left; font-size:13px}
.table th{font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:rgba(11,18,32,.7)}


/* Footer restructure: top row + legal bottom row */
.footerTop{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
  align-items:start;
}
.footerBottom{margin-top:22px;}
.footerBottom .notice{margin-top:0;}
@media (max-width:1024px){
  .footerTop{grid-template-columns: 1fr 1fr; gap:16px;}
}
@media (max-width:768px){
  .footerTop{grid-template-columns: 1fr;}
}


/* Landing hero spacing */
.hero.heroLanding .proofbar{margin-top:34px}


/* Team photo fallback (initials) for missing images */
.teamPhotoFallback{
  display:none;
  width:92px; height:92px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(246,242,234,.9);
  color:rgba(11,18,32,.72);
  font-weight:650;
  letter-spacing:.6px;
  align-items:center;
  justify-content:center;
}
.teamCard.no-photo .teamPhotoFallback{display:flex;}
.teamCard.no-photo .teamPhoto{display:none;}
@media (max-width:720px){
  .teamPhotoFallback{ width:110px; height:110px; }
}


/* === Mobile navigation + responsive fixes (v30) === */
/* === Mobile nav (stable on iOS Safari) === */
.navMobile{display:none; position:relative;}
.navToggle{
  cursor:pointer;
  user-select:none;
  font-size:14px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  background:transparent;
  display:inline-flex;
  align-items:center;
  gap:8px;
  line-height:1;
  list-style:none;
  -webkit-tap-highlight-color: transparent;
}
.navToggle::-webkit-details-marker{display:none;}
.navToggle::marker{content:"";}
.navMobile[open] .navToggle{background:rgba(15,23,42,.06);}
.mobileMenu{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:220px;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  z-index:50;
}


.tableWrap{width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch;}

@media (max-width: 900px){
  .nav{flex-wrap:wrap; gap:12px;}
  .navMobile{display:block;}
  .sectionHead{flex-direction:column; align-items:flex-start; gap:10px;}
}

@media (max-width: 560px){
  .table{min-width:720px;}
}

}

.proofValue{
    font-size: 13px !important;
    line-height: 1.18 !important;
    letter-spacing: -0.01em !important;
    font-weight: 500 !important;
  }
  .proofLabel{
    margin-top: 6px !important;
    font-size: 10px !important;
    line-height: 1.32 !important;
    opacity: 0.85;
  }
}

}

}

}

/* =========================================================
   Mobile polish pass — ultra-premium institutional finish
   (Mobile only; desktop/tablet unchanged)
   ========================================================= */
@media (max-width: 900px){
  /* Nav: calmer alignment + consistent tap targets */
  .nav{ height:64px; }
  .brand{ line-height:1.05; }
  .navToggle{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:8px 10px;
    list-style:none;
    -webkit-tap-highlight-color: transparent;
  }
  summary.navToggle::-webkit-details-marker{display:none;}

  /* Dropdown: premium editorial panel (narrow, disciplined, readable) */
  .mobileMenu{
    min-width:0 !important;
    width: min(31vw, 112px) !important;
    inline-size: min(31vw, 112px) !important;
    max-width: 112px !important;

    right: 12px !important;
    left: auto !important;

    padding: 10px !important;
    gap: 0 !important;

    border: 1px solid rgba(15,23,42,.12) !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.94) !important;

    box-shadow: 0 10px 26px rgba(11,18,32,.10), 0 1px 0 rgba(11,18,32,.04) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .mobileMenu a{
    display:flex;
    align-items:center;
    min-height:44px; /* iOS tap target */
    padding: 10px 10px;
    border-radius: 12px;
    color: var(--ink);
    text-decoration:none;
    font-weight:500;
    -webkit-tap-highlight-color: transparent;
  }
  .mobileMenu a:active{
    background: rgba(11,18,32,.05);
  }
/* Home hero: cleaner breathing room + proof bar feels calmer */
  .hero.heroLanding{ padding: 86px 0 54px; }
  .heroLanding::before{
    /* slightly richer contrast on mobile without losing restraint */
    filter: contrast(1.05) saturate(.90) brightness(.93);
  }

  /* Proof bar: one-column on mobile for premium rhythm */
  .heroLanding .proofCards{
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 16px !important;
  }
  .heroLanding .proofCard{
    padding: 12px 14px !important;
    border-radius: 16px !important;
    box-shadow: none !important; /* calmer, less KPI-card */
  }
  .heroLanding .proofValue{
    font-size: 14px !important;
    line-height: 1.2 !important;
    letter-spacing: -0.01em;
  }
  .heroLanding .proofLabel{
    font-size: 11.5px !important;
    line-height: 1.35 !important;
    margin-top: 6px !important;
  }
}

/* Extra-small phones */
@media (max-width: 560px){
  /* Section headers: title + button stack cleanly */
  .sectionHead{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .sectionHead .btn{ align-self:flex-start; }
}

/* Mobile dropdown — narrower + premium dividers (institutional) */
@media (max-width: 900px){
  .mobileMenu{
    width: min(31vw, 112px) !important;
    inline-size: min(31vw, 112px) !important;
    max-width: 112px !important;
    min-width: 0 !important;

    right: 12px !important;
    left: auto !important;

    border: 1px solid rgba(15,23,42,.10) !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.94) !important;

    box-shadow: 0 12px 28px rgba(11,18,32,.10), 0 1px 0 rgba(11,18,32,.04) !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);

    padding: 0 !important;
    overflow: hidden;
    box-sizing: border-box;
  }

  .mobileMenu a{
    display:flex;
    align-items:center;
    min-height:44px;
    padding: 10px 12px;
    border-radius: 0;
    text-decoration:none;
    color: var(--ink);
    -webkit-tap-highlight-color: transparent;
  }

  .mobileMenu a + a{
    border-top: 1px solid rgba(15,23,42,.08);
  }

  .mobileMenu a:active{
    background: rgba(11,18,32,.04);
  }
}

/* Mobile Home proof bar — width -30% (institutional) */

/* Mobile Home hero proof bar — narrower (institutional) */
@media (max-width: 900px){
  /* index.html uses .proofbar (lowercase) + .proofCards */
  .heroLanding .proofbar.proofCards{
    width: 75% !important;          /* +5% width for label fit */
    max-width: 300px !important;    /* slightly wider so 'Institutional Governance' stays on one line */
    margin-left: auto;
    margin-right: auto;

    /* optional: more premium mobile rhythm */
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
}
