/* ============ TOKENS ============ */
:root{
  --navy:#0b2545;
  --navy-deep:#06182f;
  --teal:#1a8a99;
  --teal-bright:#23b0bf;
  --teal-pale:#cfe9eb;
  --cream:#f6f1e7;
  --cream-warm:#efe6d3;
  --coral:#d97a5a;
  --sand:#e8b298;
  --ink:#0a1426;
  --muted:#5a6373;
  --line:rgba(11,37,69,0.12);
  --serif:'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --sans:'Manrope', system-ui, -apple-system, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  font-size:16px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ============ TEXTURE / GRAIN OVERLAY ============ */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.35;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.04 0 0 0 0 0.08 0 0 0 0 0.16 0 0 0 0.4 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ============ LAYOUT ============ */
.wrap{max-width:1320px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
section{position:relative;z-index:2}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:20px 0;
  transition:background .35s ease, padding .35s ease, box-shadow .35s ease;
  backdrop-filter:blur(0);
}
.nav.scrolled{
  background:rgba(246,241,231,0.86);
  backdrop-filter:saturate(1.4) blur(14px);
  padding:14px 0;
  box-shadow:0 1px 0 var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo img{height:44px;width:auto}
.nav-logo .word{
  font-family:var(--serif);
  font-weight:600;
  font-size:16px;
  letter-spacing:.02em;
  color:var(--navy);
  line-height:1;
}
.nav-logo .word small{
  display:block;font-family:var(--sans);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-top:4px;
}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--ink);
  letter-spacing:.02em;position:relative;padding:6px 0;
  transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--teal);transition:width .3s ease;
}
.nav-links a:hover{color:var(--teal)}
.nav-links a:hover::after{width:100%}
.nav-links a.nav-cta{
  background:var(--navy);color:var(--cream);
  padding:11px 22px;border-radius:999px;
  font-size:13px;font-weight:600;letter-spacing:.02em;
  transition:transform .2s, background .2s, color .2s;
  border:1px solid var(--navy);
}
.nav-links a.nav-cta:hover{background:var(--teal);border-color:var(--teal);color:var(--cream);transform:translateY(-1px)}
.nav-links a.nav-cta::after{display:none}
.menu-btn{display:none}

/* ============ HERO ============ */
.hero{
  min-height:100vh;
  padding:140px 0 120px;
  position:relative;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
}
.hero-bg svg{width:100%;height:100%;position:absolute;inset:0}
.hero-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:60px;
  align-items:end;
  position:relative;z-index:2;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--teal);
  margin-bottom:36px;
}
.eyebrow::before{
  content:'';width:36px;height:1px;background:var(--teal);
}
.hero h1{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(48px, 7.2vw, 108px);
  line-height:.96;
  letter-spacing:-0.022em;
  color:var(--navy);
  margin-bottom:36px;
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.hero h1 em{
  font-style:italic;
  font-weight:300;
  color:var(--teal);
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.hero h1 .stroke{
  -webkit-text-stroke:1.5px var(--navy);
  -webkit-text-fill-color:transparent;
}
.hero-lead{
  max-width:520px;
  font-size:18px;line-height:1.55;
  color:var(--muted);
  margin-bottom:44px;
  font-weight:400;
}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 28px;border-radius:999px;
  font-size:14px;font-weight:600;letter-spacing:.02em;
  transition:all .25s ease;
}
.btn-primary{background:var(--navy);color:var(--cream)}
.btn-primary:hover{background:var(--teal);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(26,138,153,.6)}
.btn-ghost{color:var(--navy);border:1px solid var(--navy)}
.btn-ghost:hover{background:var(--navy);color:var(--cream)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

.hero-side{
  display:flex;flex-direction:column;align-items:flex-end;gap:28px;
}
.hero-logo-card{
  background:linear-gradient(165deg, #ffffff 0%, var(--cream-warm) 100%);
  border-radius:24px;
  padding:32px;
  width:100%;max-width:380px;
  box-shadow:
    0 30px 60px -25px rgba(11,37,69,.18),
    0 8px 20px -10px rgba(11,37,69,.12),
    inset 0 1px 0 rgba(255,255,255,.8);
  position:relative;
  overflow:hidden;
}
.hero-logo-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(35,176,191,.12), transparent 50%);
}
.hero-logo-card img{position:relative;width:100%;height:auto}
.hero-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  width:100%;max-width:380px;
}
.hero-stat{
  border-top:1px solid var(--line);
  padding-top:16px;
}
.hero-stat .num{
  font-family:var(--serif);font-weight:500;
  font-size:44px;line-height:1;color:var(--navy);
  letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.hero-stat .lbl{
  font-size:12px;letter-spacing:.06em;color:var(--muted);
  margin-top:8px;line-height:1.4;
}

/* Hero scroll cue */
.scroll-cue{
  position:absolute;left:40px;bottom:36px;
  display:flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);z-index:3;
}
.scroll-cue .line{
  width:42px;height:1px;background:var(--muted);
  position:relative;overflow:hidden;
}
.scroll-cue .line::after{
  content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;
  background:var(--navy);animation:slide 2.2s ease-in-out infinite;
}
@keyframes slide{
  0%{left:-100%}50%{left:0}100%{left:100%}
}

/* ============ MARQUEE STRIP ============ */
.marquee{
  background:var(--navy);
  color:var(--cream);
  padding:22px 0;
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.marquee-track{
  display:flex;gap:80px;
  animation:scroll 40s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.marquee-item{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:24px;color:var(--cream);
  display:flex;align-items:center;gap:80px;
}
.marquee-item span{color:var(--teal-bright);font-style:normal;font-family:var(--sans);font-size:14px;letter-spacing:.2em;text-transform:uppercase;}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ============ SECTION BASE ============ */
.section{padding:140px 0;position:relative}
.section-head{
  display:grid;grid-template-columns:1fr 2fr;gap:60px;
  margin-bottom:80px;
  align-items:end;
}
.section-tag{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;
}
.section-tag .num{
  font-family:var(--serif);font-style:italic;
  color:var(--muted);margin-right:10px;font-size:14px;
  letter-spacing:0;text-transform:none;
}
.section-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px, 5vw, 68px);
  line-height:1.02;letter-spacing:-0.02em;
  color:var(--navy);
  font-variation-settings:"opsz" 144;
}
.section-title em{font-style:italic;color:var(--teal);font-weight:300}

