﻿/* ============================================================
   SRI KOLLU RAVINDRA â€” PREMIUM MINISTER PORTAL
   TDP theme Â· Gold #FFC20E + Red #D6342C
   Heavy on motion: aurora hero, orbs, tilt cards, drawing
   timeline, shine buttons, staggered reveals.
   ============================================================ */
:root{
  --yellow:#FFC20E; --yellow-deep:#E8A800; --yellow-soft:#FFE08A;
  --red:#E0322A; --red-deep:#B0261F;
  --ink:#16161f; --muted:#5d6470; --line:#e9ebf1;
  --bg:#ffffff; --bg-alt:#fbfaf4; --dark:#0d0d15;
  --shadow:0 24px 60px -24px rgba(20,20,35,.35);
  --glow-y:0 0 40px rgba(255,194,14,.55);
  --glow-r:0 0 40px rgba(224,50,42,.45);
  --radius:18px; --maxw:1500px;
  --te:'Noto Sans Telugu',sans-serif;
  --grad:linear-gradient(100deg,var(--yellow) 0%,var(--red) 100%);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',var(--te);color:var(--ink);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
body.lang-te,body.lang-te *{font-family:var(--te)!important}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,60px)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Poppins','Inter',var(--te);line-height:1.12;letter-spacing:-.02em}
::selection{background:var(--yellow);color:#1a1300}

/* ---- DARK MODE ---- */
body.dark{--ink:#eef0f6;--muted:#a9aebd;--line:#262838;--bg:#0c0d15;--bg-alt:#12131e;--dark:#07070d;
  --shadow:0 24px 60px -22px rgba(0,0,0,.8)}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--dark);display:flex;
  flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .6s,visibility .6s}
.preloader.done{opacity:0;visibility:hidden}
.preloader__logo{font-size:3rem;animation:ride 1.6s ease-in-out infinite}
@keyframes ride{0%{transform:translateX(-45vw) translateY(0) rotate(-4deg)}
  50%{transform:translateX(0) translateY(-14px) rotate(4deg)}
  100%{transform:translateX(45vw) translateY(0) rotate(-4deg)}}
.preloader__bar{width:200px;height:5px;background:rgba(255,255,255,.15);border-radius:99px;overflow:hidden}
.preloader__bar i{display:block;height:100%;width:0;background:var(--grad);border-radius:99px;animation:load 1.6s ease forwards}
@keyframes load{to{width:100%}}
.preloader__txt{font-family:'Poppins';font-weight:700;color:var(--yellow);letter-spacing:.25em;
  text-transform:uppercase;font-size:.85rem}


/* ============================================================
   BUTTONS â€” with shine sweep
   ============================================================ */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-weight:700;font-size:.95rem;padding:.85rem 1.7rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s;white-space:nowrap;overflow:hidden;z-index:1}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;z-index:-1;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);transition:left .6s}
.btn:hover::after{left:140%}
.btn--red{background:var(--red);color:#fff;box-shadow:0 14px 30px -12px var(--red),var(--glow-r)}
.btn--red:hover{transform:translateY(-3px) scale(1.02)}
.btn--yellow{background:var(--yellow);color:#1a1300;box-shadow:0 14px 30px -12px var(--yellow-deep)}
.btn--yellow:hover{transform:translateY(-3px)}
.btn--ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6);color:#fff;backdrop-filter:blur(6px)}
.btn--ghost:hover{background:#fff;color:#1a1300;transform:translateY(-3px)}
.btn--block{width:100%}
/* Form submit buttons (e.g. "Join as Member"): no hover "pop" + clear gap so
   they don't lift/scale into the fields above. Keep it calm and aligned. */
.form .btn{margin-top:6px}
/* Form submit buttons stay completely still — no lift/scale on any state, no shine sweep. */
.form .btn,.form .btn:hover,.form .btn:active,.form .btn:focus{transform:none}
.form .btn::after{display:none}
/* Form cards must not lift/tilt on hover (the "pop"). */
.card.form:hover{transform:none}
/* Whole Join section: no card hover-lift on any panel. */
#join .card:hover{transform:none}

/* ============================================================
   TOPBAR â€” clean government strip
   ============================================================ */
.topbar{background:#10101a;color:#cfd2dc;font-size:.78rem;position:relative;z-index:40;
  border-bottom:1px solid rgba(255,255,255,.06)}
.topbar__accent{display:none}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar__gov{letter-spacing:.1em;font-weight:600;color:#d9b34d}
.topbar__right{display:flex;align-items:center;gap:14px}
.topbar__link{color:#cfd2dc}.topbar__link:hover{color:var(--yellow)}
.lang-toggle{background:var(--yellow);color:#1a1300;border:0;font-weight:800;padding:.3rem .85rem;
  border-radius:7px;cursor:pointer;font-size:.78rem;transition:.18s}
.lang-toggle:hover{background:var(--yellow-deep)}
.theme-toggle{background:transparent;border:1px solid rgba(255,255,255,.25);color:#cfd2dc;border-radius:7px;width:32px;
  height:26px;cursor:pointer;font-size:.82rem;line-height:1;transition:.2s}
.theme-toggle:hover{border-color:var(--yellow);color:var(--yellow)}

/* ============================================================
   HEADER â€” clean, solid, professional
   ============================================================ */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);
  transition:box-shadow .3s,height .3s}
.header::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:3px;background:var(--grad)}
body.dark .header{background:#0f1018;border-bottom-color:#23252f}
.header.shrink{box-shadow:0 6px 22px -12px rgba(0,0,0,.3)}
.header__inner{display:flex;align-items:center;gap:20px;height:74px;transition:height .3s;position:relative}
.header.shrink .header__inner{height:60px}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto;flex:none}
.brand__text strong,.brand__text small{white-space:nowrap}
.nav{flex-wrap:nowrap}
.nav a{white-space:nowrap}
.brand__symbol{position:relative;width:48px;height:48px;display:grid;place-items:center;background:var(--grad);
  border-radius:13px;box-shadow:0 6px 16px -6px var(--yellow-deep);transition:transform .3s}
.brand:hover .brand__symbol{transform:translateY(-2px) rotate(-3deg)}
.brand__avatar{position:relative;width:50px;height:50px;border-radius:50%;flex:none;
  background:#fff;box-shadow:0 0 0 3px var(--yellow),0 6px 16px -6px var(--yellow-deep);
  transition:transform .3s,width .3s,height .3s;animation:brandFloat 3.5s ease-in-out infinite}
.brand__avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.brand__avatar::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:2px solid var(--red);
  opacity:.8;animation:brandPulse 2.2s ease-out infinite;pointer-events:none}
.brand:hover .brand__avatar{transform:translateY(-2px) scale(1.06)}
.header.shrink .brand__avatar{width:42px;height:42px}
@keyframes brandFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes brandPulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}
.brand__text strong{display:block;font-size:1.16rem;font-family:'Poppins';color:var(--ink);letter-spacing:-.01em}
.brand__text small{color:var(--red);font-size:.74rem;font-weight:700}
.nav{display:flex;gap:2px}
.nav a{position:relative;font-weight:600;font-size:.9rem;color:var(--ink);padding:.5rem .7rem;transition:color .2s}
.nav a::after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.25rem;height:2.5px;border-radius:3px;
  background:var(--grad);transform:scaleX(0);transform-origin:center;transition:transform .25s ease}
