/* =========================================================================
   NXGEN  |  Brand Stylesheet
   Where the future takes shape
   ------------------------------------------------------------------------- */

/* ---------- Tokens ----------------------------------------------------- */
:root{
  /* Brand colors — from NXGEN Brand Book */
  --blue-x:   #001e57;   /* Pantone 281C — foundation */
  --blue-xg:  #00319b;   /* Pantone 286C — advancement */
  --cyan-x:   #00c3fa;   /* Pantone 2250C — vision */
  --cyan-soft:#67d8fb;
  --ink:      #0b1437;
  --paper:    #ffffff;
  --paper-2:  #eef4fb;
  --line:     rgba(0,30,87,.12);

  /* Brand gradient (degraded X) */
  --grad-blue: linear-gradient(135deg, var(--blue-xg) 0%, var(--cyan-x) 100%);
  --grad-deep: linear-gradient(160deg, #00102e 0%, var(--blue-x) 60%, var(--blue-xg) 100%);

  /* Type */
  --font-display: 'Roobert','Inter','Roboto','Helvetica Neue',Arial,sans-serif;
  --font-body:    'Roboto','Inter','Helvetica Neue',Arial,sans-serif;

  /* Layout */
  --max:       1240px;
  --gutter:    clamp(20px, 4vw, 56px);
  --radius:    14px;
  --pill:      999px;

  --shadow-1: 0 6px 24px rgba(0,30,87,.10);
  --shadow-2: 0 18px 48px rgba(0,30,87,.18);
}

/* ---------- Reset / base ---------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--blue-xg);text-decoration:none}
a:hover{color:var(--cyan-x)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--blue-x);margin:0 0 .5em;line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.2vw,3.25rem);font-weight:700}
h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1em}
small{font-size:.85rem}

/* ---------- Layout helpers ------------------------------------------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(56px,8vw,120px) 0}
.section--tight{padding:clamp(40px,5vw,72px) 0}
.section--paper{background:var(--paper)}
.section--mist{background:var(--paper-2)}
.section--ink{background:var(--grad-deep);color:#fff}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff}
.eyebrow{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.82rem;
  color:var(--cyan-x);
  position:relative;
  padding-top:14px;
  display:inline-block;
}
.eyebrow::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:40px;height:2px;
  background:var(--cyan-x);
  border-radius:2px;
}
.center .eyebrow::before,
.invest-cta .eyebrow::before,
.coingt-cta .eyebrow::before{
  left:50%;
  transform:translateX(-50%);
}
.lead{font-size:1.1rem;line-height:1.6;color:#3a4670;max-width:54ch}

/* ---------- Top navigation ------------------------------------------- */
.topnav{
  position:fixed;top:0;left:0;right:0;z-index:30;
  padding:24px 0 16px;
  transition:background .25s ease, padding .25s ease, box-shadow .25s ease;
}
/* When scrolled past the hero, add solid dark backdrop with stronger contrast
   so the nav remains clearly visible even when overlapping dark navy sections. */
.topnav.is-scrolled{
  background:linear-gradient(180deg, rgba(0,8,28,.98) 0%, rgba(0,15,46,.96) 100%);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  box-shadow:0 1px 0 rgba(0,195,250,.18), 0 1px 0 rgba(255,255,255,.05) inset, 0 10px 28px rgba(0,8,28,.45);
  padding:14px 0;
}
/* Inverse variant (used on light pages like bios): solid white backdrop on scroll */
.topnav--ink.is-scrolled{
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 0 rgba(0,30,87,.06), 0 8px 24px rgba(0,30,87,.10);
}
.topnav__inner{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--gutter);
  display:flex;align-items:center;gap:32px;justify-content:space-between;
}
.topnav__logo{display:block;width:170px}
.topnav__logo svg{width:100%;height:auto}
.topnav__menu{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.topnav__menu a{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.78rem;
  color:#fff;
  padding:10px 18px;
  border-radius:var(--pill);
  border:1.5px solid transparent;
  transition:border-color .18s, background .18s, color .18s;
}
.topnav__menu a.is-active{border-color:#fff}
.topnav__menu a:hover{background:var(--cyan-x);border-color:var(--cyan-x);color:#fff}
.topnav--ink .topnav__menu a{color:var(--blue-x)}
.topnav--ink .topnav__menu a.is-active{border-color:var(--blue-x)}
.topnav--ink .topnav__menu a:hover{background:var(--cyan-x);border-color:var(--cyan-x);color:#fff}

/* Mobile nav: simple stack */
@media (max-width:780px){
  .topnav__menu{display:none}
  .topnav__menu.is-open{display:flex;width:100%;flex-direction:column;align-items:flex-start;background:rgba(0,15,46,.92);padding:14px;border-radius:14px}
  .topnav__inner{flex-wrap:wrap}
  .topnav__toggle{display:inline-flex}
}
.topnav__toggle{
  display:none;background:transparent;border:1.5px solid #fff;color:#fff;
  border-radius:var(--pill);padding:8px 14px;font-weight:700;letter-spacing:.1em;
}
.topnav--ink .topnav__toggle{color:var(--blue-x);border-color:var(--blue-x)}

/* ---------- Language toggle pill ------------------------------------- */
/* Language detection banner — top of EN pages, shown only when browser is Spanish */
.lang-prompt{background:var(--blue-x);color:#fff;font-family:var(--font-display);font-size:.85rem}
.lang-prompt[hidden]{display:none}
.lang-prompt__inner{max-width:var(--max);margin:0 auto;padding:12px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.lang-prompt__text{letter-spacing:.01em}
.lang-prompt__sep{opacity:.5;padding:0 4px}
.lang-prompt__en{opacity:.7}
.lang-prompt__buttons{display:flex;gap:8px;flex-shrink:0}
.lang-prompt__btn{font-family:var(--font-display);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;padding:7px 16px;border-radius:var(--pill);cursor:pointer;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s}
.lang-prompt__btn--yes{background:var(--cyan-x);color:var(--blue-x);border-color:var(--cyan-x)}
.lang-prompt__btn--yes:hover{background:#fff;border-color:#fff}
.lang-prompt__btn--no{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.45)}
.lang-prompt__btn--no:hover{border-color:#fff;background:rgba(255,255,255,.08)}
@media (max-width:680px){.lang-prompt__inner{flex-direction:column;gap:10px;text-align:center}.lang-prompt__sep,.lang-prompt__en{display:none}}

.lang-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  margin-left:8px;padding:10px 30px;font-size:.78rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;text-decoration:none;
  border:1.5px solid var(--blue-x);border-radius:var(--pill);color:#fff;
  background:var(--blue-x);transition:background .2s, color .2s, border-color .2s;
}
.topnav__menu .lang-toggle:hover{background:#fff;border-color:#fff;color:var(--blue-x)}
.topnav--ink .lang-toggle{background:var(--cyan-x);border-color:var(--cyan-x);color:var(--blue-x)}
.topnav--ink .topnav__menu .lang-toggle:hover{background:#fff;border-color:#fff;color:var(--blue-x)}

/* ---------- Buttons --------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;font-size:.78rem;
  padding:13px 26px;border-radius:var(--pill);
  border:1.5px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .2s, color .2s, border-color .2s;
}
.btn:hover{transform:translateY(-1px)}
.btn--cyan{background:var(--cyan-x);color:var(--blue-x)}
.btn--cyan:hover{background:#23d2ff;color:var(--blue-x)}
.btn--navy{background:var(--blue-x);color:#fff}
.btn--navy:hover{background:var(--blue-xg);color:#fff}
.btn--ghost{background:transparent;color:#fff;border-color:#fff}
.btn--ghost:hover{background:#fff;color:var(--blue-x)}
.btn--ghost-dark{background:transparent;color:var(--blue-x);border-color:var(--blue-x)}
.btn--ghost-dark:hover{background:var(--blue-x);color:#fff}
.btn .arrow{display:inline-block;transform:translateY(-1px)}
.btn--disabled{
  opacity:.65;
  cursor:not-allowed;
  pointer-events:none;
  filter:saturate(.55);
}
.btn--disabled:hover{transform:none}
.btn__badge{
  display:inline-block;
  margin-left:10px;
  padding:3px 8px;
  font-size:.62rem;
  letter-spacing:.18em;
  background:rgba(0,30,87,.18);
  color:var(--blue-x);
  border-radius:3px;
  font-weight:700;
}
.btn .arrow::after{content:"›";font-size:1.2em;line-height:1}

/* ---------- Hero (signature arrow-cut) -------------------------------- */
/* NOTE: do NOT add isolation:isolate here — it creates a stacking context
   that traps the .topnav (which is rendered inside the hero) and lets later
   sections paint over the fixed nav. */
.hero{
  position:relative;color:#fff;
  min-height:720px;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero--cyan-right{background:var(--cyan-x)}
.hero--ink-right{background:var(--blue-x)}
.hero--cyan-left{background:var(--cyan-x)}
.hero__photo{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  /* Default: photo on the left, chevron points right into cyan.
     Tip pulled back from 100% so it doesn't touch the right border. */
  clip-path:polygon(0 0, 76% 0, 96% 50%, 76% 100%, 0 100%);
  z-index:1;
}
.hero--right .hero__photo{
  /* photo on the right, chevron points left into cyan; tip pulled back from 0%. */
  clip-path:polygon(24% 0, 100% 0, 100% 100%, 24% 100%, 4% 50%);
}
.hero__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,15,46,.78) 0%, rgba(0,15,46,.45) 45%, rgba(0,15,46,.05) 75%);
}
.hero--right .hero__photo::after{
  background:linear-gradient(270deg, rgba(0,15,46,.78) 0%, rgba(0,15,46,.45) 45%, rgba(0,15,46,.05) 75%);
}
.hero__inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;
  padding:152px var(--gutter) 75px;width:100%;
}
.hero__copy{max-width:640px}
.hero--right .hero__copy{margin-left:auto;text-align:right}
.hero h1{color:#fff;margin-bottom:.55em}
.hero p{font-size:1.15rem;color:#eaf3ff;max-width:52ch;margin-bottom:1.6em}
.hero--right p{margin-left:auto}
.hero p.hero__sub{font-family:var(--font-display);font-weight:700;font-size:1.24rem;letter-spacing:.02em;margin-bottom:1.4em;color:var(--cyan-x);max-width:none;white-space:nowrap}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero--right .hero__cta{justify-content:flex-end}

/* Project hero: centered with badge-left + name-center top row */
.hero--center{text-align:center}
.hero-project{min-height:700px;align-items:flex-start}
/* Badge aligned with logo (left gutter), vertically aligned with project name line */
.hero-project .hero-badge--anchor{
  position:absolute;
  left:var(--gutter);
  top:157px; /* aligns with the Guatemala eyebrow line */
  transform:none;
}
/* Shift just the Watch Video button left to sit over the tracks vanishing point.
   Adjust this value to dial in exact position. */
.hero-project .hero__cta{transform:translate(-24px, 30px)}
/* Vignette overlay: lightens the tracks area (bottom-center) while keeping edges darker for text contrast */
.hero-project .hero__photo::after{
  background:
    radial-gradient(ellipse 60% 50% at 50% 70%, rgba(0,15,46,0) 0%, rgba(0,15,46,.10) 50%, rgba(0,15,46,.35) 100%),
    linear-gradient(180deg, rgba(0,15,46,0) 0%, rgba(0,15,46,.02) 60%, rgba(0,15,46,.03) 100%);
}
.hero-project + .section--tight{padding-top:clamp(34px,4vw,52px)}
.hero__inner--center .hero__copy--center{max-width:920px;margin:0 auto;text-align:center}
.hero-top{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:48px;margin-bottom:12px;
}
.hero-badge{
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  display:inline-block;font-family:var(--font-display);font-weight:600;
  font-size:.92rem;letter-spacing:.22em;text-transform:uppercase;
  color:#fff;padding:10px 20px;
  border:1px solid rgba(255,255,255,.55);border-radius:2px;
}
.hero .hero__name{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.4rem,2.2vw,1.8rem);
  color:rgba(255,255,255,.92);
  letter-spacing:.01em;margin:0;max-width:none;line-height:1.25;
  transform:translateY(10px);
}
.hero-flourish{
  display:block;margin:0 auto 26px;
  width:48px;height:1px;background:var(--cyan-x);opacity:.7;
}
.hero__sub--center{margin-left:auto;margin-right:auto;max-width:60ch;white-space:normal}
@media (max-width:720px){
  .hero-top{flex-direction:column;gap:14px}
  .hero-badge{position:static;transform:none}
}

/* Project body: centered editorial copy */
.proj-center{
  max-width:820px;margin:0 auto;text-align:left;
}
.proj-center h2{margin:28px 0 24px}
.proj-center p{font-size:1.02rem;line-height:1.8;color:#3a4670;margin:0 0 1.2em}
.proj-center p:last-child{margin-bottom:0}
.proj-center strong{color:var(--blue-x);font-weight:700}

/* Left-rail editorial variant — aligned under logo */
.proj-left{
  max-width:none;
  margin:0;
  text-align:left;
}
.proj-left .eyebrow{display:block;margin-bottom:28px}
.proj-left h2{
  margin:0 0 28px;
  max-width:20ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.proj-left p{
  max-width:54ch;
  font-size:1.02rem;line-height:1.8;color:#3a4670;
  margin:0 0 1.2em;
}
.proj-left p:last-child{margin-bottom:0}
.proj-left strong{color:var(--blue-x);font-weight:700}

/* ---------- Partnership section: left-rail head + 3 partner cards ---------- */
.partnership-feature{
  padding:clamp(72px,8vw,112px) 0;
  background:linear-gradient(180deg, #f4f7fb 0%, #eef2f8 100%);
  border-top:1px solid rgba(0,30,87,.06);
}
.partnership-head{
  max-width:1080px;
  margin:0;
  text-align:left;
}
.partnership-head .eyebrow{display:block;margin-bottom:28px}
.partnership-head h2{
  margin:0 0 22px;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.partnership-lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0;
  max-width:96ch;
  text-wrap:balance;
  hyphens:none;
}
.partnership-lead strong{color:var(--blue-x);font-weight:700}

.partners-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:clamp(20px,2.5vw,36px);
  margin-top:clamp(40px,5vw,64px);
}
.partners-grid--two{
  grid-template-columns:repeat(2, minmax(0,1fr));
  max-width:920px;
  margin-left:auto;
  margin-right:auto;
}

/* Partner rows — horizontal dossier layout */
.partner-rows{
  margin:clamp(20px,2.5vw,32px) 0 0;
  max-width:1000px;
  border-top:1px solid rgba(0,30,87,.10);
}
.partner-row{
  display:flex;
  flex-direction:column;
  gap:clamp(14px,1.6vw,20px);
  padding:clamp(28px,3.2vw,42px) 0;
  border-bottom:1px solid rgba(0,30,87,.10);
}
.partner-row__head{
  display:flex;
  align-items:center;
  gap:clamp(17px,1.6vw,23px);
}
.partner-row__body{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr);
  gap:clamp(9px,1.3vw,20px);
  align-items:start;
  max-width:96%;
}
.partner-row__title{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.partner-row__num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(1.9rem,2.7vw,2.4rem);
  line-height:1;
  letter-spacing:-.02em;
  color:var(--blue-x);
  opacity:.85;
}
.partner-row__chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:24px;
  padding:0 8px;
  border:1px solid rgba(0,30,87,.20);
  border-radius:3px;
  background:rgba(0,30,87,.04);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.16em;
  color:var(--blue-x);
}
.partner-row__name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.4rem,1.95vw,1.75rem);
  line-height:1.2;
  letter-spacing:-.012em;
  color:var(--ink);
  margin:0;
  text-wrap:balance;
  max-width:22ch;
}
.partner-row__abbr{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#6e798f;
}
.partner-row__role{
  font-size:1.02rem;
  line-height:1.65;
  color:#374055;
  margin:0;
  text-align:justify;
  text-justify:inter-word;
  hyphens:none;
}
@media (max-width:820px){
  .partner-row{
    grid-template-columns:1fr;
    gap:18px;
    padding:28px 0;
  }
  .partner-row__num{font-size:1.7rem}
}
.partner-card{
  position:relative;
  display:flex;
  flex-direction:column;
  padding:clamp(20px,2.2vw,32px);
  background:#fff;
  border:1px solid rgba(0,30,87,.08);
  border-radius:14px;
  box-shadow:0 6px 20px -12px rgba(0,30,87,.18);
  transition:transform .2s ease, box-shadow .25s ease, border-color .25s ease;
}
.partner-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 36px -16px rgba(0,30,87,.28);
  border-color:rgba(0,195,250,.35);
}
.partner-card::before{
  content:"";
  position:absolute;
  top:0;left:24px;right:24px;
  height:3px;
  background:linear-gradient(90deg, var(--cyan-x), var(--blue-xg));
  border-radius:0 0 3px 3px;
}
.partner-card__tag{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.68rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue-xg);
  margin-bottom:14px;
}
.partner-card__abbr{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(1.5rem,2.3vw,1.95rem);
  letter-spacing:-.01em;
  color:var(--blue-x);
  margin:0 0 6px;
  line-height:1;
}
.partner-card__name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.95rem;
  color:var(--blue-x);
  margin:0 0 14px;
  line-height:1.3;
}
.partner-card__sub{font-size:.82rem;font-weight:500;color:#6e798f;letter-spacing:.01em}
.partner-card__role{
  font-size:.9rem;line-height:1.6;color:#3a4670;
  margin:0;
}
@media (max-width:820px){
  .partners-grid{grid-template-columns:1fr;gap:18px}
}

/* ---------- Strategic Impact section: 3 numbered impact cards ---------- */
.strategic-impact{
  padding:clamp(72px,8vw,112px) 0;
}
.strategic-impact__head{
  max-width:760px;
  margin:0 0 clamp(40px,5vw,64px);
  text-align:left;
}
.strategic-impact__head .eyebrow{display:block;margin-bottom:28px}
.strategic-impact__head h2{
  margin:0 0 22px;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.strategic-impact__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0;
  max-width:54ch;
  text-wrap:balance;hyphens:none;
}
.strategic-impact__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:clamp(20px,2.5vw,36px);
}
.impact-card{
  position:relative;
  display:flex;
  flex-direction:column;
  padding:clamp(28px,3vw,40px);
  background:linear-gradient(180deg, #fff 0%, #f6f9fd 100%);
  border-radius:8px;
  border:1px solid rgba(0,30,87,.06);
  box-shadow:0 8px 24px -12px rgba(0,30,87,.18);
  transition:transform .25s ease, box-shadow .25s ease;
}
.impact-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 42px -16px rgba(0,30,87,.28);
}
.impact-card__num{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(2.6rem,3.6vw,3.4rem);
  letter-spacing:-.04em;
  line-height:1;
  background:linear-gradient(135deg, var(--cyan-x) 0%, var(--blue-xg) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:var(--blue-xg);
  margin-bottom:18px;
  display:inline-block;
}
.impact-card__chev{display:none}
.impact-card__title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.18rem;
  color:var(--blue-x);
  margin:0 0 12px;
  line-height:1.25;
  letter-spacing:-.01em;
}
.impact-card__body{
  font-size:.96rem;line-height:1.7;color:#3a4670;
  margin:0;
}
@media (max-width:820px){
  .strategic-impact__grid{grid-template-columns:1fr;gap:18px}
}


/* ---------- Trade Routes section: blue map showing global shipping lanes ---------- */
.trade-routes{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:#001233;
  color:#fff;
  padding:clamp(72px,8vw,112px) 0 clamp(90px,9.5vw,133px);
}
/* Subtle radial backdrop behind the headline area for depth */
.trade-routes__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 22% 22%, rgba(0,195,250,.08) 0%, rgba(0,195,250,0) 60%),
    radial-gradient(ellipse 60% 50% at 78% 80%, rgba(0,49,155,.18) 0%, rgba(0,49,155,0) 60%);
  z-index:0;
  pointer-events:none;
}
.trade-routes__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
  position:relative;
  z-index:2;
}
.trade-routes__head{
  max-width:760px;
  margin:0 0 clamp(40px,4.5vw,60px);
}
.trade-routes__eyebrow{
  display:block;
  margin-bottom:28px;
  color:var(--cyan-x) !important;
}
.trade-routes h2{
  margin:0 0 22px;
  color:#fff;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
  text-shadow:0 2px 18px rgba(0,8,28,.4);
}
.trade-routes__lead{
  font-size:1.04rem;line-height:1.78;color:#cfdcf6;
  margin:0;
  max-width:54ch;
  text-wrap:balance;hyphens:none;
}
/* Map wrapper: full-bleed with vignette + bottom fade for graceful exit */
.trade-routes__map-wrap{
  position:relative;
  width:100vw;
  margin:clamp(56px,6vw,84px) calc(50% - 50vw) clamp(20px,2.4vw,32px);
  z-index:1;
  overflow:hidden;
}
.trade-routes__map{
  position:relative;
  width:100%;
  height:clamp(345px,38.5vw,520px);
  background-size:cover;
  background-position:center 48%;
  background-repeat:no-repeat;
}
/* Side fade so the cropped map edges blend into the section bg */
.trade-routes__map-wrap::before,
.trade-routes__map-wrap::after{
  content:"";
  position:absolute;
  top:0;bottom:0;
  width:clamp(24px,3.5vw,60px);
  pointer-events:none;
  z-index:2;
}
.trade-routes__map-wrap::before{
  left:0;
  background:linear-gradient(90deg, #001233 0%, rgba(0,18,51,0) 100%);
}
.trade-routes__map-wrap::after{
  right:0;
  background:linear-gradient(270deg, #001233 0%, rgba(0,18,51,0) 100%);
}
/* Subtle vignette on the map for depth */
.trade-routes__map::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 80% 70% at 50% 50%, transparent 65%, rgba(0,18,51,.18) 100%);
  pointer-events:none;
}


