/* ============================================================
   CINEMATIC DREAM — Premium Editorial Film-Ecosystem
   Design System  ·  cinematic-luxury (ink / magenta / purple / gold)
   ============================================================ */

/* ---------- 1. DESIGN TOKENS ---------- */
:root{
  /* backgrounds */
  --ink:#0B0710;
  --aubergine:#140A18;
  --plum:#1C0E22;
  /* accents */
  --magenta:#E11D74;
  --crimson:#F43F5E;
  --purple:#8B5CF6;
  --violet:#7C3AED;
  --gold:#F5B544;
  --gold-2:#E8B04B;
  /* text */
  --ivory:#F6F1F4;
  --muted:#B9A9C2;
  --muted-2:#8A7A95;
  /* glass / lines */
  --line:rgba(245,181,68,.20);
  --line-soft:rgba(246,241,244,.08);
  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(28,14,34,.55);
  /* type */
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --hindi:'Tiro Devanagari Hindi',serif;
  --mono:'DM Mono','SF Mono',monospace;
  /* scale */
  --display:clamp(3.5rem,9vw,9rem);
  --mega:clamp(2rem,4.2vw,3.5rem);
  --huge:clamp(2rem,4.5vw,4.5rem);
  --editorial:clamp(1.5rem,2.5vw,2.25rem);
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---------- 2. RESET / BASE ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--ivory);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--magenta);color:#fff}

/* custom scrollbar */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--magenta),var(--violet));border-radius:10px;border:2px solid var(--ink)}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(var(--crimson),var(--purple))}

/* ---------- 3. LAYOUT HELPERS ---------- */
.wrap{max-width:1280px;margin-inline:auto;padding-inline:clamp(1.25rem,4vw,3rem)}
.section{position:relative;padding-block:clamp(4.5rem,10vw,9rem)}
.center{text-align:center}
/* .grain kept as a class hook only; the noise is now ONE fixed full-screen layer (#grain-overlay)
   so it never repaints per-section and uses a normal blend (no mix-blend-mode recomposite). */
.grain{position:relative}
#grain-overlay{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  will-change:auto;transform:translateZ(0);contain:strict;
}

/* spotlight / vignette */
.vignette::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 55% at 50% 0%,rgba(225,29,116,.10),transparent 60%),
             radial-gradient(circle at 80% 90%,rgba(139,92,246,.10),transparent 55%);
}

/* ---------- 4. TYPOGRAPHY ---------- */
.kicker{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:.6rem;font-weight:500;
}
.kicker::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold)}
.kicker.mag{color:var(--crimson)}
.kicker.mag::before{background:var(--crimson);box-shadow:0 0 12px var(--crimson)}

.serif{font-family:var(--serif);font-weight:340;letter-spacing:-.02em;line-height:1.02}
.serif em{font-style:italic;font-weight:300;color:var(--gold-2)}
.serif .mg{color:var(--crimson);font-style:italic;font-weight:300}
.hindi{font-family:var(--hindi);font-weight:400}
.mono{font-family:var(--mono)}

h1,h2,h3{font-family:var(--serif);font-weight:360;letter-spacing:-.02em;line-height:1.04}
.t-display{font-size:var(--display)}
.t-mega{font-size:var(--mega)}
.t-huge{font-size:var(--huge)}
.t-edit{font-size:var(--editorial)}

.lead{font-size:clamp(1rem,1.3vw,1.0625rem);color:var(--muted);max-width:60ch}
.muted{color:var(--muted)}
.gold-text{color:var(--gold-2)}
.mag-text{color:var(--crimson)}

/* gold hairline */
.hairline{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);border:0;margin-block:2rem}
.hairline.left{background:linear-gradient(90deg,var(--gold),transparent)}

/* ---------- 5. GLASS / CARDS ---------- */
/* backdrop-filter removed (it repaints on every scroll frame). Replaced with slightly more
   opaque solid backgrounds that look visually identical over the dark page bg. */