/* ============ ABOUT ============ */
.about{
  background:var(--cream);
}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:start;
}
.about-lede{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(24px,2.4vw,34px);line-height:1.25;
  color:var(--navy);letter-spacing:-0.01em;
}
.about-lede em{font-style:italic;color:var(--teal)}
.about-body p{
  font-size:16px;line-height:1.7;color:var(--muted);
  margin-bottom:20px;
}
.about-body p strong{color:var(--ink);font-weight:600}
.about-pillars{
  margin-top:36px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.pillar{
  border-top:1px solid var(--line);
  padding-top:16px;
}
.pillar h4{
  font-family:var(--serif);font-weight:500;font-size:18px;
  color:var(--navy);margin-bottom:6px;
}
.pillar p{font-size:13.5px;line-height:1.55;color:var(--muted)}


/* ============ LEADERSHIP / DIRECTOR ============ */
.leadership{
  margin-top:140px;
  padding-top:90px;
  border-top:1px solid var(--line);
  position:relative;
}
.leadership-head{
  margin-bottom:60px;
  display:flex;align-items:baseline;gap:24px;
  flex-wrap:wrap;
}
.leadership-head .section-tag .num{color:var(--muted)}
.leadership-head h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px,4vw,52px);line-height:1.02;
  color:var(--navy);letter-spacing:-0.022em;
  font-variation-settings:"opsz" 144;
}
.leadership-head h3 em{font-style:italic;color:var(--teal)}
.leadership-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:72px;
  align-items:start;
}
.portrait-wrap{
  position:relative;
  padding:32px 32px 0 0;
}
.portrait-wrap::before{
  content:'';
  position:absolute;top:0;right:0;
  width:78%;height:66%;
  background:linear-gradient(140deg, var(--teal-pale) 0%, rgba(35,176,191,.35) 100%);
  border-radius:18px;
  z-index:0;
}
.portrait-wrap::after{
  content:'';
  position:absolute;bottom:-16px;left:-16px;
  width:120px;height:120px;
  border:1px solid var(--coral);
  border-radius:50%;
  opacity:.5;
  z-index:0;
}
.portrait{
  position:relative;z-index:1;
  width:100%;
  max-width:420px;
  aspect-ratio:1289/2144;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 32px 60px -28px rgba(11,37,69,.35);
}
.portrait img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.portrait-chip{
  position:absolute;bottom:18px;left:18px;
  background:rgba(11,37,69,.88);
  backdrop-filter:blur(8px);
  color:var(--cream);
  padding:9px 16px;border-radius:999px;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;z-index:2;
  display:flex;align-items:center;gap:8px;
}
.portrait-chip::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--teal-bright);
}

.director-content{padding-top:8px}
.director-eyebrow{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
  display:flex;align-items:center;gap:12px;
}
.director-eyebrow::before{
  content:'';width:32px;height:1px;background:var(--teal);
}
.director-name{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(40px,5vw,68px);line-height:.98;
  color:var(--navy);letter-spacing:-0.025em;
  margin-bottom:14px;
  font-variation-settings:"opsz" 144;
}
.director-title{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2vw,24px);color:var(--teal);
  margin-bottom:36px;letter-spacing:-0.005em;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.director-bio p{
  font-size:15.5px;line-height:1.7;color:var(--muted);
  margin-bottom:18px;
}
.director-bio strong{color:var(--ink);font-weight:600}
.director-bio em{color:var(--teal);font-style:italic;font-weight:500}


.un-projects{
  margin-top:36px;padding-top:28px;
  border-top:1px solid var(--line);
}
.un-projects-label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:24px;
}
.un-projects-list{
  display:flex;flex-direction:column;gap:0;
}
.un-project{
  display:grid;
  grid-template-columns:160px 1fr auto;
  gap:24px;
  padding:18px 0;
  border-bottom:1px solid var(--line);
  align-items:baseline;
  transition:padding .25s ease;
}
.un-project:last-child{border-bottom:none}
.un-project:hover{padding-left:8px}
.un-project .place{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:18px;color:var(--teal);
  letter-spacing:-0.005em;
  font-variation-settings:"opsz" 144;
}
.un-project .desc{
  font-size:14px;line-height:1.45;color:var(--ink);
  font-weight:500;
}
.un-project .desc small{
  display:block;font-weight:400;color:var(--muted);
  font-size:12.5px;margin-top:3px;
}
.un-project .role{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);font-weight:600;white-space:nowrap;
}

.credentials{
  margin-top:36px;padding-top:28px;
  border-top:1px solid var(--line);
}
.credentials-label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:18px;
}
.credentials-list{
  display:flex;flex-wrap:wrap;gap:10px;
}
.cred{
  font-size:13px;color:var(--navy);font-weight:500;
  padding:9px 16px;background:var(--cream);
  border:1px solid var(--line);border-radius:999px;
  letter-spacing:.01em;
  transition:all .25s ease;
}
.cred:hover{
  background:var(--navy);color:var(--cream);
  border-color:var(--navy);
}

