/* ===== DESIGN SYSTEM — Bhakti Purusottama Swami Maharaja ===== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Inter:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── Tokens ── */
:root{
  --saffron:#FF6F00;--saffron-light:#FF9800;--saffron-dark:#E65100;
  --maroon:#5B0E2D;--maroon-deep:#3D0A1E;--maroon-light:#7B1F3F;
  --gold:#D4AF37;--gold-light:#F0D060;--gold-dark:#B8960C;
  --cream:#FFF8E7;--cream-dark:#F5E6C8;
  --charcoal:#1A1A2E;--charcoal-light:#2D2D44;--charcoal-mid:#16213E;
  --dark:#0F0F1A;--white:#FFFFFF;--off-white:#FAFAF5;
  --terracotta:#C75B39;--forest:#2D5016;--teal:#1A6B5A;
  --glass-bg:rgba(255,255,255,.08);--glass-border:rgba(255,255,255,.15);
  --glass-bg-light:rgba(255,248,231,.85);--glass-border-light:rgba(212,175,55,.3);
  --shadow-sm:0 2px 8px rgba(0,0,0,.12);--shadow-md:0 8px 32px rgba(0,0,0,.18);
  --shadow-lg:0 16px 64px rgba(0,0,0,.25);--shadow-glow:0 0 40px rgba(255,111,0,.25);
  --radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-xl:40px;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-accent:'Cormorant Garamond',Georgia,serif;
  --font-mono:'JetBrains Mono',monospace;
  --ease-out-expo:cubic-bezier(.16,1,.3,1);
  --ease-out-back:cubic-bezier(.34,1.56,.64,1);
  --transition-fast:.2s var(--ease-out-expo);
  --transition-med:.4s var(--ease-out-expo);
  --transition-slow:.7s var(--ease-out-expo);
  --nav-h:80px;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:var(--font-body);background:var(--dark);color:var(--cream);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,video,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;border:none;outline:none;background:none;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--saffron);color:var(--white)}

/* ── Skip Nav ── */
.skip-nav{position:absolute;top:-100%;left:16px;background:var(--saffron);color:#fff;padding:12px 24px;border-radius:0 0 var(--radius-sm) var(--radius-sm);z-index:10000;font-weight:600;transition:top .3s}
.skip-nav:focus{top:0}

/* ── Accessibility ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
*:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* ── Scroll Progress ── */
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--saffron),var(--gold),var(--saffron));z-index:10001;transform-origin:left;transform:scaleX(0);transition:none;pointer-events:none}

/* ── Custom Cursor ── */
.cursor-dot{width:8px;height:8px;background:var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:99999;transition:transform .15s,opacity .15s;mix-blend-mode:difference}
.cursor-ring{width:40px;height:40px;border:2px solid rgba(212,175,55,.5);border-radius:50%;position:fixed;pointer-events:none;z-index:99998;transition:transform .3s var(--ease-out-expo),width .3s,height .3s;transform:translate(-50%,-50%)}
.cursor-ring.hover{width:60px;height:60px;border-color:var(--saffron)}
@media(max-width:1024px){.cursor-dot,.cursor-ring{display:none}}

/* ── Film Grain Overlay ── */
.grain-overlay{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Animated Blobs ── */
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;pointer-events:none;animation:blobFloat 20s ease-in-out infinite}
.blob-1{width:500px;height:500px;background:var(--saffron);top:-100px;right:-100px;animation-delay:0s}
.blob-2{width:400px;height:400px;background:var(--maroon);bottom:-100px;left:-100px;animation-delay:-7s}
.blob-3{width:350px;height:350px;background:var(--gold);top:50%;left:50%;animation-delay:-14s}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-50px) scale(1.1)}50%{transform:translate(-20px,40px) scale(.9)}75%{transform:translate(50px,20px) scale(1.05)}}

