/* ═══════════════════════════════════════════════════════════════════
   ISMAAC – International Society of Ma Anandamayi Consciousness
   Complete Stylesheet v2.0 — Professional & Live
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --gold:         #C9982A;
  --gold-light:   #E8C96A;
  --gold-pale:    #FDF3DC;
  --gold-glow:    rgba(201,152,42,0.35);
  --saffron:      #E07B2A;
  --saffron-light:#F5A55A;
  --cream:        #FFFBF3;
  --parchment:    #F6EDD8;
  --burgundy:     #4A0E24;
  --maroon:       #7A2337;
  --deep-brown:   #1C0A05;
  --mid-brown:    #6B3F2A;
  --sage:         #7A9B76;
  --text-dark:    #2A1A0A;
  --text-mid:     #5C3D25;
  --text-light:   #9B7A5A;
  --white:        #FFFFFF;
  --dark-card:    rgba(255,255,255,0.07);
  --font-serif:   'Playfair Display','Noto Serif Devanagari',Georgia,serif;
  --font-sans:    'Lato',sans-serif;
  --font-hindi:   'Noto Serif Devanagari','Playfair Display',serif;
  --radius:       10px;
  --radius-lg:    18px;
  --shadow:       0 4px 24px rgba(74,14,36,0.10);
  --shadow-lg:    0 12px 48px rgba(74,14,36,0.22);
  --shadow-gold:  0 8px 32px rgba(201,152,42,0.25);
  --transition:   0.35s ease;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-sans);background:var(--cream);color:var(--text-dark);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.lang-hi{font-family:var(--font-hindi)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4,h5{font-family:var(--font-serif);line-height:1.25;color:var(--burgundy)}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 0.75s ease,transform 0.75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity 0.75s ease,transform 0.75s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity 0.75s ease,transform 0.75s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.88);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* ── SECTION LABELS & HEADERS ── */
.section-label{font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;display:block}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:1rem}
.section-desc{color:var(--text-mid);max-width:640px;margin:0 auto;font-size:1.05rem}
.section-header.light .section-label{color:var(--gold-light)}
.section-header.light h2{color:var(--white)}
.divider-om{text-align:center;font-size:1.8rem;color:var(--gold);margin:1rem 0;opacity:.6;font-family:var(--font-hindi)}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--gold),var(--saffron));color:var(--white);padding:.9rem 2.1rem;border-radius:50px;font-weight:700;font-size:.95rem;letter-spacing:.04em;transition:var(--transition);border:none;cursor:pointer;box-shadow:0 4px 20px rgba(201,152,42,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(201,152,42,.5)}
.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;border:2px solid rgba(255,255,255,.7);color:var(--white);padding:.85rem 2rem;border-radius:50px;font-weight:700;font-size:.95rem;transition:var(--transition)}
.btn-ghost:hover{background:rgba(255,255,255,.15)}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;border:2px solid var(--gold);color:var(--gold);padding:.75rem 1.75rem;border-radius:50px;font-weight:700;font-size:.9rem;transition:var(--transition)}
.btn-secondary:hover{background:var(--gold);color:var(--white);box-shadow:var(--shadow-gold)}
.btn-outline-light{display:inline-flex;align-items:center;gap:.5rem;border:2px solid rgba(255,255,255,.65);color:var(--white);padding:.75rem 1.75rem;border-radius:50px;font-weight:700;font-size:.9rem;transition:var(--transition)}
.btn-outline-light:hover{background:rgba(255,255,255,.15)}
.btn-saffron{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--saffron),#c75e1a);color:var(--white);padding:.85rem 2rem;border-radius:50px;font-weight:700;font-size:.92rem;transition:var(--transition);box-shadow:0 4px 18px rgba(224,123,42,.4)}
.btn-saffron:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(224,123,42,.55)}

/* ═══════════════════════════════════════
   HEADER / NAV
   ═══════════════════════════════════════ */
#top-header{position:fixed;top:0;left:0;right:0;z-index:520;background:rgba(28,10,5,.97);border-bottom:1px solid rgba(201,152,42,.25);transition:var(--transition)}
.header-inner{display:flex;align-items:center;gap:1.5rem;max-width:1340px;margin:0 auto;padding:.85rem 2rem}
.logo-wrap{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.logo-dot{font-size:2.6rem;color:var(--gold);line-height:1;font-family:var(--font-serif);filter:drop-shadow(0 0 6px var(--gold-glow))}
.logo-text{font-family:var(--font-serif);font-size:1.5rem;color:var(--white);font-weight:700;letter-spacing:.05em}
.logo-sub{font-size:.62rem;color:rgba(255,255,255,.55);letter-spacing:.07em;display:none;max-width:180px;line-height:1.3}
@media(min-width:1100px){.logo-sub{display:block}}
.main-nav{display:flex;gap:.05rem;flex:1;justify-content:center;flex-wrap:nowrap}
.nav-link{color:rgba(255,255,255,.78);font-size:.78rem;font-weight:700;letter-spacing:.02em;padding:.4rem .6rem;border-radius:6px;transition:var(--transition);white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--gold-light);background:rgba(201,152,42,.14)}
/* Desktop active nav: gold underline indicator */
.nav-link.active{position:relative}
.nav-link.active::after{content:'';position:absolute;bottom:-2px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);border-radius:2px}
.header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0;margin-left:auto}
/* 3-way language switcher */
.lang-btns{display:flex;gap:1px;background:rgba(201,152,42,.12);border:1px solid rgba(201,152,42,.32);border-radius:22px;padding:2px;overflow:hidden;flex-shrink:0}
.lang-btn{background:transparent;border:none;color:rgba(255,255,255,.55);padding:.3rem .6rem;border-radius:18px;font-size:.72rem;cursor:pointer;transition:all .2s ease;font-family:var(--font-sans);font-weight:700;letter-spacing:.02em;white-space:nowrap;min-width:30px;text-align:center}
.lang-btn.active{background:var(--gold);color:#1a0a0f;box-shadow:0 2px 8px rgba(201,152,42,.4)}
.lang-btn:hover:not(.active){color:var(--gold-light);background:rgba(201,152,42,.12)}
/* keep backward compat */
.lang-toggle{display:none}
.hamburger{display:none;background:rgba(201,152,42,.12);border:1px solid rgba(201,152,42,.35);border-radius:8px;color:var(--gold-light);font-size:1.4rem;cursor:pointer;width:40px;height:38px;align-items:center;justify-content:center;transition:.2s;padding:0;flex-shrink:0}
.hamburger:hover{background:rgba(201,152,42,.22);border-color:rgba(201,152,42,.6)}
/* ── SIDEBAR NAV (≤1400px) ─────────────────────────────────────────── */
@media(max-width:1400px){
  .main-nav{
    display:flex;flex-direction:column;gap:0;
    position:fixed;top:0;right:0;bottom:0;
    width:min(300px,88vw);
    background:linear-gradient(175deg,#1a1225 0%,#15101e 100%);
    padding:0 0 2rem;
    border-left:1px solid rgba(201,152,42,.25);
    z-index:500;
    transform:translateX(100%);
    transition:transform .38s cubic-bezier(0.4,0,0.2,1);
    overflow-y:auto;overflow-x:hidden;
    scrollbar-width:thin;scrollbar-color:rgba(201,152,42,.2) transparent;
  }
  .main-nav.open{
    transform:translateX(0);
    box-shadow:-20px 0 60px rgba(0,0,0,.9);
  }
  .hamburger{display:flex}
  .logo-sub{display:none !important}
  .logo-swami{display:none !important}

  /* Nav link items */
  .nav-link{
    display:flex;align-items:center;gap:.85rem;
    padding:1rem 1.6rem;
    font-size:1rem;font-weight:600;
    letter-spacing:.01em;
    color:#e8e0f0;
    border:none;border-radius:0;
    margin:0;
    transition:color .2s ease,background .2s ease;
    position:relative;
  }
  /* gold bullet dot */
  .nav-link::before{
    content:'◦';
    font-size:1rem;
    color:#C9982A;
    opacity:1;
    flex-shrink:0;
    transition:opacity .2s,transform .2s;
  }
  .nav-link:hover{
    color:#ffffff;
    background:rgba(255,255,255,.06);
  }
  .nav-link:hover::before{content:'•';transform:scale(1.1)}
  .nav-link.active{
    color:#E8C96A;
    font-weight:700;
    background:rgba(201,152,42,.1);
  }
  .nav-link.active::before{
    content:'•';
    color:#C9982A;
  }
}

/* Sidebar brand header — injected by JS */
.nav-brand{
  display:none;
  padding:1.6rem 1.6rem 1.4rem;
  position:relative;
  flex-shrink:0;
  background:rgba(201,152,42,.06);
  border-bottom:1px solid rgba(201,152,42,.2);
}
@media(max-width:1400px){.nav-brand{display:flex;align-items:center;gap:.8rem}}
.nav-brand-om{
  font-family:var(--font-hindi);font-size:2rem;
  color:#C9982A;line-height:1;
  flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(201,152,42,.5));
}
.nav-brand-title{
  font-family:var(--font-serif);
  font-size:1.3rem;font-weight:700;
  color:#ffffff;letter-spacing:.08em;
  line-height:1;
}

/* Thin gold separator below brand */
.nav-brand-divider{
  display:none;
  height:1px;
  margin:0 1.6rem .6rem;
  background:rgba(201,152,42,.18);
}
@media(max-width:1400px){.nav-brand-divider{display:block}}

/* Sidebar overlay backdrop */
.nav-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.7);z-index:499;cursor:pointer;
}
.nav-overlay.open{display:block}

/* Close X — circular gold button top right */
.nav-close-btn{
  display:none;
  position:absolute;top:1.2rem;right:1rem;
  background:#C9982A;
  border:2px solid rgba(255,255,255,.25);
  color:#1a0a0f;width:38px;height:38px;border-radius:50%;
  cursor:pointer;font-size:1.1rem;font-weight:900;line-height:1;
  align-items:center;justify-content:center;
  transition:transform .2s,background .2s,box-shadow .2s;
  box-shadow:0 2px 14px rgba(201,152,42,.55);
  z-index:501;
}
.nav-close-btn:hover{transform:scale(1.12);background:#E8C96A;box-shadow:0 4px 20px rgba(201,152,42,.7)}
@media(max-width:1400px){.nav-close-btn{display:flex}}

/* Bottom footer inside sidebar */
.nav-footer{display:none;margin-top:auto;padding:1rem 1.8rem}
@media(max-width:1400px){.nav-footer{display:block}}
.nav-footer-text{
  font-size:.65rem;color:rgba(255,255,255,.22);
  letter-spacing:.06em;text-align:center;line-height:1.7;
}
.nav-footer-om{
  font-family:var(--font-hindi);font-size:1rem;
  color:rgba(201,152,42,.28);display:block;
  margin-bottom:.25rem;text-align:center;letter-spacing:.12em;
}

/* Nav section label */
.nav-section-label{display:none}
@media(max-width:1400px){
  .nav-section-label{
    display:block;
    font-size:.58rem;font-weight:800;
    letter-spacing:.22em;text-transform:uppercase;
    color:rgba(255,255,255,.2);
    padding:.7rem 1.8rem .3rem;
  }
}

/* ── Index consciousness section: stack SVG + quality cards on mobile ──── */
@media(max-width:768px) {
  .idx-consciousness-grid { grid-template-columns:1fr !important }
}

/* ══════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE FIX  ≤640px
   Tightens padding on inner-page heroes and common sections
   so phones don't waste screen space on large whitespace.
   ══════════════════════════════════════════════════════════ */
@media(max-width:640px) {
  /* Inner-page heroes: reduce top-padding from 9.5rem → 6.5rem */
  .page-hero { padding:6.5rem 1.5rem 3rem !important }

  /* Container side-padding on phones */
  .container { padding:0 1.2rem }

  /* Section padding */
  .sadhya-section,
  .pillars-section,
  .teachings-section,
  .consciousness-section,
  .about-page,
  .gallery-page,
  .resources-section { padding-left:1.2rem !important; padding-right:1.2rem !important }

  /* Big decorative quote marks — shrink to avoid clipping */
  .big-quote::before,
  .big-quote::after { font-size:3rem }

  /* Hero CTA wrap — stack buttons on small phones */
  .hero-cta-wrap { flex-direction:column; align-items:flex-start; gap:.75rem }
}

/* ── Mobile header ≤480px: hide Register button so hamburger stays visible ── */
/* Root cause: logo + Register + lang-btns + hamburger > 375px available width */
/* NOTE: must use !important to override the global PROFESSIONAL HEADER OVERHAUL block */
.sidebar-auth-wrap { display:none }
@media(max-width:480px) {
  #authBtn      { display:none !important }
  /* Override the global 2.5rem padding + 2rem gap set by PROFESSIONAL HEADER OVERHAUL */
  .header-inner { padding:.65rem 1rem !important; gap:1rem !important }
  /* Show the Register button that JS injects into the sidebar */
  .sidebar-auth-wrap {
    display:block;
    padding:.8rem 1.6rem 1rem;
    border-bottom:1px solid rgba(201,152,42,.18);
  }
  .sidebar-auth-wrap .btn-auth {
    width:100%;
    border-radius:8px;
    padding:.55rem 1rem;
    justify-content:center;
  }
}

/* ═══════════════════════════════════════
   HERO — v2
   ═══════════════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,#1A0508 0%,var(--burgundy) 50%,#2A0A10 100%);padding:6rem 2rem 4rem;position:relative;overflow:hidden;gap:3rem}
/* Animated lotus particle overlay */
.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}
/* Particles: gold colour, visible opacity — fade in fast, stay visible, fade out near top */
.particle{position:absolute;color:rgba(201,152,42,.9);font-size:1.2rem;opacity:0;animation:floatUp 14s infinite linear;text-shadow:0 0 8px rgba(201,152,42,.6)}
.particle:nth-child(1){left:5%;animation-delay:0s;font-size:1.8rem}
.particle:nth-child(2){left:14%;animation-delay:2.5s;font-size:1rem}
.particle:nth-child(3){left:24%;animation-delay:5.5s;font-size:1.4rem}
.particle:nth-child(4){left:38%;animation-delay:1s;font-size:2.2rem}
.particle:nth-child(5){left:52%;animation-delay:3.5s;font-size:1rem}
.particle:nth-child(6){left:63%;animation-delay:7.5s;font-size:1.6rem}
.particle:nth-child(7){left:74%;animation-delay:2s;font-size:1.5rem}
.particle:nth-child(8){left:83%;animation-delay:4.5s;font-size:.95rem}
.particle:nth-child(9){left:91%;animation-delay:6.5s;font-size:1.3rem}
.particle:nth-child(10){left:32%;animation-delay:9s;font-size:1.1rem}
.particle:nth-child(11){left:47%;animation-delay:10.5s;font-size:1.9rem}
.particle:nth-child(12){left:70%;animation-delay:12s;font-size:1.2rem}
/* Fade IN from bottom → visible through mid-hero (including top) → fade OUT at very top */
@keyframes floatUp{
  0%{transform:translateY(100vh) rotate(0deg);opacity:0}
  12%{opacity:.45}
  75%{opacity:.38}
  92%{opacity:.18}
  100%{transform:translateY(-15vh) rotate(720deg);opacity:0}
}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 25% 50%,rgba(201,152,42,.1) 0%,transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(224,123,42,.07) 0%,transparent 50%);pointer-events:none}
.hero-content{flex:1;max-width:580px;position:relative;z-index:2;padding-left:2rem}
.hero-mantra{font-family:var(--font-hindi);font-size:3.8rem;color:var(--gold-light);margin-bottom:.4rem;opacity:.9;line-height:1;filter:drop-shadow(0 0 12px var(--gold-glow));animation:pulseGlow 3s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{filter:drop-shadow(0 0 12px var(--gold-glow))}50%{filter:drop-shadow(0 0 24px rgba(201,152,42,.6))}}
.hero-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--saffron-light);margin-bottom:.6rem;display:flex;align-items:center;gap:.6rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--saffron-light))}
.hero-eyebrow::after{background:linear-gradient(90deg,var(--saffron-light),transparent)}
.hero-title{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,4.8rem);color:var(--white);font-weight:700;line-height:1.08;margin-bottom:.7rem}
.hero-title span{color:var(--gold-light);display:block}
.hero-subtitle{font-size:1.08rem;color:rgba(255,255,255,.75);letter-spacing:.06em;margin-bottom:1.6rem;font-style:italic}
.hero-dot-wrap{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.1rem 1.4rem;background:rgba(201,152,42,.1);border-left:3px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0;backdrop-filter:blur(6px)}
.hero-dot-label{color:rgba(255,255,255,.85);font-size:.93rem;font-style:italic;line-height:1.45}
.signature-dot{font-size:4.5rem;color:var(--gold-light);line-height:.4;font-family:var(--font-serif);flex-shrink:0;filter:drop-shadow(0 0 8px var(--gold-glow));animation:pulseGlow 2.5s ease-in-out infinite}
.hero-cta-wrap{display:flex;gap:1rem;flex-wrap:wrap}
.hero-image-col{flex-shrink:0;width:min(440px,44vw);position:relative;z-index:2}
.hero-img-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 0 80px rgba(201,152,42,.3),var(--shadow-lg);border:2px solid rgba(201,152,42,.45)}
.hero-img-frame img{width:100%;object-fit:cover;filter:sepia(10%) contrast(1.05)}
.img-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,152,42,.18),transparent 60%);pointer-events:none}
.hero-img-badge{position:absolute;bottom:1.2rem;left:1.2rem;background:rgba(28,10,5,.85);backdrop-filter:blur(8px);border:1px solid rgba(201,152,42,.4);border-radius:8px;padding:.6rem 1rem;color:var(--gold-light);font-size:.78rem;font-weight:700;letter-spacing:.08em}
@media(max-width:800px){.hero{flex-direction:column;padding-top:7.5rem;text-align:center}.hero-content{padding-left:0}.hero-cta-wrap{justify-content:center}.hero-image-col{width:min(320px,88vw)}.hero-eyebrow::before,.hero-eyebrow::after{display:none}}

