/*
 * NCB Kingston Page Styles
 * E-Condolence Home Plugin — INTERPOL NCB Kingston
 * Version: 6.0.0
 */


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── INTERPOL OFFICIAL PALETTE ───────────────────────
   Primary Blue:  #003087
   Mid Blue:      #005EB8
   Light Blue:    #E8F0F9
   Red:           #CC0000
   White:         #FFFFFF
   Dark text:     #0D1B2A
   Muted:         #5A6B7C
   ─────────────────────────────────────────────────── */
:root{
  --blue:    #003087;
  --blue2:   #004aad;
  --blue3:   #005EB8;
  --blue-lt: #E8F0F9;
  --blue-xl: #f0f5fc;
  --red:     #CC0000;
  --red2:    #e00;
  --white:   #ffffff;
  --ink:     #0D1B2A;
  --muted:   #5A6B7C;
  --border:  #d0dce8;
  --gold:    #c8963e;
}

html{scroll-behavior:smooth}
body{
  font-family:'Libre Baskerville',serif;
  background:var(--white);
  color:var(--ink);
  overflow-x:hidden;
  cursor:none;
}

/* ── CURSOR ─────────────────────────────── */
#cursor{
  position:fixed;width:9px;height:9px;
  background:var(--blue);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .12s,background .2s;
}
#cursor-ring{
  position:fixed;width:32px;height:32px;
  border:1.5px solid rgba(0,48,135,0.4);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s,border-color .2s;
}

/* ── NAV ─────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:64px;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(16px);
  border-bottom:2px solid var(--blue);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 56px;
}
.nav-left{display:flex;align-items:center;gap:18px}
.nav-interpol-bar{
  width:4px;height:32px;
  background:linear-gradient(180deg,var(--blue) 50%,var(--red) 50%);
}
.nav-name-block{}
.nav-org{
  font-family:'Share Tech Mono',monospace;
  font-size:8.5px;letter-spacing:.28em;
  color:var(--muted);text-transform:uppercase;
  display:block;margin-bottom:1px;
}
.nav-name{
  font-family:'Rajdhani',sans-serif;
  font-size:16px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--blue);
  display:block;line-height:1;
}
.nav-right{display:flex;align-items:center;gap:36px}
.nav-link{
  font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;color:var(--muted);
  text-decoration:none;transition:color .2s;position:relative;
}
.nav-link::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;
  background:var(--blue);transform:scaleX(0);transition:transform .2s;
}
.nav-link:hover{color:var(--blue)}
.nav-link:hover::after{transform:scaleX(1)}
.nav-status{
  display:flex;align-items:center;gap:8px;
  font-family:'Share Tech Mono',monospace;font-size:9px;
  color:var(--muted);padding:6px 14px;
  border:1px solid var(--border);background:var(--blue-xl);
}
.nav-dot{width:6px;height:6px;border-radius:50%;background:#00a651;flex-shrink:0;animation:pulse-g 2s infinite}
@keyframes pulse-g{0%,100%{box-shadow:0 0 0 0 rgba(0,166,81,.5)}50%{box-shadow:0 0 0 6px rgba(0,166,81,0)}}

/* ── HERO ─────────────────────────────────── */
#hero{
  min-height:100vh;
  background:var(--blue);
  position:relative;overflow:hidden;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  padding-top:64px;
}

