/* ============================================================
   CPDI Pakistan — static site styles
   Brand: primary blue #005891, Poppins, Bootstrap 5 base
   ============================================================ */
:root{
  --cpdi-blue:#005891;
  --cpdi-blue-dark:#00426c;
  --cpdi-blue-light:#e6f0f6;
  --cpdi-green:#3a9d4a;
  --cpdi-yellow:#ffd400;
  --cpdi-ink:#1a1d20;
  --cpdi-muted:#5b6670;
  --cpdi-line:#e6e9ec;
  --cpdi-bg:#ffffff;
  --cpdi-bg-soft:#f6f8fa;
  --cpdi-footer:#0f0f0f;
  --cpdi-footer-bar:#1a1a1a;
  --bs-primary:#005891;
  --bs-primary-rgb:0,88,145;
}

*{box-sizing:border-box}
html,body{overflow-x:hidden}
body{
  font-family:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  color:var(--cpdi-ink);
  margin:0;
  line-height:1.6;
  background:var(--cpdi-bg);
}
a{color:var(--cpdi-blue);text-decoration:none}
a:hover{color:var(--cpdi-blue-dark)}
img{max-width:100%}
.text-cpdi{color:var(--cpdi-blue)!important}
.bg-cpdi{background:var(--cpdi-blue)!important;color:#fff}
.bg-soft{background:var(--cpdi-bg-soft)}
.btn-cpdi{background:var(--cpdi-blue);border-color:var(--cpdi-blue);color:#fff;font-weight:500}
.btn-cpdi:hover{background:var(--cpdi-blue-dark);border-color:var(--cpdi-blue-dark);color:#fff}
.btn-outline-cpdi{color:var(--cpdi-blue);border:1px solid var(--cpdi-blue);font-weight:500;background:#fff}
.btn-outline-cpdi:hover{background:var(--cpdi-blue);color:#fff}
.section{padding:64px 0}
.section-sm{padding:40px 0}
.eyebrow{
  text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;
  font-weight:600;color:var(--cpdi-green)
}
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.25;color:var(--cpdi-ink)}
.section-title{position:relative;display:inline-block;font-size:2rem;margin-bottom:.25rem}
.section-title:after{
  content:"";display:block;width:64px;height:4px;border-radius:3px;
  background:var(--cpdi-green);margin-top:12px
}

/* ---------- top utility bar ---------- */
.topbar{background:var(--cpdi-blue);color:#fff;font-size:.82rem}
.topbar a{color:#fff;opacity:.92}
.topbar a:hover{opacity:1;color:#fff}
.topbar .bi{font-size:1rem}

/* ---------- navbar ---------- */
.cpdi-nav{background:#fff;box-shadow:0 2px 14px rgba(0,0,0,.06);position:sticky;top:0;z-index:1030}
.cpdi-nav .navbar-brand img{height:64px;width:auto}
.cpdi-nav .nav-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0}
.cpdi-menu{display:flex;gap:.25rem;list-style:none;margin:0;padding:0;align-items:center}
.cpdi-menu>li{position:static}
.cpdi-menu>li>a.top-link{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:1.25rem .9rem;font-weight:600;font-size:.92rem;color:var(--cpdi-ink);
  text-transform:uppercase;letter-spacing:.02em;cursor:pointer;border:0;background:none
}
.cpdi-menu>li>a.top-link:hover,.cpdi-menu>li.open>a.top-link{color:var(--cpdi-blue)}
.cpdi-menu>li>a.top-link .bi{font-size:.7rem;transition:transform .2s}
.cpdi-menu>li.open>a.top-link .bi{transform:rotate(180deg)}

/* mega panel */
.mega{
  position:absolute;left:0;right:0;top:100%;
  background:#fff;border-top:3px solid var(--cpdi-blue);
  box-shadow:0 18px 40px rgba(0,0,0,.14);
  padding:28px 0;display:none;z-index:1040
}
.cpdi-menu>li.open .mega{display:block}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 28px}
.mega-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.mega-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.mega-col h6{
  font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;
  color:var(--cpdi-blue);font-weight:700;margin-bottom:.6rem;
  padding-bottom:.5rem;border-bottom:1px solid var(--cpdi-line)
}
.mega-col h6 a{color:var(--cpdi-blue)}
.mega-col ul{list-style:none;margin:0;padding:0}
.mega-col li a{
  display:block;padding:.32rem 0;color:var(--cpdi-muted);font-size:.9rem;font-weight:500;
  border-radius:6px;transition:.15s
}
.mega-col li a:hover{color:var(--cpdi-blue);padding-left:6px}

/* search */
.nav-search-btn{border:0;background:none;font-size:1.15rem;color:var(--cpdi-ink);padding:.4rem .6rem;cursor:pointer}
.nav-search-btn:hover{color:var(--cpdi-blue)}
.search-overlay{
  position:fixed;inset:0;background:rgba(255,255,255,.97);z-index:2000;
  display:none;align-items:flex-start;justify-content:center;padding-top:14vh
}
.search-overlay.show{display:flex}
.search-box{width:min(680px,92vw)}
.search-box input{font-size:1.4rem;padding:.8rem 1rem;border:0;border-bottom:3px solid var(--cpdi-blue)}
.search-box input:focus{outline:none;box-shadow:none}
.search-results{max-height:52vh;overflow:auto;margin-top:1rem}
.search-results a{display:block;padding:.7rem .4rem;border-bottom:1px solid var(--cpdi-line);color:var(--cpdi-ink)}
.search-results a:hover{background:var(--cpdi-bg-soft);color:var(--cpdi-blue)}
.search-results .badge{font-weight:500}

/* mobile menu */
.nav-toggle{display:none;border:0;background:none;font-size:1.6rem;color:var(--cpdi-ink);cursor:pointer}
.mobile-menu{display:none}
@media(max-width:1199px){
  .cpdi-menu,.cpdi-nav .nav-search-btn.desktop{display:none}
  .nav-toggle{display:inline-block}
  .mobile-menu{display:block;border-top:1px solid var(--cpdi-line);max-height:0;overflow:hidden;transition:max-height .3s}
  .mobile-menu.open{max-height:80vh;overflow:auto}
  .mobile-menu .acc-head{
    width:100%;text-align:left;border:0;background:none;font-weight:600;
    padding:.85rem .25rem;text-transform:uppercase;font-size:.9rem;border-bottom:1px solid var(--cpdi-line);
    display:flex;justify-content:space-between;align-items:center
  }
  .mobile-menu .acc-body{display:none;padding:.25rem 0 .75rem}
  .mobile-menu .acc-body.open{display:block}
  .mobile-menu .acc-body h6{font-size:.78rem;color:var(--cpdi-blue);text-transform:uppercase;margin:.6rem 0 .2rem}
  .mobile-menu .acc-body a{display:block;padding:.35rem .5rem;color:var(--cpdi-muted);font-size:.92rem}
}

/* ---------- hero / page heading ---------- */
.page-head{
  background:linear-gradient(120deg,var(--cpdi-blue),var(--cpdi-blue-dark));
  color:#fff;padding:54px 0 48px
}
.page-head h1{color:#fff;font-size:2.4rem;margin:0}
.page-head .crumb{font-size:.85rem;opacity:.9;margin-bottom:.5rem}
.page-head .crumb a{color:#fff;text-decoration:underline}

/* ---------- cards ---------- */
.card-cpdi{
  background:#fff;border:1px solid var(--cpdi-line);border-radius:14px;overflow:hidden;height:100%;
  transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column
}
.card-cpdi:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(0,0,0,.10)}
.card-cpdi .thumb{aspect-ratio:16/10;object-fit:cover;width:100%;background:var(--cpdi-bg-soft)}
.card-cpdi .thumb.tall{aspect-ratio:3/4}
.card-cpdi .card-body{padding:1.1rem 1.15rem;flex:1;display:flex;flex-direction:column}
.card-cpdi h3,.card-cpdi h5{font-size:1.05rem;margin:.2rem 0 .5rem}
.card-cpdi h3 a{color:var(--cpdi-ink)}
.card-cpdi h3 a:hover{color:var(--cpdi-blue)}
.card-cpdi p{color:var(--cpdi-muted);font-size:.9rem;margin-bottom:.8rem}
.pill{
  display:inline-block;background:var(--cpdi-blue-light);color:var(--cpdi-blue);
  font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:20px;
  text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem
}
.pill.green{background:#e6f4e9;color:var(--cpdi-green)}
.meta{font-size:.8rem;color:var(--cpdi-muted)}
.clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.clamp-4{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- markdown body ---------- */
.md-body{font-size:1rem;color:#2c343b;line-height:1.8}
.md-body h1,.md-body h2,.md-body h3{margin:1.4rem 0 .7rem}
.md-body h2{font-size:1.5rem}.md-body h3{font-size:1.2rem}
.md-body p{margin:0 0 1rem}
.md-body img{border-radius:10px;margin:1rem 0}
.md-body ul,.md-body ol{margin:0 0 1rem 1.1rem}
.md-body li{margin-bottom:.35rem}
.md-body a{color:var(--cpdi-blue);text-decoration:underline}
.md-body table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.92rem}
.md-body th,.md-body td{border:1px solid var(--cpdi-line);padding:.5rem .7rem;text-align:left}
.md-body th{background:var(--cpdi-blue-light);color:var(--cpdi-blue)}
.md-body blockquote{border-left:4px solid var(--cpdi-green);padding-left:1rem;color:var(--cpdi-muted);margin:1rem 0}

/* ---------- skeleton ---------- */
.sk{background:linear-gradient(90deg,#eef1f4 25%,#e2e7ec 37%,#eef1f4 63%);background-size:400% 100%;animation:sk 1.3s infinite;border-radius:8px}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}
.sk-card{height:300px;margin-bottom:1.5rem}

/* ---------- footer ---------- */
.cpdi-footer{background:var(--cpdi-footer);color:#cfd3d6;padding:54px 0 0}
.cpdi-footer h6{color:#fff;font-size:1rem;margin-bottom:1rem;font-weight:600}
.cpdi-footer a{color:#bfc4c8}
.cpdi-footer a:hover{color:#fff}
.cpdi-footer .footer-link{display:block;padding:.28rem 0;font-size:.92rem}
.cpdi-footer .social{display:flex;gap:.9rem;margin-bottom:1rem}
.cpdi-footer .social a{font-size:1.5rem;color:#fff}
.cpdi-footer .social a:hover{color:var(--cpdi-yellow)}
.cpdi-footer .footer-bar{background:var(--cpdi-footer-bar);text-align:center;padding:1rem;margin-top:2.5rem;font-size:.82rem}

/* ---------- carousel ---------- */
.hero-carousel .slide-img{height:78vh;min-height:460px;max-height:760px;width:100%;object-fit:cover}
.hero-carousel .slide-cap{
  position:absolute;left:0;right:0;bottom:0;padding:90px 0 44px;
  background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.25),transparent);color:#fff
}
.hero-carousel .slide-cap h2{color:#fff;font-size:2.1rem;max-width:880px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.hero-carousel .slide-cap p{max-width:760px;opacity:.95;font-size:1.02rem}
@media(max-width:767px){
  .hero-carousel .slide-img{height:62vh;min-height:360px}
  .hero-carousel .slide-cap h2{font-size:1.35rem}
  .page-head h1{font-size:1.7rem}
  .section{padding:42px 0}
}

/* stat block */
.stat-card{position:relative;border-radius:16px;overflow:hidden;min-height:220px;display:flex;align-items:flex-end;color:#fff}
.stat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.stat-card .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,66,108,.92),rgba(0,88,145,.35))}
.stat-card .inner{position:relative;padding:1.3rem}
.stat-card .num{font-size:2.5rem;font-weight:800;line-height:1}
.stat-card .lab{font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;margin:.2rem 0 .4rem}
.stat-card .txt{font-size:.82rem;opacity:.92}

/* partners */
.partner-logo{display:flex;align-items:center;justify-content:center;padding:1rem;background:#fff;border:1px solid var(--cpdi-line);border-radius:12px;height:110px}
.partner-logo img{max-height:64px;object-fit:contain;filter:grayscale(1);opacity:.75;transition:.2s}
.partner-logo:hover img{filter:none;opacity:1}

/* program tiles */
.prog-tile{position:relative;border-radius:14px;overflow:hidden;min-height:230px;display:block;color:#fff}
.prog-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.4s}
.prog-tile:hover img{transform:scale(1.06)}
.prog-tile .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,66,108,.94),rgba(0,66,108,.15) 70%)}
.prog-tile .inner{position:relative;padding:1.2rem;height:100%;display:flex;flex-direction:column;justify-content:flex-end}
.prog-tile h3{color:#fff;font-size:1.15rem;margin:0 0 .3rem}
.prog-tile p{font-size:.82rem;opacity:.92;margin:0}
.prog-tile:hover{color:#fff}

/* video */
.video-thumb{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;display:block}
.video-thumb img{width:100%;aspect-ratio:16/9;object-fit:cover}
.video-thumb .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center
}
.video-thumb .play i{font-size:3.6rem;color:#fff;background:rgba(0,88,145,.85);width:78px;height:78px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.video-thumb:hover .play i{background:var(--cpdi-blue)}

/* gallery */
.gal-grid{columns:4;column-gap:12px}
@media(max-width:991px){.gal-grid{columns:3}}
@media(max-width:575px){.gal-grid{columns:2}}
.gal-grid img{width:100%;margin-bottom:12px;border-radius:10px;cursor:pointer;break-inside:avoid;transition:.2s}
.gal-grid img:hover{filter:brightness(1.05);transform:scale(1.01)}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:3000;display:none;align-items:center;justify-content:center}
.lb.show{display:flex}
.lb img{max-width:92vw;max-height:88vh;border-radius:6px}
.lb .x{position:absolute;top:18px;right:26px;color:#fff;font-size:2.4rem;cursor:pointer;background:none;border:0}
.lb .nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:3rem;cursor:pointer;background:none;border:0;padding:0 1rem;opacity:.8}
.lb .nav:hover{opacity:1}
.lb .prev{left:10px}.lb .next{right:10px}

/* pagination */
.pager{display:flex;gap:.35rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}
.pager button{border:1px solid var(--cpdi-line);background:#fff;color:var(--cpdi-ink);min-width:42px;height:42px;border-radius:8px;font-weight:500;cursor:pointer}
.pager button:hover{border-color:var(--cpdi-blue);color:var(--cpdi-blue)}
.pager button.active{background:var(--cpdi-blue);color:#fff;border-color:var(--cpdi-blue)}
.pager button:disabled{opacity:.4;cursor:not-allowed}

/* filter chips */
.chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.chip{border:1px solid var(--cpdi-line);background:#fff;color:var(--cpdi-muted);padding:.4rem .9rem;border-radius:30px;font-size:.85rem;font-weight:500;cursor:pointer}
.chip:hover{border-color:var(--cpdi-blue);color:var(--cpdi-blue)}
.chip.active{background:var(--cpdi-blue);color:#fff;border-color:var(--cpdi-blue)}

/* misc */
.empty{text-align:center;padding:3rem 1rem;color:var(--cpdi-muted)}
.back-top{position:fixed;right:20px;bottom:20px;width:46px;height:46px;border-radius:50%;background:var(--cpdi-blue);color:#fff;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:1000;box-shadow:0 6px 18px rgba(0,0,0,.2)}
.back-top.show{display:flex}
.team-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px}
.accordion-cpdi .ac-item{border:1px solid var(--cpdi-line);border-radius:10px;margin-bottom:.6rem;overflow:hidden}
.accordion-cpdi .ac-head{width:100%;text-align:left;padding:1rem 1.2rem;background:#fff;border:0;font-weight:600;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.accordion-cpdi .ac-head:hover{background:var(--cpdi-bg-soft)}
.accordion-cpdi .ac-body{padding:0 1.2rem;max-height:0;overflow:hidden;transition:.3s;color:var(--cpdi-muted)}
.accordion-cpdi .ac-item.open .ac-body{padding:0 1.2rem 1.1rem;max-height:1200px}
