
:root{
  --bg:#f6f8fb; --surface:#ffffff; --text:#172338; --muted:#5f6e81;
  --brand:#0b2c4d; --brand2:#163f69; --accent:#0b92de; --line:#dfe7f0;
  --shadow:0 18px 44px rgba(15,33,57,.08); --radius:22px; --max:1180px;
  --font:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{overflow-x:hidden;margin:0;background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6}
a{text-decoration:none;color:inherit} img{display:block;max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.topbar{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border-bottom:none;box-shadow:none}
.topbar .container{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:10px 18px;font-size:14px}
.meta{display:flex;gap:14px;flex-wrap:wrap}
.navwrap{position:sticky;top:0;z-index:60;background:rgba(246,248,251,.96);backdrop-filter:blur(12px);border-top:none;border-bottom:1px solid rgba(223,231,240,.88);box-shadow:none}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;position:relative}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.35px}
.brand img{width:42px;height:42px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow)}
.mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--accent),#13b0d4);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow);font-weight:900}
.navlinks{display:flex;gap:6px;align-items:center}
.navlinks a{padding:10px 12px;border-radius:12px;font-weight:700;color:#23354e;white-space:nowrap;}
.navlinks a.active,.navlinks a:hover{background:#eaf3ff;color:var(--brand)}
.cta{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;border:1px solid var(--line);background:#fff;font-weight:800;color:#20314a}
.btn.primary{background:linear-gradient(135deg,var(--accent),#0ea6df);border-color:transparent;color:#fff;box-shadow:0 14px 34px rgba(0,122,204,.24)}
.menuBtn{display:none}
.hero,.section,.banner{padding:28px 0}
.heroCard,.bannerCard{background:linear-gradient(145deg,#fff,#f4f8ff);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);overflow:hidden}
.heroGrid{display:grid;grid-template-columns:1.05fr .95fr}
.heroCopy{padding:42px 40px 34px}
.kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:#eaf3ff;border:1px solid #d8e8ff;border-radius:999px;color:var(--brand);font-size:12px;font-weight:900;letter-spacing:.4px}
.h1{font-size:clamp(34px,5vw,54px);line-height:1.04;margin:16px 0 12px;font-weight:900;letter-spacing:-1px}
.lead{font-size:17px;color:var(--muted);max-width:62ch}
.heroStats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px}
.stat strong{display:block;font-size:22px;color:var(--brand)}
.heroImg,.bannerImg{min-height:340px;position:relative;background:var(--brand)}
.heroImg img,.bannerImg img{width:100%;height:100%;object-fit:cover}
.heroImg:after,.bannerImg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,44,77,0),rgba(11,44,77,.25))}
.sectionHead{display:flex;justify-content:space-between;gap:18px;align-items:end;margin-bottom:18px}
.sectionHead h2{margin:0;font-size:30px;line-height:1.15}
.sectionHead p{margin:0;max-width:58ch;color:var(--muted)}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card h3,.card h4{margin:0 0 8px}
.card p{margin:0;color:var(--muted)}
.iconTag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#edf5ff;border:1px solid #d9ebff;color:var(--brand);font-size:12px;font-weight:800;margin-bottom:10px}
.list{margin:10px 0 0;padding-left:18px}
.list li{margin:6px 0}
.darkBox{background:linear-gradient(145deg,var(--brand),var(--brand2));color:#fff;border-radius:24px;padding:26px;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}
.darkBox p,.darkBox li{color:#e0ebfa}
.badges{display:flex;flex-wrap:wrap;gap:10px}
.badge{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:800;font-size:13px}
.projectGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.projectCard{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.projectCard img{width:100%;height:230px;object-fit:cover}
.projectBody{padding:16px}
.projectBody h3{margin:0 0 6px;font-size:18px}
.projectBody p{margin:0;color:var(--muted)}
.galleryGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.thumb{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);cursor:pointer}
.thumb img{width:100%;height:220px;object-fit:cover;transition:transform .25s ease}
.thumb:hover img{transform:scale(1.04)}
.caption{padding:12px 13px}
.caption h4{margin:0;font-size:15px}
.caption p{margin:3px 0 0;color:var(--muted);font-size:13px}
.teamHero{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.person{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.person img{width:100%;height:280px;object-fit:cover;background:#eef3f9}
.person .body{padding:16px}
.person h3{margin:0 0 4px;font-size:18px}
.person .role{font-weight:800;color:var(--brand);margin-bottom:8px;font-size:14px}
.person p{margin:0;color:var(--muted);font-size:14px}
.deptGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.miniTeam{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.miniPerson{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--shadow)}
.miniPerson img{width:72px;height:72px;border-radius:16px;object-fit:cover;background:#eef3f9;flex:0 0 72px}
.miniPerson h4{margin:0 0 3px;font-size:15px}
.miniPerson p{margin:0;color:var(--muted);font-size:13px}
.contactGrid,.footerTop{display:grid;gap:18px}
.contactGrid{grid-template-columns:.95fr 1.05fr}
.footer{margin-top:34px;background:#0d1522;color:#dbe7ff}
.footer .container{padding:26px 18px}
.footerTop{grid-template-columns:1.1fr .9fr}
.sep{border:none;border-top:1px solid rgba(255,255,255,.12);margin:18px 0}
.footerNote{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.small{font-size:13px;color:inherit;opacity:.92}
.splitMedia{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mediaCard{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.mediaCard img{width:100%;height:250px;object-fit:cover}
.mediaCard .body{padding:16px}
.lightbox{position:fixed;inset:0;background:rgba(7,12,20,.88);display:none;align-items:center;justify-content:center;padding:18px;z-index:120}
.lightbox.open{display:flex}
.lightbox img{max-width:min(1180px,96vw);max-height:84vh;border-radius:20px;border:1px solid rgba(255,255,255,.18);box-shadow:0 30px 90px rgba(0,0,0,.45)}
.lightbox .close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);color:#fff;padding:10px 14px;border-radius:14px;font-size:20px;cursor:pointer}
@media (max-width:1080px){
  .heroGrid,.grid2,.grid3,.projectGrid,.contactGrid,.footerTop,.teamHero,.deptGrid,.splitMedia{grid-template-columns:1fr 1fr}
  .galleryGrid{grid-template-columns:repeat(3,1fr)}
  .heroStats{grid-template-columns:1fr}
}
@media (max-width:900px){
  .menuBtn{display:inline-flex}
  .cta{display:none}
  .navlinks{display:none;position:absolute;right:0;top:64px;flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:10px;min-width:250px}
  .navlinks.open{display:flex}
  .heroGrid,.grid2,.grid3,.projectGrid,.contactGrid,.footerTop,.teamHero,.deptGrid,.splitMedia,.miniTeam{grid-template-columns:1fr}
  .galleryGrid{grid-template-columns:repeat(2,1fr)}
  .topbar .container{display:block}
  .heroCopy{padding:30px 24px}
}
@media (max-width:560px){
  .galleryGrid{grid-template-columns:1fr}
  .thumb img{height:240px}
  .h1{font-size:34px}
  .sectionHead h2{font-size:26px}
}

/* --- Refinements for cleaner header and team cards --- */
.person h3,
.miniPerson h4{
  line-height:1.28;
  word-break:keep-all;
  overflow-wrap:normal;
  hyphens:none;
}

.deptGrid{
  align-items:start;
}

.miniTeam{
  grid-template-columns:1fr;
}

.miniPerson{
  min-height:96px;
  align-items:center;
}

.miniPerson div{
  flex:1;
  min-width:0;
}

.miniPerson h4{
  margin:0 0 4px;
  font-size:16px;
}

.miniPerson p{
  line-height:1.35;
}

.person img{
  height:260px;
  object-fit:cover;
  border-bottom:1px solid #e6edf5;
}

@media (min-width: 901px){
  .deptGrid{
    grid-template-columns:repeat(3,1fr);
  }
}

/* --- Final v3 refinements --- */
.brand img{
  width:56px;
  height:56px;
  border-radius:50%;
  object-fit:contain;
  background:#fff;
  padding:2px;
  box-shadow:none;
}
.brand span:last-child{
  line-height:1.05;
}
.navlinks{
  flex-wrap:nowrap;
}
.navlinks a{
  padding:10px 14px;
  white-space:nowrap;
}
.heroStats .stat span{
  display:block;
  color:var(--muted);
  font-size:14px;
  line-height:1.4;
}
.person, .miniPerson, .projectCard, .card, .mediaCard, .thumb{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.person:hover, .miniPerson:hover, .projectCard:hover, .card:hover, .mediaCard:hover, .thumb:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 48px rgba(15,33,57,.12);
  border-color:#cfe0f3;
}
.teamHero{
  align-items:stretch;
}
.person{
  display:flex;
  flex-direction:column;
  height:100%;
}
.person .body{
  flex:1;
}
.deptGrid{
  gap:24px;
}
.miniTeam{
  gap:16px;
}
.miniPerson{
  min-height:108px;
}
.miniPerson p{
  white-space:normal;
}
@media (min-width: 901px){
  .nav .brand{
    flex:0 0 auto;
  }
  .navlinks{
    gap:10px;
  }
}

/* --- v4 viewport and portrait fixes --- */
html, body{
  max-width:100%;
  overflow-x:hidden;
}
.container{
  width:min(100%, var(--max));
}
.nav{
  flex-wrap:nowrap;
}
.brand{
  min-width:0;
}
.brand span:last-child{
  font-size:15px;
}
.cta .btn{
  padding:11px 14px;
}
.heroCard, .bannerCard, .card, .projectCard, .mediaCard, .person, .thumb, .miniPerson{
  max-width:100%;
}
.teamHero{
  grid-template-columns:repeat(4, minmax(0,1fr));
}
.deptGrid{
  grid-template-columns:repeat(3, minmax(0,1fr));
}
.person img{
  height:300px;
  object-fit:contain !important;
  object-position:center top;
  background:#f7f9fc;
  padding:8px;
}
.miniPerson img{
  object-fit:contain !important;
  object-position:center top;
  background:#f7f9fc;
  padding:4px;
}
.heroImg img,
.bannerImg img{
  object-fit:cover;
  object-position:center center;
}
@media (max-width: 1280px){
  .navlinks a{
    padding:9px 10px;
    font-size:15px;
  }
  .cta .btn{
    padding:10px 12px;
    font-size:15px;
  }
  .brand span:last-child{
    font-size:14px;
  }
}
@media (max-width: 1180px){
  .cta{
    display:none;
  }
}
@media (max-width: 980px){
  .nav{
    flex-wrap:wrap;
  }
}

/* --- v5 portrait presentation fixes --- */
.person{
  overflow:hidden;
}
.person img{
  width:100%;
  height:320px;
  object-fit:contain !important;
  object-position:center center !important;
  background:#f7f9fc;
  padding:10px 10px 0 10px;
}
.miniPerson{
  align-items:flex-start;
}
.miniPerson img{
  width:76px;
  height:76px;
  border-radius:14px;
  object-fit:contain !important;
  object-position:center center !important;
  background:#f7f9fc;
  padding:3px;
  border:1px solid #edf2f7;
}
.person .body{
  padding-top:14px;
}
@media (max-width:900px){
  .person img{
    height:280px;
  }
}

/* --- v6 portrait natural framing --- */
.person img{
  width:100%;
  height:340px;
  object-fit:contain !important;
  object-position:center top !important;
  background:#f7f9fc;
  padding:18px 14px 8px 14px !important;
}
.miniPerson img{
  width:82px;
  height:82px;
  object-fit:contain !important;
  object-position:center top !important;
  background:#f7f9fc;
  padding:8px 6px 4px 6px !important;
  border:1px solid #edf2f7;
  border-radius:14px;
}
.person{
  overflow:hidden;
}
.miniPerson{
  align-items:flex-start;
}
@media (max-width:900px){
  .person img{
    height:300px;
  }
}

/* --- v7 leadership card layout refinement --- */
.teamHero{
  grid-template-columns:repeat(4, minmax(0,1fr));
  align-items:stretch;
}
.person{
  text-align:center;
  padding-top:12px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  min-height:100%;
}
.person img{
  width:240px !important;
  max-width:78%;
  height:auto !important;
  max-height:320px;
  display:block;
  margin:28px auto 18px auto !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#ffffff !important;
  padding:0 !important;
  border:none !important;
  box-shadow:none !important;
}
.person .body{
  padding:14px 18px 18px 18px;
  text-align:left;
}
.person h3{
  font-size:18px;
  margin:0 0 4px 0;
}
.person .role{
  font-size:14px;
  margin-bottom:10px;
}
.person p{
  font-size:13px;
  line-height:1.45;
}
.miniPerson{
  align-items:center !important;
}
.miniPerson img{
  width:72px !important;
  height:72px !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#ffffff !important;
  padding:2px !important;
  border-radius:10px !important;
  border:1px solid #edf2f7;
  box-shadow:none !important;
}
.miniPerson div{
  flex:1;
}
@media (max-width:1200px){
  .person img{
    width:210px !important;
  }
}
@media (max-width:900px){
  .teamHero{
    grid-template-columns:1fr 1fr;
  }
  .person img{
    width:190px !important;
    max-height:280px;
  }
}
@media (max-width:640px){
  .teamHero{
    grid-template-columns:1fr;
  }
}


/* --- v9 contact + premium refinements --- */
.leadershipContactLayout{
  display:grid;
  grid-template-columns:minmax(0,3fr) minmax(280px,1fr);
  gap:32px;
  align-items:start;
}
.teamArea{
  min-width:0;
}
.contactArea{
  min-width:0;
}
.contactStickyCard{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.contactStickyCard .darkBox{
  position:sticky;
  top:118px;
}
.contactQuickMeta{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  box-shadow:var(--shadow);
}
.person{
  border-radius:24px;
}
.person .body{
  padding-top:10px;
}
.person h3{
  letter-spacing:-.2px;
}
.miniPerson{
  border-radius:20px;
}
.miniPerson h4{
  letter-spacing:-.1px;
}
.deptGrid .card{
  border-radius:24px;
}
@media (max-width:1080px){
  .leadershipContactLayout{
    grid-template-columns:1fr;
  }
  .contactStickyCard .darkBox{
    position:relative;
    top:auto;
  }
}


/* --- Gallery redesign --- */
.galleryHero{
  background:linear-gradient(135deg,#0b2c4d,#163f69);
  color:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.galleryHeroGrid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
}
.galleryHeroCopy{
  padding:38px 36px 34px;
}
.galleryHeroCopy p{
  color:#e2ecfa;
}
.galleryHeroImage{
  min-height:320px;
}
.galleryHeroImage img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.galleryStats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:20px;
}
.galleryStat{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  border-radius:18px;
  padding:14px;
}
.galleryStat strong{
  display:block;
  font-size:22px;
  color:#fff;
}
.galleryControls{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.galleryChip{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  color:var(--brand);
  border:1px solid var(--line);
  font-weight:800;
}
.gallerySection{
  margin-top:10px;
}
.gallerySection h3{
  margin:0 0 6px;
  font-size:24px;
}
.gallerySectionIntro{
  margin:0 0 14px;
  color:var(--muted);
}
.galleryMasonry{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.galleryCard{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.galleryCard:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 48px rgba(15,33,57,.12);
  border-color:#cfe0f3;
}
.galleryCard img{
  width:100%;
  height:250px;
  object-fit:cover;
}
.galleryCardBody{
  padding:14px 16px 16px;
}
.galleryCardBody h4{
  margin:0 0 4px;
  font-size:17px;
}
.galleryCardBody p{
  margin:0;
  color:var(--muted);
  font-size:14px;
}
.galleryNotice{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  box-shadow:var(--shadow);
}
@media (max-width:1080px){
  .galleryHeroGrid,
  .galleryMasonry{
    grid-template-columns:1fr 1fr;
  }
  .galleryStats{
    grid-template-columns:1fr;
  }
}
@media (max-width:900px){
  .galleryHeroGrid,
  .galleryMasonry{
    grid-template-columns:1fr;
  }
}