.glass{
  background:rgba(36,22,44,.55);
  border:1px solid var(--line-soft);border-radius:18px;
}
.glass-dark{
  background:rgba(24,13,30,.78);
  border:1px solid var(--line);border-radius:18px;
}
.lift{transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}
.lift:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 24px 60px -24px rgba(225,29,116,.35)}

/* ---------- 6. BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 1.6rem;border-radius:999px;
  font-size:.9rem;font-weight:500;letter-spacing:.01em;transition:all .4s var(--ease);white-space:nowrap;
}
.btn i{transition:transform .4s var(--ease)}
.btn:hover i{transform:translateX(4px)}
.btn-primary{background:linear-gradient(135deg,var(--magenta),var(--violet));color:#fff;box-shadow:0 10px 30px -10px rgba(225,29,116,.6)}
.btn-primary:hover{box-shadow:0 16px 44px -10px rgba(225,29,116,.85);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#1a0f06;font-weight:600;box-shadow:0 10px 30px -10px rgba(245,181,68,.55)}
.btn-gold:hover{box-shadow:0 16px 44px -10px rgba(245,181,68,.8);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--ivory);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(245,181,68,.06)}

/* ---------- 7. FLOATING BLOBS ---------- */
/* lighter blur + GPU containment so the (transform-only) animation never repaints siblings */
.blob{position:absolute;border-radius:50%;filter:blur(32px);opacity:.45;pointer-events:none;z-index:0;
  transform:translateZ(0);contain:strict}
.blob-mag{background:radial-gradient(circle,rgba(225,29,116,.6),transparent 70%)}
.blob-pur{background:radial-gradient(circle,rgba(139,92,246,.55),transparent 70%)}
.blob-gold{background:radial-gradient(circle,rgba(245,181,68,.4),transparent 70%)}
@keyframes float1{0%,100%{transform:translateZ(0) translate(0,0) scale(1)}50%{transform:translateZ(0) translate(40px,-30px) scale(1.1)}}
@keyframes float2{0%,100%{transform:translateZ(0) translate(0,0) scale(1)}50%{transform:translateZ(0) translate(-35px,40px) scale(1.08)}}
/* animate blobs only on capable, non-touch, reduced-motion-OK environments */
@media (min-width:1024px) and (prefers-reduced-motion:no-preference){
  .float1{animation:float1 16s ease-in-out infinite}
  .float2{animation:float2 20s ease-in-out infinite}
}

/* sprocket / film reel motif */
@keyframes spin{to{transform:translateZ(0) rotate(360deg)}}
.reel{animation:spin 40s linear infinite;opacity:.12;will-change:transform;transform:translateZ(0)}
/* drop the spinning reel on tablet & below */
@media (max-width:1024px){.reel{display:none}}
@media (prefers-reduced-motion:reduce){.reel{animation:none}}

/* ---------- 8. IMAGE FRAME ---------- */
.img-frame{position:relative;overflow:hidden;border-radius:18px;border:1px solid var(--line-soft)}
.img-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);filter:saturate(1.05) contrast(1.03)}
.img-frame:hover img{transform:scale(1.06)}
.img-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,7,16,.7),transparent 55%);pointer-events:none}
.img-frame .stamp{
  position:absolute;top:14px;left:14px;z-index:3;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);background:rgba(11,7,16,.78);border:1px solid var(--line);
  padding:.3rem .6rem;border-radius:6px;
}
.img-frame .cap{position:absolute;bottom:14px;left:16px;right:16px;z-index:3;font-size:.8rem;color:var(--ivory)}

/* ---------- 9. REVEAL / MOTION ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}

/* counters keep visible */
[data-count]{font-variant-numeric:tabular-nums}

/* ---------- 10. MARQUEE ---------- */
.marquee{overflow:hidden;white-space:nowrap;border-block:1px solid var(--line-soft);padding-block:1.1rem}
.marquee-track{display:inline-flex;gap:2.5rem;animation:scroll-x 28s linear infinite;transform:translateZ(0)}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll-x{from{transform:translateZ(0) translateX(0)}to{transform:translateZ(0) translateX(-50%)}}
.tag{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--muted)}
.tag .dot{color:var(--magenta);font-style:normal;margin-left:2.5rem}