/* left panel */
.hero-left{
  padding:80px 72px;
  position:relative;z-index:2;
}
.hero-eyebrow{
  display:flex;align-items:center;gap:14px;
  font-family:'Share Tech Mono',monospace;
  font-size:10px;letter-spacing:.28em;
  color:rgba(255,255,255,.55);
  text-transform:uppercase;margin-bottom:28px;
}
.hero-eyebrow-line{width:36px;height:1px;background:var(--red)}
.hero-h1{
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(58px,7vw,100px);
  font-weight:700;line-height:.88;
  letter-spacing:.01em;
  color:#fff;
  margin-bottom:32px;
}
.hero-h1 .accent{color:var(--gold)}
.hero-h1 .outline{
  -webkit-text-stroke:1.5px rgba(255,255,255,.35);
  color:transparent;
}
.hero-desc{
  font-size:17px;
  font-style:italic;font-weight:400;
  color:rgba(255,255,255,.65);
  max-width:420px;line-height:1.8;
  margin-bottom:48px;
}
.hero-desc strong{color:rgba(255,255,255,.9);font-style:normal;font-weight:400}
.hero-ctas{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.cta-primary{
  font-family:'Rajdhani',sans-serif;
  font-size:13px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;
  background:#fff;color:var(--blue);
  padding:14px 32px;text-decoration:none;
  display:inline-block;
  transition:background .2s,transform .15s;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.cta-primary:hover{background:var(--blue-lt);transform:translateY(-2px)}
.cta-ghost{
  font-family:'Rajdhani',sans-serif;
  font-size:13px;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.6);
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.cta-ghost:hover{color:#fff;border-color:rgba(255,255,255,.5)}

/* right panel */
.hero-right{
  position:relative;height:100%;min-height:100vh;
  background:var(--blue2);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-right-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:48px 48px;
  animation:grid-move 20s linear infinite;
}
@keyframes grid-move{0%{background-position:0 0}100%{background-position:48px 48px}}

.radar{position:relative;width:340px;height:340px}
.radar svg{position:absolute;inset:0;width:100%;height:100%}
.sweep-arm{transform-origin:180px 180px;animation:sweep 4s linear infinite}
@keyframes sweep{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.blip{animation:blip 4s ease-in-out infinite}
.blip2{animation:blip 4s ease-in-out 1.4s infinite}
.blip3{animation:blip 4s ease-in-out 2.6s infinite}
@keyframes blip{0%,100%{opacity:0}45%,55%{opacity:1}50%{r:5}}

.radar-data{
  position:absolute;bottom:-60px;left:50%;transform:translateX(-50%);
  text-align:center;white-space:nowrap;
}
.radar-coord{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.2em;
  color:rgba(255,255,255,.35);
}

/* bottom strip */
.hero-strip{
  position:absolute;bottom:0;left:0;right:50%;
  background:rgba(0,0,0,.25);
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;z-index:3;
}
.hs-item{
  flex:1;padding:20px 28px;
  border-right:1px solid rgba(255,255,255,.1);
}
.hs-item:last-child{border-right:none}
.hs-num{
  font-family:'Rajdhani',sans-serif;
  font-size:30px;font-weight:700;color:#fff;line-height:1;
}
.hs-lbl{
  font-family:'Share Tech Mono',monospace;
  font-size:8.5px;letter-spacing:.15em;
  color:rgba(255,255,255,.4);margin-top:4px;text-transform:uppercase;
}

/* ── MANDATE BAND ─────────────────────────── */
.mandate-band{
  background:var(--red);
  padding:52px 80px;
  display:flex;align-items:center;gap:60px;
  position:relative;overflow:hidden;
}
.mandate-band::after{
  content:'INTERPOL';
  position:absolute;right:-20px;top:-20px;
  font-family:'Rajdhani',sans-serif;
  font-size:160px;font-weight:700;
  color:rgba(255,255,255,.04);
  letter-spacing:-.02em;line-height:1;
  pointer-events:none;
}
.mb-pipe{width:3px;height:60px;background:rgba(255,255,255,.3);flex-shrink:0}
.mb-text{
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(18px,2.4vw,28px);font-weight:500;
  color:#fff;line-height:1.5;max-width:880px;
}
.mb-text em{font-style:normal;color:rgba(255,255,255,.6)}

/* ── SECTION BASE ─────────────────────────── */
.section{padding:96px 80px;position:relative}
.section-inner{max-width:1200px;margin:0 auto}
.s-label{
  font-family:'Share Tech Mono',monospace;
  font-size:9.5px;letter-spacing:.3em;
  color:var(--blue3);text-transform:uppercase;
  margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.s-label::before{content:'';width:28px;height:2px;background:var(--red)}
.s-h2{
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(36px,5vw,62px);font-weight:700;
  line-height:.95;letter-spacing:-.01em;color:var(--blue);
}
.s-sub{
  font-size:17px;font-style:italic;color:var(--muted);
  margin-top:14px;line-height:1.75;max-width:540px;
}

/* divider */
.divider{height:1px;background:var(--border);margin:0 80px}

/* ── ABOUT ────────────────────────────────── */
.about-section{background:var(--white)}
.about-grid{
  display:grid;
  grid-template-columns:1fr 440px;
  gap:80px;align-items:center;
  margin-top:56px;
}
.about-text p{
  font-size:16px;line-height:1.9;
  color:#3a4a5a;margin-bottom:20px;
}
.about-text p:last-child{margin-bottom:0}
.about-text strong{color:var(--ink);font-weight:700}

.about-visual{
  position:relative;
  background:var(--blue);
  aspect-ratio:3/4;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.about-vis-globe svg{opacity:.12}
.about-corner2{
  position:absolute;width:26px;height:26px;
  border-color:rgba(255,255,255,.3);border-style:solid;
}
.about-corner2.tl{top:14px;left:14px;border-width:2px 0 0 2px}
.about-corner2.tr{top:14px;right:14px;border-width:2px 2px 0 0}
.about-corner2.bl{bottom:14px;left:14px;border-width:0 0 2px 2px}
.about-corner2.br{bottom:14px;right:14px;border-width:0 2px 2px 0}
.about-overlay-text{
  position:absolute;bottom:20px;left:20px;
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.18em;
  color:rgba(255,255,255,.3);
}

/* ── PILLARS ──────────────────────────────── */
.pillars-section{background:var(--blue-xl)}
.pillars-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
  border:1px solid var(--border);
  margin-top:56px;
  overflow:hidden;
}
.pillar{
  background:var(--white);
  padding:44px 36px;
  border-right:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:background .25s;
}
.pillar:last-child{border-right:none}
.pillar:hover{background:var(--blue);color:#fff}
.pillar::after{
  content:'';position:absolute;
  top:0;left:0;right:0;height:3px;
  background:var(--red);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s;
}
.pillar:hover::after{transform:scaleX(1)}
.pillar-n{
  position:absolute;top:-8px;right:16px;
  font-family:'Rajdhani',sans-serif;
  font-size:100px;font-weight:700;
  color:rgba(0,48,135,.04);
  line-height:1;pointer-events:none;
  transition:color .25s;
}
.pillar:hover .pillar-n{color:rgba(255,255,255,.06)}
.pillar-ico{
  width:42px;height:42px;
  background:var(--blue-lt);
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
  transition:background .25s,border-color .25s;
}
.pillar:hover .pillar-ico{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.pillar-ico svg{
  width:18px;height:18px;
  stroke:var(--blue);fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  transition:stroke .25s;
}
.pillar:hover .pillar-ico svg{stroke:#fff}
.pillar h3{
  font-family:'Rajdhani',sans-serif;
  font-size:17px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--blue);
  margin-bottom:14px;
  transition:color .25s;
}
.pillar:hover h3{color:#fff}
.pillar p{
  font-family:'Libre Baskerville',serif;
  font-size:13px;line-height:1.75;
  color:var(--muted);transition:color .25s;
}
.pillar:hover p{color:rgba(255,255,255,.7)}

/* ── NUMBERS ──────────────────────────────── */
.numbers-section{
  background:var(--blue);
  padding:0 80px;
}
.numbers-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  border-left:1px solid rgba(255,255,255,.1);
}
.num-item{
  padding:64px 48px;
  border-right:1px solid rgba(255,255,255,.1);
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
  position:relative;overflow:hidden;
  transition:background .3s;
}
.num-item::before{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:3px;
  background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s;
}
.num-item:hover::before{transform:scaleX(1)}
.num-value{
  font-family:'Rajdhani',sans-serif;
  font-size:clamp(50px,5vw,72px);font-weight:700;
  color:#fff;line-height:1;
  display:flex;align-items:baseline;gap:3px;
}
.num-suf{font-size:34px;color:var(--gold)}
.num-lbl{
  font-family:'Share Tech Mono',monospace;
  font-size:9.5px;letter-spacing:.2em;
  color:rgba(255,255,255,.4);
  text-transform:uppercase;line-height:1.65;
  margin-top:12px;
}

/* ── INITIATIVES ──────────────────────────── */
.initiatives-section{background:var(--white)}
.init-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:28px;margin-top:56px;
}
.init-card{
  background:var(--white);
  border:1px solid var(--border);
  overflow:hidden;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.init-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 48px rgba(0,48,135,.1);
  border-color:var(--blue3);
}
.init-img{
  height:190px;background:var(--blue);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.init-img::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:60px;
  background:linear-gradient(0deg,rgba(0,48,135,.5),transparent);
}
.init-img svg{opacity:.1}
.init-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.85;
  transition:transform .4s;
}
.init-card:hover .init-img img{transform:scale(1.06)}
.init-body{padding:28px 26px}
.init-tag{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.2em;
  color:var(--red);text-transform:uppercase;
  border:1px solid rgba(204,0,0,.25);
  padding:3px 10px;display:inline-block;
  margin-bottom:14px;
}
.init-body h3{
  font-family:'Rajdhani',sans-serif;
  font-size:19px;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;color:var(--blue);
  margin-bottom:12px;line-height:1.2;
}
.init-body p{
  font-size:13.5px;line-height:1.8;color:var(--muted);
}

/* ── PARTNERS ─────────────────────────────── */
.partners-section{background:var(--blue-xl)}
.partners-row{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-top:40px;
}
.p-chip{
  font-family:'Rajdhani',sans-serif;
  font-size:12px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--blue);
  border:1.5px solid var(--border);
  background:var(--white);
  padding:9px 20px;
  transition:all .2s;cursor:default;
}
.p-chip:hover{
  background:var(--blue);color:#fff;
  border-color:var(--blue);
}

/* ── GALLERY ──────────────────────────────── */
.gallery-section{background:var(--white)}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:260px 200px;
  gap:6px;
  margin-top:56px;
}
.g-cell{
  overflow:hidden;position:relative;
  background:var(--blue-lt);cursor:pointer;
}
.g-cell:nth-child(1){grid-column:span 2;grid-row:span 2}
.g-cell img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .45s;display:block;
  filter:brightness(.9);
}
.g-cell:hover img{transform:scale(1.05);filter:brightness(1)}
.g-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blue-lt) 0%,var(--border) 100%);
}
.g-placeholder svg{opacity:.25}
.g-overlay{
  position:absolute;inset:0;
  background:rgba(0,48,135,0);
  transition:background .3s;
}
.g-cell:hover .g-overlay{background:rgba(0,48,135,.1)}

