/* ================================================================
   VRUSHABH POL - OFFICIAL WEBSITE CSS v2
   Maharashtrian Political Leader - Premium Design
   ================================================================ */
:root {
  --saffron:#FF6B35; --saffron2:#FF8C5A; --saffron-pale:#FFF4EF;
  --gold:#D4A017; --gold2:#F0C040; --green:#2E7D32; --green2:#4CAF50;
  --dark:#1A1A1A; --body:#444; --muted:#777;
  --white:#fff; --soft:#FBF7F4; --cream:#FFF8F3; --border:#E8DDD5;
  --shadow-sm:0 2px 12px rgba(255,107,53,.08);
  --shadow-md:0 8px 30px rgba(0,0,0,.10);
  --shadow-lg:0 20px 60px rgba(0,0,0,.14);
  --r:12px; --r-lg:20px;
  --ease:all .3s cubic-bezier(.4,0,.2,1);

}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins','Noto Sans Devanagari',sans-serif;background:#fff;color:var(--body);line-height:1.7;overflow-x:hidden}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section-padding{padding:80px 0}
.bg-soft{background:var(--soft)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ================================================================
   TOP BAR
   ================================================================ */
.top-bar{background:var(--dark);color:rgba(255,255,255,.75);font-size:.78rem;padding:6px 0;position:relative;z-index:1001}
.top-bar-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.top-bar-left{display:flex;gap:20px}
.top-bar-left span{display:flex;align-items:center;gap:6px}
.top-bar-left i{color:var(--saffron)}
.top-bar-right{display:flex;align-items:center;gap:10px}
.top-bar-right a{color:rgba(255,255,255,.7);width:26px;height:26px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:var(--ease)}
.top-bar-right a:hover{background:var(--saffron);color:#fff}
.top-lang-btn{background:rgba(255,255,255,.12)!important;padding:0 10px!important;width:auto!important;border-radius:20px!important;font-size:.75rem;gap:5px;display:flex!important;align-items:center;gap:5px;color:#fff!important}
.top-lang-btn:hover{background:var(--saffron)!important}

/* ================================================================
   SPECTACULAR HEADER
   ================================================================ */
.site-header{position:sticky;top:0;z-index:1000;padding:0;overflow:visible}
.header-gradient-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg, #B45309 0%, #FF6B35 50%, #2E7D32 100%);
  z-index:0
}


.nav-container{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px}
/* logo-wrap and hamburger stay at edges; pill is absolute centre */
.logo-wrap{flex-shrink:0;z-index:11;position:relative}
.hamburger{flex-shrink:0;z-index:11;position:relative}
.logo-wrap{flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.15}
.logo-name{font-size:1.1rem;font-weight:800;color:#fff;font-family:'Playfair Display',serif;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.logo-sub{font-size:.62rem;color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:1.5px}
.logo-img{height:52px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}

/* ── Center Nav Pill — FIXED perfectly centred ── */
.nav-pill-wrap{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  justify-content:center;
  z-index:10;
  width:auto;
  max-width:80%
}
.nav-pill{
  background:rgba(255,255,255,.97);
  border-radius:50px;
  padding:0 10px;
  display:flex;
  align-items:center;
  gap:0;
  box-shadow:0 4px 24px rgba(0,0,0,.22);
  position:relative;
  height:52px;
  white-space:nowrap;
  overflow:visible
}

/* Leader photo — sits in flow between left/right links via gap spacers */
.nav-leader-photo{
  border-radius:50%;
  background:#fff;
  border:3px solid var(--saffron);
  box-shadow:0 4px 16px rgba(255,107,53,.4);
  overflow:hidden;
  z-index:20;
  flex-shrink:0;
  position:relative;
  /* Pop above the pill visually */
  margin-top:-8px;
  margin-bottom:-8px
}
.nav-leader-photo img{width:100%;height:100%;object-fit:cover;display:block}
.nav-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--saffron-pale);color:var(--saffron);font-size:1.4rem}

/* Nav links — padding creates gap around centre photo */
.nav-links-left,.nav-links-right{list-style:none;display:flex;align-items:center;gap:0;padding:0;margin:0;height:100%}

.nav-links-left a,.nav-links-right a{
  display:flex;align-items:center;justify-content:center;height:100%;
  min-width:150px;
  padding:0 14px;
  font-size:.73rem;font-weight:700;color:var(--dark);
  text-transform:uppercase;letter-spacing:.4px;
  transition:var(--ease);white-space:nowrap;
  border-radius:50px;
  text-decoration:none
}
.nav-links-left a:hover,.nav-links-right a:hover,
.nav-links-left a.active,.nav-links-right a.active{color:var(--saffron);background:var(--saffron-pale)}

/* Spacer blocks that push links away from centre photo area */
.nav-gap{display:inline-block;flex-shrink:0}

.nav-live-btn{
  background:linear-gradient(135deg,#FF6B35,#D97706)!important;
  color:#fff!important;
  border-radius:50px!important;
  display:flex!important;align-items:center;gap:5px;
  padding:6px 14px!important
}
.nav-live-btn:hover{opacity:.9}
.nav-live-btn i{animation:blink-live 1.2s infinite;font-size:.5rem}
@keyframes blink-live{0%,100%{opacity:1}50%{opacity:.2}}

/* ── Announcement Ticker ── */
.ticker-wrap{
  background:var(--ticker-bg,#1a1a1a);
  overflow:hidden;
  height:36px;
  display:flex;
  align-items:center;
  position:relative;
  z-index:990
}
.ticker-label{
  background:var(--saffron);
  color:#fff;
  font-size:.72rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.5px;
  padding:0 16px;
  height:100%;
  display:flex;
  align-items:center;
  flex-shrink:0;
  gap:6px;
  z-index:2;
  position:relative
}
.ticker-label::after{
  content:'';
  position:absolute;
  right:-14px;top:0;
  border-top:18px solid transparent;
  border-bottom:18px solid transparent;
  border-left:14px solid var(--saffron)
}
.ticker-track{
  display:flex;
  align-items:center;
  animation:ticker-scroll linear infinite;
  animation-duration:var(--ticker-speed,30s);
  gap:0;
  padding-left:40px;
  will-change:transform
}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.ticker-item{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ticker-color,#FF6B35);
  font-size:.8rem;font-weight:500;
  padding:0 28px 0 0;
  white-space:nowrap
}
.ticker-item a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.ticker-item::after{
  content:'◆';
  color:rgba(255,255,255,.25);
  margin-left:28px;
  font-size:.5rem
}
.ticker-item:last-child::after{content:''}
.hamburger{display:none;flex-direction:column;gap:5px;background:rgba(255,255,255,.2);border:none;cursor:pointer;padding:8px 10px;border-radius:8px}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--ease)}

/* Mobile nav */
.mobile-nav{position:fixed;top:0;right:-100%;width:85%;max-width:320px;height:100vh;background:linear-gradient(180deg,#1a0a00 0%,#2d1200 100%);z-index:2000;transition:right .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding:70px 0 30px;box-shadow:-5px 0 30px rgba(0,0,0,.4)}
.mobile-nav.open{right:0;display:block}
.mobile-nav ul{list-style:none;padding:0 20px}
.mobile-nav li{border-bottom:1px solid rgba(255,255,255,.07)}
.mobile-nav li a{display:flex;align-items:center;gap:12px;padding:14px 8px;border-radius:0;font-weight:500;font-size:.92rem;color:rgba(255,255,255,.85);transition:color .2s}
.mobile-nav li a:hover{background:transparent;color:var(--saffron)}
.mobile-nav li a i{width:20px;color:var(--saffron);font-size:.9rem}

/* ================================================================
   HERO SECTION (SLIDER)
   ================================================================ */
.hero-section{position:relative;margin-top:0}
.heroSwiper{height:88vh;min-height:520px}
.hero-slide{
  height:100%;
  background-size:cover;background-position:center;
  display:flex;align-items:center
}
.hero-default{height:88vh;min-height:520px;position:relative;display:flex;align-items:center}
.hero-default-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#FFF4EF 0%,#FFF8E7 40%,#E8F5E9 100%);
}
.hero-slide-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right, rgba(0,0,0,.65) 0%,rgba(0,0,0,.35) 50%,transparent 100%)
}
.hero-slide-content{
  position:relative;z-index:2;
  max-width:680px;padding:40px 60px;color:#fff
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.3);
  padding:6px 16px;border-radius:50px;
  font-size:.8rem;font-weight:500;margin-bottom:18px
}
.hero-name{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;
  line-height:1.15;margin-bottom:16px;
  color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)
}
.hero-name-highlight{color:var(--saffron)}
.hero-tagline{font-size:1rem;margin-bottom:32px;opacity:.9;line-height:1.8}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px}

