/* =========================================================
   JGo — Executive Leadership Digital Experience
   Premium design system
   ========================================================= */

:root{
  --atlantic:#0A1E3F;
  --atlantic-2:#0F2A57;
  --midnight:#061229;
  --ivory:#FAF7F1;
  --sand:#E8DFCE;
  --sand-warm:#D9CDB3;
  --gold:#C9A24A;
  --gold-soft:#E3C77A;
  --coral:#E76F51;
  --coral-soft:#F2A58E;
  --silver:#B6BFCC;
  --grey-1:#1F2A3C;
  --grey-2:#3A475B;
  --grey-3:#6B7689;
  --line:rgba(10,30,63,.12);
  --line-dark:rgba(255,255,255,.14);

  --ff-display:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --ff-serif:'Playfair Display', Georgia, serif;
  --ff-sans:'Inter', 'Manrope', system-ui, -apple-system, sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --container:min(1280px, 92vw);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--grey-1);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ====== Typography ====== */
.display{
  font-family:var(--ff-display);
  font-weight:500;
  letter-spacing:-.01em;
  line-height:1.04;
}
.serif{font-family:var(--ff-serif);font-weight:500}
.eyebrow{
  font-family:var(--ff-sans);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.eyebrow::before{
  content:"";
  width:34px;height:1px;background:var(--gold);
}
.eyebrow.center::after{
  content:"";
  width:34px;height:1px;background:var(--gold);
}
.eyebrow.center{display:inline-flex;gap:12px}

h1,h2,h3,h4{margin:0;font-family:var(--ff-display);font-weight:500;letter-spacing:-.01em;line-height:1.08}
h1{font-size:clamp(2.6rem,6vw,5.8rem)}
h2{font-size:clamp(2rem,4vw,3.6rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
p{line-height:1.7;color:var(--grey-2)}

.container{width:var(--container);margin-inline:auto}

/* ====== Navigation ====== */
.site-nav{
  position:fixed;inset:0 0 auto 0;
  z-index:60;
  padding:16px 0;
  transition:background .45s var(--ease), box-shadow .45s var(--ease), padding .45s var(--ease);
  background:linear-gradient(180deg, rgba(6,18,41,.55), rgba(6,18,41,0));
}
.site-nav.solid{
  background:rgba(250,247,241,.96);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  box-shadow:0 8px 30px rgba(10,30,63,.08);
  padding:12px 0;
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:48px;
  width:var(--container);margin-inline:auto;
}
.brand{
  display:inline-block;
  font-family:var(--ff-display);
  font-size:20px;letter-spacing:.015em;font-weight:500;
  color:#fff;
  line-height:1;
  white-space:nowrap;
  flex:0 0 auto;
}
.site-nav.solid .brand{color:var(--atlantic)}

.nav-links{
  display:flex;gap:34px;align-items:center;
  list-style:none;margin:0;padding:0;
  flex:0 0 auto;flex-wrap:nowrap;
  margin-left:auto;
}
.nav-links a{
  position:relative;
  font-size:13px;letter-spacing:.06em;font-weight:500;
  color:rgba(255,255,255,.95);padding:6px 0;white-space:nowrap;
}
.site-nav.solid .nav-links a{color:var(--atlantic)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--gold);
  transition:width .4s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold)}

.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 22px;border-radius:50px;
  background:var(--gold);color:var(--atlantic);
  font-size:12px;letter-spacing:.2em;font-weight:700;text-transform:uppercase;
  transition:all .35s var(--ease);
  white-space:nowrap;
  flex:0 0 auto;
  margin-left:8px;
}
.nav-cta:hover{background:var(--atlantic);color:var(--gold)}