/* ── CONTACT ──────────────────────────────── */
.contact-section{background:var(--blue-xl)}
.contact-grid{
  display:grid;grid-template-columns:1fr 380px;
  gap:72px;align-items:start;margin-top:56px;
}
.c-items{display:flex;flex-direction:column;gap:0}
.c-row{
  display:flex;align-items:flex-start;gap:18px;
  padding:24px 0;border-bottom:1px solid var(--border);
}
.c-row:first-child{border-top:1px solid var(--border)}
.c-ico{
  width:38px;height:38px;flex-shrink:0;
  background:var(--blue);
  display:flex;align-items:center;justify-content:center;margin-top:2px;
}
.c-ico svg{
  width:14px;height:14px;stroke:#fff;fill:none;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
}
.c-lbl{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.22em;color:var(--red);
  text-transform:uppercase;margin-bottom:5px;
}
.c-val{
  font-family:'Rajdhani',sans-serif;
  font-size:16px;font-weight:500;letter-spacing:.04em;
  color:var(--ink);line-height:1.55;
}

.c-card{
  background:var(--blue);
  position:relative;overflow:hidden;
}
.c-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--red),var(--gold));
}
.c-card-header{
  padding:22px 28px;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;gap:10px;
}
.c-card-title{
  font-family:'Share Tech Mono',monospace;
  font-size:9.5px;letter-spacing:.2em;
  color:rgba(255,255,255,.5);text-transform:uppercase;
}
.c-card-body{padding:28px}
.hq-name{
  font-family:'Rajdhani',sans-serif;
  font-size:18px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:#fff;margin-bottom:16px;line-height:1.2;
}
.hq-addr{
  font-family:'Libre Baskerville',serif;
  font-size:13.5px;color:rgba(255,255,255,.55);
  line-height:2;
}
.hq-badge{
  display:inline-block;margin-top:24px;
  font-family:'Share Tech Mono',monospace;
  font-size:8.5px;letter-spacing:.2em;
  color:var(--gold);border:1px solid rgba(200,150,62,.3);
  padding:5px 14px;
}
.hq-badge-dot{
  display:inline-block;width:5px;height:5px;
  border-radius:50%;background:#00a651;
  margin-right:8px;
  animation:pulse-g 2s infinite;
}

