/* =======================================================================
   SIGHTS & SOUNDS OF RENEWED HOPE — Master stylesheet (style.css)
   Design system: deep Nigerian green, lime, cream, gold, red.
   Used by index.html, dashboard.html, map.html, election.html.
   ======================================================================= */
:root{
  --green-900:#073D1E; --green-800:#0A5429; --green-700:#0B6E33; --green-500:#13913F;
  --lime:#6FBE44; --lime-soft:#A7D88A; --cream:#F6F4EC; --paper:#FBFAF5;
  --ink:#11160F; --muted:#5C6657; --line:#E2DFD2; --gold:#C9A227; --red:#C8102E;
  --silver:#b9c2bd; --dark-bg:#06160C; --dark-card:#0c2417; --dark-line:rgba(111,190,68,.18);
  --shadow:0 10px 40px rgba(7,61,30,.10); --maxw:1180px;
  --spacing-xs:6px; --spacing-sm:10px; --spacing-md:16px; --spacing-lg:24px;
  --spacing-xl:36px; --spacing-2xl:56px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;line-height:1.05;letter-spacing:-.01em}
.serif{font-family:'Fraunces',serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:'Archivo';text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:700;color:var(--green-500)}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Archivo';font-weight:700;font-size:.86rem;padding:10px 18px;border-radius:999px;background:var(--green-700);color:#fff;transition:.18s;border:none;cursor:pointer}
.btn:hover{background:var(--green-900);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--green-700);border:1.5px solid var(--green-700)}
.btn.ghost:hover{background:var(--green-700);color:#fff}
.btn.lime{background:var(--lime);color:var(--green-900)}.btn.lime:hover{background:#fff}
.btn.line{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn.line:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn.subtle{background:var(--cream);color:var(--green-900)}.btn.subtle:hover{background:var(--line)}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(251,250,245,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Archivo';font-weight:900;font-size:1.02rem;letter-spacing:-.02em}
.brand img.logo-mark{height:46px;width:auto;flex:none;filter:drop-shadow(0 2px 4px rgba(7,61,30,.18))}
.brand small{display:block;font-family:'Inter';font-weight:500;font-size:.62rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
nav .links{display:flex;gap:22px;align-items:center}
nav .links a{font-weight:600;font-size:.86rem;color:var(--muted)}
nav .links a:hover{color:var(--green-700)}
.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--green-700)}
/* live clock pill */
.clock{display:inline-flex;align-items:center;gap:8px;font-family:'Archivo';font-weight:700;font-size:.72rem;color:var(--green-700);background:rgba(111,190,68,.12);border:1px solid rgba(111,190,68,.25);padding:6px 12px;border-radius:999px;white-space:nowrap}
.clock .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(111,190,68,.6);animation:cpulse 2s infinite}
@keyframes cpulse{0%{box-shadow:0 0 0 0 rgba(111,190,68,.5)}70%{box-shadow:0 0 0 7px rgba(111,190,68,0)}100%{box-shadow:0 0 0 0 rgba(111,190,68,0)}}

/* ---------- HERO ---------- */
.hero{position:relative;background:var(--green-900);color:#fff;overflow:hidden;padding:74px 0 96px}
.hero:before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 500px at 85% -10%,rgba(111,190,68,.30),transparent 60%),
  radial-gradient(700px 500px at 0% 110%,rgba(19,145,63,.4),transparent 60%);}
.hero:after{content:"";position:absolute;inset:0;opacity:.06;background-image:
  linear-gradient(rgba(167,216,138,.6) 1px,transparent 1px),
  linear-gradient(90deg,rgba(167,216,138,.6) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(circle at 30% 40%,#000,transparent 70%);mask-image:radial-gradient(circle at 30% 40%,#000,transparent 70%)}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.flagline{display:flex;gap:3px;margin-bottom:24px}
.flagline i{height:5px;border-radius:3px;display:block}
.flagline i:nth-child(odd){background:var(--lime);width:34px}
.flagline i:nth-child(even){background:#fff;width:18px;opacity:.55}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.4rem);font-weight:900;letter-spacing:-.025em}
.hero h1 .accent{color:var(--lime)}
.hero h1 .out{-webkit-text-stroke:2px var(--lime-soft);color:transparent}
.hero p.lead{margin-top:20px;font-size:1.12rem;max-width:36ch;color:rgba(255,255,255,.85)}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.trust{margin-top:34px;padding-top:22px;border-top:1px solid rgba(255,255,255,.16);display:flex;gap:30px;flex-wrap:wrap}
.trust div{font-size:.78rem;color:rgba(255,255,255,.7)}
.trust b{display:block;font-family:'Archivo';font-weight:800;font-size:1.5rem;color:#fff;letter-spacing:-.02em}
.hero-logo{position:relative;display:flex;flex-direction:column;align-items:center}
.hero-logo .glow{position:absolute;top:-10px;width:78%;height:60%;border-radius:50%;background:radial-gradient(circle,rgba(111,190,68,.28),transparent 65%);filter:blur(20px)}
.hero-logo>img{position:relative;width:100%;max-width:420px;filter:drop-shadow(0 24px 50px rgba(0,0,0,.45))}

/* mirror / audio player */
.mirror{position:relative;margin-top:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:8px;box-shadow:0 20px 50px rgba(0,0,0,.3);width:100%;max-width:460px}
.mirror-head{display:flex;gap:6px;padding:10px 12px 4px}
.mtab{flex:1;text-align:center;font-family:'Archivo';font-weight:700;font-size:.8rem;padding:9px;border-radius:11px;cursor:pointer;color:rgba(255,255,255,.6);transition:.2s;border:1px solid transparent}
.mtab.active{background:#fff;color:var(--green-900)}
.mtab[data-tab="hear"].active{background:var(--lime);color:var(--green-900)}
.mirror-body{background:#0a3019;border-radius:14px;padding:18px}
.panel{display:none}.panel.show{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.see-img{height:120px;border-radius:11px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:12px;background:#0a3019}
.see-img.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.see-img.photo:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,61,30,.85),transparent 60%);z-index:1}
.see-cap{position:relative;z-index:2;font-family:'Archivo';font-weight:800;color:#fff;font-size:.92rem;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.see-meta{margin-top:12px;display:flex;justify-content:space-between;font-size:.78rem;color:rgba(255,255,255,.7)}
.see-meta b{color:var(--lime)}
.wave{display:flex;align-items:center;gap:3px;height:42px;margin:2px 0 8px}
.wave i{flex:1;background:var(--lime);border-radius:3px;animation:eq 1.1s ease-in-out infinite;opacity:.85}
.wave.paused i{animation-play-state:paused;height:30%!important;opacity:.4}
@keyframes eq{0%,100%{height:18%}50%{height:100%}}
.player{display:flex;align-items:center;gap:14px}
.player-main{flex:1;min-width:0}
.play{flex:none;width:46px;height:46px;border-radius:50%;background:var(--lime);display:grid;place-items:center;color:var(--green-900);font-size:1rem;cursor:pointer;transition:.15s;border:none;font-family:inherit}
.play:hover{transform:scale(1.06);background:#fff}
.seek{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:999px;background:rgba(255,255,255,.18);outline:none;cursor:pointer}
.seek::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--lime);cursor:pointer;border:2px solid #0a3019}
.seek::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--lime);cursor:pointer;border:2px solid #0a3019}
.player-meta{display:flex;justify-content:space-between;font-size:.7rem;color:rgba(255,255,255,.6);margin-top:6px;font-variant-numeric:tabular-nums}
.quote{font-family:'Fraunces',serif;font-size:1rem;color:#fff;font-style:italic;margin-top:12px}
.quote-by{margin-top:8px;font-size:.78rem;color:var(--lime);font-weight:600}

/* scroll indicator */
.scroll-ind{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;animation:bob 2.4s ease-in-out infinite}
.scroll-ind .ssrh-mark{width:42px;height:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.4))}
.scroll-ind span{font-family:'Archivo';font-weight:700;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--lime-soft)}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@media (prefers-reduced-motion:reduce){.scroll-ind{animation:none}.wave i{animation:none}.clock .dot{animation:none}}

/* ticker */
.ticker{background:var(--lime);color:var(--green-900);overflow:hidden;white-space:nowrap;border-top:3px solid var(--green-900)}
.ticker .run{display:inline-block;padding:11px 0;font-family:'Archivo';font-weight:800;font-size:.9rem;letter-spacing:.02em;animation:scroll 38s linear infinite}
.ticker .run span{margin:0 26px}.ticker .run b{color:var(--green-700)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* section shells */
section.block{padding:84px 0}
.sec-head{max-width:64ch;margin-bottom:42px}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:800;margin-top:12px;color:var(--green-900)}
.sec-head p{margin-top:14px;color:var(--muted);font-size:1.05rem}
.mission{background:var(--cream)}
.mcards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px}
.mcard .ic{width:44px;height:44px;border-radius:11px;background:var(--green-700);color:#fff;display:grid;place-items:center;font-size:1.1rem;margin-bottom:14px}
.mcard h3{font-size:1.12rem;color:var(--green-900)}
.mcard p{margin-top:8px;color:var(--muted);font-size:.92rem}
.proof-band{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:30px}
.proof-band figure{position:relative;border-radius:13px;overflow:hidden;aspect-ratio:4/3;margin:0}
.proof-band img{width:100%;height:100%;object-fit:cover;transition:.4s}
.proof-band figure:hover img{transform:scale(1.06)}
.proof-band figcaption{position:absolute;left:0;right:0;bottom:0;padding:10px;background:linear-gradient(to top,rgba(7,61,30,.9),transparent);color:#fff;font-size:.72rem;font-family:'Archivo';font-weight:600;z-index:1}

/* compendium */
.compendium{background:#fff}
.comp-list{display:grid;gap:14px}
.comp{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--paper);transition:.2s}
.comp.open{box-shadow:var(--shadow);border-color:var(--lime-soft)}
.comp-head{display:flex;align-items:center;gap:18px;padding:20px 22px;cursor:pointer;user-select:none}
.comp-head .cnum{font-family:'Archivo';font-weight:900;font-size:1.5rem;color:#fff;background:var(--green-700);width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:none}
.comp.open .cnum{background:var(--lime);color:var(--green-900)}
.comp-head .ctitle{flex:1}.comp-head .ctitle h3{font-size:1.16rem;color:var(--green-900)}
.comp-head .ctitle p{font-size:.84rem;color:var(--muted);margin-top:2px}
.comp-head .chev{font-size:1.1rem;color:var(--green-500);transition:transform .25s;flex:none}
.comp.open .chev{transform:rotate(180deg)}
.comp-body{max-height:0;overflow:hidden;transition:max-height .4s ease}
.comp-inner{padding:4px 22px 24px}
.comp-photo-wrap{position:relative;border-radius:13px;overflow:hidden;margin-bottom:18px}
.comp-photo{width:100%;height:220px;object-fit:cover;display:block}
.comp-photo-wrap .cap{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;background:linear-gradient(to top,rgba(7,61,30,.88),transparent);color:#fff;font-size:.8rem;font-family:'Archivo';font-weight:600;z-index:1}
.comp-photo-wrap .src-pill{position:absolute;top:10px;right:10px;background:rgba(7,61,30,.7);color:#fff;font-size:.62rem;padding:4px 9px;border-radius:999px;letter-spacing:.04em}
.delta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:18px}
.delta{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px}
.delta .dl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.delta .dv{font-family:'Archivo';font-weight:900;font-size:1.5rem;color:var(--green-900);margin:6px 0 2px;letter-spacing:-.02em}
.delta .dv .lime{color:var(--green-500)}
.delta .dfrom{font-size:.76rem;color:var(--muted)}
.delta .dbar{height:6px;border-radius:999px;background:var(--line);margin-top:10px;overflow:hidden}
.delta .dfill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green-500),var(--lime));width:0;transition:width 1s ease}
.comp-ss{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.comp-ss .ss{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:.86rem}
.comp-ss .tag{font-family:'Archivo';font-weight:800;font-size:.6rem;letter-spacing:.08em;padding:3px 8px;border-radius:6px;flex:none;margin-top:1px}
.comp-ss .ss.see .tag{background:var(--green-700);color:#fff}
.comp-ss .ss.hear .tag{background:var(--lime);color:var(--green-900)}
.comp-ss .ss span{color:var(--muted)}
.comp-src{font-size:.7rem;color:#8a9483;margin-top:14px}

/* phases + calendar */
.phases{background:var(--green-900);color:#fff}
.phases .sec-head h2{color:#fff}.phases .sec-head p{color:rgba(255,255,255,.78)}
.ptrack{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:34px}
.phase{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:28px}
.phase .ph-tag{display:inline-block;font-family:'Archivo';font-weight:800;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:999px;background:var(--lime);color:var(--green-900)}
.phase h3{font-size:1.4rem;margin:14px 0 4px}
.phase .dates{color:var(--lime);font-weight:600;font-size:.86rem;margin-bottom:14px}
.phase ul{list-style:none;display:grid;gap:9px}
.phase li{padding-left:24px;position:relative;font-size:.92rem;color:rgba(255,255,255,.85)}
.phase li:before{content:"";position:absolute;left:0;top:8px;width:9px;height:9px;border-radius:50%;background:var(--lime)}
.cal-title{font-family:'Archivo';font-weight:800;font-size:1.1rem;margin-bottom:16px;color:#fff;display:flex;align-items:center;gap:10px}
.cal{display:grid;gap:10px}
.cal-row{display:grid;grid-template-columns:128px 1fr;gap:16px;align-items:start;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:13px;padding:14px 18px}
.cal-month{font-family:'Archivo';font-weight:800;font-size:.82rem;color:var(--lime);letter-spacing:.04em;padding-top:3px}
.cal-acts{display:flex;flex-wrap:wrap;gap:8px}
.cal-act{font-size:.8rem;background:rgba(111,190,68,.12);border:1px solid rgba(111,190,68,.3);color:#EAF3EC;border-radius:8px;padding:6px 11px}
.cal-act b{color:var(--lime);font-weight:700}
.ph-pill{display:inline-block;font-size:.66rem;font-family:'Archivo';font-weight:800;letter-spacing:.08em;padding:3px 9px;border-radius:999px;margin-bottom:14px}
.ph-pill.p1{background:var(--lime-soft);color:var(--green-900)}
.ph-pill.p2{background:var(--gold);color:#3a2e00}

/* feature cards (links to map / dashboard / election) */
.features{background:var(--paper)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{position:relative;border-radius:18px;overflow:hidden;min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;border:1px solid var(--line)}
.feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.feat:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,61,30,.94),rgba(7,61,30,.35) 70%);z-index:1}
.feat>*{position:relative;z-index:2}
.feat .fic{font-size:1.6rem;margin-bottom:auto}
.feat h3{font-size:1.25rem;margin-bottom:6px}
.feat p{font-size:.86rem;color:rgba(255,255,255,.82)}
.feat .go{margin-top:14px;font-family:'Archivo';font-weight:700;font-size:.82rem;color:var(--lime)}
.feat:hover img{transform:scale(1.05);transition:.5s}

/* engage */
.engage{background:var(--cream)}
.eg-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.roles{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.role{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px}
.role b{font-family:'Archivo';display:block;color:var(--green-900);margin-bottom:3px}
.role span{font-size:.85rem;color:var(--muted)}
.engage-photo{width:100%;border-radius:16px;aspect-ratio:16/11;object-fit:cover;box-shadow:var(--shadow)}
.form{background:var(--green-900);border-radius:20px;padding:30px;color:#fff}
.form h3{font-size:1.3rem}
.form label{display:block;font-size:.8rem;font-weight:600;margin:16px 0 6px;color:rgba(255,255,255,.8)}
.form input,.form select{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-family:inherit;font-size:.92rem}
.form input::placeholder{color:rgba(255,255,255,.5)}
.consent-line{display:flex;gap:10px;align-items:flex-start;margin-top:16px;font-size:.78rem;color:rgba(255,255,255,.72)}
.consent-line a{color:var(--lime);text-decoration:underline}
.form .btn.lime{width:100%;justify-content:center;margin-top:18px}
.form-note{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:10px;text-align:center}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:60px 0 26px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
footer h4{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px;font-family:'Archivo'}
footer a{display:block;font-size:.88rem;margin-bottom:9px;color:rgba(255,255,255,.65)}
footer a:hover{color:var(--lime)}
.fbrand .brand img.logo-mark{height:52px}
.fbrand p{font-size:.88rem;margin-top:14px;max-width:34ch}
.fbar{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.78rem}
.nonpartisan{display:inline-block;margin-top:14px;font-size:.7rem;border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:999px;color:rgba(255,255,255,.6)}

/* cookie / consent */
.cookie{position:fixed;left:0;right:0;bottom:0;z-index:90;padding:16px;display:none}
.cookie.show{display:block;animation:up .4s ease}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
.cookie-card{max-width:var(--maxw);margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.22);padding:22px 24px;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}
.cookie-card h4{font-size:1.05rem;color:var(--green-900)}
.cookie-card p{font-size:.86rem;color:var(--muted);margin-top:6px;max-width:70ch}
.cookie-card p a{color:var(--green-700);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.cookie-actions .btn{font-size:.82rem}
.modal{position:fixed;inset:0;z-index:100;background:rgba(7,61,30,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-card{background:#fff;border-radius:20px;max-width:560px;width:100%;max-height:88vh;overflow:auto;padding:30px}
.modal-card h3{color:var(--green-900);font-size:1.4rem}.modal-card>p{color:var(--muted);font-size:.9rem;margin-top:8px}
.pref{border:1px solid var(--line);border-radius:13px;padding:16px;margin-top:14px;display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.pref b{font-family:'Archivo';color:var(--green-900);font-size:.96rem}
.pref small{display:block;color:var(--muted);font-size:.82rem;margin-top:4px}
.switch{position:relative;width:46px;height:26px;flex:none;margin-top:2px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:var(--line);border-radius:999px;cursor:pointer;transition:.2s}
.slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked+.slider{background:var(--green-500)}
.switch input:checked+.slider:before{transform:translateX(20px)}
.switch input:disabled+.slider{background:var(--green-700);opacity:.55;cursor:not-allowed}
.modal-actions{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.cookie-fab{position:fixed;left:18px;bottom:18px;z-index:60;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 14px;font-size:.78rem;font-weight:600;color:var(--green-700);box-shadow:var(--shadow);cursor:pointer;display:none;align-items:center;gap:7px}
.cookie-fab.show{display:inline-flex}

/* =====================================================================
   DASHBOARD (dark theme)
   ===================================================================== */
body.dashboard{background:var(--dark-bg);color:#e9f1ea}
.dashboard-container{max-width:1220px;margin:0 auto;padding:0 24px}
.dashboard-header{display:flex;align-items:center;justify-content:space-between}
.dashboard-header-left{display:flex;align-items:center;gap:18px}
.back-link{color:var(--lime);font-weight:600;font-size:.86rem}
.live-indicator{display:flex;align-items:center;gap:8px;font-family:'Archivo';font-weight:700;font-size:.74rem;color:var(--lime);letter-spacing:.04em}
.pulse-dot{width:9px;height:9px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(111,190,68,.6);animation:cpulse 2s infinite}
.dashboard-hero{padding:46px 0 28px}
.dashboard-hero h1{font-size:clamp(2rem,4vw,3rem);color:#fff}
.dashboard-hero p{color:rgba(233,241,234,.7);margin-top:10px;font-size:1.02rem}
.filter-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.chip{font-family:'Archivo';font-weight:700;font-size:.78rem;padding:9px 16px;border-radius:999px;border:1px solid var(--dark-line);background:transparent;color:rgba(233,241,234,.75);cursor:pointer;transition:.18s}
.chip:hover{border-color:var(--lime);color:#fff}
.chip.active{background:var(--lime);color:var(--green-900);border-color:var(--lime)}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:18px 0 40px}
.kpi-card{background:var(--dark-card);border:1px solid var(--dark-line);border-radius:16px;padding:22px}
.kpi-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(233,241,234,.6);font-weight:600}
.kpi-value{font-family:'Archivo';font-weight:900;font-size:2.2rem;color:#fff;margin:8px 0 4px;letter-spacing:-.02em}
.kpi-badge{font-size:.76rem;color:var(--lime);font-weight:600}
.priority-section{background:var(--dark-card);border:1px solid var(--dark-line);border-radius:18px;padding:28px;margin-bottom:22px;transition:opacity .3s}
.priority-section.dimmed{opacity:.28}
.priority-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.priority-badge-large{width:46px;height:46px;border-radius:12px;background:var(--lime);color:var(--green-900);font-family:'Archivo';font-weight:900;font-size:1.4rem;display:grid;place-items:center;flex:none}
.priority-header h3{color:#fff;font-size:1.2rem}
.priority-body{display:grid;grid-template-columns:1.6fr .9fr;gap:26px;align-items:start}
.priority-description{color:rgba(233,241,234,.72);font-size:.95rem;margin-bottom:18px}
.priority-metrics{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.metric-item{background:rgba(255,255,255,.03);border:1px solid var(--dark-line);border-radius:12px;padding:14px}
.metric-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(233,241,234,.55);font-weight:600;margin-bottom:8px}
.metric-before{font-size:.8rem;color:rgba(233,241,234,.45);text-decoration:line-through}
.metric-after{font-family:'Archivo';font-weight:900;font-size:1.3rem;color:var(--lime);margin:2px 0 8px}
.progress-bar{height:6px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green-500),var(--lime));width:0;transition:width 1.1s ease}
.chart-container{background:rgba(255,255,255,.02);border:1px solid var(--dark-line);border-radius:12px;padding:14px;margin-bottom:14px}
.evidence-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.evidence-item{background:rgba(111,190,68,.08);border:1px solid rgba(111,190,68,.2);border-radius:10px;padding:12px 14px;font-size:.84rem;color:rgba(233,241,234,.85)}
.evidence-item strong{color:var(--lime)}
.priority-image{border-radius:14px;overflow:hidden;position:relative;min-height:200px;background:#0a3019}
.priority-image img{width:100%;height:100%;min-height:200px;object-fit:cover}
.photo-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory}
.scroll-img{flex:none;width:300px;scroll-snap-align:start;border-radius:14px;overflow:hidden;aspect-ratio:3/2;border:1px solid var(--dark-line)}
.scroll-img img{width:100%;height:100%;object-fit:cover}
.dash-section-title{color:var(--lime);font-size:1.4rem;margin-bottom:6px}
.dash-story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.dash-story{background:var(--dark-card);border:1px solid var(--dark-line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.dash-story.playing{outline:2px solid var(--lime)}
.dash-story .svis{position:relative;height:150px;overflow:hidden;background:#0a3019}
.dash-story .svis img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.dash-story .svis:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,61,30,.85),transparent 60%)}
.dash-story .svis .scap{position:absolute;left:12px;bottom:10px;z-index:2;color:#fff;font-family:'Archivo';font-weight:800;font-size:.9rem;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.dash-story .sbody{padding:16px;flex:1;display:flex;flex-direction:column}
.dash-story .stag{font-family:'Archivo';font-weight:700;font-size:.62rem;letter-spacing:.08em;color:var(--lime);text-transform:uppercase}
.dash-story .sq{font-family:'Fraunces',serif;font-style:italic;color:#e9f1ea;font-size:.95rem;margin:8px 0}
.dash-story .sby{font-size:.78rem;color:rgba(233,241,234,.55)}
.dash-story .listen{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:.76rem;color:var(--lime);font-weight:600;background:none;border:none;font-family:inherit;cursor:pointer;padding:0;text-align:left}
.dash-story .listen:hover{color:#fff}
.dash-story .listen .ic{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:var(--lime);color:#062b13;font-size:.55rem;flex:none}
.dash-credit{margin-top:30px;padding:18px 20px;background:rgba(201,162,39,.08);border:1px solid rgba(201,162,39,.25);border-radius:14px;font-size:.84rem;color:rgba(233,241,234,.8)}
.dash-credit strong{color:var(--gold)}

/* =====================================================================
   NIGERIA MAP (interactive SVG)
   ===================================================================== */
.mapwrap{background:var(--green-900);color:#fff;border-radius:22px;padding:26px;display:grid;grid-template-columns:1.4fr 1fr;gap:26px;align-items:start}
.map-stage{position:relative;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:10px;min-height:420px}
.map-stage svg{width:100%;height:auto;display:block}
.ng-state{fill:rgba(111,190,68,.22);stroke:#0a3019;stroke-width:1.2;cursor:pointer;transition:fill .18s,transform .18s;transform-origin:center}
.ng-state:hover{fill:var(--lime)}
.ng-state.active{fill:var(--gold)}
.ng-dot{cursor:pointer}
.map-side{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:22px;min-height:420px}
.map-side h3{color:#fff;font-size:1.3rem}
.map-side .zone-tag{display:inline-block;font-size:.68rem;font-family:'Archivo';font-weight:800;letter-spacing:.06em;padding:4px 10px;border-radius:999px;background:var(--lime);color:var(--green-900);margin:8px 0}
.map-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}
.map-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:11px;padding:12px}
.map-stat b{display:block;font-family:'Archivo';font-weight:900;font-size:1.3rem;color:var(--lime)}
.map-stat span{font-size:.72rem;color:rgba(255,255,255,.65)}
.map-lga-list{margin-top:8px;max-height:200px;overflow:auto;display:flex;flex-wrap:wrap;gap:6px}
.map-lga{font-size:.72rem;background:rgba(111,190,68,.12);border:1px solid rgba(111,190,68,.25);border-radius:7px;padding:4px 9px;color:#EAF3EC}
.map-hint{color:rgba(255,255,255,.55);font-size:.82rem}
.map-tooltip{position:fixed;pointer-events:none;background:#fff;color:var(--green-900);font-family:'Archivo';font-weight:700;font-size:.74rem;padding:5px 10px;border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,.25);z-index:200;opacity:0;transition:opacity .12s;white-space:nowrap}
.map-tooltip.show{opacity:1}

/* =====================================================================
   CHATBOT
   ===================================================================== */
.chat-fab{position:fixed;right:20px;bottom:20px;z-index:120;width:60px;height:60px;border-radius:50%;background:var(--green-700);color:#fff;border:none;cursor:pointer;box-shadow:0 10px 30px rgba(7,61,30,.4);display:grid;place-items:center;font-size:1.5rem;transition:.2s}
.chat-fab:hover{background:var(--green-900);transform:scale(1.06)}
.chat-panel{position:fixed;right:20px;bottom:90px;z-index:121;width:370px;max-width:calc(100vw - 40px);height:540px;max-height:calc(100vh - 130px);background:#fff;border-radius:20px;box-shadow:0 24px 70px rgba(0,0,0,.3);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--line)}
.chat-panel.open{display:flex;animation:up .3s ease}
.chat-head{background:var(--green-900);color:#fff;padding:16px 18px;display:flex;align-items:center;gap:12px}
.chat-head img{height:34px}
.chat-head .ct{flex:1}
.chat-head .ct b{font-family:'Archivo';font-size:.95rem;display:block}
.chat-head .ct span{font-size:.7rem;color:var(--lime-soft)}
.chat-head .cclose{background:none;border:none;color:#fff;font-size:1.3rem;cursor:pointer;opacity:.8}
.chat-body{flex:1;overflow-y:auto;padding:16px;background:var(--cream);display:flex;flex-direction:column;gap:12px}
.chat-msg{max-width:84%;padding:11px 14px;border-radius:14px;font-size:.88rem;line-height:1.5}
.chat-msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:var(--green-700);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-msg.bot b{color:var(--green-700)}
.chat-suggest{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 12px;background:var(--cream)}
.chat-chip{font-size:.74rem;background:#fff;border:1px solid var(--lime-soft);color:var(--green-700);border-radius:999px;padding:7px 12px;cursor:pointer;font-weight:600}
.chat-chip:hover{background:var(--lime);color:var(--green-900);border-color:var(--lime)}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 16px;font-family:inherit;font-size:.88rem;outline:none}
.chat-input input:focus{border-color:var(--lime)}
.chat-input button{background:var(--green-700);color:#fff;border:none;border-radius:50%;width:42px;height:42px;cursor:pointer;font-size:1rem;flex:none}
.chat-typing{display:flex;gap:4px;padding:11px 14px;align-self:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px}
.chat-typing i{width:7px;height:7px;border-radius:50%;background:var(--lime);animation:typ 1.2s infinite}
.chat-typing i:nth-child(2){animation-delay:.2s}.chat-typing i:nth-child(3){animation-delay:.4s}
@keyframes typ{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* =====================================================================
   ELECTION TOOL
   ===================================================================== */
.el-shell{max-width:1220px;margin:0 auto;padding:0 24px}
.el-hero{padding:40px 0 24px}
.el-hero h1{font-size:clamp(2rem,4vw,2.8rem);color:#fff}
.el-hero p{color:rgba(233,241,234,.72);margin-top:10px}
.el-demo-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,162,39,.14);border:1px solid rgba(201,162,39,.4);color:var(--gold);font-family:'Archivo';font-weight:700;font-size:.74rem;padding:7px 14px;border-radius:999px;margin-top:14px}
.el-tabs{display:flex;gap:8px;margin:24px 0;flex-wrap:wrap}
.el-tab{font-family:'Archivo';font-weight:700;font-size:.82rem;padding:11px 20px;border-radius:12px;border:1px solid var(--dark-line);background:transparent;color:rgba(233,241,234,.75);cursor:pointer;transition:.18s}
.el-tab.active{background:var(--lime);color:var(--green-900);border-color:var(--lime)}
.el-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:26px}
.el-sum-card{background:var(--dark-card);border:1px solid var(--dark-line);border-radius:14px;padding:18px}
.el-sum-card .v{font-family:'Archivo';font-weight:900;font-size:1.7rem;color:var(--lime)}
.el-sum-card .l{font-size:.72rem;color:rgba(233,241,234,.6);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
.el-panel{background:var(--dark-card);border:1px solid var(--dark-line);border-radius:18px;padding:24px;margin-bottom:22px}
.el-panel h3{color:#fff;margin-bottom:16px;font-size:1.15rem}
.el-drill{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.el-select label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(233,241,234,.6);font-weight:600;margin-bottom:6px}
.el-select select{width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--dark-line);background:#06160c;color:#e9f1ea;font-family:inherit;font-size:.86rem;cursor:pointer}
.el-breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.8rem;color:rgba(233,241,234,.7);margin-bottom:16px}
.el-breadcrumb b{color:var(--lime)}
.el-results-table{width:100%;border-collapse:collapse;font-size:.86rem}
.el-results-table th{text-align:left;padding:10px 12px;color:rgba(233,241,234,.6);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--dark-line)}
.el-results-table td{padding:11px 12px;border-bottom:1px solid rgba(255,255,255,.05)}
.el-party{display:inline-flex;align-items:center;gap:8px;font-weight:600}
.el-party .swatch{width:12px;height:12px;border-radius:3px;flex:none}
.el-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;min-width:120px}
.el-bar i{display:block;height:100%;border-radius:999px}
.el-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.el-field label{display:block;font-size:.74rem;color:rgba(233,241,234,.7);font-weight:600;margin-bottom:6px}
.el-field input,.el-field select,.el-field textarea{width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--dark-line);background:#06160c;color:#e9f1ea;font-family:inherit;font-size:.88rem}
.el-field.full{grid-column:1/-1}
.el-incident{background:rgba(200,16,46,.08);border:1px solid rgba(200,16,46,.3);border-radius:12px;padding:14px;margin-bottom:10px}
.el-incident .sev{font-family:'Archivo';font-weight:800;font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;padding:3px 9px;border-radius:999px;display:inline-block}
.el-incident .sev.high{background:var(--red);color:#fff}
.el-incident .sev.med{background:var(--gold);color:#3a2e00}
.el-incident .sev.low{background:var(--lime);color:var(--green-900)}
.el-log{max-height:300px;overflow:auto}
.el-feed-item{display:flex;gap:12px;padding:12px;border:1px solid var(--dark-line);border-radius:12px;margin-bottom:8px;font-size:.84rem;color:rgba(233,241,234,.85)}
.el-feed-item .tm{color:var(--lime);font-family:'Archivo';font-weight:700;font-size:.72rem;flex:none}
.el-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.el-note{font-size:.78rem;color:rgba(233,241,234,.55);margin-top:8px}

/* responsive */
@media(max-width:980px){
  .hero-grid,.eg-grid,.ptrack,.mcards,.fgrid,.feat-grid,.priority-body,.kpi-row,.el-chart-grid,.mapwrap{grid-template-columns:1fr}
  .comp-ss{grid-template-columns:1fr}
  .cal-row{grid-template-columns:1fr}
  .priority-metrics,.evidence-row{grid-template-columns:1fr 1fr}
  .dash-story-grid,.feat-grid{grid-template-columns:1fr 1fr}
  .el-summary{grid-template-columns:1fr 1fr 1fr}
  .el-drill{grid-template-columns:1fr 1fr}
  nav .links{display:none}.menu-toggle{display:block}
  .cookie-card{grid-template-columns:1fr}.cookie-actions{justify-content:stretch}.cookie-actions .btn{flex:1;justify-content:center}
  .trust b{font-size:1.25rem}.hero-logo{order:-1}
}
@media(max-width:620px){
  .kpi-row,.dash-story-grid,.feat-grid,.el-summary,.proof-band{grid-template-columns:1fr 1fr}
  .priority-metrics,.evidence-row,.el-form-grid{grid-template-columns:1fr}
  .el-summary{grid-template-columns:1fr 1fr}
}