/* Animated trade-route flow: cyan glow pulses along the white routes */
.trade-routes__flow{
  position:absolute;
  inset:0;
  pointer-events:none;
  /* Bright cyan tint, masked to ONLY appear where the routes are */
  background-color: #00e5ff;
  -webkit-mask-position: center 43%;
  mask-position: center 43%;
  -webkit-mask-size: cover;
  mask-size: cover;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  filter: drop-shadow(0 0 6px rgba(0,229,255,.85));
  animation: tr-flow 3.4s ease-in-out infinite;
  z-index:2;
  opacity:0;
}
@keyframes tr-flow{
  0%, 100% { opacity: 0; }
  50%      { opacity: .85; }
}
@media (prefers-reduced-motion: reduce){
  .trade-routes__flow{ animation:none; opacity:0; }
}

/* Soft fade at the bottom of the map so it transitions cleanly into stats */
.trade-routes__map-fade{display:none}
/* Bottom inner: stats row */
.trade-routes__inner--bottom{
  margin-top:0;
}
.trade-routes__stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(24px,3vw,48px);
  border-top:1px solid rgba(0,195,250,.18);
  padding-top:clamp(28px,3vw,40px);
}
.tr-stat{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
.tr-stat__num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2.1rem,3.42vw,3.04rem);
  letter-spacing:-.03em;
  line-height:1;
  background:linear-gradient(135deg, #fff 0%, var(--cyan-x) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:#fff;
}

.tr-stat__lbl{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  line-height:1.4;
}
.tr-stat__lbl em{
  display:block;
  font-style:normal;
  font-weight:400;
  font-size:.59rem;
  letter-spacing:.06em;
  color:#7eb6e6;
  margin-top:6px;
  white-space:nowrap;
}
@media (max-width:820px){
  .trade-routes__map{height:clamp(260px,55vw,360px);background-position:center}
  .trade-routes__stats{grid-template-columns:1fr;gap:24px}
  .tr-stat{padding-bottom:18px;border-bottom:1px solid rgba(0,195,250,.12)}
  .tr-stat:last-child{border-bottom:none}
}

/* Trade Routes: mid-page CTA strip (after closer paragraph) */
.trade-routes__cta{
  margin:clamp(44px,4.6vw,66px) auto 0;
  max-width:60ch;
  text-align:center;
}
.trade-routes__cta-eyebrow{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#fff;
  margin-bottom:14px;
}
.trade-routes__cta-line{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(.96rem,1.2vw,1.1rem);
  line-height:1.5;
  color:#cfdcf6;
  margin:0 0 22px;
}

/* Trade Routes: closing statement (former Strategic Impact merge) */
.trade-routes__closer{
  margin:clamp(32px,3.4vw,48px) auto 0;
  max-width:96ch;
  padding-top:clamp(22px,2.4vw,32px);
  border-top:1px solid rgba(0,195,250,.18);
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(1.03rem, 1.35vw, 1.24rem);
  line-height:1.55;
  color:#cfdcf6;
  text-align:center;
  letter-spacing:-.005em;
  text-wrap:balance;
}
.trade-routes__closer strong{
  color:var(--cyan-x);
  font-weight:600;
}
@media (max-width:820px){
  .trade-routes__closer{text-align:left}
}