/* ============ SERVICES ============ */
.services{
  background:var(--navy);
  color:var(--cream);
  padding:160px 0;
  position:relative;overflow:hidden;
}
.services::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 10% 20%, rgba(35,176,191,.12), transparent 50%),
    radial-gradient(ellipse at 90% 80%, rgba(217,122,90,.08), transparent 50%);
  pointer-events:none;
}
.services .section-tag{color:var(--teal-bright)}
.services .section-tag .num{color:rgba(246,241,231,.5)}
.services .section-title{color:var(--cream)}
.services .section-title em{color:var(--teal-bright)}
.services .section-head p{
  color:rgba(246,241,231,.7);max-width:560px;
  font-size:16px;line-height:1.6;
}
.service-list{
  display:flex;flex-direction:column;
  border-top:1px solid rgba(246,241,231,.16);
}
.service{
  display:grid;
  grid-template-columns:80px 1fr 1.2fr 60px;
  gap:48px;
  padding:44px 0;
  border-bottom:1px solid rgba(246,241,231,.16);
  align-items:start;
  position:relative;
  cursor:pointer;
  transition:padding .3s ease;
}
.service:hover{padding-left:16px}
.service::before{
  content:'';position:absolute;left:-16px;top:50%;width:6px;height:6px;
  border-radius:50%;background:var(--teal-bright);
  transform:translateY(-50%) scale(0);
  transition:transform .3s ease;
}
.service:hover::before{transform:translateY(-50%) scale(1)}
.service-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:22px;color:var(--teal-bright);
  font-variation-settings:"opsz" 144;
}
.service-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(26px,3vw,40px);line-height:1.05;
  color:var(--cream);letter-spacing:-0.015em;
  font-variation-settings:"opsz" 144;
}
.service-desc{
  font-size:15px;line-height:1.65;color:rgba(246,241,231,.72);
}
.service-desc strong{color:var(--teal-bright);font-weight:600;display:block;margin-bottom:8px;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.service-desc ul{list-style:none;margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}
.service-desc li{
  font-size:12px;padding:5px 12px;
  background:rgba(246,241,231,.06);
  border-radius:999px;letter-spacing:.02em;
  color:rgba(246,241,231,.85);
}
.service-arrow{
  align-self:center;
  width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(246,241,231,.3);
  display:flex;align-items:center;justify-content:center;
  transition:all .3s ease;
}
.service:hover .service-arrow{
  background:var(--teal-bright);
  border-color:var(--teal-bright);
  transform:rotate(-45deg);
}
.service-arrow svg{width:18px;height:18px;stroke:var(--cream)}

/* ============ CAPACITY BUILDING ============ */
.capacity{
  background:var(--cream-warm);
  padding:160px 0;
  position:relative;
  overflow:hidden;
}
.capacity::before{
  content:'';position:absolute;top:-150px;right:-150px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle, rgba(217,122,90,.14), transparent 70%);
  pointer-events:none;
}
.capacity::after{
  content:'';position:absolute;bottom:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(35,176,191,.1), transparent 70%);
  pointer-events:none;
}
.capacity-lead{
  max-width:980px;margin-bottom:90px;
  padding-left:40px;
  border-left:2px solid var(--coral);
  position:relative;
}
.capacity-lead p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,32px);line-height:1.32;
  color:var(--navy);letter-spacing:-0.01em;
  font-variation-settings:"opsz" 144;
}
.capacity-lead p em{font-style:italic;color:var(--coral);font-weight:400}
.capacity-domains{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;margin-bottom:90px;
  position:relative;z-index:2;
}
.domain{
  background:var(--cream);
  padding:40px 32px 32px;
  border-radius:22px;
  position:relative;
  overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease;
  border:1px solid var(--line);
  display:flex;flex-direction:column;
}
.domain:hover{
  transform:translateY(-6px);
  box-shadow:0 32px 60px -28px rgba(11,37,69,.22);
}
.domain::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--coral), var(--teal));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s ease;
}
.domain:hover::before{transform:scaleX(1)}
.domain-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:40px;color:var(--coral);
  margin-bottom:24px;line-height:1;
  font-variation-settings:"opsz" 144;
}
.domain h3{
  font-family:var(--serif);font-weight:500;font-size:28px;
  color:var(--navy);margin-bottom:14px;letter-spacing:-0.012em;line-height:1.1;
  font-variation-settings:"opsz" 144;
}
.domain p{
  font-size:14.5px;line-height:1.65;color:var(--muted);
  margin-bottom:24px;
}
.domain ul{
  list-style:none;display:flex;flex-direction:column;gap:10px;
  border-top:1px solid var(--line);padding-top:20px;margin-top:auto;
}
.domain li{
  font-size:13px;color:var(--ink);letter-spacing:.01em;
  display:flex;align-items:center;gap:12px;font-weight:500;
}
.domain li::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:var(--coral);flex-shrink:0;
}

.capacity-methods{
  border-top:1px solid var(--line);
  padding-top:48px;
  position:relative;z-index:2;
  display:grid;grid-template-columns:240px 1fr;gap:60px;
  align-items:center;
}
.methods-label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;line-height:1.5;
}
.methods-label em{
  display:block;font-family:var(--serif);font-style:italic;
  font-weight:400;font-size:24px;letter-spacing:-0.01em;
  text-transform:none;color:var(--navy);margin-top:6px;
}
.methods-list{
  display:flex;flex-wrap:wrap;gap:14px 28px;
}
.method{
  display:flex;align-items:center;gap:10px;
  font-size:14.5px;color:var(--navy);font-weight:500;
  padding:8px 16px 8px 14px;background:var(--cream);
  border-radius:999px;border:1px solid var(--line);
  transition:all .25s ease;
}
.method:hover{
  background:var(--navy);color:var(--cream);
  border-color:var(--navy);
  transform:translateY(-2px);
}
.method:hover .m-num{color:var(--teal-bright)}
.m-num{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--coral);font-size:16px;
  font-variation-settings:"opsz" 144;
  transition:color .25s;
}

/* ============ COVERAGE ============ */
.coverage{background:var(--cream);padding:160px 0}
.coverage-grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;
  align-items:start;
}
.coverage-text h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px,4vw,52px);line-height:1.05;
  color:var(--navy);margin-bottom:24px;letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.coverage-text h3 em{font-style:italic;color:var(--teal)}
.coverage-text p{
  font-size:16px;line-height:1.65;color:var(--muted);
  margin-bottom:24px;max-width:480px;
}
.coverage-map{
  position:relative;
  aspect-ratio:1/1;
  background:linear-gradient(145deg, #ffffff 0%, var(--cream-warm) 100%);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 30px 60px -25px rgba(11,37,69,.18);
}
.coverage-map svg{position:absolute;inset:0;width:100%;height:100%}
.country-list{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1px solid var(--line);
}
.country{
  padding:14px 0;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  font-size:14px;letter-spacing:.02em;
  transition:padding .25s ease;
}
.country:hover{padding-left:8px;color:var(--teal)}
.country:nth-child(odd){border-right:1px solid var(--line);padding-right:20px}
.country:nth-child(even){padding-left:20px}
.country .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--teal);opacity:.5;
}

/* ============ APPROACH / PROCESS ============ */
.approach{
  background:var(--cream-warm);
  padding:160px 0;
  position:relative;overflow:hidden;
}
.approach::after{
  content:'';position:absolute;left:-100px;bottom:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(35,176,191,.15), transparent 70%);
  pointer-events:none;
}
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.step{
  background:var(--cream-warm);
  padding:48px 32px;
  display:flex;flex-direction:column;gap:20px;
  position:relative;
  transition:background .3s ease;
}
.step:hover{background:var(--cream)}
.step-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:64px;line-height:1;color:var(--teal);
  font-variation-settings:"opsz" 144;
}
.step h4{
  font-family:var(--serif);font-weight:500;font-size:22px;
  color:var(--navy);line-height:1.15;
}
.step p{
  font-size:14px;line-height:1.6;color:var(--muted);
}

