:root{--green:#008751;--forest:#005c38;--deep:#003d26;--night:#0A1A0F;--gold:#D4AF37;--gold-l:#F4D160;--gold-d:#A08020;--white:#fff;--offwhite:#F7F9F7;--lgray:#EFF3EF;--mgray:#7A8A7A;--dark:#0A1A0F;--text:#1a2e1e;--muted:#4A6050;--border:#D0E4D0;--red:#C0392B;--ff-display:'Playfair Display',Georgia,serif;--ff-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--ff-grotesk:'Space Grotesk',sans-serif;--r:12px;--r-lg:20px;--r-xl:32px;--r-full:9999px;--sh:0 4px 24px rgba(0,135,81,.12);--sh-lg:0 12px 48px rgba(0,135,81,.18);--sh-xl:0 24px 80px rgba(0,0,0,.20);--tr:all .3s cubic-bezier(.4,0,.2,1);--hh:80px;--uh:40px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--ff-body);background:var(--white);color:var(--text);line-height:1.6;overflow-x:hidden}img{display:block;max-width:100%;height:auto}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}ul{list-style:none}
.container{max-width:1280px;margin:0 auto;padding:0 clamp(1rem,4vw,3rem)}.section{padding:clamp(4rem,8vw,8rem) 0}.section--sm{padding:clamp(2rem,4vw,4rem) 0}.flex{display:flex}.grid{display:grid}.hidden{display:none!important}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:var(--r-full);font-size:.9rem;font-weight:600;letter-spacing:.01em;transition:var(--tr);white-space:nowrap;border:none;cursor:pointer}
.btn--primary{background:var(--green);color:#fff}.btn--primary:hover{background:var(--forest);transform:translateY(-1px);box-shadow:var(--sh)}
.btn--gold{background:var(--gold);color:var(--dark)}.btn--gold:hover{background:var(--gold-l);transform:translateY(-1px)}
.btn--outline{border:2px solid var(--green);color:var(--green);background:transparent}.btn--outline:hover{background:var(--green);color:#fff}
.btn--outline-white{border:2px solid rgba(255,255,255,.6);color:#fff;background:transparent}.btn--outline-white:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn--sm{padding:.5rem 1.25rem;font-size:.8rem}.btn--lg{padding:1rem 2.5rem;font-size:1rem}.btn--xl{padding:1.125rem 3rem;font-size:1.1rem}
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .75rem;border-radius:var(--r-full);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.badge--green{background:rgba(0,135,81,.12);color:var(--green)}.badge--gold{background:rgba(212,175,55,.15);color:var(--gold-d)}.badge--live{background:var(--red);color:#fff;animation:pulse-b 1.5s infinite}
@keyframes pulse-b{0%,100%{opacity:1}50%{opacity:.7}}
.card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;transition:var(--tr)}.card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}.card__body{padding:1.5rem}.card__title{font-family:var(--ff-display);font-size:1.1rem;font-weight:700;margin-bottom:.5rem;line-height:1.3}.card__text{font-size:.9rem;color:var(--muted);line-height:1.6}
.section-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}.section-header .overline{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--green);margin-bottom:1rem}.section-header .overline::before,.section-header .overline::after{content:'';width:2rem;height:1px;background:var(--green);opacity:.4}.section-header h2{font-family:var(--ff-display);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;margin-bottom:1rem}.section-header p{font-size:clamp(1rem,2vw,1.125rem);color:var(--muted);max-width:600px;margin:0 auto}
/* UTILITY BAR */
.utility-bar{height:var(--uh);background:var(--night);display:flex;align-items:center}.utility-bar .container{display:flex;justify-content:space-between;align-items:center;width:100%}.utility-bar a,.utility-bar button{font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.7);padding:.25rem .6rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.35rem;border:none;cursor:pointer}.utility-bar a:hover,.utility-bar button:hover{color:#fff;background:rgba(255,255,255,.08)}.utility-bar__left{display:flex;align-items:center;gap:1rem}.utility-bar__right{display:flex;align-items:center;gap:.25rem}.donate-btn{background:var(--gold)!important;color:var(--dark)!important;border-radius:4px;padding:.25rem .75rem!important}.donate-btn:hover{background:var(--gold-l)!important}.divider-v{width:1px;height:14px;background:rgba(255,255,255,.15);margin:0 .25rem}
/* MAIN NAV */
.main-nav{position:sticky;top:0;z-index:1000;height:var(--hh);background:var(--dark);border-bottom:1px solid rgba(255,255,255,.05);transition:var(--tr)}.main-nav.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.4);background:rgba(10,26,15,.97);backdrop-filter:blur(20px)}.nav-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav-logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.nav-logo img{height:46px;width:auto;object-fit:contain}.nav-logo__text{display:flex;flex-direction:column}.nav-logo__name{font-family:var(--ff-display);font-size:1.05rem;font-weight:900;color:#fff;line-height:1}.nav-logo__year{font-size:.62rem;font-weight:700;letter-spacing:.15em;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:0}.nav-item{position:relative}.nav-link{display:flex;align-items:center;gap:.3rem;padding:0 .85rem;height:var(--hh);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.75);transition:all .2s;white-space:nowrap;position:relative}.nav-link:hover,.nav-link.active{color:#fff}.nav-link::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:3px;background:var(--green);transition:var(--tr);border-radius:2px 2px 0 0}.nav-link:hover::after,.nav-link.active::after{left:0;right:0}.caret{font-size:.6rem;opacity:.5;transition:all .2s}.nav-item:hover .caret{opacity:1;transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:100%;left:0;background:var(--dark);border:1px solid rgba(255,255,255,.08);border-top:3px solid var(--green);border-radius:0 0 var(--r) var(--r);min-width:210px;padding:.5rem 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--tr);box-shadow:var(--sh-xl)}.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown a{display:flex;align-items:center;gap:.6rem;padding:.65rem 1.25rem;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.7);transition:all .2s;white-space:nowrap}.nav-dropdown a:hover{color:#fff;background:rgba(0,135,81,.15);padding-left:1.6rem}.nav-dropdown a i{width:16px;color:var(--green);font-size:.8rem}
.nav-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.hamburger{display:none;flex-direction:column;gap:5px;padding:.5rem}.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--tr)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--dark);z-index:1100;overflow-y:auto;flex-direction:column;padding:1.5rem}.mobile-menu.open{display:flex}.mobile-menu__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.mobile-menu__nav a{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;margin-bottom:.25rem;font-size:1rem;font-weight:600;color:rgba(255,255,255,.8);border-radius:var(--r);border-left:3px solid transparent;transition:all .2s}.mobile-menu__nav a:hover{background:rgba(255,255,255,.06);border-color:var(--green);color:#fff;padding-left:1.25rem}.mobile-menu__footer{margin-top:auto;padding-top:2rem;display:flex;gap:.75rem;flex-wrap:wrap}
/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}.hero__bg{position:absolute;inset:0;z-index:0;background:var(--night)}.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center top;opacity:.35}.hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(0,30,15,.92) 0%,rgba(0,87,51,.5) 50%,rgba(0,30,15,.8) 100%)}.hero__flag{position:absolute;left:0;top:0;bottom:0;width:8px;z-index:2;background:linear-gradient(180deg,#fff 0%,var(--green) 50%,#fff 100%);opacity:.4}
.hero__content{position:relative;z-index:3;padding:6rem 0 4rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;width:100%}
.hero__overline{display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold)}.hero__overline::before{content:'';width:2rem;height:1px;background:var(--gold)}
.hero__headline{font-family:var(--ff-display);font-weight:900;line-height:1.05;font-size:clamp(2.8rem,5.5vw,5.5rem);color:#fff;margin-bottom:1.25rem}.hero__headline em{color:var(--gold);font-style:normal}
.hero__sub{font-size:clamp(1rem,2vw,1.25rem);color:rgba(255,255,255,.8);margin-bottom:2rem;max-width:560px;line-height:1.65}
.hero__slogan{font-family:var(--ff-display);font-style:italic;font-size:.95rem;color:rgba(255,255,255,.5);margin-bottom:2.5rem;border-left:2px solid var(--gold);padding-left:1rem}
.hero__ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{display:flex;gap:2rem;margin-top:3rem;flex-wrap:wrap}.hero__stat-num{font-family:var(--ff-grotesk);font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:700;color:var(--gold);line-height:1}.hero__stat-label{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:.25rem;letter-spacing:.05em;text-transform:uppercase}
.hero__img-col{position:relative;display:flex;justify-content:center}
.hero__frame{position:relative;width:min(400px,100%)}.hero__frame::before{content:'';position:absolute;inset:-12px;border-radius:50%;background:conic-gradient(var(--green),var(--gold),var(--forest),var(--gold),var(--green));animation:spin 12s linear infinite;opacity:.25}
.hero__cimg{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center top;border-radius:var(--r-xl);position:relative;z-index:1;border:4px solid rgba(212,175,55,.4);box-shadow:0 32px 80px rgba(0,0,0,.5)}
.hero__badge{position:absolute;bottom:1.5rem;left:-1rem;z-index:2;background:var(--dark);border:2px solid var(--gold);border-radius:var(--r);padding:.75rem 1.25rem;box-shadow:var(--sh-lg)}.hero__badge .name{font-family:var(--ff-display);font-weight:700;font-size:.9rem;color:#fff;line-height:1.2}.hero__badge .ttl{font-size:.68rem;color:var(--gold);letter-spacing:.05em;text-transform:uppercase;margin-top:.2rem}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:3;color:rgba(255,255,255,.4);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;animation:bounce 2s infinite}.hero__scroll-line{width:1px;height:2.5rem;background:linear-gradient(180deg,transparent,rgba(255,255,255,.3))}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
/* STATS BAR */
.stats-bar{background:var(--green);padding:1.5rem 0}.stats-bar .container{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}.stat-item{padding:.75rem;border-right:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;align-items:center}.stat-item:last-child{border-right:none}.stat-num{font-family:var(--ff-grotesk);font-size:clamp(1.5rem,2.5vw,2rem);font-weight:700;color:#fff;line-height:1}.stat-label{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:.35rem}.stat-icon{font-size:1.1rem;color:var(--gold);margin-bottom:.2rem}
/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center}.about-img-stack{position:relative;padding-bottom:2rem}.about-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:var(--r-xl);box-shadow:var(--sh-xl)}.about-img-secondary{position:absolute;bottom:0;right:-1.5rem;width:55%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-lg);border:4px solid #fff;box-shadow:var(--sh-lg)}.about-img-badge{position:absolute;top:1.5rem;left:-1rem;background:var(--green);color:#fff;border-radius:var(--r);padding:.75rem 1rem;box-shadow:var(--sh)}.about-img-badge .num{font-family:var(--ff-grotesk);font-size:1.5rem;font-weight:700;line-height:1}.about-img-badge .txt{font-size:.65rem;letter-spacing:.05em;text-transform:uppercase;opacity:.8}
.about-quote{background:var(--green);color:#fff;border-radius:var(--r);padding:1.25rem 1.5rem;margin:1.5rem 0;position:relative;overflow:hidden}.about-quote::before{content:'"';font-family:var(--ff-display);font-size:6rem;color:rgba(255,255,255,.1);position:absolute;top:-.5rem;left:.5rem;line-height:1}.about-quote p{font-style:italic;font-size:1rem;position:relative;z-index:1;line-height:1.7}.about-quote cite{font-size:.75rem;opacity:.7;margin-top:.5rem;display:block;font-style:normal}
.achieve-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1.5rem 0}.achieve-item{display:flex;align-items:flex-start;gap:.75rem;background:#fff;border-radius:var(--r);padding:.9rem;border:1px solid var(--border)}.achieve-item i{color:var(--green);font-size:1rem;margin-top:.15rem;flex-shrink:0}.achieve-item span{font-size:.82rem;font-weight:500;line-height:1.4}
/* MANIFESTO CARDS */
.manifesto-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.manifesto-card{border-radius:var(--r-lg);overflow:hidden;transition:var(--tr);cursor:pointer;border:1px solid var(--border)}.manifesto-card:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}.manifesto-card__hdr{padding:1.5rem;position:relative;overflow:hidden;min-height:140px;display:flex;flex-direction:column;justify-content:flex-end}.mc-1{background:#003d26}.mc-2{background:#008751}.mc-3{background:#1A5E3A}.mc-4{background:#0D4A2E}.mc-5{background:#2D7A52}.mc-6{background:#1B6640}.mc-7{background:#3A8C5E}.mc-8{background:#123E28}.manifesto-card__icon{font-size:2.2rem;position:absolute;top:1rem;right:1rem;opacity:.12;color:#fff}.manifesto-card__n{font-family:var(--ff-grotesk);font-size:2.5rem;font-weight:900;color:rgba(255,255,255,.12);position:absolute;top:.5rem;left:1rem}.manifesto-card__pl{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem}.manifesto-card__title{font-family:var(--ff-display);font-size:1.05rem;font-weight:700;color:#fff;line-height:1.3}.manifesto-card__body{padding:1.25rem;background:#fff}.manifesto-card__commits{display:flex;flex-direction:column;gap:.5rem}.manifesto-card__commit{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--muted)}.manifesto-card__commit::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;font-size:.75rem;margin-top:.15rem}.manifesto-card__more{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.manifesto-card__more a{font-size:.78rem;font-weight:600;color:var(--green);display:flex;align-items:center;gap:.3rem}
/* CONSTITUENCY */
.constituency-section{background:var(--night)}.constituency-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:start}.ward-map{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl);padding:2rem}.ward-map__title{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem}.ward-map__svg{width:100%;max-width:440px;margin:0 auto;display:block}.ward-map__legend{display:flex;gap:1.5rem;margin-top:1.25rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:rgba(255,255,255,.6)}.legend-dot{width:10px;height:10px;border-radius:50%}
.ward-cards{display:flex;flex-direction:column;gap:1rem}.ward-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-left:4px solid var(--green);border-radius:var(--r);padding:1.25rem;transition:var(--tr);cursor:pointer}.ward-card:hover,.ward-card.active{background:rgba(0,135,81,.12)}.ward-card__hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.ward-card__name{font-weight:700;font-size:.9rem;color:#fff}.ward-card__lga{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}.ward-stats{display:flex;gap:1.5rem}.ward-stat-num{font-family:var(--ff-grotesk);font-size:.95rem;font-weight:700;color:#fff}.ward-stat-label{font-size:.65rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em}
.progress-bar{height:4px;background:rgba(255,255,255,.1);border-radius:2px;margin-top:.75rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--gold));border-radius:2px;transition:width 1.2s ease}
/* COUNTDOWN */
.countdown-section{background:linear-gradient(135deg,var(--forest),var(--deep));position:relative;overflow:hidden}.countdown-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(212,175,55,.08) 0%,transparent 60%)}.countdown-inner{position:relative;z-index:1;text-align:center}.countdown-title{font-family:var(--ff-display);font-size:clamp(1.5rem,2.5vw,2rem);color:#fff;margin-bottom:.5rem}.countdown-sub{color:rgba(255,255,255,.6);margin-bottom:3rem}
.countdown-rings{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;align-items:center}.countdown-unit{display:flex;flex-direction:column;align-items:center;gap:.75rem}.cd-ring-wrap{position:relative;width:120px;height:120px}.cd-ring-svg{transform:rotate(-90deg)}.cd-ring-bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:6}.cd-ring-fill{fill:none;stroke:var(--gold);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.cd-num-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.cd-num{font-family:var(--ff-grotesk);font-size:2rem;font-weight:700;color:#fff;line-height:1}.cd-label{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5)}.cd-sep{font-size:2rem;color:var(--gold);opacity:.4}
.milestones{display:flex;justify-content:center;gap:2rem;margin-top:3rem;flex-wrap:wrap}.milestone{text-align:center;background:rgba(255,255,255,.06);border-radius:var(--r);padding:1rem 1.5rem;border:1px solid rgba(255,255,255,.08)}.milestone-days{font-family:var(--ff-grotesk);font-size:1.5rem;font-weight:700;color:var(--gold)}.milestone-label{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:.25rem;text-transform:uppercase;letter-spacing:.06em}
/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.gallery-item{overflow:hidden;border-radius:var(--r);cursor:pointer;position:relative}.gallery-item.featured{grid-column:span 2;grid-row:span 2}.gallery-item img{width:100%;height:100%;min-height:160px;object-fit:cover;transition:transform .5s ease}.gallery-item:hover img{transform:scale(1.05)}.gallery-item__ov{position:absolute;inset:0;background:rgba(0,30,15,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--tr)}.gallery-item:hover .gallery-item__ov{opacity:1}.gallery-item__ov i{font-size:2rem;color:#fff}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:2000;display:none;align-items:center;justify-content:center;padding:2rem}.lightbox.open{display:flex}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--r)}.lb-close{position:absolute;top:1.5rem;right:1.5rem;color:#fff;font-size:1.5rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);border:none}
/* NEWS */
.news-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:1.5rem}.news-featured{grid-row:span 2}.news-card{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);transition:var(--tr);display:flex;flex-direction:column}.news-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}.news-card img{width:100%;aspect-ratio:16/9;object-fit:cover}.news-featured img{aspect-ratio:4/3}.news-card__body{padding:1.25rem;flex:1;display:flex;flex-direction:column}.news-card__cat{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:.5rem}.news-card__title{font-family:var(--ff-display);font-size:1.05rem;font-weight:700;line-height:1.35;margin-bottom:.5rem;flex:1}.news-featured .news-card__title{font-size:1.35rem}.news-card__date{font-size:.75rem;color:var(--mgray);margin-top:auto;padding-top:.75rem;display:flex;align-items:center;gap:.4rem}
/* MURAL */
.mural-section{background:var(--night);position:relative;overflow:hidden}.mural-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green),var(--gold),var(--green))}.mural-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.mural-feature{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:rgba(255,255,255,.04);border-radius:var(--r);border:1px solid rgba(255,255,255,.06);margin-bottom:.6rem}.mural-feature i{color:var(--gold);font-size:1rem;width:20px}.mural-feature span{font-size:.85rem;color:rgba(255,255,255,.75)}
.mural-tpl{padding:.3rem .7rem;border-radius:var(--r-full);background:rgba(0,135,81,.2);border:1px solid rgba(0,135,81,.4);font-size:.72rem;color:rgba(255,255,255,.7);cursor:pointer;transition:all .2s;margin:.2rem}.mural-tpl:hover,.mural-tpl.active{background:rgba(0,135,81,.5);color:#fff}
.mural-upload-btn{width:100%;padding:.85rem;border:2px dashed rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.5);border-radius:var(--r);font-size:.85rem;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit}.mural-upload-btn:hover{border-color:var(--gold);color:var(--gold)}
/* PLEDGE */
.pledge-section{background:var(--green)}.pledge-wall{display:grid;grid-template-columns:1fr 2fr;gap:3rem;align-items:start}.pledge-stat{background:rgba(0,0,0,.15);border-radius:var(--r);padding:1.25rem;border:1px solid rgba(255,255,255,.1);margin-bottom:1rem}.pledge-stat__num{font-family:var(--ff-grotesk);font-size:2rem;font-weight:700;color:#fff}.pledge-stat__label{font-size:.75rem;color:rgba(255,255,255,.65);margin-top:.25rem;text-transform:uppercase;letter-spacing:.07em}.pledge-bar{height:4px;background:rgba(255,255,255,.15);border-radius:2px;margin-top:.75rem}.pledge-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 1.2s ease}
.pledge-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.pledge-card{background:rgba(0,0,0,.15);border-radius:var(--r-lg);padding:1rem;border:1px solid rgba(255,255,255,.1);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.pledge-card__av{width:44px;height:44px;border-radius:50%;overflow:hidden;border:2px solid var(--gold)}.pledge-card__av img{width:100%;height:100%;object-fit:cover}.pledge-card__name{font-size:.82rem;font-weight:600;color:#fff}.pledge-card__ward{font-size:.68rem;color:rgba(255,255,255,.5)}
/* VOLUNTEER */
.volunteer-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.volunteer-form-card{background:#fff;border-radius:var(--r-xl);padding:2.5rem;box-shadow:var(--sh-lg);border:1px solid var(--border)}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--r);font-size:.9rem;color:var(--text);transition:all .2s;background:#fff;font-family:inherit}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(0,135,81,.1)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-group{display:flex;align-items:flex-start;gap:.7rem;margin-bottom:1.25rem}.checkbox-group input[type=checkbox]{accent-color:var(--green);margin-top:3px;width:16px;height:16px;flex-shrink:0}
.benefit-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.25rem}.benefit-icon{width:48px;height:48px;border-radius:var(--r);background:rgba(0,135,81,.1);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:1.2rem;flex-shrink:0}.benefit-text h4{font-weight:700;margin-bottom:.25rem}.benefit-text p{font-size:.85rem;color:var(--muted);line-height:1.5}
/* LIVE */
.live-btn{position:fixed;top:50%;right:1.5rem;transform:translateY(-50%);z-index:900}.live-circle{width:52px;height:52px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;letter-spacing:.05em;flex-direction:column;gap:1px;box-shadow:0 0 0 4px rgba(192,57,43,.2),0 4px 20px rgba(192,57,43,.4);cursor:pointer;transition:var(--tr);animation:live-p 2s infinite}.live-circle:hover{transform:scale(1.1)}.live-dot{width:6px;height:6px;border-radius:50%;background:#fff}@keyframes live-p{0%,100%{box-shadow:0 0 0 4px rgba(192,57,43,.2),0 4px 20px rgba(192,57,43,.4)}50%{box-shadow:0 0 0 10px rgba(192,57,43,.08),0 4px 24px rgba(192,57,43,.5)}}
.live-panel{position:fixed;top:50%;right:5rem;transform:translateY(-50%);width:320px;background:var(--dark);border:1px solid rgba(255,255,255,.08);border-left:3px solid var(--red);border-radius:var(--r-lg);padding:1.25rem;z-index:890;max-height:70vh;overflow-y:auto;box-shadow:var(--sh-xl);display:none}.live-panel.open{display:block;animation:slideR .3s ease}@keyframes slideR{from{opacity:0;transform:translateY(-50%) translateX(20px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}.live-ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.live-ht{font-size:.8rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:.5rem}.live-dot2{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse-b 1.5s infinite}.live-close{color:rgba(255,255,255,.4);font-size:1.1rem;cursor:pointer;transition:all .2s;background:none;border:none}.live-close:hover{color:#fff}
.live-item{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.06)}.live-item:last-child{border-bottom:none;margin-bottom:0}.live-item__platform{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.2rem}.twitter{color:#1DA1F2}.facebook{color:#4267B2}.whatsapp{color:#25D366}.news{color:var(--gold)}.live-item__text{font-size:.8rem;color:rgba(255,255,255,.7);line-height:1.5}.live-item__time{font-size:.7rem;color:rgba(255,255,255,.3);margin-top:.25rem}
/* AI */
.ai-widget{position:fixed;bottom:2rem;right:2rem;z-index:950}.ai-toggle{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--forest));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;cursor:pointer;box-shadow:0 4px 24px rgba(0,135,81,.5);transition:var(--tr);position:relative}.ai-toggle:hover{transform:scale(1.08)}.ai-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--gold);border-radius:50%;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:var(--dark)}
.ai-panel{position:fixed;bottom:6rem;right:2rem;width:340px;background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh-xl);z-index:940;display:none;overflow:hidden;border:1px solid var(--border)}.ai-panel.open{display:block;animation:slideUp .3s ease}@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.ai-hdr{background:linear-gradient(135deg,var(--forest),var(--green));padding:1.25rem;display:flex;align-items:center;gap:.75rem}.ai-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff}.ai-name{font-weight:700;color:#fff;font-size:.95rem}.ai-status{font-size:.72rem;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:.35rem}.ai-sdot{width:6px;height:6px;border-radius:50%;background:#44FF8A;animation:pulse-b 2s infinite}.ai-close2{margin-left:auto;color:rgba(255,255,255,.6);cursor:pointer;font-size:1rem;transition:all .2s;background:none;border:none}.ai-close2:hover{color:#fff}
.ai-lang-row{display:flex;gap:.4rem;padding:.5rem .75rem 0}.ai-lang-btn{padding:.2rem .6rem;border-radius:var(--r-full);border:1px solid var(--border);font-size:.7rem;cursor:pointer;transition:all .2s;background:#fff;font-family:inherit}.ai-lang-btn.active{background:var(--green);color:#fff;border-color:var(--green)}
.ai-msgs{padding:1rem;height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.ai-msg{max-width:85%}.ai-msg.bot{align-self:flex-start}.ai-msg.user{align-self:flex-end}.ai-bubble{padding:.7rem .9rem;border-radius:12px;font-size:.82rem;line-height:1.55}.ai-msg.bot .ai-bubble{background:var(--lgray);border-bottom-left-radius:4px}.ai-msg.user .ai-bubble{background:var(--green);color:#fff;border-bottom-right-radius:4px}
.ai-qr{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.ai-qr-btn{padding:.3rem .65rem;border-radius:var(--r-full);border:1px solid var(--border);background:#fff;font-size:.72rem;cursor:pointer;transition:all .2s;color:var(--green);font-weight:500;font-family:inherit}.ai-qr-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}
.ai-input-area{padding:.75rem;border-top:1px solid var(--border);background:var(--offwhite)}.ai-input-row{display:flex;gap:.5rem}.ai-input{flex:1;padding:.6rem .9rem;border:1.5px solid var(--border);border-radius:var(--r-full);font-size:.82rem;transition:all .2s;background:#fff;font-family:inherit}.ai-input:focus{outline:none;border-color:var(--green)}.ai-send{width:36px;height:36px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;transition:var(--tr);flex-shrink:0;border:none}.ai-send:hover{background:var(--forest)}
/* FOOTER */
.site-footer{background:var(--night);padding:4rem 0 0}.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}.footer-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.footer-logo img{height:48px}.footer-logo-text .name{font-family:var(--ff-display);font-size:1.1rem;font-weight:900;color:#fff}.footer-logo-text .year{font-size:.62rem;font-weight:700;letter-spacing:.15em;color:var(--gold)}.footer-tagline{font-style:italic;color:rgba(255,255,255,.5);font-size:.85rem;margin-bottom:1.25rem;border-left:2px solid var(--gold);padding-left:.75rem}.footer-socials{display:flex;gap:.6rem;flex-wrap:wrap}.social-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.9rem;transition:var(--tr)}.social-btn:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.footer-col h4{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}.footer-col ul li{margin-bottom:.5rem}.footer-col ul a{font-size:.85rem;color:rgba(255,255,255,.5);transition:all .2s;display:flex;align-items:center;gap:.4rem}.footer-col ul a:hover{color:#fff;padding-left:.4rem}
.newsletter-input{flex:1;padding:.55rem .9rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-full);color:#fff;font-size:.82rem;font-family:inherit}.newsletter-input::placeholder{color:rgba(255,255,255,.3)}.newsletter-input:focus{outline:none;border-color:var(--green)}.newsletter-btn{padding:.55rem 1.1rem;background:var(--green);color:#fff;border-radius:var(--r-full);font-size:.8rem;font-weight:600;cursor:pointer;border:none;font-family:inherit}.newsletter-form{display:flex;gap:.5rem;margin-top:.75rem}
.footer-bottom{padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-legal{font-size:.75rem;color:rgba(255,255,255,.3)}.footer-legal a{color:rgba(255,255,255,.4)}.footer-legal a:hover{color:#fff}.apc-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:rgba(0,135,81,.2);border-radius:var(--r-full);border:1px solid rgba(0,135,81,.3);font-size:.72rem;color:rgba(255,255,255,.4)}
/* PAGE HERO */
.page-hero{background:linear-gradient(135deg,var(--night),var(--forest));padding:7rem 0 4rem;text-align:center;position:relative;overflow:hidden}.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23008751' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}.page-hero h1{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3.5rem);color:#fff;font-weight:900;margin-bottom:.75rem;position:relative;z-index:1}.page-hero p{color:rgba(255,255,255,.7);font-size:1.1rem;position:relative;z-index:1;max-width:600px;margin:0 auto}.breadcrumb{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:1.25rem;position:relative;z-index:1}.breadcrumb a,.breadcrumb span{font-size:.78rem;color:rgba(255,255,255,.5)}.breadcrumb a:hover{color:#fff}.breadcrumb .sep{color:rgba(255,255,255,.25)}.breadcrumb .current{color:var(--gold);font-weight:600}
/* DASHBOARD */
.dash-layout{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 120px)}.dash-sidebar{background:var(--night);padding:1.5rem}.dash-nav{display:flex;flex-direction:column;gap:.25rem;margin-top:1.5rem}.dash-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--r);font-size:.85rem;font-weight:500;color:rgba(255,255,255,.6);transition:all .2s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit}.dash-nav-item:hover,.dash-nav-item.active{background:rgba(0,135,81,.2);color:#fff}.dash-nav-item.active{border-left:3px solid var(--green)}.dash-nav-item i{width:16px}
.dash-main{padding:2rem;background:var(--offwhite)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.kpi-card{background:#fff;border-radius:var(--r-lg);padding:1.5rem;border:1px solid var(--border)}.kpi-label{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem}.kpi-num{font-family:var(--ff-grotesk);font-size:2rem;font-weight:700;color:var(--dark);line-height:1;margin-bottom:.5rem}.kpi-change{font-size:.78rem;display:flex;align-items:center;gap:.3rem}.kpi-change.up{color:var(--green)}.kpi-change.down{color:var(--red)}.kpi-icon{float:right;font-size:1.5rem;color:var(--green);opacity:.2}
/* E-GUARD */
.eguard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem}.eguard-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);padding:1.75rem;transition:var(--tr)}.eguard-card:hover{box-shadow:var(--sh)}.eguard-card__icon{font-size:2rem;color:var(--green);margin-bottom:1rem}.incident-feed{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.incident-item{background:rgba(255,255,255,.04);border-radius:var(--r);padding:1rem;border-left:3px solid var(--green)}.incident-item.alert{border-left-color:var(--red)}.incident-item.info{border-left-color:var(--gold)}.incident-time{font-size:.7rem;color:rgba(255,255,255,.4);margin-bottom:.3rem}.incident-text{font-size:.82rem;color:rgba(255,255,255,.75)}.incident-loc{font-size:.72rem;color:var(--green);margin-top:.25rem;display:flex;align-items:center;gap:.3rem}
/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate-fade-up{animation:fadeInUp .7s ease both}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--lgray)}::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}
/* RESPONSIVE */
@media(max-width:1100px){.manifesto-grid{grid-template-columns:repeat(2,1fr)}.news-grid{grid-template-columns:1fr 1fr}.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:900px){:root{--hh:64px}.nav-links{display:none}.hamburger{display:flex}.hero__content{grid-template-columns:1fr;text-align:center}.hero__img-col{display:none}.hero__ctas{justify-content:center}.hero__stats{justify-content:center}.about-grid{grid-template-columns:1fr}.constituency-grid{grid-template-columns:1fr}.mural-grid{grid-template-columns:1fr}.pledge-wall{grid-template-columns:1fr}.volunteer-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-layout{grid-template-columns:1fr}.dash-sidebar{display:none}.eguard-grid{grid-template-columns:1fr 1fr}.stats-bar .container{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.gallery-grid{grid-template-columns:1fr 1fr}.gallery-item.featured{grid-column:span 2}.news-grid{grid-template-columns:1fr}.manifesto-grid{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr}.eguard-grid{grid-template-columns:1fr}.pledge-cards{grid-template-columns:1fr 1fr}.achieve-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.utility-bar__left{display:none}.live-btn{right:.75rem}.ai-panel{width:calc(100vw - 2rem);right:1rem}.live-panel{width:calc(100vw - 2rem);right:unset;left:1rem}.cd-ring-wrap{width:85px;height:85px}.cd-num{font-size:1.5rem}}

