/* ════════════════════════════════════════════
   UDAAN FOUNDATION — design system v2
   Pink #ED1E79 → Purple #662D8C
   ════════════════════════════════════════════ */

:root{
  --pink:#ED1E79;
  --purple:#662D8C;
  --grad:linear-gradient(120deg,#ED1E79 0%,#A8268B 50%,#662D8C 100%);
  --grad-soft:linear-gradient(120deg,rgba(237,30,121,.12),rgba(102,45,140,.12));
  --bg:#FFF9FC;
  --surface:#ffffff;
  --text:#23102B;
  --text2:rgba(35,16,43,.62);
  --line:rgba(102,45,140,.12);
  --shadow:0 24px 70px -28px rgba(102,45,140,.28);
  --glow:0 10px 40px -8px rgba(237,30,121,.45);
  --display:'Playfair Display',Georgia,serif;
  --ui:'DM Sans',system-ui,sans-serif;
  --r:20px;
  --ease:cubic-bezier(.22,1,.36,1);
}
[data-theme="dark"]{
  --bg:#160B1C;
  --surface:#1F1027;
  --text:#F7EFF6;
  --text2:rgba(247,239,246,.62);
  --line:rgba(237,30,121,.18);
  --shadow:0 24px 70px -28px rgba(0,0,0,.6);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ui);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit}
::selection{background:var(--pink);color:#fff}
.sprite{display:none}
.flip{transform:rotate(180deg)}
.heart-inline{vertical-align:-1px}

.logo-dark{display:none}
[data-theme="dark"] .logo-light{display:none}
[data-theme="dark"] .logo-dark{display:block}

/* ════════ SPLASH ════════ */
html:not(.js) #splash{display:none}
#splash{
  position:fixed;inset:0;z-index:1000;
  background:
    radial-gradient(60% 60% at 70% 35%,rgba(237,30,121,.10),transparent 70%),
    radial-gradient(50% 50% at 25% 75%,rgba(102,45,140,.10),transparent 70%),
    #fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .7s var(--ease),visibility .7s;
}
#splash.gone{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{width:min(220px,52vw);animation:splashPop 1s var(--ease) both}
@keyframes splashPop{from{opacity:0;transform:scale(.86)}to{opacity:1;transform:scale(1)}}
.splash-orbit{position:absolute;inset:0;pointer-events:none}
.splash-orbit span{
  position:absolute;left:50%;top:50%;border-radius:50%;
  border:1px solid rgba(237,30,121,.16);
  translate:-50% -50%;
  animation:orbit 14s linear infinite;
}
.splash-orbit span:nth-child(1){width:300px;height:300px}
.splash-orbit span:nth-child(2){width:440px;height:440px;animation-duration:20s;animation-direction:reverse;border-color:rgba(102,45,140,.13)}
.splash-orbit span:nth-child(3){width:600px;height:600px;animation-duration:28s;border-color:rgba(237,30,121,.08)}
.splash-orbit span::after{
  content:'';position:absolute;top:-3px;left:50%;width:6px;height:6px;border-radius:50%;
  background:var(--grad);
}
@keyframes orbit{to{transform:rotate(360deg)}}
.splash-footer{
  position:absolute;bottom:32px;
  font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;
  color:rgba(35,16,43,.45);display:flex;align-items:center;gap:8px;
}
.splash-footer svg{color:var(--pink);animation:beat 1.4s ease infinite}
@keyframes beat{0%,100%{transform:scale(1)}25%{transform:scale(1.25)}}