.nav a:hover,.nav a.active{color:var(--red)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav__cta{font-size:.85rem;padding:.6rem 1.2rem;box-shadow:0 8px 20px -10px var(--red)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamburger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.25s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* ============================================================
   NEWS TICKER
   ============================================================ */
.ticker{display:flex;align-items:center;background:var(--dark);color:#fff;overflow:hidden;position:relative;z-index:30}
.ticker__tag{flex:none;background:var(--red);font-weight:800;font-size:.72rem;letter-spacing:.12em;
  padding:.55rem 1rem;align-self:stretch;display:flex;align-items:center;position:relative;z-index:2}
.ticker__track{display:flex;gap:60px;white-space:nowrap;padding:.55rem 0;animation:marquee 34s linear infinite}
.ticker__track span{font-size:.84rem;opacity:.92}
.ticker:hover .ticker__track{animation-play-state:paused}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   PHOTO FRAMES
   ============================================================ */
.photo-frame{border-radius:var(--radius);overflow:hidden;background:var(--bg-alt);border:5px solid #fff;
  box-shadow:var(--shadow);position:relative}
body.dark .photo-frame{border-color:#181a26}
.photo-frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;transition:transform .6s}
.photo-frame:hover img{transform:scale(1.05)}
.photo-frame--lg img{aspect-ratio:4/5}
/* crop the wide Kollu banner to focus on his figure (right side) in square/portrait frames */
.img-kollu{object-position:82% 26%!important}
.img-cm{object-position:center 22%!important}

/* ============================================================
   HERO â€” animated aurora + orbs
   ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--bg)}
.hero__bg{position:absolute;inset:0;z-index:0;
  background:linear-gradient(120deg,#fff6d6,#ffffff,#ffe3e0,#fff6d6);background-size:400% 400%;
  animation:aurora 16s ease infinite}
body.dark .hero__bg{background:linear-gradient(120deg,#1a160a,#0c0d15,#1a0f0e,#1a160a);background-size:400% 400%}
@keyframes aurora{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero__grid-overlay{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(214,52,44,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(214,52,44,.05) 1px,transparent 1px);
  background-size:42px 42px;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%)}
.hero__orbs{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__orbs i{position:absolute;border-radius:50%;filter:blur(50px);opacity:.55}
.hero__orbs i:nth-child(1){width:340px;height:340px;background:var(--yellow);top:-80px;right:-60px;animation:drift 14s ease-in-out infinite}
.hero__orbs i:nth-child(2){width:300px;height:300px;background:var(--red);bottom:-100px;left:-40px;animation:drift 18s ease-in-out infinite reverse}
.hero__orbs i:nth-child(3){width:200px;height:200px;background:var(--yellow-deep);bottom:40px;right:30%;animation:drift 12s ease-in-out infinite}
@keyframes drift{0%,100%{transform:translate(0,0)}33%{transform:translate(40px,-30px)}66%{transform:translate(-30px,25px)}}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:44px;
  align-items:center;padding:72px 24px 84px}
/* full-width banner hero */
.hero__banner-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:18px;padding:34px 24px 54px}
.hero__banner{width:100%;max-width:1280px;border-radius:20px;box-shadow:var(--shadow);
  border:1px solid var(--line);background:#fff}
.hero__banner-wrap .hero__eyebrow{margin-bottom:2px;animation:rise .7s .1s both}
.hero__banner-wrap .hero__tag{border:0;padding:0;max-width:60ch;margin:0}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(224,50,42,.1);color:var(--red-deep);
  font-weight:800;font-size:.76rem;letter-spacing:.1em;padding:.45rem 1rem;border-radius:999px;text-transform:uppercase;
  border:1px solid rgba(224,50,42,.25);opacity:0;animation:rise .7s .2s forwards}
.hero__eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(224,50,42,.25);animation:pulse 1.6s infinite}
.hero h1{font-size:clamp(2.4rem,5.5vw,4rem);margin:.8rem 0 .25rem;opacity:0;animation:rise .7s .35s forwards;
  background:linear-gradient(100deg,var(--ink),var(--ink));-webkit-background-clip:text}
.hero h1 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__desig{font-weight:700;color:var(--red-deep);font-size:1.08rem;margin-bottom:1rem;opacity:0;animation:rise .7s .5s forwards}
.hero__tag{color:var(--muted);font-size:1.08rem;max-width:46ch;margin-bottom:1.9rem;font-style:italic;
  border-left:3px solid var(--yellow);padding-left:1rem;opacity:0;animation:rise .7s .65s forwards}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:rise .7s .8s forwards}
.hero__slogan{display:inline-block;align-self:flex-start;font-weight:800;font-size:clamp(1.05rem,2.4vw,1.45rem);
  line-height:1.4;letter-spacing:.01em;color:var(--ink);margin:.2rem 0 1.6rem;padding:.7rem 1.2rem;border-radius:14px;
  background:linear-gradient(100deg,rgba(255,194,14,.22),rgba(224,50,42,.14));
  border:1px solid rgba(224,50,42,.3);box-shadow:0 6px 20px rgba(224,50,42,.12);
  position:relative;opacity:0;animation:rise .7s .72s forwards}
.hero__slogan::before{content:"";position:absolute;left:0;top:12%;bottom:12%;width:4px;border-radius:4px;background:var(--grad)}
.hero__banner-wrap .hero__slogan{align-self:center;text-align:center;max-width:60ch}
.hero__banner-wrap .hero__slogan::before{display:none}
.hero__photo{position:relative;justify-self:center;max-width:370px;width:100%;opacity:0;animation:rise .9s .5s forwards}
.hero__photo::before{content:"";position:absolute;inset:-20px;border-radius:34px;z-index:-1;
  background:conic-gradient(from 0deg,var(--yellow),var(--red),var(--yellow-deep),var(--yellow));
  filter:blur(34px);opacity:.55;animation:spin 10s linear infinite}
.hero__photo::after{content:"ðŸš² TDP";position:absolute;bottom:16px;left:-14px;background:var(--dark);color:var(--yellow);
  font-weight:800;font-size:.85rem;padding:.5rem 1rem;border-radius:12px;box-shadow:var(--shadow);animation:floaty 4s ease-in-out infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(224,50,42,.4)}50%{box-shadow:0 0 0 7px rgba(224,50,42,0)}}

/* ============================================================
   LEADERS
   ============================================================ */