/* Trade Routes: pinpoint marker + legend overlays */
.trade-routes__pin{
  position:absolute;
  left:50.5%;
  top:66.8%;
  width:0;height:0;
  z-index:3;
  pointer-events:none;
}
.trade-routes__pin-dot{
  position:absolute;
  left:-7px;top:-7px;
  width:14px;height:14px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.35), 0 0 18px 4px rgba(255,255,255,.55);
  z-index:2;
}
.trade-routes__pin-pulse{
  position:absolute;
  left:-7px;top:-7px;
  width:14px;height:14px;
  border-radius:50%;
  background:rgba(0,229,255,.78);
  box-shadow:0 0 17px 4px rgba(0,229,255,.38);
  z-index:1;
  animation:tr-pulse 2.1s ease-out infinite;
}
@keyframes tr-pulse{
  0%   { transform:scale(1);   opacity:.78; }
  60%  { opacity:.32; }
  100% { transform:scale(6);   opacity:0;   }
}
.trade-routes__pin-stem{
  position:absolute;
  left:-0.75px;
  bottom:0;
  width:1.5px;
  height:64px;
  background:linear-gradient(180deg, rgba(0,229,255,0) 0%, rgba(0,229,255,.85) 60%, #fff 100%);
  z-index:1;
  pointer-events:none;
}
.trade-routes__pin-chevron{
  position:absolute;
  left:-7px;
  bottom:60px;
  width:14px;
  height:11px;
  background:var(--cyan-x);
  /* Brand pentagon arrow pointing DOWN (rotated from the right-pointing version) */
  clip-path:polygon(50% 100%, 0 40%, 0 0, 100% 0, 100% 40%);
  filter:drop-shadow(0 0 6px rgba(0,229,255,.6));
  z-index:2;
}

.trade-routes__pin-label{
  position:absolute;
  left:14px;
  top:-78px;
  white-space:nowrap;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fff;
  line-height:1.35;
  text-shadow:0 1px 8px rgba(0,8,28,.85), 0 0 14px rgba(0,8,28,.7);
}
/* Legend in bottom-left of map */
.trade-routes__legend{
  position:absolute;
  left:clamp(290px,28vw,420px);
  bottom:clamp(16px,2.4vw,36px);
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:14px 18px;
  background:rgba(0,18,51,.62);
  border:1px solid rgba(0,195,250,.22);
  border-radius:8px;
  backdrop-filter:saturate(140%) blur(6px);
  -webkit-backdrop-filter:saturate(140%) blur(6px);
  z-index:3;
  pointer-events:none;
}
.trade-routes__legend-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#cfdcf6;
  line-height:1;
}
.trade-routes__legend-key{
  display:inline-block;
  width:38px;
  height:4px;
  flex-shrink:0;
  border-radius:2px;
}
.trade-routes__legend-key--solid{
  background:#fff;
}
.trade-routes__legend-key--dashed{
  background-image:linear-gradient(to right, #fff 0, #fff 10px, transparent 10px, transparent 16px);
  background-size:16px 4px;
  background-repeat:repeat-x;
  background-position:left center;
}
@media (max-width:820px){
  .trade-routes__pin-label{font-size:.66rem;left:14px}
  .trade-routes__legend{padding:10px 12px;left:32px;bottom:12px}
  .trade-routes__legend-item{font-size:.66rem;letter-spacing:.1em}
  .trade-routes__legend-key{width:22px}
}




/* Cinematic corridor section: immersive photo with editorial text overlay */
.corridor-feature{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  padding:clamp(72px,8vw,112px) 0;
  background:#001233;
  scroll-margin-top:clamp(150px,17vh,200px);
}
.corridor-feature__photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center 38%;
  z-index:0;
  filter:saturate(1.18) brightness(.96) contrast(1.06);
}
.corridor-feature__scrim{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(0,18,51,.78) 0%, rgba(0,18,51,.66) 30%, rgba(0,18,51,.32) 55%, rgba(0,18,51,.04) 88%, rgba(0,18,51,0) 100%),
    linear-gradient(180deg, rgba(0,18,51,.22) 0%, rgba(0,18,51,0) 22%, rgba(0,18,51,0) 80%, rgba(0,18,51,.30) 100%);
  pointer-events:none;
}
.corridor-feature__chev{
  position:absolute;
  top:50%;
  left:-1px;
  transform:translateY(-50%);
  width:clamp(150px,13vw,216px);
  height:clamp(320px,32vw,440px);
  background:linear-gradient(135deg, var(--cyan-x) 0%, #0aa6d6 70%, #0892bf 100%);
  /* Stout pyramid — tall base on left, gentle apex on right */
  clip-path:polygon(0 0, 100% 50%, 0 100%);
  z-index:3;
  pointer-events:none;
  filter:drop-shadow(0 14px 40px rgba(0,195,250,.4));
}
.corridor-feature__wrap{
  position:relative;
  z-index:3;
}
.corridor-feature__text{
  position:relative;
  max-width:560px;
  color:#fff;
}
.corridor-feature__eyebrow{
  position:relative;
  z-index:1;
  display:block;
  color:var(--cyan-x) !important;
  margin-bottom:28px;
}
.corridor-feature h2{
  position:relative;
  z-index:1;
  color:#fff;
  margin:0 0 24px;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
  text-shadow:0 2px 18px rgba(0,8,28,.35);
}
.corridor-feature p{
  position:relative;
  z-index:1;
  color:rgba(255,255,255,.94);
  font-size:1.04rem;
  line-height:1.78;
  margin:0 0 1.2em;
  max-width:54ch;
  text-shadow:0 1px 6px rgba(0,8,28,.35);
}
.corridor-feature p:last-child{margin-bottom:0}
.corridor-feature strong{color:var(--cyan-x);font-weight:700}
@media (max-width:820px){
  .corridor-feature{padding:clamp(56px,9vw,80px) 0}
  .corridor-feature__scrim{
    background:linear-gradient(180deg, rgba(0,18,51,.85) 0%, rgba(0,18,51,.78) 60%, rgba(0,18,51,.95) 100%);
  }
  .corridor-feature__text{max-width:none}
}


/* Variant: deep gradient hero (no photo) — used on Contact */
.hero--gradient{background:var(--cyan-x);color:#fff}
.hero--gradient .hero__photo{background:var(--blue-x);clip-path:polygon(38% 0, 100% 0, 100% 100%, 38% 100%, 18% 50%);}
.hero--gradient .hero__photo::after{background:none}

@media (max-width:820px){
  .hero{min-height:520px}
  .hero__photo{clip-path:polygon(0 0,100% 0,100% 86%,0 100%)}
  .hero--right .hero__photo{clip-path:polygon(0 0,100% 0,100% 100%,0 86%)}
  .hero--right .hero__copy{margin-left:0;text-align:left}
  .hero--right p{margin-left:0}
  .hero--right .hero__cta{justify-content:flex-start}
}

/* ---------- Chevron-flanked headings (mirrors live `creamox-titulo-flechas`) -- */
.h-flechas, .h-flecha-izq, .h-flecha-der, .h-flechas-xl{
  display:inline-flex;align-items:center;gap:18px;justify-content:center;text-align:left;
}
.h-flechas::before, .h-flechas::after,
.h-flecha-izq::before,
.h-flecha-der::after,
.h-flechas-xl::before, .h-flechas-xl::after{
  content:"";display:inline-block;flex:0 0 auto;
  width:30px;height:30px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><path d='M8 4 L24 16 L8 28 Z' fill='%2300c3fa'/></svg>");
  background-repeat:no-repeat;background-position:center;background-size:contain;
}
.h-flechas::before, .h-flechas-xl::before, .h-flecha-izq::before{transform:scaleX(-1)}
.h-flechas-xl::before, .h-flechas-xl::after{width:48px;height:48px}
.section--ink .h-flechas::before, .section--ink .h-flechas::after,
.section--ink .h-flecha-izq::before,
.section--ink .h-flecha-der::after{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><path d='M8 4 L24 16 L8 28 Z' fill='%2367d8fb'/></svg>");
}
.h-flechas-row{display:flex;justify-content:center}

/* ---------- Embedded hero quote card (e.g. JPMorgan stat) ----------- */
.hero-quote{
  position:relative;
  display:block;max-width:480px;
  margin:1.6em 0 1.4em;
  padding:18px 22px 20px;
  border-radius:14px;
  border:1px solid rgba(0,195,250,.32);
  background:linear-gradient(145deg, rgba(0,30,87,.55), rgba(0,15,46,.45));
  backdrop-filter:saturate(140%) blur(6px);
  -webkit-backdrop-filter:saturate(140%) blur(6px);
  box-shadow:0 18px 40px -16px rgba(0,30,87,.55);
  overflow:hidden;
  text-align:left;
}
.hero-quote::before{
  content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;
  background:var(--cyan-x);border-radius:0 3px 3px 0;
}
.hero-quote__big{
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(1.6rem,2.6vw,2.1rem);
  letter-spacing:-.02em;
  line-height:1;
  color:var(--cyan-x);
  margin-bottom:.45em;
}
.hero-quote__text{
  font-size:.95rem;line-height:1.45;
  color:#fff;font-style:italic;
  margin:0 0 .8em;font-weight:300;
}
.hero-quote__rule{
  width:32px;height:2px;background:var(--cyan-x);
  border-radius:2px;margin:0 0 8px;
}
.hero-quote__source{
  font-family:var(--font-display);
  font-size:.72rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:#cfdcf6;
}

/* ---------- Pull-quote with chevrons --------------------------------- */
.pullquote{
  display:flex;gap:24px;align-items:center;justify-content:center;
  text-align:left;max-width:920px;margin:0 auto;
}
.pullquote__text{
  font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,1.8vw,1.35rem);
  color:var(--blue-x);max-width:60ch;line-height:1.4;
}
.pullquote__chev{color:var(--cyan-x);font-size:2.2rem;line-height:1;font-weight:900;font-family:var(--font-display)}
.pullquote__chev--l::before{content:"‹"}
.pullquote__chev--r::before{content:"›"}
.pullquote__sub{margin-top:14px;color:#3a4670;font-size:1rem}

/* ---------- Stats grid ----------------------------------------------- */
.stats{
  background:var(--grad-blue);color:#fff;
  border-radius:18px;
  padding:40px clamp(20px,3vw,48px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:left;
  box-shadow:var(--shadow-2);
}
.stats .stat__num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,3.4vw,2.6rem);letter-spacing:-.02em}
.stats .stat__lbl{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;opacity:.92}
@media (max-width:820px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Feature cards (image + text) — single column, alternating sides ----------------------------- */
.features{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(22px,2.8vw,42px);
  margin-top:clamp(30px,3.5vw,52px);
}
.feature{
  max-width:950px;
  margin:0 auto;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
  box-shadow:0 16px 44px -18px rgba(0,30,87,.20);
  border:1px solid rgba(0,30,87,.06);
  min-height:clamp(195px,21.5vw,282px);
}
.feature:nth-child(even) > .feature__img{ order:2 }
.feature__img{
  position:relative;
  background-size:cover;
  background-position:center;
  min-height:clamp(195px,21.5vw,282px);
}
.feature__img::after{
  /* chevron edge pointing into text on image-left features */
  content:"";position:absolute;top:0;right:-1px;bottom:0;width:38px;
  background:#fff;clip-path:polygon(100% 0, 0 50%, 100% 100%);
}
.feature:nth-child(even) > .feature__img::after{
  /* mirrored for image-right features */
  right:auto;left:-1px;
  width:38px;
  clip-path:polygon(0 0, 100% 50%, 0 100%);
}
.feature__body{
  padding:clamp(20px,2.2vw,36px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.feature__kicker{
  font-family:var(--font-display);font-weight:700;
  color:var(--cyan-x);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  margin-bottom:14px;
  display:block;
}
.feature__body h3{
  color:var(--blue-x);
  font-size:clamp(1.2rem,1.5vw,1.4rem);
  margin:0 0 .55em;
  line-height:1.15;
  letter-spacing:-.018em;
}
.feature__body p{
  color:#3a4670;
  margin:0;
  font-size:1rem;
  line-height:1.78;
  max-width:54ch;
}
@media (max-width:820px){
  .feature{grid-template-columns:1fr}
  .feature:nth-child(even) > .feature__img{order:0}
  .feature__img{min-height:240px}
  .feature__img::after,
  .feature:nth-child(even) > .feature__img::after{display:none}
}

/* ---------- Bullet list with chevron --------------------------------- */
.chev-list{list-style:none;padding:0;margin:0}
.chev-list li{position:relative;padding:6px 0 6px 28px}
.chev-list li::before{
  content:"";position:absolute;left:0;top:14px;
  width:14px;height:14px;
  background:var(--cyan-x);
  clip-path:polygon(0 0, 60% 0, 100% 50%, 60% 100%, 0 100%, 40% 50%);
}

/* ---------- Value cards (Investing/Total/Risk style) ----------------- */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:820px){.value-grid{grid-template-columns:1fr}}
.value-card{
  position:relative;color:#fff;
  padding:28px 26px 30px;
  border-radius:14px;
  background:var(--blue-x);
  overflow:hidden;
  min-height:340px;
}
.value-card--mid{background:var(--blue-xg)}
.value-card--cyan{background:var(--cyan-x);color:var(--blue-x)}
.value-card h3{font-size:1.4rem;margin-bottom:0;color:inherit}
.value-card .value-card__top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
  margin-bottom:8px;
}
.value-card .chev{color:#fff;font-size:1.6rem;font-weight:900;font-family:var(--font-display);line-height:1}
.value-card--cyan .chev{color:var(--blue-x)}
.value-card .value-card__sub{font-family:var(--font-display);font-weight:600;font-size:.92rem;opacity:.92;margin:14px 0 18px;letter-spacing:.02em}
.value-card h4{margin:14px 0 4px;font-family:var(--font-display);font-size:.98rem;letter-spacing:.02em}
.value-card p{font-size:.9rem;line-height:1.55;margin:0 0 8px;opacity:.93}

/* ---------- Photo grid (COINGT-style 2x3) ---------------------------- */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:820px){.photo-grid{grid-template-columns:1fr}}
.photo-card{
  position:relative;border-radius:14px;overflow:hidden;
  min-height:240px;background-size:cover;background-position:center;color:#fff;
  display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:var(--shadow-1);
}
.photo-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,30,87,.05) 30%, rgba(0,30,87,.85) 100%);
}
.photo-card__body{position:relative;padding:18px 20px}
.photo-card h3{color:#fff;margin-bottom:.25em;font-size:1.25rem}
.photo-card p{margin:0;font-size:.9rem;color:#dbe6f7;line-height:1.5}

/* ---------- About: values strip --------------------------------------- */
.values{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media (max-width:980px){.values{grid-template-columns:repeat(2,1fr)}}
.values__card{
  background:var(--blue-x);color:#fff;border-radius:12px;padding:20px;
}
.values__card h3{color:#fff;font-size:1.02rem;margin-bottom:.4em}
.values__card p{font-size:.86rem;color:#e6edff;margin:0;line-height:1.5}

/* ---------- Team --------------------------------------------------- */
.team{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.team__card{
  text-align:left;padding:14px 22px 16px;min-width:220px;
  border:1.5px solid var(--blue-x);border-radius:var(--pill);
  transition:background .18s,border-color .18s;
}
.team__card a{color:var(--blue-x);font-family:var(--font-display);font-weight:700;letter-spacing:.04em;display:block;font-size:1rem}
.team__card span{color:#3a4670;font-size:.8rem;letter-spacing:.06em}
.team__card:hover{background:var(--blue-x)}
.team__card:hover a{color:#fff}
.team__card:hover span{color:#9ec5ff}
/* Dark-section variant — used inside .section--ink */
.section--ink .team__card{border-color:#fff;background:rgba(255,255,255,.04)}
.section--ink .team__card a{color:#fff}
.section--ink .team__card span{color:#9ec5ff}
.section--ink .team__card:hover{background:#fff}
.section--ink .team__card:hover a{color:var(--blue-x)}
.section--ink .team__card:hover span{color:#3a4670}
.team__advisor{margin-top:14px}

/* ---------- Partners ---------------------------------------------- */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:center}
@media (max-width:820px){.partners{grid-template-columns:1fr}}
.partners__item{text-align:left;padding:24px;border:1px solid var(--line);border-radius:14px;background:#fff}
.partners__item .label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-x);font-weight:700;margin-bottom:8px}
.partners__item .name{font-family:var(--font-display);font-weight:700;color:var(--blue-x);font-size:1.05rem}

/* ---------- Bio (team detail) -------------------------------------- */
.bio{display:grid;grid-template-columns:1.1fr 1.4fr;gap:48px;align-items:start}
@media (max-width:820px){.bio{grid-template-columns:1fr;gap:24px}}
.bio__avatar{
  background:var(--grad-blue);border-radius:18px;color:#fff;padding:32px;min-height:300px;
  display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden;
}
.bio__avatar::after{
  content:"";position:absolute;right:-30px;top:-30px;width:160px;height:160px;
  background:var(--cyan-x);opacity:.32;
  clip-path:polygon(0 0, 60% 0, 100% 50%, 60% 100%, 0 100%, 40% 50%);
}
.bio__avatar h1{color:#fff;margin-bottom:.25em}
.bio__avatar .role{font-family:var(--font-display);font-weight:600;letter-spacing:.06em;opacity:.95}
.bio__body p{margin-bottom:1.1em;color:#3a4670}

/* ---------- Contact form ------------------------------------------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:28px}}
.form{display:grid;gap:14px}
.form .field label{
  display:block;font-family:var(--font-display);font-weight:600;
  font-size:.82rem;letter-spacing:.08em;color:#fff;margin-bottom:6px;
}
.form .field input,
.form .field textarea,
.form .field select{
  width:100%;background:#fff;border:0;border-radius:6px;
  padding:12px 14px;font:inherit;color:var(--blue-x);
}
.form .field input:focus,
.form .field textarea:focus{outline:3px solid #fff7;outline-offset:2px}
.form textarea{min-height:110px;resize:vertical}
.form .submit-row{margin-top:8px}
.contact-info{color:#fff}
.contact-info .row{margin-bottom:14px}
.contact-info a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4)}
.contact-info .city{font-family:var(--font-display);font-weight:700;letter-spacing:.04em;font-size:1rem;margin-bottom:2px}
.contact-info .addr{font-size:.92rem;opacity:.9;line-height:1.5}


/* ---------- Footer -------------------------------------------------- */
.footer{
  background:linear-gradient(180deg,#0a1632 0%, #050b1d 100%);
  color:#cfd7e8;padding:24px var(--gutter) 28px;margin-top:0;
}
.footer__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:28px;
  align-items:start;
}
@media (max-width:820px){.footer__inner{grid-template-columns:1fr 1fr;gap:24px}}
.footer__logo{width:140px;margin-bottom:10px}
.footer__dropdown-title{display:block;color:#fff;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;margin-bottom:10px}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin-bottom:5px}
.footer ul li a{color:#cfd7e8;font-size:.9rem}
.footer ul li a:hover{color:var(--cyan-x)}
.footer__contact .pill{display:inline-flex;align-items:center;gap:6px;background:var(--cyan-x);color:var(--blue-x);font-family:var(--font-display);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;padding:8px 16px;border-radius:var(--pill);margin-bottom:10px}
.footer__contact .email{color:#fff;font-size:.9rem;display:block;margin-bottom:12px}
.footer__social{display:flex;gap:10px}
.footer__social a{
  display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;
  border:1.5px solid #fff;color:#fff;
}
.footer__social a:hover{background:#fff;color:var(--blue-x)}
.footer__disclaimer{
  max-width:80ch;margin:18px auto 0;padding-top:14px;
  font-size:.7rem;line-height:1.6;color:#7283a8;
  text-align:center;
  text-wrap:balance;
}
.footer__bottom{
  max-width:var(--max);margin:14px auto 0;padding-top:0;
  border-top:none;
  font-size:.78rem;color:#8d99b6;text-align:left;
}

/* ---------- Diagram (advantage hub) -------------------------------- */
.advantage{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;
}
@media (max-width:980px){.advantage{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.advantage{grid-template-columns:1fr}}
.advantage__card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:20px 22px;color:#3a4670;font-size:.92rem;line-height:1.55;
}
.advantage__card .head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.advantage__card .head h3{margin:0;font-size:1rem;color:var(--blue-x)}
.advantage__card .head .chev{color:var(--cyan-x);font-weight:900;font-family:var(--font-display)}
.advantage__hub{
  grid-column:1/-1;
  background:var(--grad-blue);
  border-radius:14px;color:#fff;padding:30px;text-align:left;
  margin:6px 0;
}
.advantage__hub h3{color:#fff;font-size:1.6rem;letter-spacing:.04em}
.advantage__hub p{margin:0;color:#eaf3ff}

/* ---------- Tiny utilities ---------------------------------------- */
.center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.mt-2{margin-top:16px}
.mt-4{margin-top:32px}
.mt-6{margin-top:48px}
.muted{color:#3a4670}
.divider{border:0;height:1px;background:var(--line);margin:48px 0}
.tag-pill{display:inline-block;font-family:var(--font-display);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;background:var(--cyan-x);color:var(--blue-x);padding:6px 14px;border-radius:var(--pill)}

/* ---------- Print --------------------------------------------------- */
@media print{
  .topnav,.footer{display:none}
  body{background:#fff;color:#000}
}
/* ---------- How We Operate (left-aligned, premium cards) ---------- */
.operate .operate__head{
  max-width:680px;margin:0 0 56px;text-align:left;
}
.operate .operate__head h2{color:#fff;margin:6px 0 14px}
.operate .operate__head .eyebrow{color:var(--cyan-x)}
.operate__desc{
  color:#a8b3cc;font-size:1.05rem;line-height:1.7;max-width:54ch;
}
/* Light variant overrides */
.operate--light .operate__head h2{color:var(--blue-x)}
.operate--light .operate__head .eyebrow{color:var(--blue-xg)}
.operate--light .operate__desc{color:#3a4670}
.operate--light .operate__card{
  background:linear-gradient(145deg,rgba(0,49,155,.04),rgba(0,49,155,.01));
  border:1px solid rgba(0,49,155,.10);
  border-top:none;
  padding-top:calc(1.9rem + 4px);
}
/* Solid cyan accent — hidden at rest, fades in on hover (subtle) */
.operate--light .operate__card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--cyan-x);
  border-radius:12px 12px 0 0;
  opacity:0;
  transition:opacity .35s ease;
}
/* hide the small inner accent line at rest too */
.operate--light .operate__card::before{opacity:0;transition:opacity .35s ease, width .35s ease}
.operate--light .operate__card:hover{
  border-color:rgba(0,49,155,.22);
  box-shadow:0 12px 28px -16px rgba(0,49,155,.18);
}
.operate--light .operate__card:hover::after{opacity:.55}
.operate--light .operate__card:hover::before{opacity:1}
.operate--light .operate__card:hover::before{opacity:1}
.operate--light .operate__card h3{color:var(--blue-x)}
.operate--light .operate__card p{color:#3a4670}
.operate__grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1.6rem;
  max-width:1080px;margin:0 auto;
}
@media (max-width:980px){.operate__grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.operate__grid{grid-template-columns:1fr}}
.operate__card{
  position:relative;padding:1.6rem 1.45rem;border-radius:12px;
  background:linear-gradient(145deg,rgba(0,195,250,.06),rgba(0,195,250,.015));
  border:1px solid rgba(0,195,250,.14);
  border-top:3px solid var(--cyan-x);
  transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
/* short accent line above the title */
.operate__card::before{
  content:"";display:block;
  width:36px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--cyan-x),#9eeaff);
  margin-bottom:1.3rem;
  transition:width .3s ease;
}
.operate__card:hover{
  border-color:rgba(0,195,250,.4);
  border-top-color:#9eeaff;
  transform:translateY(-4px);
  box-shadow:0 12px 28px -16px rgba(0,195,250,.28);
}
.operate__card:hover::before{width:56px}
.operate__card h3{color:#fff;font-size:1.12rem;font-weight:700;margin:0 0 .55rem;letter-spacing:-.2px}
.operate__card p{color:#a8b3cc;font-size:.94rem;line-height:1.65;margin:0}

/* ---------- NXG Advantage (2-column: copy left, cards right) ------ */
.edge__grid{
  display:grid;grid-template-columns:1.05fr .92fr;gap:64px;align-items:center;
}
@media (max-width:900px){.edge__grid{grid-template-columns:1fr;gap:36px}}
.edge--light .edge__copy h2{color:var(--blue-x);margin:6px 0 18px}
.edge--light .edge__copy .eyebrow{color:var(--blue-xg)}
.edge--light .edge__copy p{
  color:#3a4670;font-size:1.02rem;line-height:1.75;margin:0 0 1em;max-width:54ch;
}
.edge__cards{display:flex;flex-direction:column;gap:14px}
.edge--light .edge__card{
  position:relative;padding:1.4rem 1.6rem;border-radius:12px;
  background:linear-gradient(145deg,rgba(0,49,155,.04),rgba(0,49,155,.01));
  border:1px solid rgba(0,49,155,.10);
  transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.edge--light .edge__card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--cyan-x);
  border-radius:12px 12px 0 0;
  opacity:0;transition:opacity .35s ease;
}
.edge--light .edge__card:hover{
  border-color:rgba(0,49,155,.22);
  transform:translateY(-2px);
  box-shadow:0 10px 24px -16px rgba(0,49,155,.18);
}
.edge--light .edge__card:hover::after{opacity:.55}
.edge--light .edge__card h3{color:var(--blue-x);font-size:1.1rem;font-weight:700;margin:0 0 .35rem;letter-spacing:-.2px}
.edge--light .edge__card p{color:#3a4670;font-size:.94rem;line-height:1.6;margin:0}

/* ---------- Where We Invest (dark, photo cards) ------------------- */
.invest{padding:clamp(48px,5.5vw,80px) 0}
.invest .invest__head{max-width:880px;margin:0 0 32px;text-align:left}
.invest .invest__head h2{color:var(--blue-x);margin:6px 0 0}
.invest .invest__head .eyebrow{color:var(--blue-xg)}
.invest .invest__lead{margin-top:14px;text-wrap:balance}
.invest__grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;
  max-width:1030px;margin:0 auto;
}
@media (max-width:980px){.invest__grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.invest__grid{grid-template-columns:1fr}}
.invest__card{
  position:relative;border-radius:14px;overflow:hidden;
  background:#fff;
  border:1px solid rgba(0,30,87,.08);
  box-shadow:0 14px 32px -20px rgba(0,30,87,.18);
  transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.invest__card:hover{
  border-color:rgba(0,195,250,.30);
  transform:translateY(-4px);
  box-shadow:0 22px 44px -22px rgba(0,30,87,.25);
}
.invest__img{
  width:100%;height:140px;background-size:cover;background-position:center;
}
.invest__body{padding:1.2rem 1.4rem 1.5rem}
.invest__body h3{color:var(--ink);font-size:1.18rem;font-weight:700;margin:0 0 .6rem;letter-spacing:-.2px}
.invest__body p{color:#3a4670;font-size:.95rem;line-height:1.7;margin:0}

/* ---------- JPMorgan banner + quote section ----------------------- */
.jpm-section{
  padding-top:clamp(40px,4.5vw,68px);padding-bottom:clamp(36px,4vw,60px);
  background:var(--paper-2);
}
.jpm-banner{
  max-width:1100px;margin:0 auto 1.8rem;
  display:flex;align-items:center;justify-content:center;gap:.6rem;
}
.jpm-banner__inner{
  display:flex;align-items:center;gap:1.4rem;
  flex-wrap:wrap;justify-content:center;
  padding:1.4rem 2.2rem;max-width:820px;width:100%;
  background:linear-gradient(135deg, rgba(0,49,155,.04) 0%, rgba(0,195,250,.06) 100%);
  border:none;
  border-radius:14px;
  box-shadow:0 8px 28px -16px rgba(0,49,155,.18);
}
.jpm-num{
  font-family:var(--font-display);
  font-weight:800;letter-spacing:-.5px;
  font-size:clamp(1.7rem,2.6vw,2.2rem);
  line-height:1;
  background:linear-gradient(135deg, var(--blue-xg) 0%, var(--cyan-x) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--blue-xg);
}
.jpm-label{
  font-size:.82rem;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--blue-x);
}
.jpm-source{
  font-size:.82rem;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:#5e6b7d;
}
.jpm-vdivider{
  width:2px;height:24px;
  background:linear-gradient(180deg, transparent 0%, rgba(0,30,87,.55) 50%, transparent 100%);
  display:inline-block;
}
.jpm-chev{
  width:30px;height:48px;
  color:var(--cyan-x);
  flex-shrink:0;
  filter:drop-shadow(0 2px 6px rgba(0,195,250,.35));
}

.jpm-quote{
  max-width:780px;margin:0;text-align:left;
  font-family:var(--font-display);
  font-weight:500;line-height:1.6;
  font-size:clamp(.98rem,1.3vw,1.12rem);
  color:var(--ink);padding:0;
  text-wrap:balance;
}
/* News page hero: shorter than default hero */
.hero-news{min-height:470px;align-items:flex-start}
.hero-news .hero__inner{padding-top:152px;padding-bottom:55px}
.hero-news h1{font-size:clamp(2rem,3.8vw,2.95rem);margin-bottom:.4em}
.hero-news p.hero__sub{
  font-size:1.1rem;
  white-space:normal;
  max-width:50ch;
  text-wrap:balance;
  color:#fff;
  text-shadow:0 2px 12px rgba(0,8,28,.55), 0 1px 2px rgba(0,8,28,.45);
}

/* ---------- News / Press Releases page ---------------------------- */
.press-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;margin:0 0 24px;flex-wrap:wrap;
}
.press-head h2{margin:0;color:var(--blue-x)}
.press-filter{display:flex;flex-direction:column;gap:8px;min-width:300px}
.press-filter label{
  font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--blue-x);
}
.press-filter__row{display:flex;gap:10px}
.press-filter select{
  flex:1;padding:10px 14px;border:1px solid var(--line);border-radius:6px;
  background:#fff;font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  appearance:auto;
}
.press-filter .btn{padding:11px 28px;font-size:.78rem;letter-spacing:.18em}

.press-bar{
  background:linear-gradient(90deg, var(--blue-xg) 0%, var(--blue-x) 100%);
  color:#fff;padding:14px 22px;border-radius:4px;
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.04em;
  margin:0 0 8px;
}

/* News page — featured release card (replaces "All Releases" bar) */
.press-feature{
  display:block;
  position:relative;
  padding:clamp(22px,2.5vw,30px) clamp(24px,2.6vw,32px);
  margin:0 0 clamp(20px,2.2vw,28px);
  border:1px solid rgba(0,30,87,.10);
  border-left:3px solid var(--cyan-x);
  border-radius:6px;
  background:linear-gradient(180deg, #fff 0%, rgba(0,195,250,.03) 100%);
  box-shadow:0 6px 22px -18px rgba(0,30,87,.15);
}
.press-feature__tag{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.62rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:10px;
}
.press-feature__date{
  display:block;
  margin-bottom:8px;
  padding-top:0;
}
.press-feature__title{
  display:block;
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.15rem,1.65vw,1.4rem);
  line-height:1.3;
  letter-spacing:-.01em;
  color:var(--blue-x);
  text-decoration:none;
  margin-bottom:10px;
  text-wrap:balance;
}
.press-feature__title:hover{color:var(--blue-xg)}
.press-feature__excerpt{
  font-size:.98rem;
  line-height:1.65;
  color:#3a4670;
  margin:0 0 18px;
  max-width:62ch;
}
.press-feature__actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.press-list{list-style:none;padding:0;margin:0}
.press-list li{
  display:grid;grid-template-columns:160px 1fr auto;gap:24px;align-items:start;
  padding:22px 22px;border-bottom:1px solid var(--line);
}
.press-list li:hover{background:#f7faff}
.press-item__main{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.press-excerpt{
  margin:0;
  font-size:.94rem;
  line-height:1.6;
  color:#5e6b7d;
  max-width:62ch;
}
.press-date{
  color:var(--cyan-x);font-family:var(--font-display);font-weight:600;
  font-size:.85rem;letter-spacing:.04em;padding-top:2px;
}
.press-title{
  color:var(--blue-x);font-family:var(--font-display);font-weight:600;
  font-size:1.05rem;line-height:1.4;
}
.press-title:hover{color:var(--blue-xg)}
.press-lang{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.20em;text-transform:uppercase;
  color:var(--blue-x);
  border:1.5px solid var(--blue-x);
  padding:7px 14px 7px 12px;border-radius:var(--pill);
  background:transparent;
  text-decoration:none;
  transition:border-color .25s ease, color .25s ease, background .25s ease, transform .2s ease;
}
.press-lang__arrow{
  display:inline-block;
  font-size:.85rem;font-weight:600;line-height:1;
  letter-spacing:0;
  transition:transform .2s ease;
}
.press-lang:hover{
  border-color:var(--cyan-x);
  background:var(--cyan-x);
  color:var(--blue-x);
}
.press-lang:hover .press-lang__arrow{transform:translateX(3px)}

@media (max-width:760px){
  .press-list li{grid-template-columns:1fr;gap:6px}
  .press-head{flex-direction:column;align-items:flex-start}
  .press-filter{min-width:0;width:100%}
}
/* COINGT hero photo: default chevron pattern (same as home), gold coins centered */
.hero-coingt .hero__photo{
  background-position:center !important;
  filter:saturate(1.05);
}
.hero-coingt{min-height:700px;align-items:flex-start}
.hero-coingt .hero__inner{padding-top:152px}
/* Stronger navy overlay on the left for text contrast, easing to reveal the coins on the right */
.hero-coingt .hero__photo::after{
  background:
    linear-gradient(0deg, rgba(0,195,250,.046) 0%, rgba(0,195,250,.015) 12%, transparent 22%),
    linear-gradient(90deg, rgba(0,12,38,.66) 0%, rgba(0,12,38,.55) 30%, rgba(0,12,38,.34) 55%, rgba(0,12,38,.13) 78%, rgba(0,12,38,.04) 100%) !important;
}

/* ---------- COINGT page (badge strip + pillars + reg + cta) ------- */
.coingt-badges{
  background:linear-gradient(135deg, #1a1f2e 0%, #232838 50%, #1a1f2e 100%);
  padding:44px 0;
  border-top:2px solid var(--cyan-x);
  position:relative;
}
.coingt-badges::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(0,195,250,.3) 50%, transparent 100%);
}
.coingt-badges__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
@media (max-width:900px){.coingt-badges__grid{grid-template-columns:repeat(2,1fr);row-gap:24px}}
@media (max-width:600px){.coingt-badges__grid{grid-template-columns:1fr;row-gap:18px}}
.coingt-badge{
  padding:8px 32px;
  position:relative;
  border-left:1px solid rgba(255,255,255,.14);
  transition:background .25s ease;
}
.coingt-badge:first-child{border-left:none;padding-left:0}
@media (max-width:900px){
  .coingt-badge:nth-child(3){border-left:none;padding-left:0}
}
@media (max-width:600px){
  .coingt-badge{border-left:none !important;padding-left:0 !important}
}
.coingt-badge__label{
  font-family:var(--font-display);font-weight:600;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan-x);margin-bottom:8px;
}
.coingt-badge__value{
  font-family:var(--font-display);font-weight:500;
  font-size:.92rem;color:#fff;line-height:1.35;letter-spacing:-.005em;
  white-space:nowrap;
}

/* Better vertical rhythm for COINGT page sections */
.hero-coingt + .coingt-badges{margin-top:0}
.coingt-badges + .section--paper{padding-top:clamp(56px,7vw,90px)}
.section--paper + .pillars-section{padding-top:clamp(48px,6vw,80px);padding-bottom:clamp(56px,7vw,90px)}
.pillars-section + .coingt-reg{padding-top:clamp(64px,8vw,100px);padding-bottom:clamp(64px,8vw,100px)}
.coingt-reg + .coingt-cta{padding-top:clamp(56px,7vw,90px)}

/* Pillars grid (light section) */
.pillars-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px;
}
@media (max-width:900px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pillars-grid{grid-template-columns:1fr}}

/* Grouped pillars layout — Returns row + Structural Protections row */
.pillars-group{
  margin-top:clamp(36px,4vw,52px);
}
.pillars-group__head{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:clamp(20px,2.4vw,28px);
}
.pillars-group__label{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-xg);
  flex:0 0 auto;
}
.pillars-group__rule{
  flex:1 1 auto;
  height:1px;
  background:rgba(0,30,87,.14);
}
.pillars-grid--3{
  grid-template-columns:repeat(3,1fr);
  margin-top:0;
}
@media (max-width:900px){
  .pillars-grid--3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:600px){
  .pillars-grid--3{grid-template-columns:1fr}
}
.pillar-card{
  background:#fff;border:1px solid var(--line);
  border-top:3px solid var(--cyan-x);
  padding:30px 26px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pillar-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px -22px rgba(0,30,87,.22);
  border-top-color:var(--blue-xg);
}
.pillar-num{
  font-family:var(--font-display);font-weight:700;
  font-size:.74rem;letter-spacing:.3em;color:var(--cyan-x);
  margin-bottom:14px;
}
.pillar-card h3,
.pillar-card h4{
  font-family:var(--font-display);
  font-size:1.18rem;font-weight:600;color:var(--blue-x);
  margin:0 0 12px;line-height:1.3;letter-spacing:-.01em;
}
.pillar-card p{
  font-size:.94rem;color:#3a4670;line-height:1.65;margin:0;
}

/* Regulatory section (centered ink) */
.coingt-reg .proj-center p{color:#cfdcf6;font-size:1.05rem;line-height:1.7}

/* CTA fine print */
.cta-fine{
  font-family:var(--font-display);font-weight:600;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:#5e6b7d;margin-top:32px;
}
/* Project body 2-col copy grid (heading left, body right) - also used by COINGT */
.proj-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start;
}
@media (max-width:900px){.proj-grid{grid-template-columns:1fr;gap:36px}}
.proj-grid h2{margin:8px 0 0}
.proj-grid__copy p{font-size:1.05rem;line-height:1.75;color:#3a4670;margin:0 0 1em;max-width:54ch}
.proj-grid__copy p:last-child{margin-bottom:0}
.proj-grid__copy strong{color:var(--blue-x);font-weight:700}
/* Pillars section header (left-aligned, like the upload) */
.pillars-head{max-width:880px;margin:0 0 48px;text-align:left}
.pillars-head h2{margin:8px 0 16px}
.pillars-head p{font-size:1.05rem;line-height:1.7;color:#3a4670;max-width:80ch;margin:0;text-wrap:balance}

/* Pillar cards: image at top, body with number + title + text */
.pillars-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
@media (max-width:980px){.pillars-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pillars-grid{grid-template-columns:1fr}}
.pillar-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  overflow:hidden;
  border-top:none !important;
  padding:0 !important;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pillar-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,49,155,.25);
  box-shadow:0 22px 48px -24px rgba(0,30,87,.28);
}
.pillar-card__img{
  width:100%;height:150px;
  background-size:cover;background-position:center;
  position:relative;
}
/* Strip pillar card variant — slim navy band on top instead of full image */
.pillar-card--strip{
  padding-top:0;
}
.pillar-card__strip{
  height:18px;
  margin:0 -27px;
  background:
    linear-gradient(90deg, transparent 0%, rgba(0,195,250,.12) 50%, transparent 100%),
    linear-gradient(135deg, #001233 0%, #002a72 35%, #003ca6 55%, #002a72 75%, #001233 100%);
  border-bottom:1px solid rgba(0,195,250,.45);
  position:relative;
  overflow:hidden;
}
.pillar-card__strip::before{
  content:"";
  position:absolute;
  top:0;left:-10%;
  width:40%;height:100%;
  background:radial-gradient(ellipse at 70% 50%, rgba(0,195,250,.30) 0%, rgba(0,195,250,0) 70%);
  pointer-events:none;
}
.pillar-card__strip::after{
  content:"";
  position:absolute;
  top:0;right:-10%;
  width:40%;height:100%;
  background:radial-gradient(ellipse at 30% 50%, rgba(0,195,250,.30) 0%, rgba(0,195,250,0) 70%);
  pointer-events:none;
}
.pillar-card--strip .pillar-card__body{
  padding-top:24px;
}
.pillar-card__img--abstract{
  background:
    linear-gradient(135deg, #001a4d 0%, #002a72 50%, #001a4d 100%);
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pillar-card__img--abstract::before{
  content:"";
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:140px;height:140px;
  background:radial-gradient(circle, rgba(0,195,250,.28) 0%, rgba(0,195,250,0) 65%);
  pointer-events:none;
  z-index:0;
}
.pillar-card__img--abstract::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:2px;
  background:linear-gradient(90deg, transparent 0%, rgba(0,195,250,.6) 50%, transparent 100%);
}
.pillar-bignum-wrap{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:baseline;
  gap:4px;
}
.pillar-bignum{
  font-family:var(--font-display);
  font-weight:700;
  font-size:42px;
  line-height:1;
  letter-spacing:-.04em;
  background:linear-gradient(180deg, rgba(0,195,250,.95) 0%, rgba(0,195,250,.55) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:var(--cyan-x);
}
.pillar-bigtotal{
  font-family:var(--font-display);
  font-weight:700;
  font-size:42px;
  line-height:1;
  letter-spacing:-.04em;
  color:var(--cyan-x);
  opacity:.55;
}

.pillar-card__body{
  padding:22px 24px 26px;
}
.pillar-card__body .pillar-num{
  font-family:var(--font-display);font-weight:700;
  font-size:.74rem;letter-spacing:.3em;color:var(--cyan-x);
  margin-bottom:10px;
}
.pillar-card__body h3,
.pillar-card__body h4{
  font-family:var(--font-display);
  font-size:1.15rem;font-weight:600;color:var(--blue-x);
  margin:0 0 10px;line-height:1.3;letter-spacing:-.01em;
}
.pillar-card__body p{
  font-size:.93rem;color:#3a4670;line-height:1.6;margin:0;
}
/* ---------- COINGT Regulatory section (refined) ------------------- */
.coingt-reg{
  position:relative;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(0,195,250,.12) 0%, transparent 60%),
    var(--grad-deep);
}
.reg-content{max-width:880px;margin:0 auto;text-align:center}
.reg-content h2{color:#fff;margin:8px 0 22px;line-height:1.15}
.reg-content .eyebrow{color:var(--cyan-x)}
.reg-lead{color:#cfdcf6;font-size:1.1rem;line-height:1.65;max-width:680px;margin:0 auto 40px;text-wrap:balance}
.reg-pillars{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  max-width:680px;margin:0 auto 40px;
}
@media (max-width:640px){.reg-pillars{grid-template-columns:1fr}}
.reg-pill{
  padding:24px 26px;border-radius:12px;
  background:linear-gradient(145deg, rgba(0,195,250,.08), rgba(0,195,250,.02));
  border:1px solid rgba(0,195,250,.22);
  text-align:left;
  position:relative;overflow:hidden;
  transition:border-color .3s ease, transform .3s ease;
}
.reg-pill::before{
  content:"";position:absolute;top:0;left:0;width:32px;height:2px;
  background:var(--cyan-x);
  transition:width .3s ease;
}
.reg-pill:hover{border-color:rgba(0,195,250,.55);transform:translateY(-2px)}
.reg-pill:hover::before{width:64px}
.reg-pill__label{
  font-family:var(--font-display);font-weight:600;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan-x);margin-bottom:10px;
}
.reg-pill__value{
  font-family:var(--font-display);font-weight:600;
  font-size:1.15rem;color:#fff;line-height:1.3;letter-spacing:-.01em;
}
.reg-fine{
  color:#9eaecf;font-size:.95rem;line-height:1.6;font-style:italic;
  max-width:560px;margin:0 auto;text-wrap:balance;
}
.reg-flourish{
  display:block;margin:40px auto 0;
  width:60px;height:1px;background:var(--cyan-x);opacity:.7;
  position:relative;
}
.reg-flourish::after{
  content:"";position:absolute;top:-3px;left:50%;
  transform:translateX(-50%) rotate(45deg);
  width:6px;height:6px;background:var(--cyan-x);
}
/* COINGT Regulatory: left-aligned 2-col like rest of page */
.coingt-reg .proj-grid h2{margin:8px 0 0}
.coingt-reg .proj-grid .eyebrow{color:var(--cyan-x)}
.reg-body p{color:#cfdcf6}
.reg-body .reg-lead{font-size:1.05rem;line-height:1.75;margin:0 0 20px;text-wrap:balance;max-width:none}
.reg-body .reg-pillars{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:0 0 28px;max-width:none;
}
.reg-body .reg-pill{padding:18px 20px}
.reg-body .reg-pill__value{font-size:1.02rem}
@media (max-width:640px){.reg-body .reg-pillars{grid-template-columns:1fr}}
.reg-body .reg-fine{font-size:1.05rem;line-height:1.75;font-style:normal;color:#cfdcf6;max-width:none;margin:0;text-align:left;text-wrap:balance}
/* ---------- About page ------------------------------------------- */
.hero-about{align-items:flex-start;min-height:700px;position:relative}
.hero-about p.hero__sub{
  color:#fff;
  text-shadow:0 2px 12px rgba(0,8,28,.55), 0 1px 2px rgba(0,8,28,.45);
}
.hero-about .hero__copy p:not(.hero__sub){
  text-shadow:0 2px 10px rgba(0,8,28,.50), 0 1px 2px rgba(0,8,28,.40);
}
/* Hero photo: Singapore Marina Bay panorama at blue hour. Already cool/dark,
   so overlay can be much lighter than the Dubai version this replaced. */
.hero-about .hero__photo{
  background-position:center center !important;
  background-size:cover !important;
  filter:saturate(1.04);
}
/* Overlay: light left-side scrim for text contrast, near-clear on the right
   so the dense skyline + reflections remain visible. */
.hero-about .hero__photo::after{
  background:
    /* Water lightener — bottom-to-middle wash between Chesnutt and Sibrian columns */
    radial-gradient(ellipse 28% 36% at 78% 70%, rgba(255,255,255,.22) 0%, rgba(255,255,255,.10) 50%, rgba(255,255,255,0) 100%),
    /* Bottom edge fade into the section below */
    linear-gradient(0deg, rgba(0,16,46,.32) 0%, rgba(0,16,46,.10) 10%, rgba(0,16,46,0) 22%),
    /* Glow softener — radial dim over skyline glow above di Vigliano's column */
    radial-gradient(ellipse 38% 28% at 38% 28%, rgba(0,8,28,.18) 0%, rgba(0,8,28,.06) 60%, rgba(0,8,28,0) 100%),
    /* Glow softener — radial dim over skyline glow above Chesnutt's column */
    radial-gradient(ellipse 38% 28% at 65% 28%, rgba(0,8,28,.18) 0%, rgba(0,8,28,.06) 60%, rgba(0,8,28,0) 100%),
    /* Subtle navy left-to-right wash: photo is already cool, so light scrim only */
    linear-gradient(90deg, rgba(0,8,28,.42) 0%, rgba(0,8,28,.30) 30%, rgba(0,12,38,.12) 58%, rgba(0,12,38,.02) 82%, rgba(0,12,38,0) 100%) !important;
}
.about-pill{
  display:inline-block;border:1px solid rgba(255,255,255,.45);
  padding:9px 18px;border-radius:2px;color:#fff;
  margin-bottom:24px;
}

/* About callout: simple single-line italic statement */
.about-callout{
  padding-top:clamp(48px,5vw,76px);
  padding-bottom:clamp(48px,5vw,76px);
  text-align:left;
}
.about-callout__inner{
  max-width:1000px;margin:0 auto;
}
.about-callout__text{
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;font-weight:400;
  font-size:clamp(1.4rem,2.2vw,1.85rem);
  color:rgba(255,255,255,.94);
  line-height:1.4;letter-spacing:-.005em;
  max-width:none;margin:0 auto;text-wrap:balance;
}
.about-callout__text em{
  font-style:italic;font-weight:600;
  color:var(--cyan-x);
}
/* Light variant override */
.about-callout--light .about-callout__text{color:var(--blue-x)}
.about-callout--light .about-callout__text em{color:var(--blue-xg)}

/* Credentials section: header block + 3-card grid */
.creds-head{max-width:880px;margin:0 0 48px;text-align:left}
.creds-head h2{margin:8px 0 16px}
.creds-head p{font-size:1.05rem;line-height:1.7;color:#3a4670;max-width:54ch;margin:0}
.creds-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
@media (max-width:900px){.creds-grid{grid-template-columns:1fr}}
.cred-card{
  background:#fff;border:1px solid var(--line);
  border-top:3px solid var(--blue-x);
  padding:34px 30px;
  transition:transform .25s ease, box-shadow .25s ease, border-top-color .25s ease;
}
.cred-card:hover{
  transform:translateY(-3px);
  box-shadow:0 22px 48px -22px rgba(0,30,87,.22);
  border-top-color:var(--cyan-x);
}
.cred-card__label{
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan-x);margin-bottom:14px;
}
.cred-card h3,
.cred-card h4{
  font-family:var(--font-display);
  font-size:1.32rem;font-weight:600;color:var(--blue-x);
  margin:0 0 12px;line-height:1.3;letter-spacing:-.01em;
}
.cred-card p{
  font-size:.95rem;color:#3a4670;line-height:1.65;margin:0;
}

/* Team grid */
.team-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;
  margin-top:8px;
}
.team-member{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:36px 28px;text-align:left;
  display:block;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.team-member:hover{
  transform:translateY(-3px);
  border-color:rgba(0,49,155,.25);
  box-shadow:0 18px 40px -22px rgba(0,30,87,.22);
}
.team-avatar{
  width:88px;height:88px;border-radius:50%;
  background:linear-gradient(135deg, var(--blue-x), var(--blue-xg));
  margin:0 auto 18px;
  display:flex;align-items:center;justify-content:center;
  color:var(--cyan-x);
  font-family:var(--font-display);font-size:1.5rem;font-weight:600;
  letter-spacing:.06em;
}
.team-member .team-name{
  font-family:var(--font-display);font-size:1.1rem;font-weight:700;
  color:var(--blue-x);margin:0 0 6px;line-height:1.3;
  min-height:2.6em;
}
.team-member .team-role{
  font-family:var(--font-display);font-weight:600;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cyan-x);margin:0 0 14px;
}
.team-member .team-bio{
  font-size:.9rem;color:#3a4670;line-height:1.6;
}

/* Advised By */
.advised-head{text-align:left;max-width:680px;margin:0 auto 36px}
.advised-head h2{margin:8px 0 0;text-wrap:balance}
.advised-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:0;
  border-top:1px solid rgba(0,195,250,.18);
  border-bottom:1px solid rgba(0,195,250,.18);
}
@media (max-width:900px){.advised-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:540px){.advised-grid{grid-template-columns:repeat(2,1fr)}}
.advised-item{
  padding:30px 16px;text-align:left;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border-left:1px solid rgba(255,255,255,.08);
  transition:background .25s ease;
}
.advised-item:first-child{border-left:none}
@media (max-width:900px){
  .advised-item:nth-child(3n+1){border-left:none}
  .advised-item:nth-child(n+4){border-top:1px solid rgba(255,255,255,.08)}
}
@media (max-width:540px){
  .advised-item:nth-child(3n+1){border-left:1px solid rgba(255,255,255,.08)}
  .advised-item:nth-child(odd){border-left:none}
  .advised-item:nth-child(n+3){border-top:1px solid rgba(255,255,255,.08)}
}
.advised-item:hover{background:rgba(255,255,255,.025)}
.advised-mark{
  position:relative;padding:8px 0;display:block;margin-bottom:12px;
  font-family:var(--font-display);font-weight:600;
  font-size:1.3rem;letter-spacing:.02em;color:#fff;line-height:1;
}
.advised-mark::before,.advised-mark::after{
  content:"";position:absolute;left:50%;transform:translateX(-50%);
  width:32px;height:1px;background:rgba(0,195,250,.6);
}
.advised-mark::before{top:0}
.advised-mark::after{bottom:0}
.advised-mark--serif{
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;font-weight:400;font-size:1.5rem;letter-spacing:.01em;
}
.advised-mark--compact{font-size:1.05rem;letter-spacing:.04em}
.advised-item small{
  display:block;
  font-family:var(--font-display);font-weight:500;
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
/* Partner logos: contained in white card with logo image inside */
.advised-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
  border:none;
}
@media (max-width:900px){.advised-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:540px){.advised-grid{grid-template-columns:repeat(2,1fr)}}
.advised-grid .advised-item{
  background:#fff;border:1px solid rgba(255,255,255,.12);border-radius:12px;
  padding:24px 18px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  border-left:1px solid rgba(255,255,255,.12);
  transition:transform .25s ease, box-shadow .25s ease;
}
.advised-grid .advised-item:hover{
  background:#fff;
  transform:translateY(-3px);
  box-shadow:0 18px 40px -22px rgba(0,195,250,.3);
}
.advised-logo{
  width:100%;height:80px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.advised-logo img{
  max-width:100%;max-height:100%;
  object-fit:contain;width:auto;height:auto;
}
.advised-grid .advised-item small{
  display:block;
  font-family:var(--font-display);font-weight:600;
  font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--blue-x);
}
.advised-lead{
  color:#cfdcf6;font-size:1.05rem;line-height:1.7;
  max-width:700px;margin:14px auto 0;text-wrap:balance;
}
/* Partners section — light bg, minimal logo strip */
.partners-light{padding-top:clamp(56px,7vw,90px);padding-bottom:clamp(56px,7vw,90px)}
.partners-head{text-align:left;max-width:880px;margin:0 0 56px}
.partners-head h2{margin:8px 0 16px}
.partners-head p{font-size:1.05rem;line-height:1.7;color:#3a4670;max-width:54ch;margin:0}

.partners-row{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
@media (max-width:900px){.partners-row{grid-template-columns:repeat(3,1fr)}}
@media (max-width:540px){.partners-row{grid-template-columns:repeat(2,1fr)}}
.partner{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:36px 22px 30px;
  border-left:1px solid var(--line);
  position:relative;
  transition:background .25s ease;
}
.partner:first-child{border-left:none}
@media (max-width:900px){
  .partner:nth-child(3n+1){border-left:none}
  .partner:nth-child(n+4){border-top:1px solid var(--line)}
}
@media (max-width:540px){
  .partner:nth-child(odd){border-left:none}
  .partner:nth-child(3n+1){border-left:1px solid var(--line)}
  .partner:nth-child(n+3){border-top:1px solid var(--line)}
}
.partner::before{
  content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:var(--cyan-x);
  transition:width .3s ease;
}
.partner:hover{background:#f7faff}
.partner:hover::before{width:48px}
.partner__logo{
  width:100%;height:80px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.partner__logo img{
  object-fit:contain;
  transition:transform .25s ease;
}
/* Square logos: cap by height so they don't dominate */
.partner__logo img.lg-square{max-height:64px;max-width:64px;width:auto;height:auto}
/* Wide logos (text-heavy): scale up so they hold visual weight similar to the squares */
.partner__logo img.lg-wide{max-height:50px;max-width:75%;width:auto;height:auto}
.partner:hover .partner__logo img{transform:scale(1.04)}
.partner__role{
  font-family:var(--font-display);font-weight:600;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--blue-xg);
}
/* ---------- About: Stats band ----------------------------------- */
.stats-band{padding-top:22px;padding-bottom:22px}
/* Animation: fade + slide each cell in on scroll, with stagger */
.stats-band .stat-cell{
  transition:opacity .7s ease, transform .7s ease;
}
.stats-band.js-prep .stat-cell{opacity:0;transform:translateY(14px)}
.stats-band.is-visible .stat-cell{opacity:1;transform:translateY(0)}
.stats-band.is-visible .stat-cell:nth-child(1){transition-delay:0s}
.stats-band.is-visible .stat-cell:nth-child(2){transition-delay:.10s}
.stats-band.is-visible .stat-cell:nth-child(3){transition-delay:.20s}
.stats-band.is-visible .stat-cell:nth-child(4){transition-delay:.30s}
@media (prefers-reduced-motion: reduce){
  .stats-band .stat-cell{transition:none}
  .stats-band.js-prep .stat-cell{opacity:1;transform:none}
}
.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid rgba(0,195,250,.18);
  border-bottom:1px solid rgba(0,195,250,.18);
}
@media (max-width:780px){.stats-row{grid-template-columns:repeat(2,1fr)}}
.stat-cell{
  padding:22px 28px;text-align:left;
  border-left:1px solid rgba(255,255,255,.10);
}
.stat-cell:first-child{border-left:none}
@media (max-width:780px){
  .stat-cell:nth-child(odd){border-left:none}
  .stat-cell:nth-child(n+3){border-top:1px solid rgba(255,255,255,.10)}
}
.stat-cell__num{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.45rem,2.85vw,2.05rem);
  color:var(--cyan-x);line-height:1;letter-spacing:-.02em;
  margin-bottom:6px;
}
.stat-cell__plus{font-size:.6em;color:rgba(0,195,250,.7);margin-left:2px}
.stat-cell__lbl{
  font-family:var(--font-display);font-weight:600;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:#cfdcf6;
}

/* ---------- About: Premium Leadership cards --------------------- */
.team-group{
  display:flex;align-items:center;gap:18px;
  margin:36px 0 18px;
}
.team-group__label{
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--blue-xg);white-space:nowrap;
}
.team-group__rule{
  flex:1;height:1px;background:var(--line);
}
.team-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;
  margin-top:8px;
}
.team-member{
  position:relative;
  background:#fff;border:1px solid var(--line);
  border-top:3px solid var(--blue-x);
  padding:24px 22px 50px;display:block;
  transition:transform .25s ease, box-shadow .25s ease, border-top-color .25s ease;
}
.team-member:hover{
  transform:translateY(-3px);
  border-top-color:var(--cyan-x);
  box-shadow:0 22px 48px -22px rgba(0,30,87,.22);
}
.team-num{
  font-family:var(--font-display);font-weight:700;
  font-size:.74rem;letter-spacing:.3em;color:var(--cyan-x);
  margin:0 0 16px;
}
.team-member .team-role{
  font-family:var(--font-display);font-weight:600;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--blue-xg);margin:0 0 10px;
}
.team-member .team-name{
  font-family:var(--font-display);font-size:1.18rem;font-weight:700;
  color:var(--blue-x);margin:0 0 14px;line-height:1.3;letter-spacing:-.01em;
  text-align:left;min-height:auto;
}
.team-member .team-bio{
  font-size:.94rem;color:#3a4670;line-height:1.6;text-align:left;
}
.team-arrow{
  position:absolute;bottom:16px;right:22px;
  color:var(--blue-xg);
  font-size:1.6rem;font-weight:700;line-height:1;
  font-family:var(--font-display);
  transition:transform .25s ease, color .25s ease;
}
.team-member:hover .team-arrow{transform:translateX(5px);color:var(--cyan-x)}

/* ---------- About: Editorial leadership lineup (no cards) ---------------- */
.team-lineup{
  display:grid;
  /* Butte (col 1) gets a touch more width for his slightly longer bio */
  grid-template-columns:1.15fr 1fr 1fr 1fr;
  gap:0;
  margin-top:8px;
  position:relative;
}
.team-lead{
  position:relative;
  display:block;
  padding:6px 18px 12px;
  text-decoration:none;
  color:inherit;
  text-align:left;
  border-left:1px solid rgba(0,195,250,.22);
  transition:transform .25s ease;
}
.team-lead, .team-lead *{text-align:left}
.team-lead:first-child{border-left:none;padding-left:0}
.team-lead:last-child{padding-right:0}
.team-lead__num{
  font-family:var(--font-display);font-weight:700;
  font-size:.78rem;line-height:1;letter-spacing:.32em;
  color:#ffffff;opacity:.85;
  margin:0 0 14px;
}
.team-lead__role{
  font-family:var(--font-display);font-weight:600;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan-x);
  margin:0 0 12px;
}
.team-lead__name{
  font-family:var(--font-display);font-weight:700;
  font-size:1.18rem;line-height:1.2;letter-spacing:-.018em;
  color:#fff;
  margin:0 0 16px;
  white-space:nowrap;
  transition:color .3s ease;
}
.team-lead__rule{
  display:block;width:36px;height:2px;
  background:var(--cyan-x);opacity:.7;
  margin:0 0 18px;
  transition:width .35s ease, opacity .35s ease;
}
.team-lead__bio{
  font-size:.95rem;
  line-height:1.6;
  color:#cfdcf6;
  margin:0 0 22px;
}
.team-lead__cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.20em;text-transform:uppercase;
  color:#ffffff;opacity:.85;
  transition:opacity .25s ease, color .25s ease;
}
.team-lead:hover .team-lead__cta{color:var(--cyan-x);opacity:1}
.team-lead__arrow{
  display:inline-block;font-size:.95rem;line-height:1;
  transition:transform .25s ease;
}
.team-lead:hover{transform:translateY(-3px)}
.team-lead:hover .team-lead__rule{width:80px;opacity:1}
.team-lead:hover .team-lead__name{color:var(--cyan-x)}
.team-lead:hover .team-lead__cta{opacity:1}
.team-lead:hover .team-lead__arrow{transform:translateX(4px)}
@media (max-width:920px){
  .team-lineup{grid-template-columns:repeat(2,1fr);gap:48px 0}
  .team-lead{border-left:none;padding:0 0 0 24px}
  .team-lead:nth-child(odd){border-left:none;padding-left:0}
  .team-lead:nth-child(even){border-left:1px solid rgba(0,195,250,.22)}
  .team-lead__name{min-height:auto}
}
@media (max-width:560px){
  .team-lineup{grid-template-columns:1fr;gap:40px 0}
  .team-lead{border-left:none !important;padding:0 !important}
}

/* ---------- Bio (team detail) — editorial hero treatment ----------------- */
.bio-page{
  position:relative;
  padding-top:clamp(40px,5vw,72px);
  padding-bottom:clamp(64px,8vw,110px);
  overflow:hidden;
}
/* Decorative diagonal ribbons in page background (far right, very faint) */
.bio-page__ribbons{
  position:absolute;
  top:0;right:-6%;
  width:60%;height:100%;
  pointer-events:none;
  opacity:.85;
  background:
    repeating-linear-gradient(60deg, transparent 0 220px, rgba(0,30,87,.04) 220px 221px, transparent 221px 440px),
    repeating-linear-gradient(65deg, transparent 0 260px, rgba(0,30,87,.04) 260px 261px, transparent 261px 520px),
    repeating-linear-gradient(70deg, transparent 0 300px, rgba(0,30,87,.04) 300px 301px, transparent 301px 600px);
  z-index:0;
}
.bio-page > .wrap{position:relative;z-index:1}

.bio-back{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;
  font-size:.74rem;letter-spacing:.20em;text-transform:uppercase;
  color:var(--blue-x);
  padding:10px 18px;
  border:1.5px solid var(--blue-x);
  border-radius:var(--pill);
  background:transparent;
  text-decoration:none;
  transition:background-color .25s ease, color .25s ease, transform .2s ease;
  margin:0 0 clamp(28px,4vw,48px);
}
.bio-back__arrow{font-size:1rem;line-height:1;transition:transform .2s ease}
.bio-back:hover{background:var(--blue-x);color:#fff}
.bio-back:hover .bio-back__arrow{transform:translateX(-3px)}

/* ---------- Bio editorial spread (typography-led) ---------- */
.bio-spread{
  max-width:1080px;
  margin:0 auto;
  padding:clamp(20px,3vw,40px) 0 clamp(60px,8vw,120px);
}
.bio-spread__head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:24px;
  margin-bottom:clamp(28px,3.4vw,44px);
  padding-bottom:clamp(20px,2.4vw,32px);
  border-bottom:1px solid rgba(0,30,87,.12);
}
.bio-spread__num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,3.4vw,2.8rem);
  letter-spacing:-.02em;
  line-height:1;
  color:var(--cyan-x);
  opacity:.85;
}
.bio-spread__role{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-xg);
  text-align:right;
  line-height:1.4;
  max-width:260px;
}
.bio-spread__name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.9rem,3.6vw,2.8rem);
  line-height:1.1;
  letter-spacing:-.018em;
  color:var(--ink);
  margin:0 0 18px;
  text-wrap:balance;
}
.bio-spread__rule{
  display:block;
  width:64px;
  height:3px;
  background:var(--cyan-x);
  margin:0 0 clamp(36px,4.5vw,56px);
}
.bio-spread__body{
  display:grid;
  grid-template-columns:minmax(0,1.85fr) minmax(0,1fr);
  gap:clamp(40px,5vw,80px);
  align-items:start;
}
.bio-spread__main{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.bio-spread__main p{
  font-size:1.04rem;
  line-height:1.78;
  color:#374055;
  margin:0;
}
.bio-spread__meta{
  display:flex;
  flex-direction:column;
  gap:36px;
}

/* Bio metadata blocks — no card boxes, just label + rule + tabular rows */
.bio-meta-block{
  display:block;
}
.bio-meta-block__label{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-xg);
  margin:0 0 10px;
}
.bio-meta-block__rule{
  display:block;
  width:32px;
  height:1px;
  background:var(--cyan-x);
  margin:0 0 18px;
}
.bio-meta-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.bio-meta-list li{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.bio-meta-list__role{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.92rem;
  color:var(--ink);
  line-height:1.4;
}
.bio-meta-list__org{
  font-size:.88rem;
  color:#6e798f;
  line-height:1.45;
}
@media (max-width:780px){
  .bio-spread__body{
    grid-template-columns:1fr;
    gap:48px;
  }
  .bio-spread__head{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }
  .bio-spread__role{
    text-align:left;
    max-width:none;
  }
}

/* Bio hero — compact gradient banner, low-key treatment.
   Padding matches .bio-body so the hero aligns flush with the body content. */
.bio-hero{
  position:relative;
  background:linear-gradient(135deg, #00468f 0%, #0c7fd5 60%, #1aa8ff 100%);
  color:#fff;
  padding:clamp(22px, 3vw, 40px) clamp(20px, 3vw, 40px) clamp(22px, 3vw, 40px) clamp(20px, 3vw, 36px);
  overflow:hidden;
  margin-bottom:clamp(28px, 3.5vw, 48px);
  margin-right:clamp(20px, 3vw, 40px);
  border-left:4px solid var(--cyan-x);
}
/* Subtle diagonal chevron ribbons — toned down for a quieter feel */
.bio-hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(135deg, transparent 42%, rgba(0,30,87,.10) 42%, rgba(0,30,87,.10) 47%, transparent 47%),
    linear-gradient(135deg, transparent 64%, rgba(0,30,87,.08) 64%, rgba(0,30,87,.08) 70%, transparent 70%);
  pointer-events:none;
}
.bio-hero__inner{position:relative;z-index:1;max-width:920px;display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 18px}
.bio-hero__name{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  line-height:1.12;letter-spacing:-.015em;
  color:#fff;
  margin:0;
}
.bio-hero__role{
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;font-weight:400;
  font-size:clamp(.92rem, 1.2vw, 1.08rem);
  letter-spacing:0;text-transform:none;
  color:rgba(255,255,255,.92);
  margin:0;
  padding-left:14px;
  border-left:1px solid rgba(255,255,255,.35);
}

/* Section divider between hero and body */
.bio-divider{
  height:1px;
  width:auto;
  margin:0 clamp(20px, 3vw, 40px) 0 0;
  background:linear-gradient(90deg, var(--cyan-x) 0%, rgba(0,195,250,.30) 30%, transparent 80%);
}

/* 2-col body: wider left, narrower-but-clean sidebar.
   Horizontal padding matches .bio-hero so they share the same flush edges. */
.bio-body{
  display:grid;
  grid-template-columns:minmax(0, 1.55fr) minmax(280px, 1fr);
  gap:clamp(40px,4.5vw,72px);
  align-items:start;
  padding:clamp(40px,5vw,64px) clamp(20px,3vw,40px) 0 clamp(20px,3vw,36px);
}
@media (max-width:920px){
  .bio-body{grid-template-columns:1fr;gap:32px;padding:clamp(32px,5vw,48px) 0 0}
}
.bio-body__main{font-size:.94rem;line-height:1.75;color:#3a4670}
.bio-body__main p{
  margin:0 0 1.5em;
  text-align:justify;
  text-justify:inter-word;
  hyphens:none;
  -webkit-hyphens:none;
  text-wrap:pretty;
}
.bio-body__main p:last-child{margin-bottom:0}

/* Drop-cap on first paragraph */
.bio-body__lead{position:relative}
.bio-body__lead::first-letter{
  font-family:var(--font-display);font-weight:800;
  font-size:3.2em;line-height:.9;
  color:var(--cyan-x);
  float:left;
  padding:4px 8px 0 0;
  margin-right:4px;
}

/* Editorial pull-quote */
.bio-body__quote{
  margin:28px 0;
  padding:6px 0 6px 22px;
  border-left:3px solid var(--cyan-x);
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;font-weight:400;
  font-size:.95rem;line-height:1.65;
  color:var(--blue-x);
  letter-spacing:-.005em;
  text-wrap:pretty;
}

/* Sidebar */
.bio-body__aside{display:flex;flex-direction:column;gap:18px}
.bio-aside__card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-top:none;
  padding:24px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.bio-aside__card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--blue-x), var(--cyan-x));
}
.bio-aside__card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 36px -22px rgba(0,30,87,.20);
}
.bio-aside__title{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--blue-xg);
  margin:0 0 16px;
}
.bio-aside__title::before{
  content:"";display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan-x);
}
.bio-aside__list{
  list-style:none;margin:0;padding:0;
}
.bio-aside__list li{
  padding:10px 0;
  border-top:1px solid rgba(0,30,87,.10);
}
.bio-aside__list li:first-child{border-top:none;padding-top:0}
.bio-aside__list li:last-child{padding-bottom:0}
.bio-aside__list strong{
  display:block;
  font-family:var(--font-display);font-weight:700;
  font-size:.92rem;line-height:1.3;
  color:var(--blue-x);
  letter-spacing:-.005em;
}
.bio-aside__list .org{
  display:block;
  font-size:.84rem;line-height:1.45;
  color:#3a4670;
  margin-top:3px;
}

/* ---------- About: Partners cards (light variant) ----------- */
.partners-light{padding-top:clamp(56px,7vw,90px);padding-bottom:clamp(56px,7vw,90px)}
.partners-head--light{text-align:left;max-width:880px;margin:0 0 48px}
.partners-head--light h2{margin:8px 0 16px;color:var(--blue-x)}
.partners-head--light p{color:#3a4670;font-size:1.05rem;line-height:1.7;max-width:88ch;margin:0}
/* Legacy dark-variant aliases retained for any other pages still using them */
.partners-dark{padding-top:clamp(56px,7vw,90px);padding-bottom:clamp(56px,7vw,90px)}
.partners-head--dark{text-align:left;max-width:880px;margin:0 0 48px}
.partners-head--dark h2{margin:8px 0 16px}
.partners-head--dark p{color:#cfdcf6;font-size:1.05rem;line-height:1.7;max-width:54ch;margin:0}
.ptr-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;
}
@media (max-width:980px){.ptr-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.ptr-grid{grid-template-columns:repeat(2,1fr)}}
.ptr-card{
  position:relative;
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px 18px 20px;
  display:flex;flex-direction:column;align-items:center;
  transition:border-color .3s ease, transform .3s ease, background .3s ease, box-shadow .3s ease;
}
.ptr-card::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:var(--cyan-x);
  transition:width .3s ease;
}
.ptr-card:hover{
  border-color:rgba(0,195,250,.45);
  transform:translateY(-3px);
  box-shadow:0 18px 36px -22px rgba(0,30,87,.18);
}
.ptr-card:hover::before{width:48px}
.ptr-card__role{
  font-family:var(--font-display);font-weight:600;
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--blue-xg);margin-bottom:14px;text-align:left;
}
.ptr-card__logo{
  width:100%;height:72px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  background:#fff;border-radius:8px;padding:12px 12px;
}
.ptr-card__logo img.lg-square{max-height:64px;max-width:64px;width:auto;height:auto;object-fit:contain}
.ptr-card__logo img.lg-wide{max-height:42px;max-width:88%;width:auto;height:auto;object-fit:contain}
.ptr-card__name{
  font-family:var(--font-display);font-weight:600;
  font-size:.86rem;color:var(--blue-x);line-height:1.35;text-align:left;
  letter-spacing:-.005em;
}
/* When parent section is dark navy (partners-dark), keep the original light-on-dark card style */
.partners-dark .ptr-card{
  background:linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(0,195,250,.18);
}
.partners-dark .ptr-card:hover{
  border-color:rgba(0,195,250,.5);
  background:linear-gradient(160deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  box-shadow:none;
}
.partners-dark .ptr-card__role{color:var(--cyan-x)}
.partners-dark .ptr-card__name{color:#fff}

/* Leadership section with world-map background (about page) */
.team-section--mapped{
  position:relative;
  padding-top:clamp(80px,9vw,128px);
  padding-bottom:clamp(56px,6.5vw,96px);
  background:linear-gradient(160deg, #051433 0%, #001e57 60%, #00184a 100%);
  color:#fff;
  overflow:hidden;
}
/* World map: clearly visible base layer */
.team-section--mapped::before{
  content:"";position:absolute;inset:0;
  background:url('../assets/img/world-map.webp') no-repeat center top;
  background-size:cover;
  /* Anchor to the top of the image so the globe's curve dominates the section
     and the densest land/city-light area is cropped off the bottom. */
  background-position:center 8%;
  opacity:.78;
  mix-blend-mode:normal;
  pointer-events:none;
  z-index:0;
}
/* Multi-band scrim:
   1) Top stays clear (lighter map at very top), then ramps up behind the headline row
   2) Stronger middle dim where the bright land/city lights sit behind Avogadro & Chesnutt
   3) Soft horizontal band across the cards row to even out brightness across all 4 columns */
.team-section--mapped::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,
      rgba(0,12,38,0) 0%,
      rgba(0,12,38,0) 10%,
      rgba(0,12,38,.08) 16%,
      rgba(0,12,38,.32) 24%,
      rgba(0,12,38,.30) 40%,
      rgba(0,12,38,.10) 50%,
      rgba(0,12,38,0) 56%,
      rgba(0,12,38,0) 100%
    ),
    /* Targeted dim over middle two columns where the bright glow sits */
    radial-gradient(ellipse 38% 36% at 50% 75%, rgba(0,8,28,.62) 0%, rgba(0,8,28,.40) 45%, rgba(0,8,28,.10) 80%, rgba(0,8,28,0) 100%),
    /* Soft cyan-tinted lift on the right-of-center bottom — brightens the water area there */
    radial-gradient(ellipse 28% 22% at 70% 92%, rgba(120,190,230,.20) 0%, rgba(120,190,230,.10) 45%, rgba(120,190,230,0) 80%),
    /* Horizontal band across the entire cards row to keep brightness even left-to-right */
    linear-gradient(180deg, rgba(0,8,28,0) 55%, rgba(0,8,28,.22) 70%, rgba(0,8,28,.28) 85%, rgba(0,8,28,.18) 100%);
  pointer-events:none;
  z-index:0;
}
.team-section--mapped .wrap{position:relative;z-index:1}
/* Breathing room between header row and cards */
.team-section--mapped .proj-grid{margin-bottom:clamp(32px,4vw,56px)}
.team-section--mapped .proj-grid__copy{padding-top:clamp(23px,2.25vw,30px)}
.team-section--mapped .proj-grid h2{color:#fff;text-shadow:0 2px 14px rgba(0,8,28,.7), 0 0 24px rgba(0,8,28,.4)}
.team-section--mapped .proj-grid p{color:#eaf2ff;text-shadow:0 2px 10px rgba(0,8,28,.7), 0 0 18px rgba(0,8,28,.4)}
.team-section--mapped .proj-grid .eyebrow{color:var(--cyan-x);font-weight:700;text-shadow:0 2px 10px rgba(0,8,28,.85), 0 0 18px rgba(0,8,28,.7)}
.team-section--mapped .team-member{box-shadow:0 22px 48px -28px rgba(0,0,0,.6)}

/* Very narrow phones: tighten paddings + headline sizes */
@media (max-width: 480px) {
  .hero__inner{padding-top:120px;padding-bottom:32px}
  .hero h1{font-size:clamp(1.7rem, 9vw, 2.3rem)}
  .hero p{font-size:1rem}
  .stat-cell__num{font-size:1.4rem}
  .bio-hero{padding:18px 16px}
  .bio-hero__name{font-size:1.5rem}
  .bio-hero__role{font-size:.9rem}
  .bio-body{padding:24px 12px 0}
  .bio-aside__card{padding:18px}
  .ptr-card{padding:18px}
  .team-lead{padding:0}
  .team-lead__name{font-size:1.1rem}
}


/* ---------- Contact page (editorial layout) ---------- */
.contact-hero-band{margin-bottom:0;padding-top:152px !important;padding-bottom:70px !important;background:linear-gradient(135deg, #0066d8 0%, #1aa8ff 60%, #2dc1ff 100%) !important}
.contact-hero-band .bio-hero__inner{max-width:none;width:100%}

.contact-page{
  position:relative;
  padding-top:clamp(40px,5vw,72px);
  padding-bottom:clamp(64px,8vw,110px);
}
.contact-body{
  display:grid;
  grid-template-columns:minmax(0, 1.55fr) minmax(280px, 1fr);
  gap:clamp(40px,4.5vw,72px);
  align-items:start;
}
@media (max-width:920px){
  .contact-body{grid-template-columns:1fr;gap:32px}
}
.contact-body__lead{
  font-size:1.04rem;line-height:1.75;color:#3a4670;
  margin:0 0 32px;max-width:54ch;
;text-align:justify;text-justify:inter-word;hyphens:none;text-wrap:pretty}

/* Form */
.contact-form{display:grid;gap:18px;max-width:540px}
.cf-field{display:grid;gap:6px}
.cf-field label{
  font-family:var(--font-display);font-weight:700;
  font-size:.7rem;letter-spacing:.20em;text-transform:uppercase;
  color:var(--blue-x);
}
.cf-req{color:var(--cyan-x);margin-left:2px}
.cf-field input,
.cf-field textarea{
  background:#fff;color:var(--blue-x);
  border:1px solid var(--line);border-radius:6px;
  padding:11px 14px;
  font-family:var(--font-body);font-size:.95rem;
  width:100%;outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.cf-field input:focus,
.cf-field textarea:focus{
  border-color:var(--cyan-x);
  box-shadow:0 0 0 2px rgba(0,195,250,.18);
}
.cf-field textarea{resize:vertical;min-height:120px}

.contact-form .btn{align-self:start;justify-self:start;margin-top:6px}

/* Aside */
.contact-aside{display:flex;flex-direction:column;gap:18px}
.contact-aside__card{
  position:relative;background:#fff;
  border:1px solid var(--line);
  padding:24px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.contact-aside__card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--blue-x), var(--cyan-x));
}
.contact-aside__card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 36px -22px rgba(0,30,87,.18);
}
.contact-aside__title{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--blue-xg);
  margin:0 0 16px;
}
.contact-aside__title::before{
  content:"";display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--cyan-x);
}
.contact-aside__list{list-style:none;margin:0;padding:0}
.contact-aside__list li{
  padding:10px 0;
  border-top:1px solid rgba(0,30,87,.10);
  font-size:.92rem;line-height:1.5;color:var(--blue-x);
}
.contact-aside__list li:first-child{border-top:none;padding-top:0}
.contact-aside__list li:last-child{padding-bottom:0}
.contact-aside__list a{
  color:var(--blue-x);text-decoration:none;
  transition:color .2s ease;
}
.contact-aside__list a:hover{color:var(--cyan-x)}
.contact-offices li strong{
  display:block;
  font-family:var(--font-display);font-weight:700;
  font-size:.95rem;color:var(--blue-x);
  letter-spacing:-.005em;
  margin-bottom:3px;
}
.contact-offices li span{
  display:block;font-size:.84rem;line-height:1.45;color:#3a4670;
}

.contact-hero-band .bio-hero__name{font-size:clamp(2rem, 4.2vw, 3.25rem)}

/* Contact hero alignment + chevron decorations */
.contact-hero-band{position:relative;margin-right:0;border-left:0;padding-left:0 !important;padding-right:0 !important}
.contact-hero-band .wrap{margin-left:auto;margin-right:auto;max-width:1240px;padding:0 var(--gutter)}
.contact-hero-band .bio-hero__inner{display:block;padding:0;margin:0}
.contact-hero-band::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(135deg, transparent 28%, rgba(255,255,255,.10) 28%, rgba(255,255,255,.10) 44%, transparent 44%),
    linear-gradient(135deg, transparent 52%, rgba(255,255,255,.08) 52%, rgba(255,255,255,.08) 70%, transparent 70%),
    linear-gradient(135deg, transparent 78%, rgba(0,30,87,.12) 78%, rgba(0,30,87,.12) 92%, transparent 92%) !important;
  pointer-events:none !important;
  z-index:0 !important;
}





/* === Contact page: 9 design enhancements (added) === */

/* 1+sidebar icon styling */
.cai{
  flex-shrink:0;color:var(--cyan-x);
  margin-top:2px;
  align-self:flex-start;
}
.contact-aside__list li{
  display:flex;align-items:flex-start;gap:10px;
}

/* 2. Map silhouette inside Offices card */




/* 4. Cyan accent rule under headline */
.contact-hero-band .bio-hero__rule{
  display:block;width:64px;height:3px;background:var(--cyan-x);
  margin:18px 0 0;
  opacity:.85;
}

/* 5. Privacy reassurance under form */
.contact-form__privacy{
  font-size:.78rem;line-height:1.5;color:#5e6b7d;font-style:italic;
  margin:14px 0 0;max-width:480px;
}

/* 6. Form input focus animation */
.cf-field{position:relative}
.cf-field input,
.cf-field textarea{
  position:relative;
  transition:border-color .25s ease, box-shadow .25s ease;
}
.cf-field input:focus,
.cf-field textarea:focus{
  border-color:var(--cyan-x);
  box-shadow:0 0 0 2px rgba(0,195,250,.18), 0 2px 0 0 var(--cyan-x);
}

/* 7. Accent stripe on each office entry */
.contact-offices li{
  display:flex;align-items:flex-start;gap:10px;
  padding-left:12px;
  border-left:2px solid var(--cyan-x);
}

/* 8. Page-background diagonal ribbons */
.contact-page{position:relative;overflow:hidden}
.contact-page::before{
  content:"";
  position:absolute;top:0;right:-6%;
  width:60%;height:100%;
  background:
    repeating-linear-gradient(60deg, transparent 0 320px, rgba(0,30,87,.04) 320px 321px, transparent 321px 640px),
    repeating-linear-gradient(65deg, transparent 0 280px, rgba(0,30,87,.03) 280px 281px, transparent 281px 560px);
  pointer-events:none;z-index:0;
}
.contact-page > .wrap{position:relative;z-index:1}

/* 9. Closing CTA strip */








/* ---------- Project page: featured pull-quote section ---------- */
.project-feature{
  position:relative;
  background:var(--paper-2);
  padding:clamp(72px,8vw,112px) 0;
  overflow:hidden;
  border-top:1px solid rgba(0,30,87,.06);
  border-bottom:1px solid rgba(0,30,87,.06);
}
/* Big faded "01" ghost behind */
.project-feature__bg{
  position:absolute;
  top:50%;right:6%;left:auto;
  transform:translateY(-46%);
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(11rem,18vw,18rem);
  line-height:.85;letter-spacing:-.05em;
  color:rgba(0,30,87,.045);
  pointer-events:none;
  z-index:0;
  user-select:none;
}
/* Cyan chevron accent at top-right corner — matches site visual language */
.project-feature__chevron{
  position:absolute;top:0;right:0;
  width:280px;height:140px;
  background:linear-gradient(135deg, transparent 38%, var(--cyan-x) 38%, var(--cyan-x) 50%, transparent 50%);
  opacity:.18;
  pointer-events:none;
  z-index:0;
}
.project-feature > .wrap{position:relative;z-index:1;text-align:left}
.project-feature__eyebrow{
  display:block;
  font-family:var(--font-display);font-weight:700;
  font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--blue-xg);
  margin-bottom:28px;
  text-align:left;
  position:relative;
  padding-top:14px;
}
.project-feature__eyebrow::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:40px;height:2px;
  background:var(--cyan-x);
  border-radius:2px;
}
.project-feature__text{
  display:block;
  text-align:left;
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.55rem,2.9vw,2.3rem);
  color:var(--blue-x);
  line-height:1.12;letter-spacing:-.018em;
  margin:0;
  max-width:50ch;
}
.project-feature__text .pf-tag{
  display:inline;
}
.project-feature__lead{
  display:block;
  text-align:left;
  margin:clamp(22px,2.6vw,36px) 0 0;
  max-width:80ch;
  font-size:clamp(1.2rem,1.5vw,1.4rem);
  font-weight:500;
  line-height:1.55;
  color:#3a4670;
}
.partner-row__brand{
  display:inline-flex;
  align-items:center;
}
.partner-row__brand img{
  height:clamp(36px,3vw,46px);
  width:auto;
  display:block;
}

/* Opportunity section CTA — gives the visual moment forward motion */
.project-feature__cta{
  display:flex;
  justify-content:center;
  margin-top:clamp(28px,3.5vw,44px);
}


/* ---- 372 km hero stat (live-site style) ---- */
.kpi-banner{
  max-width:clamp(580px,64vw,924px);
  margin:clamp(36px,5vw,64px) auto 0;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:clamp(20px,2.5vw,36px);
  align-items:start;
  padding:clamp(22px,2.4vw,32px) clamp(18px,2vw,28px);
  background:linear-gradient(135deg, var(--cyan-x) 0%, #00a8db 100%);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  box-shadow:0 14px 40px -14px rgba(0,49,155,.35);
}
/* KPI banner: prep state + visible state for count-up reveal */
.kpi-banner.js-prep{opacity:0;transform:translateY(8px);transition:opacity .6s ease-out, transform .6s ease-out}
.kpi-banner.is-visible{opacity:1;transform:none}

.kpi-feature{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:left;
  gap:8px;
  margin:0;
}
.kpi-feature:not(:last-child)::after{
  content:"";
  position:absolute;
  right:calc(-1 * clamp(10px,1.5vw,24px));
  top:0;
  bottom:0;
  width:1px;
  background:rgba(255,255,255,.9);
}
@media (max-width:820px){
  .kpi-feature::after{display:none}
}
.kpi-feature__num{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.66rem,2.95vw,2.36rem);
  letter-spacing:-.02em;
  color:#fff;
  line-height:1;
  display:inline-flex;
  align-items:baseline;
  gap:.08em;
}
.kpi-feature__suffix{
  font-size:.42em;
  font-weight:700;
  color:var(--blue-x);
  letter-spacing:.02em;
}
.kpi-feature__label{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(.68rem,.85vw,.82rem);
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#fff;
  margin:0;
  line-height:1.25;
  text-align:center;
}
.kpi-feature__suffix{
  font-size:.5em;
  font-weight:300;
  color:rgba(255,255,255,.92);
}
.kpi-feature__plus{
  font-size:.62em;
  font-weight:300;
  color:rgba(255,255,255,.92);
  align-self:center;
  line-height:1;
  margin-left:.05em;
}

@media (max-width:820px){
  .kpi-banner{grid-template-columns:repeat(2,1fr);gap:28px}
}


/* ---------- Project page: cinematic corridor pano band ---------- */
.corridor-band{
  position:relative;
  width:100%;
  height:clamp(220px,28vw,420px);
  overflow:hidden;
  background:#001e57;
}
.corridor-band__photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
}
.corridor-band__photo::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(0deg, rgba(0,30,87,.20) 0%, rgba(0,30,87,0) 25%), linear-gradient(180deg, rgba(0,30,87,.20) 0%, rgba(0,30,87,0) 25%);
  pointer-events:none;
}


/* Infrastructure section: head pattern matches Strategic & Financial Impact */
.infrastructure-section__head{
  max-width:760px;
  margin:0 0 clamp(40px,5vw,64px);
  text-align:left;
}
.infrastructure-section__head .eyebrow{display:block;margin-bottom:28px}
.infrastructure-section__head h2{
  margin:0 0 22px;
  max-width:22ch;
  line-height:1.12;
  letter-spacing:-.018em;
  text-align:left;
}
.infrastructure-section__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0;
  max-width:none;
  text-wrap:balance;hyphens:none;
}


/* ---------- Connecting Changes Everything: combined Financial + Social Impact ---------- */
.connecting-everything{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  padding:clamp(72px,8vw,112px) 0;
  background:#001233;
  color:#fff;
}
.connecting-everything__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 60% at 18% 20%, rgba(0,195,250,.10) 0%, rgba(0,195,250,0) 60%),
    radial-gradient(ellipse 60% 60% at 82% 80%, rgba(0,49,155,.20) 0%, rgba(0,49,155,0) 60%);
}
.connecting-everything__wrap{position:relative;z-index:1}
.connecting-everything__head{
  max-width:760px;
  margin:0 0 clamp(48px,6vw,80px);
}
.connecting-everything__eyebrow{
  display:block;
  margin-bottom:28px;
  color:var(--cyan-x) !important;
}
.connecting-everything h2{
  margin:0 0 22px;
  color:#fff;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
  text-shadow:0 2px 18px rgba(0,8,28,.4);
}
.connecting-everything__lead{
  font-size:1.04rem;line-height:1.78;color:#cfdcf6;
  margin:0;
  max-width:54ch;
  text-wrap:balance;hyphens:none;
}
.connecting-everything__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,5vw,80px);
  position:relative;
}
.connecting-everything__grid::before{
  /* thin vertical separator between columns */
  content:"";
  position:absolute;
  left:50%;top:8%;bottom:8%;
  width:1px;
  background:linear-gradient(180deg, rgba(0,195,250,0) 0%, rgba(0,195,250,.4) 50%, rgba(0,195,250,0) 100%);
  pointer-events:none;
}
.connecting-column__label{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:clamp(28px,3vw,40px);
}
.connecting-list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:clamp(24px,3vw,36px);
}
.connecting-list li{
  display:grid;
  grid-template-columns:24px 1fr;
  gap:18px;
  align-items:start;
}
.connecting-list__mark{
  margin-top:8px;
  width:14px;height:12px;
  background:var(--cyan-x);
  /* Brand right-pointing pentagon arrow */
  clip-path:polygon(0 0, 60% 0, 100% 50%, 60% 100%, 0 100%);
  filter:drop-shadow(0 0 6px rgba(0,195,250,.5));
}
.connecting-list__body h4{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.08rem;
  color:#fff;
  margin:0 0 6px;
  line-height:1.25;
  letter-spacing:-.01em;
}
.connecting-list__body p{
  margin:0;
  font-size:.95rem;
  line-height:1.7;
  color:#cfdcf6;
}
@media (max-width:820px){
  .connecting-everything__grid{grid-template-columns:1fr;gap:48px}
  .connecting-everything__grid::before{display:none}
}