/* ── FOOTER ─────────────────────────────────── */
footer{
  background:var(--blue);
  border-top:1px solid rgba(255,255,255,.1);
  padding:36px 80px;
}
.footer-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
}
.footer-brand{
  font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:#fff;
  display:flex;align-items:center;gap:14px;
}
.footer-bar{width:1px;height:18px;background:rgba(255,255,255,.2)}
.footer-sub{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.15em;color:rgba(255,255,255,.3);
}
.footer-tags{display:flex;gap:24px;flex-wrap:wrap}
.footer-tag{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.14em;
  color:rgba(255,255,255,.25);text-transform:uppercase;
}
.footer-copy{
  font-family:'Share Tech Mono',monospace;
  font-size:9px;letter-spacing:.08em;
  color:rgba(255,255,255,.2);
}

/* ── REVEALS ─────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.reveal.on{opacity:1;transform:translateY(0)}
.reveal-l{opacity:0;transform:translateX(-28px);transition:opacity .75s ease,transform .75s ease}
.reveal-l.on{opacity:1;transform:translateX(0)}
.reveal-r{opacity:0;transform:translateX(28px);transition:opacity .75s ease,transform .75s ease}
.reveal-r.on{opacity:1;transform:translateX(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── RESPONSIVE ─────────────────────────── */
/* ═══════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
═══════════════════════════════════════════════════════ */