/* ═══════════════════════════════════════
   STATS BAR (animated counters)
   ═══════════════════════════════════════ */
.stats-bar{background:linear-gradient(135deg,#1C0A05 0%,#2D0E0A 100%);padding:2.2rem 2rem;border-top:1px solid rgba(201,152,42,.25);border-bottom:1px solid rgba(201,152,42,.25)}
.stats-inner{display:flex;align-items:center;justify-content:space-around;gap:1.5rem;flex-wrap:wrap;max-width:1100px;margin:0 auto}
.stat-item{text-align:center;flex:1;min-width:110px}
.stat-number{font-family:var(--font-serif);font-size:clamp(1.9rem,3.5vw,2.8rem);color:var(--gold-light);font-weight:700;line-height:1;display:block}
.stat-label{font-size:.72rem;color:rgba(255,255,255,.55);letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem;display:block}
.stat-divider{width:1px;height:40px;background:rgba(201,152,42,.3);flex-shrink:0}
@media(max-width:600px){.stat-divider{display:none}.stat-item{min-width:100px}}

/* ═══════════════════════════════════════
   SADHYA-NIRDESH — Six Principal Statements
   ═══════════════════════════════════════ */
.sadhya-section{background:linear-gradient(170deg,#0E0305 0%,#1A0508 40%,#2D0A14 100%);padding:7rem 2rem;position:relative;overflow:hidden}
.sadhya-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(ellipse at 50% 0%,rgba(201,152,42,.12) 0%,transparent 60%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Ccircle cx='60' cy='60' r='55' fill='none' stroke='rgba(201,152,42,0.04)' stroke-width='1'/%3E%3Ccircle cx='60' cy='60' r='35' fill='none' stroke='rgba(201,152,42,0.03)' stroke-width='1'/%3E%3Cline x1='5' y1='60' x2='115' y2='60' stroke='rgba(201,152,42,0.025)' stroke-width='1'/%3E%3Cline x1='60' y1='5' x2='60' y2='115' stroke='rgba(201,152,42,0.025)' stroke-width='1'/%3E%3C/svg%3E");pointer-events:none}
.sadhya-header{text-align:center;margin-bottom:4rem;position:relative;z-index:2}
.sadhya-header .appendix-label{font-size:.75rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--saffron-light);margin-bottom:.75rem;display:block}
.sadhya-header h2{font-size:clamp(1.6rem,3.5vw,2.6rem);color:var(--white);font-family:var(--font-hindi);margin-bottom:.5rem}
.sadhya-header .subtitle-hindi{font-size:clamp(1rem,2vw,1.25rem);color:var(--gold-light);font-family:var(--font-hindi);margin-bottom:.5rem;font-style:italic}
.sadhya-header .subtitle-en{font-size:.92rem;color:rgba(255,255,255,.55);letter-spacing:.06em}
.sadhya-header-divider{width:120px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.5rem auto 0}

.sadhya-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;position:relative;z-index:2;max-width:1100px;margin:0 auto}
.sadhya-card{background:rgba(255,255,255,.04);border:1px solid rgba(201,152,42,.22);border-radius:16px;padding:2.2rem 1.75rem;position:relative;overflow:hidden;transition:var(--transition);cursor:default}
.sadhya-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,152,42,.07),transparent 60%);opacity:0;transition:var(--transition)}
.sadhya-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--saffron));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.sadhya-card:hover{transform:translateY(-6px);border-color:rgba(201,152,42,.55);box-shadow:0 12px 40px rgba(201,152,42,.2)}
.sadhya-card:hover::before{opacity:1}
.sadhya-card:hover::after{transform:scaleX(1)}
.sadhya-card.featured{border-color:rgba(201,152,42,.5);background:rgba(201,152,42,.08)}
.sadhya-num{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--saffron));font-family:var(--font-hindi);font-size:1.4rem;color:var(--white);font-weight:700;margin-bottom:1.25rem;box-shadow:0 4px 16px rgba(201,152,42,.4);flex-shrink:0}
.sadhya-card.featured .sadhya-num{width:60px;height:60px;font-size:1.6rem;box-shadow:0 6px 24px rgba(201,152,42,.55)}
.sadhya-sanskrit{font-family:var(--font-hindi);font-size:clamp(1.05rem,1.8vw,1.25rem);color:var(--gold-light);font-weight:600;line-height:1.5;margin-bottom:.85rem}
.sadhya-english{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.65;font-style:italic;border-top:1px solid rgba(201,152,42,.18);padding-top:.85rem;margin-top:auto}
.sadhya-card-shine{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 40% 40%,rgba(255,255,255,.04),transparent 60%);pointer-events:none}

.sadhya-closing{text-align:center;margin-top:3.5rem;position:relative;z-index:2}
.sadhya-jai{font-family:var(--font-hindi);font-size:1.2rem;color:var(--gold-light);line-height:2;opacity:.85}
.sadhya-jai span{display:block}

@media(max-width:900px){.sadhya-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.sadhya-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════
   QUOTE BAND
   ═══════════════════════════════════════ */
.quote-band{background:linear-gradient(135deg,var(--parchment),var(--gold-pale));padding:2.5rem 2rem 2rem;border-top:3px solid var(--gold);border-bottom:3px solid var(--gold)}
.quote-carousel{position:relative}
/* Inactive slides completely removed from layout — no height bleed */
.quote-slide{display:none;max-width:820px;margin:0 auto;text-align:center;font-family:var(--font-serif);font-size:clamp(1.05rem,2vw,1.3rem);color:var(--burgundy);font-style:italic;line-height:1.75}
.quote-slide.active{display:block;animation:quoteFadeIn .5s ease}
@keyframes quoteFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.q-mark{font-size:3rem;line-height:.5;vertical-align:-.5rem;color:var(--gold);font-family:var(--font-serif)}
.quote-band cite{display:block;margin-top:1rem;font-style:normal;font-size:.88rem;font-weight:700;letter-spacing:.08em;color:var(--mid-brown);font-family:var(--font-sans)}
/* Dot indicator row */
.quote-dots{display:flex;justify-content:center;gap:.6rem;margin-top:1.4rem}
.quote-dot{width:8px;height:8px;border-radius:50%;border:none;padding:0;cursor:pointer;background:rgba(139,34,82,.25);transition:background .3s,transform .3s}
.quote-dot.active{background:var(--gold);transform:scale(1.35)}

/* ═══════════════════════════════════════
   FIVE PILLARS
   ═══════════════════════════════════════ */
.pillars-section{padding:6rem 2rem;background:var(--cream)}
.pillars-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.75rem;margin-bottom:3rem}
.pillar-card{background:var(--white);border:1px solid rgba(201,152,42,.22);border-radius:var(--radius-lg);padding:2.2rem 1.75rem;transition:var(--transition);position:relative;overflow:hidden;display:flex;flex-direction:column;cursor:pointer}
.pillar-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--saffron));opacity:0;transition:var(--transition)}
.pillar-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.pillar-card:hover::after{opacity:1}
.pillar-card--gold{background:linear-gradient(135deg,var(--gold-pale),var(--parchment));border-color:rgba(201,152,42,.5)}
.pillar-icon{width:58px;height:58px;background:linear-gradient(135deg,var(--gold-pale),var(--parchment));border:2px solid var(--gold-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-hindi);font-size:1.15rem;color:var(--gold);font-weight:700;margin-bottom:1.3rem;flex-shrink:0}
.pillar-icon.large-dot{font-size:2.8rem;line-height:.75}
.pillar-card h3{font-size:1.18rem;color:var(--burgundy);margin-bottom:.75rem}
.pillar-card p{color:var(--text-mid);font-size:.91rem;line-height:1.68;flex:1}
.pillar-link{display:inline-block;margin-top:1.25rem;color:var(--gold);font-weight:700;font-size:.88rem;letter-spacing:.04em;transition:var(--transition)}
.pillar-card:hover .pillar-link{color:var(--saffron)}
.pillars-cta{text-align:center}

/* ═══════════════════════════════════════
   SWAMI KEDARNATHJI
   ═══════════════════════════════════════ */
.swami-section{padding:6.5rem 2rem;background:linear-gradient(135deg,var(--parchment),var(--gold-pale) 60%,var(--parchment));position:relative;overflow:hidden}
.swami-section::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:radial-gradient(ellipse,rgba(201,152,42,.1),transparent 70%);pointer-events:none}
.swami-grid{display:grid;grid-template-columns:360px 1fr;gap:4rem;align-items:center;max-width:1100px;margin:0 auto}
.swami-img-col{position:relative}
.swami-img-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid rgba(201,152,42,.4);max-height:420px}
.swami-img-wrap img{width:100%;object-fit:cover;filter:sepia(15%) warm(1.1)}
.swami-img-badge{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(28,10,5,.92),transparent);padding:1.75rem 1.5rem;color:var(--white)}
.swami-img-badge h4{font-family:var(--font-serif);font-size:1.3rem;color:var(--gold-light);margin-bottom:.25rem}
.swami-img-badge p{font-size:.82rem;color:rgba(255,255,255,.75);line-height:1.4}
.swami-role-tag{display:inline-block;background:linear-gradient(135deg,var(--saffron),var(--gold));color:var(--white);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.35rem .9rem;border-radius:20px;margin-bottom:1.5rem}
.swami-text h2{font-size:clamp(1.7rem,2.5vw,2.3rem);color:var(--burgundy);margin-bottom:1.25rem}
.swami-text p{color:var(--text-mid);line-height:1.8;margin-bottom:1.1rem;font-size:1.02rem}
.swami-quote{background:linear-gradient(135deg,rgba(201,152,42,.12),rgba(201,152,42,.06));border-left:4px solid var(--saffron);padding:1.4rem 1.6rem;border-radius:0 10px 10px 0;margin:1.75rem 0;font-family:var(--font-serif);font-style:italic;color:var(--burgundy);font-size:1.05rem;line-height:1.75;position:relative}
.swami-quote::before{content:'\201C';position:absolute;top:-.3rem;left:.75rem;font-size:3rem;color:var(--gold);opacity:.5;line-height:1}
.swami-years{display:flex;gap:1.5rem;margin:1.5rem 0;flex-wrap:wrap}
.swami-year-badge{background:var(--white);border:1px solid rgba(201,152,42,.3);border-radius:8px;padding:.65rem 1.1rem;text-align:center;box-shadow:var(--shadow)}
.swami-year-badge .year{font-family:var(--font-serif);font-size:1.3rem;color:var(--saffron);font-weight:700;display:block}
.swami-year-badge .label{font-size:.72rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.1em}
.swami-ashrams{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}
.ashram-tag{background:var(--white);border:1px solid rgba(201,152,42,.3);border-radius:20px;padding:.4rem 1rem;font-size:.82rem;font-weight:700;color:var(--mid-brown);display:flex;align-items:center;gap:.4rem}
@media(max-width:900px){.swami-grid{grid-template-columns:1fr;gap:2.5rem}.swami-img-col{max-width:400px;margin:0 auto}}

/* ═══════════════════════════════════════
   LIFE OVERVIEW / TIMELINE
   ═══════════════════════════════════════ */
.life-overview{padding:6rem 2rem;background:var(--cream)}
.life-timeline{max-width:820px;margin:0 auto;position:relative;margin-bottom:3rem}
.life-timeline::before{content:'';position:absolute;left:82px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold),var(--saffron),var(--gold))}
.timeline-item{display:flex;gap:2rem;margin-bottom:2.5rem;align-items:flex-start}
.tl-year{flex-shrink:0;width:82px;text-align:right;font-family:var(--font-serif);font-size:.86rem;font-weight:700;color:var(--gold);padding-top:.2rem}
.tl-dot{flex-shrink:0;width:14px;height:14px;border-radius:50%;background:var(--gold);margin-top:.5rem;box-shadow:0 0 0 4px rgba(201,152,42,.2);position:relative;left:.5rem}
.tl-content{flex:1;background:var(--white);border-radius:10px;padding:1.5rem;box-shadow:var(--shadow);border-left:3px solid var(--gold);transition:var(--transition)}
.tl-content:hover{transform:translateX(4px);box-shadow:var(--shadow-lg)}
.tl-content h4{font-size:1rem;color:var(--burgundy);margin-bottom:.5rem}
.tl-content p{font-size:.91rem;color:var(--text-mid);line-height:1.65}
.life-cta{text-align:center}

/* ═══════════════════════════════════════
   TEACHINGS PREVIEW
   ═══════════════════════════════════════ */
.teachings-preview{padding:6rem 2rem;background:linear-gradient(135deg,var(--burgundy) 0%,#3A0B1C 100%)}
.quotes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}
.quote-card{background:rgba(255,255,255,.07);border:1px solid rgba(201,152,42,.28);border-radius:12px;padding:2rem 1.75rem;transition:var(--transition);backdrop-filter:blur(4px)}
.quote-card:hover{background:rgba(255,255,255,.11);border-color:var(--gold);transform:translateY(-4px);box-shadow:0 8px 32px rgba(201,152,42,.2)}
.quote-card p{color:rgba(255,255,255,.88);font-family:var(--font-serif);font-style:italic;font-size:.96rem;line-height:1.72;margin-bottom:1rem}
.quote-card cite{font-size:.78rem;color:var(--gold-light);font-weight:700;letter-spacing:.06em}
.teachings-cta{text-align:center}

/* ═══════════════════════════════════════
   RESOURCES — Books / Videos / Podcasts
   ═══════════════════════════════════════ */
.resources-section{padding:6.5rem 2rem;background:var(--cream)}
.resources-tabs{display:flex;gap:.75rem;justify-content:center;margin-bottom:3.5rem;flex-wrap:wrap}
.rtab{background:var(--white);border:2px solid rgba(201,152,42,.3);border-radius:50px;padding:.65rem 1.75rem;font-weight:700;font-size:.9rem;color:var(--text-mid);cursor:pointer;transition:var(--transition)}
.rtab.active,.rtab:hover{background:var(--gold);border-color:var(--gold);color:var(--white);box-shadow:var(--shadow-gold)}
.resource-panel{display:none}
.resource-panel.active{display:block}

/* Books */
.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:2rem}
/* Centred grid — last row centred so orphaned books don't left-align (#13 fix) */
.books-grid--centered{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem}
.books-grid--centered .book-card{width:210px;flex-shrink:0;flex-grow:0}
.book-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition);border:1px solid rgba(201,152,42,.18)}
.book-card:hover{transform:translateY(-8px) rotate(.5deg);box-shadow:var(--shadow-lg)}
.book-cover{height:240px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.book-cover-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;text-align:center;position:relative}
.book-cover-inner::before{content:'';position:absolute;inset:0;background:inherit;filter:blur(8px) brightness(.6);z-index:0}
.book-cover-content{position:relative;z-index:1}
.book-cover h4{font-family:var(--font-hindi);font-size:1.1rem;color:var(--white);text-shadow:0 2px 8px rgba(0,0,0,.5);line-height:1.4;margin-bottom:.4rem}
.book-cover .book-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.9}
.book-info{padding:1.25rem 1.1rem}
.book-info h4{font-size:.97rem;color:var(--burgundy);margin-bottom:.4rem;line-height:1.4}
.book-info .book-author{font-size:.8rem;color:var(--text-light);margin-bottom:.6rem;font-style:italic}
.book-info .book-desc{font-size:.82rem;color:var(--text-mid);line-height:1.55}
.book-badge{display:inline-block;background:var(--gold-pale);border:1px solid var(--gold-light);color:var(--mid-brown);font-size:.72rem;font-weight:700;padding:.25rem .7rem;border-radius:20px;margin-top:.75rem}