/* Feature card upgrades: numbered markers, kicker rule, hover, dramatic chevron */
.feature__num{
  display:block;
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(1.8rem,2.4vw,2.4rem);
  letter-spacing:-.04em;
  line-height:1;
  background:linear-gradient(135deg, var(--cyan-x) 0%, var(--blue-xg) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:var(--blue-xg);
  margin-bottom:14px;
}
.feature__kicker{
  position:relative;
  padding-bottom:8px;
  margin-bottom:8px !important;
}
.feature__kicker::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:32px;
  height:2px;
  background:var(--cyan-x);
}
.feature{transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.feature:hover{
  transform:translateY(-3px);
  box-shadow:0 26px 56px -22px rgba(0,30,87,.30);
  border-color:rgba(0,195,250,.35);
}
/* Subtle inner dark gradient on photo edge for depth */
.feature__img{
  background-color:#001233;
}
.feature__img > .feature__edge{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg, rgba(0,18,51,0) 70%, rgba(0,18,51,.25) 100%);
}
.feature:nth-child(even) > .feature__img > .feature__edge{
  background:linear-gradient(270deg, rgba(0,18,51,0) 70%, rgba(0,18,51,.25) 100%);
}


/* ---------- COINGT closing CTA section ---------- */
.coingt-cta{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  padding:clamp(72px,8vw,120px) 0;
  background:#fff;
}
.coingt-cta__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 60% at 80% 20%, rgba(0,195,250,.08) 0%, rgba(0,195,250,0) 60%),
    radial-gradient(ellipse 60% 60% at 20% 80%, rgba(0,49,155,.06) 0%, rgba(0,49,155,0) 60%);
}
.coingt-cta__wrap{
  position:relative;
  z-index:1;
}
.coingt-cta__split{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:clamp(12px,1.6vw,26px);
  align-items:start;
}
.coingt-cta__head{
  max-width:560px;
}
.coingt-cta__head .eyebrow{
  display:block;
  margin-bottom:24px;
}
.coingt-cta h2{
  margin:0 auto 22px;
  max-width:none;
  line-height:1.12;
  letter-spacing:-.018em;
}
.coingt-cta__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0;
  max-width:54ch;
  text-wrap:balance;hyphens:none;
}
.coingt-cta__lead strong{
  color:var(--blue-x);
  font-weight:700;
}
.coingt-cta__buttons{
  display:flex;
  flex-wrap:wrap;
  gap:clamp(20px,2.5vw,36px);
  margin-top:clamp(28px,3.5vw,44px);
  padding-left:clamp(36px,3.6vw,56px);
}
.coingt-cta__buttons .btn:nth-child(2){
  margin-left:clamp(8px,1vw,18px);
}