/* ── Navigation ── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:9000;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,60px);transition:all var(--transition-med)}
.nav::before{content:'';position:absolute;inset:0;background:rgba(15,15,26,.6);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);opacity:0;transition:opacity var(--transition-med)}
.nav.scrolled::before{opacity:1}
.nav.scrolled{height:64px}
.nav-logo{position:relative;z-index:2;display:flex;align-items:center;gap:12px}
.nav-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--saffron),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--white);font-family:var(--font-display)}
.nav-logo-text{font-family:var(--font-display);font-size:clamp(16px,1.8vw,22px);font-weight:700;color:var(--cream);letter-spacing:.5px}
.nav-logo-text span{color:var(--gold)}
.nav-links{display:flex;gap:clamp(16px,2.5vw,36px);position:relative;z-index:2}
.nav-links a{font-size:14px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:rgba(255,248,231,.7);transition:color var(--transition-fast);position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--gold);transition:width var(--transition-med)}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;position:relative;z-index:2;width:28px;padding:4px 0}
.nav-toggle span{display:block;height:2px;background:var(--cream);border-radius:2px;transition:all var(--transition-fast)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){
  .nav-links{position:fixed;inset:0;background:rgba(15,15,26,.97);backdrop-filter:blur(30px);flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;visibility:hidden;transition:all var(--transition-med)}
  .nav-links.open{opacity:1;visibility:visible}
  .nav-links a{font-size:18px;letter-spacing:3px}
  .nav-toggle{display:flex}
}

/* ── Hero ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,15,26,.85),rgba(91,14,45,.6),rgba(15,15,26,.7))}
.hero-content{position:relative;z-index:2;max-width:900px;padding:calc(var(--nav-h) + 40px) clamp(20px,6vw,80px) 80px}
.hero-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:24px;opacity:0;animation:fadeInUp .8s var(--ease-out-expo) .3s forwards}
.hero-label::before{content:'';width:32px;height:1px;background:var(--gold)}
.hero-title{font-family:var(--font-display);font-size:clamp(36px,7vw,88px);font-weight:900;line-height:1.05;margin-bottom:24px;opacity:0;animation:fadeInUp .8s var(--ease-out-expo) .5s forwards}
.hero-title .gradient-text{background:linear-gradient(135deg,var(--saffron),var(--gold-light),var(--saffron-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-family:var(--font-accent);font-size:clamp(18px,2.5vw,28px);font-weight:400;color:rgba(255,248,231,.8);margin-bottom:40px;max-width:600px;opacity:0;animation:fadeInUp .8s var(--ease-out-expo) .7s forwards;font-style:italic}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeInUp .8s var(--ease-out-expo) .9s forwards}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);animation:float 3s ease-in-out infinite}
.hero-scroll span{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent)}
@keyframes float{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-10px)}}

/* ── Split Hero ── */
.hero-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;overflow:hidden}
.hero-split .hero-text{display:flex;flex-direction:column;justify-content:center;padding:calc(var(--nav-h) + 40px) clamp(24px,5vw,80px) 60px}
.hero-split .hero-image{position:relative;overflow:hidden}
.hero-split .hero-image img{width:100%;height:100%;object-fit:cover}
.hero-split .hero-image::before{content:'';position:absolute;inset:0;background:linear-gradient(270deg,transparent 60%,var(--dark));z-index:1}
@media(max-width:900px){.hero-split{grid-template-columns:1fr}.hero-split .hero-image{height:50vh}}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:var(--radius-xl);font-weight:600;font-size:14px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all var(--transition-med);position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity var(--transition-fast)}
.btn-primary{background:linear-gradient(135deg,var(--saffron),var(--saffron-dark));color:var(--white);box-shadow:0 4px 24px rgba(255,111,0,.3)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 40px rgba(255,111,0,.45)}
.btn-secondary{background:transparent;border:1.5px solid var(--gold);color:var(--gold)}
.btn-secondary:hover{background:var(--gold);color:var(--dark);transform:translateY(-3px)}
.btn .btn-arrow{transition:transform var(--transition-fast)}.btn:hover .btn-arrow{transform:translateX(4px)}

/* ── Ripple Effect ── */
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.3);transform:scale(0);animation:rippleAnim .6s linear;pointer-events:none}
@keyframes rippleAnim{to{transform:scale(4);opacity:0}}

/* ── Section Styles ── */
.section{padding:clamp(60px,10vw,140px) clamp(20px,6vw,80px);position:relative}
.section-dark{background:var(--dark)}
.section-charcoal{background:var(--charcoal)}
.section-gradient{background:linear-gradient(135deg,var(--charcoal),var(--charcoal-mid))}
.section-saffron{background:linear-gradient(135deg,var(--saffron-dark),var(--saffron),var(--gold))}
.section-maroon{background:linear-gradient(135deg,var(--maroon-deep),var(--maroon))}
.section-cream{background:var(--cream);color:var(--charcoal)}