/* ============ TESTIMONIAL / QUOTE ============ */
.quote{
  background:var(--cream);
  padding:160px 0;
  text-align:center;
}
.quote blockquote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(28px,4vw,52px);line-height:1.2;
  color:var(--navy);letter-spacing:-0.015em;
  max-width:1000px;margin:0 auto 40px;
  font-variation-settings:"opsz" 144;
}
.quote blockquote::before,
.quote blockquote::after{
  font-family:var(--serif);color:var(--teal);
  font-size:1em;font-weight:400;font-style:normal;
}
.quote blockquote::before{content:'“';margin-right:4px}
.quote blockquote::after{content:'”';margin-left:4px}
.quote-credit{
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}
.quote-credit span{color:var(--teal);margin:0 10px}

/* ============ CTA / CONTACT ============ */
.cta{
  background:var(--navy-deep);
  color:var(--cream);
  padding:140px 0 100px;
  position:relative;overflow:hidden;
}
.cta-wave{
  position:absolute;top:0;left:0;right:0;
  height:60px;pointer-events:none;
}
.cta::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(35,176,191,.18), transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(217,122,90,.1), transparent 60%);
}
.cta-inner{position:relative;z-index:2;text-align:center;max-width:900px;margin:0 auto}
.cta h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,6vw,84px);line-height:1.02;
  letter-spacing:-0.025em;margin-bottom:32px;
  font-variation-settings:"opsz" 144;
}
.cta h2 em{font-style:italic;color:var(--teal-bright);font-weight:300}
.cta p{
  font-size:17px;line-height:1.6;color:rgba(246,241,231,.7);
  max-width:560px;margin:0 auto 48px;
}
.cta-actions{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:80px}
.cta .btn-primary{background:var(--teal-bright);color:var(--navy-deep)}
.cta .btn-primary:hover{background:var(--cream);color:var(--navy-deep)}
.cta .btn-ghost{color:var(--cream);border-color:rgba(246,241,231,.4)}
.cta .btn-ghost:hover{background:var(--cream);color:var(--navy-deep);border-color:var(--cream)}
.cta-contact{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  text-align:left;border-top:1px solid rgba(246,241,231,.16);
  padding-top:48px;
}
.cta-contact a{transition:color .2s}
.cta-contact a:hover{color:var(--teal-bright)}
.contact-item .lbl{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal-bright);font-weight:600;margin-bottom:10px;
}
.contact-item .val{
  font-family:var(--serif);font-weight:400;font-size:20px;
  color:var(--cream);line-height:1.3;
}

/* ============ FOOTER ============ */
.foot{
  background:var(--navy-deep);
  color:rgba(246,241,231,.6);
  padding:40px 0;
  border-top:1px solid rgba(246,241,231,.1);
  font-size:13px;
}
.foot-inner{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.foot-tag{font-family:var(--serif);font-style:italic;color:rgba(246,241,231,.7)}

/* ============ REVEAL ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ============ RESPONSIVE ============ */
@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr;gap:60px}
  .hero-side{align-items:flex-start}
  .section-head{grid-template-columns:1fr;gap:24px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .coverage-grid{grid-template-columns:1fr;gap:48px}
  .steps{grid-template-columns:1fr 1fr}
  .service{grid-template-columns:60px 1fr 1.2fr;gap:24px}
  .service-arrow{display:none}
  .capacity-domains{grid-template-columns:1fr;gap:20px}
  .capacity-methods{grid-template-columns:1fr;gap:24px}
  .leadership-grid{grid-template-columns:1fr;gap:48px}
  .portrait-wrap{max-width:420px}
}
@media (max-width:720px){
  .wrap{padding:0 22px}
  .nav-links a:not(.nav-cta){display:none}
  .hero{padding:120px 0 80px;min-height:auto}
  .hero h1{font-size:48px}
  .section{padding:90px 0}
  .services{padding:100px 0}
  .approach,.coverage,.quote,.capacity{padding:100px 0}
  .service{grid-template-columns:40px 1fr;gap:16px}
  .service-desc{grid-column:2}
  .steps{grid-template-columns:1fr}
  .cta-contact{grid-template-columns:1fr;gap:28px}
  .about-pillars{grid-template-columns:1fr}
  .country-list{grid-template-columns:1fr}
  .country:nth-child(odd){border-right:none;padding-right:0}
  .country:nth-child(even){padding-left:0}
  .scroll-cue{display:none}
  .hero-stat .num{font-size:36px}
  .capacity-lead{padding-left:24px}
  .leadership{margin-top:80px;padding-top:60px}
  .director-name{font-size:42px}
  .portrait-wrap{padding:24px 24px 0 0}
  .un-project{grid-template-columns:1fr;gap:4px;padding:16px 0}
  .un-project .role{order:-1}
}
/* ===================================================================
   SERVICE DETAIL PAGES — shared styles
   =================================================================== */

/* Service page hero */
.service-hero{
  padding:160px 0 100px;
  position:relative;overflow:hidden;
  background:var(--cream);
}
.service-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 90% 30%, rgba(35,176,191,.1), transparent 50%),
    radial-gradient(ellipse at 10% 90%, rgba(217,122,90,.06), transparent 50%);
}
.breadcrumb{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;letter-spacing:.02em;color:var(--muted);
  margin-bottom:48px;font-weight:500;
  transition:color .2s, transform .25s;
}
.breadcrumb:hover{color:var(--teal);transform:translateX(-4px)}
.service-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:end;position:relative;z-index:2;
}
.service-hero h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px, 7vw, 96px);line-height:.98;
  letter-spacing:-0.025em;color:var(--navy);
  margin-bottom:24px;
  font-variation-settings:"opsz" 144;
}
.service-hero h1 em{font-style:italic;color:var(--teal);font-weight:300}
.service-hero .lede{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2.2vw,28px);line-height:1.3;
  color:var(--teal);letter-spacing:-0.005em;
  font-variation-settings:"opsz" 144, "SOFT" 100;
}
.service-hero-side{padding-bottom:24px}
.service-hero-side p{
  font-size:16px;line-height:1.7;color:var(--muted);
  max-width:480px;
}