/* ════════ NAV ════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;gap:28px;
  padding:14px clamp(18px,4vw,48px);
  transition:background .4s,backdrop-filter .4s,box-shadow .4s,padding .4s;
}
#nav.scrolled{
  background:color-mix(in srgb,var(--bg) 78%,transparent);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  box-shadow:0 8px 32px -16px rgba(102,45,140,.25);
  padding-top:10px;padding-bottom:10px;
}
.nav-logo img{height:34px;width:auto}
.nav-menu{display:flex;gap:clamp(14px,2vw,30px);margin-left:auto}
.nav-menu a{
  font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text2);position:relative;padding:6px 2px;
  transition:color .3s;
}
.nav-menu a::after{
  content:'';position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:var(--grad);border-radius:2px;
  transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease);
}
.nav-menu a:hover,.nav-menu a.on{color:var(--text)}
.nav-menu a:hover::after,.nav-menu a.on::after{transform:scaleX(1);transform-origin:left}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-donate{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;background:var(--grad);
  padding:10px 20px;border-radius:99px;
  box-shadow:var(--glow);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.nav-donate:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 14px 44px -8px rgba(237,30,121,.55)}
#themeBtn{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);transition:border-color .3s,transform .3s}
#themeBtn:hover{border-color:var(--pink);transform:rotate(20deg)}
/* ── language switcher (desktop header) ── */
.lang-wrap{position:relative}
.lang-btn{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);transition:border-color .3s,transform .3s,color .3s}
.lang-btn:hover{border-color:var(--pink);color:var(--pink);transform:rotate(14deg)}
.lang-menu{
  position:absolute;right:0;top:calc(100% + 12px);
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:10px;
  width:230px;max-height:min(430px,70vh);overflow-y:auto;
  display:none;z-index:960;
}
.lang-menu.open{display:grid;grid-template-columns:1fr 1fr;gap:4px;animation:langIn .25s var(--ease)}
@keyframes langIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.lang-menu-l{grid-column:1/-1;font-size:.58rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--pink);padding:4px 8px 8px}
.lang-opt{
  font-size:.82rem;font-weight:500;text-align:left;
  padding:8px 10px;border-radius:9px;color:var(--text);
  transition:background .2s,color .2s;
}
.lang-opt:hover{background:var(--grad-soft);color:var(--pink)}
.lang-opt.active{background:var(--grad);color:#fff;font-weight:700}
/* transparent nav sits on the dark hero — go light until scrolled */
#nav:not(.scrolled) .nav-menu a{color:rgba(255,255,255,.78)}
#nav:not(.scrolled) .nav-menu a:hover,#nav:not(.scrolled) .nav-menu a.on{color:#fff}
#nav:not(.scrolled) #themeBtn{border-color:rgba(255,255,255,.35);color:#fff}
#nav:not(.scrolled) .lang-btn{border-color:rgba(255,255,255,.35);color:#fff}
#nav:not(.scrolled) #burger span{background:#fff}
#nav:not(.scrolled) .nav-donate{box-shadow:0 10px 40px -8px rgba(0,0,0,.5)}
#nav:not(.scrolled) .nav-logo .logo-light{display:none}
#nav:not(.scrolled) .nav-logo .logo-dark{display:block}
.ic-sun{display:none}
[data-theme="dark"] .ic-sun{display:block}
[data-theme="dark"] .ic-moon{display:none}

.nav-left{display:flex;align-items:center;gap:14px}
#burger{display:flex;flex-direction:column;gap:5px;width:38px;height:38px;align-items:flex-start;justify-content:center}
#burger span{display:block;height:2px;border-radius:2px;background:var(--text);transition:width .3s}
#burger span:nth-child(1){width:22px}
#burger span:nth-child(2){width:15px}
#burger span:nth-child(3){width:22px}
#burger:hover span{width:22px}

/* ════════ SIDE MENU ════════ */
#sideMenu{
  position:fixed;top:0;left:0;bottom:0;z-index:950;
  width:min(360px,86vw);
  background:var(--surface);
  padding:80px 36px 36px;
  transform:translateX(-102%);
  transition:transform .55s var(--ease);
  display:flex;flex-direction:column;
  box-shadow:30px 0 80px -30px rgba(0,0,0,.3);
}
#sideMenu.open{transform:translateX(0)}
#smClose{position:absolute;top:20px;right:22px;font-size:1.1rem;color:var(--text2)}
.sm-nav{display:flex;flex-direction:column;gap:4px;overflow-y:auto}
.sm-link{
  font-family:var(--display);font-size:1.4rem;padding:8px 0;
  display:flex;align-items:baseline;gap:14px;
  opacity:0;transform:translateX(-18px);
  transition:color .3s;
}
#sideMenu.open .sm-link{animation:smIn .5s var(--ease) forwards}
#sideMenu.open .sm-link:nth-child(1){animation-delay:.08s}
#sideMenu.open .sm-link:nth-child(2){animation-delay:.12s}
#sideMenu.open .sm-link:nth-child(3){animation-delay:.16s}
#sideMenu.open .sm-link:nth-child(4){animation-delay:.2s}
#sideMenu.open .sm-link:nth-child(5){animation-delay:.24s}
#sideMenu.open .sm-link:nth-child(6){animation-delay:.28s}
#sideMenu.open .sm-link:nth-child(7){animation-delay:.32s}
#sideMenu.open .sm-link:nth-child(8){animation-delay:.36s}
#sideMenu.open .sm-link:nth-child(9){animation-delay:.4s}
#sideMenu.open .sm-link:nth-child(10){animation-delay:.44s}
#sideMenu.open .sm-link:nth-child(11){animation-delay:.48s}
@keyframes smIn{to{opacity:1;transform:translateX(0)}}
.sm-link span{font-family:var(--ui);font-size:.6rem;letter-spacing:.2em;color:var(--pink)}
.sm-link:hover{color:var(--pink)}
.sm-lang{margin-top:auto;padding-top:20px;border-top:1px solid var(--line)}
.sm-lang-l{display:flex;align-items:center;gap:7px;font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);margin-bottom:10px}
.sm-lang-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.sm-lang-grid .lang-opt{font-size:.74rem;padding:7px 6px;text-align:center;border:1px solid var(--line);border-radius:9px}
.sm-lang-grid .lang-opt:hover{border-color:var(--pink)}
.sm-lang-grid .lang-opt.active{border-color:transparent}
.sm-social{display:flex;gap:10px;padding-top:18px}
.sm-social a{
  display:grid;place-items:center;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);color:var(--text2);
  transition:all .3s;
}
.sm-social a:hover{background:var(--grad);color:#fff;border-color:transparent;transform:translateY(-3px)}
#smVeil{position:fixed;inset:0;z-index:940;background:rgba(20,8,26,.5);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.4s}
#smVeil.on{opacity:1;visibility:visible}

/* ════════ CURSOR ════════ */
#cursorDot,#cursorRing{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:1001;display:none}
@media(hover:hover) and (pointer:fine){
  #cursorDot{display:block;width:6px;height:6px;background:var(--pink);translate:-50% -50%}
  #cursorRing{display:block;width:34px;height:34px;border:1.5px solid rgba(237,30,121,.5);translate:-50% -50%;transition:width .25s,height .25s,border-color .25s}
  #cursorRing.big{width:58px;height:58px;border-color:rgba(102,45,140,.7)}
}

/* ════════ SHARED ════════ */
section{position:relative}
.sec-head{max-width:1180px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.62rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;
  color:var(--pink);margin-bottom:18px;
}
.eyebrow::before{content:'';width:26px;height:1.5px;background:var(--grad);border-radius:2px}
.eyebrow.center{justify-content:center;display:flex}
.eyebrow.center::before{display:none}
.eyebrow.light{color:#FF9AC8}
.sec-title{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.12;letter-spacing:-.01em;
  margin-bottom:14px;
}
.sec-title em{font-style:italic}
.sec-title.center{text-align:center}
.sec-title.light{color:#fff}
.grad-text{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.sec-sub{color:var(--text2);font-size:1.02rem;max-width:560px;margin-bottom:10px}

/* buttons — every button breathes through the brand gradient */
@keyframes breathe{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes borderBreathe{
  0%,100%{border-color:#ED1E79;color:#ED1E79}
  50%{border-color:#8E5BC7;color:#9D4EDD}
}
@keyframes borderBreatheLight{
  0%,100%{border-color:#FF6FB1}
  50%{border-color:#C77BFF}
}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  padding:16px 30px;border-radius:99px;
  transition:transform .35s var(--ease),box-shadow .35s,background .35s,color .35s;
  position:relative;overflow:hidden;
}
.btn .btn-arr{transition:transform .35s var(--ease)}
.btn:hover .btn-arr{transform:translateX(5px)}
.btn-solid{background:linear-gradient(120deg,#ED1E79,#A8268B,#662D8C,#FF4D9E,#ED1E79);background-size:340% 100%;animation:breathe 5.5s ease-in-out infinite;color:#fff;box-shadow:var(--glow)}
.btn-solid::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .7s var(--ease);
}
.btn-solid:hover{transform:translateY(-3px);box-shadow:0 18px 50px -10px rgba(237,30,121,.6)}
.btn-solid:hover::before{transform:translateX(120%)}
.btn-solid.invert{background:linear-gradient(#fff,#fff) padding-box,linear-gradient(120deg,#ED1E79,#662D8C,#FF6FB1,#ED1E79) border-box;background-size:100% 100%,340% 100%;border:2px solid transparent;animation:breathe 5.5s ease-in-out infinite;color:var(--purple);box-shadow:0 14px 40px -12px rgba(0,0,0,.4)}
.btn-line{border:1.5px solid var(--pink);color:var(--pink);animation:borderBreathe 5.5s ease-in-out infinite}
.btn-line:hover{transform:translateY(-3px)}
.btn-line.light{color:#fff!important;animation:borderBreatheLight 5.5s ease-in-out infinite}
.btn-line.light:hover{background:rgba(255,255,255,.1)}
.btn-ghost{padding:12px 0;gap:8px;font-weight:700;background:linear-gradient(120deg,#ED1E79,#662D8C,#FF4D9E,#ED1E79);background-size:340% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:breathe 5.5s ease-in-out infinite}
.btn-ghost svg{color:var(--pink)}
.btn-ghost:hover .btn-arr{transform:translateX(6px)}
.btn-oline{
  border:2px solid transparent;color:#FFD9EB;
  background:linear-gradient(rgba(24,6,32,.42),rgba(24,6,32,.42)) padding-box,
             linear-gradient(120deg,#ED1E79,#662D8C,#FF6FB1,#ED1E79) border-box;
  background-size:100% 100%,340% 100%;
  animation:breathe 5.5s ease-in-out infinite;
}
.btn-oline:hover{transform:translateY(-3px);color:#fff;box-shadow:0 12px 38px -10px rgba(237,30,121,.55)}
.btn-oline-dark{
  border:2px solid transparent;color:var(--pink);
  background:linear-gradient(var(--bg),var(--bg)) padding-box,
             linear-gradient(120deg,#ED1E79,#662D8C,#FF6FB1,#ED1E79) border-box;
  background-size:100% 100%,340% 100%;
  animation:breathe 5.5s ease-in-out infinite;
}
.btn-oline-dark:hover{transform:translateY(-3px);box-shadow:var(--glow)}
.sec-more{display:flex;justify-content:center;margin-top:42px}

/* reveal animations — only when JS is confirmed running (html.js).
   Without JS the whole site stays fully visible. */
.js .rv,.js .rv-s,.js .rv-img{opacity:0;transform:translateY(34px);filter:blur(6px);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.js .rv-s{transform:translateY(26px) scale(.97)}
.js .rv-img{transform:translateY(0) scale(1.04);filter:blur(10px)}
.js .rv.in,.js .rv-s.in,.js .rv-img.in{opacity:1;transform:none;filter:blur(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.26s}.d4{transition-delay:.36s}

/* ════════ HERO ════════ */
.hero{
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:120px clamp(20px,5vw,72px) 150px;
  color:#fff;overflow:hidden;
  isolation:isolate;
}
.hero-bg{position:absolute;inset:0;z-index:-3}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 18s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1) translateX(0)}to{transform:scale(1.1) translateX(-2%)}}
.hero-veil{
  position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(100deg,rgba(22,6,30,.92) 0%,rgba(63,15,66,.78) 42%,rgba(102,45,140,.35) 75%,rgba(237,30,121,.18) 100%),
    linear-gradient(to top,rgba(22,6,30,.85),transparent 38%);
}
.orb{position:absolute;border-radius:50%;filter:blur(70px);z-index:-1;opacity:.55;pointer-events:none}
.orb-a{width:480px;height:480px;background:radial-gradient(circle,#ED1E79,transparent 70%);top:-120px;right:-100px;animation:drift 16s ease-in-out infinite alternate}
.orb-b{width:380px;height:380px;background:radial-gradient(circle,#662D8C,transparent 70%);bottom:0;left:-120px;animation:drift 20s ease-in-out infinite alternate-reverse}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(50px,-40px) scale(1.15)}}

.hero-inner{max-width:1180px;width:100%;margin:0 auto}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.62rem;font-weight:600;letter-spacing:.42em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);backdrop-filter:blur(8px);
  padding:10px 20px;border-radius:99px;margin-bottom:34px;
  animation:fadeUp 1s .5s var(--ease) both;
}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:#ED1E79;box-shadow:0 0 0 0 rgba(237,30,121,.7);animation:ping 1.8s infinite}
@keyframes ping{70%{box-shadow:0 0 0 12px rgba(237,30,121,0)}100%{box-shadow:0 0 0 0 rgba(237,30,121,0)}}

.hero-title{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2.7rem,8.4vw,7rem);
  line-height:1.02;letter-spacing:-.02em;
  margin-bottom:28px;
}
.hl{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em}
.hl-in{display:inline-block;transform:translateY(115%);animation:lineUp 1.1s var(--ease) forwards}
.hl:nth-child(1) .hl-in{animation-delay:.65s}
.hl:nth-child(2) .hl-in{animation-delay:.8s}
.hl:nth-child(3) .hl-in{animation-delay:.95s}
@keyframes lineUp{to{transform:translateY(0)}}
.hl-thin{font-weight:400}
.hl-thin i{font-style:italic;color:#FFB0D4}
.grad-shimmer{
  font-style:italic;
  background:linear-gradient(110deg,#FF6FB1 10%,#fff 28%,#FF3D94 46%,#C77BFF 64%,#FF6FB1 82%);
  background-size:220% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shimmer 5s linear infinite;
}
@keyframes shimmer{to{background-position:220% center}}

.hero-sub{
  max-width:520px;font-size:clamp(.98rem,1.4vw,1.12rem);font-weight:300;
  color:rgba(255,255,255,.82);margin-bottom:38px;
  animation:fadeUp 1s 1.15s var(--ease) both;
}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;animation:fadeUp 1s 1.3s var(--ease) both}
.btn-eq{width:255px;max-width:100%;justify-content:center;white-space:nowrap;padding-left:18px;padding-right:18px}
.hero-stats{
  display:flex;gap:clamp(26px,5vw,64px);margin-top:54px;padding-top:30px;
  border-top:1px solid rgba(255,255,255,.16);
  animation:fadeUp 1s 1.5s var(--ease) both;
}
.hs b{font-family:var(--display);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:600;display:block;line-height:1}
.hs i{font-style:normal;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6)}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

.marquee{
  position:absolute;left:0;right:0;bottom:0;
  border-top:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);backdrop-filter:blur(10px);
  overflow:hidden;padding:14px 0;
}
.mq-track{display:flex;gap:34px;width:max-content;animation:mq 26s linear infinite;align-items:center}
.mq-track span{font-size:.7rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.75);white-space:nowrap}
.mq-track em{color:var(--pink);font-style:normal;font-size:.8rem}
@keyframes mq{to{transform:translateX(-50%)}}

.scroll-cue{
  position:absolute;right:clamp(20px,4vw,48px);bottom:74px;
  width:44px;height:44px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);
  display:grid;place-items:center;color:#fff;
  animation:cueBob 2.2s ease-in-out infinite;
}
@keyframes cueBob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ════════ ABOUT ════════ */
.about{padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px)}
.about-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,5vw,76px);align-items:center;
}
.about-media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.about-media img{width:100%;height:100%;min-height:420px;object-fit:cover;transition:transform .8s var(--ease)}
.about-media:hover img{transform:scale(1.05)}
.about-chip{
  position:absolute;left:18px;bottom:18px;
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(8px);
  color:var(--purple);font-size:.66rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  padding:10px 16px;border-radius:99px;
}
.about-chip svg{color:var(--pink)}
.about-copy .lead{font-size:1.16rem;font-weight:400;color:var(--text);margin-bottom:16px;line-height:1.7}
.about-copy .body{color:var(--text2);margin-bottom:24px}
.about-copy blockquote{
  font-family:var(--display);font-style:italic;font-size:1.3rem;
  border-left:3px solid;border-image:var(--grad) 1;
  padding-left:20px;margin-bottom:26px;color:var(--text);
}

/* ════════ ACRONYM — ALWAYS ONE LINE ════════ */
.acro{
  padding:clamp(80px,10vw,130px) clamp(14px,3vw,48px);
  background:
    radial-gradient(70% 90% at 80% 10%,rgba(237,30,121,.07),transparent 60%),
    radial-gradient(60% 80% at 10% 90%,rgba(102,45,140,.07),transparent 60%),
    var(--surface);
  text-align:center;
}
.acro-row{
  display:flex;flex-wrap:nowrap;justify-content:center;
  gap:clamp(6px,1.6vw,22px);
  max-width:1180px;margin:38px auto 0;
}
.acro-card{
  flex:1 1 0;min-width:0;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:clamp(10px,1.6vw,18px);
  padding:clamp(14px,3vw,40px) clamp(2px,.8vw,12px) clamp(12px,2.4vw,30px);
  transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;
  position:relative;overflow:hidden;
}
.acro-card::before{
  content:'';position:absolute;inset:0;
  background:var(--grad-soft);
  opacity:0;transition:opacity .4s;
}
.acro-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.acro-card:hover::before{opacity:1}
.acro-letter{
  position:relative;display:block;
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.5rem,6.4vw,4.4rem);line-height:1;
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.acro-word{
  position:relative;display:block;margin-top:clamp(4px,1vw,14px);
  font-size:clamp(.46rem,1.55vw,1rem);font-weight:600;
  color:var(--text);white-space:nowrap;
}
.acro-note{margin-top:34px;color:var(--text2);font-size:1.05rem}
.acro-note em{font-family:var(--display);font-style:italic;color:var(--text)}
.acro-note b{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ════════ PROGRAMS — full-image cards ════════ */
.impact{padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px)}
.prog-grid{
  max-width:1180px;margin:46px auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);
}
.prog{
  position:relative;border-radius:var(--r);overflow:hidden;
  aspect-ratio:3/4;cursor:pointer;
  transform-style:preserve-3d;
  outline-offset:4px;
}
.prog img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease);
}
.prog:hover img,.prog.on img,.prog:focus-visible img{transform:scale(1.09)}
.prog-shade{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,5,28,.92) 0%,rgba(20,5,28,.45) 38%,rgba(20,5,28,.05) 65%,transparent 100%);
  transition:background .5s;
}
.prog:hover .prog-shade,.prog.on .prog-shade,.prog:focus-visible .prog-shade{
  background:linear-gradient(to top,rgba(72,10,62,.96) 0%,rgba(58,14,66,.72) 50%,rgba(30,8,38,.3) 100%);
}
.prog-bottom{
  position:absolute;left:0;right:0;bottom:0;
  padding:clamp(18px,2.4vw,28px);color:#fff;
}
.prog-cat{
  display:block;font-size:.6rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;
  color:#FF9AC8;margin-bottom:8px;
}
.prog-name{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,2.6vw,2.3rem);line-height:1;
  transition:transform .45s var(--ease);
}
.prog-more{
  max-height:0;opacity:0;overflow:hidden;
  transform:translateY(14px);
  transition:max-height .55s var(--ease),opacity .45s,transform .55s var(--ease);
}
.prog:hover .prog-more,.prog.on .prog-more,.prog:focus-visible .prog-more{
  max-height:280px;opacity:1;transform:translateY(0);margin-top:14px;
}
.pm-tag{font-family:var(--display);font-style:italic;font-size:.98rem;line-height:1.5;margin-bottom:8px}
.pm-tag em{color:#FF6FB1}
.pm-line{font-size:.84rem;font-weight:300;color:rgba(255,255,255,.78);margin-bottom:12px}
.pm-link{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.64rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#FF9AC8;
}
.pm-link svg{transition:transform .3s}
.prog:hover .pm-link svg{transform:translateX(4px)}

/* ════════ HOW ════════ */
.how{padding:clamp(80px,10vw,130px) clamp(20px,4vw,48px);background:var(--surface)}
.how-grid{max-width:1180px;margin:44px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.how-card{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--r);
  padding:0 0 26px;overflow:hidden;position:relative;
  transition:transform .45s var(--ease),box-shadow .45s;
}
.how-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.how-img{height:190px;overflow:hidden}
.how-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.how-card:hover .how-img img{transform:scale(1.07)}
.how-num{
  position:absolute;top:160px;right:20px;
  font-family:var(--display);font-style:italic;font-size:2.2rem;font-weight:700;color:#fff;
  text-shadow:0 4px 18px rgba(0,0,0,.4);
}
.how-card h3{font-family:var(--display);font-size:1.34rem;font-weight:600;margin:20px 24px 8px}
.how-card p{font-size:.92rem;color:var(--text2);margin:0 24px}

/* ════════ VOICES ════════ */
.voices{
  padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px);
  background:linear-gradient(135deg,#3A0F42 0%,#662D8C 55%,#8E2475 100%);
  text-align:center;overflow:hidden;
}
.voices-orbs span{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;pointer-events:none}
.voices-orbs span:nth-child(1){width:420px;height:420px;background:#ED1E79;top:-140px;left:-120px;animation:drift 18s ease-in-out infinite alternate}
.voices-orbs span:nth-child(2){width:360px;height:360px;background:#41147F;bottom:-120px;right:-100px;animation:drift 22s ease-in-out infinite alternate-reverse}
.v-carousel{max-width:760px;margin:40px auto 0;position:relative;min-height:330px}
.vslide{
  position:absolute;inset:0;
  opacity:0;transform:translateY(22px) scale(.98);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  pointer-events:none;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.vslide.on{opacity:1;transform:none;pointer-events:auto}
.vslide img{
  width:84px;height:84px;border-radius:50%;object-fit:cover;
  border:3px solid rgba(255,255,255,.35);
  box-shadow:0 10px 34px -8px rgba(0,0,0,.5);
}
.vslide blockquote{
  font-family:var(--display);font-style:italic;font-weight:500;
  font-size:clamp(1.15rem,2.3vw,1.65rem);line-height:1.55;color:#fff;
}
.vslide figcaption{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:#FF9AC8;font-weight:600}
.v-controls{display:flex;align-items:center;justify-content:center;margin-top:36px}
.v-controls button{
  width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(255,255,255,.3);color:#fff;
  display:grid;place-items:center;
  transition:background .3s,transform .3s;
}
.v-controls button:hover{background:rgba(255,255,255,.14);transform:scale(1.08)}
.v-pips{display:flex;gap:8px}
.vpip{width:8px;height:8px;border-radius:99px;background:rgba(255,255,255,.3);transition:width .4s var(--ease),background .4s;cursor:pointer}
.vpip.on{width:26px;background:#fff}

/* ════════ INSIGHTS ════════ */
.insights{padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px)}
.ins-grid{max-width:1180px;margin:44px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.8vw,22px)}
.ins{
  position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4.2;cursor:pointer;
}
.ins img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.ins:hover img{transform:scale(1.08)}
.ins-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,5,28,.94) 0%,rgba(20,5,28,.4) 45%,transparent 75%)}
.ins-bottom{position:absolute;left:0;right:0;bottom:0;padding:20px;color:#fff}
.ins-tag{display:block;font-size:.58rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#FF9AC8;margin-bottom:8px}
.ins-bottom h3{font-family:var(--display);font-size:1.05rem;font-weight:600;line-height:1.35;margin-bottom:10px}
.ins .pm-link{opacity:0;transform:translateY(8px);transition:.4s var(--ease)}
.ins:hover .pm-link{opacity:1;transform:none}

/* ════════ RESOURCES ════════ */
.resources{padding:clamp(80px,10vw,130px) clamp(20px,4vw,48px);background:var(--surface)}
.rs-grid{max-width:1180px;margin:44px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px)}
.rs{
  position:relative;display:block;
  background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r);
  padding:24px 24px 22px;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s,border-color .45s;
}
.rs::after{
  content:'';position:absolute;inset:0;
  background:var(--grad-soft);opacity:0;transition:opacity .45s;
}
.rs:hover{transform:translateY(-7px);box-shadow:var(--glow);border-color:rgba(237,30,121,.45)}
.rs:hover::after{opacity:1}
.rs>*{position:relative;z-index:1}
.rs-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.rs-ic{
  width:44px;height:44px;border-radius:13px;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(120deg,#ED1E79,#662D8C);
  box-shadow:0 8px 22px -6px rgba(237,30,121,.5);
  transition:transform .4s var(--ease);
}
.rs:hover .rs-ic{transform:scale(1.08) rotate(-5deg)}
.rs-tag{
  font-size:.56rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;
  color:var(--pink);background:rgba(237,30,121,.09);
  padding:5px 12px;border-radius:99px;
}
.rs h3{font-family:var(--display);font-size:1.3rem;font-weight:600;margin-bottom:6px}
.rs .rs-num{font-size:2.2rem;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.rs p{font-size:.88rem;color:var(--text2);margin-bottom:14px}
.rs-go{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);
}
.rs-go svg{transition:transform .3s}
.rs:hover .rs-go svg{transform:translateX(5px)}

/* ════════ GALLERY ════════ */
.gallery{padding:clamp(80px,10vw,130px) clamp(14px,3vw,48px)}
.gl-strip{
  max-width:1280px;margin:40px auto 0;
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:clamp(130px,14vw,210px);
  grid-auto-flow:dense;
  gap:clamp(10px,1.4vw,18px);
}
.gl{border-radius:calc(var(--r) - 6px);overflow:hidden;position:relative}
/* masonry pattern: 4+2+2+4+12 singles = 24 cells = exactly 6 full rows of 4 */
.gl:nth-child(1){grid-column:span 2;grid-row:span 2}
.gl:nth-child(4){grid-row:span 2}
.gl:nth-child(8){grid-row:span 2}
.gl:nth-child(10){grid-column:span 2;grid-row:span 2}
.gl img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .6s}
.gl:hover img{transform:scale(1.07)}
.gl::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(102,45,140,.35),transparent 55%);opacity:0;transition:.4s}
.gl:hover::after{opacity:1}

/* ════════ JOIN (style preserved) ════════ */
.join{
  position:relative;overflow:hidden;
  padding:clamp(90px,12vw,160px) clamp(20px,4vw,48px);
  color:#fff;
}
.join-bg{position:absolute;inset:0;z-index:-2}
.join-bg img{width:100%;height:100%;object-fit:cover}
.join::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,rgba(38,8,52,.95) 0%,rgba(91,17,84,.9) 50%,rgba(112,20,78,.85) 100%);
}
.join-inner{max-width:1180px;margin:0 auto}
.join-sub{max-width:620px;color:rgba(255,255,255,.85);font-weight:300;font-size:1.05rem;margin-bottom:44px}
.join-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px);margin-bottom:48px}
.join-card{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
  border-radius:var(--r);padding:26px 24px;
  transition:transform .4s var(--ease),background .4s,border-color .4s;
}
.join-card:hover{transform:translateY(-8px);background:rgba(255,255,255,.12);border-color:rgba(255,154,200,.4)}
.jn-num{font-family:var(--display);font-style:italic;font-size:1.5rem;font-weight:700;color:#FF6FB1}
.join-card h3{font-family:var(--display);font-size:1.22rem;font-weight:600;margin:10px 0 8px}
.join-card p{font-size:.88rem;font-weight:300;color:rgba(255,255,255,.78)}
.join-cta{display:flex;gap:16px;flex-wrap:wrap}

/* ════════ TRUST ════════ */
.trust{padding:clamp(80px,10vw,130px) clamp(20px,4vw,48px);background:var(--surface)}
.tr-grid{max-width:1180px;margin:44px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px)}
.tr{
  position:relative;display:block;overflow:hidden;
  background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r);
  padding:28px 26px 24px;
  transition:transform .45s var(--ease),box-shadow .45s,border-color .45s;
}
.tr::before{
  content:'';position:absolute;left:0;right:0;top:0;height:4px;
  background:linear-gradient(120deg,#ED1E79,#662D8C,#FF6FB1,#ED1E79);
  background-size:340% 100%;animation:breathe 6s ease-in-out infinite;
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.tr:hover{transform:translateY(-7px);box-shadow:var(--glow);border-color:rgba(237,30,121,.4)}
.tr:hover::before{transform:scaleX(1)}
.tr-ghost{
  position:absolute;right:-26px;top:-26px;color:var(--purple);opacity:.05;
  transform:rotate(12deg);transition:transform .6s var(--ease),opacity .6s;
  pointer-events:none;
}
.tr:hover .tr-ghost{transform:rotate(2deg) scale(1.08);opacity:.09}
.tr-ic{
  position:relative;width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;color:#fff;margin-bottom:18px;
  background:linear-gradient(120deg,#ED1E79,#662D8C);
  box-shadow:0 8px 22px -6px rgba(237,30,121,.5);
  transition:transform .4s var(--ease);
}
.tr:hover .tr-ic{transform:scale(1.08) rotate(-5deg)}
.tr h3{position:relative;font-family:var(--display);font-size:1.18rem;font-weight:600;margin-bottom:8px}
.tr p{position:relative;font-size:.88rem;color:var(--text2);margin-bottom:16px}
.tr-go{
  position:relative;display:inline-flex;align-items:center;gap:7px;
  font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);
}
.tr-go svg{transition:transform .3s}
.tr:hover .tr-go svg{transform:translateX(5px)}

/* ════════ TEAM — editorial, no patches ════════ */
.team{padding:clamp(80px,10vw,130px) clamp(20px,4vw,48px)}
.tm-grid{max-width:1180px;margin:54px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,40px)}
.tm{margin:0}
.tm-photo{
  position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/4.7;
  box-shadow:0 18px 50px -22px rgba(102,45,140,.35);
}
.tm-photo::before{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(160deg,rgba(237,30,121,.22),rgba(102,45,140,.30));
  mix-blend-mode:multiply;transition:opacity .6s var(--ease);
}
.tm-photo::after{
  content:'';position:absolute;inset:0;z-index:3;border-radius:var(--r);
  border:2px solid transparent;
  transition:border-color .5s var(--ease);
}
.tm-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.35) contrast(1.02);
  transition:filter .7s var(--ease),transform .9s var(--ease);
}
.tm:hover .tm-photo img{filter:grayscale(0);transform:scale(1.06)}
.tm:hover .tm-photo::before{opacity:0}
.tm:hover .tm-photo::after{border-color:rgba(237,30,121,.55)}
.tm-idx{
  position:absolute;z-index:4;top:16px;right:18px;
  font-family:var(--display);font-style:italic;font-weight:700;font-size:1.3rem;
  color:rgba(255,255,255,.85);text-shadow:0 4px 16px rgba(0,0,0,.45);
}
.tm figcaption{padding:18px 6px 0}
.tm-role{
  display:block;width:fit-content;font-size:.6rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.tm-name{font-family:var(--display);font-weight:600;font-size:1.35rem;line-height:1.2;position:relative;display:inline-block}
.tm-name::after{
  content:'';position:absolute;left:0;bottom:-6px;height:2px;width:100%;
  background:var(--grad);border-radius:2px;
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.tm:hover .tm-name::after{transform:scaleX(1)}
@media(min-width:901px){
  .tm:nth-child(2),.tm:nth-child(5){margin-top:40px}
}

/* ════════ DONATE ════════ */
.donate{
  padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px);
  background:linear-gradient(125deg,#ED1E79 0%,#A8268B 48%,#662D8C 100%);
  color:#fff;overflow:hidden;position:relative;
}
.donate::before{
  content:'';position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);
  top:-200px;right:-160px;
}
.dn-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(36px,5vw,70px);align-items:center}
.dn-sub{color:rgba(255,255,255,.88);font-weight:300;margin-bottom:30px;max-width:480px}
.dn-amounts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:30px;max-width:520px}
.dn-amt{
  text-align:left;border:1.5px solid rgba(255,255,255,.3);border-radius:16px;
  padding:16px 18px;color:#fff;
  transition:background .3s,border-color .3s,transform .3s;
}
.dn-amt b{font-family:var(--display);font-size:1.3rem;display:block}
.dn-amt i{font-style:normal;font-size:.72rem;color:rgba(255,255,255,.75)}
.dn-amt:hover{transform:translateY(-3px);border-color:#fff}
.dn-amt.active{background:#fff;color:var(--purple);border-color:#fff}
.dn-amt.active i{color:rgba(102,45,140,.7)}
.dn-cta{display:flex;gap:16px;flex-wrap:wrap}
.dn-media{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
.dn-media img{width:100%;height:100%;min-height:430px;object-fit:cover}
.dn-quote{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(to top,rgba(20,5,28,.92),transparent);
  padding:60px 26px 26px;
}
.dn-quote p{font-family:var(--display);font-style:italic;font-size:1.12rem;line-height:1.55}
.dn-quote em{color:#FF9AC8}

/* ════════ CONTACT ════════ */
.contact{padding:clamp(90px,12vw,150px) clamp(20px,4vw,48px)}
.ct-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(36px,5vw,76px);align-items:start}
.ct-links{display:flex;flex-direction:column;margin-top:26px;border-top:1px solid var(--line)}
.ct-link{
  display:flex;align-items:center;gap:18px;
  padding:20px 4px;border-bottom:1px solid var(--line);
  transition:padding-left .35s var(--ease);
  position:relative;
}
.ct-link:hover{padding-left:14px}
.ct-ic{
  width:46px;height:46px;border-radius:50%;flex:none;
  display:grid;place-items:center;
  background:var(--grad-soft);color:var(--pink);
  transition:background .35s,color .35s,transform .35s;
}
.ct-link:hover .ct-ic{background:var(--grad);color:#fff;transform:scale(1.06)}
.ct-val{font-size:1.06rem;font-weight:500}
.ct-arr{margin-left:auto;color:var(--pink);opacity:0;transform:translateX(-8px);transition:.35s var(--ease)}
.ct-link:hover .ct-arr{opacity:1;transform:none}
.ct-social{display:flex;gap:10px;margin-top:26px}
.ct-social a{
  width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);color:var(--text2);
  display:grid;place-items:center;
  transition:all .3s var(--ease);
}
.ct-social a:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-4px)}
.ct-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:30px;box-shadow:var(--shadow);
  position:sticky;top:100px;
}
.ct-card-l{
  display:flex;align-items:center;gap:8px;
  font-size:.62rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--pink);
  margin:18px 0 8px;
}
.ct-card-l:first-child{margin-top:0}
.ct-card p{font-size:.94rem;color:var(--text2);line-height:1.7}