/* Videos */
.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem}
.video-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:var(--transition);border:1px solid rgba(201,152,42,.18)}
.video-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.video-thumb{position:relative;padding-top:56.25%;background:#1A0508;overflow:hidden}
.video-thumb img,.video-thumb iframe{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.video-thumb .play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(74,14,36,.4);transition:var(--transition)}
.video-thumb .play-btn span{width:56px;height:56px;background:rgba(201,152,42,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--white);transition:var(--transition)}
.video-card:hover .play-btn span{transform:scale(1.1);background:var(--gold)}
.video-info{padding:1.1rem 1.25rem}
.video-info h4{font-size:.95rem;color:var(--burgundy);margin-bottom:.4rem;line-height:1.4}
.video-info p{font-size:.82rem;color:var(--text-light)}

/* Podcasts */
.podcasts-grid{display:flex;flex-direction:column;gap:1.25rem;max-width:780px;margin:0 auto}
.podcast-card{background:var(--white);border:1px solid rgba(201,152,42,.2);border-radius:var(--radius-lg);padding:1.5rem 1.75rem;display:flex;gap:1.5rem;align-items:center;transition:var(--transition);box-shadow:var(--shadow)}
.podcast-card:hover{transform:translateX(6px);border-color:var(--gold);box-shadow:var(--shadow-lg)}
.podcast-icon{width:60px;height:60px;background:linear-gradient(135deg,var(--burgundy),#3A0B1C);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0;box-shadow:var(--shadow)}
.podcast-info{flex:1}
.podcast-info h4{font-size:1rem;color:var(--burgundy);margin-bottom:.3rem}
.podcast-info p{font-size:.84rem;color:var(--text-mid);line-height:1.5}
.podcast-info .podcast-meta{display:flex;gap:1rem;margin-top:.5rem;font-size:.76rem;color:var(--text-light)}
.podcast-play{background:linear-gradient(135deg,var(--gold),var(--saffron));border:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1rem;cursor:pointer;flex-shrink:0;box-shadow:var(--shadow-gold);transition:var(--transition)}
.podcast-play:hover{transform:scale(1.1)}
.coming-soon-banner{text-align:center;padding:4rem 2rem;background:var(--gold-pale);border-radius:var(--radius-lg);border:2px dashed rgba(201,152,42,.4)}
.coming-soon-banner h3{font-family:var(--font-serif);color:var(--burgundy);font-size:1.5rem;margin-bottom:.75rem}
.coming-soon-banner p{color:var(--text-mid);max-width:480px;margin:0 auto}

/* ═══════════════════════════════════════
   GALLERY STRIP
   ═══════════════════════════════════════ */
.gallery-strip{padding:6rem 2rem;background:var(--parchment)}
.gallery-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.75rem;margin-bottom:2.5rem}
.gallery-thumb{overflow:hidden;border-radius:10px;box-shadow:var(--shadow);position:relative}
.gallery-thumb img{width:100%;height:220px;object-fit:cover;transition:transform .5s ease,filter .3s ease;filter:sepia(12%)}
.gallery-thumb:hover img{transform:scale(1.07);filter:sepia(0%)}
.gallery-cta{text-align:center}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:540px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════
   ABOUT SECTION
   ═══════════════════════════════════════ */
.about-section{padding:6.5rem 2rem;background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start}
.about-img-col img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);filter:sepia(10%)}
.about-img-caption{text-align:center;margin-top:.75rem;color:var(--text-light);font-size:.84rem;font-style:italic}
.about-text-col h2{font-size:clamp(1.6rem,2.5vw,2.1rem);margin-bottom:1.25rem}
.about-text-col p{color:var(--text-mid);margin-bottom:1.1rem;line-height:1.78}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1.75rem 0}
.about-feature{display:flex;align-items:center;gap:.65rem;font-size:.9rem;font-weight:700;color:var(--mid-brown)}
.feat-icon{font-size:1.2rem}
@media(max-width:780px){.about-grid{grid-template-columns:1fr;gap:2.5rem}}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.site-footer{background:var(--deep-brown);padding:4.5rem 2rem 0;color:rgba(255,255,255,.72)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
.footer-brand .footer-logo{font-family:var(--font-serif);font-size:1.45rem;color:var(--gold-light);display:flex;align-items:center;gap:.4rem;margin-bottom:.75rem}
.footer-brand p{font-size:.87rem;line-height:1.5;margin-bottom:.5rem}
.footer-tagline{color:var(--gold-light);font-style:italic;font-size:.82rem!important}
.footer-links h4,.footer-ashrams h4{color:var(--gold-light);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-links a,.footer-ashrams a{display:block;font-size:.87rem;color:rgba(255,255,255,.62);margin-bottom:.5rem;transition:var(--transition)}
.footer-links a:hover,.footer-ashrams a:hover{color:var(--gold-light);padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.75rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.38)}
.footer-blessing{font-family:var(--font-hindi);font-size:1.3rem!important;color:var(--gold)!important}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}}

/* ═══════════════════════════════════════
   PAGE HERO (inner pages)
   ═══════════════════════════════════════ */
.page-hero{background:linear-gradient(135deg,#1A0508 0%,var(--burgundy) 100%);padding:6.5rem 2rem 3.5rem;text-align:center;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 60%,rgba(201,152,42,.1),transparent 70%);pointer-events:none}
.page-hero h1{font-size:clamp(2.2rem,5vw,3.5rem);color:var(--white);margin-bottom:1rem;position:relative;z-index:2}
.page-hero .page-hero-sub{font-size:1.08rem;color:rgba(255,255,255,.72);max-width:640px;margin:0 auto;position:relative;z-index:2;line-height:1.75}
.page-hero .section-label{position:relative;z-index:2}

/* ═══════════════════════════════════════
   CONSCIOUSNESS PAGE
   ═══════════════════════════════════════ */
.consciousness-section{padding:5.5rem 2rem}
.consciousness-section:nth-child(odd){background:var(--cream)}
.consciousness-section:nth-child(even){background:var(--parchment)}
.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
.cs-grid.reversed .cs-text{order:2}
.cs-grid.reversed .cs-visual{order:1}
.cs-text .anchor-tag{font-size:.73rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;display:block}
.cs-text h2{font-size:clamp(1.6rem,2.5vw,2.2rem);color:var(--burgundy);margin-bottom:1.25rem}
.cs-text p{color:var(--text-mid);line-height:1.82;margin-bottom:1rem}
.cs-text .cs-quote{background:linear-gradient(135deg,var(--gold-pale),var(--parchment));border-left:4px solid var(--gold);padding:1.25rem 1.5rem;border-radius:0 8px 8px 0;margin:1.5rem 0;font-family:var(--font-serif);font-style:italic;color:var(--burgundy);font-size:1.02rem;line-height:1.7}
.cs-visual{background:linear-gradient(135deg,var(--burgundy),#3A0B1C);border-radius:18px;padding:3rem 2rem;text-align:center;color:var(--white);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.cs-visual::before{content:'';position:absolute;inset:-50%;background:radial-gradient(ellipse at center,rgba(201,152,42,.1) 0%,transparent 70%);pointer-events:none}
.cs-symbol{font-size:6rem;font-family:var(--font-hindi);color:var(--gold-light);line-height:1;margin-bottom:1rem;position:relative;z-index:1}
.cs-visual-title{font-size:1.3rem;color:var(--gold-light);margin-bottom:.75rem;position:relative;z-index:1;font-family:var(--font-serif)}
.cs-visual-text{font-size:.9rem;color:rgba(255,255,255,.75);max-width:280px;margin:0 auto;line-height:1.65;position:relative;z-index:1}
@media(max-width:780px){.cs-grid{grid-template-columns:1fr;gap:2.5rem}.cs-grid.reversed .cs-text,.cs-grid.reversed .cs-visual{order:unset}}

/* ═══════════════════════════════════════
   LIFE PAGE
   ═══════════════════════════════════════ */
.fact-box{background:var(--white);border:1px solid rgba(201,152,42,.28);border-radius:var(--radius-lg);padding:2.2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;box-shadow:var(--shadow)}
.fact-item{text-align:center;padding:.5rem}
.fact-number{font-family:var(--font-serif);font-size:2.1rem;color:var(--gold);font-weight:700}
.fact-label{font-size:.78rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}

/* ═══════════════════════════════════════
   TEACHINGS PAGE
   ═══════════════════════════════════════ */
.teachings-section{padding:5.5rem 2rem}
.teachings-section:nth-child(odd){background:var(--cream)}
.teachings-section:nth-child(even){background:var(--parchment)}
.big-quote{font-family:var(--font-serif);font-size:clamp(1.1rem,2vw,1.45rem);color:var(--burgundy);font-style:italic;line-height:1.8;max-width:800px;margin:0 auto 2rem;text-align:center;padding:0 1rem;position:relative}
.big-quote::before{content:'\201C';font-size:5rem;color:var(--gold);position:absolute;top:1.2rem;left:-.5rem;line-height:.5;font-family:var(--font-serif)}
.big-quote::after{content:'\201D';font-size:5rem;color:var(--gold);position:absolute;bottom:-1.5rem;right:-.5rem;line-height:.5;font-family:var(--font-serif)}
.quotes-masonry{columns:2;gap:1.5rem;margin-top:2rem}
.quotes-masonry .quote-card{break-inside:avoid;margin-bottom:1.5rem;background:var(--white);color:var(--text-dark);border:1px solid rgba(201,152,42,.2)}
.quotes-masonry .quote-card p{color:var(--burgundy)}
.quotes-masonry .quote-card cite{color:var(--mid-brown)}
@media(max-width:640px){.quotes-masonry{columns:1}}

/* ═══════════════════════════════════════
   GALLERY PAGE
   ═══════════════════════════════════════ */
.gallery-page{padding:5.5rem 2rem;background:var(--cream)}
.gallery-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gp-thumb{border-radius:10px;overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--shadow)}
.gp-thumb img{width:100%;height:280px;object-fit:cover;transition:transform .45s ease}
.gp-thumb:hover img{transform:scale(1.05)}
.gp-thumb .gp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(74,14,36,.6),transparent 50%);opacity:0;transition:var(--transition)}
.gp-thumb:hover .gp-overlay{opacity:1}

/* ═══════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════ */
.about-page{padding:5.5rem 2rem}
.about-page:nth-child(odd){background:var(--cream)}
.about-page:nth-child(even){background:var(--parchment)}
.mission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.75rem;margin-top:2rem}
.mission-card{background:var(--white);border-radius:var(--radius-lg);padding:2.1rem;box-shadow:var(--shadow);border-top:3px solid var(--gold);transition:var(--transition)}
.mission-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.mission-card h3{color:var(--burgundy);margin-bottom:.75rem;font-size:1.1rem}
.mission-card p{color:var(--text-mid);font-size:.91rem;line-height:1.65}
.sources-list{max-width:700px;margin-top:2rem}
.source-item{display:flex;gap:1.25rem;align-items:flex-start;padding:1.4rem 0;border-bottom:1px solid rgba(201,152,42,.2)}
.source-num{font-family:var(--font-serif);font-size:1.5rem;color:var(--gold);font-weight:700;flex-shrink:0;width:2rem}
.source-item h4{color:var(--burgundy);margin-bottom:.3rem;font-size:1rem}
.source-item p{color:var(--text-mid);font-size:.88rem;line-height:1.6}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-top:2rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:.85rem 1.1rem;border:1.5px solid rgba(201,152,42,.35);border-radius:var(--radius);background:var(--white);font-family:var(--font-sans);font-size:.95rem;color:var(--text-dark);margin-bottom:1rem;transition:var(--transition)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,152,42,.15)}
.contact-form textarea{min-height:140px;resize:vertical}
@media(max-width:640px){.contact-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════
   LIGHTBOX
   ═══════════════════════════════════════ */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:9999;align-items:center;justify-content:center;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:6px;box-shadow:0 0 80px rgba(201,152,42,.3)}
.lb-close{position:absolute;top:1.5rem;right:2rem;color:white;font-size:2.5rem;cursor:pointer;z-index:1;background:rgba(0,0,0,.5);border:none;padding:.25rem .75rem;border-radius:6px}
.lb-close:hover{color:var(--gold-light)}
.lb-caption{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.72);font-size:.9rem;font-style:italic;text-align:center}

/* ═══════════════════════════════════════
   RESOURCES PAGE
   ═══════════════════════════════════════ */
.res-hero-icon{font-size:3rem;margin-bottom:1rem}
.resources-full{padding:5.5rem 2rem}
.resources-full:nth-child(odd){background:var(--cream)}
.resources-full:nth-child(even){background:var(--parchment)}