.hamburger{display:none;width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(255,255,255,.35);position:relative;z-index:80;background:transparent}
/* CRITICAL: mobile drawer must be hidden on desktop */
.mobile-menu{display:none}
.hamburger span{position:absolute;left:12px;right:12px;height:1.5px;background:#fff;transition:all .3s var(--ease)}
.hamburger span:nth-child(1){top:17px}
.hamburger span:nth-child(2){top:22px}
.hamburger span:nth-child(3){top:27px}
.site-nav.solid .hamburger{border-color:var(--atlantic)}
.site-nav.solid .hamburger span{background:var(--atlantic)}
.hamburger.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:22px;transform:rotate(-45deg)}

@media (max-width:1400px){
  .brand{font-size:18px}
  .nav-inner{gap:28px}
  .nav-links{gap:22px}
  .nav-links a{font-size:12px}
}
@media (max-width:1250px){
  .site-nav .nav-links,.site-nav .nav-cta{display:none}
  .hamburger{display:inline-block;margin-left:auto}
  .mobile-menu{
    position:fixed;inset:0;background:var(--atlantic);z-index:70;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    gap:32px;padding:40px;
    transform:translateY(-100%);transition:transform .5s var(--ease);
  }
  .mobile-menu.active{transform:translateY(0)}
  .mobile-menu .nav-links{display:flex;flex-direction:column;gap:22px}
  .mobile-menu .nav-links a{color:#fff;font-size:22px;font-family:var(--ff-display);padding:4px 0}
  .mobile-menu .nav-cta{display:inline-flex}
}
@media (max-width:560px){
  .brand-text{display:none}
}

/* ====== Buttons ====== */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 30px;border-radius:50px;
  font-size:12.5px;letter-spacing:.2em;font-weight:700;text-transform:uppercase;
  transition:all .4s var(--ease);
  border:1px solid transparent;
}
.btn-primary{background:var(--gold);color:var(--atlantic)}
.btn-primary:hover{background:#fff;color:var(--atlantic);transform:translateY(-2px);box-shadow:0 14px 36px rgba(0,0,0,.18)}
.btn-outline{border-color:rgba(255,255,255,.45);color:#fff}
.btn-outline:hover{background:#fff;color:var(--atlantic);border-color:#fff}
.btn-dark{background:var(--atlantic);color:#fff}
.btn-dark:hover{background:var(--gold);color:var(--atlantic)}
.btn .arrow{width:14px;height:1px;background:currentColor;position:relative}
.btn .arrow::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;border-right:1px solid currentColor;border-top:1px solid currentColor;transform:rotate(45deg)}

/* ====== Password Gate ====== */
.gate{
  position:fixed;inset:0;
  display:grid;place-items:center;
  z-index:100;overflow:hidden;
}
.gate-bg{position:absolute;inset:0;z-index:-2}
.gate-bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.55) saturate(1.05)}
.gate-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(201,162,74,.25), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(231,111,81,.18), transparent 50%),
    linear-gradient(135deg, rgba(6,18,41,.7), rgba(10,30,63,.82));
}
.gate-panel{
  width:min(540px,92vw);
  padding:56px 48px;
  border-radius:26px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(26px) saturate(1.1);
  -webkit-backdrop-filter:blur(26px);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 30px 80px rgba(0,0,0,.55);
  color:#fff;
  text-align:center;
  position:relative;
}
.gate-seal{
  width:84px;height:84px;border-radius:50%;
  display:grid;place-items:center;margin:0 auto 26px;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  color:var(--atlantic);
  font-family:var(--ff-display);font-size:32px;font-weight:600;
  box-shadow:0 14px 40px rgba(201,162,74,.4);
}
.gate h1{
  font-size:clamp(1.9rem,3.4vw,2.6rem);
  margin-bottom:6px;
  color:#fff;
}
.gate p.sub{letter-spacing:.32em;text-transform:uppercase;font-size:11px;color:var(--gold-soft);margin:0 0 34px;font-weight:600}
.gate-form{display:flex;flex-direction:column;gap:16px;text-align:left}
.gate-form label{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:600}
.gate-input{
  padding:16px 20px;border-radius:14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:15px;letter-spacing:.04em;
  transition:all .3s var(--ease);
}
.gate-input:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.12)}
.gate-btn{
  margin-top:6px;padding:17px;border-radius:14px;
  background:var(--gold);color:var(--atlantic);
  font-weight:700;letter-spacing:.22em;font-size:12.5px;text-transform:uppercase;
  transition:all .3s var(--ease);
}
.gate-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,0,0,.35)}
.gate-error{
  margin-top:14px;color:var(--coral-soft);font-size:13px;
  opacity:0;transition:opacity .3s var(--ease);height:18px;
}
.gate-error.show{opacity:1}
.shake{animation:shake .5s}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-10px)}
  40%{transform:translateX(10px)}
  60%{transform:translateX(-7px)}
  80%{transform:translateX(7px)}
}
.gate-foot{
  margin-top:30px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:500;
}