/* ---------- 11. HEADER ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:80;padding:1rem clamp(1rem,4vw,2rem);transition:padding .35s var(--ease)}
.navbar{
  max-width:1240px;margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.7rem 1.2rem;border-radius:999px;border:1px solid var(--line-soft);
  background:rgba(11,7,16,.82);transition:background .35s var(--ease),border-color .35s var(--ease),padding .35s var(--ease);
}
.header.scrolled{padding-top:.55rem;padding-bottom:.55rem}
.header.scrolled .navbar{background:rgba(11,7,16,.85);border-color:var(--line)}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--serif);font-size:1.15rem;letter-spacing:-.01em}
.brand .name .star{color:var(--gold)}
.brand .sub{font-family:var(--hindi);font-size:.62rem;color:var(--muted);letter-spacing:.04em;margin-top:2px}
.nav-links{display:flex;gap:1.6rem}
.nav-links a{font-size:.82rem;color:var(--muted);transition:color .3s;position:relative}
.nav-links a:hover{color:var(--ivory)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.clock{font-family:var(--mono);font-size:.72rem;color:var(--gold-2);letter-spacing:.04em;white-space:nowrap}
.burger{display:none;font-size:1.3rem;color:var(--ivory)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:79;background:rgba(11,7,16,.98);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s var(--ease)}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--serif);font-size:1.8rem}

/* ---------- 12. HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  padding-top:7rem;padding-bottom:3rem;
  background:radial-gradient(ellipse 90% 70% at 20% 10%,var(--plum),var(--ink) 60%),var(--ink);overflow:hidden}
/* 12-col grid · both columns aligned to same top baseline & vertically centered */
.hero-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(2rem,5vw,4.5rem);
  align-items:center;position:relative;z-index:5}
.hero-copy{grid-column:span 6;max-width:36rem}      /* lg:col-span-6 + max-w-xl */
.collage{grid-column:span 6}                          /* lg:col-span-6 */
.hero-bar{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-bottom:1.8rem}
.hero-bar .hindi{font-style:italic;color:var(--gold-2);font-size:1rem}
/* capped, responsive headline — NOT the giant display scale */
.hero h1{font-size:clamp(1.875rem,3.5vw,3rem);line-height:1.08;letter-spacing:-.02em;margin:0}
.hero-copy .lead{margin-top:1.5rem}                   /* mt-6 */
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}      /* mt-8 */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2.5rem;
  border-top:1px solid var(--line-soft);padding-top:1.6rem}            /* mt-10 */
.stat .num{font-family:var(--serif);font-size:clamp(1.1rem,1.8vw,1.5rem);color:var(--ivory);line-height:1.1}
.stat .lbl{font-size:.72rem;color:var(--muted);margin-top:.4rem;letter-spacing:.02em}

/* hero collage — height-stable, predictable, aligns beside text */
.collage{position:relative;height:72vh;min-height:420px;max-height:640px}
.collage .img-frame{position:absolute;box-shadow:0 30px 80px -30px rgba(0,0,0,.8)}
.collage .img-frame img{width:100%;height:100%;object-fit:cover}
.c1{width:62%;height:74%;top:0;right:0;z-index:2}
.c2{width:46%;height:50%;bottom:0;left:0;z-index:3}
.c3{width:40%;height:32%;bottom:6%;right:8%;z-index:4}
.chip{position:absolute;z-index:6;font-size:.72rem;padding:.5rem .85rem;border-radius:999px;
  display:flex;align-items:center;gap:.5rem;color:var(--ivory);white-space:nowrap}
.chip i{color:var(--gold)}
.chip-1{top:8%;left:-4%}
.chip-2{top:46%;right:-6%}
.chip-3{bottom:-3%;left:30%}

/* ---------- 13. GENERIC SECTION HEADER ---------- */
.sec-head{max-width:760px;margin-bottom:3.5rem}
.sec-head h2{margin-block:1.2rem .8rem}
.sec-head.center{margin-inline:auto}