/* Diagonal / Angled */
.section-angled{clip-path:polygon(0 5%,100% 0,100% 95%,0 100%);padding-top:clamp(100px,14vw,200px);padding-bottom:clamp(100px,14vw,200px)}

.container{max-width:1320px;margin:0 auto;width:100%}
.section-header{text-align:center;margin-bottom:clamp(40px,6vw,80px)}
.section-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.section-label::before,.section-label::after{content:'';width:20px;height:1px;background:var(--gold)}
.section-title{font-family:var(--font-display);font-size:clamp(28px,5vw,56px);font-weight:900;line-height:1.15;margin-bottom:16px}
.section-subtitle{font-family:var(--font-accent);font-size:clamp(16px,2vw,22px);color:rgba(255,248,231,.65);max-width:700px;margin:0 auto;font-style:italic}

/* ── Bento Grid ── */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bento-grid .card:nth-child(1){grid-column:span 2}
.bento-grid .card:nth-child(4){grid-column:span 2}
@media(max-width:900px){.bento-grid{grid-template-columns:1fr}.bento-grid .card:nth-child(1),.bento-grid .card:nth-child(4){grid-column:span 1}}

/* ── Cards ── */
.card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:clamp(24px,3vw,40px);transition:all var(--transition-med);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,111,0,.05),transparent);opacity:0;transition:opacity var(--transition-med)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(212,175,55,.3)}
.card:hover::before{opacity:1}
.card-icon{width:56px;height:56px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--saffron),var(--gold));display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:20px}
.card-title{font-family:var(--font-display);font-size:clamp(18px,2vw,24px);font-weight:700;margin-bottom:12px}
.card-text{color:rgba(255,248,231,.65);font-size:15px;line-height:1.8}

/* Glassmorphism Card */
.glass-card{background:rgba(255,255,255,.06);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:clamp(24px,3vw,40px)}

/* ── Stats Counter ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat-item .stat-number{font-family:var(--font-display);font-size:clamp(36px,5vw,64px);font-weight:900;color:var(--white);line-height:1}
.stat-item .stat-label{font-size:14px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:8px}
@media(max-width:768px){.stats{grid-template-columns:repeat(2,1fr);gap:24px}}

/* ── Timeline ── */
.timeline{position:relative;padding-left:40px}
.timeline::before{content:'';position:absolute;left:16px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--saffron),var(--gold),var(--maroon))}
.timeline-item{position:relative;padding:0 0 60px 40px}
.timeline-item::before{content:'';position:absolute;left:-32px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--gold);border:3px solid var(--dark);z-index:1;box-shadow:0 0 20px rgba(212,175,55,.4)}
.timeline-date{font-family:var(--font-mono);font-size:13px;letter-spacing:2px;color:var(--saffron);margin-bottom:8px}
.timeline-title{font-family:var(--font-display);font-size:clamp(18px,2.5vw,28px);font-weight:700;margin-bottom:12px}
.timeline-text{color:rgba(255,248,231,.65);line-height:1.8;font-size:15px}

/* ── Testimonials ── */
.testimonial{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:clamp(28px,4vw,48px);position:relative}
.testimonial::before{content:'\201C';position:absolute;top:16px;left:24px;font-size:80px;font-family:var(--font-display);color:var(--gold);opacity:.2;line-height:1}
.testimonial-text{font-family:var(--font-accent);font-size:clamp(16px,2vw,22px);font-style:italic;line-height:1.8;margin-bottom:20px;color:var(--cream)}
.testimonial-author{display:flex;align-items:center;gap:16px}
.testimonial-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px}
.testimonial-name{font-weight:600;font-size:15px}.testimonial-role{font-size:13px;color:rgba(255,248,231,.5)}