/* ====== HERO (home) ====== */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;padding-bottom:90px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(6,18,41,.35) 0%, rgba(6,18,41,.15) 40%, rgba(6,18,41,.82) 100%),
    linear-gradient(100deg, rgba(10,30,63,.55) 0%, transparent 55%);
}
.hero-inner{position:relative;z-index:2;width:var(--container);margin-inline:auto;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:end}
.hero-side{border-left:1px solid rgba(255,255,255,.2);padding-left:28px}
.hero-side .meta-line{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:20px;font-weight:600}
.hero-side p{color:rgba(255,255,255,.78);font-size:15px;max-width:360px}

.hero h1{color:#fff;font-size:clamp(3rem,8vw,7.6rem);margin-bottom:24px}
.hero h1 em{font-style:italic;color:var(--gold-soft);font-weight:400}
.hero-tagline{
  display:flex;align-items:center;gap:18px;
  margin-bottom:14px;
}
.hero-tagline .line{width:60px;height:1px;background:var(--gold)}
.hero-tagline span{font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600}
.hero-ctas{display:flex;gap:18px;flex-wrap:wrap;margin-top:32px}

.hero-frame-corner{
  position:absolute;top:50%;right:6vw;transform:translateY(-50%);
  width:320px;z-index:2;
  border:1px solid rgba(255,255,255,.18);
  padding:14px;background:rgba(255,255,255,.06);backdrop-filter:blur(18px);
  border-radius:14px;
}
.hero-frame-corner img{aspect-ratio:4/5;object-fit:cover;border-radius:8px;object-position:center top}
.hero-frame-corner .label{color:var(--gold-soft);font-size:11px;letter-spacing:.28em;text-transform:uppercase;margin-top:12px;text-align:center;display:block}

.hero-scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.32em;color:rgba(255,255,255,.7);
  text-transform:uppercase;z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero-scroll::after{content:"";width:1px;height:40px;background:rgba(255,255,255,.4);animation:scroll 2s infinite}
@keyframes scroll{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:28px;padding-top:130px}
  .hero-frame-corner{display:none}
  .hero{padding-bottom:60px}
}