/* ---------- 14. STORY (alternating blocks) ---------- */
.story-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;margin-bottom:clamp(4rem,8vw,7rem)}
.story-block:nth-child(even) .story-media{order:2}
.story-block .num-big{font-family:var(--serif);font-size:clamp(3rem,7vw,6rem);color:rgba(245,181,68,.18);line-height:.8}
.story-media{height:min(60vh,520px)}

/* ---------- 15. CARD GRIDS ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.problem-card{padding:2rem;height:100%}
.problem-card .pn{font-family:var(--mono);font-size:.78rem;color:var(--gold);letter-spacing:.2em}
.problem-card h3{font-size:1.35rem;margin-block:1rem .7rem}
.problem-card .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.1rem;
  background:linear-gradient(135deg,rgba(225,29,116,.2),rgba(139,92,246,.2));color:var(--crimson);margin-bottom:1.2rem;border:1px solid var(--line-soft)}
.problem-card .mini{margin-top:1rem;font-family:var(--mono);font-size:.72rem;color:var(--gold-2);
  border-top:1px dashed var(--line);padding-top:.8rem}

/* ---------- 16. OPPORTUNITY STATS ---------- */
.opp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.opp-stat{padding:1.8rem;text-align:center}
.opp-stat .num{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);
  background:linear-gradient(135deg,var(--crimson),var(--purple));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.opp-stat .lbl{font-size:.8rem;color:var(--muted);margin-top:.6rem}

/* ---------- 17. PILLARS DIAGRAM ---------- */
.pillars{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;position:relative;
  contain:layout style;
}
.pillar{
  padding:1.9rem 1.6rem;position:relative;height:100%;
  contain:layout style paint;
  transition:border-color .35s var(--ease),transform .35s var(--ease);
}
.pillar:hover{border-color:var(--line);transform:translateY(-4px)}
.pillar .pidx{font-family:var(--mono);font-size:.72rem;color:var(--gold);letter-spacing:.18em}
.pillar .picon{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:1.3rem;margin:1rem 0;
  background:linear-gradient(135deg,var(--magenta),var(--violet));color:#fff;
  box-shadow:0 8px 24px -8px rgba(225,29,116,.45);
}
.pillar h3{font-size:1.3rem;margin-bottom:.6rem;position:relative;z-index:1}
.pillar .role{font-family:var(--mono);font-size:.68rem;color:var(--gold-2);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.8rem}

/* ---------- 18. FLYWHEEL ---------- */
.flywheel{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.fw-stage{position:relative;width:min(420px,80vw);aspect-ratio:1;margin-inline:auto}
.fw-ring{position:absolute;inset:0;border-radius:50%;border:1px dashed var(--line);animation:spin 60s linear infinite}
.fw-ring.inner{inset:18%;border-color:var(--line-soft);animation-direction:reverse;animation-duration:45s}
.fw-center{position:absolute;inset:33%;border-radius:50%;display:grid;place-items:center;text-align:center;
  background:radial-gradient(circle,var(--plum),var(--aubergine));border:1px solid var(--line);
  font-family:var(--serif);font-size:1rem;color:var(--gold-2);padding:1rem}
.fw-node{position:absolute;width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-size:1.1rem;
  background:rgba(24,13,30,.85);border:1px solid var(--line);color:var(--crimson);
  left:50%;top:50%;transform:translate(-50%,-50%)}
.fw-step{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line-soft)}
.fw-step .s-n{font-family:var(--mono);color:var(--gold);font-size:.85rem;min-width:1.5rem}
.fw-step strong{font-family:var(--serif);font-weight:400}

/* ---------- 19. JOURNEY PANELS ---------- */
.journey-panel{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;margin-bottom:clamp(3rem,7vw,6rem)}
.journey-panel:nth-child(even) .jp-media{order:2}
.jp-media{height:min(56vh,480px)}
.jp-mod{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;color:var(--gold)}
.jp-meta{margin-top:1.5rem;display:flex;flex-direction:column;gap:.7rem}
.jp-meta li{display:flex;gap:.7rem;align-items:center;font-size:.9rem;color:var(--muted)}
.jp-meta li i{color:var(--crimson);font-size:.8rem}
.jp-apply{margin-top:1.8rem;display:inline-flex;gap:.5rem;align-items:center;color:var(--gold-2);font-size:.9rem;font-family:var(--mono);letter-spacing:.05em}
.jp-apply:hover{color:var(--gold)}