/* ════════ FOOTER ════════ */
footer{
  background:var(--surface);
  border-top:1px solid var(--line);
  padding:60px clamp(20px,4vw,48px) 110px;
  position:relative;
}
footer::before{content:'';position:absolute;top:-1px;left:0;right:0;height:3px;background:var(--grad)}
.ft-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(30px,4vw,60px)}
.ft-logo{height:40px;width:auto;margin-bottom:16px}
.ft-brand p{font-size:.9rem;color:var(--text2);max-width:300px;margin-bottom:18px}
.ft-social{display:flex;gap:9px}
.ft-social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line);color:var(--text2);
  display:grid;place-items:center;
  transition:all .3s var(--ease);
}
.ft-social a:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-3px)}
.ft-col{display:flex;flex-direction:column;gap:9px}
.ft-l{font-size:.62rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--pink);margin-bottom:6px}
.ft-col a{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--text2);transition:color .25s,padding-left .25s}
.ft-col a svg{color:var(--pink);flex:none;opacity:.85}
.ft-col a:hover{color:var(--pink);padding-left:5px}
/* policies dropdown (opens upward) */
.ft-pol{position:relative}
.ft-pol-l{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--text2);padding:0;transition:color .25s}
.ft-pol-l svg:first-child{color:var(--pink);opacity:.85}
.ft-pol-ch{transition:transform .3s;transform:rotate(180deg)}
.ft-pol:hover .ft-pol-l,.ft-pol.open .ft-pol-l{color:var(--pink)}
.ft-pol:hover .ft-pol-ch,.ft-pol.open .ft-pol-ch{transform:rotate(0deg)}
.ft-pol-menu{
  position:absolute;left:0;bottom:calc(100% + 10px);
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);padding:8px;min-width:220px;
  display:none;flex-direction:column;gap:2px;z-index:30;
}
.ft-pol:hover .ft-pol-menu,.ft-pol.open .ft-pol-menu{display:flex;animation:langIn .25s var(--ease)}
.ft-pol-menu a{padding:9px 12px;border-radius:9px;font-size:.86rem}
.ft-pol-menu a:hover{background:var(--grad-soft);padding-left:12px}
.ft-bottom{
  max-width:1180px;margin:44px auto 0;padding-top:22px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-size:.74rem;color:var(--text2);
}
.ft-bottom svg{color:var(--pink)}