/* Service overview section */
.service-overview{
  background:var(--cream);
  padding:120px 0 80px;
}
.overview-grid{
  display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;
}
.overview-grid .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;
  position:sticky;top:120px;
}
.overview-grid .body p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.3vw,30px);line-height:1.35;
  color:var(--navy);letter-spacing:-0.01em;
  margin-bottom:24px;
  font-variation-settings:"opsz" 144;
}
.overview-grid .body p em{font-style:italic;color:var(--teal)}

/* Deliverables grid */
.deliverables-section{
  background:var(--cream-warm);
  padding:140px 0;
  position:relative;overflow:hidden;
}
.deliverables-section::before{
  content:'';position:absolute;top:-100px;left:-150px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle, rgba(35,176,191,.12), transparent 70%);
  pointer-events:none;
}
.deliverables-head{
  margin-bottom:60px;
  position:relative;z-index:2;
}
.deliverables-head .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
}
.deliverables-head h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,64px);line-height:1.02;
  letter-spacing:-0.022em;color:var(--navy);
  font-variation-settings:"opsz" 144;
}
.deliverables-head h2 em{font-style:italic;color:var(--teal)}
.deliverables-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;z-index:2;
}
.deliverable{
  background:var(--cream-warm);
  padding:40px 36px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .25s ease;
}
.deliverable:hover{background:var(--cream)}
.deliverable .d-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:18px;color:var(--coral);
  letter-spacing:.02em;
  font-variation-settings:"opsz" 144;
}
.deliverable h3{
  font-family:var(--serif);font-weight:500;
  font-size:24px;line-height:1.15;color:var(--navy);
  letter-spacing:-0.012em;
  font-variation-settings:"opsz" 144;
}
.deliverable p{
  font-size:14.5px;line-height:1.65;color:var(--muted);
}

/* Approach steps for service pages */
.service-approach{
  background:var(--navy);
  color:var(--cream);
  padding:140px 0;
  position:relative;overflow:hidden;
}
.service-approach::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(35,176,191,.12), transparent 50%),
    radial-gradient(ellipse at 20% 90%, rgba(217,122,90,.08), transparent 50%);
  pointer-events:none;
}
.service-approach .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal-bright);font-weight:600;margin-bottom:18px;
}
.service-approach h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,60px);line-height:1.02;
  letter-spacing:-0.022em;color:var(--cream);margin-bottom:60px;
  font-variation-settings:"opsz" 144;
}
.service-approach h2 em{font-style:italic;color:var(--teal-bright);font-weight:300}
.approach-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  position:relative;z-index:2;
}
.approach-item{
  border-top:1px solid rgba(246,241,231,.2);
  padding-top:24px;
}
.approach-item .a-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:38px;line-height:1;color:var(--teal-bright);
  margin-bottom:16px;
  font-variation-settings:"opsz" 144;
}
.approach-item h4{
  font-family:var(--serif);font-weight:500;font-size:22px;
  color:var(--cream);margin-bottom:10px;line-height:1.15;
}
.approach-item p{
  font-size:14px;line-height:1.6;color:rgba(246,241,231,.7);
}

/* Capacity callout on service pages */
.cap-callout{
  background:var(--cream);
  padding:120px 0;
}
.cap-callout-inner{
  display:grid;grid-template-columns:auto 1fr auto;gap:60px;
  align-items:center;
  padding:48px 56px;
  border-radius:24px;
  background:linear-gradient(135deg, var(--cream-warm) 0%, var(--teal-pale) 100%);
  position:relative;overflow:hidden;
}
.cap-callout-inner::before{
  content:'';position:absolute;top:-80px;right:-80px;
  width:200px;height:200px;border-radius:50%;
  border:1px solid var(--coral);opacity:.3;
}
.cap-icon{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:64px;line-height:1;color:var(--teal);
  font-variation-settings:"opsz" 144;
}
.cap-callout-text h3{
  font-family:var(--serif);font-weight:400;font-size:28px;
  color:var(--navy);margin-bottom:8px;letter-spacing:-0.01em;
  line-height:1.2;
}
.cap-callout-text p{
  font-size:15px;line-height:1.6;color:var(--muted);max-width:560px;
}
.cap-callout-link{
  white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--navy);
  padding:14px 24px;border-radius:999px;
  border:1px solid var(--navy);
  transition:all .25s ease;
}
.cap-callout-link:hover{background:var(--navy);color:var(--cream)}

/* Other services nav at bottom of service pages */
.other-services-section{
  background:var(--cream-warm);
  padding:140px 0 120px;
}
.other-services-section .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
}
.other-services-section h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px,4vw,52px);line-height:1.02;
  color:var(--navy);margin-bottom:60px;letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.other-services-section h2 em{font-style:italic;color:var(--teal)}
.other-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.other-card{
  display:flex;flex-direction:column;
  padding:32px 28px;border-radius:18px;
  background:var(--cream);border:1px solid var(--line);
  transition:all .3s ease;
  min-height:200px;
}
.other-card:hover{
  background:var(--navy);
  border-color:var(--navy);
  transform:translateY(-4px);
  box-shadow:0 28px 50px -22px rgba(11,37,69,.3);
}
.other-card .oc-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:18px;color:var(--coral);margin-bottom:auto;
  font-variation-settings:"opsz" 144;
}
.other-card h3{
  font-family:var(--serif);font-weight:500;font-size:22px;
  color:var(--navy);letter-spacing:-0.01em;line-height:1.15;
  margin-top:24px;
  transition:color .3s;
}
.other-card .oc-arrow{
  margin-top:14px;font-size:13px;color:var(--teal);font-weight:600;
  letter-spacing:.02em;transition:color .3s, transform .3s;
}
.other-card:hover h3{color:var(--cream)}
.other-card:hover .oc-arrow{color:var(--teal-bright);transform:translateX(4px)}

/* Responsive */
@media (max-width:1100px){
  .service-hero-grid{grid-template-columns:1fr;gap:48px}
  .overview-grid{grid-template-columns:1fr;gap:36px}
  .overview-grid .label{position:static}
  .deliverables-grid{grid-template-columns:1fr}
  .approach-grid{grid-template-columns:1fr 1fr;gap:36px}
  .other-grid{grid-template-columns:1fr 1fr;gap:16px}
  .cap-callout-inner{grid-template-columns:1fr;gap:24px;text-align:left;padding:36px 28px}
  .cap-callout-link{justify-self:start}
}
@media (max-width:720px){
  .service-hero{padding:120px 0 60px}
  .deliverables-section,.service-approach,.cap-callout,.other-services-section{padding:80px 0}
  .approach-grid{grid-template-columns:1fr}
  .other-grid{grid-template-columns:1fr}
}