.coingt-cta__media{
  position:relative;
  min-height:clamp(210px,24vw,310px);
  margin-top:46px;
}
.coingt-cta__photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  border-radius:18px;
  box-shadow:0 24px 60px -22px rgba(0,30,87,.32);
}
.coingt-cta__chev{
  position:absolute;
  top:-18px;
  right:-18px;
  width:clamp(48px,5vw,68px);
  height:clamp(38px,4vw,54px);
  background:var(--cyan-x);
  clip-path:polygon(0 0, 60% 0, 100% 50%, 60% 100%, 0 100%);
  filter:drop-shadow(0 10px 24px rgba(0,195,250,.4));
  z-index:2;
}
@media (max-width:820px){
  .coingt-cta__split{grid-template-columns:1fr;gap:36px}
  .coingt-cta__media{min-height:clamp(240px,55vw,340px)}
}
@media (max-width:540px){
  .coingt-cta__buttons{flex-direction:column;align-items:stretch}
  .coingt-cta__buttons .btn{justify-content:center}
}


/* COINGT CTA — same pyramid brand mark as Corridor section, anchored at left edge */
.coingt-cta{position:relative}
.coingt-cta__pyramid{
  position:absolute;
  top:50%;
  left:-1px;
  transform:translateY(-50%);
  width:clamp(150px,13vw,216px);
  height:clamp(320px,32vw,440px);
  background:linear-gradient(135deg, var(--cyan-x) 0%, #0aa6d6 70%, #0892bf 100%);
  clip-path:polygon(0 0, 100% 50%, 0 100%);
  z-index:1;
  pointer-events:none;
  filter:drop-shadow(0 14px 40px rgba(0,195,250,.32));
}


/* The Outcome — atmospheric photo wash backdrop */
.connecting-everything__photo{
  position:absolute;
  inset:0;
  z-index:0;
  background-size:cover;
  background-position:center;
  opacity:.28;
  filter:saturate(1) brightness(1.05);
  pointer-events:none;
}


/* =================================================================
   INVEST PAGE — Hero, Why Now, Structured, Model, Pillars, Waterfall, CTA
   ================================================================= */

/* Hero invest: badge, epigraph, italic emphasis */
.hero-invest{align-items:flex-start}
.hero-invest .hero__inner{padding-bottom:80px}
/* Hero photo: dusk port aerial. Already cool blue, so overlay is light. */
.hero-invest .hero__photo{
  background-position:center 60% !important;
  background-size:cover !important;
  filter:saturate(1.04);
}
.hero-invest .hero__photo::after{
  background:
    linear-gradient(0deg, rgba(0,16,46,.30) 0%, rgba(0,16,46,.10) 10%, rgba(0,16,46,0) 22%),
    linear-gradient(90deg, rgba(0,8,28,.55) 0%, rgba(0,8,28,.42) 30%, rgba(0,12,38,.20) 58%, rgba(0,12,38,.04) 82%, rgba(0,12,38,0) 100%) !important;
}
.invest-badge{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  padding:8px 16px;
  border:1px solid rgba(0,195,250,.45);
  border-radius:2px;
  margin-bottom:32px;
}
.invest-epigraph{
  max-width:760px;
  border-left:2px solid var(--cyan-x);
  padding:6px 0 6px 22px;
  margin:0 0 36px;
  font-style:italic;
  color:rgba(255,255,255,.85);
  font-size:1.12rem;
  line-height:1.6;
  font-family:Georgia,'Times New Roman',serif;
}
.invest-epigraph cite{
  display:block;
  margin-top:10px;
  font-style:normal;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--cyan-x);
}
.invest-epigraph--after{
  margin:8px 0 32px;
}
.hero p.invest-lead{
  font-size:1.12rem;
  line-height:1.8;
  color:#eaf3ff;
  max-width:none;
  margin:0 0 1.2em;
}
.hero p.invest-lead strong{color:var(--cyan-x);font-weight:600}
.hero p.invest-lead:last-of-type{margin-bottom:0}
.invest-h1{
  font-size:clamp(1.9rem,3.9vw,3rem);
  font-weight:700;
  line-height:1.12;
  margin:0 0 28px;
  letter-spacing:-.01em;
  color:#fff;
  white-space:nowrap;
}
@media (max-width:720px){
  .invest-h1{white-space:normal;font-size:clamp(1.6rem,7vw,2.1rem)}
}