/* ── rpanel (alias for resource-panel) ── */
.rpanel{display:none}
.rpanel.active{display:block;animation:fadePanel .4s ease}
@keyframes fadePanel{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Stats bar layout fix (no .stats-inner wrapper) ── */
.stats-bar{display:flex;align-items:center;justify-content:space-around;gap:1.5rem;flex-wrap:wrap}
@media(max-width:600px){.stats-bar{padding:1.8rem 1rem}}

/* ── Sadhya-Nirdesh extras ── */
.sadhya-body{flex:1}
.sadhya-card{display:flex;align-items:flex-start;gap:1.1rem}
.sadhya-trans{font-size:.86rem;color:rgba(255,255,255,.6);font-style:italic;line-height:1.6;border-top:1px solid rgba(201,152,42,.18);padding-top:.75rem;margin-top:.75rem}
.sadhya-footer{text-align:center;margin-top:3rem;font-size:.8rem;color:rgba(255,255,255,.38);letter-spacing:.08em;font-style:italic;position:relative;z-index:2}

/* ── Swami section extras ── */
.swami-quote-block{background:linear-gradient(135deg,rgba(201,152,42,.12),rgba(201,152,42,.06));border-left:4px solid var(--saffron);padding:1.4rem 1.6rem;border-radius:0 10px 10px 0;margin:0 0 1.75rem;position:relative}
.swami-quote-block .swami-quote-mark{font-size:3.5rem;line-height:.6;color:var(--gold);font-family:var(--font-serif);opacity:.5;display:block;margin-bottom:.3rem}
.swami-quote-block p{font-family:var(--font-serif);font-style:italic;color:var(--burgundy);font-size:1.08rem;line-height:1.75;margin-bottom:.6rem}
.swami-quote-block cite{font-size:.8rem;font-weight:700;color:var(--mid-brown);letter-spacing:.06em;display:block}
.swami-text-col > p{color:var(--text-mid);line-height:1.8;margin-bottom:1.2rem;font-size:1.02rem}
.swami-facts{display:flex;flex-direction:column;gap:.7rem;margin:1.5rem 0}
.swami-fact{display:flex;align-items:center;gap:.75rem;font-size:.9rem;font-weight:700;color:var(--mid-brown)}
.sf-icon{font-size:1.15rem;flex-shrink:0;width:1.5rem;text-align:center}
.swami-img-badge{font-family:var(--font-serif);font-size:1rem;font-weight:700;color:var(--gold-light);letter-spacing:.04em}

/* ── Swami photo placeholder ── */
.swami-photo-placeholder{
  width:100%;aspect-ratio:1;max-height:360px;
  background:linear-gradient(145deg,#1A0508,#2D0A14,#1A0A00);
  border-radius:var(--radius-lg);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.swami-photo-placeholder::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 40%,rgba(201,152,42,.18),transparent 65%);
}
.swami-photo-placeholder::after{
  content:'';position:absolute;inset:12px;border:1px solid rgba(201,152,42,.25);border-radius:calc(var(--radius-lg) - 4px);
}
.swami-ph-inner{text-align:center;z-index:1;padding:2rem}
.swami-ph-om{font-family:var(--font-hindi);font-size:5rem;color:var(--gold);opacity:.7;line-height:1;text-shadow:0 0 40px rgba(201,152,42,.6);animation:dotGlow 2.5s ease-in-out infinite}
.swami-ph-name{font-family:var(--font-hindi);font-size:1.2rem;color:var(--gold-light);margin-top:1.2rem;line-height:1.5}
.swami-ph-sub{font-family:var(--font-serif);font-size:.95rem;color:rgba(255,255,255,.65);margin-top:.4rem;font-style:italic}
.swami-ph-note{font-size:.78rem;color:rgba(255,255,255,.35);margin-top:.6rem;letter-spacing:.1em;text-transform:uppercase}

/* ── Book extras ── */
.book-cover{background:linear-gradient(135deg,var(--burgundy),#2D0A14)}
.book-cover--saffron{background:linear-gradient(135deg,#8B3A0A,var(--saffron))}
.book-cover--maroon{background:linear-gradient(135deg,var(--maroon),#2D0A14)}
.book-cover--deep{background:linear-gradient(135deg,#0A0A2E,#1A0538)}
.book-cover--teal{background:linear-gradient(135deg,#0A4A4A,#1A6B6B)}
.book-cover--green{background:linear-gradient(135deg,#1A3A1A,#2D5A2D)}
/* ── Book action row ── */
.book-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}
.book-actions .book-tag{margin-top:0}
.btn-read-online{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--dark-bg);font-size:.75rem;font-weight:700;padding:.35rem .9rem;border-radius:20px;text-decoration:none;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap;letter-spacing:.02em}
.btn-read-online:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(201,152,42,.5)}

/* ── Book gating states ─────────────────────────────────────── */
/* Description blur transition */
.book-card .book-desc{transition:filter .35s ease}
/* Register CTA — shown to guests */
.btn-gate--register{display:inline-flex;align-items:center;gap:.4rem;background:rgba(139,34,82,.18);border:1px solid rgba(139,34,82,.45);color:rgba(253,245,224,.75);font-size:.75rem;font-weight:700;padding:.35rem .9rem;border-radius:20px;cursor:pointer;transition:all .2s;white-space:nowrap;letter-spacing:.02em;font-family:var(--font-sans)}
.btn-gate--register:hover{background:rgba(139,34,82,.35);color:#fff;border-color:rgba(139,34,82,.7);transform:translateY(-2px);box-shadow:0 4px 14px rgba(139,34,82,.3)}
/* Unlock CTA — shown to registered users for paid books */
.btn-gate--unlock{display:inline-flex;align-items:center;gap:.4rem;background:rgba(201,152,42,.14);border:1px solid rgba(201,152,42,.4);color:rgba(201,152,42,.9);font-size:.75rem;font-weight:700;padding:.35rem .9rem;border-radius:20px;cursor:pointer;transition:all .2s;white-space:nowrap;letter-spacing:.02em;font-family:var(--font-sans)}
.btn-gate--unlock:hover{background:rgba(201,152,42,.28);color:#E8C97A;border-color:rgba(201,152,42,.7);transform:translateY(-2px);box-shadow:0 4px 14px rgba(201,152,42,.25)}
/* Payment fallback modal card */
.ismaac-pay-card{position:relative;background:linear-gradient(150deg,#1a0c14,#220d18,#1a0c14);border:1px solid rgba(201,152,42,.4);border-radius:20px;padding:2.4rem 2rem;max-width:420px;width:100%;text-align:center;box-shadow:0 8px 48px rgba(0,0,0,.75)}
.ismaac-pay-close{position:absolute;top:.85rem;right:.9rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.6);font-size:1rem;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:.2s;line-height:1;display:flex;align-items:center;justify-content:center}
.ismaac-pay-close:hover{background:rgba(201,152,42,.2);color:#fff;border-color:rgba(201,152,42,.5)}
.ismaac-pay-title{font-family:var(--font-serif);color:#E8C97A;font-size:1.15rem;margin:0 0 .75rem;line-height:1.4}
.ismaac-pay-sub{color:rgba(253,245,224,.72);font-size:.95rem;line-height:1.6;margin:0 0 1.25rem}
.ismaac-pay-note{background:rgba(201,152,42,.08);border:1px solid rgba(201,152,42,.2);border-radius:10px;padding:1rem 1.25rem;color:rgba(253,245,224,.65);font-size:.88rem;line-height:1.6}
.ismaac-pay-email{display:inline-block;margin-top:.6rem;color:rgba(201,152,42,.85);text-decoration:none;font-weight:700;font-size:.9rem;transition:color .2s}
.ismaac-pay-email:hover{color:#E8C97A}
.book-cover-om{font-family:var(--font-hindi);font-size:2.8rem;color:rgba(255,255,255,.45);display:block;margin-bottom:.5rem;position:relative;z-index:1}
.book-title-spine{font-family:var(--font-serif);font-size:.88rem;color:rgba(255,255,255,.85);line-height:1.4;text-align:center;position:relative;z-index:1;padding:0 .5rem}
.book-tag{display:inline-block;background:var(--gold-pale);border:1px solid var(--gold-light);color:var(--mid-brown);font-size:.72rem;font-weight:700;padding:.25rem .7rem;border-radius:20px;margin-top:.75rem}
.book-info h3{font-size:1.05rem;color:var(--burgundy);margin-bottom:.4rem;line-height:1.45}
.book-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.76rem;color:var(--text-light);margin:.75rem 0;padding:.6rem;background:var(--parchment);border-radius:6px}
.book-card--featured{grid-column:span 2}
.book-card--featured .book-cover{height:300px}
.book-card--featured .book-cover-om{font-size:3.5rem}
.book-card--featured .book-info{padding:1.75rem}
.book-card--featured h3{font-size:1.3rem}
.books-grid--large{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:2.25rem}
@media(max-width:700px){.book-card--featured{grid-column:span 1}}

/* ── Video extras ── */
.video-tag{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--saffron));color:var(--white);font-size:.7rem;font-weight:700;padding:.2rem .65rem;border-radius:12px;letter-spacing:.06em}
.video-meta{display:flex;align-items:center;gap:.75rem;margin-top:.6rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-light)}
.videos-grid--large{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.play-btn{font-size:1.4rem;color:var(--white);background:rgba(201,152,42,.9);width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.video-card:hover .play-btn{transform:scale(1.12);background:var(--gold)}

/* ── Podcast extras ── */
.podcast-art{width:90px;height:90px;border-radius:14px;background:linear-gradient(135deg,var(--burgundy),#3A0B1C);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-lg)}
.podcast-art--saffron{background:linear-gradient(135deg,#8B3A0A,var(--saffron))}
.podcast-art--maroon{background:linear-gradient(135deg,var(--maroon),#3A0B1C)}
.podcast-om{font-family:var(--font-hindi);font-size:2.2rem;color:rgba(255,255,255,.85)}
.podcast-host{font-size:.78rem;color:var(--text-light);font-style:italic;margin-bottom:.6rem}
.podcast-info p{font-size:.88rem;color:var(--text-mid);line-height:1.6;margin-bottom:.9rem}
.podcast-info h4{font-size:1.05rem;color:var(--burgundy);margin-bottom:.25rem}
.podcast-episodes{display:flex;flex-direction:column;gap:.3rem;margin:.75rem 0;padding:.75rem;background:var(--parchment);border-radius:8px;border-left:3px solid var(--gold-light)}
.podcast-episodes span{font-size:.78rem;color:var(--text-mid);font-family:var(--font-hindi);padding:.15rem 0}
.podcast-play{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--gold),var(--saffron));border:none;color:var(--white);font-weight:700;font-size:.82rem;padding:.6rem 1.2rem;border-radius:20px;cursor:pointer;transition:var(--transition);margin-top:.5rem;box-shadow:var(--shadow-gold)}
.podcast-play:hover{transform:translateY(-2px)}
.podcasts-grid--large{flex-direction:column;max-width:100%;gap:2rem}
.podcasts-grid--large .podcast-card{align-items:flex-start;flex-direction:row}

/* ── Podcast notify box ── */
.podcast-notify-box{margin-top:3rem;background:linear-gradient(135deg,var(--gold-pale),var(--parchment));border:2px solid rgba(201,152,42,.4);border-radius:var(--radius-lg);padding:2rem 2.5rem}
.pnb-inner{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.pnb-icon{font-size:2.5rem;flex-shrink:0}
.pnb-inner div{flex:1;min-width:200px}
.pnb-inner h4{color:var(--burgundy);margin-bottom:.35rem}
.pnb-inner p{font-size:.88rem;color:var(--text-mid)}

/* ── Resources dedicated page overrides ── */
.resources-page{background:var(--deep-brown);padding-bottom:6rem}
.resources-page .section-header.light{padding-top:3rem}
.resources-page .books-grid,
.resources-page .videos-grid,
.resources-page .podcasts-grid{background:transparent}
.resources-page .book-card,
.resources-page .video-card,
.resources-page .podcast-card{background:var(--white)}

/* ── Page hero overlay/content (resources.html uses .page-hero-overlay) ── */
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,3,5,.85),rgba(74,14,36,.7));pointer-events:none;z-index:1}
.page-hero-content{position:relative;z-index:2}
.page-hero-content p{color:rgba(255,255,255,.7);font-size:1.05rem;margin-top:.75rem;max-width:580px;margin-left:auto;margin-right:auto}
.page-hero-content .hero-mantra{font-family:var(--font-hindi);font-size:2rem;color:var(--gold-light);margin-bottom:.5rem;line-height:1}

/* ── Resources section on home page vs dark background ── */
.resources-section{background:var(--deep-brown)}
.resources-section .section-header.light h2{color:var(--white)}
.resources-section .book-card,.resources-section .video-card,.resources-section .podcast-card{background:rgba(255,255,255,.06);border-color:rgba(201,152,42,.25)}
.resources-section .book-card:hover,.resources-section .video-card:hover,.resources-section .podcast-card:hover{background:rgba(255,255,255,.1)}
.resources-section .book-info h4,.resources-section .video-info h4,.resources-section .podcast-info h4{color:var(--gold-light)}
.resources-section .book-info p,.resources-section .video-info p,.resources-section .podcast-info p{color:rgba(255,255,255,.65)}
.resources-section .book-author{color:rgba(255,255,255,.45)!important}
.resources-section .book-tag{background:rgba(201,152,42,.2);border-color:rgba(201,152,42,.4);color:var(--gold-light)}

/* ── Header scrolled state ── */
#top-header.scrolled{box-shadow:0 2px 30px rgba(0,0,0,.45)}

/* ══════════════════════════════════════════════════════════
   COSMIC / FUTURISTIC THEME LAYER
══════════════════════════════════════════════════════════ */

/* ── Three.js hero canvas ── */
#cosmicCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.hero-overlay,.hero-content,.hero-image-col,.hero-particles{z-index:2;position:relative}

/* ── Floating Sanskrit glyphs ── */
.cosmic-glyph{
  position:fixed;
  font-family:var(--font-hindi);
  color:var(--gold);
  pointer-events:none;
  z-index:0;
  animation:cosmicFloat linear infinite;
  text-shadow:0 0 18px rgba(201,152,42,.6);
  user-select:none;
}
@keyframes cosmicFloat{
  0%  {transform:translateY(110vh) rotate(0deg);   opacity:0}
  5%  {opacity:1}
  95% {opacity:0.6}
  100%{transform:translateY(-12vh) rotate(360deg); opacity:0}
}

/* ── Energy orbs ── */
.energy-orb{
  position:absolute;border-radius:50%;pointer-events:none;
  animation:orbDrift ease-in-out infinite alternate;
  filter:blur(40px);z-index:0;
}
@keyframes orbDrift{
  0%  {transform:translate(0,0)   scale(1)}
  50% {transform:translate(18px,-22px) scale(1.12)}
  100%{transform:translate(-14px,16px) scale(0.92)}
}

/* ── Quantum scan on hover ── */
.quantum-scan{overflow:hidden!important}
.quantum-scan::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(201,152,42,.08) 50%,transparent 100%);
  animation:qscan .6s linear;pointer-events:none;border-radius:inherit;
}
@keyframes qscan{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

/* ── Cursor trail ── */
.cursor-trail{
  position:fixed;width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,152,42,.8),transparent);
  pointer-events:none;z-index:99999;
  transform-origin:center;transition:none;
  filter:blur(2px);
}

/* ── Mandala SVG wrapper ── */
.mandala-wrap{display:flex;justify-content:center;padding:1.5rem 0;position:relative;z-index:1;opacity:.7}
.mandala-svg{width:min(220px,55vw);height:auto;display:block}
.mring{transform-box:fill-box;transform-origin:center}
.mr1{animation:mSpin 60s linear infinite}
.mr2{animation:mSpin 40s linear infinite reverse}
.mr3{animation:mSpin 30s linear infinite}
.mr4{animation:mSpin 22s linear infinite reverse}
.mr5{animation:mSpin 16s linear infinite}
.mpetal{animation:mSpin 45s linear infinite}
.mpulse{animation:mPulse 3s ease-in-out infinite}
.mcentre{animation:mGlow 2.8s ease-in-out infinite}
@keyframes mSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes mPulse{0%,100%{opacity:.35;r:45}50%{opacity:.6;r:52}}
@keyframes mGlow{0%,100%{opacity:.75;filter:url(#glow)}50%{opacity:1}}

/* ══════════════════════════════════════════════════════════
   GLASSMORPHISM UPGRADES
══════════════════════════════════════════════════════════ */

/* Sadhya cards — glass + glow border */
.sadhya-card{
  background:rgba(26,5,8,.65)!important;
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border:1px solid rgba(201,152,42,.22)!important;
  box-shadow:0 4px 32px rgba(0,0,0,.45),inset 0 0 0 1px rgba(255,255,255,.04);
  transition:border-color .3s, box-shadow .3s, transform .3s;
}
.sadhya-card:hover{
  border-color:rgba(201,152,42,.6)!important;
  box-shadow:0 0 28px rgba(201,152,42,.25),0 8px 40px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.06)!important;
  transform:translateY(-4px) scale(1.01)!important;
}

/* Stats bar — holographic glass ── */
.stats-bar{
  background:rgba(15,5,8,.72)!important;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(201,152,42,.18);
  border-bottom:1px solid rgba(201,152,42,.18);
  position:relative;overflow:hidden;
}
.stats-bar::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,rgba(201,152,42,.03) 0px,rgba(201,152,42,.03) 1px,transparent 1px,transparent 60px);
  pointer-events:none;
}
.stat-item{position:relative}
.stat-item::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transition:width .4s;
}
.stat-item:hover::after{width:80%}
.stat-number{
  background:linear-gradient(135deg,#fff 0%,var(--gold-light) 50%,var(--saffron) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 8px rgba(201,152,42,.5));
}

/* Book cards — glass effect ── */
.book-card{
  background:rgba(20,5,8,.6)!important;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(201,152,42,.18)!important;
  transition:border-color .3s,box-shadow .3s,transform .3s!important;
}
.book-card:hover{
  border-color:rgba(201,152,42,.5)!important;
  box-shadow:0 0 24px rgba(201,152,42,.18),0 8px 32px rgba(0,0,0,.5)!important;
  transform:translateY(-5px)!important;
}

/* Swami section glass ── */
.swami-section{position:relative;overflow:hidden}
.swami-quote-block{
  background:linear-gradient(135deg,rgba(15,4,8,.88),rgba(30,10,5,.82))!important;
  backdrop-filter:blur(16px)!important;
  -webkit-backdrop-filter:blur(16px)!important;
  border:1px solid rgba(201,152,42,.35)!important;
  box-shadow:0 0 40px rgba(201,152,42,.15),inset 0 1px 0 rgba(255,255,255,.06)!important;
}
/* Make quote text bright & legible on dark bg */
.swami-quote-block p{color:rgba(255,255,255,.92)!important;font-size:1.12rem!important;line-height:1.85!important;font-style:italic}
.swami-quote-block cite{color:var(--gold-light)!important;letter-spacing:.08em}
.swami-quote-block .swami-quote-mark{color:var(--gold)!important;opacity:.8!important;text-shadow:0 0 20px rgba(201,152,42,.6)}

/* Five Pillars — unique per-card colour theme ── */
.pillar-card{transition:transform .3s,box-shadow .3s,border-color .3s!important}

/* 1 Purna Brahma — gold */
.pillar-card:nth-child(1){border-top:3px solid #C9982A!important}
.pillar-card:nth-child(1) .pillar-icon{background:linear-gradient(135deg,#C9982A,#E8C97A);border-color:#C9982A;color:#fff;box-shadow:0 4px 16px rgba(201,152,42,.4)}
.pillar-card:nth-child(1):hover{border-color:#C9982A!important;box-shadow:0 0 28px rgba(201,152,42,.25),0 10px 32px rgba(0,0,0,.1)!important;transform:translateY(-7px)!important}

/* 2 No-Centre — teal */
.pillar-card:nth-child(2){border-top:3px solid #17BABA!important}
.pillar-card:nth-child(2) .pillar-icon{background:linear-gradient(135deg,#0A6B6B,#17BABA);border-color:#17BABA;color:#fff;box-shadow:0 4px 16px rgba(23,186,186,.4)}
.pillar-card:nth-child(2):hover{border-color:#17BABA!important;box-shadow:0 0 28px rgba(23,186,186,.25),0 10px 32px rgba(0,0,0,.1)!important;transform:translateY(-7px)!important}

/* 3 The Dot — deep purple */
.pillar-card:nth-child(3){border-top:3px solid #C030C0!important}
.pillar-card:nth-child(3) .pillar-icon{background:linear-gradient(135deg,#6B0A6B,#C030C0);border-color:#C030C0;color:#fff;box-shadow:0 4px 16px rgba(192,48,192,.4)}
.pillar-card:nth-child(3):hover{border-color:#C030C0!important;box-shadow:0 0 28px rgba(192,48,192,.25),0 10px 32px rgba(0,0,0,.1)!important;transform:translateY(-7px)!important}

/* 4 Witnessed Birth — crimson */
.pillar-card:nth-child(4){border-top:3px solid #C93030!important}
.pillar-card:nth-child(4) .pillar-icon{background:linear-gradient(135deg,#8B1A1A,#C93030);border-color:#C93030;color:#fff;box-shadow:0 4px 16px rgba(201,48,48,.4)}
.pillar-card:nth-child(4):hover{border-color:#C93030!important;box-shadow:0 0 28px rgba(201,48,48,.25),0 10px 32px rgba(0,0,0,.1)!important;transform:translateY(-7px)!important}

/* 5 No Space — cosmic violet */
.pillar-card:nth-child(5){border-top:3px solid #6868B8!important}
.pillar-card:nth-child(5) .pillar-icon{background:linear-gradient(135deg,#2A2A5A,#6868B8);border-color:#6868B8;color:#fff;box-shadow:0 4px 16px rgba(104,104,184,.4)}
.pillar-card:nth-child(5):hover{border-color:#6868B8!important;box-shadow:0 0 28px rgba(104,104,184,.25),0 10px 32px rgba(0,0,0,.1)!important;transform:translateY(-7px)!important}

/* Nav glass ── backdrop-filter removed: it creates a CSS containing block
   that breaks position:fixed on child .main-nav (sidebar won't full-height) */
#top-header{
  background:rgba(15,4,6,.95)!important;
  border-bottom:1px solid rgba(201,152,42,.12)!important;
}
#top-header.scrolled{
  background:rgba(10,2,4,.98)!important;
  border-bottom-color:rgba(201,152,42,.22)!important;
}

/* Holographic hero text ── */
.hero-title{
  background:linear-gradient(135deg,#fff 0%,var(--gold-light) 40%,var(--saffron) 70%,#fff 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:holoShift 6s ease-in-out infinite;
  filter:drop-shadow(0 0 30px rgba(201,152,42,.4));
}
@keyframes holoShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Glow CTA buttons ── */
.btn-primary{
  box-shadow:0 0 20px rgba(201,152,42,.3),0 4px 14px rgba(0,0,0,.4)!important;
  transition:box-shadow .3s,transform .25s!important;
}
.btn-primary:hover{
  box-shadow:0 0 40px rgba(201,152,42,.55),0 6px 24px rgba(0,0,0,.5)!important;
  transform:translateY(-3px) scale(1.03)!important;
}

/* Footer glass ── */
.site-footer{
  border-top:1px solid rgba(201,152,42,.15);
  position:relative;overflow:hidden;
}
.site-footer::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,rgba(201,152,42,.02) 0px,rgba(201,152,42,.02) 1px,transparent 1px,transparent 40px);
  pointer-events:none;
}

/* Section labels futuristic ── */
.section-label{
  letter-spacing:.18em!important;
  text-transform:uppercase;
  background:linear-gradient(90deg,var(--saffron),var(--gold-light));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 6px rgba(201,152,42,.3));
}

/* Sadhya number — unified gold theme (#10 audit fix) ── */
.sadhya-num{color:var(--white)!important;background-clip:unset!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:unset!important;text-shadow:none!important}
.sadhya-card .sadhya-num{background:linear-gradient(135deg,#C9982A,#E8C97A)!important;box-shadow:0 4px 20px rgba(201,152,42,.55)!important}

/* Sadhya card — unified gold border accent ── */
.sadhya-card{border-top:2px solid rgba(201,152,42,.45)!important}

/* Sanskrit text glow ── */
.sadhya-sanskrit{
  text-shadow:0 0 20px rgba(201,152,42,.35)!important;
}

/* Signature dot cosmic glow ── */
.signature-dot{
  animation:dotGlow 2s ease-in-out infinite!important;
  text-shadow:0 0 30px rgba(201,152,42,.9),0 0 60px rgba(255,140,0,.5)!important;
}
@keyframes dotGlow{
  0%,100%{text-shadow:0 0 30px rgba(201,152,42,.9),0 0 60px rgba(255,140,0,.5)}
  50%    {text-shadow:0 0 60px rgba(201,152,42,1), 0 0 100px rgba(255,140,0,.8)}
}

/* Resources section dark glass ── */
.resources-section{
  background:rgba(10,2,4,.85)!important;
  backdrop-filter:blur(8px);
  border-top:1px solid rgba(201,152,42,.1);
  border-bottom:1px solid rgba(201,152,42,.1);
}

/* Chatbot bubble glow ── */
.chat-bubble{
  box-shadow:0 0 20px rgba(201,152,42,.4),0 4px 20px rgba(0,0,0,.5)!important;
}
.chat-bubble:hover{
  box-shadow:0 0 40px rgba(201,152,42,.65),0 6px 28px rgba(0,0,0,.5)!important;
}

/* ══════════════════════════════════════════════════════════
   CHATBOT WIDGET
══════════════════════════════════════════════════════════ */
#ismaac-chat{position:fixed;bottom:2rem;right:2rem;z-index:9999;font-family:var(--font-sans)}

/* ── Floating bubble ── */
.chat-bubble{position:relative;width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--burgundy),var(--maroon));border:2px solid var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.45);transition:transform .25s,box-shadow .25s}
.chat-bubble:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(201,152,42,.4)}
.chat-bubble.active{background:linear-gradient(135deg,#3D0A14,var(--burgundy))}
.chat-bubble-icon{font-size:1.55rem;line-height:1;position:relative;z-index:1;font-family:'Noto Serif Devanagari',serif;color:var(--gold-light);font-weight:700;text-shadow:0 0 12px rgba(201,152,42,.8)}
.chat-bubble-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--gold);opacity:.5;animation:chatPulse 2.2s ease-out infinite}
@keyframes chatPulse{0%{transform:scale(.95);opacity:.5}70%{transform:scale(1.15);opacity:0}100%{transform:scale(.95);opacity:0}}

/* ── Chat window ── */
.chat-window{position:absolute;bottom:80px;right:0;width:360px;max-height:520px;background:#1A0508;border:1px solid rgba(201,152,42,.3);border-radius:16px;box-shadow:0 16px 60px rgba(0,0,0,.6);display:flex;flex-direction:column;overflow:hidden;transform:scale(.85) translateY(20px);opacity:0;pointer-events:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .25s}
.chat-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}

/* ── Header ── */
.chat-header{background:linear-gradient(135deg,#2D0A14,#1A0508);padding:1rem 1.1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(201,152,42,.25)}
.chat-header-info{display:flex;align-items:center;gap:.75rem}
.chat-avatar{font-size:1.5rem;font-family:'Noto Serif Devanagari',serif;color:var(--gold-light);text-shadow:0 0 8px rgba(201,152,42,.6)}
.chat-title{font-family:var(--font-serif);color:var(--gold-light);font-size:.95rem;font-weight:700;line-height:1.2}
.chat-subtitle{color:rgba(255,255,255,.45);font-size:.72rem;margin-top:.1rem}
.chat-close{background:rgba(201,152,42,.15);border:1px solid rgba(201,152,42,.3);color:rgba(255,255,255,.85);font-size:1rem;cursor:pointer;padding:.3rem .55rem;border-radius:6px;transition:all .2s;font-weight:700;line-height:1}
.chat-close:hover{background:rgba(201,152,42,.35);color:#fff;border-color:rgba(201,152,42,.6)}

/* ── Messages ── */
.chat-messages{flex:1;overflow-y:auto;padding:.9rem 1rem;display:flex;flex-direction:column;gap:.7rem;scrollbar-width:thin;scrollbar-color:rgba(201,152,42,.3) transparent}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-thumb{background:rgba(201,152,42,.3);border-radius:4px}

.chat-msg{max-width:86%;font-size:.85rem;line-height:1.6;padding:.65rem .9rem;border-radius:12px;animation:msgIn .25s ease-out}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.chat-msg--bot{background:rgba(255,255,255,.07);border:1px solid rgba(201,152,42,.15);color:rgba(255,255,255,.88);align-self:flex-start;border-radius:4px 12px 12px 12px}
.chat-msg--user{background:linear-gradient(135deg,var(--burgundy),#2D0A14);border:1px solid rgba(201,152,42,.25);color:rgba(255,255,255,.9);align-self:flex-end;border-radius:12px 4px 12px 12px}

/* ── Typing indicator ── */
.chat-typing{display:flex;align-items:center;gap:4px;padding:.7rem .9rem}
.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.5;animation:typingDot 1.2s ease-in-out infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,100%{opacity:.25;transform:translateY(0)}50%{opacity:.9;transform:translateY(-4px)}}

/* ── Suggestions ── */
.chat-suggestions{display:flex;flex-wrap:wrap;gap:.4rem;padding:.6rem 1rem .4rem;border-top:1px solid rgba(255,255,255,.06)}
.chat-sugg{background:rgba(201,152,42,.1);border:1px solid rgba(201,152,42,.3);color:var(--gold-light);font-size:.72rem;padding:.3rem .7rem;border-radius:20px;cursor:pointer;transition:background .2s,border-color .2s;white-space:nowrap}
.chat-sugg:hover{background:rgba(201,152,42,.22);border-color:var(--gold)}

/* ── Input row ── */
.chat-input-row{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid rgba(201,152,42,.2);background:rgba(0,0,0,.2)}
.chat-input-row input{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(201,152,42,.25);border-radius:24px;padding:.5rem .9rem;color:#fff;font-size:.84rem;outline:none;transition:border-color .2s;font-family:var(--font-sans)}
.chat-input-row input::placeholder{color:rgba(255,255,255,.3)}
.chat-input-row input:focus{border-color:var(--gold)}
#chatSend{background:linear-gradient(135deg,var(--gold),var(--saffron));border:none;border-radius:50%;width:36px;height:36px;min-width:36px;cursor:pointer;color:#1A0508;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}
#chatSend:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(201,152,42,.4)}

@media(max-width:480px){.chat-window{width:calc(100vw - 2rem);right:-1rem;max-height:70vh}}

/* ══════════════════════════════════════════════════════════
   PAGE-SPECIFIC COSMIC ELEMENTS
   life.html, teachings.html, gallery.html, resources.html, about.html
══════════════════════════════════════════════════════════ */

/* Life.html — vertical shimmer light columns */
.page-shimmer-line {
  position: fixed;
  top: 0; bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom,
    transparent 0%,
    rgba(201,152,42,.45) 40%,
    rgba(224,123,42,.3) 60%,
    transparent 100%);
  pointer-events: none;
  z-index: 0;
  animation: shimmerLine var(--dur, 5s) ease-in-out var(--delay, 0s) infinite;
}
@keyframes shimmerLine {
  0%, 100% { opacity: .1; transform: scaleY(.55) }
  50%       { opacity: .5; transform: scaleY(1)   }
}

/* Teachings.html — drifting quote marks */
.floating-quote-mark {
  position: fixed;
  font-family: var(--font-serif);
  pointer-events: none;
  z-index: 0;
  user-select: none;
  animation: cosmicFloat var(--dur, 20s) linear var(--delay, 0s) infinite;
  color: rgba(201,152,42,.13);
}

/* Gallery.html — sparkle burst points */
.gallery-sparkle {
  position: fixed;
  width: 5px; height: 5px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(circle, rgba(201,152,42,.95) 0%, transparent 70%);
  animation: sparkleBurst var(--dur, 3s) ease-out var(--delay, 0s) infinite;
}
@keyframes sparkleBurst {
  0%   { transform: scale(0);   opacity: 0 }
  25%  { opacity: 1;             transform: scale(1)   }
  100% { transform: scale(5);   opacity: 0 }
}

/* Resources.html — flowing Sanskrit characters */
.resource-flow-char {
  position: fixed;
  font-family: 'Noto Serif Devanagari', serif;
  pointer-events: none;
  z-index: 0;
  user-select: none;
  animation: cosmicFloat var(--dur, 22s) linear var(--delay, 0s) infinite;
  color: rgba(201,152,42,.1);
}

/* About.html — concentric pulse rings (absolute within .page-hero) */
.about-pulse-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(201,152,42,.22);
  pointer-events: none;
  z-index: 1;
  left: 50%; top: 50%;
  transform: translate(-50%,-50%) scale(.3);
  animation: aboutPulse var(--dur, 6s) ease-out var(--delay, 0s) infinite;
}
@keyframes aboutPulse {
  0%   { transform: translate(-50%,-50%) scale(.25); opacity: .7 }
  100% { transform: translate(-50%,-50%) scale(3.5); opacity: 0  }
}

/* ══════════════════════════════════════════════════════════
   FADE-UP REVEAL CLASS
══════════════════════════════════════════════════════════ */
.fade-up {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* ══════════════════════════════════════════════════════════
   THEME BALANCE — LIGHT SECTIONS
   Problem: some sections were near-white, others near-black with no warmth.
   Fix: warm gold-cream gradient on light sections; enrich dark sections.
══════════════════════════════════════════════════════════ */

/* Five Pillars — warm spiritual light, subtle aura */
.pillars-section {
  background: linear-gradient(160deg,#FFFCF0 0%,#FFF7E3 35%,#FFFCF0 70%,#FFF8EA 100%) !important;
  position: relative;
}
.pillars-section::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%,   rgba(201,152,42,.08) 0%, transparent 50%),
    radial-gradient(ellipse at 100% 100%,rgba(224,123,42,.05) 0%, transparent 45%);
  pointer-events: none; z-index: 0;
}
.pillars-section .container { position: relative; z-index: 1; }

/* Pillar cards — creamy white with warm border */
.pillar-card {
  background: linear-gradient(145deg,#FFFFFF 0%,#FFFDF8 100%) !important;
  border: 1px solid rgba(201,152,42,.22) !important;
  box-shadow: 0 2px 18px rgba(201,152,42,.09), 0 1px 4px rgba(0,0,0,.05) !important;
}
.pillar-card h3 { color: var(--burgundy) !important; }
.pillar-card p   { color: var(--text-mid) !important; }

/* Swami section (parchment bg) — warm quote block, NOT dark glass */
.swami-section .swami-quote-block {
  background: linear-gradient(135deg,rgba(255,247,222,.98),rgba(253,240,200,.95)) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-left: 4px solid var(--saffron) !important;
  border-top: 1px solid rgba(201,152,42,.2) !important;
  border-right: 1px solid rgba(201,152,42,.12) !important;
  border-bottom: 1px solid rgba(201,152,42,.15) !important;
  box-shadow: 0 4px 24px rgba(201,152,42,.13), inset 0 1px 0 rgba(255,255,255,.85) !important;
}
.swami-section .swami-quote-block p {
  color: var(--burgundy) !important;
  font-size: 1.06rem !important;
  line-height: 1.82 !important;
  font-style: italic;
}
.swami-section .swami-quote-block cite {
  color: var(--mid-brown) !important;
  letter-spacing: .07em;
}
.swami-section .swami-quote-block .swami-quote-mark {
  color: var(--gold) !important;
  opacity: .55 !important;
  text-shadow: none !important;
}

/* Life overview — warm honey gradient */
.life-overview {
  background: linear-gradient(160deg,#FFFCF0 0%,#F9F0DE 50%,#FFFCF0 100%) !important;
}

/* Timeline cards — creamy white */
.tl-content {
  background: linear-gradient(145deg,#FFFFFF,#FFFDF8) !important;
  border-left: 3px solid var(--gold) !important;
}

/* About section — warm cream */
.about-section {
  background: linear-gradient(160deg,#FFFCF0 0%,#FFF8E3 50%,#FFFCF0 100%) !important;
}

/* Quote band — richer parchment */
.quote-band {
  background: linear-gradient(135deg,#F5EBD4 0%,#FDF2DC 50%,#EFDFC2 100%) !important;
  border-top: 2px solid rgba(201,152,42,.38) !important;
  border-bottom: 2px solid rgba(201,152,42,.38) !important;
  position: relative;
}
.quote-band::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 50%,rgba(201,152,42,.06),transparent 60%);
  pointer-events: none;
}

/* Gallery strip */
.gallery-strip {
  background: linear-gradient(160deg,#F5EBD4 0%,#EDE0C4 100%) !important;
}

/* Consciousness sections — warm alternating */
.consciousness-section:nth-child(odd) {
  background: linear-gradient(160deg,#FFFCF0 0%,#FFF7E3 100%) !important;
}
.consciousness-section:nth-child(even) {
  background: linear-gradient(160deg,#F5EBD4 0%,#ECE0C5 100%) !important;
}

/* ══════════════════════════════════════════════════════════
   THEME BALANCE — DARK SECTIONS
   Enrich with warm deep maroon, not pure black
══════════════════════════════════════════════════════════ */
.sadhya-section {
  background: linear-gradient(170deg,#0E0307 0%,#1C0610 40%,#2A0A12 70%,#180508 100%) !important;
}
.teachings-preview {
  background: linear-gradient(145deg,#2D0814 0%,#1A0508 50%,#3A0B1C 100%) !important;
}
.resources-section {
  background: linear-gradient(160deg,#0C0308 0%,#1A0508 50%,#110208 100%) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — SECTION HEADINGS
══════════════════════════════════════════════════════════ */

/* Section h2 on LIGHT backgrounds — rich burgundy gradient */
.pillars-section .section-header h2,
.life-overview .section-header h2,
.life-overview h2,
.about-section h2,
.gallery-strip .section-header h2 {
  background: linear-gradient(135deg,#4A0E24 0%,#7A2337 45%,#9B3040 80%,#4A0E24 100%) !important;
  background-size: 200% 100% !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  filter: drop-shadow(0 2px 8px rgba(74,14,36,.15)) !important;
  animation: headingShimmer 8s ease-in-out infinite !important;
}
@keyframes headingShimmer {
  0%,100% { background-position: 0% 50% }
  50%     { background-position: 100% 50% }
}

/* Section h2 on DARK backgrounds — gold glow */
.sadhya-section .sadhya-header h2,
.teachings-preview .section-header h2,
.resources-section .section-header h2 {
  text-shadow: 0 0 30px rgba(201,152,42,.35), 0 0 60px rgba(201,152,42,.15) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — HERO IMAGE DIVINE GLOW
══════════════════════════════════════════════════════════ */
.hero-img-frame {
  filter: none;
}
.hero-img-frame::before {
  content: '';
  position: absolute;
  inset: -10px;
  border-radius: calc(var(--radius-lg) + 10px);
  background: conic-gradient(
    from 0deg,
    rgba(201,152,42,.18),
    rgba(224,123,42,.12),
    rgba(201,152,42,.22),
    rgba(255,180,60,.12),
    rgba(201,152,42,.18)
  );
  z-index: -1;
  filter: blur(16px);
  animation: divineAura 5s linear infinite;
}
@keyframes divineAura {
  0%   { transform: rotate(0deg);   opacity: .7 }
  50%  { opacity: 1 }
  100% { transform: rotate(360deg); opacity: .7 }
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — SECTION HEADER DECORATION
══════════════════════════════════════════════════════════ */

/* Decorative line under section label */
.section-label::after {
  content: ' ✦ ';
  opacity: .55;
  font-size: .7em;
}
.section-label::before {
  content: ' ✦ ';
  opacity: .55;
  font-size: .7em;
}

/* Section description — color has no !important so dark-section overrides and inline styles work */
.section-desc {
  color: var(--text-mid);
  line-height: 1.82 !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — CARD HOVER DIVINE EFFECT
══════════════════════════════════════════════════════════ */

/* Sadhya card — pulsing aura on hover */
.sadhya-card:hover .sadhya-num {
  animation: numPulse .6s ease-in-out !important;
}
@keyframes numPulse {
  0%,100% { transform: scale(1) }
  50%     { transform: scale(1.12) }
}

/* Pillar card hover — warm glow */
.pillar-card:hover {
  box-shadow:
    0 0 0 1px rgba(201,152,42,.3),
    0 8px 32px rgba(201,152,42,.18),
    0 16px 40px rgba(0,0,0,.08) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — MISSION CARDS (About page)
══════════════════════════════════════════════════════════ */
.mission-card {
  background: linear-gradient(145deg,#FFFFFF 0%,#FFFDF7 100%) !important;
  border-top: 3px solid var(--gold) !important;
  box-shadow: 0 2px 20px rgba(201,152,42,.09), 0 1px 4px rgba(0,0,0,.05) !important;
}
.mission-card:hover {
  box-shadow: 0 0 0 1px rgba(201,152,42,.2), 0 8px 32px rgba(201,152,42,.15) !important;
  transform: translateY(-5px) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — RESOURCES PAGE DARK GLASS CARDS
══════════════════════════════════════════════════════════ */
.resources-section .book-info h4,
.resources-page  .book-info h3,
.resources-page  .book-info h4 {
  color: var(--gold-light) !important;
}
.resources-section .book-info .book-author,
.resources-page   .book-info .book-author {
  color: rgba(255,255,255,.48) !important;
}
.resources-section .book-info .book-desc,
.resources-page   .book-info p {
  color: rgba(255,255,255,.62) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — PAGE HERO ENHANCEMENT
══════════════════════════════════════════════════════════ */
.page-hero {
  background: linear-gradient(145deg,#0E0205 0%,#1A0508 30%,#2D0514 60%,#1A0508 100%) !important;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 25% 60%,rgba(201,152,42,.13) 0%,transparent 50%),
    radial-gradient(ellipse at 75% 30%,rgba(224,123,42,.09) 0%,transparent 45%);
  pointer-events: none; z-index: 1;
}
.page-hero h1 {
  text-shadow: 0 0 40px rgba(201,152,42,.3), 0 2px 12px rgba(0,0,0,.5) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — FOOTER WARM TREATMENT
══════════════════════════════════════════════════════════ */
.site-footer {
  background: linear-gradient(160deg,#160508 0%,#1C0A05 50%,#0E0305 100%) !important;
}

/* ══════════════════════════════════════════════════════════
   SPIRITUAL AESTHETICS — STATS BAR TEXT
══════════════════════════════════════════════════════════ */
.stat-label {
  color: rgba(255,255,255,.6) !important;
  letter-spacing: .13em !important;
}

/* ══════════════════════════════════════════════════════════
   SMOOTH SECTION TRANSITIONS (gradient-fade pseudo-elements)
══════════════════════════════════════════════════════════ */

/* Stats bar → Sadhya (dark after dark: seamless) */
/* Quote band → Five Pillars: parchment to cream — add gold separator */
.quote-band + .pillars-section {
  border-top: 2px solid rgba(201,152,42,.2);
}
/* Teachings preview dark to Life overview light */
.teachings-preview + .life-overview {
  border-top: 2px solid rgba(201,152,42,.15);
}
/* Gallery strip to About section */
.gallery-strip + .about-section,
.gallery-strip + * {
  border-top: 1px solid rgba(201,152,42,.12);
}

/* ══════════════════════════════════════════════════════════
   SECTION BRIDGE DIVIDERS
   Smooth visual transition between dark↔light sections
══════════════════════════════════════════════════════════ */
.section-bridge-divider {
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, #1A0508, #2A0A14);
  padding: .6rem 3rem;
  gap: 1.2rem;
  position: relative;
  z-index: 2;
}
.section-bridge-divider--dark {
  background: linear-gradient(135deg, #F5EBD4, #FDF2DC);
}
.sbd-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,152,42,.45), transparent);
}
.sbd-om {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 1.4rem;
  color: var(--gold);
  opacity: .65;
  text-shadow: 0 0 12px rgba(201,152,42,.5);
  animation: dotGlow 3s ease-in-out infinite;
  flex-shrink: 0;
}
.section-bridge-divider--dark .sbd-line {
  background: linear-gradient(90deg, transparent, rgba(201,152,42,.35), transparent);
}
.section-bridge-divider--dark .sbd-om {
  color: var(--gold);
  text-shadow: 0 0 8px rgba(201,152,42,.3);
}

/* ══════════════════════════════════════════════════════════
   QUOTE BAND — richer typography
══════════════════════════════════════════════════════════ */
.quote-band blockquote {
  position: relative; z-index: 1;
}
.quote-band blockquote > span[data-en] {
  background: linear-gradient(135deg, var(--burgundy) 0%, #6B2030 50%, var(--burgundy) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}
.q-mark {
  color: var(--gold) !important;
  opacity: .75;
}

/* ══════════════════════════════════════════════════════════
   HERO IMAGE FRAME — ensure z-index so badge shows
══════════════════════════════════════════════════════════ */
.hero-img-frame {
  position: relative;
  z-index: 2;
}
.hero-img-badge {
  z-index: 3;
}

/* ══════════════════════════════════════════════════════════
   PILLAR ICONS — spiritual symbol glow on hover
══════════════════════════════════════════════════════════ */
.pillar-card:hover .pillar-icon {
  transform: scale(1.08) rotate(5deg);
  transition: transform .3s ease;
}

/* ══════════════════════════════════════════════════════════
   GALLERY STRIP — thumbnail overlay enhancement
══════════════════════════════════════════════════════════ */
.gallery-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(74,14,36,.35), transparent 50%);
  opacity: 0;
  transition: opacity .3s;
  border-radius: 10px;
}
.gallery-thumb:hover::after { opacity: 1; }

/* ══════════════════════════════════════════════════════════
   SWAMI SECTION — subtle warm glow on the image
══════════════════════════════════════════════════════════ */
.swami-img-wrap {
  transition: box-shadow .4s ease;
}
.swami-img-wrap:hover {
  box-shadow: 0 0 40px rgba(201,152,42,.2), var(--shadow-lg) !important;
}

/* ══════════════════════════════════════════════════════════
   ABOUT SECTION — about-feature items
══════════════════════════════════════════════════════════ */
.about-feature {
  background: linear-gradient(135deg, rgba(255,255,255,.7), rgba(255,248,225,.6)) !important;
  border: 1px solid rgba(201,152,42,.18) !important;
  border-radius: 8px !important;
  padding: .5rem .75rem !important;
  transition: background .2s, border-color .2s !important;
}
.about-feature:hover {
  background: linear-gradient(135deg, rgba(255,248,225,.95), rgba(253,240,200,.9)) !important;
  border-color: rgba(201,152,42,.35) !important;
}

/* ══════════════════════════════════════════════════════════
   SCROLL REVEAL — Additional classes used by JS
══════════════════════════════════════════════════════════ */
.reveal-up {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .8s ease, transform .8s ease;
}
.reveal-up.visible { opacity: 1; transform: translateY(0); }
.reveal-zoom {
  opacity: 0;
  transform: scale(.92);
  transition: opacity .65s ease, transform .65s ease;
}
.reveal-zoom.visible { opacity: 1; transform: scale(1); }

/* ══════════════════════════════════════════════════════════
   FINAL THEME BALANCE — ELIMINATE FULL-BLACK & FULL-WHITE
   Goal: No section goes below #1A0508 (dark) or above #FDF5E0 (light)
   Every section sits somewhere in a warm spiritual palette.
══════════════════════════════════════════════════════════ */

/* ── DARK SECTIONS: Warm deep maroon instead of near-black ── */
.sadhya-section {
  background: linear-gradient(160deg,#1C0810 0%,#240A14 40%,#2E0C16 70%,#1C0A10 100%) !important;
}
.resources-section {
  background: linear-gradient(160deg,#160608 0%,#1E0A10 50%,#16060A 100%) !important;
}
.teachings-preview {
  background: linear-gradient(145deg,#300A18 0%,#1E0810 50%,#3A0C1E 100%) !important;
}
.hero {
  background: linear-gradient(135deg,#1A0508 0%,#2E0A14 50%,#220810 100%) !important;
}
.stats-bar {
  background: rgba(18,5,10,.88) !important;
}
.site-footer {
  background: linear-gradient(160deg,#180608 0%,#1E0A08 50%,#100306 100%) !important;
}

/* ── LIGHT SECTIONS: Warm amber-cream instead of near-white ── */
.pillars-section {
  background: linear-gradient(160deg,#FDF5E0 0%,#F8ECCB 35%,#FDF5E0 70%,#F8EDD0 100%) !important;
}
.life-overview {
  background: linear-gradient(160deg,#FDF2D8 0%,#F5E6C0 50%,#FDF2D8 100%) !important;
}
.about-section {
  background: linear-gradient(160deg,#FDF5E0 0%,#F8EDD0 50%,#FDF5E0 100%) !important;
}
.quote-band {
  background: linear-gradient(135deg,#EED8A8 0%,#F5E8C0 50%,#E8D098 100%) !important;
}
.gallery-strip {
  background: linear-gradient(160deg,#EDD8A8 0%,#E4CC98 100%) !important;
}
.swami-section {
  background: linear-gradient(135deg,#F0E4C4 0%,#F8EDD0 60%,#EDD8B0 100%) !important;
}

/* ── INNER PAGE CONTENT: Alternate warm amber tones ── */
/* [removed conflicting nth-child override] */

/* Gallery and life pages */
.gallery-page {
  background: linear-gradient(160deg,#F5E8C8 0%,#EDD8A8 100%) !important;
}

/* ── TEXT READABILITY on deeper amber backgrounds ── */
.about-section h2,
.life-overview h2,
.pillars-section h2,
.swami-section h2,
.gallery-strip h2 {
  color: var(--burgundy) !important;
  -webkit-text-fill-color: var(--burgundy) !important;
  background: none !important;
  filter: none !important;
  animation: none !important;
}
.swami-section p,
.swami-text-col > p,
.swami-text p {
  color: var(--text-dark) !important;
}
.swami-quote-block p,
.swami-section .swami-quote-block p {
  color: var(--burgundy) !important;
}

/* ── Pillar cards warm amber to match section ── */
.pillar-card {
  background: linear-gradient(145deg,#FFFAF0 0%,#FFF5DC 100%) !important;
  border: 1px solid rgba(201,152,42,.25) !important;
}

/* ── Timeline cards on amber background ── */
.tl-content {
  background: linear-gradient(145deg,#FFFAF0,#FFF5DC) !important;
}

/* ── Mission cards on amber ── */
.mission-card {
  background: linear-gradient(145deg,#FFFAF0 0%,#FFF5DC 100%) !important;
}

/* ── Source items and contact form on amber ── */
.source-item,
.contact-form input,
.contact-form textarea,
.contact-form select {
  background: rgba(255,250,240,.85) !important;
}

/* ── Quote band text legibility on deeper amber ── */
.quote-band blockquote span[data-en] {
  background: none !important;
  -webkit-text-fill-color: var(--burgundy) !important;
  color: var(--burgundy) !important;
}
.quote-band blockquote {
  color: var(--burgundy) !important;
}

/* ── Section descriptions on amber light sections ── */
.pillars-section .section-desc,
.swami-section .section-desc,
.life-overview .section-desc,
.about-section .section-desc {
  color: var(--text-mid) !important;
}

/* ── Fact box on life page ── */
.fact-box {
  background: linear-gradient(145deg,#FFFAF0,#FFF5DC) !important;
}

/* ── Page hero: consistent deep warm dark (NOT black) ── */
.page-hero {
  background: linear-gradient(145deg,#1A0508 0%,#2A0C14 30%,#320E18 60%,#1E0810 100%) !important;
}

/* ── Resources page (dedicated dark page) ── */
.resources-page {
  background: linear-gradient(160deg,#160608 0%,#1C0810 50%,#160608 100%) !important;
}

/* ── About ashrams / footer links ── */
.footer-links a,
.footer-ashrams a {
  color: rgba(255,255,255,.65) !important;
}

/* ── Swami year badges on amber bg ── */
.swami-year-badge {
  background: linear-gradient(145deg,#FFFAF0,#FFF5DC) !important;
}

/* ── Ashram tags on amber bg ── */
.ashram-tag {
  background: linear-gradient(145deg,#FFFAF0,#FFF5DC) !important;
  color: var(--mid-brown) !important;
}

/* ══════════════════════════════════════════════════════════
   FINAL THEME OVERRIDE — ELIMINATE NEAR-BLACK & NEAR-WHITE
   No section darker than #1A0508; no section lighter than #FDF5E0
   Every tone lives in the warm spiritual maroon ↔ amber spectrum
══════════════════════════════════════════════════════════ */

/* ── DARK SECTIONS: warm deep maroon, never near-black ── */
.hero {
  background: linear-gradient(145deg,#1A0508 0%,#2E0A14 50%,#220810 100%) !important;
}
.sadhya-section {
  background: linear-gradient(160deg,#1C0810 0%,#240A14 40%,#2E0C16 70%,#1C0A10 100%) !important;
}
.teachings-preview {
  background: linear-gradient(145deg,#300A18 0%,#1E0810 50%,#3A0C1E 100%) !important;
}
.resources-section {
  background: linear-gradient(160deg,#1A0608 0%,#220A10 50%,#1A060A 100%) !important;
}
.stats-bar {
  background: rgba(28,8,16,.90) !important;
}
.site-footer {
  background: linear-gradient(160deg,#1A0608 0%,#200A08 50%,#140406 100%) !important;
}
.page-hero {
  background: linear-gradient(145deg,#1A0508 0%,#2A0C14 30%,#320E18 60%,#1E0810 100%) !important;
}

/* ── LIGHT SECTIONS: warm amber-cream, never near-white ── */
.pillars-section {
  background: linear-gradient(160deg,#FDF5E0 0%,#F8ECCB 35%,#FDF5E0 70%,#F8EDD0 100%) !important;
}

.life-overview {
  background: linear-gradient(160deg,#FDF2D8 0%,#F5E6C0 50%,#FDF2D8 100%) !important;
}
.about-section {
  background: linear-gradient(160deg,#FDF5E0 0%,#F8EDD0 50%,#FDF5E0 100%) !important;
}
.quote-band {
  background: linear-gradient(135deg,#EED8A8 0%,#F5E8C0 50%,#E8D098 100%) !important;
}
.gallery-strip {
  background: linear-gradient(160deg,#EDD8A8 0%,#E4CC98 100%) !important;
}
.swami-section {
  background: linear-gradient(135deg,#F0E4C4 0%,#F8EDD0 60%,#EDD8B0 100%) !important;
}
/* [removed conflicting nth-child override] */
.gallery-page {
  background: linear-gradient(160deg,#F5E8C8 0%,#EDD8A8 100%) !important;
}
.resources-page {
  background: linear-gradient(160deg,#1A0608 0%,#200C10 50%,#1A0608 100%) !important;
}

/* -- Headings on amber: solid burgundy */
.about-section h2,.life-overview h2,.pillars-section h2,.swami-section h2,.gallery-strip h2,
.pillars-section .section-header h2,.life-overview .section-header h2,
.about-section .section-header h2,.gallery-strip .section-header h2,
.swami-section .section-header h2 {
  color: var(--burgundy) !important;
  -webkit-text-fill-color: var(--burgundy) !important;
  background: none !important;
  filter: none !important;
}
/* -- Cards on amber */
.pillar-card,.tl-content,.mission-card,.fact-box {
  background: linear-gradient(145deg,#FFFAF0 0%,#FFF5DC 100%) !important;
  border-color: rgba(201,152,42,.22) !important;
}
.source-item,.contact-form input,.contact-form textarea,.contact-form select {
  background: rgba(255,250,240,.88) !important;
}
/* -- Quote band text */
.quote-band blockquote > span[data-en],.quote-band blockquote {
  background: none !important;
  -webkit-text-fill-color: var(--burgundy) !important;
  color: var(--burgundy) !important;
}
/* -- Swami quote block */
.swami-section .swami-quote-block {
  background: linear-gradient(135deg,rgba(255,247,222,.98),rgba(253,240,200,.95)) !important;
  backdrop-filter: none !important; -webkit-backdrop-filter: none !important;
  border-left: 4px solid var(--saffron) !important; border-radius: 6px !important;
}
.swami-section .swami-quote-block p { color: var(--burgundy) !important; }
.swami-section .swami-quote-block cite { color: var(--mid-brown) !important; }
.swami-section p,.swami-text p { color: var(--text-dark) !important; }
/* -- Badges & tags */
.swami-year-badge,.ashram-tag {
  background: linear-gradient(145deg,#FFFAF0,#FFF5DC) !important;
  color: var(--mid-brown) !important; border-color: rgba(201,152,42,.28) !important;
}
/* -- Footer */
.footer-links a,.footer-ashrams a { color: rgba(255,255,255,.65) !important; }
/* -- Page-specific cosmic elements */
.page-shimmer-line {
  position: fixed; top: 0; bottom: 0; width: 1px;
  background: linear-gradient(to bottom,transparent 0%,rgba(201,152,42,.45) 40%,rgba(224,123,42,.3) 60%,transparent 100%);
  pointer-events: none; z-index: 0;
  animation: shimmerLine var(--dur,5s) ease-in-out var(--delay,0s) infinite;
}
@keyframes shimmerLine { 0%,100%{opacity:.1;transform:scaleY(.55)} 50%{opacity:.5;transform:scaleY(1)} }
.gallery-sparkle {
  position: fixed; border-radius: 50%; pointer-events: none; z-index: 0;
  background: radial-gradient(circle,rgba(201,152,42,.95) 0%,transparent 70%);
  animation: sparkleBurst var(--dur,3s) ease-out var(--delay,0s) infinite;
}
@keyframes sparkleBurst { 0%{transform:scale(0);opacity:0} 25%{opacity:1;transform:scale(1)} 100%{transform:scale(5);opacity:0} }
.about-pulse-ring {
  position: absolute; border-radius: 50%; left: 50%; top: 50%;
  transform: translate(-50%,-50%) scale(.3);
  animation: aboutPulse var(--dur,6s) ease-out var(--delay,0s) infinite;
}
@keyframes aboutPulse {
  0%  { transform: translate(-50%,-50%) scale(.25); opacity: .7; }
  100%{ transform: translate(-50%,-50%) scale(3.5); opacity: 0;  }
}
.resource-flow-char {
  position: fixed; pointer-events: none; z-index: 0;
  font-family: 'Noto Serif Devanagari',serif; color: rgba(201,152,42,.22);
  animation: cosmicFloat var(--dur,14s) linear var(--delay,0s) infinite;
}
.floating-quote-mark {
  position: fixed; pointer-events: none; z-index: 0;
  font-size: 8rem; line-height: 1; color: rgba(201,152,42,.07); font-family: Georgia,serif;
  animation: cosmicFloat var(--dur,18s) linear var(--delay,0s) infinite;
}

/* ══════════════════════════════════════════════════════════
   CONTENT SECTION DEPTH — Break the flat amber uniformity
══════════════════════════════════════════════════════════ */

/* Amber sections get a very subtle mandala watermark */
.pillars-section::after,
.life-overview::after,
.about-section::after,
.swami-section::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    radial-gradient(ellipse at 20% 30%, rgba(201,152,42,.07) 0%, transparent 45%),
    radial-gradient(ellipse at 80% 70%, rgba(224,123,42,.05) 0%, transparent 40%),
    radial-gradient(ellipse at 50% 50%, rgba(201,152,42,.04) 0%, transparent 60%);
}
.pillars-section > *, .life-overview > *, .about-section > *, .swami-section > * {
  position: relative; z-index: 1;
}

/* Cards: richer shadow + gold top border accent */
.pillar-card {
  border-top: 3px solid rgba(201,152,42,.55) !important;
  box-shadow: 0 4px 28px rgba(201,152,42,.13), 0 1px 4px rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.pillar-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 12px 40px rgba(201,152,42,.22), 0 4px 12px rgba(0,0,0,.08) !important;
}

/* Teaching/consciousness cards get dark-on-amber style */
.teaching-card, .concept-card, .source-card {
  background: linear-gradient(145deg, rgba(74,14,36,.88) 0%, rgba(42,10,20,.92) 100%) !important;
  border: 1px solid rgba(201,152,42,.35) !important;
  box-shadow: 0 6px 30px rgba(0,0,0,.25) !important;
}

/* Quote blocks on amber sections */
.quote-block, .teachings-quote, .consciousness-quote {
  background: linear-gradient(135deg,rgba(74,14,36,.06),rgba(201,152,42,.08)) !important;
  border-left: 3px solid rgba(201,152,42,.55) !important;
  border-radius: 4px !important;
}

/* Timeline items — warm dark card on amber */
.tl-content {
  border-top: 3px solid rgba(201,152,42,.55) !important;
  box-shadow: 0 4px 22px rgba(201,152,42,.10), 0 1px 4px rgba(0,0,0,.05) !important;
}
.tl-content h4 { color: var(--burgundy) !important; }

/* Section labels: gold on all sections */
.section-label {
  color: var(--gold) !important;
  letter-spacing: .18em !important;
  font-size: .8rem !important;
}

/* Section dividers between content blocks */
.consciousness-section + .consciousness-section,
.teachings-section + .teachings-section {
  border-top: 1px solid rgba(201,152,42,.18);
}

/* About page mission cards */
.mission-card {
  border-top: 3px solid rgba(201,152,42,.5) !important;
  box-shadow: 0 4px 24px rgba(201,152,42,.1), inset 0 1px 0 rgba(255,255,255,.85) !important;
}

/* Resources page: keep dark glass style cards on dark bg */
.resources-page .book-card,
.resources-section .book-card {
  background: linear-gradient(145deg,rgba(42,10,20,.9),rgba(28,8,16,.95)) !important;
  border: 1px solid rgba(201,152,42,.28) !important;
}

/* ══════════════════════════════════════════════════════════
   FINAL CONSISTENCY FIXES
══════════════════════════════════════════════════════════ */

/* Source items text on dark background */
.source-item h4 { color: var(--gold-light) !important; }
.source-item p  { color: rgba(255,255,255,.72) !important; }
.source-item .source-num { color: var(--gold) !important; opacity: .65; }

/* Swami grid responsive - prevent oversized placeholder gap */
.swami-img-wrap { max-height: 400px !important; }
.swami-photo-placeholder { max-height: 380px !important; aspect-ratio: 1 !important; }
@media (max-width: 900px) {
  .swami-grid { grid-template-columns: 1fr !important; }
  .swami-img-col { max-width: 340px !important; margin: 0 auto; }
}

/* Footer particle layer doesn't obscure footer text */
.site-footer > * { position: relative; z-index: 1; }
.footer-particle { z-index: 0 !important; }

/* Inner-page section backgrounds — use page's own inline style, not overrides */
/* Only set backgrounds for sections WITHOUT inline styles */
.consciousness-section:not([style]) {
  background: linear-gradient(160deg,#FDF2D8 0%,#F8EACC 100%);
}

/* What Maa Taught cards — keep their dark styling (section is dark maroon) */
/* The teaching cards use rgba(255,255,255,0.07) glass on dark bg — correct */

/* About page Sources section — dark background heading */
#sources .section-header h2 { color: var(--white) !important; -webkit-text-fill-color: var(--white) !important; background: none !important; }
#sources .section-label { color: var(--gold) !important; }
#sources .section-desc  { color: rgba(255,255,255,.62) !important; }

/* Contact section on about page */
#contact { background: linear-gradient(160deg,#FDF2D8 0%,#F8EACC 100%) !important; }

/* Gallery page amber sections */
.gallery-page:nth-child(even) {
  background: linear-gradient(160deg,#F0DFB4 0%,#E8D49C 100%) !important;
}

/* ── Swami Kedarnathji tagline behind logo ── */
.logo-wrap { flex-wrap: wrap; align-items: center; }
.logo-swami {
  display: none;
  width: 100%;
  font-size: .58rem;
  color: rgba(201,152,42,.75);
  letter-spacing: .06em;
  line-height: 1.3;
  margin-top: -.1rem;
  font-style: italic;
}
@media(min-width:1100px) { .logo-swami { display: block; } }

/* ── Consciousness intro section padding ── */
.consciousness-intro-section,
.research-pillars-section,
.eight-practices-section {
  padding: 6rem 0;
}

/* ══════════════════════════════════════════════════════════
   PROFESSIONAL HEADER OVERHAUL
══════════════════════════════════════════════════════════ */
#top-header {
  background: rgba(14,4,2,.97) !important;
  border-bottom: 1px solid rgba(201,152,42,.3) !important;
  box-shadow: 0 2px 24px rgba(0,0,0,.5) !important;
}
.header-inner {
  padding: .7rem 2.5rem !important;
  gap: 2rem !important;
  align-items: center !important;
}

/* Logo: dot + ISMAAC on same row, sub-lines below */
.logo-wrap {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  grid-template-rows: auto auto auto !important;
  column-gap: .55rem !important;
  align-items: start !important;
  flex-wrap: unset !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
}
.logo-dot {
  grid-column: 1 !important;
  grid-row: 1 / 4 !important;
  font-size: 2.2rem !important;
  align-self: center !important;
  line-height: 1 !important;
  margin-top: .1rem !important;
}
.logo-text {
  grid-column: 2 !important;
  grid-row: 1 !important;
  font-size: 1.45rem !important;
  letter-spacing: .08em !important;
  line-height: 1.1 !important;
}
.logo-sub {
  grid-column: 2 !important;
  grid-row: 2 !important;
  font-size: .6rem !important;
  color: rgba(253,245,224,.88) !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
  display: block !important;
  max-width: 240px !important;
  white-space: nowrap !important;
  margin-top: .1rem !important;
}
.logo-swami {
  grid-column: 2 !important;
  grid-row: 3 !important;
  font-size: .57rem !important;
  color: rgba(253,245,224,.88) !important;
  letter-spacing: .04em !important;
  font-style: italic !important;
  line-height: 1.2 !important;
  display: block !important;
  margin-top: .05rem !important;
}

/* Tighten nav links */
.nav-link {
  font-size: .82rem !important;
  padding: .42rem .75rem !important;
  letter-spacing: .02em !important;
}

/* ══════════════════════════════════════════════════════════
   HERO — PROFESSIONAL LAYOUT
══════════════════════════════════════════════════════════ */
.hero {
  padding: 7rem 4rem 5rem !important;
  gap: 4rem !important;
  align-items: center !important;
  max-width: 100vw !important;
}
.hero-content {
  padding-left: 0 !important;
  max-width: 52% !important;
}
.hero-title {
  font-size: clamp(3rem,5.5vw,5.2rem) !important;
  line-height: 1.05 !important;
}
.hero-image-col {
  width: min(480px,46vw) !important;
  flex-shrink: 0 !important;
}
.hero-img-frame {
  border-radius: 16px !important;
  border: 2px solid rgba(201,152,42,.5) !important;
  box-shadow: 0 0 60px rgba(201,152,42,.25), 0 20px 60px rgba(0,0,0,.6) !important;
  overflow: hidden !important;
}
.hero-img-frame img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center top !important;
  display: block !important;
  min-height: 520px !important;
  filter: sepia(8%) contrast(1.08) brightness(1.02) !important;
}

@media(max-width:900px) {
  .hero { padding: 7rem 2rem 4rem !important; gap: 2rem !important; flex-direction: column !important; }
  .hero-content { max-width: 100% !important; text-align: center !important; }
  .hero-image-col { width: min(360px,90vw) !important; }
  .logo-sub, .logo-swami { white-space: normal !important; max-width: 180px !important; }
}

/* ══════════════════════════════════════════════════════════
   MOBILE LOGO FIX — re-hide sub/swami texts on sidebar screens
   The "PROFESSIONAL HEADER OVERHAUL" block above forces
   display:block !important on both elements (no media guard).
   These rules come AFTER that block so they win the cascade.
   ══════════════════════════════════════════════════════════ */
@media(max-width:1400px) {
  /* Hide the two logo text lines — only hamburger trigger width is needed */
  .logo-sub  { display:none !important }
  .logo-swami{ display:none !important }
  /* Restore flex layout so the grid columns don't warp the header */
  .logo-wrap {
    display:flex !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    gap:.6rem !important;
  }
}

/* ══════════════════════════════════════════════════════════
   REVEAL FIX — ensure content always visible (file:// compat)
   Animations are progressive enhancement; content must show
══════════════════════════════════════════════════════════ */
.reveal,
.reveal-left,
.reveal-right,
.reveal-scale,
.fade-up {
  opacity: 1 !important;
  transform: none !important;
}

/* ══════════════════════════════════════════════════════════
   SOURCE-ITEM VISIBILITY FIX — dark bg + readable text
══════════════════════════════════════════════════════════ */
.source-item {
  background: linear-gradient(135deg,rgba(42,10,20,.95),rgba(28,8,16,.98)) !important;
  border-bottom: none !important;
  border: 1px solid rgba(201,152,42,.35) !important;
  border-left: 4px solid var(--gold) !important;
  border-radius: 10px !important;
  padding: 1.8rem 2rem !important;
  margin-bottom: 0 !important;
}
.source-item h4 {
  color: var(--gold-light) !important;
  font-size: 1.05rem !important;
  margin-bottom: .5rem !important;
}
.source-item p {
  color: rgba(253,245,224,.8) !important;
  font-size: .9rem !important;
  line-height: 1.65 !important;
}
.source-item .source-num {
  color: var(--gold) !important;
  opacity: .8 !important;
  font-size: 2rem !important;
}

/* ══ Consciousness teaser — responsive grid ══ */
@media(max-width:700px) {
  /* Diagram + cards: stack vertically */
  [style*="grid-template-columns:1fr 1fr"][style*="align-items:center"] {
    grid-template-columns: 1fr !important;
  }
}

/* ══════════════════════════════════════════════════════════
   GALLERY ROW — flex layout so images appear side by side
   ══════════════════════════════════════════════════════════ */
.gallery-row {
  display: flex !important;
  gap: 1.2rem !important;
  align-items: stretch !important;
}
.gallery-row .gp-thumb {
  flex: 1 1 0 !important;
  min-width: 0 !important;
}
@media(max-width: 640px) {
  .gallery-row {
    flex-direction: column !important;
  }
}

/* ══════════════════════════════════════════════════════════
   GAP FIX — remove excess space between swami & about
   ══════════════════════════════════════════════════════════ */
.swami-section {
  margin-bottom: 0 !important;
  padding-bottom: 4rem !important;
}
.about-section {
  margin-top: 0 !important;
  padding-top: 4rem !important;
  position: relative !important;
}
/* Ensure reveal-left/right children are always visible */
.about-section .reveal-left,
.about-section .reveal-right,
.about-section .reveal {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* ══════════════════════════════════════════════════════════
   ENERGY-ORB FIX — restore position:absolute so orbs don't
   push into normal flow and create a blank gap in sections
   (overrides the .swami-section > * { position:relative } rule)
   ══════════════════════════════════════════════════════════ */
.energy-orb {
  position: absolute !important;
}

/* ══ NAV: prevent link text wrapping at medium widths ══ */
.nav-link {
  white-space: nowrap !important;
}


/* ══════════════════════════════════════════════════════════
   GLOBAL READABILITY FIX
   Root cause: .section-desc forces dark brown (#5C3D25) via
   !important, overriding all inline white/cream text on dark
   sections. Low-opacity rgba(255,255,255,.45-.65) values also
   made text invisible. This block corrects all of it.
══════════════════════════════════════════════════════════ */

/* 1. Section descriptions — cream on dark headers, dark on light */
.section-header.light .section-desc,
.section-header.light p.section-desc {
  color: rgba(253,245,224,.92) !important;
}

/* 2. Inline section-desc overrides on dark HTML sections
      (removes !important lock from the earlier .section-desc rule) */
section[style*="#1C0810"] .section-desc,
section[style*="#0E0205"] .section-desc,
section[style*="var(--burgundy)"] .section-desc,
section[style*="rgba(14,3,5"] .section-desc,
section[style*="rgb(14,3,5"] .section-desc {
  color: rgba(253,245,224,.92) !important;
}
/* Light gradient sections keep dark readable text */
[style*="background:linear-gradient(160deg,#FDF2D8"] .section-desc,
[style*="background: linear-gradient(160deg,#FDF2D8"] .section-desc {
  color: #3a1f0e !important;
}

/* 3. Section label glow — make the gradient labels pop on dark bg */
.section-label {
  filter: drop-shadow(0 0 10px rgba(201,152,42,.85)) !important;
}

/* 4. Stats bar — label text */
.stat-label {
  color: rgba(255,255,255,.88) !important;
}

/* 5. Sadhya section subtitle & card text */
.sadhya-header .subtitle-en {
  color: rgba(255,255,255,.9) !important;
}
.sadhya-english,
.sadhya-trans {
  color: rgba(255,255,255,.88) !important;
}

/* 6. Swami placeholder card */
.swami-ph-sub  { color: rgba(255,255,255,.88) !important; }
.swami-ph-note { color: rgba(255,255,255,.75) !important; }

/* 7. Page hero description text */
.page-hero-content p {
  color: rgba(255,255,255,.92) !important;
}

/* 8. Resources page — book/video/podcast info text */
.resources-section .book-info .book-author,
.resources-page   .book-info .book-author,
.resources-section .book-author,
.resources-page   .book-author {
  color: rgba(255,255,255,.82) !important;
}
.resources-section .book-info .book-desc,
.resources-section .book-info p,
.resources-page   .book-info p,
.resources-page   .book-desc {
  color: rgba(255,255,255,.9) !important;
}

/* 9. Footer links */
.footer-links a,
.footer-ashrams a {
  color: rgba(255,255,255,.85) !important;
}
.footer-bottom p {
  color: rgba(255,255,255,.72) !important;
}

/* 10. Consciousness page pillar VISUAL CARD text (dark bg card only) */
.cs-visual-text {
  color: rgba(255,255,255,.88) !important;
}
/* cs-text p and cs-quote intentionally NOT overridden — they sit on
   light parchment sections and need dark body text (inherited from body) */

/* 11. Teachings page body text on dark sections */
.teachings-content p,
.pillar-body,
.practice-desc {
  color: rgba(253,245,224,.9) !important;
}

/* 12. Life page timeline & facts text */
.timeline-text,
.fact-desc,
.timeline-body {
  color: rgba(253,245,224,.9) !important;
}

/* 13. Any remaining inline rgba(.8) cream — bump to .92 */
/* Chat widget subtitle */
.chat-subtitle { color: rg
/* ══════════════════════════════════════════════════════════
   MOBILE TIMELINE FIX — life.html "From Kheora to Eternity"
   On phones the 82px date column + gap leaves ~250px for
   content which causes ugly narrow line breaks.
   Solution: stack date above card on screens < 640px.
   ══════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  /* Remove the vertical line positioned at left:82px */
  .life-timeline::before {
    display: none !important;
  }

  /* Stack each item vertically: year → card */
  .timeline-item {
    flex-direction: column !important;
    gap: 0.4rem !important;
    padding-left: 1rem !important;
    border-left: 3px solid var(--gold) !important;
    margin-left: 0.5rem !important;
    margin-bottom: 2rem !important;
  }

  /* Date shown as a small label above the card */
  .tl-year {
    width: auto !important;
    text-align: left !important;
    font-size: 0.82rem !important;
    padding-top: 0 !important;
    margin-bottom: 0.25rem !important;
    color: var(--gold) !important;
  }

  /* Hide the round dot — left border is the timeline indicator */
  .tl-dot {
    display: none !important;
  }

  /* Card takes full available width */
  .tl-content {
    width: 100% !important;
    padding: 1.1rem 1rem !important;
  }

  .tl-content h4 {
    font-size: 0.97rem !important;
    line-height: 1.45 !important;
  }

  .tl-content p {
    font-size: 0.9rem !important;
    line-height: 1.6 !important;
  }
}

/* ── Chatbot mic button — green circle ───────────────────────── */
#chatMic {
  width: 42px;
  height: 42px;
  min-width: 42px;
  border-radius: 50%;
  background: #3cb95e;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  box-shadow: 0 3px 10px rgba(60, 185, 94, 0.45);
  transition: transform 0.15s, box-shadow 0.15s, background 0.2s;
}
#chatMic:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 14px rgba(60, 185, 94, 0.6);
  background: #2ea84f;
}
#chatMic.recording {
  background: #e53e3e;
  box-shadow: 0 3px 10px rgba(229, 62, 62, 0.5);
  animation: mic-pulse 0.8s ease-in-out infinite;
}
@keyframes mic-pulse {
  0%, 100% { transform: scale(1);    opacity: 1;   }
  50%       { transform: scale(1.18); opacity: 0.75; }
}

#chatSpeak:hover {
  opacity: 1;
  transform: scale(1.15);
}

/* ══════════════════════════════════════════════════════════════
   AUTH + PAYMENT STYLES
   ══════════════════════════════════════════════════════════════ */

/* ── Register / Account button in header ──────────────────── */
.btn-auth {
  padding: .42rem .95rem;
  background: linear-gradient(135deg, #C9982A, #a07820);
  border: none;
  border-radius: 20px;
  color: #1a0a0f;
  font-family: var(--font-sans);
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .05em;
  transition: opacity .2s, transform .2s;
  white-space: nowrap;
  flex-shrink: 0;
}
.btn-auth:hover { opacity: .85; transform: translateY(-1px); }

/* When logged in — ghost gold style */
.btn-auth.auth-logged-in {
  background: rgba(201,152,42,.12);
  border: 1px solid rgba(201,152,42,.45);
  color: var(--gold);
  font-weight: 600;
}
.btn-auth.auth-logged-in:hover { background: rgba(201,152,42,.2); }

/* ── Book gate / buy buttons ──────────────────────────────── */
.book-gate-hidden { display: none !important; }

.btn-book-gate,
.btn-book-buy {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .48rem 1rem;
  border-radius: 20px;
  font-family: var(--font-sans);
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: .03em;
  transition: opacity .2s, transform .2s;
}
.btn-book-gate {
  background: rgba(201,152,42,.1);
  border: 1px solid rgba(201,152,42,.35);
  color: rgba(201,152,42,.9);
}
.btn-book-gate:hover { background: rgba(201,152,42,.2); transform: translateY(-1px); }

.btn-book-buy {
  background: linear-gradient(135deg, #C9982A, #a07820);
  border: none;
  color: #1a0a0f;
  font-weight: 700;
}
.btn-book-buy:hover { opacity: .85; transform: translateY(-1px); }

/* ── Bengali font body class ─────────────────────────────── */
body.lang-bn {
  font-family: 'Noto Sans Bengali', var(--font-sans);
}

/* ── Fade-up keyframe for toasts ─────────────────────────── */
@keyframes ismaacFadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.chat-msg-speak:hover {
  opacity: 1;
  transform: scale(1.2);
}

/* ═══════════════════════════════════════════════════════
   AUTH MODAL — glassmorphism redesign
   ═══════════════════════════════════════════════════════ */
@keyframes ismaacModalIn {
  from { opacity:0; transform:scale(.88) translateY(24px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
@keyframes ismaacOverlayIn {
  from { opacity:0; }
  to   { opacity:1; }
}
@keyframes borderGlow {
  0%,100% { box-shadow:0 0 24px rgba(201,152,42,.3),0 32px 80px rgba(0,0,0,.75); }
  50%      { box-shadow:0 0 44px rgba(201,152,42,.55),0 32px 80px rgba(0,0,0,.75); }
}
#ismaac-auth-modal {
  animation: ismaacOverlayIn .25s ease;
}
.auth-card {
  width: min(460px, 94vw);
  background: linear-gradient(145deg, rgba(22,7,12,.97) 0%, rgba(32,10,18,.97) 100%);
  border: 1px solid rgba(201,152,42,.38);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 0 32px rgba(201,152,42,.25), 0 40px 100px rgba(0,0,0,.8);
  animation: ismaacModalIn .35s cubic-bezier(0.34,1.56,0.64,1);
}
.auth-card-head {
  background: linear-gradient(90deg, rgba(201,152,42,.18) 0%, rgba(201,152,42,.06) 100%);
  padding: 1.4rem 1.6rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(201,152,42,.2);
  position: relative;
}
.auth-card-head::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,152,42,.6), transparent);
}
.auth-head-logo { display:flex; align-items:center; gap:.8rem; }
.auth-head-om {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 2rem; color: var(--gold);
  filter: drop-shadow(0 0 8px rgba(201,152,42,.6));
  animation: pulseGlow 2.5s ease-in-out infinite;
  line-height: 1;
}
.auth-head-title { font-family: var(--font-serif); color: var(--gold-light); font-size: 1.05rem; font-weight: 700; letter-spacing: .04em; }
.auth-head-sub   { font-size: .72rem; color: rgba(201,152,42,.65); letter-spacing: .06em; margin-top: .05rem; }
.auth-close-btn  {
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.7); font-size: 1.2rem;
  width: 34px; height: 34px; border-radius: 50%;
  cursor: pointer; display: flex; align-items:center; justify-content:center;
  transition: .2s; flex-shrink: 0;
}
.auth-close-btn:hover { background: rgba(201,152,42,.25); color: var(--gold-light); border-color: rgba(201,152,42,.4); }
.auth-tabs {
  display: flex;
  border-bottom: 1px solid rgba(201,152,42,.15);
}
.auth-tab-btn {
  flex: 1; padding: .9rem; background: transparent; border: none;
  color: rgba(255,255,255,.45); font-family: var(--font-sans); font-size: .9rem;
  cursor: pointer; letter-spacing: .04em; position: relative; transition: color .2s;
}
.auth-tab-btn::after {
  content: ''; position: absolute; bottom: 0; left: 15%; right: 15%; height: 2px;
  background: var(--gold); transform: scaleX(0); transition: transform .25s ease;
  border-radius: 2px;
}
.auth-tab-btn.active { color: var(--gold-light); background: rgba(201,152,42,.08); }
.auth-tab-btn.active::after { transform: scaleX(1); }
.auth-body { padding: 1.8rem 1.6rem; }
.auth-input-wrap { position: relative; margin-bottom: 1rem; }
.auth-input-icon {
  position: absolute; left: .9rem; top: 50%; transform: translateY(-50%);
  color: rgba(201,152,42,.5); font-size: .95rem; pointer-events: none;
}
.auth-input {
  width: 100%; padding: .78rem 1rem .78rem 2.4rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(201,152,42,.2);
  border-radius: 10px; color: #FDF5E0;
  font-family: var(--font-sans); font-size: .9rem;
  box-sizing: b