/* ===================================================================
   CHATBOT
   =================================================================== */
.chatbot-toggle{
  position:fixed;bottom:24px;right:24px;
  width:62px;height:62px;border-radius:50%;
  background:var(--navy);color:var(--cream);
  border:none;cursor:pointer;
  box-shadow:0 14px 32px -10px rgba(11,37,69,.45);
  z-index:100;
  display:flex;align-items:center;justify-content:center;
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease;
}
.chatbot-toggle:hover{
  background:var(--teal);transform:translateY(-3px) scale(1.05);
  box-shadow:0 18px 40px -10px rgba(26,138,153,.5);
}
.chatbot-toggle svg{width:28px;height:28px;stroke:var(--cream);fill:none;stroke-width:1.6}
.chatbot-toggle .dot{
  position:absolute;top:12px;right:12px;
  width:11px;height:11px;border-radius:50%;
  background:var(--coral);
  animation:cbPulse 2s ease-in-out infinite;
  box-shadow:0 0 0 3px var(--cream);
}
@keyframes cbPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.65}}
.chatbot-toggle[aria-expanded="true"] .dot{display:none}
.chatbot-toggle .icon-close{display:none}
.chatbot-toggle[aria-expanded="true"] .icon-open{display:none}
.chatbot-toggle[aria-expanded="true"] .icon-close{display:block}

.chatbot-panel{
  position:fixed;bottom:100px;right:24px;
  width:390px;max-width:calc(100vw - 48px);
  height:580px;max-height:calc(100vh - 140px);
  background:var(--cream);
  border-radius:22px;
  box-shadow:0 40px 80px -30px rgba(11,37,69,.55), 0 0 0 1px var(--line);
  z-index:99;
  display:flex;flex-direction:column;
  overflow:hidden;
  transform:translateY(20px) scale(.96);
  opacity:0;pointer-events:none;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), opacity .25s ease;
  font-family:var(--sans);
}
.chatbot-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.chatbot-header{
  background:var(--navy);color:var(--cream);
  padding:18px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  position:relative;
}
.chatbot-header::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--teal-bright), transparent);
  opacity:.3;
}
.chatbot-header-info{display:flex;align-items:center;gap:12px}
.chatbot-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-bright) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;
  color:var(--cream);font-size:14px;letter-spacing:-.02em;
}
.chatbot-title{font-family:var(--serif);font-size:16px;font-weight:500;line-height:1.1;letter-spacing:-.005em}
.chatbot-status{font-size:11px;color:rgba(246,241,231,.7);letter-spacing:.04em;margin-top:3px;display:flex;align-items:center;gap:6px}
.chatbot-status::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--teal-bright);box-shadow:0 0 0 2px rgba(35,176,191,.3)}
.chatbot-close{
  background:none;border:none;color:var(--cream);cursor:pointer;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;opacity:.7;transition:opacity .2s, background .2s;
  line-height:1;
}
.chatbot-close:hover{opacity:1;background:rgba(246,241,231,.1)}

.chatbot-messages{
  flex:1;overflow-y:auto;padding:22px 18px;
  display:flex;flex-direction:column;gap:12px;
  background:var(--cream);
}
.chatbot-messages::-webkit-scrollbar{width:6px}
.chatbot-messages::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}

.cb-msg{
  max-width:85%;
  padding:11px 15px;
  border-radius:16px;
  font-size:14px;line-height:1.5;
  animation:cbIn .35s ease;
  word-wrap:break-word;
}
@keyframes cbIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.cb-msg.bot{
  background:var(--cream-warm);color:var(--ink);
  align-self:flex-start;border-bottom-left-radius:4px;
}
.cb-msg.user{
  background:var(--navy);color:var(--cream);
  align-self:flex-end;border-bottom-right-radius:4px;
}
.cb-typing{
  display:flex;gap:4px;padding:14px 15px;align-items:center;
}
.cb-typing span{
  width:6px;height:6px;border-radius:50%;background:var(--muted);
  animation:cbBounce 1.2s ease-in-out infinite;
}
.cb-typing span:nth-child(2){animation-delay:.15s}
.cb-typing span:nth-child(3){animation-delay:.3s}
@keyframes cbBounce{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}

.cb-quick{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:2px;align-self:flex-start;max-width:90%;
}
.cb-quick button{
  background:var(--cream);
  border:1px solid var(--line);
  color:var(--navy);
  padding:8px 14px;border-radius:999px;
  font-size:13px;font-weight:500;cursor:pointer;
  font-family:inherit;letter-spacing:.005em;
  transition:all .2s ease;
}
.cb-quick button:hover:not(:disabled){background:var(--navy);color:var(--cream);border-color:var(--navy);transform:translateY(-1px)}
.cb-quick button:disabled{cursor:default;opacity:.4}

.cb-summary{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px 16px;
  font-size:13px;line-height:1.55;
  align-self:stretch;max-width:none;
  border-bottom-left-radius:4px;
}
.cb-summary .row{display:flex;gap:12px;padding:7px 0;border-bottom:1px dashed var(--line)}
.cb-summary .row:last-of-type{border-bottom:none}
.cb-summary .k{font-weight:600;color:var(--teal);min-width:80px;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding-top:3px;flex-shrink:0}
.cb-summary .v{color:var(--ink);flex:1;font-size:13px;line-height:1.5}
.cb-actions{display:flex;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}
.cb-actions .primary,.cb-actions .secondary{
  padding:10px 18px;border-radius:999px;
  font-size:13px;font-weight:600;cursor:pointer;
  font-family:inherit;flex:1;
  transition:all .2s;
}
.cb-actions .primary{background:var(--navy);color:var(--cream);border:1px solid var(--navy)}
.cb-actions .primary:hover{background:var(--teal);border-color:var(--teal)}
.cb-actions .secondary{background:transparent;color:var(--navy);border:1px solid var(--navy);font-weight:500}
.cb-actions .secondary:hover{background:var(--navy);color:var(--cream)}