/* Why Now bar */
.why-now{
  background:#001233;
  color:#fff;
  padding:clamp(48px,5vw,72px) 0;
  border-top:1px solid rgba(0,195,250,.12);
  border-bottom:1px solid rgba(0,195,250,.12);
}
.why-now__label{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--cyan-x);
  margin-top:0;
  margin-bottom:36px;
  text-align:left;
}
.why-now__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
}
.why-now__item{
  padding:8px 28px;
  border-left:1px solid rgba(0,195,250,.18);
  position:relative;
}
.why-now__item:first-child{border-left:none;padding-left:0}
.why-now__item:last-child{padding-right:0}
.why-now__num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.74rem;
  color:var(--cyan-x);
  letter-spacing:.22em;
  margin-bottom:10px;
}
.why-now__item h3,
.why-now__item h4{
  font-size:1rem;
  font-weight:600;
  margin:0 0 8px;
  line-height:1.3;
  color:#fff;
}
.why-now__item p{
  font-size:.86rem;
  color:rgba(255,255,255,.72);
  line-height:1.55;
  margin:0;
}
@media (max-width:900px){
  .why-now__grid{grid-template-columns:repeat(2,1fr);gap:32px 0}
  .why-now__item:nth-child(3){border-left:none;padding-left:0}
}
@media (max-width:600px){
  .why-now__grid{grid-template-columns:1fr}
  .why-now__item{border-left:none !important;padding-left:0 !important;border-top:1px solid rgba(0,195,250,.18);padding-top:24px}
  .why-now__item:first-child{border-top:none;padding-top:0}
}

/* Structured for Success */
.structured-section{
  background:#fff;
  padding:clamp(72px,8vw,112px) 0;
}
.structured-section__head{
  max-width:760px;
  margin:0;
  text-align:left;
}
.structured-section__head .eyebrow{display:block;margin-bottom:28px}
.structured-section__head h2{
  margin:0 0 22px;
  max-width:18ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.structured-section__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0 0 1.2em;
  max-width:65ch;
  text-wrap:balance;
}
.structured-section__lead:last-child{margin-bottom:0}

/* Investment Model 3-pillar grid */
.model-section{
  padding:clamp(72px,8vw,112px) 0;
}
.model-section__head{
  max-width:760px;
  margin:0 0 clamp(48px,5vw,64px);
}
.model-section__head .eyebrow{display:block;margin-bottom:28px}
.model-section__head h2{
  margin:0 0 22px;
  max-width:22ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.model-section__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  margin:0;
  max-width:54ch;
}
.model-pillars{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(20px,2.5vw,36px);
}
.model-pillar{
  position:relative;
  padding:clamp(28px,3vw,40px);
  background:#fff;
  border:1px solid rgba(0,30,87,.08);
  border-top:3px solid var(--cyan-x);
  border-radius:6px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.model-pillar:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 42px -16px rgba(0,30,87,.22);
}
.model-pillar__num{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.32em;
  color:var(--cyan-x);
  margin-bottom:18px;
}
.model-pillar__tag{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue-x);
  margin-bottom:10px;
}
.model-pillar h4{
  font-size:1.1rem;
  font-weight:700;
  margin:0 0 12px;
  color:var(--blue-x);
  line-height:1.3;
  letter-spacing:-.01em;
}
.model-pillar p{
  font-size:.94rem;
  color:#3a4670;
  line-height:1.65;
  margin:0;
}
@media (max-width:900px){
  .model-pillars{grid-template-columns:1fr;gap:18px}
}

/* NXG Advantage Pillars (dark) */
.pillars-section{
  padding:clamp(72px,8vw,112px) 0;
}
.pillars-section__head{
  max-width:760px;
  margin:0 0 clamp(48px,5vw,64px);
}
.pillars-section__head .eyebrow{display:block;margin-bottom:28px}
.pillars-section__head h2{
  margin:0 0 22px;
  color:#fff;
  max-width:22ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.pillars-section__lead{
  font-size:1.04rem;line-height:1.78;color:#cfdcf6;
  margin:0;
  max-width:54ch;
}
.advantage-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:clamp(20px,2.5vw,36px);
}
.advantage-pillar{
  position:relative;
  padding:clamp(32px,3.5vw,44px);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-top:3px solid var(--cyan-x);
  border-radius:6px;
}
.advantage-pillar__num{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  color:var(--cyan-x);
  margin-bottom:18px;
}
.advantage-pillar h3{
  font-size:1.5rem;
  font-weight:700;
  margin:0 0 6px;
  color:#fff;
  line-height:1.2;
}
.advantage-pillar__tag{
  display:block;
  font-family:Georgia,serif;
  font-style:italic;
  font-size:.94rem;
  color:var(--cyan-x);
  margin-bottom:24px;
}
.advantage-pillar ul{
  list-style:none;
  padding:0;
  margin:0;
}
.advantage-pillar li{
  padding:14px 0;
  border-top:1px solid rgba(255,255,255,.10);
  font-size:.94rem;
  color:rgba(255,255,255,.85);
  line-height:1.6;
}
.advantage-pillar li:first-child{border-top:none;padding-top:0}
.advantage-pillar li strong{
  display:block;
  color:#fff;
  font-family:var(--font-display);
  font-size:.82rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:6px;
}
@media (max-width:900px){
  .advantage-grid{grid-template-columns:1fr;gap:18px}
}