/* Slider controls */
.hero-next,.hero-prev{color:#fff!important;background:rgba(255,255,255,.2)!important;width:44px!important;height:44px!important;border-radius:50%!important;backdrop-filter:blur(4px)}
.hero-next:after,.hero-prev:after{font-size:1rem!important}
.heroSwiper-pagination .swiper-pagination-bullet{background:#fff;opacity:.6}
.heroSwiper-pagination .swiper-pagination-bullet-active{background:var(--saffron);opacity:1;width:24px;border-radius:4px}

/* ── Stats Bar ── */
.hero-stats-bar{
  background:var(--white);
  box-shadow:var(--shadow-md);
  border-top:3px solid var(--saffron);
  position:relative;z-index:10
}
.hero-stats-inner{
  display:flex;align-items:center;justify-content:center;
  gap:0;padding:18px 0
}
.hstat{
  display:flex;flex-direction:column;align-items:center;
  padding:0 40px;text-align:center
}
.hstat i{color:var(--saffron);font-size:1.4rem;margin-bottom:6px}
.hstat-num{font-size:2rem;font-weight:800;color:var(--dark);font-family:'Playfair Display',serif;line-height:1}
.hstat-suffix{font-size:1.2rem;font-weight:700;color:var(--saffron);line-height:1}
.hstat-label{font-size:.73rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}
.hstat-divider{width:1px;height:56px;background:var(--border)}

/* ================================================================
   SECTION COMMON
   ================================================================ */
.section-tag{display:flex;align-items:center;gap:10px;color:var(--saffron);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}
.section-tag.white{color:rgba(255,255,255,.9)}
.tag-line{display:block;width:28px;height:2px;background:var(--saffron);flex-shrink:0}
.tag-line.white{background:rgba(255,255,255,.7)}
.section-header{text-align:center;margin-bottom:48px}
.section-header .section-tag{justify-content:center}
.section-heading{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3.5vw,2.5rem);color:var(--dark);font-weight:700;line-height:1.25;margin-bottom:14px}
.section-heading.white{color:#fff}
.section-sub{color:var(--muted);font-size:.95rem;max-width:520px;margin:0 auto}

/* ================================================================
   ABOUT SECTION
   ================================================================ */
.about-section{background:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1.45fr;gap:60px;align-items:start}
.about-media-col{display:flex;flex-direction:column;gap:24px}
.about-img-frame{position:relative}
.about-photo{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/5;object-fit:cover}
.about-img-badge{position:absolute;bottom:24px;left:-16px;background:#fff;border-left:4px solid var(--saffron);padding:12px 20px;border-radius:0 var(--r) var(--r) 0;box-shadow:var(--shadow-md)}
.about-img-badge span{display:block;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.about-img-badge strong{font-size:1rem;color:var(--dark);font-weight:700}
.about-img-deco{position:absolute;border-radius:50%;z-index:-1}
.about-img-deco-1{width:120px;height:120px;background:var(--saffron-pale);top:-16px;right:-16px}
.about-img-deco-2{width:80px;height:80px;background:#E8F5E9;bottom:60px;right:-24px}
.about-video-wrap{background:var(--soft);border-radius:var(--r-lg);padding:18px;border:1px solid var(--border)}
.about-video-label{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--dark);margin-bottom:12px}
.about-video-label i{color:#FF0000;font-size:1.2rem}
.yt-embed-wrap iframe{width:100%;aspect-ratio:16/9;border-radius:10px}
.yt-link-btn{display:flex;align-items:center;gap:10px;background:var(--saffron);color:#fff;padding:12px 20px;border-radius:8px;font-weight:600}
.about-text{color:var(--body);margin-bottom:28px;line-height:1.85}
.timeline{border-left:2px solid var(--border);padding-left:24px;margin-bottom:32px;display:flex;flex-direction:column;gap:18px}
.timeline-item{position:relative}
.tl-dot{position:absolute;left:-31px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--saffron);border:3px solid #fff;box-shadow:0 0 0 2px var(--saffron)}
.tl-dot-active{background:var(--green);box-shadow:0 0 0 2px var(--green)}
.tl-year{font-size:.72rem;font-weight:700;color:var(--saffron);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:2px}
.tl-content p{font-size:.87rem;color:var(--body)}
.vm-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vm-card{background:var(--soft);border-radius:var(--r);padding:18px;border-left:3px solid transparent;transition:var(--ease)}
.vm-vision{border-left-color:var(--saffron)}
.vm-mission{border-left-color:var(--gold)}
.vm-icon{font-size:1.3rem;margin-bottom:8px}
.vm-vision .vm-icon{color:var(--saffron)}
.vm-mission .vm-icon{color:var(--gold)}
.vm-card h4{font-size:.87rem;font-weight:700;color:var(--dark);margin-bottom:6px}
.vm-card p{font-size:.8rem;color:var(--muted);line-height:1.65}

/* ================================================================
   ACHIEVEMENTS
   ================================================================ */
.bg-gradient-saffron{background:linear-gradient(135deg,#B45309 0%,#D97706 30%,#FF6B35 60%,#4CAF50 85%,#2E7D32 100%)}
.achievements-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ach-card{background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-lg);padding:24px;text-align:center;color:#fff;transition:var(--ease)}
.ach-card:hover{background:rgba(255,255,255,.2);transform:translateY(-4px)}
.ach-year{display:inline-block;background:rgba(255,255,255,.2);border-radius:50px;padding:3px 12px;font-size:.72rem;font-weight:700;letter-spacing:1px;margin-bottom:12px}
.ach-icon{font-size:2rem;margin-bottom:12px;color:rgba(255,255,255,.9)}
.ach-card h3{font-size:.95rem;font-weight:700;margin-bottom:8px}
.ach-card p{font-size:.8rem;opacity:.8;line-height:1.6}

/* ================================================================
   PROJECTS
   ================================================================ */
.filter-btns{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:36px}
.filter-btn{padding:7px 20px;border:1.5px solid var(--border);background:#fff;border-radius:50px;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--muted);transition:var(--ease);font-family:inherit}
.filter-btn.active,.filter-btn:hover{background:var(--saffron);border-color:var(--saffron);color:#fff}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.project-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--ease)}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.project-card.hidden-proj{display:none}
.project-img-wrap{position:relative;height:200px;overflow:hidden;background:var(--saffron-pale)}
.project-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.project-card:hover .project-img-wrap img{transform:scale(1.06)}
.project-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--saffron);font-size:3rem;opacity:.35}
.project-status{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;text-transform:uppercase}
.status-completed{background:#D1FAE5;color:#065F46}
.status-ongoing{background:#DBEAFE;color:#1E40AF}
.status-planned{background:#FEF3C7;color:#92400E}
.project-body{padding:18px}
.project-category{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--saffron);margin-bottom:6px;display:block}
.project-title{font-size:.97rem;font-weight:700;color:var(--dark);margin-bottom:8px;line-height:1.4}
.project-desc{font-size:.83rem;color:var(--muted);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ================================================================
   INITIATIVES
   ================================================================ */
.initiatives-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.initiative-card{background:#fff;border-radius:var(--r-lg);padding:26px;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;gap:18px;align-items:flex-start;transition:var(--ease)}
.initiative-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ini-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.ini-body h3{font-size:.97rem;font-weight:700;color:var(--dark);margin-bottom:6px;line-height:1.4}
.ini-body p{font-size:.83rem;color:var(--muted);line-height:1.65}

/* ================================================================
   NEWS
   ================================================================ */
.news-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:18px}
.news-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:var(--ease)}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.news-featured{grid-row:span 2}
.news-img-wrap{position:relative;height:200px;overflow:hidden;background:var(--saffron-pale)}
.news-featured .news-img-wrap{height:260px}
.news-img-wrap img{width:100%;height:100%;object-fit:cover}
.news-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--saffron);font-size:3rem;opacity:.3}
.news-featured-badge{position:absolute;top:14px;left:14px;background:var(--saffron);color:#fff;padding:4px 12px;border-radius:50px;font-size:.7rem;font-weight:700;text-transform:uppercase}
.news-body{padding:18px}
.news-date{display:flex;align-items:center;gap:6px;font-size:.73rem;color:var(--muted);margin-bottom:6px}
.news-body h3{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:8px;line-height:1.4}
.news-body p{font-size:.82rem;color:var(--muted);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testimonials-section{background:#fff}
.testimonialsSwiper{padding-bottom:50px!important}
.testi-card{background:var(--soft);border-radius:var(--r-lg);padding:32px;border:1px solid var(--border);text-align:center;margin:4px}
.testi-stars{display:flex;gap:4px;justify-content:center;margin-bottom:16px}
.testi-stars i{color:#ddd;font-size:1rem}
.testi-stars i.active{color:var(--gold)}
.testi-msg{font-size:.95rem;color:var(--body);line-height:1.8;font-style:italic;margin-bottom:24px}
.testi-author{display:flex;align-items:center;justify-content:center;gap:14px}
.testi-author img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:3px solid var(--saffron)}
.testi-avatar{width:52px;height:52px;border-radius:50%;background:var(--saffron-pale);display:flex;align-items:center;justify-content:center;color:var(--saffron);font-size:1.3rem;border:3px solid var(--saffron)}
.testi-author div{text-align:left}
.testi-author strong{display:block;font-size:.93rem;color:var(--dark)}
.testi-author span{font-size:.78rem;color:var(--muted)}
.testi-pagination .swiper-pagination-bullet{background:var(--border)}
.testi-pagination .swiper-pagination-bullet-active{background:var(--saffron)}

/* ================================================================
   GALLERY
   ================================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery-item{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;opacity:0;transition:var(--ease);font-size:.83rem;padding:10px;text-align:center;pointer-events:none}
.gallery-overlay i{font-size:1.8rem}
.gallery-item:hover .gallery-overlay{opacity:1}

/* View More Button */
.view-more-wrap{text-align:center;margin-top:36px}
.btn-view-more{display:inline-flex;align-items:center;gap:10px;background:var(--soft);border:2px solid var(--saffron);color:var(--saffron);padding:12px 30px;border-radius:50px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--ease)}
.btn-view-more:hover{background:var(--saffron);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,107,53,.3)}
.hidden-gallery{display:none}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.lightbox.open{display:flex}
.lightbox-inner{position:relative;max-width:90vw;max-height:90vh;text-align:center}
.lightbox-inner img{max-width:100%;max-height:80vh;border-radius:var(--r);box-shadow:var(--shadow-lg)}
.lightbox-inner p{color:rgba(255,255,255,.8);margin-top:12px;font-size:.9rem}
.lb-close{position:absolute;top:-12px;right:-12px;width:36px;height:36px;border-radius:50%;background:var(--saffron);border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ================================================================
   INSTAGRAM
   ================================================================ */
.instagram-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:28px}
.instagram-cell{position:relative;overflow:hidden;border-radius:8px;aspect-ratio:1;display:block}
.instagram-cell img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.instagram-cell:hover img{transform:scale(1.08)}
.insta-hover{position:absolute;inset:0;background:rgba(255,107,53,.6);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;opacity:0;transition:var(--ease)}
.instagram-cell:hover .insta-hover{opacity:1}

/* ================================================================
   FEEDBACK
   ================================================================ */
.feedback-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start;background:#fff;border-radius:var(--r-lg);padding:50px;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.feedback-left p{color:var(--muted);line-height:1.8;margin-bottom:24px}
.feedback-contact-info{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.fci-item{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--body)}
.fci-item i{color:var(--saffron);width:20px}
.fci-item a{color:var(--saffron)}
.quick-links-box{background:var(--soft);border-radius:var(--r);padding:18px;border:1px solid var(--border)}
.quick-links-box h4{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:12px}
.ql-btn{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:8px;font-size:.83rem;font-weight:500;color:var(--dark);margin-bottom:8px;transition:var(--ease)}
.ql-btn:hover{background:var(--saffron-pale);color:var(--saffron)}
.ql-btn i{color:var(--saffron);width:16px}
.feedback-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:.8rem;font-weight:600;color:var(--dark)}
.form-group input,.form-group textarea,.form-group select{padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.88rem;font-family:inherit;color:var(--dark);transition:var(--ease);background:var(--soft);outline:none;resize:none}
.form-group input:focus,.form-group textarea:focus{border-color:var(--saffron);background:#fff}
.success-msg{display:flex;align-items:center;gap:12px;background:#D1FAE5;color:#065F46;padding:20px 24px;border-radius:var(--r);font-size:.93rem;font-weight:500}
.success-msg i{font-size:1.4rem}

/* ================================================================
   CONTACT
   ================================================================ */
.contact-section{background:var(--soft)}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:36px;align-items:start}
.contact-info-col{display:flex;flex-direction:column;gap:14px}
.contact-card{display:flex;align-items:flex-start;gap:14px;background:#fff;border-radius:var(--r);padding:18px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.contact-icon{width:42px;height:42px;border-radius:10px;background:var(--saffron-pale);color:var(--saffron);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-card h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:3px}
.contact-card p,.contact-card a{font-size:.88rem;color:var(--dark)}
.contact-card a:hover{color:var(--saffron)}
.whatsapp-btn-large{display:flex;align-items:center;justify-content:center;gap:10px;background:#25D366;color:#fff;padding:13px;border-radius:var(--r);font-weight:600;font-size:.92rem;transition:var(--ease)}
.whatsapp-btn-large:hover{background:#1BA551;transform:translateY(-2px)}
.contact-map iframe{border-radius:var(--r-lg);box-shadow:var(--shadow-md);display:block}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--saffron);color:#fff;padding:11px 26px;border-radius:8px;font-weight:600;font-size:.88rem;border:2px solid var(--saffron);transition:var(--ease);cursor:pointer;font-family:inherit}
.btn-primary:hover{background:#E55A25;border-color:#E55A25;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,107,53,.3)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:11px 26px;border-radius:8px;font-weight:600;font-size:.88rem;border:2px solid rgba(255,255,255,.7);transition:var(--ease)}
.btn-outline:hover{background:rgba(255,255,255,.15)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;padding:11px 22px;border-radius:8px;font-weight:500;font-size:.88rem;border:2px solid rgba(255,255,255,.4);transition:var(--ease)}
.btn-ghost:hover{border-color:rgba(255,255,255,.8)}
.btn-full{width:100%;justify-content:center}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{background:var(--dark)}
.footer-top{padding:60px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:48px}
.footer-logo-name{display:block;font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--saffron)}
.footer-logo-sub{display:block;font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px;margin-top:2px;margin-bottom:14px}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:18px}
.social-links{display:flex;gap:8px}
.social-links a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.65);display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:var(--ease)}
.social-links a:hover{background:var(--saffron);color:#fff}
.footer-links-col h4,.footer-contact-col h4{font-size:.78rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px}
.footer-links-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links-col ul a{font-size:.85rem;color:rgba(255,255,255,.55);transition:var(--ease)}
.footer-links-col ul a:hover{color:var(--saffron)}
.footer-contact-col p{font-size:.83rem;color:rgba(255,255,255,.55);margin-bottom:10px;display:flex;align-items:flex-start;gap:10px;line-height:1.5}
.footer-contact-col p i{color:var(--saffron);margin-top:3px;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;overflow:visible}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:8px;overflow:visible}
.footer-dev-name{color:var(--saffron);font-weight:600;cursor:pointer;position:relative}
.footer-dev-name::after{content:'📞 9518586837';position:absolute;bottom:120%;left:50%;transform:translateX(-50%);background:var(--saffron);color:#fff;padding:4px 12px;border-radius:6px;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--ease)}
.footer-dev-name:hover::after{opacity:1}

/* ================================================================
   FLOATS & EXTRAS
   ================================================================ */
.whatsapp-float{position:fixed;bottom:28px;right:28px;z-index:999;width:54px;height:54px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 6px 25px rgba(37,211,102,.45);animation:wp-pulse 2s infinite}
@keyframes wp-pulse{0%,100%{box-shadow:0 6px 25px rgba(37,211,102,.45)}50%{box-shadow:0 6px 40px rgba(37,211,102,.7)}}
.back-to-top{position:fixed;bottom:28px;right:92px;z-index:999;width:44px;height:44px;border-radius:50%;background:#fff;color:var(--saffron);border:2px solid var(--saffron);display:none;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;box-shadow:var(--shadow-md);transition:var(--ease)}
.back-to-top.visible{display:flex}
.back-to-top:hover{background:var(--saffron);color:#fff}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr 1fr;gap:36px}
  .achievements-grid{grid-template-columns:repeat(2,1fr)}
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:1fr 1fr}
  .news-featured{grid-row:auto;grid-column:span 2}
  .feedback-inner{padding:32px;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .section-padding{padding:55px 0}
  .top-bar-left{display:none}
  .nav-pill-wrap{display:none}
  .hamburger{display:flex}
  .about-grid{grid-template-columns:1fr}
  .vm-cards{grid-template-columns:1fr}
  .achievements-grid{grid-template-columns:1fr 1fr}
  .projects-grid{grid-template-columns:1fr}
  .initiatives-grid{grid-template-columns:1fr}
  .initiative-card{flex-direction:row}
  .news-grid{grid-template-columns:1fr}
  .news-featured{grid-column:auto}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .instagram-grid{grid-template-columns:repeat(3,1fr)}
  .feedback-inner{grid-template-columns:1fr;padding:24px}
  .form-row{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom-inner{flex-direction:column;text-align:center}
  .hero-slide-content{padding:30px 24px}
  .heroSwiper{height:70vh}
  .hero-stats-inner{flex-wrap:wrap;gap:20px;justify-content:center;padding:16px 10px}
  .hstat{padding:0 16px}
  .hstat-divider{display:none}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .hstat-num{font-size:1.6rem}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr}
  .achievements-grid{grid-template-columns:1fr}
  .hero-name{font-size:2rem}
}

/* ================================================================
   HERO TEXT ANIMATIONS (fix missing slide-in effect)
   ================================================================ */
.hero-slide-content .hero-badge,
.hero-slide-content .hero-name,
.hero-slide-content .hero-tagline,
.hero-slide-content .hero-btns {
  opacity: 0;
  transform: translateY(40px);
  animation: heroFadeUp 0.8s cubic-bezier(0.22,1,0.36,1) forwards;
}
.hero-slide-content .hero-badge  { animation-delay: 0.2s; }
.hero-slide-content .hero-name   { animation-delay: 0.45s; }
.hero-slide-content .hero-tagline{ animation-delay: 0.65s; }
.hero-slide-content .hero-btns   { animation-delay: 0.85s; }

/* For default hero (no banners) */
.hero-default .hero-badge,
.hero-default .hero-name,
.hero-default .hero-tagline,
.hero-default .hero-btns {
  opacity: 0;
  transform: translateY(40px);
  animation: heroFadeUp 0.8s cubic-bezier(0.22,1,0.36,1) forwards;
}
.hero-default .hero-badge  { animation-delay: 0.2s; }
.hero-default .hero-name   { animation-delay: 0.45s; }
.hero-default .hero-tagline{ animation-delay: 0.65s; }
.hero-default .hero-btns   { animation-delay: 0.85s; }

@keyframes heroFadeUp {
  to { opacity: 1; transform: translateY(0); }
}

/* Hero name highlight pulse */
.hero-name-highlight {
  display: inline-block;
  color: var(--saffron);
  text-shadow: 0 0 40px rgba(255,107,53,0.4);
}

/* Swiper re-trigger animation on slide change */
.swiper-slide-active .hero-badge,
.swiper-slide-active .hero-name,
.swiper-slide-active .hero-tagline,
.swiper-slide-active .hero-btns {
  animation-play-state: running;
}
.swiper-slide:not(.swiper-slide-active) .hero-badge,
.swiper-slide:not(.swiper-slide-active) .hero-name,
.swiper-slide:not(.swiper-slide-active) .hero-tagline,
.swiper-slide:not(.swiper-slide-active) .hero-btns {
  opacity: 0;
  animation: none;
}

/* ================================================================
   IMAGE RENDERING FIX — ensure all uploaded images display correctly
   ================================================================ */
.gallery-item img,
.project-img-wrap img,
.news-img-wrap img,
.about-photo,
.testi-author img,
.banner-thumb,
.proj-thumb {
  display: block;
  width: 100%;
  object-fit: cover;
  /* Force browser to re-evaluate broken images */
  background-color: var(--saffron-pale);
  min-height: 10px;
}

/* Gallery grid images – fixed height so grid doesn't collapse */
.gallery-grid .gallery-item {
  background: var(--saffron-pale);
}
.gallery-grid .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* Hero banner background-image fallback */
.hero-slide {
  background-color: #1a1a1a;
  background-size: cover !important;
  background-position: center top !important;
  background-repeat: no-repeat !important;
}

/* ================================================================
   FEATURE 1: PUBLIC POLL
   ================================================================ */
.poll-section{background:#fff}
.poll-widget{max-width:680px;margin:0 auto;background:var(--soft);border-radius:var(--r-lg);padding:36px;border:1px solid var(--border);box-shadow:var(--shadow-md)}
.poll-question{font-size:1.1rem;font-weight:700;color:var(--dark);margin-bottom:24px;display:flex;align-items:flex-start;gap:12px;line-height:1.5}
.poll-question i{color:var(--saffron);font-size:1.4rem;flex-shrink:0;margin-top:2px}
.poll-options{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.poll-option-btn{display:flex;align-items:center;gap:14px;padding:14px 18px;border:2px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;font-size:.93rem;font-weight:500;color:var(--dark);font-family:inherit;transition:var(--ease);text-align:left}
.poll-option-btn:hover{border-color:var(--saffron);background:var(--saffron-pale)}
.poll-option-btn.selected{border-color:var(--saffron);background:var(--saffron-pale);color:var(--saffron)}
.poll-option-btn.selected .poll-radio{color:var(--saffron)}
.poll-radio{font-size:.85rem;color:var(--border);flex-shrink:0}
.poll-submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:var(--saffron);color:#fff;border:none;border-radius:10px;font-size:.93rem;font-weight:700;font-family:inherit;cursor:pointer;transition:var(--ease)}
.poll-submit-btn:disabled{background:var(--border);color:var(--muted);cursor:not-allowed}
.poll-submit-btn:not(:disabled):hover{background:#E55A25;transform:translateY(-2px)}
.poll-privacy{font-size:.75rem;color:var(--muted);text-align:center;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:6px}
.poll-privacy i{color:var(--green)}
.poll-results{display:flex;flex-direction:column;gap:14px}
.poll-result-row{}
.poll-result-label{display:flex;justify-content:space-between;font-size:.88rem;font-weight:600;color:var(--dark);margin-bottom:5px}
.poll-pct{color:var(--saffron);font-weight:800}
.poll-bar-wrap{background:#E8DDD5;border-radius:50px;height:12px;overflow:hidden;margin-bottom:4px}
.poll-bar{height:100%;background:linear-gradient(90deg,var(--saffron),var(--gold));border-radius:50px;transition:width 1s cubic-bezier(.4,0,.2,1)}
.poll-votes{font-size:.75rem;color:var(--muted)}
.poll-total-note{text-align:center;font-size:.8rem;color:var(--muted);margin-top:14px;display:flex;align-items:center;justify-content:center;gap:8px;padding-top:14px;border-top:1px solid var(--border)}

/* ================================================================
   FEATURE 2: EVENTS CALENDAR
   ================================================================ */
.events-section{background:var(--soft)}
.events-strip{display:flex;flex-direction:column;gap:16px}
.event-card{background:#fff;border-radius:var(--r-lg);padding:22px 26px;border:1px solid var(--border);box-shadow:var(--shadow-sm);display:grid;grid-template-columns:90px 1fr auto;gap:20px;align-items:center;transition:var(--ease)}
.event-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.event-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--saffron),#D97706);border-radius:12px;padding:12px 8px;color:#fff;text-align:center;min-width:72px}
.ev-day{font-size:1.8rem;font-weight:800;line-height:1;font-family:'Playfair Display',serif}
.ev-month{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;opacity:.9}
.ev-year{font-size:.62rem;opacity:.75;margin-top:2px}
.event-body h3{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:6px;line-height:1.35}
.event-venue,.event-time{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:3px}
.event-venue i,.event-time i{color:var(--saffron);width:14px}
.event-countdown{display:flex;align-items:center;gap:4px;margin-top:10px}
.cd-item{display:flex;flex-direction:column;align-items:center;background:var(--dark);color:#fff;border-radius:6px;padding:4px 8px;min-width:38px}
.cd-num{font-size:.95rem;font-weight:800;line-height:1;font-family:monospace}
.cd-unit{font-size:.58rem;opacity:.7;text-transform:uppercase;letter-spacing:.5px}
.cd-sep{color:var(--saffron);font-weight:800;font-size:1rem;margin:0 2px}
.event-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.event-wa-btn{display:inline-flex;align-items:center;gap:7px;background:#25D366;color:#fff;padding:8px 14px;border-radius:8px;font-size:.78rem;font-weight:600;white-space:nowrap;transition:var(--ease)}
.event-wa-btn:hover{background:#1BA551;transform:translateY(-2px)}
@media(max-width:700px){.event-card{grid-template-columns:70px 1fr;grid-template-rows:auto auto}.event-actions{grid-column:1/-1}}

/* ================================================================
   FEATURE 3: COMPLAINT TRACKING
   ================================================================ */
.complaints-section{background:#fff}
.complaints-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:start}
.complaint-form{display:flex;flex-direction:column;gap:12px}
.complaint-error{background:#FEE2E2;color:#991B1B;padding:12px 14px;border-radius:8px;font-size:.85rem;display:flex;align-items:center;gap:8px;margin-bottom:4px}
.complaint-success-box{background:linear-gradient(135deg,#D1FAE5,#ECFDF5);border:2px solid #6EE7B7;border-radius:var(--r-lg);padding:32px;text-align:center}
.csb-icon{font-size:3rem;color:var(--green);margin-bottom:12px}
.complaint-success-box h3{font-size:1.2rem;font-weight:700;color:var(--dark);margin-bottom:8px}
.complaint-success-box p{font-size:.88rem;color:var(--muted)}
.ticket-display{font-size:2rem;font-weight:800;color:var(--saffron);font-family:monospace;letter-spacing:4px;background:rgba(255,107,53,.1);padding:14px 24px;border-radius:10px;margin:14px 0;border:2px dashed var(--saffron)}
.complaint-track-col{display:flex;flex-direction:column;gap:16px}
.complaint-track-card{background:var(--soft);border-radius:var(--r-lg);padding:30px;border:1px solid var(--border);text-align:center}
.ctc-icon{font-size:2.5rem;color:var(--saffron);margin-bottom:12px}
.complaint-track-card h3{font-size:1.05rem;font-weight:700;color:var(--dark);margin-bottom:6px}
.complaint-track-card p{font-size:.85rem;color:var(--muted)}
.ctc-steps{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:20px;flex-wrap:wrap}
.ctc-step{display:flex;flex-direction:column;align-items:center;gap:5px}
.ctc-dot{width:30px;height:30px;border-radius:50%;color:#fff;font-weight:800;font-size:.85rem;display:flex;align-items:center;justify-content:center}
.ctc-step p{font-size:.72rem;color:var(--muted);text-align:center;max-width:70px}
.ctc-arrow{color:var(--border);font-size:.9rem}
.complaint-categories-box{background:var(--soft);border-radius:var(--r-lg);padding:20px;border:1px solid var(--border)}
.complaint-categories-box h4{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.comp-cats{display:flex;flex-wrap:wrap;gap:8px}
.comp-cats span{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:50px;padding:5px 12px;font-size:.78rem;color:var(--body)}
.comp-cats span i{color:var(--saffron);font-size:.75rem}
@media(max-width:900px){.complaints-grid{grid-template-columns:1fr}}

/* ================================================================
   FEATURE 4: PRESS COVERAGE
   ================================================================ */
.press-section{background:var(--soft)}
.press-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.press-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:var(--ease);display:flex;flex-direction:column}
.press-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.press-card.hidden-press{display:none}
.press-img-wrap{height:140px;overflow:hidden;background:var(--saffron-pale)}
.press-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.press-card:hover .press-img-wrap img{transform:scale(1.05)}
.press-body{padding:16px;display:flex;flex-direction:column;flex:1}
.press-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.press-type{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:50px;text-transform:uppercase;letter-spacing:.5px}
.press-source{font-size:.75rem;font-weight:700;color:var(--dark)}
.press-date{font-size:.7rem;color:var(--muted);margin-left:auto}
.press-headline{font-size:.87rem;font-weight:700;color:var(--dark);line-height:1.45;margin-bottom:12px;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.press-link{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--saffron);margin-top:auto}
.press-link:hover{color:#E55A25}
@media(max-width:1024px){.press-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.press-grid{grid-template-columns:1fr}}

/* ================================================================
   FEATURE 5: WARD REPORT CARD
   ================================================================ */
.report-card-section{background:linear-gradient(135deg,#7B2D00 0%,#B45309 35%,#FF6B35 65%,#2E7D32 100%)}
.report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}
.rc-card{background:rgba(255,255,255,.14);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.25);border-radius:var(--r-lg);padding:24px;color:#fff;transition:var(--ease)}
.rc-card:hover{background:rgba(255,255,255,.22);transform:translateY(-4px)}
.rc-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.rc-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.rc-nums{display:flex;align-items:baseline;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.rc-current{font-size:1.8rem;font-weight:800;line-height:1;font-family:'Playfair Display',serif}
.rc-sep{color:rgba(255,255,255,.5);font-size:1rem}
.rc-total{font-size:1rem;color:rgba(255,255,255,.7);font-weight:600}
.rc-unit{font-size:.68rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.5px;align-self:flex-end;margin-bottom:2px}
.rc-label{font-size:.85rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:12px;line-height:1.4}
.rc-bar-wrap{background:rgba(255,255,255,.2);border-radius:50px;height:8px;overflow:hidden;margin-bottom:6px}
.rc-bar{height:100%;border-radius:50px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.rc-pct{font-size:.72rem;color:rgba(255,255,255,.7);font-weight:600}
.rc-note{text-align:center;color:rgba(255,255,255,.65);font-size:.78rem;display:flex;align-items:center;justify-content:center;gap:8px}
@media(max-width:1024px){.report-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.report-grid{grid-template-columns:1fr}}


/* ================================================================
   VIDEO HERO BANNER STYLES — FULLSCREEN + MOBILE PORTRAIT
   ================================================================ */
.hero-video-slide {
  position:relative; width:100%; height:100%; min-height:520px;
  overflow:hidden; display:flex; align-items:center; justify-content:flex-start;
  background:#000;
}
.hero-video-bg {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0;
}

/* ── YouTube fullscreen wrapper ── */
.hero-yt-wrap {
  position:absolute; inset:0; z-index:0;
  pointer-events:none; overflow:hidden;
}
.yt-player-div {
  position:absolute;
  top:50%; left:50%;
  /* Always covers the container — wider than 16:9 if needed */
  width:max(100%, calc(100vh * 1.7778));
  height:max(100%, calc(100vw * 0.5625));
  transform:translate(-50%, -50%);
}
.yt-player-div iframe {
  position:absolute; inset:0;
  width:100%; height:100%;
  border:none;
}

/* Mobile portrait: full viewport height video */
@media (max-width:768px) and (orientation:portrait) {
  .hero-video-slide { min-height:100vh; }
  .yt-player-div {
    width:max(100%, calc(100vh * 1.7778));
    height:max(100vh, calc(100vw * 0.5625));
  }
  .hero-video-bg { object-position:center center; height:100vh; }
}

.hero-video-overlay {
  background:linear-gradient(135deg,rgba(180,83,9,.55) 0%,rgba(0,0,0,.45) 60%,rgba(46,125,50,.35) 100%);
}
.hero-type-badge {
  position:absolute; top:16px; right:16px; z-index:15;
  padding:4px 12px; border-radius:20px; font-size:.72rem;
  font-weight:600; letter-spacing:.5px;
  display:flex; align-items:center; gap:5px;
}
.video-badge { background:rgba(255,107,53,.85); color:#fff; }
.image-badge { background:rgba(46,125,50,.75); color:#fff; display:none; }

   MOBILE RESPONSIVENESS — COMPREHENSIVE FIX
   ================================================================ */

/* Top bar - stack on mobile */
@media(max-width:640px) {
  .top-bar { display:none; } /* hide on very small screens to save space */
}
@media(max-width:768px) {
  .top-bar-inner { flex-direction:column; align-items:flex-start; gap:6px; padding:8px 14px; }
  .top-bar-left { gap:10px; flex-wrap:wrap; }
  .top-bar-right { gap:8px; }
}

/* Header nav - mobile */
@media(max-width:900px) {
  .nav-pill-wrap { display:none; }
  .hamburger { display:flex !important; }
}
@media(max-width:640px) {
  .nav-container { padding:0 14px; min-height:60px !important; }
  .logo-name { font-size:.92rem; }
  .logo-sub { font-size:.56rem; }
  .logo-img { height:40px !important; }
}

/* Mobile nav overlay when open */
.mobile-nav.open::before { content:''; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:-1; width:100vw; left:-100vw; }

/* Hero section mobile */
@media(max-width:768px) {
  .hero-slide, .hero-video-slide, .hero-default { min-height:420px !important; }
  .hero-slide-content { padding:20px 18px 30px; }
  .hero-badge { font-size:.7rem; padding:5px 14px; margin-bottom:10px; }
  .hero-name { font-size:clamp(1.4rem, 5vw, 2.2rem) !important; margin-bottom:8px; }
  .hero-name-highlight { font-size:clamp(1.6rem, 6vw, 2.8rem) !important; }
  .hero-tagline { font-size:clamp(.82rem, 3vw, 1rem); margin-bottom:18px; }
  .hero-btns { flex-direction:column; align-items:flex-start; gap:10px; }
  .btn-primary, .btn-outline { padding:10px 20px; font-size:.85rem; }
}
@media(max-width:480px) {
  .hero-slide, .hero-video-slide, .hero-default { min-height:360px !important; }
  .hero-stats-inner { grid-template-columns:1fr 1fr !important; gap:10px !important; }
  .hstat-divider:nth-child(4) { display:none; }
  .hstat { padding:12px 6px !important; }
  .hstat-num { font-size:1.4rem !important; }
}

/* Stats bar mobile */
@media(max-width:768px) {
  .hero-stats-inner { grid-template-columns:repeat(2, 1fr); gap:12px; }
  .hstat-divider { display:none; }
  .hstat { padding:14px 10px; }
  .hstat-num { font-size:1.5rem; }
}

/* About section mobile */
@media(max-width:900px) {
  .about-grid { grid-template-columns:1fr !important; gap:30px; }
  .about-media-col { max-width:480px; margin:0 auto; }
}
@media(max-width:640px) {
  .about-img-frame { max-height:320px; overflow:hidden; border-radius:16px; }
  .about-photo { width:100%; height:300px; object-fit:cover; }
  .vm-cards { grid-template-columns:1fr !important; }
  .timeline { padding-left:16px; }
}

/* Section padding mobile */
@media(max-width:768px) {
  .section-padding { padding:50px 0; }
  .container { padding:0 14px; }
  .section-heading { font-size:clamp(1.3rem, 5vw, 2rem); }
}

/* Projects grid mobile */
@media(max-width:768px) {
  .projects-grid { grid-template-columns:1fr !important; }
  .filter-btns { gap:6px; flex-wrap:wrap; }
  .filter-btn { padding:7px 14px; font-size:.78rem; }
}
@media(min-width:480px) and (max-width:768px) {
  .projects-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* News grid mobile */
@media(max-width:768px) {
  .news-grid { grid-template-columns:1fr !important; }
  .news-featured { grid-column:auto !important; grid-row:auto !important; }
}
@media(min-width:480px) and (max-width:768px) {
  .news-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Gallery grid mobile */
@media(max-width:640px) {
  .gallery-grid { grid-template-columns:repeat(2,1fr) !important; gap:8px; }
}
@media(max-width:380px) {
  .gallery-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Achievements grid mobile */
@media(max-width:640px) {
  .achievements-grid { grid-template-columns:1fr !important; }
}
@media(min-width:480px) and (max-width:768px) {
  .achievements-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Initiatives grid mobile */
@media(max-width:640px) {
  .initiatives-grid { grid-template-columns:1fr !important; }
}

/* Feedback section mobile */
@media(max-width:900px) {
  .feedback-inner { grid-template-columns:1fr !important; }
}
@media(max-width:640px) {
  .form-row { grid-template-columns:1fr !important; }
}

/* Contact grid mobile */
@media(max-width:900px) {
  .contact-grid { grid-template-columns:1fr !important; }
  .contact-map { height:280px; }
  .contact-map iframe { height:280px; }
}

/* Complaints grid mobile */
@media(max-width:900px) {
  .complaints-grid { grid-template-columns:1fr !important; }
}
@media(max-width:640px) {
  .ctc-steps { flex-direction:column; align-items:flex-start; gap:8px; }
  .ctc-arrow { transform:rotate(90deg); }
}

/* Events mobile */
@media(max-width:640px) {
  .event-card { flex-direction:column; gap:12px; }
  .event-date-badge { flex-direction:row; gap:6px; padding:10px 16px; border-right:none; border-bottom:1px solid var(--border); }
}

/* Press grid mobile */
@media(max-width:640px) {
  .press-grid { grid-template-columns:1fr !important; }
}
@media(min-width:480px) and (max-width:768px) {
  .press-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Report card mobile */
@media(max-width:640px) {
  .report-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Instagram grid mobile */
@media(max-width:640px) {
  .instagram-grid { grid-template-columns:repeat(2,1fr) !important; }
}

/* Footer mobile */
@media(max-width:768px) {
  .footer-grid { grid-template-columns:1fr !important; gap:24px; }
  .footer-bottom-inner { flex-direction:column; text-align:center; gap:6px; }
}

/* Ticker mobile */
@media(max-width:480px) {
  .ticker-label { font-size:.68rem; padding:0 8px; }
  .ticker-track { font-size:.75rem; }
}

/* Swiper nav buttons mobile */
@media(max-width:640px) {
  .hero-next, .hero-prev { display:none !important; }
  .swiper-button-next, .swiper-button-prev { width:32px !important; height:32px !important; }
}

/* Tables on mobile */
@media(max-width:640px) {
  table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
}

/* WhatsApp float button — better position on mobile */
@media(max-width:640px) {
  .whatsapp-float { width:50px; height:50px; bottom:70px; right:14px; font-size:1.4rem; }
  .back-to-top { width:38px; height:38px; bottom:20px; right:14px; font-size:.85rem; }
}

/* Lightbox mobile */
@media(max-width:640px) {
  .lightbox-inner { padding:10px; }
  .lightbox-inner img { max-height:70vh; }
}

/* Poll widget mobile */
@media(max-width:640px) {
  .poll-widget { padding:20px 14px; }
  .poll-option-btn { padding:10px 14px; font-size:.85rem; }
}

/* General button touch targets */
@media(max-width:768px) {
  button, .btn-primary, .btn-outline, .btn-view-more, .filter-btn {
    min-height:44px;
    touch-action:manipulation;
  }
  input, select, textarea { font-size:16px !important; } /* prevent iOS zoom */
}

/* Overflow fix */
body { overflow-x:hidden; }
section, .container { overflow-x:hidden; }

/* ================================================================
   TESTIMONIAL IMAGE — proper circle, no cut-off
   ================================================================ */
.testi-author img {
  width: 60px !important;
  height: 60px !important;
  min-width: 60px !important;
  min-height: 60px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 3px solid var(--saffron) !important;
  display: block !important;
  flex-shrink: 0 !important;
}
.testi-avatar {
  width: 60px !important;
  height: 60px !important;
  min-width: 60px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}

/* ================================================================
   STATS BAR — Bold clean numbers like reference image
   ================================================================ */
.hstat-num {
  font-size: 2.6rem !important;
  font-weight: 900 !important;
  color: var(--dark) !important;
  font-family: 'Poppins', sans-serif !important;
  line-height: 1 !important;
  letter-spacing: -1px !important;
}
.hstat-suffix {
  font-size: 1.6rem !important;
  font-weight: 900 !important;
  color: var(--saffron) !important;
  line-height: 1 !important;
}
.hstat-label {
  font-size: .72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: var(--muted) !important;
  margin-top: 6px !important;
}
.hero-stats-bar {
  background: #fff !important;
  box-shadow: 0 4px 24px rgba(0,0,0,.08) !important;
}



/* ================================================================
   DEVELOPER POPUP MODAL
   ================================================================ */
.dev-popup-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.6); z-index:99999;
  align-items:center; justify-content:center;
  backdrop-filter:blur(4px);
}
.dev-popup-overlay.open { display:flex; }
.dev-popup {
  background:#fff; border-radius:20px; padding:0;
  max-width:420px; width:90%; box-shadow:0 20px 60px rgba(0,0,0,.3);
  animation:popup-in .3s cubic-bezier(.34,1.56,.64,1) both;
  overflow:hidden;
}
@keyframes popup-in {
  from { opacity:0; transform:scale(.85) translateY(20px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
.dev-popup-header {
  background:linear-gradient(135deg,#B45309,#FF6B35,#4CAF50);
  padding:28px 28px 24px; text-align:center; position:relative;
}
.dev-popup-header h3 { color:#fff; font-size:1.2rem; font-weight:800; margin:0 0 4px; }
.dev-popup-header p  { color:rgba(255,255,255,.85); font-size:.82rem; margin:0; }
.dev-popup-avatar {
  width:72px; height:72px; border-radius:50%;
  background:rgba(255,255,255,.2); border:3px solid rgba(255,255,255,.6);
  display:flex; align-items:center; justify-content:center;
  font-size:2rem; color:#fff; margin:0 auto 14px;
}
.dev-popup-close {
  position:absolute; top:12px; right:14px;
  background:rgba(255,255,255,.2); border:none; cursor:pointer;
  width:30px; height:30px; border-radius:50%; color:#fff;
  font-size:.9rem; display:flex; align-items:center; justify-content:center;
  transition:.2s;
}
.dev-popup-close:hover { background:rgba(255,255,255,.4); }
.dev-popup-body { padding:24px 28px; }
.dev-popup-row {
  display:flex; align-items:center; gap:12px;
  padding:12px 0; border-bottom:1px solid #F3F4F6;
}
.dev-popup-row:last-child { border-bottom:none; }
.dev-popup-row i { width:36px; height:36px; border-radius:10px;
  background:#FFF4EF; color:#FF6B35; display:flex; align-items:center;
  justify-content:center; flex-shrink:0; font-size:.95rem;
}
.dev-popup-row div { flex:1; }
.dev-popup-row strong { display:block; font-size:.85rem; color:#1A1A1A; font-weight:700; }
.dev-popup-row span { font-size:.78rem; color:#777; }
.dev-popup-row a { color:#FF6B35; text-decoration:none; font-weight:600; }
.dev-popup-row a:hover { text-decoration:underline; }
.dev-popup-footer { padding:0 28px 24px; text-align:center; }
.dev-popup-footer .btn-dev {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,#FF6B35,#D97706);
  color:#fff; padding:11px 24px; border-radius:50px;
  font-size:.88rem; font-weight:700; text-decoration:none;
  transition:.2s; box-shadow:0 4px 16px rgba(255,107,53,.4);
}
.dev-popup-footer .btn-dev:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,107,53,.5); }
.dev-credit { cursor:pointer !important; }

/* ================================================================
   REPORT CARD — IMPROVED CONTRAST & VISIBILITY
   ================================================================ */
.report-card-section { background:linear-gradient(135deg,#4A1500 0%,#7B2D00 25%,#B45309 55%,#1B5E20 100%) !important; }
.report-card-section .section-heading.white,
.report-card-section .section-heading { color:#fff !important; text-shadow:0 2px 8px rgba(0,0,0,.5); }
.report-card-section .section-tag.white { color:rgba(255,255,255,.9) !important; }
.report-card-section .section-sub { color:rgba(255,255,255,.85) !important; }
.rc-card {
  background:rgba(255,255,255,.18) !important;
  border:1px solid rgba(255,255,255,.35) !important;
  box-shadow:0 8px 32px rgba(0,0,0,.25) !important;
}
.rc-label { color:#fff !important; font-weight:700 !important; text-shadow:0 1px 3px rgba(0,0,0,.4); }
.rc-current { color:#FFE082 !important; text-shadow:0 2px 6px rgba(0,0,0,.4); }
.rc-sep, .rc-unit { color:rgba(255,255,255,.8) !important; }
.rc-total { color:rgba(255,255,255,.8) !important; }
.rc-pct { color:#FFE082 !important; font-weight:700 !important; font-size:.82rem !important; }
.rc-bar-wrap { background:rgba(255,255,255,.2) !important; border-radius:10px; height:8px; overflow:hidden; margin-bottom:4px; }
.rc-icon i { filter:drop-shadow(0 1px 3px rgba(0,0,0,.3)); }
.rc-note { color:rgba(255,255,255,.8) !important; background:rgba(0,0,0,.2); padding:10px 16px; border-radius:8px; }

/* ================================================================
   FOOTER DEVELOPER CREDIT WITH HOVER TOOLTIP
   ================================================================ */
.dev-credit {
  display:inline-flex;
  align-items:center;
  gap:5px;
  cursor:default;
  position:relative;
  color:rgba(255,255,255,.75);
  border-bottom:1px dotted rgba(255,107,53,.6);
  transition:color .2s;
}
.dev-credit:hover { color:#FFB347; }
.dev-credit .dev-tooltip {
  position:absolute;
  bottom:calc(100% + 10px);
  left:50%;
  transform:translateX(-50%);
  background:#FF6B35;
  color:#fff;
  padding:6px 14px;
  border-radius:8px;
  font-size:.78rem;
  white-space:nowrap;
  pointer-events:none;
  opacity:0;
  visibility:hidden;
  transition:opacity .25s, visibility .25s;
  box-shadow:0 4px 16px rgba(255,107,53,.5);
  z-index:9999;
  font-weight:600;
  letter-spacing:.3px;
}
.dev-credit .dev-tooltip::after {
  content:'';
  position:absolute;
  top:100%; left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#FF6B35;
}
.dev-credit:hover .dev-tooltip {
  opacity:1;
  visibility:visible;
}
.dev-credit i { color:var(--saffron); font-size:.8rem; }

/* ================================================================
   MOBILE NAV — CLOSE BUTTON & HEADER
   ================================================================ */
.mnav-close {
  position:absolute; top:16px; right:16px;
  background:rgba(255,255,255,.1); border:none; cursor:pointer;
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1rem; transition:background .2s;
  z-index:10;
}
.mnav-close:hover { background:var(--saffron); }
.mnav-header {
  padding:0 20px 20px;
  border-bottom:1px solid rgba(255,255,255,.1);
  margin-bottom:8px;
}
.mnav-leader-name {
  font-size:1rem; font-weight:700; color:#fff;
  font-family:'Playfair Display',serif;
}
.mnav-leader-title {
  font-size:.72rem; color:rgba(255,255,255,.6);
  margin-top:2px; text-transform:uppercase; letter-spacing:1px;
}
/* ================================================================
   BJP PRELOADER — Lotus + Tricolour spin animation
   ================================================================ */
#bjp-preloader {
  position:fixed; inset:0; z-index:999999;
  background:linear-gradient(135deg,#FF6B00 0%,#FF8C00 30%,#FFFFFF 50%,#138808 70%,#0a5c0a 100%);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:0;
  transition:opacity .6s ease, visibility .6s ease;
}
#bjp-preloader.hide { opacity:0; visibility:hidden; pointer-events:none; }
.bjp-loader-inner {
  position:relative; width:160px; height:160px;
  display:flex; align-items:center; justify-content:center;
}
/* Outer spinning tricolour ring */
@keyframes triRing {
  from { transform:rotate(0deg); }
  to   { transform:rotate(360deg); }
}
@keyframes triRingReverse {
  from { transform:rotate(0deg); }
  to   { transform:rotate(-360deg); }
}
.bjp-ring1 {
  position:absolute; width:150px; height:150px; border-radius:50%;
  border:5px solid transparent;
  border-top-color:#FF6B00; border-right-color:#FF6B00;
  border-bottom-color:#138808; border-left-color:#138808;
  animation:triRing 1.4s linear infinite;
}
.bjp-ring2 {
  position:absolute; width:126px; height:126px; border-radius:50%;
  border:4px solid transparent;
  border-top-color:#138808; border-right-color:rgba(255,255,255,.7);
  border-bottom-color:#FF6B00; border-left-color:rgba(255,255,255,.7);
  animation:triRingReverse 1.8s linear infinite;
}
/* Lotus circle in centre */
.bjp-lotus-circle {
  width:90px; height:90px; border-radius:50%;
  background:radial-gradient(circle at 40% 35%, #fff 0%, #FFF4EF 60%, #FFE0CC 100%);
  box-shadow:0 4px 24px rgba(255,107,0,.45), 0 0 0 3px rgba(255,107,0,.2);
  display:flex; align-items:center; justify-content:center;
  z-index:2; position:relative;
  animation:lotusBreath 1.6s ease-in-out infinite;
}
@keyframes lotusBreath {
  0%,100% { transform:scale(1); box-shadow:0 4px 24px rgba(255,107,0,.45); }
  50%      { transform:scale(1.06); box-shadow:0 8px 36px rgba(255,107,0,.7); }
}
/* Lotus petals via SVG-like CSS */
.bjp-lotus {
  font-size:2.6rem; line-height:1;
  background:linear-gradient(135deg,#FF6B00,#FF8C00,#D97706);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 2px 4px rgba(255,107,0,.5));
  animation:lotusSpin 8s linear infinite;
}
@keyframes lotusSpin {
  0%,100% { transform:rotate(0deg) scale(1); }
  25% { transform:rotate(10deg) scale(1.05); }
  75% { transform:rotate(-10deg) scale(1.05); }
}
.bjp-loader-text {
  margin-top:22px; text-align:center;
}
.bjp-loader-name {
  font-size:1.3rem; font-weight:800; color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,.25); letter-spacing:1px;
  font-family:'Playfair Display','Poppins',serif;
  animation:textPulse 1.5s ease-in-out infinite;
}
@keyframes textPulse {
  0%,100% { opacity:1; } 50% { opacity:.7; }
}
.bjp-loader-sub {
  font-size:.75rem; color:rgba(255,255,255,.8); letter-spacing:3px;
  text-transform:uppercase; margin-top:5px;
}
/* Tricolour bar at bottom of preloader */
.bjp-tribar {
  position:absolute; bottom:0; left:0; right:0;
  height:6px; display:flex;
}
.bjp-tribar span:nth-child(1){ flex:1; background:#FF6B00; }
.bjp-tribar span:nth-child(2){ flex:1; background:#FFFFFF; }
.bjp-tribar span:nth-child(3){ flex:1; background:#138808; }
/* Progress dots */
.bjp-dots {
  display:flex; gap:8px; margin-top:14px;
}
.bjp-dots span {
  width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.5);
  animation:dotBounce 1.2s ease-in-out infinite;
}
.bjp-dots span:nth-child(2){ animation-delay:.2s; }
.bjp-dots span:nth-child(3){ animation-delay:.4s; }
@keyframes dotBounce {
  0%,80%,100% { transform:scale(1); background:rgba(255,255,255,.5); }
  40% { transform:scale(1.4); background:#fff; }
}

/* ================================================================
   MOBILE HEADER — Show centre circle leader photo
   ================================================================ */
.mobile-nav-leader-circle {
  display:none;
}
@media(max-width:900px) {
  .mobile-nav-leader-circle {
    display:flex;
    align-items:center; justify-content:center;
    position:absolute; left:50%; top:50%;
    transform:translate(-50%,-50%);
    z-index:12; pointer-events:none;
  }
  .mobile-nav-leader-circle .mnlc-img {
    width:48px; height:48px; border-radius:50%;
    object-fit:cover; object-position:center top;
    border:3px solid rgba(255,255,255,.9);
    box-shadow:0 3px 16px rgba(0,0,0,.3), 0 0 0 2px rgba(255,107,53,.5);
    display:block;
    animation:lotusBreath 3s ease-in-out infinite;
  }
  .mobile-nav-leader-circle .mnlc-placeholder {
    width:48px; height:48px; border-radius:50%;
    background:rgba(255,255,255,.2); border:3px solid rgba(255,255,255,.7);
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:1.2rem;
  }
}

/* ================================================================
   BONUS 1 — Reading Progress Bar (top of page)
   ================================================================ */
#reading-progress {
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg,#FF6B00,#FFB347,#138808);
  z-index:99999; transition:width .1s linear;
  box-shadow:0 0 8px rgba(255,107,0,.6);
}

/* ================================================================
   BONUS 2 — Floating WhatsApp Pulse Button
   ================================================================ */
.wa-float {
  position:fixed; bottom:80px; right:20px;
  width:52px; height:52px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; text-decoration:none; z-index:9000;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  animation:waPulse 2.5s ease-in-out infinite;
  transition:transform .2s, box-shadow .2s;
}
.wa-float:hover { transform:scale(1.12); box-shadow:0 6px 28px rgba(37,211,102,.7); animation:none; }
@keyframes waPulse {
  0%,100% { box-shadow:0 4px 20px rgba(37,211,102,.5), 0 0 0 0 rgba(37,211,102,.4); }
  50%      { box-shadow:0 4px 20px rgba(37,211,102,.5), 0 0 0 14px rgba(37,211,102,0); }
}
.wa-float-badge {
  position:absolute; top:-4px; right:-4px;
  width:18px; height:18px; border-radius:50%;
  background:#FF6B35; color:#fff; font-size:.6rem; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  border:2px solid #fff; animation:badgePop 2s ease-in-out infinite;
}
@keyframes badgePop {
  0%,100% { transform:scale(1); } 50% { transform:scale(1.25); }
}

/* ================================================================
   BONUS 3 — Section Entrance Animations (Intersection Observer)
   ================================================================ */
.section-reveal {
  opacity:0; transform:translateY(40px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}
.section-reveal.revealed {
  opacity:1; transform:translateY(0);
}
.section-reveal.reveal-left  { transform:translateX(-40px); }
.section-reveal.reveal-right { transform:translateX(40px); }
.section-reveal.reveal-left.revealed,
.section-reveal.reveal-right.revealed { transform:translateX(0); }

/* ================================================================
   BONUS 4 — Dark Mode Toggle
   ================================================================ */
.dark-mode-toggle {
  position:fixed; bottom:20px; left:20px;
  width:44px; height:44px; border-radius:50%;
  background:#fff; border:2px solid var(--border);
  box-shadow:0 2px 12px rgba(0,0,0,.12);
  cursor:pointer; z-index:9000;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; transition:.3s; color:var(--dark);
}
.dark-mode-toggle:hover { background:var(--saffron-pale); color:var(--saffron); transform:scale(1.1); }
body.dark-mode {
  background:#111 !important; color:#e0e0e0 !important;
  --body:#e0e0e0; --dark:#f0f0f0; --soft:#1e1e1e; --border:#333;
  --bg-soft:#1a1a1a; --muted:#aaa;
}
body.dark-mode .about-section,
body.dark-mode .testimonials-section,
body.dark-mode .news-section,
body.dark-mode .gallery-section,
body.dark-mode .contact-section { background:#1a1a1a !important; }
body.dark-mode .project-card,
body.dark-mode .news-card,
body.dark-mode .testi-card,
body.dark-mode .press-card { background:#222 !important; border-color:#333 !important; }
body.dark-mode .site-footer { background:#0d0d0d !important; }
body.dark-mode .dark-mode-toggle { background:#222; border-color:#444; color:#FFB347; }

/* ================================================================
   BONUS 5 — Animated Counter (number roll effect on scroll)
   ================================================================ */
.hstat-num[data-count] { display:inline-block; }

/* Back to top progress ring (enhance existing) */
#backToTop {
  position:fixed; bottom:20px; right:20px;
  width:44px; height:44px; border-radius:50%;
  background:var(--saffron); color:#fff;
  border:none; cursor:pointer; z-index:9001;
  display:none; align-items:center; justify-content:center;
  font-size:.9rem; box-shadow:0 4px 16px rgba(255,107,53,.4);
  transition:.3s;
}
#backToTop.visible { display:flex; }
#backToTop:hover { transform:scale(1.1) translateY(-2px); background:#D97706; }


html { scrollbar-width:none; -ms-overflow-style:none; }
html::-webkit-scrollbar { display:none; }

* { scrollbar-width:none; -ms-overflow-style:none; }
*::-webkit-scrollbar { display:none; }