/* ════════ FIXED APP BOTTOM MENU (≤1024px) ════════ */
.bottom-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:890;
  display:none;
  grid-template-columns:repeat(7,1fr);
  align-items:end;
  background:var(--surface);
  border-top:1px solid var(--line);
  box-shadow:0 -12px 40px -18px rgba(102,45,140,.35);
  padding:8px 4px calc(8px + env(safe-area-inset-bottom));
}
.bb-item{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--text2);padding:4px 2px;
  font-size:.56rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  transition:color .3s;
}
.bb-item:hover,.bb-item:active{color:var(--pink)}
.bb-join{color:var(--text);font-weight:700}
.bb-join-ic{
  width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(120deg,#ED1E79,#A8268B,#662D8C,#FF4D9E,#ED1E79);
  background-size:340% 100%;animation:breathe 5.5s ease-in-out infinite;
  box-shadow:0 10px 26px -6px rgba(237,30,121,.6);
  margin-top:-26px;margin-bottom:2px;
  border:3px solid var(--surface);
  transition:transform .3s var(--ease);
}
.bb-join:active .bb-join-ic{transform:scale(.94)}
@media(max-width:1024px){
  .bottom-bar{display:grid}
}

/* ════════ RESPONSIVE ════════ */
@media(max-width:1080px){
  .prog-grid{grid-template-columns:repeat(2,1fr)}
  .ins-grid{grid-template-columns:repeat(2,1fr)}
  .join-grid{grid-template-columns:repeat(2,1fr)}
  .tm-grid{grid-template-columns:repeat(2,1fr)}
  .tr-grid,.rs-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .nav-menu{display:none}
  .nav-right{margin-left:auto}
  .about-grid,.dn-grid,.ct-grid{grid-template-columns:1fr}
  .ct-card{position:static}
  .how-grid{grid-template-columns:1fr;max-width:520px}
  .gl-strip{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(120px,24vw,200px)}
  .gl:nth-child(10){grid-column:span 2;grid-row:span 1}
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-brand{grid-column:1/-1}
}
@media(max-width:1024px){
  footer{padding-bottom:120px}
}
@media(max-width:640px){
  .nav-donate span{display:none}
  .nav-donate{padding:11px}
  .prog-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}
  .prog{aspect-ratio:4/4.6}
  .ins-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}
  .rs-grid,.tr-grid{grid-template-columns:1fr}
  .tm-grid{grid-template-columns:1fr 1fr;gap:12px}
  .tm-info{left:8px;right:8px;bottom:8px;padding:10px 12px}
  .tm-info h3{font-size:.92rem}
  .dn-amounts{grid-template-columns:1fr 1fr}
  .hero-stats{gap:22px}
  .scroll-cue{display:none}
  .v-carousel{min-height:400px}
}
@media(max-width:400px){
  .hero-title{font-size:2.4rem}
  .dn-amounts{grid-template-columns:1fr}
}