/* ---------- 20. WHO CAN APPLY ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.cat-card{padding:1.4rem;display:flex;align-items:center;gap:1rem;transition:all .4s var(--ease);cursor:default}
.cat-card .ci{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(139,92,246,.18),rgba(225,29,116,.18));color:var(--gold);font-size:1rem;flex-shrink:0;transition:all .4s}
.cat-card:hover{border-color:var(--line);transform:translateY(-4px)}
.cat-card:hover .ci{background:linear-gradient(135deg,var(--magenta),var(--violet));color:#fff}
.cat-card h4{font-size:.95rem;font-weight:500;font-family:var(--sans)}
.cat-card .cd{font-size:.72rem;color:var(--muted-2);max-height:0;overflow:hidden;transition:max-height .4s,margin .4s}
.cat-card:hover .cd{max-height:40px;margin-top:.3rem}

/* ---------- 21. ACADEMY / TICKET CARDS ---------- */
.fee-banner{padding:1.4rem 1.8rem;border-radius:16px;display:flex;gap:1rem;align-items:center;
  background:linear-gradient(135deg,rgba(245,181,68,.12),rgba(225,29,116,.08));border:1px solid var(--line);margin-bottom:3rem}
.fee-banner i{font-size:1.6rem;color:var(--gold)}
.fee-banner p{font-size:.95rem}
.fee-banner strong{color:var(--gold-2);font-family:var(--serif);font-weight:400}
.tickets{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.ticket{position:relative;padding:2.2rem 1.8rem;border-radius:18px;overflow:hidden;
  background:linear-gradient(160deg,#241225,#160b1c);border:1px solid var(--line)}
.ticket::before{content:"";position:absolute;inset:0;background:
  linear-gradient(135deg,transparent 40%,rgba(245,181,68,.08) 50%,transparent 60%);pointer-events:none}
.ticket .perf{position:absolute;top:50%;width:18px;height:18px;border-radius:50%;background:var(--ink);transform:translateY(-50%)}
.ticket .perf.l{left:-9px}.ticket .perf.r{right:-9px}
.ticket .tier{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase}
.ticket .price{font-family:var(--serif);font-size:2.6rem;margin-block:.6rem .2rem}
.ticket .price small{font-size:1rem;color:var(--muted)}
.ticket ul{margin-top:1.4rem;display:flex;flex-direction:column;gap:.7rem;border-top:1px dashed var(--line);padding-top:1.4rem}
.ticket li{font-size:.85rem;color:var(--muted);display:flex;gap:.6rem;align-items:flex-start}
.ticket li i{color:var(--gold-2);font-size:.75rem;margin-top:.3rem}
.ticket.featured{border-color:var(--gold);background:linear-gradient(160deg,#2a1430,#1a0d22)}
.ticket.featured .price{background:linear-gradient(135deg,var(--gold),var(--crimson));-webkit-background-clip:text;background-clip:text;color:transparent}
.badge{position:absolute;top:1.4rem;right:1.4rem;font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;
  background:var(--gold);color:#1a0f06;padding:.25rem .55rem;border-radius:6px}
.track-pills{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:2.5rem}
.track-pill{padding:.6rem 1.2rem;border-radius:999px;border:1px solid var(--line);font-size:.85rem;color:var(--muted);background:rgba(255,255,255,.02)}
.track-pill i{color:var(--gold);margin-right:.5rem}

/* ---------- 22. GOVERNMENT MOSAIC ---------- */
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(110px,auto);gap:1.25rem}
.mtile{padding:1.6rem;border:1px solid var(--line-soft);border-radius:16px;background:var(--glass);position:relative;overflow:hidden}
.mtile .bp{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--gold);text-transform:uppercase}
.mtile h4{font-family:var(--serif);font-weight:400;font-size:1.2rem;margin-block:.6rem .5rem}
.mtile p{font-size:.85rem;color:var(--muted)}
.mtile i.big{position:absolute;right:-10px;bottom:-10px;font-size:4rem;color:rgba(245,181,68,.07)}
.m-wide{grid-column:span 3}.m-mid{grid-column:span 2}.m-tall{grid-row:span 2}.m-full{grid-column:span 6}

/* ---------- 23. WIZARD ---------- */
.wizard{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border-radius:24px;overflow:hidden;border:1px solid var(--line)}
.wiz-media{position:relative;min-height:560px;background-size:cover;background-position:center}
.wiz-media::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(225,29,116,.25),rgba(11,7,16,.85))}
.wiz-media .wm-inner{position:absolute;inset:0;z-index:2;padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between}
.wiz-media h3{font-size:1.8rem;line-height:1.1}
.wiz-media .wm-hindi{font-family:var(--hindi);color:var(--gold-2);font-size:.95rem;margin-top:.6rem}
.wiz-body{background:linear-gradient(160deg,#190d1f,#120912);padding:clamp(1.8rem,3vw,2.8rem);display:flex;flex-direction:column}
.dots{display:flex;gap:.5rem;margin-bottom:.4rem}
.dot{height:5px;flex:1;border-radius:5px;background:rgba(255,255,255,.1);transition:all .5s var(--ease)}
.dot.active{background:linear-gradient(90deg,var(--magenta),var(--gold));flex:2.2}
.dot.done{background:var(--gold-2)}
.wiz-step{display:none;animation:fadeUp .5s var(--ease)}
.wiz-step.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.step-no{font-family:var(--mono);font-size:.72rem;color:var(--gold);letter-spacing:.2em;margin-top:1.2rem}
.wiz-step h4{font-size:1.5rem;margin-block:.4rem 1.4rem;font-weight:400}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:.45rem;letter-spacing:.02em}
.field label .req{color:var(--crimson)}
.field input,.field select,.field textarea{
  width:100%;padding:.8rem 1rem;border-radius:11px;background:rgba(255,255,255,.04);
  border:1px solid var(--line-soft);color:var(--ivory);font-family:inherit;font-size:.92rem;transition:border-color .3s,background .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(245,181,68,.05)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field textarea{resize:vertical;min-height:80px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23B9A9C2'%3E%3Cpath d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.chips{display:flex;gap:.6rem;flex-wrap:wrap}
.chip-sel{padding:.5rem 1rem;border-radius:999px;border:1px solid var(--line-soft);font-size:.82rem;color:var(--muted);
  background:rgba(255,255,255,.02);transition:all .3s;user-select:none}
.chip-sel:hover{border-color:var(--line)}
.chip-sel.on{background:linear-gradient(135deg,var(--magenta),var(--violet));color:#fff;border-color:transparent}
.field-row-city .ex-chips{grid-column:1/-1;min-width:0}
.ex-chips{display:flex;gap:.5rem;flex-wrap:nowrap;margin-top:.25rem;overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;overscroll-behavior-x:contain}
.ex-chips::-webkit-scrollbar{display:none}
.ex-chip{flex:0 0 auto;white-space:nowrap;font-size:.72rem;color:var(--gold-2);border:1px dashed var(--line);padding:.25rem .6rem;border-radius:6px;cursor:pointer}
.ex-chip:hover{background:rgba(245,181,68,.08)}
.check{display:flex;gap:.7rem;align-items:flex-start;font-size:.85rem;color:var(--muted);margin-bottom:1rem;cursor:pointer}
.check input{width:18px;height:18px;margin-top:2px;accent-color:var(--magenta);flex-shrink:0}
.wiz-nav{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1.8rem;gap:1rem}
.guardian{display:none}
.guardian.show{display:block;animation:fadeUp .4s var(--ease)}
.welcome-card{text-align:center;padding:1rem 0}
.welcome-card .tick{width:80px;height:80px;border-radius:50%;margin:0 auto 1.5rem;display:grid;place-items:center;font-size:2rem;
  background:linear-gradient(135deg,var(--gold),var(--crimson));color:#fff;animation:pop .6s var(--ease)}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.ref-id{font-family:var(--mono);font-size:1.3rem;color:var(--gold);letter-spacing:.1em;
  background:rgba(245,181,68,.08);border:1px dashed var(--line);padding:.8rem 1.4rem;border-radius:12px;
  display:inline-flex;gap:1rem;align-items:center;margin-top:1.2rem}
.ref-id button{color:var(--muted);font-size:.9rem}
.ref-id button:hover{color:var(--gold)}
.audio-btn{display:inline-flex;gap:.5rem;align-items:center;font-size:.78rem;color:var(--muted);
  border:1px solid var(--line-soft);padding:.4rem .8rem;border-radius:999px}
.audio-btn:hover{border-color:var(--gold);color:var(--gold-2)}

/* ---------- 24. IMPACT CHART ---------- */
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:3rem}
.impact-stat .num{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1;
  background:linear-gradient(135deg,var(--gold),var(--crimson));-webkit-background-clip:text;background-clip:text;color:transparent}
.impact-stat .lbl{font-size:.82rem;color:var(--muted);margin-top:.5rem}
.chart-wrap{padding:2.2rem}
.chart-wrap svg{width:100%;height:auto;display:block}

/* ---------- 25. COMPARISON ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.compare-col{padding:2rem;height:100%}
.compare-col.bad{border:1px solid rgba(244,63,94,.25);background:linear-gradient(160deg,rgba(244,63,94,.06),transparent)}
.compare-col.good{border:1px solid var(--line);background:linear-gradient(160deg,rgba(245,181,68,.08),transparent)}
.compare-col h3{font-size:1.4rem;margin-bottom:1.4rem;display:flex;gap:.7rem;align-items:center}
.compare-col.bad h3 i{color:var(--crimson)}
.compare-col.good h3 i{color:var(--gold)}
.compare-col li{display:flex;gap:.7rem;padding:.7rem 0;border-bottom:1px solid var(--line-soft);font-size:.9rem;color:var(--muted)}
.compare-col li i{font-size:.8rem;margin-top:.25rem}
.compare-col.bad li i{color:var(--crimson)}
.compare-col.good li i{color:var(--gold-2)}
.proof{margin-top:2.5rem;padding:1.4rem 1.8rem;text-align:center;border-radius:14px;background:var(--glass);border:1px solid var(--line-soft)}
.proof strong{color:var(--gold-2);font-family:var(--serif);font-weight:400}

/* ---------- 26. TESTIMONIALS ---------- */
.testi-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:1.5rem;scrollbar-width:thin}
.testi-track::-webkit-scrollbar{height:6px}
.testi-card{flex:0 0 clamp(280px,32vw,360px);scroll-snap-align:start}
.testi-card .img-frame{aspect-ratio:4/5}
.testi-card .body{padding:1.4rem 0}
.testi-card .where{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.testi-card .story{font-family:var(--serif);font-size:1.15rem;font-weight:340;margin-block:.7rem;line-height:1.35}
.testi-card .metric{font-size:.82rem;color:var(--crimson);font-family:var(--mono)}

/* ---------- 27. FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line-soft)}
.faq-item summary{padding:1.4rem 0;font-family:var(--serif);font-size:clamp(1.1rem,1.8vw,1.4rem);font-weight:360;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:2rem;align-items:center;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--gold-2)}
.faq-item summary .pm{font-family:var(--mono);color:var(--gold);font-size:1.4rem;transition:transform .4s var(--ease);flex-shrink:0}
.faq-item[open] summary .pm{transform:rotate(45deg)}
.faq-item .ans{padding-bottom:1.5rem;color:var(--muted);font-size:.95rem;max-width:70ch}

/* ---------- 28. FOOTER ---------- */
.footer{background:radial-gradient(ellipse 80% 60% at 50% 0%,var(--plum),var(--ink));border-top:1px solid var(--line);position:relative}
.foot-cta{text-align:center;padding-block:clamp(3rem,7vw,5rem) 3rem}
.foot-cta h2{font-size:var(--huge);margin-block:1rem 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-block:3rem;border-top:1px solid var(--line-soft)}
.foot-col h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-bottom:1.2rem}
.foot-col a{display:block;font-size:.88rem;color:var(--muted);padding:.35rem 0;transition:color .3s}
.foot-col a:hover{color:var(--ivory)}
.foot-brand .name{font-family:var(--serif);font-size:1.6rem}
.foot-brand .name .star{color:var(--gold)}
.foot-brand p{font-size:.9rem;color:var(--muted);margin-top:1rem;max-width:34ch}
.foot-socials{display:flex;gap:.8rem;margin-top:1.5rem}
.foot-socials a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line-soft);color:var(--muted);transition:all .3s}
.foot-socials a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.map-block{padding-block:3rem;border-top:1px solid var(--line-soft)}
.map-svg{width:100%;max-width:760px;margin-inline:auto;display:block}
.map-dot{fill:var(--crimson)}
.map-dot.pulse{animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{r:3;opacity:1}50%{r:5;opacity:.6}}
.map-label{fill:var(--muted);font-family:var(--mono);font-size:9px}
.foot-legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-block:2rem;border-top:1px solid var(--line-soft);font-size:.8rem;color:var(--muted-2)}
.foot-tag{font-family:var(--hindi);color:var(--gold-2);font-style:normal}

/* pause decorative animations while scrolling to free the compositor */
body.is-scrolling .float1,
body.is-scrolling .float2,
body.is-scrolling .reel,
body.is-scrolling .marquee-track,
body.is-scrolling .fw-ring,
body.is-scrolling .map-dot.pulse{
  animation-play-state:paused!important;
}
body.is-scrolling .reveal{
  transition:none!important;
}

/* ---------- 29. RESPONSIVE ---------- */
@media (max-width:1024px){
  .nav-links{display:none}
  .burger{display:block}
  /* below lg: stack into single column — copy first, collage below */
  .hero-grid{grid-template-columns:1fr;gap:2.5rem;align-items:start}
  .hero-copy,.collage{grid-column:1 / -1}
  .hero-copy{max-width:none}
  .collage{height:58vh;min-height:380px;max-height:520px}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .grid-3,.tickets,.grid-4{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr 1fr}
  .flywheel{grid-template-columns:1fr;gap:2rem}
  .wizard{grid-template-columns:1fr}
  .wiz-media{min-height:200px}
  .mosaic{grid-template-columns:repeat(2,1fr)}
  .m-wide,.m-mid,.m-full{grid-column:span 2}.m-tall{grid-row:auto}
  .impact-grid,.opp-stats{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .clock{display:none}
  .story-block,.journey-panel{grid-template-columns:1fr;gap:1.8rem}
  .story-block:nth-child(even) .story-media,.journey-panel:nth-child(even) .jp-media{order:0}
  .grid-3,.grid-2,.grid-4,.tickets,.pillars,.compare,.opp-stats,.impact-grid,.foot-grid,.field-row,.field-row-3{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr}.m-wide,.m-mid,.m-full{grid-column:span 1}
  .stat-row{grid-template-columns:1fr 1fr}
  /* hero mobile: shorter, single clean framed image, smaller blobs */
  .hero{padding-top:6rem;min-height:88svh}
  .hero .blob{width:280px!important;height:280px!important;filter:blur(60px);opacity:.4}
  .hero .reel{display:none}
  .collage{height:auto;min-height:0;max-height:none}
  .collage .img-frame{position:relative;box-shadow:0 20px 50px -24px rgba(0,0,0,.8)}
  .c1{width:100%;height:auto;aspect-ratio:4/3;inset:auto}
  .c2,.c3{display:none}          /* avoid broken overlapping collage on mobile */
  .chip{display:none}
  .foot-legal{flex-direction:column}
}