/* ====== Generic Sections ====== */
section{padding:120px 0;position:relative}
.section-head{max-width:760px;margin-bottom:64px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{margin-bottom:14px}
.section-head p{font-size:17px;color:var(--grey-2)}
.sec-dark{background:var(--atlantic);color:#fff}
.sec-dark h2{color:#fff}
.sec-dark p{color:rgba(255,255,255,.75)}
.sec-dark .eyebrow{color:var(--gold-soft)}
.sec-dark .eyebrow::before,.sec-dark .eyebrow::after{background:var(--gold-soft)}
.sec-sand{background:var(--sand);color:var(--atlantic)}

/* ====== Stat Strip ====== */
.stat-strip{
  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);
}
.stat-cell{background:var(--ivory);padding:38px 30px}
.sec-dark .stat-strip{background:var(--line-dark);border-color:var(--line-dark)}
.sec-dark .stat-cell{background:var(--atlantic)}
.stat-num{font-family:var(--ff-display);font-size:clamp(2.6rem,5vw,4rem);font-weight:500;color:var(--atlantic);line-height:1}
.sec-dark .stat-num{color:var(--gold-soft)}
.stat-label{margin-top:10px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey-3);font-weight:600}
.sec-dark .stat-label{color:rgba(255,255,255,.65)}
@media (max-width:900px){.stat-strip{grid-template-columns:repeat(2,1fr)}}

/* ====== Intro Editorial ====== */
.editorial{
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center;
}
.editorial .lead{font-size:22px;font-family:var(--ff-display);font-weight:500;color:var(--atlantic);line-height:1.45;margin-bottom:22px;font-style:italic}
.editorial .img-wrap{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden}
.editorial .img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.editorial .img-wrap::after{
  content:"";position:absolute;inset:auto -14px -14px auto;width:56%;height:58%;
  border:1px solid var(--gold);z-index:-1;
}
.editorial .signature{font-family:var(--ff-display);font-size:28px;color:var(--gold);font-style:italic;margin-top:24px}
@media (max-width:900px){.editorial{grid-template-columns:1fr;gap:40px}}

/* ====== Pillar Cards ====== */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.pillar{
  position:relative;padding:44px 34px 40px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--line);
  transition:all .45s var(--ease);
  overflow:hidden;
}
.pillar::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease);
}
.pillar:hover::before{transform:scaleY(1)}
.pillar:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(10,30,63,.1)}
.pillar .num{font-family:var(--ff-display);font-size:40px;color:var(--gold);font-style:italic;margin-bottom:12px;opacity:.75}
.pillar h3{color:var(--atlantic);margin-bottom:12px}
.pillar p{font-size:15px;color:var(--grey-2)}
.pillar .arrow-link{display:inline-flex;align-items:center;gap:10px;margin-top:22px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--atlantic);font-weight:700}
.pillar .arrow-link::after{content:"→";transition:transform .3s var(--ease)}
.pillar:hover .arrow-link::after{transform:translateX(5px)}

@media (max-width:900px){.pillars{grid-template-columns:1fr}}

/* ====== Initiative Split ====== */
.split-media{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  min-height:80vh;
}
.split-media .side-image{position:relative;overflow:hidden}
.split-media .side-image img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.split-media .side-content{padding:100px 70px;display:flex;flex-direction:column;justify-content:center;background:var(--midnight);color:#fff}
.split-media .side-content h2{color:#fff}
.split-media .side-content p{color:rgba(255,255,255,.75)}
.split-media .eyebrow{color:var(--gold-soft)}
.split-media .eyebrow::before{background:var(--gold-soft)}
@media (max-width:900px){
  .split-media{grid-template-columns:1fr}
  .split-media .side-image{min-height:60vh}
  .split-media .side-content{padding:60px 32px}
}

/* ====== Quote Banner ====== */
.quote-banner{
  position:relative;padding:160px 0;text-align:center;color:#fff;
  overflow:hidden;
}
.quote-banner .bg{position:absolute;inset:0;z-index:0}
.quote-banner .bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.45)}
.quote-banner .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,30,63,.35),rgba(6,18,41,.75))}
.quote-banner .inner{position:relative;z-index:2;max-width:900px;margin-inline:auto;padding:0 24px}
.quote-banner .mark{font-family:var(--ff-display);font-size:120px;line-height:0.7;color:var(--gold);opacity:.55;font-style:italic;display:block;margin-bottom:20px}
.quote-banner blockquote{font-family:var(--ff-display);font-size:clamp(1.8rem,3.4vw,3rem);font-weight:400;font-style:italic;line-height:1.25;margin:0 0 28px}
.quote-banner cite{font-style:normal;font-size:12px;letter-spacing:.32em;color:var(--gold-soft);text-transform:uppercase;font-weight:700}

