
:root{
  --paper:#F8F1DF;
  --paper-2:#F2E8CE;
  --ink:#1E1710;
  --ink-soft:#5A4B38;
  --red:#A4161A;
  --red-deep:#7A1115;
  --gold:#E9A100;
  --gold-soft:#F2C94C;
  --green:#1C6B3C;
  --green-deep:#134E2B;
  --line:rgba(30,23,16,.16);
  --shadow:6px 6px 0 var(--ink);
  --shadow-red:5px 5px 0 var(--red-deep);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk","Noto Sans Kannada",sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
/* ===== bilingual ===== */
.kn{font-family:"Noto Sans Kannada",sans-serif}
html[data-lang="kn"] .en{display:none}
html[data-lang="en"] .kn{display:none}
html[data-lang="en"] body{font-family:"Hanken Grotesk",sans-serif}

h1,h2,h3,.display{font-family:"Bricolage Grotesque","Noto Serif Kannada",serif;line-height:1.02;letter-spacing:-.02em;font-weight:800}
html[data-lang="kn"] h1 .kn,html[data-lang="kn"] h2 .kn,html[data-lang="kn"] h3 .kn,.knhead{font-family:"Noto Serif Kannada",serif;letter-spacing:0;line-height:1.18}

a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px;position:relative;z-index:2}
.tricolour{height:7px;display:flex}
.tricolour i{flex:1}
.tricolour i:nth-child(1){background:var(--red)}
.tricolour i:nth-child(2){background:var(--gold)}
.tricolour i:nth-child(3){background:var(--green)}