/* ── Gallery ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.gallery-item{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/3;cursor:pointer;group:true}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out-expo),filter .4s}
.gallery-item:hover img{transform:scale(1.08);filter:brightness(1.1)}
.gallery-item .gallery-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,15,26,.8) 0%,transparent 60%);opacity:0;transition:opacity var(--transition-med);display:flex;align-items:flex-end;padding:20px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-caption{font-family:var(--font-accent);font-size:16px;color:var(--cream)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:10000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-med)}
.lightbox.active{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;color:var(--cream);transition:all var(--transition-fast)}
.lightbox-close:hover{background:var(--saffron);transform:rotate(90deg)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--cream);transition:all var(--transition-fast)}
.lightbox-nav:hover{background:var(--saffron)}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}

/* ── FAQ Accordion ── */
.faq-item{border-bottom:1px solid var(--glass-border);overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:24px 0;cursor:pointer;font-family:var(--font-display);font-size:clamp(16px,2vw,20px);font-weight:600;transition:color var(--transition-fast)}
.faq-question:hover{color:var(--gold)}
.faq-icon{width:24px;height:24px;position:relative;flex-shrink:0}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:var(--gold);transition:transform var(--transition-med)}
.faq-icon::before{width:2px;height:16px;top:4px;left:11px}
.faq-icon::after{width:16px;height:2px;top:11px;left:4px}
.faq-item.open .faq-icon::before{transform:rotate(90deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .5s var(--ease-out-expo)}
.faq-answer-inner{padding:0 0 24px;color:rgba(255,248,231,.65);line-height:1.8;font-size:15px}

/* ── Forms ── */
.form-group{margin-bottom:24px;position:relative}
.form-label{display:block;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:600}
.form-input,.form-textarea{width:100%;padding:16px 20px;background:rgba(255,255,255,.06);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--cream);font-size:16px;transition:all var(--transition-fast)}
.form-input:focus,.form-textarea:focus{border-color:var(--gold);background:rgba(255,255,255,.1);box-shadow:0 0 20px rgba(212,175,55,.15)}
.form-textarea{min-height:150px;resize:vertical}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(255,248,231,.3)}
.form-error{font-size:12px;color:#FF5252;margin-top:4px;display:none}
.form-group.error .form-input,.form-group.error .form-textarea{border-color:#FF5252}
.form-group.error .form-error{display:block}

/* ── Two Column ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}
.two-col-image{position:relative;border-radius:var(--radius-lg);overflow:hidden}
.two-col-image img{width:100%;height:auto;border-radius:var(--radius-lg)}
.two-col-image::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);box-shadow:inset 0 0 0 1px rgba(212,175,55,.2)}

/* ── Marquee ── */
.marquee{overflow:hidden;white-space:nowrap;padding:24px 0;border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border)}
.marquee-inner{display:inline-flex;gap:60px;animation:marquee 30s linear infinite}
.marquee-item{font-family:var(--font-accent);font-size:clamp(18px,2.5vw,28px);font-style:italic;color:rgba(255,248,231,.4)}
.marquee-dot{color:var(--gold)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Book Cards ── */
.book-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-med)}
.book-card:hover{transform:translateY(-8px) rotateY(-2deg);box-shadow:var(--shadow-lg)}
.book-cover{aspect-ratio:2/3;background:linear-gradient(135deg,var(--maroon),var(--saffron-dark));display:flex;align-items:center;justify-content:center;padding:20px;text-align:center}
.book-cover-title{font-family:var(--font-display);font-size:clamp(16px,2vw,22px);font-weight:700;color:var(--gold-light)}
.book-info{padding:20px}
.book-title{font-family:var(--font-display);font-size:16px;font-weight:700;margin-bottom:8px}
.book-desc{font-size:13px;color:rgba(255,248,231,.6);line-height:1.6}

/* ── Process Steps ── */
.process{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px;counter-reset:step}
.process-step{position:relative;padding:32px;text-align:center;counter-increment:step}
.process-step::before{content:counter(step);font-family:var(--font-display);font-size:48px;font-weight:900;color:var(--saffron);opacity:.2;display:block;margin-bottom:16px}
.process-step-title{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:12px}
.process-step-text{font-size:14px;color:rgba(255,248,231,.6);line-height:1.7}

/* ── Newsletter ── */
.newsletter{background:var(--glass-bg);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:clamp(32px,5vw,60px);text-align:center}
.newsletter-form{display:flex;gap:12px;max-width:500px;margin:24px auto 0}
.newsletter-input{flex:1;padding:14px 20px;background:rgba(255,255,255,.08);border:1px solid var(--glass-border);border-radius:var(--radius-xl);color:var(--cream);font-size:15px}
.newsletter-input:focus{border-color:var(--gold)}
@media(max-width:600px){.newsletter-form{flex-direction:column}}