/* ====== Timeline ====== */
.timeline{position:relative;max-width:980px;margin-inline:auto}
.timeline::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line);
  transform:translateX(-50%);
}
.tl-item{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:80px;align-items:center}
.tl-item:last-child{margin-bottom:0}
.tl-item .dot{
  position:absolute;left:50%;top:30px;transform:translateX(-50%);
  width:16px;height:16px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 0 6px var(--ivory),0 0 0 7px var(--line);
  z-index:2;
}
.tl-item:nth-child(even) .tl-text{grid-column:2}
.tl-item:nth-child(even) .tl-img{grid-column:1;grid-row:1}
.tl-text .year{font-family:var(--ff-display);font-style:italic;font-size:52px;color:var(--gold);line-height:1;margin-bottom:10px}
.tl-text h3{color:var(--atlantic);margin-bottom:10px}
.tl-text p{font-size:15px}
.tl-img{aspect-ratio:4/3;overflow:hidden;border-radius:8px}
.tl-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.tl-item.text-only .tl-img{display:none}
.tl-item.text-only .tl-text{grid-column:1 / -1;max-width:720px;margin-inline:auto;text-align:center}
@media (max-width:900px){
  .timeline::before{left:20px}
  .tl-item{grid-template-columns:1fr;gap:20px}
  .tl-item .dot{left:20px}
  .tl-item:nth-child(even) .tl-text,.tl-item:nth-child(even) .tl-img{grid-column:1}
  .tl-item:nth-child(even) .tl-img{grid-row:auto}
  .tl-item{padding-left:50px}
}

/* ====== Agenda Grid ====== */
.agenda-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.agenda-card{
  position:relative;overflow:hidden;border-radius:14px;
  min-height:420px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:34px;color:#fff;
  background:var(--atlantic);
}
.agenda-card .ac-bg{position:absolute;inset:0;z-index:0}
.agenda-card .ac-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .8s var(--ease)}
.agenda-card:hover .ac-bg img{transform:scale(1.08)}
.agenda-card .ac-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,30,63,0) 30%,rgba(6,18,41,.92) 100%);
}
.agenda-card .ac-content{position:relative;z-index:2}
.agenda-card .ac-num{font-family:var(--ff-display);font-style:italic;color:var(--gold);font-size:18px;margin-bottom:10px;display:block}
.agenda-card h3{color:#fff;margin-bottom:10px}
.agenda-card p{color:rgba(255,255,255,.85);font-size:14.5px}
@media (max-width:900px){.agenda-grid{grid-template-columns:1fr}}

/* ====== Metrics (animated progress) ====== */
.metric-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:36px 60px;
}
.metric{padding:22px 0;border-bottom:1px solid var(--line)}
.metric .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.metric .label{font-size:14px;letter-spacing:.06em;font-weight:600;color:var(--atlantic)}
.metric .val{font-family:var(--ff-display);font-size:28px;color:var(--gold);font-style:italic}
.metric .bar{height:4px;background:var(--line);border-radius:4px;overflow:hidden}
.metric .bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--coral));width:0;transition:width 1.6s var(--ease)}
/* metric contrast when section is dark */
.sec-dark .metric{border-bottom-color:rgba(255,255,255,.14)}
.sec-dark .metric .label{color:#ffffff}
.sec-dark .metric .val{color:var(--gold-soft)}
.sec-dark .metric .bar{background:rgba(255,255,255,.14)}
@media (max-width:700px){.metric-row{grid-template-columns:1fr}}

/* ====== Washington Page ====== */
.wash-hero{
  min-height:70vh;display:flex;align-items:center;color:#fff;
  position:relative;overflow:hidden;padding-top:160px;padding-bottom:100px;
}
.wash-hero .bg{position:absolute;inset:0;z-index:0}
.wash-hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.55)}
.wash-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(6,18,41,.85),rgba(10,30,63,.45))}
.wash-hero .inner{position:relative;z-index:2;width:var(--container);margin-inline:auto;max-width:880px}
.wash-hero h1{color:#fff}

.federal-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center}
.federal-list{display:grid;gap:24px}
.federal-item{padding:24px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:60px 1fr;gap:24px;align-items:start}
.federal-item:first-child{border-top:none}
.federal-item .fi-num{font-family:var(--ff-display);font-size:36px;color:var(--gold);line-height:1;font-style:italic}
.federal-item h3{color:var(--atlantic);margin-bottom:8px;font-size:22px}
.federal-item p{font-size:15px;color:var(--grey-2)}
.federal-portrait{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden}
.federal-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
@media (max-width:900px){.federal-grid{grid-template-columns:1fr;gap:40px}}