/* ════════ REDUCED MOTION ════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .rv,.rv-s,.rv-img{opacity:1;transform:none;filter:none}
  .hl-in{transform:none}
}

/* ════════ GOOGLE TRANSLATE (engine hidden, our UI only) ════════ */
#google_translate_element{visibility:hidden!important;position:absolute!important;width:0!important;height:0!important;overflow:hidden!important}
.goog-te-banner-frame,.skiptranslate,#goog-gt-tt,.goog-te-balloon-frame{display:none!important}
.goog-text-highlight{background:none!important;box-shadow:none!important}
body{top:0!important}
font[style*="vertical-align"]{vertical-align:baseline!important}

/* ════════ SUB PAGES ════════ */
.pg-hero{
  padding:150px clamp(20px,5vw,72px) 70px;color:#fff;text-align:left;position:relative;overflow:hidden;
  background:linear-gradient(125deg,#3A0F42 0%,#662D8C 50%,#B41E72 100%);
}
.pg-hero::after{content:'';position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 70%);top:-180px;right:-140px}
.pg-hero-inner{max-width:980px;margin:0 auto;position:relative;z-index:1}
.pg-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,5.4vw,3.8rem);line-height:1.1;margin:14px 0 14px}
.pg-hero p{max-width:620px;color:rgba(255,255,255,.85);font-weight:300;font-size:1.04rem}
.pg-wrap{max-width:980px;margin:0 auto;padding:clamp(50px,7vw,90px) clamp(20px,4vw,48px)}
.pg-card{
  background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r);
  padding:clamp(24px,3.4vw,38px);margin-bottom:22px;
  transition:transform .4s var(--ease),box-shadow .4s;
}
.pg-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pg-card h2{font-family:var(--display);font-size:clamp(1.25rem,2.4vw,1.7rem);font-weight:600;margin-bottom:10px}
.pg-card p{color:var(--text2);font-size:.98rem}
.pg-card p+p{margin-top:10px}
.pg-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:34px}
.pg-soon{
  text-align:center;padding:clamp(50px,8vw,90px) clamp(24px,4vw,40px);
}
.pg-soon .orbit{position:relative;width:120px;height:120px;margin:0 auto 28px}
.pg-soon .orbit span{position:absolute;inset:0;border-radius:50%;border:1.5px dashed rgba(237,30,121,.4);animation:orbit 9s linear infinite}
.pg-soon .orbit svg{position:absolute;inset:0;margin:auto;color:var(--pink)}
.pg-soon h2{font-family:var(--display);font-size:clamp(1.6rem,3.6vw,2.4rem);font-weight:600;margin-bottom:12px}
.pg-soon p{color:var(--text2);max-width:480px;margin:0 auto 8px}
.pg-call{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--display);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:#fff;
  background:linear-gradient(120deg,#ED1E79,#A8268B,#662D8C,#FF4D9E,#ED1E79);
  background-size:340% 100%;animation:breathe 5.5s ease-in-out infinite;
  padding:18px 38px;border-radius:99px;box-shadow:var(--glow);
  transition:transform .3s var(--ease);
}
.pg-call:hover{transform:translateY(-4px) scale(1.02)}
.pg-nav-back{display:inline-flex;align-items:center;gap:8px;font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.pg-nav-back svg{transform:rotate(180deg)}
.pg-footer{padding:34px 20px calc(34px + env(safe-area-inset-bottom));text-align:center;border-top:1px solid var(--line);font-size:.74rem;color:var(--text2)}

/* ════════ JOIN UDAAN FORCE + EVENTS components ════════ */
.jx-grid{max-width:1180px;margin:44px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.jx-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/4.4;cursor:pointer;text-align:left;display:block;width:100%}
.jx-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.jx-card:hover img{transform:scale(1.08)}
.jx-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,5,28,.93) 0%,rgba(20,5,28,.45) 45%,rgba(20,5,28,.08) 75%);transition:background .5s}
.jx-card:hover .jx-shade{background:linear-gradient(to top,rgba(72,10,62,.96) 0%,rgba(58,14,66,.7) 55%,rgba(30,8,38,.3) 100%)}
.jx-body{position:absolute;left:0;right:0;bottom:0;padding:clamp(18px,2.4vw,26px);color:#fff}
.jx-ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.14);backdrop-filter:blur(8px);margin-bottom:14px;transition:transform .45s var(--ease),background .45s}
.jx-card:hover .jx-ic{transform:scale(1.1) translateY(-4px);background:rgba(255,255,255,.24)}
.jx-body h3{font-family:var(--display);font-weight:600;font-size:1.5rem;margin-bottom:6px}
.jx-body p{font-size:.86rem;font-weight:300;color:rgba(255,255,255,.85);margin-bottom:12px}
/* modal */
.jx-mb{position:fixed;inset:0;z-index:990;background:rgba(20,8,26,.7);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:18px;overflow-y:auto}
.jx-mb.on{display:flex}
.jx-modal{background:var(--surface);border-radius:24px;width:100%;max-width:560px;margin:auto;overflow:hidden;box-shadow:var(--shadow);animation:jxIn .5s var(--ease)}
@keyframes jxIn{from{opacity:0;transform:translateY(36px) scale(.96)}to{opacity:1;transform:none}}
.jx-mhd{background:linear-gradient(120deg,#ED1E79,#A8268B,#662D8C);padding:24px;position:relative;color:#fff}
.jx-mhd h2{font-family:var(--display);font-size:1.4rem;font-weight:600;padding-right:46px}
.jx-mhd p{font-size:.82rem;color:rgba(255,255,255,.85);margin-top:4px}
.jx-close{position:absolute;top:22px;right:18px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;display:grid;place-items:center;transition:transform .3s,background .3s}
.jx-close:hover{background:rgba(255,255,255,.35);transform:scale(1.1)}
.jx-prog{display:flex;justify-content:space-between;position:relative;padding:18px 30px;background:var(--bg);border-bottom:1px solid var(--line)}
.jx-prog::before{content:'';position:absolute;top:33px;left:50px;right:50px;height:3px;background:var(--line);border-radius:3px}
.jx-pl{position:absolute;top:33px;left:50px;height:3px;background:var(--grad);border-radius:3px;transition:width .5s var(--ease);width:0;max-width:calc(100% - 100px)}
.jx-step{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;position:relative;z-index:2}
.jx-sd{width:32px;height:32px;border-radius:50%;background:var(--surface);border:3px solid var(--line);display:grid;place-items:center;font-weight:700;font-size:.7rem;color:var(--text2);transition:all .4s var(--ease)}
.jx-step.act .jx-sd{background:var(--grad);border-color:var(--pink);color:#fff;transform:scale(1.12)}
.jx-step.dn .jx-sd{background:#10B981;border-color:#10B981;color:#fff}
.jx-sla{font-size:.56rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text2)}
.jx-step.act .jx-sla{color:var(--pink)}
.jx-body-form{padding:24px}
.jx-fs{display:none;animation:jxSl .4s var(--ease)}
.jx-fs.act{display:block}
@keyframes jxSl{from{opacity:0;transform:translateX(26px)}to{opacity:1;transform:none}}
.jx-fld{margin-bottom:18px}
.jx-lbl{display:block;font-size:.84rem;font-weight:600;margin-bottom:6px}
.jx-lbl b{color:var(--pink)}
.jx-inp,.jx-ta{width:100%;padding:13px 16px;font:inherit;font-size:.92rem;border:2px solid var(--line);border-radius:12px;background:var(--surface);color:var(--text);transition:border-color .3s,box-shadow .3s}
.jx-inp:focus,.jx-ta:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px rgba(237,30,121,.12)}
.jx-inp.err,.jx-ta.err{border-color:#ef4444;animation:jxSh .4s}
@keyframes jxSh{0%,100%{transform:translateX(0)}25%{transform:translateX(-7px)}75%{transform:translateX(7px)}}
.jx-ta{resize:vertical;min-height:96px}
.jx-er{color:#ef4444;font-size:.76rem;margin-top:5px;display:none;font-weight:500}
.jx-er.sh{display:block}
.jx-fb{display:flex;gap:12px;margin-top:6px}
.jx-btn{flex:1;padding:13px 20px;border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .3s var(--ease),box-shadow .3s}
.jx-bb{background:var(--bg);border:1.5px solid var(--line)}
.jx-bn{background:linear-gradient(120deg,#ED1E79,#A8268B,#662D8C,#FF4D9E,#ED1E79);background-size:340% 100%;animation:breathe 5.5s ease-in-out infinite;color:#fff;box-shadow:var(--glow)}
.jx-bn:hover{transform:translateY(-2px)}
.jx-btn:disabled{opacity:.55;pointer-events:none}
.jx-suc{display:none;text-align:center;padding:44px 26px}
.jx-suc.on{display:block;animation:jxIn .5s var(--ease)}
.jx-schk{width:74px;height:74px;border-radius:50%;background:linear-gradient(135deg,#10B981,#059669);display:grid;place-items:center;color:#fff;margin:0 auto 20px;animation:jxPop .5s var(--ease)}
@keyframes jxPop{from{transform:scale(0)}to{transform:scale(1)}}
.jx-suc h3{font-family:var(--display);font-size:1.5rem;font-weight:600;margin-bottom:10px}
.jx-suc p{color:var(--text2);font-size:.92rem;margin-bottom:22px}
/* events */
.ev-grid{max-width:1180px;margin:40px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px)}
.ev-card{display:flex;gap:20px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r);padding:24px;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;position:relative;overflow:hidden}
.ev-card:hover{transform:translateY(-6px);box-shadow:var(--glow);border-color:rgba(237,30,121,.4)}
.ev-date{flex:none;width:74px;height:84px;border-radius:16px;background:linear-gradient(135deg,#ED1E79,#662D8C);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 10px 26px -8px rgba(237,30,121,.55)}
.ev-date b{font-family:var(--display);font-size:1.8rem;line-height:1}
.ev-date i{font-style:normal;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase}
.ev-info h3{font-family:var(--display);font-size:1.2rem;font-weight:600;margin-bottom:4px}
.ev-meta{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--pink);margin-bottom:8px;display:block}
.ev-info p{font-size:.88rem;color:var(--text2)}
.ev-badge{position:absolute;top:14px;right:14px;font-size:.56rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#ED1E79,#662D8C);padding:5px 11px;border-radius:99px}
.ev-past{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.ev-past img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ev-past:hover img{transform:scale(1.07)}
.ev-past-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,5,28,.92),rgba(20,5,28,.25) 60%,transparent)}
.ev-past-info{position:absolute;left:0;right:0;bottom:0;padding:20px;color:#fff}
.ev-past-info h3{font-family:var(--display);font-size:1.15rem;font-weight:600;margin-bottom:4px}
.ev-past-info span{font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#FF9AC8;display:block;margin-bottom:6px}
.ev-past-info p{font-size:.8rem;color:rgba(255,255,255,.82)}
.ev-past-grid{max-width:1180px;margin:36px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px)}
.ev-host{max-width:1180px;margin:70px auto 0;border-radius:28px;padding:clamp(34px,5vw,60px);text-align:center;color:#fff;position:relative;overflow:hidden;background:linear-gradient(135deg,#3A0F42,#662D8C 55%,#B41E72)}
.ev-host::before{content:'';position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.1);top:-150px;right:-90px}
.ev-host>*{position:relative;z-index:1}
.ev-host h2{font-family:var(--display);font-size:clamp(1.6rem,3.6vw,2.5rem);font-weight:600;margin-bottom:12px}
.ev-host p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 26px;font-weight:300}
@media(max-width:900px){.jx-grid{grid-template-columns:repeat(2,1fr)}.ev-grid{grid-template-columns:1fr}.ev-past-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.jx-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}.ev-past-grid{grid-template-columns:1fr}.jx-fb{flex-direction:column}}

/* ════════ DESKTOP DRAWER: all options visible, language compact+scrollable ════════ */
@media(min-width:1025px){
  #sideMenu{width:440px;padding:64px 38px 28px}
  .sm-nav{overflow:visible;flex:none}
  .sm-link{font-size:1.06rem;padding:5px 0;gap:12px}
  .sm-lang{margin-top:16px;padding-top:14px}
  .sm-lang-grid{max-height:clamp(96px,20vh,160px);overflow-y:auto;padding-right:6px}
  .sm-lang-grid::-webkit-scrollbar{width:5px}
  .sm-lang-grid::-webkit-scrollbar-thumb{background:var(--grad);border-radius:5px}
  .sm-social{padding-top:14px}
  .sm-social a{width:36px;height:36px}
}