/* Value Creation Waterfall */
.waterfall-section{
  padding:clamp(56px,6vw,84px) 0;
}
.waterfall-section__head{
  max-width:760px;
  margin:0 0 clamp(32px,3.5vw,44px);
}
.waterfall-section__head .eyebrow{display:block;margin-bottom:18px}
.waterfall-section__head h2{
  margin:0 0 14px;
  color:#fff;
  max-width:22ch;
  line-height:1.12;
  letter-spacing:-.018em;
}
.waterfall-section__lead{
  font-size:1.04rem;line-height:1.78;color:#cfdcf6;
  margin:0;
  max-width:54ch;
}
.waterfall{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.wf-step{
  display:grid;
  grid-template-columns:80px 1fr 400px;
  gap:28px;
  align-items:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-left:3px solid var(--cyan-x);
  padding:18px 28px;
  border-radius:0 6px 6px 0;
  transition:background .2s ease;
}
.wf-step:hover{background:rgba(255,255,255,.07)}
.wf-step__num{
  font-family:var(--font-display);
  font-size:2.6rem;
  font-weight:300;
  color:var(--cyan-x);
  line-height:1;
  letter-spacing:-.02em;
}
.wf-step__main h3,
.wf-step__main h4{
  font-size:1.25rem;
  font-weight:700;
  margin:0 0 6px;
  color:#fff;
  letter-spacing:-.01em;
}
.wf-step__main p{
  font-size:.92rem;
  color:rgba(255,255,255,.72);
  line-height:1.55;
  margin:0;
}
.wf-step__unlock{
  border-left:1px solid rgba(255,255,255,.12);
  padding-left:20px;
}
.wf-step__unlock-label{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:6px;
}
.wf-step__unlock p{
  font-size:.9rem;
  color:rgba(255,255,255,.85);
  line-height:1.55;
  margin:0;
}
.wf-step--final{
  border-left-color:var(--cyan-x);
  background:linear-gradient(135deg, rgba(0,195,250,.14), rgba(0,195,250,.04));
}
@media (max-width:900px){
  .wf-step{grid-template-columns:1fr;gap:14px;padding:22px 22px}
  .wf-step__unlock{border-left:none;border-top:1px solid rgba(255,255,255,.12);padding-left:0;padding-top:14px}
}

/* Invest CTA closer */
.invest-cta{
  padding:clamp(72px,8vw,112px) 0;
  background:var(--grad-deep);
  text-align:center;
  color:#fff;
}
.invest-cta .eyebrow{display:inline-block;margin-bottom:24px}
.invest-cta h2{
  margin:0 0 18px;
  max-width:none;
  text-align:center;
  color:#fff;
}
.invest-cta__lead{
  max-width:640px;
  margin:0 auto;
  color:#cfdcf6;
  font-size:1.08rem;
  line-height:1.6;
  text-align:center;
}
.invest-cta__buttons{
  display:flex;
  justify-content:center;
  margin-top:32px;
}
.invest-cta__fine{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(207,220,246,.7);
  margin-top:36px;
}

/* ==========================================================================
   Downloads page
   ========================================================================== */
.hero-downloads{align-items:flex-start}
.dl-group__eyebrow{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-xg);
  margin-bottom:14px;
  position:relative;
  padding-top:14px;
}
.dl-group__eyebrow::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:40px;height:2px;
  background:var(--cyan-x);
  border-radius:2px;
}
.section--ink .dl-group__eyebrow{color:var(--cyan-x)}
.dl-group__title{
  font-size:clamp(1.7rem,3vw,2.4rem);
  font-weight:700;
  margin:0 0 12px;
  letter-spacing:-.01em;
}
.dl-group__lead{
  max-width:60ch;
  margin:0 0 36px;
  color:#3a4670;
  font-size:1.05rem;
  line-height:1.7;
}
.section--mist .dl-group__lead{color:#3a4670}
.dl-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:18px;
}
.dl-card{
  display:flex;
  align-items:flex-start;
  gap:18px;
  padding:24px 26px;
  background:#fff;
  border:1px solid rgba(0,30,87,.08);
  border-radius:6px;
  text-decoration:none;
  color:var(--ink);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position:relative;
}
.dl-card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(0,30,87,.10);
  border-color:rgba(0,195,250,.45);
}
.section--mist .dl-card{background:#fff}
.dl-card__icon{
  flex:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;height:56px;
  background:linear-gradient(180deg,#001e57,#00319b);
  color:#fff;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.74rem;
  letter-spacing:.18em;
  border-radius:3px;
  position:relative;
}
.dl-card__icon::before{
  content:"";
  position:absolute;top:0;right:0;
  width:0;height:0;
  border-style:solid;
  border-width:0 12px 12px 0;
  border-color:transparent #fff transparent transparent;
}
.dl-card[data-protected="true"] .dl-card__icon{
  background:linear-gradient(180deg,#001e57,#0b2a72);
}
.dl-card__body{flex:1;min-width:0}
.dl-card__title{
  font-size:1.12rem;
  font-weight:700;
  margin:0 0 6px;
  color:var(--ink);
  letter-spacing:-.005em;
}
.dl-card__desc{
  margin:0 0 10px;
  color:#3a4670;
  font-size:.95rem;
  line-height:1.55;
}
.dl-card__meta{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#6e798f;
}
.dl-card__arrow{
  flex:none;
  align-self:center;
  color:var(--cyan-x);
  font-size:1.2rem;
  font-weight:700;
  transition:transform .18s ease;
}
.dl-card:hover .dl-card__arrow{transform:translateX(4px)}
.dl-cta{text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.dl-cta h2{margin:0}
.dl-cta p{margin:0}
.dl-cta .btn{margin-top:8px}

/* Downloads — restricted (qualified investor) section */
.dl-restricted__list{
  list-style:none;
  padding:0;
  margin:clamp(28px,3vw,40px) 0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:clamp(10px,1.2vw,16px) clamp(28px,3vw,48px);
  max-width:760px;
}
.dl-restricted__list li{
  position:relative;
  padding-left:22px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.95rem;
  line-height:1.45;
  color:var(--ink);
}
.dl-restricted__list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.5em;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--cyan-x);
  box-shadow:0 0 0 4px rgba(0,229,255,.18);
}
.dl-restricted__btn{
  margin-top:clamp(12px,1.6vw,20px);
}
@media (max-width:680px){
  .dl-restricted__list{grid-template-columns:1fr}
}

/* Downloads cover-style hero (mirrors PPTX slide 1) */
.hero-downloads-cover{
  position:relative;
  min-height:78vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:#fff;
  background:#000;
}
.hero-downloads-cover__photo{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center 30%;
  z-index:0;
}
.hero-downloads-cover__veil{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.12) 0%,rgba(0,0,0,.5) 70%,rgba(0,0,0,.78) 100%);
  z-index:1;
}
.hero-downloads-cover .hero-top{position:relative;z-index:3}
.hero-downloads-cover__inner{
  position:relative;z-index:2;
  width:100%;
  max-width:880px;
  padding:0 var(--gutter);
  text-align:left;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.hero-downloads-cover__mark{
  width:clamp(150px,18.5vw,235px);
  height:auto;
  display:block;
  margin:0 auto 28px;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.45));
}
.hero-downloads-cover__rule{
  display:block;
  width:min(520px,70%);
  height:1px;
  background:rgba(255,255,255,.85);
  margin:0 auto 22px;
}
.hero-downloads-cover__title{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(1.7rem,3.5vw,2.8rem);
  letter-spacing:.04em;
  margin:0 0 36px;
  color:#fff;
}
.hero-downloads-cover__kicker{
  margin:0;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.78rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#fff;
  display:inline-flex;
  align-items:center;
  gap:18px;
}
.hero-downloads-cover__star{
  color:var(--cyan-x);
  font-size:.7rem;
  line-height:1;
}
@media (max-width:720px){
  .hero-downloads-cover{min-height:70vh}
  .hero-downloads-cover__title{margin-bottom:24px}
}

/* Downloads card wrapper (EN card + ES sibling link) */
.dl-grid{align-items:start}
.dl-card-wrap{position:relative}
.dl-card-wrap .dl-card{padding-right:54px}
.dl-card__es{
  position:absolute;
  top:18px;right:18px;
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-weight:700;
  font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue-x);
  border:1.5px solid rgba(0,30,87,.35);
  padding:5px 10px 5px 10px;border-radius:var(--pill, 999px);
  background:rgba(255,255,255,.85);
  text-decoration:none;
  transition:border-color .2s ease, color .2s ease, background .2s ease;
  z-index:2;
}
.dl-card__es-arrow{
  display:inline-block;
  font-size:.78rem;font-weight:600;line-height:1;letter-spacing:0;
  transition:transform .2s ease;
}
.dl-card__es:hover{
  border-color:var(--cyan-x);
  background:var(--cyan-x);
  color:var(--blue-x);
}
.dl-card__es:hover .dl-card__es-arrow{transform:translateX(2px)}

/* Home hero: deeper blue-black left gradient that fades into photo */
.hero-home .hero__photo::after{
  background:
    linear-gradient(180deg,
      rgba(0,15,46,0) 0%,
      rgba(0,15,46,.10) 32%,
      rgba(0,15,46,.16) 55%,
      rgba(0,15,46,.08) 78%,
      rgba(0,15,46,0) 100%),
    linear-gradient(90deg,
      rgba(0,10,28,.35) 0%,
      rgba(0,16,46,.22) 28%,
      rgba(0,22,62,.10) 52%,
      rgba(0,30,87,.03) 75%,
      rgba(0,30,87,0) 92%);
}

/* Home hero h1: tiny text-shadow to support the headline over bright photo bands */
.hero-home{align-items:flex-start}
.hero-home h1{text-shadow:0 2px 6px rgba(0,8,28,.55), 0 1px 2px rgba(0,8,28,.5)}

/* Home hero subhead + body: subtle shadow support over bright photo bands */
.hero-home p.hero__sub{text-shadow:0 1px 4px rgba(0,8,28,.55), 0 1px 2px rgba(0,8,28,.45)}
.hero-home .hero__copy > p{text-shadow:0 1px 3px rgba(0,8,28,.45)}

/* Structured for Success — 4-tile pillar grid */
.structured-section__head{margin-bottom:clamp(48px,5vw,72px) !important}
.structured-pillars{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  border-top:1px solid rgba(0,30,87,.10);
}
.structured-pillar{
  padding:36px 28px 32px;
  border-right:1px solid rgba(0,30,87,.10);
  position:relative;
}
.structured-pillar:last-child{border-right:none}
.structured-pillar::before{
  content:"";
  position:absolute;top:0;left:0;
  width:48px;height:3px;
  background:var(--cyan-x);
}
.structured-pillar__num{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.74rem;
  letter-spacing:.22em;
  color:var(--cyan-x);
  margin-bottom:14px;
}
.structured-pillar__title{
  font-size:1.18rem;
  font-weight:700;
  margin:0 0 12px;
  color:var(--ink);
  letter-spacing:-.005em;
}
.structured-pillar__desc{
  margin:0;
  font-size:.97rem;
  line-height:1.7;
  color:#3a4670;
}
@media (max-width:980px){
  .structured-pillars{grid-template-columns:repeat(2, 1fr)}
  .structured-pillar:nth-child(2){border-right:none}
  .structured-pillar:nth-child(1),
  .structured-pillar:nth-child(2){border-bottom:1px solid rgba(0,30,87,.10)}
}
@media (max-width:600px){
  .structured-pillars{grid-template-columns:1fr}
  .structured-pillar{border-right:none;border-bottom:1px solid rgba(0,30,87,.10)}
  .structured-pillar:last-child{border-bottom:none}
}

/* Structured pillars: animated entrance */
.structured-pillar{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
}
.structured-pillar.is-visible{
  opacity:1;
  transform:translateY(0);
}
.structured-pillar:nth-child(1){transition-delay:0s}
.structured-pillar:nth-child(2){transition-delay:.12s}
.structured-pillar:nth-child(3){transition-delay:.24s}
.structured-pillar:nth-child(4){transition-delay:.36s}
.structured-pillar::before{
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .8s cubic-bezier(.2,.7,.2,1) .15s;
}
.structured-pillar.is-visible::before{transform:scaleX(1)}
@media (prefers-reduced-motion:reduce){
  .structured-pillar,.structured-pillar::before{
    opacity:1 !important;transform:none !important;transition:none !important;
  }
}

/* ==========================================================================
   Investment Model — three streams, one rail (stream-bar composition)
   ========================================================================== */
.model-section{padding:clamp(80px,9vw,128px) 0}
.model-section__head{
  max-width:760px;margin:0 0 clamp(56px,6vw,84px);
  text-align:left;
}
.model-section__head .eyebrow{display:block;margin-bottom:28px}
.model-section__head h2{margin:0 0 22px;line-height:1.1;letter-spacing:-.018em;max-width:18ch}
.model-section__lead{
  font-size:1.04rem;line-height:1.78;color:#3a4670;
  max-width:54ch;margin:0;
}

.model-flow{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  padding:0 0 110px;
}
.model-stream{
  position:relative;
  padding:36px 28px 28px 36px;
  background:#fff;
  border:1px solid rgba(0,30,87,.06);
  border-radius:8px;
  box-shadow:0 14px 40px -28px rgba(0,30,87,.18);
  display:flex;flex-direction:column;
  min-height:380px;
}
/* The "stream bar" — vertical accent on the left edge with gradient */
.model-stream::before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:6px;
  border-radius:8px 0 0 8px;
  background:linear-gradient(180deg,var(--cyan-x) 0%,var(--blue-xg) 100%);
}
.model-stream[data-stream="01"]::before{
  background:linear-gradient(180deg,#9eeaff 0%,var(--cyan-x) 100%);
}
.model-stream[data-stream="02"]::before{
  background:linear-gradient(180deg,var(--cyan-x) 0%,var(--blue-xg) 50%,var(--blue-x) 100%);
}
.model-stream[data-stream="03"]::before{
  background:linear-gradient(180deg,var(--blue-xg) 0%,var(--blue-x) 100%);
}

.model-stream__num{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(2.4rem,4vw,3.4rem);
  line-height:1;
  letter-spacing:-.02em;
  background:linear-gradient(180deg,var(--blue-x) 0%,var(--cyan-x) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--blue-x);
  margin:0 0 22px;
  display:block;
}

.model-stream__tag{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:10px;
}
.model-stream__title{
  font-size:1.5rem;
  font-weight:700;
  margin:0 0 14px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.model-stream__desc{
  margin:0 0 28px;
  font-size:.97rem;
  line-height:1.7;
  color:#3a4670;
  max-width:36ch;
}
.model-stream__phase{
  margin-top:auto;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-x);
  align-self:flex-start;
  padding-top:18px;
  border-top:1px solid rgba(0,30,87,.10);
  width:100%;
}
.model-stream__phase::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--cyan-x);
  flex:none;
}

/* Hide old artifacts */
.model-stream__rule,.model-stream__node{display:none}

/* The integrated return rail with label */
.model-rail{
  position:absolute;
  left:0;right:0;
  bottom:54px;
  height:3px;
  background:linear-gradient(90deg,
    rgba(0,49,155,0) 0%,
    var(--blue-xg) 12%,
    var(--cyan-x) 50%,
    var(--blue-xg) 88%,
    rgba(0,49,155,0) 100%);
  border-radius:3px;
  transform:scaleX(0);
  transform-origin:center;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1) .3s;
}
.model-rail-label{
  position:absolute;
  left:50%;bottom:18px;
  transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:14px;
  background:#f3f6fc;
  padding:0 16px;
  opacity:0;
  transition:opacity .5s ease 1.2s;
}
.model-rail-label__line{display:none}
.model-rail-label__text{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--blue-x);
}

.model-flow.is-visible .model-rail{transform:scaleX(1)}
.model-flow.is-visible .model-rail-label{opacity:1}

@media (max-width:980px){
  .model-flow{grid-template-columns:1fr;gap:20px;padding-bottom:32px}
  .model-rail,.model-rail-label{display:none}
  .model-stream{min-height:0}
}
@media (prefers-reduced-motion:reduce){
  .model-rail{transform:scaleX(1) !important;transition:none !important}
  .model-rail-label{opacity:1 !important}
}

/* Value Creation Pathway — paper variant (inverts colors from ink default) */
.waterfall-section.section--paper{
  background:#fff;
}
.waterfall-section.section--paper .waterfall-section__head h2{color:var(--blue-x)}
.waterfall-section.section--paper .waterfall-section__head .eyebrow{color:var(--blue-xg)}
.waterfall-section.section--paper .waterfall-section__lead{color:#3a4670}
.waterfall-section.section--paper .wf-step{
  border-top:1px solid rgba(0,30,87,.10);
  border-bottom:1px solid rgba(0,30,87,.0);
}
.waterfall-section.section--paper .wf-step:last-child{
  border-bottom:1px solid rgba(0,30,87,.10);
}
.waterfall-section.section--paper .wf-step__num{
  color:var(--cyan-x);
  background:linear-gradient(180deg,var(--blue-x) 0%,var(--cyan-x) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.waterfall-section.section--paper .wf-step__main h3,
.waterfall-section.section--paper .wf-step__main h4{color:var(--ink)}
.waterfall-section.section--paper .wf-step__main p{color:#3a4670}
.waterfall-section.section--paper .wf-step__unlock{
  background:rgba(0,195,250,.06);
  border:1px solid rgba(0,195,250,.18);
}
.waterfall-section.section--paper .wf-step__unlock-label{color:var(--blue-xg)}
.waterfall-section.section--paper .wf-step__unlock p{color:var(--ink)}

/* ==========================================================================
   NXG Advantage — three parallel pillars (no sequence)
   ========================================================================== */
.advantage-trio{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  position:relative;
}
.adv-pillar{
  position:relative;
  padding:0 36px;
  display:flex;flex-direction:column;
}
.adv-pillar + .adv-pillar{
  border-left:1px solid rgba(0,195,250,.18);
}
.adv-pillar__word{
  font-family:var(--font-display);
  font-weight:200;
  font-size:clamp(2.6rem,4.4vw,3.8rem);
  line-height:1;
  letter-spacing:-.02em;
  color:#fff;
  margin:0 0 18px;
  display:block;
}
.adv-pillar__rule{
  display:block;
  width:48px;height:2px;
  background:var(--cyan-x);
  margin:0 0 18px;
  border-radius:2px;
}
.adv-pillar__kicker{
  display:block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:14px;
}
.adv-pillar__title{
  font-size:1.15rem;
  font-weight:700;
  line-height:1.35;
  margin:0 0 16px;
  color:#fff;
  letter-spacing:-.005em;
  max-width:24ch;
}
.adv-pillar__desc{
  margin:0 0 24px;
  font-size:.95rem;
  line-height:1.7;
  color:#cfdcf6;
}
.adv-pillar__list{
  list-style:none;
  margin:auto 0 0;
  padding:18px 0 0;
  border-top:1px solid rgba(0,195,250,.12);
  display:flex;flex-direction:column;gap:8px;
}
.adv-pillar__list li{
  position:relative;
  padding-left:18px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.78rem;
  letter-spacing:.04em;
  color:#9ec1ff;
  line-height:1.45;
}
.adv-pillar__list li::before{
  content:"";
  position:absolute;
  left:0;top:.55em;
  width:8px;height:1px;
  background:var(--cyan-x);
}
@media (max-width:980px){
  .advantage-trio{grid-template-columns:1fr;gap:48px}
  .adv-pillar{padding:0}
  .adv-pillar + .adv-pillar{border-left:none;border-top:1px solid rgba(0,195,250,.18);padding-top:48px}
}

/* Value Creation Pathway — timing chip on each step */
.wf-step__when{
  display:inline-block;
  margin-left:22px;
  padding:3px 10px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.62rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  vertical-align:middle;
  border-radius:999px;
}
.waterfall-section.section--paper .wf-step__when{
  color:var(--blue-xg);
  border:1px solid rgba(0,49,155,.30);
  background:rgba(0,195,250,.08);
}
.waterfall-section:not(.section--paper) .wf-step__when{
  color:var(--cyan-x);
  border:1px solid rgba(0,195,250,.40);
  background:rgba(0,195,250,.10);
}
@media (max-width:780px){
  .wf-step__when{margin-left:0;margin-top:6px;display:inline-block}
}

/* ==========================================================================
   Investment Model — Lifecycle bar chart
   ========================================================================== */
.lifecycle{
  position:relative;
  margin:0 0 56px;
  padding:0 0 60px;
}
.lifecycle__axis{
  display:grid;
  grid-template-columns:200px repeat(4,1fr);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--blue-x);
  padding-bottom:18px;
  border-bottom:2px solid rgba(0,30,87,.18);
  margin-bottom:24px;
}
.lifecycle__axis span:first-child{grid-column:1}
.lifecycle__axis span:nth-child(2){grid-column:2;text-align:left}
.lifecycle__axis span:nth-child(3){grid-column:3;text-align:left}
.lifecycle__axis span:nth-child(4){grid-column:4;text-align:left}
.lifecycle__axis span:nth-child(5){grid-column:5;text-align:left}
.lifecycle__grid{
  position:absolute;
  top:46px;
  bottom:60px;
  left:200px;
  right:0;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  pointer-events:none;
  z-index:0;
}
.lifecycle__grid span{
  border-left:1px dashed rgba(0,30,87,.10);
}
.lifecycle__grid span:first-child{border-left-color:rgba(0,30,87,.20)}
.lifecycle__row{
  display:grid;
  grid-template-columns:200px 1fr;
  align-items:center;
  gap:0;
  padding:14px 0;
  position:relative;
  z-index:1;
}
.lifecycle__label{
  display:flex;flex-direction:column;gap:4px;
  padding-right:24px;
}
.lifecycle__name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.25rem;
  color:var(--ink);
  letter-spacing:-.01em;
}
.lifecycle__tag{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.68rem;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:var(--cyan-x);
}
.lifecycle__track{
  position:relative;
  height:36px;
  display:flex;
  align-items:center;
}
.lifecycle__band{
  width:100%;
  height:32px;
  border-radius:4px;
  position:relative;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.1s cubic-bezier(.22,.7,.25,1);
}
.lifecycle.is-visible .lifecycle__band{clip-path:inset(0 0 0 0)}
.lifecycle.is-visible .lifecycle__row[data-stream="infra"] .lifecycle__band{transition-delay:.18s}
.lifecycle.is-visible .lifecycle__row[data-stream="advisory"] .lifecycle__band{transition-delay:.36s}
.lifecycle__band--land{
  background:linear-gradient(90deg,
    var(--cyan-x) 0%,
    var(--cyan-x) 32%,
    rgba(0,195,250,.65) 52%,
    rgba(0,195,250,.18) 78%,
    rgba(0,195,250,.04) 94%,
    transparent 100%);
  box-shadow:0 4px 14px -8px rgba(0,195,250,.5);
}
.lifecycle__band--infra{
  background:linear-gradient(90deg,
    rgba(0,49,155,.06) 0%,
    rgba(0,49,155,.14) 22%,
    rgba(0,49,155,.55) 40%,
    var(--blue-xg) 60%,
    var(--blue-x) 100%);
  box-shadow:0 4px 14px -8px rgba(0,49,155,.5);
}
.lifecycle__band--advisory{
  height:18px;
  background:linear-gradient(90deg,
    var(--blue-x) 0%,
    var(--blue-x) 35%,
    rgba(0,30,87,.70) 55%,
    rgba(0,30,87,.40) 70%,
    rgba(0,30,87,.18) 85%,
    rgba(0,30,87,.06) 100%);
  opacity:.95;
  box-shadow:0 3px 10px -6px rgba(0,30,87,.4);
}
.lifecycle__rail{
  position:absolute;
  left:0;right:0;
  bottom:4px;
  height:6px;
  border-radius:6px;
  background:linear-gradient(90deg,
    var(--blue-x) 0%,
    var(--blue-xg) 14%,
    var(--cyan-x) 50%,
    var(--blue-xg) 86%,
    var(--blue-x) 100%);
  box-shadow:0 8px 22px -8px rgba(0,49,155,.55), 0 0 0 1px rgba(0,195,250,.22);
}
.lifecycle__rail-label{
  position:absolute;
  left:50%;bottom:-10px;
  transform:translateX(-50%);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg,var(--blue-x),var(--blue-xg));
  padding:9px 22px;
  border-radius:999px;
  box-shadow:0 8px 22px -8px rgba(0,49,155,.55), 0 0 0 1px rgba(0,195,250,.22);
  z-index:2;
}
.model-explainers{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  margin-top:8px;
}
.model-explainer h3,
.model-explainer h4{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue-xg);
  margin:0 0 12px;
}
.model-explainer p{
  font-size:.96rem;
  line-height:1.7;
  color:#3a4670;
  margin:0;
}
@media (max-width:980px){
  .lifecycle__axis,.lifecycle__row{grid-template-columns:1fr}
  .lifecycle__axis{display:flex;justify-content:space-between}
  .lifecycle__axis span{grid-column:auto !important;text-align:left !important}
  .lifecycle__grid{display:none}
  .lifecycle__rail,.lifecycle__rail-label{position:static;transform:none;text-align:center;margin-top:24px}
  .model-explainers{grid-template-columns:1fr;gap:24px}
}