/* ====== Vision Page Futuristic ====== */
.vision-hero{
  min-height:85vh;position:relative;overflow:hidden;color:#fff;
  display:flex;align-items:center;padding-top:160px;
}
.vision-hero .bg{position:absolute;inset:0;z-index:0}
.vision-hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.5) saturate(1.1)}
.vision-hero .bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 70% 40%, rgba(201,162,74,.2),transparent 50%),
  linear-gradient(150deg,rgba(6,18,41,.85),rgba(10,30,63,.55))}
.vision-hero .inner{position:relative;z-index:2;width:var(--container);margin-inline:auto;max-width:1000px}
.vision-hero h1{color:#fff}
.vision-hero h1 em{color:var(--gold-soft);font-style:italic}

.vision-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;grid-auto-rows:220px}
.vg-card{
  position:relative;overflow:hidden;border-radius:12px;padding:28px;color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;
  background:linear-gradient(160deg,var(--atlantic),var(--midnight));
  border:1px solid rgba(255,255,255,.08);
  transition:transform .5s var(--ease);
}
.vg-card:hover{transform:translateY(-6px)}
.vg-card .tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);font-weight:700}
.vg-card h3{color:#fff;font-size:26px}
.vg-card p{color:rgba(255,255,255,.75);font-size:14px;margin:0}
.vg-card.has-img{padding:0}
.vg-card.has-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;object-position:center 22%}
.vg-card.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(6,18,41,.9))}
.vg-card.has-img .vg-inner{position:relative;z-index:2;height:100%;padding:28px;display:flex;flex-direction:column;justify-content:flex-end}
.vg-card.c-wide{grid-column:span 4}
.vg-card.c-tall{grid-row:span 2}
.vg-card.c-med{grid-column:span 3}
.vg-card.c-small{grid-column:span 2}
@media (max-width:900px){
  .vision-grid{grid-template-columns:1fr;grid-auto-rows:auto}
  .vg-card{min-height:240px;grid-column:auto !important;grid-row:auto !important}
}

/* ====== Gallery ====== */
.gallery-masonry{
  column-count:3;column-gap:18px;
}
.gm-item{
  break-inside:avoid;margin-bottom:18px;position:relative;overflow:hidden;border-radius:10px;
  cursor:pointer;
}
.gm-item img{width:100%;height:auto;display:block;transition:transform .8s var(--ease)}
.gm-item:hover img{transform:scale(1.07)}
.gm-item .caption{
  position:absolute;inset:auto 0 0 0;padding:30px 22px 18px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(6,18,41,.85));
  opacity:0;transform:translateY(8px);transition:all .4s var(--ease);
}
.gm-item:hover .caption{opacity:1;transform:translateY(0)}
.gm-item .caption h4{font-size:16px;margin-bottom:4px;color:#fff}
.gm-item .caption span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft)}
@media (max-width:900px){.gallery-masonry{column-count:2}}
@media (max-width:600px){.gallery-masonry{column-count:1}}

.lightbox{
  position:fixed;inset:0;background:rgba(6,18,41,.94);backdrop-filter:blur(8px);
  z-index:200;display:none;align-items:center;justify-content:center;padding:40px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:6px;object-fit:contain}