/* ── CTA Banner ── */
.cta-banner{position:relative;padding:clamp(60px,8vw,120px) clamp(20px,5vw,60px);text-align:center;background:linear-gradient(135deg,var(--saffron-dark),var(--saffron),var(--gold));border-radius:var(--radius-lg);overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.cta-title{font-family:var(--font-display);font-size:clamp(28px,4vw,48px);font-weight:900;color:var(--white);margin-bottom:16px;position:relative}
.cta-text{font-size:clamp(16px,1.8vw,20px);color:rgba(255,255,255,.85);margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto;position:relative}

/* ── Footer ── */
.footer{background:var(--dark);border-top:1px solid var(--glass-border);position:relative;overflow:hidden}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,4vw,60px);padding:clamp(48px,7vw,100px) clamp(20px,6vw,80px)}
.footer-brand{max-width:320px}
.footer-brand-name{font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:16px;color:var(--gold)}
.footer-brand-desc{font-size:14px;color:rgba(255,248,231,.5);line-height:1.8;margin-bottom:24px}
.footer-heading{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--cream);margin-bottom:20px;letter-spacing:1px}
.footer-links a{display:block;font-size:14px;color:rgba(255,248,231,.5);padding:6px 0;transition:color var(--transition-fast)}
.footer-links a:hover{color:var(--gold);padding-left:8px}
.footer-contact-item{display:flex;gap:12px;font-size:14px;color:rgba(255,248,231,.5);margin-bottom:12px;align-items:flex-start}
.footer-contact-icon{color:var(--gold);font-size:16px;flex-shrink:0;margin-top:2px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px clamp(20px,6vw,80px);border-top:1px solid var(--glass-border);flex-wrap:wrap;gap:16px}
.footer-credit{font-size:13px;color:rgba(255,248,231,.4)}
.footer-credit a{color:var(--gold);transition:color var(--transition-fast)}
.footer-credit a:hover{color:var(--saffron)}
.back-to-top{position:fixed;bottom:32px;right:32px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--gold));color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:8000;opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-med);font-size:20px;box-shadow:0 4px 20px rgba(255,111,0,.3)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(255,111,0,.5)}
@media(max-width:900px){.footer-main{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:span 2}}
@media(max-width:600px){.footer-main{grid-template-columns:1fr}.footer-brand{grid-column:span 1}.footer-bottom{flex-direction:column;text-align:center}}