/* ===== top utility bar ===== */
.util{background:var(--ink);color:#F3E9D2;font-size:12.5px}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;gap:14px}
.util a{opacity:.92;display:inline-flex;align-items:center;gap:6px}
.util a:hover{opacity:1;color:var(--gold-soft)}
.util .right{display:flex;align-items:center;gap:18px}
.langtog{display:inline-flex;border:1px solid rgba(243,233,210,.35);border-radius:999px;overflow:hidden}
.langtog button{background:none;border:0;color:#F3E9D2;font:inherit;font-weight:600;padding:3px 11px;cursor:pointer;font-size:12px}
.langtog button.on{background:var(--gold);color:var(--ink)}
.util .social{display:flex;gap:13px;font-weight:700}

/* ===== header ===== */
header.nav{position:sticky;top:0;z-index:40;background:rgba(248,241,223,.92);backdrop-filter:blur(8px);border-bottom:2px solid var(--ink)}
header.nav .wrap{display:flex;align-items:center;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.roundel{width:50px;height:50px;flex:0 0 50px;border-radius:50%;background:radial-gradient(circle at 50% 38%,#C23a26,#8A1419 78%);display:grid;place-items:center;box-shadow:0 0 0 2px var(--ink),3px 3px 0 var(--ink)}
.roundel svg{width:30px;height:30px}
.brand .bn{display:flex;flex-direction:column;line-height:1.05}
.brand .bn b{font-family:"Noto Serif Kannada",serif;font-size:17px;font-weight:800;color:var(--red-deep)}
.brand .bn b.en-b{font-family:"Bricolage Grotesque",sans-serif;font-size:15.5px;letter-spacing:-.01em;color:var(--red-deep)}
.brand .bn span{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
nav.links{display:flex;gap:24px;align-items:center}
nav.links a{font-weight:600;font-size:14.5px;position:relative;padding:4px 0}
nav.links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .25s}
nav.links a:hover::after{width:100%}
.cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:14px;padding:11px 18px;cursor:pointer;border:2px solid var(--ink);transition:transform .12s,box-shadow .12s}
.cta-join{background:var(--ink);color:var(--paper)}
.cta-donate{background:var(--gold);color:var(--ink);box-shadow:3px 3px 0 var(--ink)}
.cta:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.cta-sm{padding:9px 15px;font-size:13px}
.menu-btn{display:none;background:none;border:2px solid var(--ink);width:44px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{content:"";display:block;width:20px;height:2.5px;background:var(--ink);position:relative}
.menu-btn span::before{position:absolute;top:-6px}.menu-btn span::after{position:absolute;top:6px}

/* ===== hero ===== */
.hero{position:relative;background:
   radial-gradient(120% 90% at 88% 8%,rgba(233,161,0,.16),transparent 55%),
   radial-gradient(120% 100% at 5% 100%,rgba(28,107,60,.16),transparent 55%),
   var(--paper);
   overflow:hidden;border-bottom:2px solid var(--ink)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center;padding:54px 0 60px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--red-deep);background:rgba(164,22,26,.09);border:1.5px solid rgba(164,22,26,.3);padding:7px 13px;border-radius:999px;margin-bottom:22px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 3px rgba(164,22,26,.25)}
.hero h1{font-size:clamp(40px,6vw,72px);margin-bottom:18px}
html[data-lang="kn"] .hero h1{font-size:clamp(32px,5vw,60px)}
.hero h1 .accent{color:var(--red)}
.hero .sub{font-size:clamp(16px,1.6vw,19px);color:var(--ink-soft);max-width:46ch;margin-bottom:30px;font-weight:500}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-cta .cta{padding:15px 26px;font-size:15.5px}
.statline{display:flex;gap:26px;flex-wrap:wrap;border-top:1.5px dashed var(--line);padding-top:22px}
.stat b{font-family:"Bricolage Grotesque",sans-serif;font-size:30px;color:var(--red-deep);display:block;line-height:1}
.stat span{font-size:12.5px;color:var(--ink-soft);font-weight:600;letter-spacing:.03em}

/* hero art */
.hero-art{position:relative;display:grid;place-items:center}
.map-frame{position:relative;width:100%;max-width:430px;aspect-ratio:1/1.04;background:var(--paper-2);border:3px solid var(--ink);box-shadow:10px 10px 0 var(--red-deep);overflow:hidden}
.map-frame .bands{position:absolute;inset:0;display:flex;flex-direction:column}
.map-frame .bands i{flex:1}
.map-frame .bands i:nth-child(1){background:var(--red)}
.map-frame .bands i:nth-child(2){background:var(--gold)}
.map-frame .bands i:nth-child(3){background:var(--green)}
.map-frame svg.map{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(4px 6px 0 rgba(0,0,0,.25))}
.map-frame .cap{position:absolute;left:0;right:0;bottom:0;background:var(--ink);color:var(--paper);padding:11px 14px;font-weight:700;font-size:13px;display:flex;justify-content:space-between;align-items:center;letter-spacing:.02em}
.seal{position:absolute;top:-22px;right:-18px;width:118px;height:118px;border-radius:50%;background:var(--paper);border:2.5px solid var(--red-deep);display:grid;place-items:center;text-align:center;transform:rotate(8deg);box-shadow:4px 4px 0 var(--ink);z-index:3}
.seal .ring{position:absolute;inset:7px;border:1.5px dashed var(--red-deep);border-radius:50%}
.seal b{font-family:"Bricolage Grotesque",sans-serif;font-size:11px;color:var(--red-deep);line-height:1.15;letter-spacing:.02em;padding:0 8px}
.seal small{font-size:8px;letter-spacing:.08em;color:var(--ink-soft);font-weight:700;margin-top:3px}

/* ===== marquee demands ===== */
.marq{background:var(--ink);color:var(--paper);overflow:hidden;border-bottom:2px solid var(--ink)}
.marq .track{display:flex;gap:40px;white-space:nowrap;padding:13px 0;animation:scroll 26s linear infinite;font-weight:700;font-size:14.5px;letter-spacing:.02em}
.marq .track span{display:inline-flex;align-items:center;gap:14px}
.marq .track .s{color:var(--gold-soft)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== section frame ===== */
section{position:relative;z-index:2}
.sec{padding:74px 0}
.sec-head{margin-bottom:42px;max-width:660px}
.kicker{font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--green-deep);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.kicker::before{content:"";width:30px;height:3px;background:var(--green)}
.sec h2{font-size:clamp(28px,3.6vw,42px)}
html[data-lang="kn"] .sec h2{font-size:clamp(24px,3.2vw,36px)}
.sec .lede{font-size:17px;color:var(--ink-soft);margin-top:14px;font-weight:500}

/* mission band */
.mission{background:var(--red);color:#FCEFD8;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.mission .wrap{padding:60px 22px}
.mission .big{font-family:"Bricolage Grotesque","Noto Serif Kannada",serif;font-weight:800;font-size:clamp(24px,3.3vw,40px);line-height:1.16;letter-spacing:-.01em;max-width:20ch}
html[data-lang="kn"] .mission .big{font-family:"Noto Serif Kannada",serif;line-height:1.3}
.mission .big em{color:var(--gold-soft);font-style:normal}
.mission .row{display:flex;gap:40px;flex-wrap:wrap;margin-top:34px;border-top:1px solid rgba(252,239,216,.3);padding-top:26px}
.mission .row div b{font-family:"Bricolage Grotesque",sans-serif;font-size:26px;display:block}
.mission .row div span{font-size:13px;opacity:.85;font-weight:600}

/* demands grid */
.demands{background:var(--paper-2)}
.dgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dcard{background:var(--paper);border:2px solid var(--ink);padding:26px 22px 24px;position:relative;transition:transform .14s,box-shadow .14s;overflow:hidden}
.dcard:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.dcard .no{font-family:"Bricolage Grotesque",sans-serif;font-size:13px;font-weight:700;color:var(--ink-soft)}
.dcard .ic{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;margin:10px 0 16px;border:2px solid var(--ink)}
.dcard:nth-child(3n+1) .ic{background:rgba(164,22,26,.14)}
.dcard:nth-child(3n+2) .ic{background:rgba(233,161,0,.2)}
.dcard:nth-child(3n) .ic{background:rgba(28,107,60,.16)}
.dcard .ic svg{width:24px;height:24px}
.dcard h3{font-size:19px;margin-bottom:8px}
html[data-lang="kn"] .dcard h3{font-size:18px;font-family:"Noto Serif Kannada",serif}
.dcard p{font-size:14px;color:var(--ink-soft);font-weight:500}
.dcard .tag{position:absolute;top:0;right:0;background:var(--ink);color:var(--paper);font-size:10.5px;font-weight:700;padding:4px 9px;letter-spacing:.04em}
.dcard.hot{background:var(--ink);color:var(--paper)}
.dcard.hot .no,.dcard.hot p{color:#d8c9ac}
.dcard.hot .ic{background:var(--red);border-color:var(--paper)}
.dcard.hot .ic svg{stroke:var(--paper)}

/* president */
.leader{background:var(--green-deep);color:#EAF3E5;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.leader .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:44px;align-items:center;padding:64px 22px}
.portrait{position:relative;aspect-ratio:4/4.6;background:linear-gradient(160deg,#2a7d49,#134e2b);border:3px solid var(--paper);box-shadow:9px 9px 0 rgba(0,0,0,.35);display:grid;place-items:center;overflow:hidden}
.portrait .ph{display:grid;place-items:center;gap:10px;color:rgba(255,255,255,.55);text-align:center;padding:20px}
.portrait .ph svg{width:64px;height:64px;opacity:.6}
.portrait .ph small{font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.portrait .name{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.55));padding:30px 18px 16px}
.leader .kicker{color:var(--gold-soft)}
.leader .kicker::before{background:var(--gold)}
.leader h2{font-size:clamp(26px,3.4vw,40px);color:#fff;margin-bottom:6px}
.leader .role{color:var(--gold-soft);font-weight:700;font-size:15px;letter-spacing:.04em;margin-bottom:20px}
.leader blockquote{font-family:"Bricolage Grotesque","Noto Serif Kannada",serif;font-size:clamp(19px,2.2vw,26px);line-height:1.3;font-weight:700;border-left:4px solid var(--gold);padding-left:20px;margin:0 0 24px}
html[data-lang="kn"] .leader blockquote{font-family:"Noto Serif Kannada",serif;line-height:1.45}
.leader .meta{display:flex;gap:14px;flex-wrap:wrap;font-size:13.5px}
.leader .meta a{display:inline-flex;align-items:center;gap:8px;border:1.5px solid rgba(234,243,229,.4);padding:9px 14px;border-radius:999px;font-weight:600}
.leader .meta a:hover{background:rgba(255,255,255,.1)}

/* padayatra / activities */
.act .agrid{display:grid;grid-template-columns:1.3fr 1fr;gap:24px}
.feature{background:var(--ink);color:var(--paper);border:2px solid var(--ink);padding:34px 30px;display:flex;flex-direction:column;justify-content:space-between;min-height:300px;position:relative;overflow:hidden}
.feature .badge{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-weight:700;font-size:12px;padding:6px 12px;border-radius:999px;width:fit-content;letter-spacing:.05em}
.feature h3{font-size:clamp(24px,3vw,34px);margin:18px 0 10px;color:#fff}
html[data-lang="kn"] .feature h3{font-family:"Noto Serif Kannada",serif}
.feature .route{display:flex;align-items:center;gap:12px;font-weight:700;font-size:15px;color:var(--gold-soft);flex-wrap:wrap}
.feature .route .arrow{color:var(--paper)}
.feature p{color:#cdbfa4;font-size:14.5px;margin-top:10px;font-weight:500;max-width:42ch}
.feature .tstripe{position:absolute;right:-30px;top:-30px;width:150px;height:150px;border-radius:50%;background:
   conic-gradient(var(--red) 0 33%,var(--gold) 0 66%,var(--green) 0);opacity:.16}
.sidecards{display:flex;flex-direction:column;gap:24px}
.scard{background:var(--paper);border:2px solid var(--ink);padding:22px;flex:1;display:flex;flex-direction:column;justify-content:center;transition:transform .14s,box-shadow .14s}
.scard:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink)}
.scard .lbl{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red-deep);margin-bottom:8px}
.scard p{font-size:15px;color:var(--ink-soft);font-weight:500}
.scard.news{background:var(--gold)}
.scard.news .lbl{color:var(--ink)}

/* donate */
.donate{background:
  repeating-linear-gradient(45deg,var(--paper) 0 22px,var(--paper-2) 22px 44px)}
.dwrap{background:var(--paper);border:3px solid var(--ink);box-shadow:12px 12px 0 var(--red-deep);display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden}
.dleft{padding:46px 40px}
.dleft .badge80{display:inline-flex;align-items:center;gap:8px;background:rgba(28,107,60,.14);border:1.5px solid var(--green);color:var(--green-deep);font-weight:700;font-size:12.5px;padding:7px 13px;border-radius:999px;margin-bottom:18px}
.dleft h2{font-size:clamp(26px,3.2vw,38px);margin-bottom:14px}
.dleft p{color:var(--ink-soft);font-size:15.5px;font-weight:500;margin-bottom:24px;max-width:42ch}
.amts{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.amts button{font:inherit;font-weight:700;font-size:15px;padding:12px 20px;border:2px solid var(--ink);background:var(--paper);cursor:pointer;transition:.12s}
.amts button:hover,.amts button.on{background:var(--gold);transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--ink)}
.dright{background:var(--ink);color:var(--paper);padding:46px 36px;display:flex;flex-direction:column;justify-content:center}
.dright h3{color:#fff;font-size:20px;margin-bottom:18px}
.dright ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.dright li{display:flex;gap:12px;font-size:14.5px;color:#e3d6bc;font-weight:500}
.dright li svg{flex:0 0 22px;width:22px;height:22px;stroke:var(--gold-soft)}
.fineprint{font-size:12px;color:var(--ink-soft);margin-top:16px;line-height:1.5}

/* join form */
.join{background:var(--green-deep);color:#EAF3E5;border-top:2px solid var(--ink)}
.join .wrap{padding:64px 22px;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.join h2{color:#fff;font-size:clamp(26px,3.2vw,38px);margin-bottom:14px}
.join .lede{color:#c9ddc2;font-size:16px;font-weight:500}
.join .kicker{color:var(--gold-soft)}.join .kicker::before{background:var(--gold)}
form.j{background:var(--paper);color:var(--ink);border:2px solid var(--ink);box-shadow:7px 7px 0 rgba(0,0,0,.3);padding:30px}
form.j .fg{margin-bottom:16px}
form.j label{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:6px}
form.j input,form.j select{width:100%;font:inherit;font-size:15px;padding:12px 14px;border:2px solid var(--ink);background:var(--paper-2)}
form.j input:focus,form.j select:focus{outline:3px solid var(--gold)}
form.j .two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form.j button{width:100%;margin-top:8px;background:var(--red);color:#fff;border:2px solid var(--ink);font-weight:700;font-size:16px;padding:15px;cursor:pointer;box-shadow:4px 4px 0 var(--ink);transition:.12s}
form.j button:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.j-ok{display:none;background:rgba(28,107,60,.16);border:2px solid var(--green);color:var(--green-deep);padding:14px;font-weight:600;margin-top:14px;border-radius:4px}

/* footer */
footer{background:var(--ink);color:#d8c9ac;border-top:7px solid var(--gold)}
footer .wrap{padding:54px 22px 26px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
footer .brand .bn b,footer .brand .bn b.en-b{color:#fff}
footer p{font-size:14px;line-height:1.6;margin-top:14px;max-width:34ch}
footer h4{color:#fff;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;font-family:"Bricolage Grotesque",sans-serif}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px}
footer ul a:hover{color:var(--gold-soft)}
.fbot{border-top:1px solid rgba(255,255,255,.14);margin-top:36px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:#a8987c}
.regno{display:inline-block;border:1px solid rgba(255,255,255,.2);padding:5px 11px;border-radius:4px;font-weight:600;color:#d8c9ac}

/* reveal anim */
.reveal{}
.reveal.in{opacity:1;transform:none}
.hero .eyebrow{animation:rise .7s .05s both}
.hero h1{animation:rise .7s .15s both}
.hero .sub{animation:rise .7s .28s both}
.hero .hero-cta{animation:rise .7s .4s both}
.hero .statline{animation:rise .7s .52s both}
.hero-art{animation:rise .8s .35s both}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ===== responsive ===== */
@media(max-width:900px){
  .hero-grid,.leader .wrap,.act .agrid,.dwrap,.join .wrap,.fgrid{grid-template-columns:1fr}
  .dgrid{grid-template-columns:repeat(2,1fr)}
  nav.links,.util .left-extra{display:none}
  .menu-btn{display:flex}
  .header-cta-join{display:none}
  .hero-art{order:-1;width:100%}
  .map-frame{max-width:340px}
  .seal{width:96px;height:96px}
  .dright{order:-1}
  .mobile-open nav.links{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--paper);border-bottom:2px solid var(--ink);padding:18px 22px;gap:16px;box-shadow:0 14px 18px rgba(0,0,0,.12)}
}
@media(max-width:560px){
  .dgrid{grid-template-columns:1fr}
  .util .wrap{font-size:11.5px}
  .util .social{display:none}
  .statline{gap:18px}
  .seal{top:-14px;right:8px}
}
/* ===== impact + latest + home newsletter ===== */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.impact{text-align:center;padding:10px}
.impact b{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(34px,5vw,52px);color:var(--gold-soft);display:block;line-height:1}
.impact span{display:block;font-size:13.5px;font-weight:600;color:#d8c9ac;margin-top:6px}
.latest-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.latest-card{display:flex;flex-direction:column;gap:8px;background:var(--paper);border:2px solid var(--ink);padding:22px 20px;text-decoration:none;color:inherit;transition:transform .14s,box-shadow .14s}
.latest-card:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.lc-cat{align-self:flex-start;font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:var(--gold);color:var(--ink)}
.latest-card h4{font-size:18px;line-height:1.25;font-family:"Bricolage Grotesque","Noto Serif Kannada",serif}
.latest-card p{font-size:14px;color:var(--ink-soft);flex:1}
.lc-more{font-weight:700;color:var(--red-deep);font-size:14px}
.latest-card .lc-img{width:100%;height:160px;object-fit:cover;border:2px solid var(--ink);margin-bottom:6px}
.home-nl{background:var(--green-deep);color:#EAF3E5;border-top:2px solid var(--ink)}
.home-nl .wrap{padding:56px 22px;text-align:center}
.home-nl h2{font-size:clamp(24px,3.4vw,36px);color:#fff;margin-bottom:12px}
.home-nl p{max-width:54ch;margin:0 auto 22px;color:#c9ddc2;font-weight:500}
.home-nl form{display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap}
.home-nl input{flex:1;min-width:200px;font:inherit;font-size:15px;padding:13px 15px;border:2px solid var(--ink);background:var(--paper);color:var(--ink)}
.home-nl .wa-link{display:inline-block;margin-top:16px;color:var(--gold-soft);font-weight:700}
@media(max-width:820px){.impact-grid{grid-template-columns:repeat(2,1fr)}.latest-grid{grid-template-columns:1fr}}

.breadcrumb{background:var(--paper-2);border-bottom:1px solid var(--line);font-size:13px}
.breadcrumb .wrap{padding:11px 22px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;color:var(--ink-soft)}
.breadcrumb a{color:var(--red-deep);font-weight:600}.breadcrumb span{opacity:.5}
.page-hero{border-bottom:2px solid var(--ink);color:#fff;position:relative;overflow:hidden}
.page-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.page-hero .hero-ov{position:absolute;inset:0;z-index:1}
.page-hero .wrap{padding:48px 22px 42px;position:relative;z-index:2}
.page-hero.has-img .wrap{min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding-top:70px}
.page-hero h1{font-size:clamp(28px,4vw,46px);margin:14px 0 12px;color:#fff;line-height:1.1}
.page-hero.has-img h1{text-shadow:0 2px 18px rgba(0,0,0,.45)}
.page-hero .hero-sub{font-size:clamp(15px,1.7vw,19px);max-width:62ch;font-weight:500;opacity:.96}
.page-hero.has-img .hero-sub{text-shadow:0 1px 10px rgba(0,0,0,.5)}
.hero-green{background:linear-gradient(135deg,#1C6B3C,#134E2B)}
.hero-green .hero-ov{background:linear-gradient(110deg,rgba(13,58,31,.93) 0%,rgba(15,64,35,.62) 52%,rgba(15,64,35,.32) 100%)}
.hero-red{background:linear-gradient(135deg,#A4161A,#7A1115)}
.hero-red .hero-ov{background:linear-gradient(110deg,rgba(104,13,17,.93) 0%,rgba(122,17,21,.6) 52%,rgba(122,17,21,.3) 100%)}
.hero-ink{background:linear-gradient(135deg,#2A2118,#1E1710)}
.hero-ink .hero-ov{background:linear-gradient(110deg,rgba(22,16,11,.95) 0%,rgba(30,23,16,.72) 52%,rgba(30,23,16,.42) 100%)}
.hero-gold{background:linear-gradient(135deg,#E9A100,#C77F00);color:#1E1710}
.hero-gold h1{color:#1E1710}
.hero-credit{position:absolute;right:10px;bottom:9px;z-index:3;font-size:9.5px;letter-spacing:.02em;color:rgba(255,255,255,.72);background:rgba(0,0,0,.4);padding:3px 9px;border-radius:999px;text-decoration:none}
.hero-credit:hover{color:#fff}
.region-badge{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:rgba(0,0,0,.18);color:#fff;border:1px solid rgba(255,255,255,.35)}
.region-badge.light{background:rgba(255,255,255,.16)}.hero-gold .region-badge{background:rgba(0,0,0,.12);color:#1E1710;border-color:rgba(0,0,0,.3)}
.cat{display:inline-flex;font-weight:700;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:var(--gold);color:var(--ink)}
.cat.light{background:rgba(233,161,0,.95);color:var(--ink)}
.prose-wrap{max-width:790px}
.lede{font-size:19px;line-height:1.6;color:var(--ink);font-weight:500;margin-bottom:10px}
.sec-title{font-family:"Bricolage Grotesque",sans-serif;font-size:23px;letter-spacing:-.01em;margin:38px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--ink);color:var(--red-deep)}
.factgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.factcard{background:var(--paper-2);border:2px solid var(--ink);padding:18px 18px 16px}
.factcard .sev{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:4px;display:inline-block;margin-bottom:8px}
.factcard.sev-high .sev{background:var(--red);color:#fff}.factcard.sev-medium .sev{background:var(--gold);color:var(--ink)}
.factcard h4{font-size:16px;margin-bottom:6px}.factcard p{font-size:14px;color:var(--ink-soft)}
.demand-list,.fact-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin:6px 0}
.demand-list li,.fact-list li{position:relative;padding-left:30px;font-size:15.5px;line-height:1.5}
.demand-list li::before{content:"✓";position:absolute;left:0;top:0;width:21px;height:21px;background:var(--green);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700}
.fact-list li::before{content:"";position:absolute;left:4px;top:9px;width:8px;height:8px;background:var(--red);border-radius:50%}
.position{background:rgba(164,22,26,.07);border-left:4px solid var(--red);padding:18px 20px;margin:22px 0}
.position h3{font-size:15px;letter-spacing:.04em;text-transform:uppercase;color:var(--red-deep);margin-bottom:8px}
.position p{font-size:16.5px;font-weight:500;line-height:1.55}
.statrow{display:flex;gap:14px;flex-wrap:wrap}
.stat-box{flex:1;min-width:150px;background:var(--ink);color:var(--paper);padding:18px 16px;border:2px solid var(--ink)}
.stat-box b{font-family:"Bricolage Grotesque",sans-serif;font-size:24px;color:var(--gold-soft);display:block;line-height:1.1}
.stat-box span{font-size:13px;font-weight:600;display:block;margin:4px 0}.stat-box small{font-size:11px;opacity:.7}
.chips{display:flex;gap:9px;flex-wrap:wrap}
.chip{display:inline-flex;font-size:13px;font-weight:600;padding:7px 13px;border:1.5px solid var(--ink);border-radius:999px;background:var(--paper);color:var(--ink)}
a.chip:hover{background:var(--gold)}
.faq{border:1.5px solid var(--line);border-radius:6px;margin-bottom:10px;background:var(--paper)}
.faq summary{padding:14px 16px;font-weight:700;cursor:pointer;font-size:15.5px}
.faq p{padding:0 16px 16px;color:var(--ink-soft);font-size:14.5px}
.citations{margin-top:30px;background:var(--paper-2);border:1px dashed var(--line);padding:18px 20px;border-radius:6px}
.citations h4{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.citations ol{padding-left:20px;display:flex;flex-direction:column;gap:6px}.citations a{font-size:12.5px;color:var(--red-deep);word-break:break-all}
.kn-callout{font-family:"Noto Sans Kannada",sans-serif;background:rgba(28,107,60,.09);border-left:4px solid var(--green);padding:14px 18px;font-size:16px;line-height:1.6;margin-bottom:22px;font-weight:500}
.prose{font-size:16.5px;line-height:1.72;color:var(--ink)}
.prose p{margin-bottom:16px}.prose h2,.prose h3{font-family:"Bricolage Grotesque",sans-serif;margin:26px 0 10px;color:var(--red-deep)}
.prose h2{font-size:22px}.prose h3{font-size:18px}.prose ul,.prose ol{margin:0 0 16px 22px;display:flex;flex-direction:column;gap:7px}
.prose blockquote{border-left:4px solid var(--gold);padding:6px 0 6px 18px;margin:18px 0;font-style:italic;color:var(--ink-soft)}
.prose a{color:var(--red-deep);text-decoration:underline}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:26px 0 6px}
.back{display:inline-block;margin-top:24px;font-weight:700;color:var(--red-deep)}
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.cardgrid.blog{grid-template-columns:repeat(2,1fr)}
.listcard{display:flex;flex-direction:column;gap:8px;background:var(--paper);border:2px solid var(--ink);padding:22px 20px;text-decoration:none;color:inherit;transition:transform .14s,box-shadow .14s}
.listcard:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.listcard h3{font-size:18px;line-height:1.25}.listcard.issue h3,.listcard.post h3{font-size:17px}
.listcard p{font-size:14px;color:var(--ink-soft);flex:1}.listcard .more{font-weight:700;color:var(--red-deep);font-size:14px}
.listcard .region-badge{align-self:flex-start;color:var(--green-deep);background:rgba(28,107,60,.12);border-color:rgba(28,107,60,.4)}
.cta-band{background:var(--ink);color:var(--paper);border-top:2px solid var(--ink)}
.cta-band .wrap{padding:46px 22px;text-align:center}
.cta-band h3{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(22px,3vw,30px);color:#fff;margin-bottom:18px}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
/* donate */
.amt-grid{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0}
.amt-grid .amt{border:2px solid var(--ink);background:var(--paper);padding:14px 22px;font-weight:700;font-size:17px}
.amt-grid .amt b{display:block;font-family:"Bricolage Grotesque",sans-serif}.amt-grid .amt span{font-size:12px;color:var(--ink-soft);font-weight:500}
.badge80{display:inline-flex;align-items:center;gap:8px;background:rgba(28,107,60,.14);border:1.5px solid var(--green);color:var(--green-deep);font-weight:700;font-size:13px;padding:8px 14px;border-radius:999px;margin-bottom:10px}
.pay-card{background:var(--paper-2);border:2px solid var(--ink);padding:22px;margin:18px 0}
.pay-card h4{font-size:16px;margin-bottom:8px}
/* forms */
form.kk{background:var(--paper);border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink);padding:26px;max-width:560px}
form.kk .fg{margin-bottom:14px}
form.kk label{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:6px}
form.kk input,form.kk select,form.kk textarea{width:100%;font:inherit;font-size:15px;padding:12px 14px;border:2px solid var(--ink);background:var(--paper-2)}
form.kk .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
form.kk button{width:100%;margin-top:6px;background:var(--red);color:#fff;border:2px solid var(--ink);font-weight:700;font-size:16px;padding:14px;cursor:pointer;box-shadow:4px 4px 0 var(--ink)}
form.kk button:hover{transform:translate(-2px,-2px)}
.sub-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.sub-row .cta{padding:14px 22px}
/* news */
.newsgrid{display:flex;flex-direction:column;gap:0;border-top:2px solid var(--ink)}
.newsitem{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:20px 0;border-bottom:1px solid var(--line)}
.newsitem .date{font-weight:700;color:var(--red-deep);font-size:13px}
.newsitem .ncat{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:700;margin-bottom:4px;display:block}
.newsitem h3{font-size:18px;margin-bottom:6px;line-height:1.25}
.newsitem p{font-size:14.5px;color:var(--ink-soft)}
.newsitem a.src{font-size:12px;color:var(--red-deep);font-weight:600}
/* float + sticky */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:60;width:56px;height:56px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.3);border:2px solid #fff}
.wa-float svg{width:30px;height:30px;fill:#fff}
.sticky-cta{display:none}
@media(max-width:820px){.cardgrid,.cardgrid.blog,.factgrid,form.kk .two{grid-template-columns:1fr}
.newsitem{grid-template-columns:1fr;gap:6px}
.sticky-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--paper);border-top:2px solid var(--ink);padding:8px;gap:8px}
.sticky-cta .cta{flex:1;justify-content:center;padding:13px;font-size:14px}
.wa-float{bottom:74px}}
/* images */
.page-banner{margin:0;border-bottom:2px solid var(--ink)}
.page-banner img{width:100%;height:clamp(220px,34vw,380px);object-fit:cover;display:block}
.page-banner figcaption{font-size:11px;color:var(--ink-soft);padding:6px 22px;background:var(--paper-2)}
.page-banner figcaption a{color:var(--ink-soft)}
.card-imgwrap{display:block;overflow:hidden;border:2px solid var(--ink);margin-bottom:10px;background:var(--paper-2)}
.card-img{width:100%;height:172px;object-fit:cover;display:block;margin:0;transition:transform .5s ease}
.listcard:hover .card-img{transform:scale(1.07)}
.pres-portrait{margin:0 0 24px 26px;max-width:300px;float:right;border:2px solid var(--ink);background:var(--paper-2);box-shadow:7px 7px 0 var(--ink)}
.pres-portrait img{width:100%;display:block;border-bottom:2px solid var(--ink)}
.pres-portrait figcaption{padding:12px 15px}
.pres-portrait figcaption b{display:block;font-size:15.5px;font-family:"Bricolage Grotesque","Noto Serif Kannada",serif}
.pres-portrait figcaption span{font-size:12.5px;color:var(--ink-soft);display:block;margin-top:3px}
@media(max-width:600px){.pres-portrait{float:none;max-width:100%;margin:0 0 22px}}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:6px 0 8px;clear:both}
.team-card{border:2px solid var(--ink);background:var(--paper);padding:13px;display:flex;gap:12px;align-items:center;transition:transform .14s,box-shadow .14s}
.team-card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink)}
.tm-pic{flex:0 0 60px;width:60px;height:60px;border:2px solid var(--ink);overflow:hidden;background:var(--paper-2)}
.tm-pic img{width:100%;height:100%;object-fit:cover;display:block}
.tm-pic.tm-ph{display:grid;place-items:center;background:radial-gradient(circle at 50% 38%,#c23a26,#7A1115)}
.tm-pic.tm-ph span{font-family:"Bricolage Grotesque",sans-serif;font-size:24px;font-weight:800;color:#fff}
.tm-info{display:flex;flex-direction:column;gap:1px;min-width:0}
.tm-info b{font-size:14.5px;line-height:1.2}
.tm-role{font-size:12px;font-weight:700;color:var(--red-deep)}
.tm-place{font-size:11.5px;color:var(--ink-soft)}
.tm-tel{font-size:11.5px;color:var(--green-deep);font-weight:600;margin-top:2px}
@media(max-width:820px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:30px}
.gallery-grid figure{margin:0;border:2px solid var(--ink);background:var(--paper);overflow:hidden}
.gallery-grid img{width:100%;height:200px;object-fit:cover;display:block}
.gallery-grid figcaption{font-size:11px;padding:7px 10px;color:var(--ink-soft);font-weight:600}
@media(max-width:820px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