.lightbox .close{position:absolute;top:20px;right:24px;color:#fff;font-size:32px;background:none;border:none}

/* ====== News / Press ====== */
.news-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px}
.news-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;transition:all .4s var(--ease);
}
.news-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px rgba(10,30,63,.12)}
.news-card .ni-img{aspect-ratio:16/10;overflow:hidden}
.news-card.featured .ni-img{aspect-ratio:16/11}
.news-card .ni-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform .8s var(--ease)}
.news-card:hover .ni-img img{transform:scale(1.05)}
.news-card .ni-body{padding:26px 28px 30px;display:flex;flex-direction:column;gap:10px;flex:1}
.news-card .ni-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--grey-3);font-weight:600}
.news-card .ni-meta .cat{color:var(--gold);font-weight:700}
.news-card .ni-body h3{color:var(--atlantic);font-size:22px;line-height:1.25}
.news-card.featured .ni-body h3{font-size:30px}
.news-card .ni-body p{font-size:14.5px;color:var(--grey-2);margin:0}
.news-card .ni-body .read{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--atlantic);font-weight:700;margin-top:auto;padding-top:16px;display:inline-flex;gap:10px;align-items:center}
.news-card .ni-body .read::after{content:"→";transition:transform .3s var(--ease)}
.news-card:hover .read::after{transform:translateX(4px)}

.news-card.featured{grid-row:span 2;grid-column:1}
@media (max-width:900px){
  .news-grid{grid-template-columns:1fr}
  .news-card.featured{grid-row:auto;grid-column:auto}
}

.press-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);margin-top:60px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.press-strip-item{background:var(--ivory);padding:30px;display:flex;flex-direction:column;gap:8px}
.press-strip-item .d{font-family:var(--ff-display);color:var(--gold);font-style:italic;font-size:24px}
.press-strip-item h4{color:var(--atlantic);font-family:var(--ff-sans);font-size:15px;font-weight:600;letter-spacing:.01em;margin-top:6px}
.press-strip-item a{color:var(--atlantic);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-top:10px}
@media (max-width:900px){.press-strip{grid-template-columns:1fr 1fr}}

/* ====== Contact ====== */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:90vh}
.contact-form-side{padding:120px 70px;background:var(--ivory)}
.contact-visual{position:relative;overflow:hidden}
.contact-visual img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.contact-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,rgba(6,18,41,.35),rgba(10,30,63,.55));
}
.contact-visual .overlay-card{
  position:absolute;left:40px;bottom:40px;right:40px;color:#fff;
  padding:40px;background:rgba(10,30,63,.55);
  backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.15);
  border-radius:14px;
}
.contact-visual .overlay-card h3{color:#fff;margin-bottom:12px}
.contact-visual .overlay-card p{color:rgba(255,255,255,.8)}
.contact-visual .overlay-card a{color:var(--gold-soft)}

.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-form .full{grid-column:1 / -1}
.field label{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--grey-3);margin-bottom:10px}
.field input,.field textarea{
  width:100%;padding:16px 18px;border-radius:10px;
  background:#fff;border:1px solid var(--line);
  font-size:15px;font-family:inherit;color:var(--atlantic);
  transition:all .3s var(--ease);
}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,162,74,.12)}
.contact-info-list{display:grid;gap:18px;margin-top:22px}
.contact-info-list .ci{display:flex;gap:16px;align-items:center;font-size:14px;color:rgba(255,255,255,.85)}
.contact-info-list .ci .ic{
  width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.3);
  display:grid;place-items:center;color:var(--gold-soft);flex-shrink:0;
}
@media (max-width:1000px){
  .contact-split{grid-template-columns:1fr}
  .contact-form-side{padding:80px 28px}
  .contact-visual{min-height:60vh}
}