/* ==========================================================================
   NXG Advantage — Manifesto
   ========================================================================== */
.manifesto{
  display:flex;
  flex-direction:column;
}
.manifesto__row{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:48px;
  padding:48px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  align-items:start;
}
.manifesto__row:first-child{padding-top:8px}
.manifesto__row:last-child{border-bottom:none;padding-bottom:8px}
.manifesto__word{
  font-family:var(--font-display);
  font-weight:200;
  font-size:clamp(2.2rem,3.6vw,3.2rem);
  line-height:.95;
  letter-spacing:-.03em;
  color:#fff;
  background:linear-gradient(180deg,#fff 0%,rgba(0,195,250,.85) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.manifesto__body{
  display:flex;flex-direction:column;
  max-width:60ch;
}
.manifesto__claim{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.2rem,1.7vw,1.45rem);
  line-height:1.35;
  margin:0 0 18px;
  color:#fff;
  letter-spacing:-.005em;
}
.manifesto__detail{
  font-size:1rem;
  line-height:1.72;
  color:#cfdcf6;
  margin:0 0 22px;
}
.manifesto__proof{
  display:flex;flex-wrap:wrap;gap:8px 22px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--cyan-x);
  padding-top:14px;
  border-top:1px solid rgba(0,195,250,.15);
}
.manifesto__proof span{position:relative}
.manifesto__proof span::after{
  content:"·";
  margin-left:22px;
  color:rgba(0,195,250,.5);
  position:absolute;
  right:-15px;
}
.manifesto__proof span:last-child::after{content:""}
@media (max-width:780px){
  .manifesto__row{grid-template-columns:1fr;gap:18px;padding:36px 0}
  .manifesto__proof{font-size:.66rem}
  .manifesto__proof span::after{display:none}
  .manifesto__proof span{padding:2px 8px;border:1px solid rgba(0,195,250,.18);border-radius:999px}
}

/* JPM banner — dark variant with white type, sits below the quote */
.jpm-section .jpm-quote{margin-bottom:8px}
/* (older .jpm-banner--dark dark-box rules — superseded by hero stat treatment below) */

/* Why Now — banner-paragraph variant */
.why-now--banner{
  padding:clamp(56px,6vw,84px) 0;
  border-top:1px solid rgba(0,195,250,.12);
  border-bottom:1px solid rgba(0,195,250,.12);
  background:#001233;
}
.why-now--banner .why-now__label{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.82rem;
  color:var(--cyan-x);
  margin-top:0;
  margin-bottom:24px;
  position:relative;
  padding-top:14px;
}
.why-now--banner .why-now__label::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:40px;height:2px;
  background:var(--cyan-x);
  border-radius:2px;
}
.why-now__statement{
  max-width:1080px;
  margin:0;
  font-size:clamp(.98rem,1.3vw,1.12rem);
  line-height:1.65;
  color:#cfdcf6;
  font-weight:400;
  letter-spacing:-.005em;
}
.why-now__statement strong{
  color:#fff;
  font-weight:700;
}

/* Value Creation Pathway — wf-step scroll-in animation */
.wf-step{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .65s cubic-bezier(.2,.7,.2,1), transform .65s cubic-bezier(.2,.7,.2,1), background .2s ease;
}
.wf-step.is-visible{
  opacity:1;
  transform:translateY(0);
}
.wf-step:nth-child(1){transition-delay:0s,0s,0s}
.wf-step:nth-child(2){transition-delay:.08s,.08s,0s}
.wf-step:nth-child(3){transition-delay:.16s,.16s,0s}
.wf-step:nth-child(4){transition-delay:.24s,.24s,0s}
.wf-step:nth-child(5){transition-delay:.32s,.32s,0s}
@media (prefers-reduced-motion:reduce){
  .wf-step{opacity:1 !important;transform:none !important;transition:background .2s ease !important}
}

/* Why Now intro lead — sits above the 4-forces statement */
.why-now__intro{
  max-width:60ch;
  margin:0 0 22px;
  font-size:1.1rem;
  line-height:1.7;
  color:#fff;
  font-weight:500;
  letter-spacing:-.005em;
}
.why-now__intro strong{color:var(--cyan-x);font-weight:700}
.why-now--banner .why-now__intro + .why-now__statement{
  padding-top:22px;
  border-top:1px solid rgba(0,195,250,.15);
}

/* Bolivar standalone moment between hero and Why Now */
/* Global Presence section (Contact page) */
.global-presence{padding:clamp(56px,6vw,84px) 0}
.global-presence__title{
  font-size:clamp(1.6rem,2.8vw,2.2rem);
  font-weight:700;
  margin:0 0 clamp(36px,4vw,56px);
  color:var(--blue-x);
  letter-spacing:-.018em;
  line-height:1.12;
}
.global-presence__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.office-card{
  background:#fff;
  border:1px solid rgba(0,30,87,.08);
  border-radius:8px;
  padding:28px 24px;
  position:relative;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.office-card__rule{
  display:block;
  width:32px;height:2px;
  background:var(--cyan-x);
  margin-bottom:16px;
  border-radius:2px;
}
.office-card__city{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.15rem;
  margin:0 0 10px;
  color:var(--ink);
  letter-spacing:-.005em;
}
.office-card__addr{
  margin:0;
  font-size:.9rem;
  line-height:1.7;
  color:#3a4670;
}
.office-card:hover{
  transform:translateY(-2px);
  border-color:rgba(0,195,250,.30);
  box-shadow:0 14px 28px -16px rgba(0,30,87,.18);
}
@media (max-width:980px){.global-presence__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.global-presence__grid{grid-template-columns:1fr}}

/* Bio page — body max-width for editorial readability */
.bio-body__main p{max-width:60ch}

/* Bio page header polish — give the 01 / role / name composition more presence */
.bio-card__head{
  margin-bottom:32px;
}
.bio-card__num{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(2.2rem,3vw,2.8rem);
  line-height:1;
  letter-spacing:-.02em;
  background:linear-gradient(180deg,var(--cyan-x) 0%,var(--blue-xg) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--blue-xg);
  margin-bottom:6px;
}
.bio-card__role{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan-x);
  margin-bottom:14px;
}
.bio-card__name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,3.2vw,2.9rem);
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--blue-x);
  margin:0 0 18px;
}
.bio-card__rule{
  display:block;
  width:60px;height:3px;
  background:linear-gradient(90deg,var(--cyan-x),var(--blue-xg));
  border-radius:3px;
  margin-bottom:0;
}

/* Project page funding bridge — compact handoff to Coingt */
.coingt-bridge{
  padding:clamp(44px,4.8vw,68px) 0 clamp(64px,6.6vw,92px);
  border-top:1px solid rgba(0,30,87,.06);
}
.coingt-bridge__wrap{
  /* inherit .wrap max-width so eyebrow aligns with site logo */
}
.coingt-bridge__header{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  gap:24px;
  margin-bottom:clamp(44px,4.8vw,64px);
}
.coingt-bridge__header .eyebrow{
  grid-column:1;
  justify-self:start;
  margin-bottom:0;
}
.coingt-bridge__phase{
  grid-column:2;
  justify-self:center;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 18px;
  border:1px solid rgba(0,30,87,.16);
  border-radius:999px;
  background:rgba(0,30,87,.04);
  font-family:var(--font-display);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--blue-x);
  white-space:nowrap;
}
.coingt-bridge__phase-dot{
  display:inline-block;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--cyan-x);
  box-shadow:0 0 0 4px rgba(0,229,255,.18);
  flex:0 0 auto;
}
.coingt-bridge__phase-text{
  display:inline;
}
.coingt-bridge__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.7rem,2.8vw,2.4rem);
  line-height:1.18;
  color:var(--blue-x);
  margin:0 0 22px;
  letter-spacing:-.012em;
  text-align:left;
  max-width:24ch;
  position:relative;
  padding-left:clamp(18px,1.8vw,26px);
  border-left:3px solid var(--cyan-x);
}
.coingt-bridge__title strong{
  background:linear-gradient(135deg,var(--blue-xg),var(--cyan-x));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--blue-xg);
  font-weight:800;
}
.coingt-bridge__lead{
  font-size:1.04rem;
  line-height:1.7;
  color:#3a4670;
  max-width:64ch;
  margin:0 0 24px;
  text-align:left;
}
.coingt-bridge__cta{
  display:flex;
  justify-content:flex-start;
  margin-top:clamp(20px,2.4vw,30px);
}
.coingt-bridge__phase{position:relative}
.coingt-bridge__mark{
  position:absolute;
  top:calc(100% + 18px);
  left:50%;
  transform:translateX(-50%);
  width:clamp(96px,9.5vw,124px);
  z-index:1;
  pointer-events:none;
}
.coingt-bridge__mark img{
  width:100%;
  height:auto;
  display:block;
  filter:drop-shadow(0 6px 20px rgba(0,30,87,.10));
}
@media (max-width:720px){
  .coingt-bridge__mark{
    position:static;
    transform:none;
    width:96px;
    margin:18px 0 8px;
  }
}
@media (max-width:820px){
  .coingt-bridge__header{
    grid-template-columns:1fr;
    gap:14px;
  }
  .coingt-bridge__header .eyebrow{justify-self:start}
  .coingt-bridge__phase{justify-self:start}
}
@media (max-width:480px){
  .coingt-bridge__phase{
    white-space:normal;
    text-align:left;
    line-height:1.4;
  }
}

/* Project — corridor close (full-bleed bridge between infrastructure and funding) */
.corridor-close{
  position:relative;
  min-height:clamp(280px,30vw,420px);
  display:flex;
  align-items:center;
  overflow:hidden;
  background:#001233;
}
.corridor-close__bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  opacity:.55;
}
.corridor-close::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,18,51,.35) 0%, rgba(0,18,51,.78) 100%);
  pointer-events:none;
}
.corridor-close__inner{
  position:relative;z-index:2;
  width:100%;
  padding:clamp(56px,6.5vw,90px) 0;
}
.corridor-close__line{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(1.45rem,2.3vw,2.1rem);
  line-height:1.3;
  letter-spacing:-.012em;
  color:#fff;
  margin:0;
  max-width:24ch;
  text-wrap:balance;
}

/* Home — Flagship Project section (dark, full-bleed photo background) */
.flagship-section{
  position:relative;
  padding:clamp(56px,6.5vw,92px) 0;
  overflow:hidden;
  background:#001233;
  color:#fff;
}
.flagship-section__photo{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  width:100%;
  height:100%;
  background-size:cover;
  background-position:center 40%;
  background-repeat:no-repeat;
  z-index:1;
}
.flagship-section__photo::after{
  content:"";
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:linear-gradient(90deg, rgba(0,12,38,.50) 0%, rgba(0,12,38,.40) 35%, rgba(0,12,38,.20) 60%, rgba(0,12,38,.06) 85%, rgba(0,12,38,0) 100%);
  pointer-events:none;
}
.flagship-section__scrim{display:none}
.flagship-section__pyramid{
  position:absolute;
  top:48%;
  right:-1px;
  transform:translateY(-50%);
  width:clamp(141px,12.25vw,203px);
  height:clamp(300px,30vw,414px);
  background:linear-gradient(135deg, var(--cyan-x) 0%, #0aa6d6 70%, #0892bf 100%);
  clip-path:polygon(100% 0, 0 50%, 100% 100%);
  z-index:2;
  pointer-events:none;
  filter:drop-shadow(0 14px 40px rgba(0,195,250,.32));
}
.flagship-section__wrap{
  position:relative;
  z-index:3;
}
.flagship-section__copy{
  max-width:740px;
}
.flagship-section__copy .eyebrow{
  display:block;
  margin-bottom:14px;
}
.flagship-section__title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,3.4vw,3rem);
  line-height:1.1;
  letter-spacing:-.018em;
  color:#fff;
  margin:0 0 22px;
  text-shadow:0 2px 14px rgba(0,8,28,.32);
}
.flagship-section__lead{
  font-size:1.1rem;
  line-height:1.72;
  color:#dbe5f3;
  max-width:62ch;
  margin:0 0 clamp(28px,3.2vw,42px);
}
.flagship-section__stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:clamp(20px,2.6vw,40px);
  border-top:1px solid rgba(0,195,250,.18);
  padding-top:clamp(22px,2.5vw,32px);
  margin-bottom:clamp(22px,2.5vw,32px);
}
.flagship-stat{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
.flagship-stat__num{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2rem,3.15vw,2.8rem);
  letter-spacing:-.03em;
  line-height:1;
  background:linear-gradient(135deg, #fff 0%, var(--cyan-x) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:#fff;
}
.flagship-stat__num em{
  font-style:normal;
  font-size:.55em;
  font-weight:600;
  margin-left:4px;
  letter-spacing:0;
}
.flagship-stat__lbl{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#cfdcf6;
  line-height:1.4;
}
.flagship-section__cta{
  display:flex;
  margin-top:clamp(12px,1.6vw,22px);
}
@media (max-width:820px){
  .flagship-section__stats{grid-template-columns:repeat(2,1fr);gap:24px}
  .flagship-section__pyramid{display:none}
}
@media (max-width:480px){
  .flagship-section__stats{grid-template-columns:1fr}
}

/* JPM hero stat — typographic hero treatment for $13T (used on Home) */
.jpm-banner--dark{
  margin-top:clamp(14px,1.5vw,22px);
  margin-bottom:clamp(14px,1.5vw,22px);
  max-width:none;
}
.jpm-banner--dark .jpm-banner__inner{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
  max-width:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.jpm-banner--dark .jpm-num{
  font-size:clamp(2.85rem,7.1vw,5.7rem);
  font-weight:800;
  line-height:.9;
  letter-spacing:-.04em;
  background:linear-gradient(135deg, #001233 0%, var(--blue-x) 22%, var(--cyan-x) 55%, var(--blue-x) 78%, #001233 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:var(--cyan-x);
  margin:0;
  display:block;
  filter:drop-shadow(0 8px 22px rgba(0,30,87,.15));
}
.jpm-banner--dark .jpm-label{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  margin:24px 0 0 !important;
  font-size:.82rem !important;
  font-weight:700 !important;
  letter-spacing:.22em !important;
  text-transform:uppercase !important;
  color:var(--ink) !important;
  -webkit-text-fill-color:var(--ink) !important;
  background:none !important;
}
.jpm-banner--dark .jpm-source{
  display:block;
  margin:8px 0 0;
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--blue-xg);
}
.jpm-banner--dark .jpm-source::before{
  content:"\2014\00a0";
  color:var(--blue-xg);
  opacity:.55;
}
.jpm-banner--dark .jpm-vdivider{display:none}

/* JPM tie-in line below the banner — matches .jpm-quote sizing/font */
.jpm-section__eyebrow{
  display:block;
  text-align:left;
  margin:0 0 clamp(22px,2vw,28px);
}
.jpm-tiein-block{
  max-width:780px;
  margin:0;
  text-align:left;
  position:relative;
}
.jpm-tiein-block__eyebrow{
  display:block;
  margin:clamp(14px,2vw,22px) 0 clamp(14px,1.4vw,20px);
  text-align:left;
}
.jpm-tiein{
  margin:0;
  text-align:left;
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(.98rem,1.3vw,1.12rem);
  line-height:1.6;
  letter-spacing:-.005em;
  color:var(--ink);
}
.jpm-tiein-links{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:18px;
  margin-top:clamp(20px,2vw,28px);
}
.jpm-tiein-links__sep{
  color:rgba(0,30,87,.20);
  font-weight:300;
  user-select:none;
}
.jpm-tiein-link{
  display:inline-flex;
  align-items:center;
  gap:.4em;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.86rem;
  letter-spacing:.06em;
  color:var(--blue-xg);
  text-transform:uppercase;
  text-decoration:none;
  border-bottom:1px solid rgba(0,49,155,.20);
  padding-bottom:3px;
  transition:color .25s cubic-bezier(.2,.6,.2,1), border-color .25s cubic-bezier(.2,.6,.2,1), letter-spacing .25s ease;
}
.jpm-tiein-link:hover{
  color:var(--cyan-x);
  border-bottom-color:var(--cyan-x);
  letter-spacing:.07em;
}
.jpm-tiein-link .arrow{
  transition:transform .25s cubic-bezier(.2,.6,.2,1);
}
.jpm-tiein-link:hover .arrow{
  transform:translateX(5px);
}

/* Contact aside — offices block (compact, fits inside the aside) */
.contact-offices__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.contact-offices__list li{
  display:grid;grid-template-columns:14px 1fr;column-gap:14px;row-gap:3px;
  align-items:start;
  padding:14px 0 14px 22px;
  border-top:1px solid var(--line);
}
.contact-offices__list li:first-child{border-top:none;padding-top:0}
.contact-offices__list li:last-child{padding-bottom:0}
.contact-offices__marker{
  width:8px;height:8px;background:var(--cyan-x);
  transform:rotate(45deg);
  grid-column:1;grid-row:span 2;align-self:start;
  margin-top:6px;
  box-shadow:0 0 0 3px rgba(0,195,250,.14);
}
.contact-offices__city{
  grid-column:2;
  font-family:var(--font-display);font-weight:700;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue-x);
}
.contact-offices__addr{
  grid-column:2;
  font-size:.92rem;line-height:1.5;color:#3a4670;
}

/* Contact hero — kicker + subline */
.contact-hero__kicker{
  font-family:var(--font-display);font-weight:600;
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.92);
  margin:0 0 18px;display:inline-flex;align-items:center;gap:14px;
}
.contact-hero__diamond{font-size:.65rem;color:rgba(255,255,255,.65);transform:translateY(-1px)}
.contact-hero__sub{
  margin:18px 0 0;max-width:60ch;
  color:rgba(255,255,255,.92);
  font-size:1.02rem;line-height:1.7;font-weight:400;
}

/* Contact body — eyebrow + title above lead */
.contact-body__eyebrow{display:inline-block;margin:0 0 12px}
.contact-body__title{
  font-family:var(--font-display);font-weight:700;
  color:var(--blue-x);
  font-size:clamp(1.5rem, 2.6vw, 2rem);
  line-height:1.2;margin:0 0 18px;max-width:22ch;
}

/* Contact aside cards — cyan accent on top + lift on hover (already styled by ::before; keep for safety) */
.contact-aside__card{position:relative;overflow:hidden}

/* Contact closing band */
.contact-closing{padding:clamp(60px,7vw,96px) 0;text-align:center;position:relative;overflow:hidden}
.contact-closing > .wrap{position:relative;z-index:1}
.contact-closing__rule{
  display:block;width:48px;height:2px;background:var(--cyan-x);
  margin:0 auto 28px;
}
.contact-closing__lead{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.6rem,3vw,2.4rem);
  color:#fff;line-height:1.2;margin:0 0 16px;letter-spacing:-.005em;
}
.contact-closing__accent{color:var(--cyan-x)}
.contact-closing__sub{
  color:#cfdcf6;font-size:1.02rem;line-height:1.7;
  margin:0 auto;max-width:48ch;
}

/* Bio pages — restore two-column layout (main body + aside cards) */
.bio-content{
  display:grid;
  grid-template-columns:minmax(0, 1.6fr) minmax(280px, 1fr);
  gap:clamp(40px,4.5vw,72px);
  align-items:start;
  margin-top:clamp(28px,3vw,44px);
}
@media (max-width:920px){
  .bio-content{grid-template-columns:1fr;gap:32px}
}
.bio-content__main{min-width:0}
.bio-content__main p{margin:0 0 1.1em;color:#3a4670;font-size:1.02rem;line-height:1.78}
.bio-aside{di