.chatbot-input{
  border-top:1px solid var(--line);
  padding:12px 14px;
  display:flex;gap:8px;align-items:flex-end;
  background:var(--cream);
}
.chatbot-input.hidden{display:none}
.chatbot-input textarea{
  flex:1;padding:10px 14px;
  border:1px solid var(--line);
  border-radius:18px;
  font-family:inherit;font-size:14px;
  color:var(--ink);background:var(--cream-warm);
  outline:none;resize:none;
  line-height:1.4;min-height:38px;max-height:90px;
  transition:border-color .2s, background .2s;
}
.chatbot-input textarea:focus{border-color:var(--teal);background:var(--cream)}
.chatbot-input button{
  background:var(--navy);color:var(--cream);
  border:none;width:38px;height:38px;border-radius:50%;
  cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s, transform .2s;
}
.chatbot-input button:hover{background:var(--teal);transform:scale(1.05)}
.chatbot-input button svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

@media (max-width:480px){
  .chatbot-panel{bottom:86px;right:12px;left:12px;width:auto;height:calc(100vh - 120px)}
  .chatbot-toggle{bottom:16px;right:16px;width:56px;height:56px}
}

/* ============ TRAINING / CERTIFICATION ============ */
.training{
  background:var(--navy-deep);
  color:var(--cream);
  padding:160px 0;
  position:relative;overflow:hidden;
}
.training::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 85% 15%, rgba(217,122,90,.16), transparent 55%),
    radial-gradient(ellipse at 15% 85%, rgba(35,176,191,.1), transparent 50%);
}
.training .section-tag{color:var(--coral)}
.training .section-tag .num{color:rgba(246,241,231,.4)}
.training .section-title{color:var(--cream)}
.training .section-title em{color:var(--coral);font-weight:300}

.training-lead{
  max-width:1000px;margin-bottom:70px;
  padding-left:40px;
  border-left:2px solid var(--coral);
  position:relative;z-index:2;
}
.training-lead p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,32px);line-height:1.32;
  color:var(--cream);letter-spacing:-0.01em;
  font-variation-settings:"opsz" 144;
}
.training-lead p em{font-style:italic;color:var(--coral);font-weight:400}
.training-lead p strong{font-weight:500;color:var(--teal-bright)}

.training-features{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(246,241,231,.12);
  border-top:1px solid rgba(246,241,231,.12);
  border-bottom:1px solid rgba(246,241,231,.12);
  margin-bottom:80px;
  position:relative;z-index:2;
}
.t-feature{
  background:var(--navy-deep);
  padding:32px 28px;
  display:flex;flex-direction:column;gap:18px;
}
.t-feature-icon{
  width:38px;height:38px;
  color:var(--coral);
  stroke:currentColor;fill:none;stroke-width:1.5;
}
.t-feature-title{
  font-family:var(--serif);font-weight:500;font-size:22px;
  color:var(--cream);line-height:1.15;letter-spacing:-0.01em;
  font-variation-settings:"opsz" 144;
}
.t-feature-sub{
  font-size:13px;line-height:1.5;
  color:rgba(246,241,231,.65);margin-top:6px;
}

.training-model{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  position:relative;z-index:2;
  margin-bottom:60px;
}
.model-track{
  background:rgba(246,241,231,.05);
  border:1px solid rgba(246,241,231,.14);
  border-radius:22px;
  padding:40px 36px;
  position:relative;overflow:hidden;
}
.model-track::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--coral);transform:scaleX(.3);transform-origin:left;
  transition:transform .5s ease;
}
.model-track:hover::before{transform:scaleX(1)}
.track-meta{
  display:flex;align-items:center;gap:14px;margin-bottom:20px;
}
.track-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:var(--coral);font-size:30px;line-height:1;
  font-variation-settings:"opsz" 144;
}
.track-tag{
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--coral);font-weight:600;
  border:1px solid rgba(217,122,90,.5);
  border-radius:999px;padding:5px 14px;
}
.model-track h3{
  font-family:var(--serif);font-weight:400;
  font-size:32px;line-height:1.05;color:var(--cream);
  letter-spacing:-0.018em;margin-bottom:24px;
  font-variation-settings:"opsz" 144;
}
.model-track h3 em{font-style:italic;color:var(--coral);font-weight:300}
.model-track ul{
  list-style:none;display:flex;flex-direction:column;gap:11px;
  border-top:1px solid rgba(246,241,231,.1);padding-top:22px;
}
.model-track li{
  font-size:14.5px;line-height:1.55;color:rgba(246,241,231,.85);
  padding-left:20px;position:relative;
}
.model-track li::before{
  content:'';position:absolute;left:0;top:9px;
  width:6px;height:6px;border-radius:50%;
  background:var(--coral);
}

.training-cta{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14px;font-weight:600;letter-spacing:.02em;
  color:var(--navy-deep);padding:16px 32px;
  border-radius:999px;background:var(--coral);
  transition:all .25s;position:relative;z-index:2;
}
.training-cta:hover{
  background:var(--cream);color:var(--navy-deep);
  transform:translateY(-2px);
  box-shadow:0 14px 32px -12px rgba(246,241,231,.4);
}
.training-cta span{transition:transform .25s}
.training-cta:hover span{transform:translateX(4px)}

/* ============ TRAINING PAGE — specific sections ============ */

/* Partnership section */
.partnership{
  background:var(--cream);
  padding:140px 0;
}
.partnership-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:80px;
  align-items:start;
}
.partnership h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,56px);line-height:1.02;
  color:var(--navy);letter-spacing:-0.022em;
  font-variation-settings:"opsz" 144;
}
.partnership h2 em{font-style:italic;color:var(--coral)}
.partnership-body p{
  font-size:16.5px;line-height:1.7;color:var(--muted);
  margin-bottom:20px;
}
.partnership-body p strong{color:var(--ink);font-weight:600}
.partnership-points{
  margin-top:32px;
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--line);
}
.pp-row{
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  padding:18px 0;
  border-bottom:1px solid var(--line);
  align-items:start;
}
.pp-mark{
  font-family:var(--serif);font-style:italic;color:var(--coral);
  font-size:20px;line-height:1.3;
  font-variation-settings:"opsz" 144;
}
.pp-text{font-size:15px;line-height:1.6;color:var(--ink)}
.pp-text strong{font-weight:600;color:var(--navy)}