/* ── Tablet 1100px ──────────────────────── */
@media(max-width:1100px){
  nav{padding:0 32px}
  #hero{grid-template-columns:1fr;min-height:auto}
  .hero-right{min-height:420px}
  .hero-left{padding:100px 48px 80px}
  .hero-strip{right:0}
  .about-grid{grid-template-columns:1fr;gap:44px}
  .pillars-grid{grid-template-columns:repeat(2,1fr)}
  .numbers-inner{grid-template-columns:repeat(2,1fr)}
  .init-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .section,.mandate-band,.numbers-section,.partners-section,.gallery-section,.footer{padding-left:40px;padding-right:40px}
}

/* ── Mobile 768px ───────────────────────── */
@media(max-width:768px){
  /* Nav: show hamburger, hide desktop links */
  nav{padding:0 20px;height:60px;position:relative}
  .nav-right{
    display:none;
    position:fixed;top:60px;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:#fff;padding:16px 20px 24px;
    box-shadow:0 8px 24px rgba(0,0,0,.15);
    z-index:9999;border-top:3px solid var(--blue);gap:4px
  }
  .nav-right.open{display:flex}
  #nav-hamburger{display:flex !important}
  .nav-link{font-size:12px;padding:11px 8px;border-bottom:1px solid var(--border);display:block;letter-spacing:.1em}
  .nav-link[style*="border:1px"]{margin-top:8px;padding:10px 12px !important;text-align:center}
  .nav-status{width:100%;margin-top:8px;justify-content:center;font-size:10px;border-bottom:none}

  /* Hero */
  .hero-left{padding:76px 24px 60px}
  .hero-h1{font-size:48px;line-height:1.05}
  .hero-right{min-height:300px}
  .hero-strip{flex-wrap:wrap;right:0}
  .hs-item{min-width:50%;border-bottom:1px solid rgba(255,255,255,.1);padding:14px 20px}

  /* Sections */
  .section,.mandate-band,.numbers-section,.partners-section,.gallery-section,.footer{padding-left:20px;padding-right:20px}
  .s-h2{font-size:clamp(26px,7vw,40px)}

  /* About */
  .about-grid{grid-template-columns:1fr;gap:28px}
  .about-visual{min-height:260px}

  /* Pillars */
  .pillars-grid{grid-template-columns:1fr}
  .pillar-card{padding:28px 22px}

  /* Numbers */
  .numbers-inner{grid-template-columns:1fr 1fr;border-left:none}
  .num-val{font-size:50px}
  .num-item{padding:28px 20px}

  /* Initiatives */
  .init-grid{grid-template-columns:1fr}
  .init-img{height:190px}
  .init-body{padding:20px}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:6px}
  .g-cell:nth-child(1){grid-column:span 2;grid-row:span 1;height:220px}
  .g-cell{height:180px}

  /* FAQ */
  .faq-grid{grid-template-columns:1fr !important}
  .faq-card{grid-template-columns:1fr !important;padding:22px !important}
  .faq-officer{display:none !important}

  /* Contact */
  .contact-grid{grid-template-columns:1fr}

  /* Footer */
  .footer-inner{flex-direction:column;gap:14px;text-align:center}
  .footer-tags{justify-content:center;flex-wrap:wrap}

  /* Lightbox arrows */
  #ncb-lb-prev{left:-44px}
  #ncb-lb-next{right:-44px}
}