/* ── Gallery Filters ── */
.gallery-filters{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.gallery-filter{padding:10px 24px;border-radius:var(--radius-xl);font-size:13px;letter-spacing:1px;text-transform:uppercase;font-weight:600;cursor:pointer;transition:all var(--transition-fast);background:rgba(255,255,255,.06);border:1px solid var(--glass-border);color:rgba(255,248,231,.6)}
.gallery-filter.active,.gallery-filter:hover{background:var(--saffron);border-color:var(--saffron);color:var(--white)}

/* ── Animation Utilities ── */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.fade-in-right.visible{opacity:1;transform:translateX(0)}
.scale-in{opacity:0;transform:scale(.9);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.scale-in.visible{opacity:1;transform:scale(1)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Typewriter ── */
.typewriter{overflow:hidden;border-right:2px solid var(--gold);white-space:nowrap;animation:typewriterBlink .8s step-end infinite}
@keyframes typewriterBlink{50%{border-color:transparent}}

/* ── Parallax ── */
.parallax{position:relative;overflow:hidden}
.parallax-bg{position:absolute;inset:-20%;will-change:transform}
.parallax-bg img{width:100%;height:100%;object-fit:cover}

/* ── 3D Tilt ── */
.tilt-card{transform-style:preserve-3d;transition:transform .15s ease}
.tilt-card .tilt-inner{transform:translateZ(30px)}

/* ── Image Treatment ── */
.img-duotone{filter:grayscale(30%) sepia(20%) contrast(1.1)}
.img-shadow{box-shadow:var(--shadow-lg);border-radius:var(--radius-lg)}
.img-border{border:2px solid var(--glass-border);border-radius:var(--radius-lg)}

/* ── Gate Page ── */
.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--dark);position:relative;overflow:hidden}
.gate-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--dark),var(--maroon-deep),var(--charcoal));animation:gateGradient 10s ease-in-out infinite}
@keyframes gateGradient{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.gate-card{position:relative;z-index:2;background:var(--glass-bg);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:clamp(32px,5vw,60px);text-align:center;max-width:440px;width:90%}
.gate-icon{width:80px;height:80px;margin:0 auto 24px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--gold));display:flex;align-items:center;justify-content:center;font-size:36px;animation:pulse 2s ease-in-out infinite}
.gate-title{font-family:var(--font-display);font-size:clamp(24px,3vw,32px);font-weight:700;margin-bottom:8px;color:var(--gold)}
.gate-subtitle{font-size:14px;color:rgba(255,248,231,.5);margin-bottom:32px}
.gate-input{width:100%;padding:18px 24px;background:rgba(255,255,255,.06);border:2px solid var(--glass-border);border-radius:var(--radius-md);color:var(--cream);font-size:20px;text-align:center;letter-spacing:8px;font-family:var(--font-mono);transition:all var(--transition-fast);margin-bottom:20px}
.gate-input:focus{border-color:var(--gold);box-shadow:0 0 30px rgba(212,175,55,.2)}
.gate-input.error{border-color:#FF5252;animation:shake .5s}
.gate-input.success{border-color:#4CAF50;box-shadow:0 0 30px rgba(76,175,80,.3)}
.gate-error{font-size:13px;color:#FF5252;margin-top:-12px;margin-bottom:16px;min-height:20px}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}

/* Floating Particles */
.particle{position:absolute;border-radius:50%;background:var(--gold);opacity:.15;pointer-events:none;animation:particleFloat linear infinite}
@keyframes particleFloat{0%{transform:translateY(100vh) rotate(0deg);opacity:0}10%{opacity:.15}90%{opacity:.15}100%{transform:translateY(-100px) rotate(720deg);opacity:0}}

/* ── Map ── */
.map-container{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-border);height:400px}
.map-container iframe{width:100%;height:100%;border:none;filter:invert(.9) hue-rotate(180deg) saturate(.5) brightness(.8)}

/* ── Tabs ── */
.tabs{display:flex;gap:4px;background:rgba(255,255,255,.04);border-radius:var(--radius-xl);padding:4px;margin-bottom:32px;overflow-x:auto}
.tab{padding:12px 24px;border-radius:var(--radius-xl);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;color:rgba(255,248,231,.5)}
.tab.active{background:var(--saffron);color:var(--white)}
.tab:hover:not(.active){color:var(--cream);background:rgba(255,255,255,.06)}
.tab-content{display:none}.tab-content.active{display:block;animation:fadeIn .5s}

/* ── Video Embed ── */
.video-container{position:relative;padding-bottom:56.25%;height:0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}

/* ── Social Links ── */
.social-links{display:flex;gap:12px}
.social-link{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);font-size:16px}
.social-link:hover{background:var(--saffron);border-color:var(--saffron);transform:translateY(-3px)}

/* ── Donation Widget ── */
.donate-card{background:linear-gradient(135deg,var(--saffron-dark),var(--saffron));border-radius:var(--radius-lg);padding:clamp(24px,3vw,40px);text-align:center;color:var(--white)}
.donate-card .btn{background:var(--white);color:var(--saffron-dark);margin-top:20px}
.donate-card .btn:hover{background:var(--gold);color:var(--dark)}

/* ── Loading ── */
.loader{position:fixed;inset:0;background:var(--dark);z-index:99999;display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
.loader.hidden{opacity:0;visibility:hidden}
.loader-spinner{width:48px;height:48px;border:3px solid var(--glass-border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}

/* ── Misc Utilities ── */
.text-gold{color:var(--gold)}.text-saffron{color:var(--saffron)}.text-cream{color:var(--cream)}
.text-center{text-align:center}.text-left{text-align:left}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mt-5{margin-top:48px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.mb-5{margin-bottom:48px}
.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}.gap-4{gap:32px}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.w-full{width:100%}.mx-auto{margin-left:auto;margin-right:auto}
.relative{position:relative}.overflow-hidden{overflow:hidden}
.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}