/* ====== Footer ====== */
footer.site-footer{
  background:var(--midnight);color:rgba(255,255,255,.75);
  padding:80px 0 36px;position:relative;overflow:hidden;
}
footer.site-footer::before{
  content:"";position:absolute;inset:auto 0 auto 0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid var(--line-dark)}
.footer-brand .brand{color:#fff;margin-bottom:20px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.65);max-width:360px;margin-bottom:20px}
.footer-col h5{font-family:var(--ff-sans);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 18px;font-weight:700}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{color:rgba(255,255,255,.75);font-size:14px;transition:color .3s var(--ease)}
.footer-col ul a:hover{color:var(--gold-soft)}

.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding-top:34px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.55);
}
.footer-bottom a{color:rgba(255,255,255,.85)}
.footer-bottom a:hover{color:var(--gold-soft)}
.socials{display:flex;gap:10px}
.socials a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;color:rgba(255,255,255,.85);
  transition:all .3s var(--ease);
}
.socials a:hover{background:var(--gold);color:var(--atlantic);border-color:var(--gold);transform:translateY(-2px)}
.socials svg{width:15px;height:15px;fill:currentColor}

.footer-credits-mid{
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding:20px 0;font-size:13px;color:rgba(255,255,255,.55);
}
.footer-credits-mid a{color:var(--gold-soft)}

@media (max-width:900px){
  .footer-top{grid-template-columns:1fr;gap:40px}
}

/* ====== Reveal animations ======
   Text is FULLY visible at all times. The .in class plays a
   gentle slide-up only — no opacity manipulation, so text cannot
   ever be stuck hidden even if JS / observer fails. */
.reveal.in{animation:revealIn .7s var(--ease)}
.reveal-delay-1.in{animation-delay:.08s}
.reveal-delay-2.in{animation-delay:.16s}
.reveal-delay-3.in{animation-delay:.24s}
@keyframes revealIn{
  from{transform:translateY(18px)}
  to{transform:translateY(0)}
}
@media (prefers-reduced-motion:reduce){
  .reveal.in{animation:none}
}

/* ====== Utility ====== */
.mt-0{margin-top:0}
.center{text-align:center}
.mx-auto{margin-inline:auto}
.small-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:700}

/* ====== Page Headers ====== */
.page-header{
  position:relative;
  min-height:60vh;display:flex;align-items:flex-end;
  padding:170px 0 70px;color:#fff;overflow:hidden;
}
.page-header .bg{position:absolute;inset:0;z-index:0}
.page-header .bg img{width:100%;height:100%;object-fit:cover;object-position:center 18%;filter:brightness(.6)}
.page-header .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,18,41,.45),rgba(10,30,63,.85))}
.page-header .inner{position:relative;z-index:2;width:var(--container);margin-inline:auto;max-width:920px}
.page-header .crumb{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:18px;font-weight:700}
.page-header h1{color:#fff;margin-bottom:16px}
.page-header p{color:rgba(255,255,255,.82);max-width:640px;font-size:17px}

/* ====== Initiative List ====== */
.initiative-list{display:grid;gap:0}
.init-item{
  display:grid;grid-template-columns:120px 1fr auto;gap:40px;
  padding:40px 0;border-top:1px solid var(--line);align-items:center;
  transition:all .4s var(--ease);
}
.init-item:first-child{border-top:none}
.init-item .no{font-family:var(--ff-display);font-size:48px;color:var(--gold);font-style:italic;line-height:1}
.init-item .txt h3{color:var(--atlantic);margin-bottom:8px}
.init-item .txt p{font-size:15px;max-width:600px;color:var(--grey-2);margin:0}
.init-item .tag{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey-3);font-weight:600}
.init-item:hover{padding-left:20px}
@media (max-width:800px){
  .init-item{grid-template-columns:1fr;gap:10px;padding:30px 0}
  .init-item .no{font-size:34px}
  .init-item:hover{padding-left:0}
}