/* ── Small mobile 480px ─────────────────── */
@media(max-width:480px){
  /* Hero */
  .hero-left{padding:70px 16px 200px}
  .hero-h1{font-size:36px;line-height:1.1}
  .hero-tag{font-size:8px;letter-spacing:.15em}
  .hs-item{min-width:100%;padding:11px 14px}
  .hero-right{min-height:260px}

  /* Sections */
  .section,.mandate-band,.numbers-section,.partners-section,.gallery-section,.footer{padding-left:14px;padding-right:14px}
  .section-inner{max-width:100%;padding:0}
  .s-h2{font-size:clamp(24px,8vw,34px)}
  .s-sub{font-size:14px}

  /* Mandate band */
  .mandate-text{font-size:13px;line-height:1.7}

  /* Numbers */
  .numbers-inner{grid-template-columns:1fr}
  .num-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .num-val{font-size:54px}

  /* Gallery single col */
  .gallery-grid{grid-template-columns:1fr;gap:6px}
  .g-cell{height:200px;grid-column:1 !important;grid-row:auto !important}

  /* Partners */
  .p-chip{font-size:10px;padding:6px 14px}

  /* Contact form: prevent iOS zoom on focus */
  #contact-form input,
  #contact-form textarea{font-size:16px !important}
  #contact-form > div:first-child{grid-template-columns:1fr !important}

  /* Footer */
  footer{padding:22px 14px}
  .footer-brand{font-size:17px}
  .footer-tag{font-size:9px;padding:3px 9px}

  /* Lightbox tighter */
  #ncb-lb-prev{left:-36px;width:32px;height:32px;font-size:14px}
  #ncb-lb-next{right:-36px;width:32px;height:32px;font-size:14px}
}

/* ── Hamburger button styles ─────────────── */
.ham-bar{display:block;width:22px;height:2px;background:var(--blue);border-radius:2px;transition:all .3s}
#nav-hamburger.open .ham-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
#nav-hamburger.open .ham-bar:nth-child(2){opacity:0;transform:scaleX(0)}
#nav-hamburger.open .ham-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Gallery zoom icon ──────────────────────────────── */
.g-zoom-icon{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0);
  color:#fff;font-size:28px;
  opacity:0;transition:opacity .3s,transform .3s;
  pointer-events:none;z-index:2;
  text-shadow:0 2px 8px rgba(0,0,0,.6);
}
.g-cell:hover .g-zoom-icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
.g-cell:hover .g-overlay{background:rgba(0,48,135,.35)}

/* ── Lightbox dots ──────────────────────────────────── */
.ncb-lb-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.3);
  cursor:pointer;transition:background .2s,transform .2s;border:none;
}
.ncb-lb-dot.active{background:#fff;transform:scale(1.25)}

/* ── Hamburger menu ──────────────────────────────────── */
.ham-bar{display:block;width:22px;height:2px;background:var(--blue);border-radius:2px;transition:all .3s}

@media(max-width:768px){
  #nav-hamburger{display:flex !important}

  .nav-right{
    display:none;
    position:fixed;top:60px;left:0;right:0;
    background:#fff;
    flex-direction:column;
    align-items:stretch;
    padding:16px 20px 24px;
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    z-index:999;
    border-top:3px solid var(--blue);
    gap:4px !important;
  }
  .nav-right.open{display:flex !important}
  .nav-right .nav-link{
    font-size:12px !important;letter-spacing:.12em;
    padding:12px 8px !important;
    border-bottom:1px solid var(--border);
    border-left:none !important;
    border-right:none !important;
    border-top:none !important;
    display:block;
  }
  .nav-right .nav-link[style*="border"]{
    margin-top:8px;border:1.5px solid rgba(204,0,0,0.3) !important;
    padding:10px 12px !important;text-align:center;
  }
  .nav-status{width:100%;margin-top:8px;justify-content:center;font-size:10px !important}

  /* Hamburger open state */
  #nav-hamburger.open .ham-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
  #nav-hamburger.open .ham-bar:nth-child(2){opacity:0}
  #nav-hamburger.open .ham-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