.leaders{background:linear-gradient(135deg,#FFD23B 0%,var(--yellow) 45%,var(--yellow-deep) 100%);padding:50px 0;position:relative;overflow:hidden}
.leaders::before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60"><circle cx="30" cy="30" r="1.5" fill="white" opacity="0.25"/></svg>')}
.leaders__title{position:relative;text-align:center;color:#3a2c00;font-size:1.05rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.16em;margin-bottom:30px}
.leaders__grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1040px;margin:0 auto}
.leaders__grid--4{grid-template-columns:repeat(4,1fr);max-width:1180px}
.leader{text-align:center}
.leader .photo-frame{width:140px;height:140px;margin:0 auto 14px;border-radius:50%;border-color:#fff;transition:transform .3s}
.leader:hover .photo-frame{transform:translateY(-8px) scale(1.05)}
.leader figcaption strong{display:block;font-size:1.02rem;color:#1a1300}
.leader figcaption span{font-size:.82rem;color:#5a4500}
.leader--highlight .photo-frame{border-color:var(--dark);transform:scale(1.08);box-shadow:0 18px 40px -14px rgba(0,0,0,.5)}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--dark);color:#fff;padding:46px 0;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;top:-50%;left:50%;width:140%;height:200%;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(255,194,14,.1),transparent 60%)}
.stats__grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat__num{display:inline-block;font-family:'Poppins';font-size:2.4rem;font-weight:800;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__label{display:block;font-size:.82rem;color:#c4c7d0}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:88px 0;position:relative}
.section--alt{background:var(--bg-alt)}
.section--dark{background:var(--dark);color:#fff}
.section--mesh{overflow:hidden;background:
  radial-gradient(circle at 10% 12%,rgba(255,194,14,.16),transparent 38%),
  radial-gradient(circle at 92% 88%,rgba(224,50,42,.14),transparent 40%),var(--bg-alt)}
.section__head{text-align:center;max-width:680px;margin:0 auto 52px}
.kicker{display:inline-block;background:rgba(224,50,42,.1);color:var(--red);font-weight:800;font-size:.76rem;
  letter-spacing:.14em;text-transform:uppercase;padding:.35rem .9rem;border-radius:999px;margin-bottom:.9rem}
.kicker--light{background:rgba(255,194,14,.18);color:var(--yellow)}
.section h2{font-size:clamp(1.9rem,3.8vw,2.7rem)}
.section__head p{color:var(--muted);margin-top:.7rem}

/* ============================================================
   ABOUT
   ============================================================ */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.about__photo{position:relative;max-width:400px}
.about__photo::before{content:"";position:absolute;inset:-14px -14px 14px 14px;border:3px solid var(--yellow);
  border-radius:var(--radius);z-index:-1}
.about__text h2{margin:.3rem 0 1.1rem}
.about__text p{color:var(--muted);margin-bottom:1rem}
.about__subhead{font-size:1.05rem;margin:1.6rem 0 .4rem;color:var(--red);display:flex;align-items:center;gap:.5rem}
.about__subhead::before{content:"";width:22px;height:3px;background:var(--grad);border-radius:3px}
.about__facts{list-style:none;display:grid;gap:10px;margin-top:.6rem}
.about__facts li{display:flex;gap:14px;align-items:baseline;border-left:3px solid var(--yellow);padding-left:14px;transition:.2s}
.about__facts li:hover{border-left-color:var(--red);transform:translateX(4px)}
.about__facts strong{min-width:122px;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em}
.about__facts span{color:var(--muted)}

/* ============================================================
   CARDS â€” glass + tilt
   ============================================================ */
.cards{display:grid;gap:24px}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden;transform-style:preserve-3d}
body.dark .card{background:#161823}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1.5px;
  background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s;pointer-events:none}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.card:hover::before{opacity:1}
.card--flat{text-align:center}
.card__icon{font-size:2.2rem;margin-bottom:.7rem;display:inline-block;transition:transform .3s}
.card:hover .card__icon{transform:scale(1.2) rotate(-6deg)}
.card h3{font-size:1.18rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.94rem}
.card__link{display:inline-block;margin-top:.9rem;color:var(--red);font-weight:700;font-size:.9rem;transition:.2s}
.card__link:hover{letter-spacing:.03em}
.section--dark .card{background:#16181f;color:#eef0f6}
body.dark .section--dark .card{background:#1c1e2b}

/* ============================================================
   IMPACT
   ============================================================ */
.impact{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.impact__bars{display:grid;gap:24px}
.bar__top{display:flex;justify-content:space-between;font-weight:700;margin-bottom:.5rem;font-size:.95rem}
.bar__top b{color:var(--red)}
.bar__track{height:14px;background:rgba(224,50,42,.1);border-radius:999px;overflow:hidden}
.bar__track i{display:block;height:100%;width:0;border-radius:999px;background:var(--grad);
  box-shadow:0 0 16px rgba(255,194,14,.6);transition:width 1.6s cubic-bezier(.2,.8,.2,1)}
.impact__highlights{display:grid;gap:18px}
.hl{background:var(--bg);border:1px solid var(--line);border-left:5px solid var(--yellow);border-radius:14px;
  padding:20px 24px;box-shadow:var(--shadow);transition:.25s}
body.dark .hl{background:#161823}
.hl:hover{transform:translateX(6px);border-left-color:var(--red)}
.hl__num{font-family:'Poppins';font-size:2.1rem;font-weight:800;color:var(--red);line-height:1}
.hl__plus{font-family:'Poppins';font-size:1.1rem;font-weight:800;color:var(--yellow-deep)}
.hl__lbl{display:block;color:var(--muted);font-size:.86rem;margin-top:.25rem}
.disclaimer{text-align:center;color:var(--muted);font-size:.78rem;margin-top:30px;font-style:italic;opacity:.8}

/* ============================================================
   TIMELINE â€” self-drawing line
   ============================================================ */
.timeline{position:relative;max-width:1040px;margin:0 auto;padding:10px 0}
.timeline::before{content:"";position:absolute;left:50%;top:0;width:3px;height:0;transform:translateX(-50%);
  background:var(--grad);box-shadow:0 0 14px rgba(255,194,14,.6);transition:height 1.6s ease}
.timeline.draw::before{height:100%}
.tl-item{position:relative;width:50%;padding:18px 44px;box-sizing:border-box}
.tl-item:nth-child(odd){left:0;text-align:right}
.tl-item:nth-child(even){left:50%}
.tl-dot{position:absolute;top:26px;width:50px;height:50px;border-radius:50%;display:grid;place-items:center;
  font-size:1.25rem;background:var(--bg);border:3px solid var(--yellow);box-shadow:0 10px 22px -6px rgba(224,50,42,.5);z-index:2}
body.dark .tl-dot{background:#161823}
.tl-item:nth-child(odd) .tl-dot{right:-25px}
.tl-item:nth-child(even) .tl-dot{left:-25px}
.tl-card{background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:22px 24px;
  box-shadow:var(--shadow);transition:.3s;position:relative}
body.dark .tl-card{background:#161823}
.tl-card:hover{transform:translateY(-6px) scale(1.01)}
.tl-card::before{content:"";position:absolute;top:30px;width:14px;height:14px;background:inherit;
  border:1px solid var(--line);transform:rotate(45deg)}
.tl-item:nth-child(odd) .tl-card::before{right:-8px;border-left:0;border-bottom:0}
.tl-item:nth-child(even) .tl-card::before{left:-8px;border-right:0;border-top:0}
.tl-date{display:inline-block;background:var(--grad);color:#1a1300;font-weight:800;font-size:.78rem;
  padding:.28rem .85rem;border-radius:999px;margin-bottom:.6rem}
.tl-card h3{font-size:1.14rem;margin-bottom:.4rem}
.tl-card p{color:var(--muted);font-size:.92rem}
.tl-item--now .tl-dot{border-color:var(--red);animation:glowdot 1.8s infinite}
/* auto-cycling + hover highlight (same behaviour as the journey strip) */
.tl-item.lit .tl-card,.tl-item:hover .tl-card{transform:translateY(-6px) scale(1.01);border-color:rgba(224,50,42,.45)}
.tl-item.lit .tl-dot,.tl-item:hover .tl-dot{border-color:var(--red);transform:scale(1.15);
  box-shadow:0 0 0 7px rgba(224,50,42,.18),0 0 18px rgba(224,50,42,.55)}
.tl-item.lit .tl-date,.tl-item:hover .tl-date{box-shadow:0 0 12px rgba(255,194,14,.55)}
@keyframes glowdot{0%,100%{box-shadow:0 0 0 0 rgba(224,50,42,.55)}50%{box-shadow:0 0 0 14px rgba(224,50,42,0)}}

/* ============================================================
   GRIEVANCE / FORMS
   ============================================================ */
.grievance{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.grievance__intro p{color:#c9ccd6;margin:1rem 0 1.6rem;max-width:46ch}
.track{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:24px;backdrop-filter:blur(6px)}
.track h4{font-size:1rem;margin-bottom:.8rem}
.track__row{display:flex;gap:10px}
.track__row input{flex:1;padding:.75rem .95rem;border-radius:10px;border:1px solid #3a3d4a;background:#fff;color:#16161f}
.track__result{margin-top:.9rem;font-size:.9rem;min-height:1.2em}
.track__result.ok{color:var(--yellow)}.track__result.bad{color:#ff9b95}
/* light-section variant (appointment tracker) */
.track--light{background:var(--bg-alt);border:1px solid var(--line);backdrop-filter:none;margin-top:1.4rem}
.track--light .track__row input{border:1px solid var(--line)}
body.dark .track--light .track__row input{background:#10111b;color:var(--ink)}
.track--light .track__result.ok{color:#16a34a}.track--light .track__result.bad{color:var(--red)}
.form{display:flex;flex-direction:column;gap:15px}
.form h3{margin-bottom:.2rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:600}
.form input,.form select,.form textarea{padding:.78rem .95rem;border:1px solid var(--line);border-radius:11px;
  font:inherit;background:var(--bg);color:var(--ink);transition:.18s}
body.dark .form input,body.dark .form select,body.dark .form textarea{background:#10111b}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(224,50,42,.12)}
.form__note{font-size:.92rem;font-weight:700;min-height:1.2em}
.form__note.ok{color:#16a34a}.form__note.bad{color:var(--red)}

/* ============================================================
   APPOINTMENT / CONTACT
   ============================================================ */
.appt,.contact{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.appt__text p,.contact__info p{color:var(--muted)}
.contact__list{list-style:none;display:grid;gap:18px;margin:1.5rem 0}
.contact__list li{display:flex;gap:14px;align-items:flex-start}
.contact__ico{font-size:1.35rem}
.contact__list strong{display:block}
.contact__list a,.contact__list span{color:var(--muted)}
.contact__list a:hover{color:var(--red)}
.social{display:flex;gap:12px;margin-top:1rem}
.social a{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:var(--yellow);
  color:#1a1300;font-weight:800;transition:.25s}
.social a:hover{background:var(--red);color:#fff;transform:translateY(-4px) rotate(8deg)}
.contact__map iframe{width:100%;height:360px;border:0;border-radius:var(--radius);box-shadow:var(--shadow)}
.contact__map--full iframe{height:460px}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;grid-auto-rows:210px}
.gallery__item{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.gallery__item--wide{grid-column:span 2}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.4));opacity:0;transition:.3s}
.gallery__item:hover img{transform:scale(1.12)}
.gallery__item:hover::after{opacity:1}

/* ============================================================
   NEWS
   ============================================================ */
.news{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.3s}
body.dark .news{background:#161823}
.news:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.news__img{height:190px;overflow:hidden}
.news__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.news:hover .news__img img{transform:scale(1.08)}
.news__body{padding:22px}
.news__body time{color:var(--red);font-weight:800;font-size:.78rem}
.news__body h3{font-size:1.12rem;margin:.45rem 0}
.news__body p{color:var(--muted);font-size:.92rem}

/* ============================================================
   FOOTER â€” premium dark, animated, multi-column
   ============================================================ */
.footer{position:relative;background:linear-gradient(160deg,#15100a 0%,#0b0b12 55%,#170a09 100%);
  color:#b9bdc9;padding:120px 0 0;overflow:hidden}
.footer__wave{position:absolute;top:-1px;left:0;width:100%;line-height:0}
.footer__wave svg{width:100%;height:90px}
.footer__wave svg path{fill:var(--bg-alt);animation:waveShift 9s ease-in-out infinite alternate}
.footer__glow{position:absolute;top:40px;left:50%;width:120%;height:340px;transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(255,194,14,.12),transparent 60%)}
.footer__cycle{position:absolute;right:-40px;bottom:40px;width:340px;color:rgba(255,194,14,.06);pointer-events:none}
.footer__cycle .bike{width:100%}
.footer__cycle .wheel{animation:roll 8s linear infinite}

.footer__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;padding-bottom:50px}
.footer__col h4{color:#fff;font-family:'Poppins';font-size:1rem;margin-bottom:1.1rem;position:relative;padding-bottom:.6rem}
.footer__col h4::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:3px;background:var(--grad);border-radius:3px}
.footer__col ul{list-style:none;display:grid;gap:.7rem}
.footer__col ul a{font-size:.9rem;color:#b9bdc9;transition:.2s;display:inline-flex;align-items:center;gap:.4rem}
.footer__col ul a::before{content:"â€º";color:var(--yellow);opacity:0;transform:translateX(-6px);transition:.2s}
.footer__col ul a:hover{color:#fff;transform:translateX(4px)}
.footer__col ul a:hover::before{opacity:1;transform:none}

.footer__brand{display:flex;align-items:center;gap:14px;margin-bottom:1.2rem}
.footer__badge{position:relative;width:54px;height:54px;display:grid;place-items:center;background:var(--grad);
  border-radius:15px;color:#1a1300;box-shadow:0 10px 24px -8px var(--yellow-deep);flex:none}
.footer__badge::before{content:"";position:absolute;inset:-3px;border-radius:18px;z-index:-1;
  background:conic-gradient(from 0deg,var(--yellow),var(--red),var(--yellow));filter:blur(8px);opacity:.6;animation:spin 7s linear infinite}
.footer__badge .bike{width:38px;color:#1a1300}
.footer__name strong{display:block;color:#fff;font-size:1.15rem;font-family:'Poppins'}
.footer__name small{color:var(--yellow);font-size:.8rem;font-weight:600}
.footer__about{font-size:.9rem;line-height:1.7;max-width:42ch;margin-bottom:1.3rem}
.footer__social{display:flex;gap:12px}
.footer__social a{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#cfd2db;transition:.25s}
.footer__social svg{width:19px;height:19px}
.footer__social a:hover{background:var(--grad);color:#1a1300;transform:translateY(-5px) rotate(-6deg);border-color:transparent;
  box-shadow:0 12px 24px -8px var(--yellow-deep)}

.footer__contact{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;margin-bottom:.7rem}
.footer__contact a:hover{color:var(--yellow)}
.footer__news{display:flex;gap:8px;margin-top:1rem}
.footer__news input{flex:1;min-width:0;padding:.7rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.06);color:#fff;font:inherit}
.footer__news input::placeholder{color:#8b8f9c}
.footer__news input:focus{outline:none;border-color:var(--yellow);box-shadow:0 0 0 3px rgba(255,194,14,.18)}
.footer__news .btn{padding:.7rem 1.2rem}
.footer__news-msg{color:var(--yellow);font-size:.82rem;font-weight:600;margin-top:.6rem;min-height:1em}

.footer__bottom{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.25)}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding:18px 0;font-size:.82rem}
.footer__bottom strong{color:#fff}
.footer__made a{color:var(--yellow)}.footer__made a:hover{text-decoration:underline}

/* ============================================================
   FLOATING + PROGRESS
   ============================================================ */
.fab-stack{position:fixed;right:22px;bottom:22px;z-index:60;display:flex;flex-direction:column;gap:14px;align-items:center}
.fab-stack .wa-float{position:static;right:auto;bottom:auto}
.fab-stack .to-top{position:static;right:auto;bottom:auto}
.fab{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;
  box-shadow:0 14px 30px -8px rgba(0,0,0,.4);transition:transform .2s ease}
.fab:hover{transform:scale(1.1)}
.fab svg{width:28px;height:28px}
.fab--fb{background:#1877F2;box-shadow:0 14px 30px -8px rgba(24,119,242,.7)}
.fab--ig{background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%);
  box-shadow:0 14px 30px -8px rgba(214,36,159,.6)}
/* ---- Instagram reels grid ---- */
.reels-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.reel-card{position:relative;display:block;aspect-ratio:9/16;border-radius:16px;overflow:hidden;
  background:#111;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease;text-decoration:none}
.reel-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 40px -12px rgba(0,0,0,.45)}
.reel-card__thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.reel-card__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;
  display:grid;place-items:center;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;font-size:1.1rem;
  backdrop-filter:blur(2px);transition:transform .2s ease,background .2s ease}
.reel-card:hover .reel-card__play{transform:translate(-50%,-50%) scale(1.12);background:rgba(214,36,159,.8)}
.reel-card__cap{position:absolute;left:0;right:0;bottom:0;padding:24px 10px 10px;color:#fff;font-size:.78rem;
  line-height:1.3;background:linear-gradient(transparent,rgba(0,0,0,.78));
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.reels-more{text-align:center;margin-top:26px}
.btn--ig{background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285AEB 90%);
  color:#fff;border:0}
@media(max-width:1024px){.reels-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.reels-grid{grid-template-columns:repeat(2,1fr)}}
.wa-float{position:fixed;right:22px;bottom:22px;width:60px;height:60px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;font-size:1.7rem;z-index:60;box-shadow:0 14px 30px -8px rgba(37,211,102,.7);animation:pulse2 2.5s infinite}
@keyframes pulse2{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.scroll-progress{position:fixed;top:0;left:0;height:4px;width:0;z-index:100;background:var(--grad);
  box-shadow:0 0 12px var(--red);transition:width .08s linear}

/* ============================================================
   REVEAL ANIMATION ENGINE â€” varied, keyframe-based (JS adds .in)
   Uses animation (not transition) so it never fights hover/tilt.
   ============================================================ */
.has-js .reveal{opacity:0}
.reveal.in{opacity:1;animation-duration:.85s;animation-timing-function:cubic-bezier(.2,.8,.2,1);
  animation-fill-mode:both;animation-delay:var(--d,0s)}
.reveal.in[data-reveal="up"]{animation-name:rv-up}
.reveal.in[data-reveal="down"]{animation-name:rv-down}
.reveal.in[data-reveal="left"]{animation-name:rv-left}
.reveal.in[data-reveal="right"]{animation-name:rv-right}
.reveal.in[data-reveal="zoom"]{animation-name:rv-zoom}
.reveal.in[data-reveal="zoom-out"]{animation-name:rv-zoomout}
.reveal.in[data-reveal="flip"]{animation-name:rv-flip}
.reveal.in[data-reveal="flip-y"]{animation-name:rv-flipy}
.reveal.in[data-reveal="blur"]{animation-name:rv-blur}
.reveal.in[data-reveal="rotate"]{animation-name:rv-rotate}
.reveal.in[data-reveal="rise-rotate"]{animation-name:rv-riserotate}
.reveal.in[data-reveal="mask"]{animation-name:rv-mask}
.reveal.in[data-reveal="mask-left"]{animation-name:rv-maskleft}
@keyframes rv-up{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:none}}
@keyframes rv-down{from{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:none}}
@keyframes rv-left{from{opacity:0;transform:translateX(-64px)}to{opacity:1;transform:none}}
@keyframes rv-right{from{opacity:0;transform:translateX(64px)}to{opacity:1;transform:none}}
@keyframes rv-zoom{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:none}}
@keyframes rv-zoomout{from{opacity:0;transform:scale(1.14)}to{opacity:1;transform:none}}
@keyframes rv-flip{from{opacity:0;transform:perspective(1000px) rotateX(-34deg) translateY(30px)}to{opacity:1;transform:none}}
@keyframes rv-flipy{from{opacity:0;transform:perspective(1000px) rotateY(30deg)}to{opacity:1;transform:none}}
@keyframes rv-blur{from{opacity:0;filter:blur(16px);transform:scale(1.05)}to{opacity:1;filter:blur(0);transform:none}}
@keyframes rv-rotate{from{opacity:0;transform:rotate(-7deg) translateY(44px) scale(.92)}to{opacity:1;transform:none}}
@keyframes rv-riserotate{from{opacity:0;transform:translateY(60px) rotate(4deg)}to{opacity:1;transform:none}}
@keyframes rv-mask{from{opacity:0;clip-path:inset(0 0 100% 0);transform:translateY(18px)}to{opacity:1;clip-path:inset(0 0 0 0);transform:none}}
@keyframes rv-maskleft{from{opacity:0;clip-path:inset(0 100% 0 0)}to{opacity:1;clip-path:inset(0 0 0 0)}}

/* ============================================================
   ANIMATED BICYCLE (cycle symbol) â€” spinning wheels
   ============================================================ */
.bike{width:100%;height:100%;display:block;color:var(--ink)}
.brand__symbol .bike{color:var(--dark)}
.bike .wheel{transform-box:fill-box;transform-origin:center;animation:roll 2.2s linear infinite}
@keyframes roll{to{transform:rotate(360deg)}}
.bike--xl{width:130px;height:auto;color:var(--yellow);filter:drop-shadow(0 6px 14px rgba(255,194,14,.5))}
.bike--xl .wheel{animation-duration:1.4s}

/* ============================================================
   TDP PARTY JOURNEY
   ============================================================ */
.party{position:relative;background:linear-gradient(135deg,#1a1206 0%,#0d0d15 55%,#1a0a09 100%);
  color:#fff;padding:90px 0 70px;overflow:hidden}
.party__wave{position:absolute;left:0;width:100%;line-height:0;z-index:3}
.party__wave svg{width:100%;height:70px}
.party__wave--top{top:-1px}
.party__wave--top svg path{fill:var(--dark)}
.party__wave--top svg{transform:rotate(180deg)}
.party__wave--bottom{bottom:-1px}
.party__wave--bottom svg path{fill:var(--bg)}
body.dark .party__wave--bottom svg path{fill:var(--bg)}
.party__symbols{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;opacity:.16}
.float-sym{position:absolute;bottom:-60px;color:var(--yellow);animation:floatUp linear infinite}
.float-sym svg{width:100%;height:100%}
@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:.8}90%{opacity:.6}100%{transform:translateY(-120vh) rotate(360deg);opacity:0}}
.party__inner{position:relative;z-index:2;display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.party__flag img{width:100%;max-width:360px;border-radius:18px;box-shadow:0 22px 50px -18px rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.1)}
.party__content .kicker--light{background:rgba(255,194,14,.16)}
.party__content h2{font-size:clamp(2rem,4.5vw,3.2rem);margin:.6rem 0 1rem}
.party__content h2 .count-up{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.party__content p{color:#cfd2db;max-width:54ch}
.bigcycle{display:flex;align-items:center;gap:16px;margin-top:1.6rem;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,194,14,.25);border-radius:16px;padding:14px 20px;width:fit-content;backdrop-filter:blur(6px)}
.bigcycle span{font-family:'Poppins';font-weight:800;letter-spacing:.06em;color:var(--yellow)}
.bigcycle__logo{width:120px;height:auto;display:block;background:#fff;border-radius:12px;
  padding:8px 12px;box-shadow:0 6px 16px rgba(0,0,0,.4)}

/* journey rail */
.journey{position:relative;z-index:2;display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:64px}
.journey__line{position:absolute;top:46px;left:6%;right:6%;height:3px;background:linear-gradient(90deg,var(--yellow),var(--red));
  transform:scaleX(0);transform-origin:left;transition:transform 1.6s ease;border-radius:3px;box-shadow:0 0 12px rgba(255,194,14,.6)}
.journey.draw .journey__line{transform:scaleX(1)}
.jstep{position:relative;text-align:center;padding-top:0}
.jstep__yr{display:inline-block;font-family:'Poppins';font-weight:800;font-size:1.25rem;color:#fff;margin-bottom:24px}
.jstep__dot{position:absolute;top:38px;left:50%;transform:translateX(-50%);width:18px;height:18px;border-radius:50%;
  background:var(--yellow);border:3px solid var(--dark);box-shadow:0 0 0 4px rgba(255,194,14,.25);z-index:2}
.jstep p{color:#c9ccd6;font-size:.84rem;margin-top:18px;padding:0 4px}
.jstep--now .jstep__dot{background:var(--red);animation:glowdot 1.8s infinite}
.jstep--now .jstep__yr{color:var(--yellow)}
/* auto-cycling + hover highlight: the active step lifts and glows */
.jstep{transition:transform .25s;border-radius:14px}
.jstep.lit,.jstep:hover{transform:translateY(-6px)}
.jstep.lit .jstep__yr,.jstep:hover .jstep__yr{color:var(--yellow)}
.jstep.lit .jstep__dot,.jstep:hover .jstep__dot{background:var(--red);transform:translateX(-50%) scale(1.35);
  box-shadow:0 0 0 7px rgba(224,50,42,.25),0 0 18px rgba(224,50,42,.6)}
.jstep.lit p,.jstep:hover p{color:#fff}

/* ============================================================
   MAGNETIC BTN helper
   ============================================================ */
.btn{will-change:transform}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* collapse nav to menu button before it can wrap */
@media(max-width:1060px){
  .nav,.nav__cta{display:none}
  .hamburger{display:flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:2px;background:var(--bg);
    padding:14px;box-shadow:var(--shadow);border-bottom:3px solid var(--yellow);max-height:75vh;overflow:auto}
  .nav.open a{padding:.7rem .9rem;border-radius:10px}
  .nav.open a::after{display:none}
  .nav.open a:hover,.nav.open a.active{background:var(--bg-alt);color:var(--red)}
}
@media(max-width:980px){
  .hero__inner,.about,.grievance,.appt,.contact,.impact,.party__inner{grid-template-columns:1fr}
  .hero__photo{grid-row:1;max-width:300px}
  .party__flag{max-width:240px;margin:0 auto}
  .journey{grid-template-columns:1fr 1fr;gap:30px 14px}
  .journey__line{display:none}
  .cards--3,.cards--4{grid-template-columns:repeat(2,1fr)}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .footer__copy{text-align:left}
  .timeline::before{left:25px}
  .tl-item,.tl-item:nth-child(even){width:100%;left:0;text-align:left;padding-left:66px;padding-right:4px}
  .tl-item:nth-child(odd){text-align:left}
  .tl-item:nth-child(odd) .tl-dot,.tl-item:nth-child(even) .tl-dot{left:1px;right:auto}
  .tl-item:nth-child(odd) .tl-card::before,.tl-item:nth-child(even) .tl-card::before{left:-8px;right:auto;border:1px solid var(--line);border-right:0;border-top:0}
}
@media(max-width:560px){
  .leaders__grid{grid-template-columns:1fr;max-width:260px}
  .cards--3,.cards--4,.form__row{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .topbar__gov{display:none}
}
/* ============================================================
   ADVANCED v3 â€” a11y, bento, search, lightbox, faq, downloads,
   videos, back-to-top, scroll-spy, contrast & focus fixes
   ============================================================ */
:root{--grad-text:linear-gradient(100deg,#E0322A 0%,#C98700 100%)}
.container--narrow{max-width:1040px}

/* ---- SKIP LINK ---- */
.skip-link{position:fixed;top:-60px;left:12px;z-index:9999;background:var(--red);color:#fff;font-weight:700;
  padding:.7rem 1.1rem;border-radius:0 0 10px 10px;transition:top .25s}
.skip-link:focus{top:0;outline:3px solid var(--yellow)}

/* ---- FOCUS VISIBLE (a11y) ---- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible,.gallery__item:focus-visible{
  outline:3px solid var(--red);outline-offset:3px;border-radius:6px}
.nav a:focus-visible{outline-offset:-2px}

/* ---- ANCHOR OFFSET under sticky header ---- */
section[id],main [id]{scroll-margin-top:96px}

/* ---- READABLE GRADIENT TEXT (fix yellow-on-white) ---- */
.hero h1 em,.stat__num,.count-up,.party__content h2 .count-up{background:var(--grad-text);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.stats .stat__num{background:linear-gradient(100deg,#FFD23B,#FF7A3C);-webkit-background-clip:text;background-clip:text}
.stat__suffix{font-family:'Poppins';font-weight:800;font-size:1.4rem;color:var(--yellow);vertical-align:top}
.count-plus{color:var(--yellow);font-weight:800}
.stat__num--text{-webkit-text-fill-color:initial}
.disclaimer{opacity:1;color:var(--muted)}

/* ---- HAMBURGER -> X ---- */
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---- SVG CYCLE PATH DRAW on reveal ---- */
.bike--xl path,.bike--xl circle{stroke-dasharray:520;stroke-dashoffset:520;animation:draw 2.2s ease forwards .2s}
@keyframes draw{to{stroke-dashoffset:0}}

/* ============================================================
   BENTO QUICK ACTIONS
   ============================================================ */
.bento-wrap{padding:34px 0;background:var(--bg)}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:118px;gap:16px}
.bento__cell{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:18px;padding:20px;
  display:flex;flex-direction:column;justify-content:center;gap:8px;background:var(--bg);transition:transform .3s,box-shadow .3s,border-color .3s}
body.dark .bento__cell{background:#161823}
.bento__cell:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.bento__cell--hero{grid-column:span 2;grid-row:span 2;background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));color:#241900;justify-content:center}
.bento__cell--hero .bento__ico{font-size:2.6rem}
.bento__cell--hero h3{font-size:1.5rem;margin:.4rem 0;color:#241900}
.bento__cell--hero p{color:#3a2c00;max-width:34ch;font-weight:500}
.bento__go{margin-top:.7rem;font-weight:800}
.bento__cell--y{background:rgba(255,194,14,.14)}
.bento__cell--r{background:rgba(224,50,42,.1)}
.bento__cell--wa{background:rgba(37,211,102,.12)}
.bento__ico{font-size:1.8rem;transition:transform .3s}
.bento__cell:hover .bento__ico{transform:scale(1.18) rotate(-6deg)}
.bento__cell h4{font-size:1.08rem;color:var(--ink)}
.bento__cell::after{content:"â†—";position:absolute;top:14px;right:16px;opacity:0;transform:translate(-4px,4px);transition:.3s;font-weight:800}
.bento__cell:hover::after{opacity:.6;transform:none}

/* ============================================================
   SCHEME SEARCH + CHIPS
   ============================================================ */
.scheme-tools{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;margin-bottom:30px}
.search{position:relative;flex:1;min-width:240px;max-width:380px}
.search__ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.6}
.search input{width:100%;padding:.8rem 1rem .8rem 2.6rem;border:1px solid var(--line);border-radius:999px;
  font:inherit;background:var(--bg);color:var(--ink);transition:.18s}
body.dark .search input{background:#12131d}
.search input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(224,50,42,.12)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;font-weight:600;
  font-size:.86rem;cursor:pointer;color:var(--muted);transition:.2s}
body.dark .chip{background:#161823}
.chip:hover{border-color:var(--red);color:var(--red)}
.chip.is-active{background:var(--grad);color:#1a1300;border-color:transparent}
.scheme{transition:transform .4s,opacity .4s,box-shadow .3s,border-color .3s}
.scheme.hide{display:none}
.no-result{text-align:center;color:var(--muted);padding:20px;font-weight:600}

/* ============================================================
   GALLERY (button + zoom)
   ============================================================ */
.gallery__item{border:0;padding:0;cursor:pointer;background:var(--bg-alt);display:block}
.gallery__zoom{position:absolute;inset:0;display:grid;place-items:center;font-size:1.6rem;color:#fff;
  background:rgba(0,0,0,.35);opacity:0;transition:.3s}
.gallery__item:hover .gallery__zoom{opacity:1}

/* ============================================================
   VIDEOS (YouTube facade)
   ============================================================ */
.video{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.3s}
body.dark .video{background:#161823}
.video:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.video__thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.video__thumb img{width:100%;height:100%;object-fit:cover}
.video__play{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;background:var(--red);
  color:#fff;display:grid;place-items:center;font-size:1.4rem;box-shadow:0 10px 26px -8px rgba(224,50,42,.8);transition:.3s}
.video:hover .video__play{transform:scale(1.12)}
.video__body{padding:18px}
.video__body h3{font-size:1.04rem}
.video iframe{width:100%;aspect-ratio:16/9;border:0;display:block}

/* ============================================================
   DOWNLOADS
   ============================================================ */
.downloads{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.dl{display:flex;align-items:center;gap:16px;background:var(--bg);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;transition:.25s}
body.dark .dl{background:#161823}
.dl:hover{transform:translateX(6px);border-color:var(--red);box-shadow:var(--shadow)}
.dl__ico{font-size:1.7rem}
.dl strong{display:block}
.dl small{color:var(--muted)}
.dl__arr{margin-left:auto;font-weight:800;color:var(--red);font-size:1.2rem;transition:.25s}
.dl:hover .dl__arr{transform:translateY(3px)}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq{display:grid;gap:12px}
.faq__item{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:0 20px;overflow:hidden}
body.dark .faq__item{background:#161823}
.faq__item summary{list-style:none;cursor:pointer;font-weight:700;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-size:1.5rem;color:var(--red);transition:transform .3s;font-weight:400}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{color:var(--muted);padding:0 0 18px;margin:0;animation:fadeIn .35s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,8,14,.92);display:flex;align-items:center;
  justify-content:center;backdrop-filter:blur(6px);animation:lbIn .3s ease}
.lightbox[hidden]{display:none}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lightbox__img{max-width:88vw;max-height:84vh;border-radius:14px;box-shadow:0 30px 80px -20px #000;animation:lbZoom .35s cubic-bezier(.2,.9,.2,1)}
@keyframes lbZoom{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  color:#fff;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:.2s}
.lightbox__close{top:22px;right:22px;width:46px;height:46px;font-size:1.2rem}
.lightbox__nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2rem}
.lightbox__prev{left:22px}.lightbox__next{right:22px}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--red);transform:scale(1.1)}
.lightbox__nav:hover{transform:translateY(-50%) scale(1.1)}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.to-top{position:fixed;right:22px;bottom:92px;width:48px;height:48px;border-radius:50%;border:0;cursor:pointer;
  background:var(--dark);color:var(--yellow);font-size:1.3rem;font-weight:800;z-index:60;opacity:0;visibility:hidden;
  transform:translateY(12px);transition:.3s;box-shadow:var(--shadow)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--red);color:#fff;transform:translateY(-3px)}

/* ---- SCROLL-SPY active nav (pill style) ---- */
.nav a.active{color:var(--red);font-weight:700}
.nav a.active::before{transform:scale(1);opacity:1}

/* ---- animated wave dividers ---- */
.party__wave svg path{animation:waveShift 9s ease-in-out infinite alternate}
@keyframes waveShift{from{d:path("M0,40 C360,90 1080,-10 1440,40 L1440,80 L0,80 Z")}to{d:path("M0,40 C420,0 1020,95 1440,40 L1440,80 L0,80 Z")}}

/* ---- journey/timeline dot hover ---- */
.jstep__dot,.tl-dot{transition:transform .25s,box-shadow .25s}
.jstep:hover .jstep__dot{transform:translateX(-50%) scale(1.35)}
.tl-card:hover ~ .tl-dot,.tl-item:hover .tl-dot{transform:scale(1.15)}

@media(max-width:980px){
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:108px}
  .bento__cell--hero{grid-column:span 2;grid-row:span 1}
  .downloads{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__col--brand{grid-column:1 / -1}
  .footer__cycle{display:none}
}
@media(max-width:560px){
  .footer__grid{grid-template-columns:1fr;gap:32px}
  .footer__bottom-inner{flex-direction:column;text-align:center}
}

/* ============================================================
   ADVANCED v4 â€” grain, custom cursor, a11y toolbar, charts,
   map, smooth-scroll polish
   ============================================================ */

/* ---- GRAIN / NOISE TEXTURE ---- */
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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")}

/* ---- ACCESSIBILITY TOOLBAR ---- */
.a11y{position:fixed;left:22px;bottom:22px;z-index:70}
.a11y__toggle{width:50px;height:50px;border-radius:50%;border:0;cursor:pointer;font-size:1.5rem;
  background:var(--dark);color:var(--yellow);box-shadow:var(--shadow);transition:.25s}
.a11y__toggle:hover{background:var(--red);color:#fff;transform:scale(1.08)}
.a11y__panel{position:absolute;left:0;bottom:62px;width:240px;background:var(--bg);border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:18px;display:grid;gap:10px;animation:fadeIn .25s ease}
body.dark .a11y__panel{background:#161823}
.a11y__panel[hidden]{display:none}
.a11y__panel>strong{font-family:'Poppins'}
.a11y__row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;font-weight:600}
.a11y__btns{display:flex;gap:6px}
.a11y__btns button{width:34px;height:30px;border:1px solid var(--line);background:var(--bg-alt);border-radius:8px;cursor:pointer;font-weight:700;color:var(--ink)}
.a11y__btns button:hover{border-color:var(--red);color:var(--red)}
.a11y__opt{text-align:left;border:1px solid var(--line);background:var(--bg-alt);border-radius:10px;padding:.6rem .8rem;
  cursor:pointer;font-weight:600;font-size:.88rem;color:var(--ink);transition:.2s}
.a11y__opt:hover{border-color:var(--red)}
.a11y__opt.on{background:var(--grad);color:#1a1300;border-color:transparent}
.a11y__reset{background:none;border:0;color:var(--red);font-weight:700;cursor:pointer;padding:.3rem;text-align:left}

/* a11y modes applied to <html>/<body> */
body.a11y-contrast{filter:contrast(1.35)}
body.a11y-contrast .hero__bg,body.a11y-contrast .hero__orbs{opacity:.3}
body.a11y-readable,body.a11y-readable *{font-family:'Inter',var(--te)!important;letter-spacing:.01em}
body.a11y-links a{text-decoration:underline!important;text-underline-offset:3px}
body.a11y-stopmotion *{animation:none!important}

/* ---- DASHBOARD / CHARTS ---- */
.charts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.chart-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
body.dark .chart-card{background:#161823}
.chart-card--wide{grid-column:auto}
.chart-card h3{font-size:.98rem;margin-bottom:.85rem}
/* Uniform, smaller chart area — all three render the same height */
.chart-box{position:relative;height:200px}
.chart-box canvas{position:absolute;inset:0;width:100%!important;height:100%!important}

/* ---- MAP ---- */
.map-wrap{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.works-map{height:440px;width:100%;background:var(--bg-alt)}
.leaflet-container{font-family:inherit}
.map-legend{position:absolute;right:14px;bottom:14px;z-index:500;background:var(--bg);border:1px solid var(--line);
  border-radius:12px;padding:10px 14px;display:grid;gap:6px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow)}
body.dark .map-legend{background:#161823}
.map-legend span{display:flex;align-items:center;gap:8px}
.map-legend i{width:12px;height:12px;border-radius:50%;display:inline-block}
.works-popup b{display:block;font-size:.95rem;margin-bottom:2px}
.works-popup .st{display:inline-block;margin-top:4px;font-size:.72rem;font-weight:700;padding:.1rem .5rem;border-radius:999px;background:#16a34a;color:#fff}
.works-popup .st--prog{background:var(--yellow-deep)}

@media(max-width:920px){.charts{grid-template-columns:1fr}}

/* ---- TDP spinning cycle-wheel accent on every section kicker ---- */
.kicker{display:inline-flex;align-items:center;gap:.5rem}
.kicker::before{content:"";width:16px;height:16px;flex:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cg fill='none' stroke='%23E0322A' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 3v18M3 12h18M5.6 5.6l12.8 12.8M18.4 5.6L5.6 18.4'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
  animation:roll 3.5s linear infinite}
.kicker--light::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cg fill='none' stroke='%23FFC20E' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 3v18M3 12h18M5.6 5.6l12.8 12.8M18.4 5.6L5.6 18.4'/%3E%3C/g%3E%3C/svg%3E")}

/* ---- faint floating-cycle layer injected into more sections ---- */
.sec-symbols{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;opacity:.05}
.sec-symbols .float-sym{color:var(--red)}
.section{position:relative}
.section>.container{position:relative;z-index:1}

/* ============================================================
   ADVANCED v5 â€” scrollytelling, services, events+countdown,
   social wall, join/volunteer/contribute
   ============================================================ */

/* ---- STORY (scrollytelling, sticky) ---- */
.story{background:var(--bg);padding:40px 0}
.story__inner{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.story__sticky{position:sticky;top:110px;height:max-content}
.story__visual{position:relative;max-width:420px}
.story__visual .photo-frame{transition:transform .6s}
.story__year{position:absolute;bottom:-18px;right:-10px;font-family:'Poppins';font-weight:800;font-size:2.4rem;
  background:var(--dark);color:var(--yellow);padding:.3rem 1.1rem;border-radius:14px;box-shadow:var(--shadow);
  transition:transform .4s}
.story__steps{display:grid;gap:18px;padding:60px 0}
.story__intro{margin-bottom:10px}
.story__step{background:var(--bg-alt);border:1px solid var(--line);border-left:4px solid var(--line);
  border-radius:14px;padding:24px;opacity:.45;transform:translateY(10px);transition:.45s}
body.dark .story__step{background:#161823}
.story__step.is-active{opacity:1;transform:none;border-left-color:var(--red);box-shadow:var(--shadow)}
.story__step:hover{opacity:1;transform:none;border-left-color:var(--red);box-shadow:var(--shadow)}
.story__step h3{font-size:1.2rem;margin-bottom:.5rem}
.story__step p{color:var(--muted)}

/* ---- SERVICES (Mana Mitra) ---- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px;position:relative;z-index:2}
.service-card{display:flex;gap:14px;align-items:center;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:18px 20px;transition:.25s;backdrop-filter:blur(6px);color:#fff}
.service-card:hover{transform:translateY(-5px);border-color:var(--yellow);box-shadow:var(--shadow)}
.service-card__ico{font-size:1.8rem;flex:none}
.service-card strong{display:block;font-size:1rem}
.service-card small{color:#c9ccd6;font-size:.82rem}
.service-card--wa:hover{background:rgba(37,211,102,.16)}
.service-card--mm:hover{background:rgba(255,194,14,.14)}

/* ---- COUNTDOWN ---- */
.countdown{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;
  background:var(--grad);border-radius:var(--radius);padding:26px 32px;margin-bottom:36px;color:#1a1300;box-shadow:var(--shadow)}
.countdown__label span{font-family:'Poppins';font-weight:800;font-size:1.15rem}
.countdown__clock{display:flex;gap:14px}
.cd{background:rgba(0,0,0,.85);color:#fff;border-radius:12px;padding:.6rem 1rem;text-align:center;min-width:62px}
.cd b{display:block;font-family:'Poppins';font-size:1.7rem;color:var(--yellow)}
.cd span{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;opacity:.85}

/* ---- EVENTS ---- */
.events{display:grid;gap:14px}
.event{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;background:var(--bg);
  border:1px solid var(--line);border-radius:14px;padding:18px 22px;transition:.25s}
body.dark .event{background:#161823}
.event:hover{transform:translateX(6px);border-color:var(--red);box-shadow:var(--shadow)}
.event__date{text-align:center;background:var(--bg-alt);border-radius:12px;padding:.6rem .9rem;min-width:64px}
body.dark .event__date{background:#0f1018}
.event__date b{display:block;font-family:'Poppins';font-size:1.5rem;color:var(--red);line-height:1}
.event__date span{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.event__info h3{font-size:1.08rem}
.event__info p{color:var(--muted);font-size:.9rem}
.event__rsvp{white-space:nowrap}

/* ---- SOCIAL WALL ---- */
.social-wall{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.social-col h3{font-size:1.1rem;margin-bottom:14px;display:flex;gap:.5rem;align-items:center}
.social-embed{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;min-height:360px}
body.dark .social-embed{background:#161823}
.social-embed iframe{width:100%;border:0;display:block;min-height:420px}
.social-embed--ph{display:grid;place-items:center;text-align:center;color:var(--muted);padding:30px;min-height:360px}
.social-embed .twitter-tweet{margin:0 auto!important}
.x-fallback{display:flex;flex-direction:column;gap:.4rem;text-decoration:none;color:var(--ink)}
.x-fallback strong{font-size:1.15rem}
.x-fallback span{color:var(--red);font-weight:700}

/* ---- JOIN / VOLUNTEER / CONTRIBUTE ---- */
.join-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.join-tab{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:999px;
  padding:.65rem 1.4rem;font-weight:700;cursor:pointer;transition:.2s}
.join-tab:hover{border-color:var(--yellow)}
.join-tab.is-active{background:var(--grad);color:#1a1300;border-color:transparent}
.join-panels{max-width:680px;margin:0 auto}
.join-panel{display:none}
.join-panel.is-active{display:block;animation:fadeIn .35s ease}
.join-contribute{padding:28px}
.join-contribute h3{margin-bottom:.6rem}
.join-contribute p{color:var(--muted)}
.contribute__row{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-top:18px}
.contribute__qr{width:160px;height:160px;border-radius:14px;background:#fff;display:grid;place-items:center;overflow:hidden;flex:none;border:1px solid var(--line)}
.contribute__qr img{width:100%;height:100%}
.contribute__upi{margin-bottom:12px}
.contribute__upi span{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.contribute__upi strong{font-family:'Poppins';font-size:1.3rem;color:var(--ink)}
.contribute__note{font-size:.78rem;color:var(--muted);margin-top:10px}

@media(max-width:860px){
  .story__inner{grid-template-columns:1fr}
  .story__sticky{position:relative;top:0;margin:0 auto}
  .story__steps{padding:24px 0}
  .services,.social-wall{grid-template-columns:1fr}
  .countdown{flex-direction:column;text-align:center}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .bike--xl path,.bike--xl circle{stroke-dashoffset:0}
  .reveal{opacity:1!important;transform:none!important}
  /* keep the LATEST news ticker scrolling — it is core content, not decoration */
  .ticker__track{animation:marquee 34s linear infinite!important}
}

/* ---- PRINT ---- */
@media print{
  .topbar,.header,.ticker,.bento-wrap,.wa-float,.to-top,.scroll-progress,.cursor-glow,
  .hero__orbs,.party__symbols,.lightbox,.preloader,.hamburger,.social,form,.contact__map{display:none!important}
  *{box-shadow:none!important;background:#fff!important;color:#000!important;animation:none!important}
  body{font-size:12pt}
  .section{padding:18px 0;page-break-inside:avoid}
}