/* Curriculum section */
.curriculum{
  background:var(--cream-warm);
  padding:140px 0;
  position:relative;overflow:hidden;
}
.curriculum::before{
  content:'';position:absolute;top:-150px;right:-150px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle, rgba(217,122,90,.12), transparent 70%);
  pointer-events:none;
}
.curriculum-head{margin-bottom:60px;position:relative;z-index:2}
.curriculum-head .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
}
.curriculum-head h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,64px);line-height:1.02;
  letter-spacing:-0.022em;color:var(--navy);
  font-variation-settings:"opsz" 144;
}
.curriculum-head h2 em{font-style:italic;color:var(--coral)}
.year-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:30px;
  position:relative;z-index:2;
}
.year-card{
  background:var(--cream);
  border-radius:22px;
  padding:44px 40px;
  border:1px solid var(--line);
  transition:transform .35s ease, box-shadow .35s ease;
}
.year-card:hover{
  transform:translateY(-6px);
  box-shadow:0 32px 60px -28px rgba(11,37,69,.2);
}
.year-card .y-mark{
  display:flex;align-items:baseline;gap:12px;margin-bottom:8px;
}
.year-card .y-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:48px;line-height:1;color:var(--coral);letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.year-card .y-label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}
.year-card h3{
  font-family:var(--serif);font-weight:500;font-size:28px;
  color:var(--navy);margin-bottom:28px;letter-spacing:-0.015em;line-height:1.1;
  font-variation-settings:"opsz" 144;
}
.year-card ul{
  list-style:none;display:flex;flex-direction:column;gap:14px;
  border-top:1px solid var(--line);padding-top:24px;
}
.year-card li{
  display:grid;grid-template-columns:auto 1fr;gap:14px;
  align-items:start;
  font-size:14.5px;line-height:1.55;color:var(--ink);
}
.year-card li::before{
  content:counter(item, decimal-leading-zero);
  counter-increment:item;
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--coral);font-size:13px;flex-shrink:0;
  letter-spacing:.02em;padding-top:2px;
}
.year-card ul{counter-reset:item}

/* Outcomes section */
.outcomes{background:var(--cream);padding:140px 0}
.outcomes-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
}
.outcome-block h3{
  font-family:var(--serif);font-weight:500;font-size:30px;
  color:var(--navy);margin-bottom:8px;letter-spacing:-0.015em;
  font-variation-settings:"opsz" 144;
}
.outcome-block h3 em{font-style:italic;color:var(--coral)}
.outcome-block .o-tag{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
}
.outcome-block ul{
  list-style:none;display:flex;flex-direction:column;gap:14px;
  margin-top:28px;border-top:1px solid var(--line);padding-top:22px;
}
.outcome-block li{
  font-size:15px;line-height:1.6;color:var(--ink);
  padding-left:22px;position:relative;
}
.outcome-block li::before{
  content:'+';position:absolute;left:0;top:0;
  font-family:var(--serif);font-style:italic;color:var(--coral);
  font-size:18px;font-weight:400;
  font-variation-settings:"opsz" 144;
}

/* Eligibility & application */
.eligibility{
  background:var(--navy);
  color:var(--cream);
  padding:140px 0;
  position:relative;overflow:hidden;
}
.eligibility::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(35,176,191,.12), transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(217,122,90,.08), transparent 60%);
}
.eligibility .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal-bright);font-weight:600;margin-bottom:18px;
}
.eligibility h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,60px);line-height:1.02;
  letter-spacing:-0.022em;color:var(--cream);margin-bottom:48px;
  font-variation-settings:"opsz" 144;
}
.eligibility h2 em{font-style:italic;color:var(--teal-bright);font-weight:300}
.elig-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  position:relative;z-index:2;
}
.elig-block h3{
  font-family:var(--serif);font-weight:500;font-size:24px;
  color:var(--cream);margin-bottom:20px;letter-spacing:-0.012em;
}
.elig-list{
  list-style:none;display:flex;flex-direction:column;gap:14px;
  border-top:1px solid rgba(246,241,231,.2);padding-top:22px;
}
.elig-list li{
  font-size:14.5px;line-height:1.55;color:rgba(246,241,231,.85);
  padding-left:22px;position:relative;
}
.elig-list li::before{
  content:'';position:absolute;left:0;top:9px;
  width:6px;height:6px;border-radius:50%;
  background:var(--teal-bright);
}
.apply-steps{
  list-style:none;display:flex;flex-direction:column;gap:14px;
  border-top:1px solid rgba(246,241,231,.2);padding-top:22px;
  counter-reset:step;
}
.apply-steps li{
  display:grid;grid-template-columns:36px 1fr;gap:14px;
  font-size:14.5px;line-height:1.55;color:rgba(246,241,231,.85);
  counter-increment:step;
}
.apply-steps li::before{
  content:counter(step);
  font-family:var(--serif);font-weight:400;font-size:22px;
  color:var(--teal-bright);line-height:1;
  font-variation-settings:"opsz" 144;
}
.apply-steps li strong{color:var(--cream);font-weight:600;display:block;margin-bottom:2px}

/* FAQ */
.faq{background:var(--cream);padding:140px 0}
.faq-head{margin-bottom:48px}
.faq-head .label{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:18px;
}
.faq-head h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,5vw,56px);line-height:1.02;
  color:var(--navy);letter-spacing:-0.022em;
  font-variation-settings:"opsz" 144;
}
.faq-head h2 em{font-style:italic;color:var(--coral)}
.faq-list{border-top:1px solid var(--line)}
.faq-item{
  border-bottom:1px solid var(--line);
  padding:24px 0;
  cursor:pointer;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:24px;
  font-family:var(--serif);font-weight:500;font-size:21px;
  color:var(--navy);letter-spacing:-0.01em;line-height:1.25;
  font-variation-settings:"opsz" 144;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-family:var(--serif);font-weight:300;color:var(--coral);
  font-size:32px;line-height:.6;transition:transform .25s ease;flex-shrink:0;
  font-variation-settings:"opsz" 144;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{
  margin-top:16px;font-size:15px;line-height:1.7;color:var(--muted);
  max-width:880px;
}

@media (max-width:1100px){
  .training-features{grid-template-columns:1fr 1fr}
  .training-model{grid-template-columns:1fr;gap:18px}
  .partnership-grid{grid-template-columns:1fr;gap:36px}
  .year-grid{grid-template-columns:1fr;gap:18px}
  .outcomes-grid{grid-template-columns:1fr;gap:48px}
  .elig-grid{grid-template-columns:1fr;gap:48px}
}
@media (max-width:720px){
  .training{padding:100px 0}
  .training-features{grid-template-columns:1fr}
  .training-lead{padding-left:24px}
  .model-track{padding:32px 24px}
  .partnership,.curriculum,.outcomes,.eligibility,.faq{padding:90px 0}
  .year-card{padding:32px 24px}
  .faq-item summary{font-size:18px;gap:14px}
}
