/* === YAGYASEVA DESIGN SYSTEM === */
@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=Cinzel:wght@400;600;700&family=Hind:wght@300;400;500;600&display=swap');

:root {
  --saffron:#E8650A; --deep-saffron:#C4520A; --gold:#D4A017; --gold-light:#F5D06A;
  --maroon:#7C1F1F; --deep-maroon:#4A0F0F; --cream:#FDF6E3; --cream2:#FBF0D0;
  --warm-white:#FFFBF2; --text-dark:#2A1407; --text-mid:#5C3012; --text-light:#8B6040;
  --border:#E8C98A; --border-light:#F3DFA8; --shadow:rgba(90,30,5,0.12);
  --shadow-gold:rgba(212,160,23,0.25);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hind',sans-serif;background:var(--warm-white);color:var(--text-dark);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none}

/* TOPBAR */
.topbar{background:var(--deep-maroon);color:var(--gold-light);text-align:center;font-size:13px;padding:7px 16px;letter-spacing:.5px}
.topbar a{color:var(--gold-light)}

/* NAV */
nav{background:var(--cream);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:1000;box-shadow:0 2px 16px var(--shadow)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:68px;gap:20px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--saffron),var(--maroon));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 2px 10px var(--shadow-gold)}
.logo-img{width:48px;height:48px;border-radius:50%;object-fit:contain;flex-shrink:0;background:#fff;padding:2px;box-shadow:0 2px 12px rgba(212,160,23,.35);border:2px solid rgba(212,160,23,.3);transition:transform .2s}
.logo:hover .logo-img{transform:rotate(-5deg) scale(1.06)}
@media(max-width:768px){.logo-img{width:40px;height:40px}}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-text .main{font-family:'Cinzel Decorative',serif;font-size:18px;color:var(--saffron);font-weight:700}
.logo-text .sub{font-size:11px;color:var(--text-light);letter-spacing:2px;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--text-mid);padding:8px 13px;border-radius:6px;transition:all .2s;display:flex;align-items:center;gap:5px}
.nav-links a:hover,.nav-links a.active{background:var(--cream2);color:var(--saffron)}
.nav-actions{display:flex;gap:10px;align-items:center}
.btn-outline{font-size:13px;font-weight:600;color:var(--saffron);border:1.5px solid var(--saffron);background:transparent;padding:7px 18px;border-radius:6px;cursor:pointer;transition:all .2s}
.btn-outline:hover{background:var(--saffron);color:#fff}
.btn-primary{font-size:13px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));border:none;padding:8px 20px;border-radius:6px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(232,101,10,.3)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(232,101,10,.4)}
.hamburger{display:none;font-size:24px;cursor:pointer;background:none;border:none;color:var(--text-mid);padding:4px}

/* MOBILE NAV */
.mobile-menu{display:none;position:absolute;top:68px;left:0;right:0;background:var(--cream);border-top:1px solid var(--border);border-bottom:2px solid var(--border);padding:16px 24px;z-index:999;flex-direction:column;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--text-mid);padding:10px 12px;border-radius:8px;border-bottom:1px solid var(--border-light)}
.mobile-menu a:hover{color:var(--saffron);background:var(--cream2)}
.mobile-actions{display:flex;gap:10px;margin-top:12px}

/* PAGE HERO BANNER */
.page-hero{background:linear-gradient(160deg,var(--deep-maroon) 0%,#6B1515 50%,#3D0D0D 100%);padding:52px 24px 56px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;opacity:.06;background-image:repeating-linear-gradient(45deg,var(--gold) 0,var(--gold) 1px,transparent 0,transparent 50%),repeating-linear-gradient(-45deg,var(--gold) 0,var(--gold) 1px,transparent 0,transparent 50%);background-size:30px 30px}
.page-hero-inner{position:relative;z-index:1;max-width:1280px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:14px}
.breadcrumb a{color:var(--gold-light)}
.breadcrumb span{color:rgba(255,255,255,.4)}
.page-hero h1{font-family:'Cinzel',serif;font-size:clamp(26px,4vw,46px);font-weight:700;color:#fff;margin-bottom:10px;line-height:1.2}
.page-hero h1 .accent{color:var(--gold-light)}
.page-hero p{font-size:16px;color:rgba(255,255,255,.75);max-width:580px;line-height:1.7}
.page-hero-meta{display:flex;gap:24px;margin-top:20px;flex-wrap:wrap}
.hero-meta-chip{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:6px 14px;border-radius:100px;font-size:13px;color:rgba(255,255,255,.9)}

/* SECTIONS */
.section{padding:64px 24px}
.section-alt{background:var(--cream2)}
.section-inner{max-width:1280px;margin:0 auto}
.section-header{text-align:center;margin-bottom:44px}
.section-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--saffron);margin-bottom:10px}
.section-title{font-family:'Cinzel',serif;font-size:clamp(20px,3vw,32px);font-weight:700;color:var(--text-dark);line-height:1.3;margin-bottom:12px}
.section-title .hl{color:var(--saffron)}
.section-desc{font-size:15px;color:var(--text-light);max-width:540px;margin:0 auto;line-height:1.7}
.divider{width:56px;height:3px;background:linear-gradient(90deg,var(--saffron),var(--gold));margin:14px auto 0;border-radius:2px}
.section-header-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.view-all{font-size:13px;font-weight:600;color:var(--saffron);display:flex;align-items:center;gap:4px;transition:gap .2s;white-space:nowrap}
.view-all:hover{gap:8px}

/* POOJA CARDS */
.pooja-card{background:#fff;border:1px solid var(--border-light);border-radius:18px;overflow:hidden;transition:all .3s;box-shadow:0 2px 12px var(--shadow);cursor:pointer}
.pooja-card:hover{transform:translateY(-7px);box-shadow:0 18px 44px var(--shadow);border-color:var(--gold)}
.pooja-img{width:100%;height:180px;display:flex;align-items:center;justify-content:center;font-size:64px;position:relative}
.badge-tag{position:absolute;top:12px;left:12px;background:var(--maroon);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px;letter-spacing:.5px;font-family:'Hind',sans-serif}
.badge-tag.gold{background:linear-gradient(135deg,var(--gold),#C48A10);color:var(--deep-maroon)}
.badge-tag.green{background:#2E7D32}
.pooja-body{padding:16px 18px 18px}
.pooja-name{font-family:'Cinzel',serif;font-size:15px;font-weight:600;color:var(--text-dark);margin-bottom:5px;line-height:1.3}
.pooja-meta{display:flex;gap:12px;margin-bottom:8px}
.meta-chip{font-size:11px;color:var(--text-light);display:flex;align-items:center;gap:4px}
.pooja-desc{font-size:12.5px;color:var(--text-light);line-height:1.6;margin-bottom:14px}
.pooja-footer{display:flex;justify-content:space-between;align-items:center}
.pooja-price{font-family:'Cinzel',serif;font-size:17px;font-weight:700;color:var(--saffron)}
.pooja-price small{font-size:10px;font-family:'Hind',sans-serif;color:var(--text-light);display:block;font-weight:400}
.pooja-rating{font-size:12px;color:var(--text-light);display:flex;align-items:center;gap:4px}
.pooja-rating .star{color:var(--gold)}
.btn-book{background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;font-size:12px;font-weight:700;padding:9px 18px;border-radius:8px;cursor:pointer;transition:all .2s;font-family:'Hind',sans-serif;letter-spacing:.3px}
.btn-book:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(232,101,10,.35)}

/* FEATURED SCROLL */
.featured-scroll{display:flex;gap:18px;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.featured-scroll::-webkit-scrollbar{height:4px}
.featured-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.f-card{flex-shrink:0;width:190px;background:var(--cream);border:1px solid var(--border-light);border-radius:16px;overflow:hidden;transition:all .25s;cursor:pointer;scroll-snap-align:start;box-shadow:0 2px 10px var(--shadow)}
.f-card:hover{transform:translateY(-6px);box-shadow:0 12px 30px var(--shadow);border-color:var(--gold)}
.f-img{width:100%;height:130px;overflow:hidden;position:relative}
.f-img img{width:100%;height:100%;object-fit:cover;display:block}
.f-name{padding:10px 12px;font-family:'Cinzel',serif;font-size:12px;font-weight:600;color:var(--text-dark);text-align:center;line-height:1.4}
.f-price{padding:0 12px 12px;font-size:12px;color:var(--saffron);font-weight:600;text-align:center}

/* CATEGORY CARDS */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cat-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;height:180px;background:var(--cream2);transition:all .3s ease;box-shadow:0 4px 16px var(--shadow);animation:catCardIn .4s ease both}
.cat-bg-img{position:absolute;inset:0;width:100%;height:100%;overflow:hidden}
.cat-bg-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(60,15,5,.88) 0%,transparent 55%);display:flex;align-items:flex-end;padding:16px}
.cat-name{font-family:'Cinzel',serif;font-size:13.5px;font-weight:700;color:#fff;margin-bottom:2px}
.cat-count{font-size:11px;color:rgba(255,255,255,.7)}
.cat-card:hover{transform:scale(1.04)}
.cat-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:54px;position:absolute;inset:0}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(60,15,5,.88) 0%,transparent 55%);display:flex;align-items:flex-end;padding:16px}
.cat-name{font-family:'Cinzel',serif;font-size:14px;font-weight:600;color:#fff;line-height:1.3}
.cat-count{font-size:11px;color:var(--gold-light);margin-top:3px}

/* DEITY GRID */
.deity-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.deity-card{text-align:center;cursor:pointer;transition:transform .2s}
.deity-card:hover{transform:translateY(-5px)}
.deity-circle{width:88px;height:88px;border-radius:50%;margin:0 auto 12px;font-size:38px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);box-shadow:0 4px 16px var(--shadow-gold);transition:all .2s}
.deity-card:hover .deity-circle{border-color:var(--gold);box-shadow:0 6px 24px var(--shadow-gold)}
.deity-name{font-family:'Cinzel',serif;font-size:12px;font-weight:600;color:var(--text-dark);margin-bottom:4px}
.deity-link{font-size:11px;color:var(--saffron);font-weight:600}

/* HOW IT WORKS */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;position:relative}
.steps-grid::before{content:'';position:absolute;top:44px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,var(--border),var(--gold),var(--border));z-index:0}
.step-card{text-align:center;position:relative;z-index:1}
.step-num{width:72px;height:72px;background:linear-gradient(135deg,var(--saffron),var(--maroon));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 18px;box-shadow:0 4px 16px var(--shadow);transition:transform .2s}
.step-card:hover .step-num{transform:scale(1.1)}
.step-title{font-family:'Cinzel',serif;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:7px}
.step-desc{font-size:13px;color:var(--text-light);line-height:1.6}

/* TESTIMONIALS */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.t-card{background:#fff;border:1px solid var(--border-light);border-radius:18px;padding:26px 22px;box-shadow:0 2px 12px var(--shadow);transition:transform .2s;position:relative}
.t-card:hover{transform:translateY(-4px)}
.quote{font-family:'Cinzel Decorative',serif;font-size:68px;color:var(--saffron);opacity:.12;position:absolute;top:10px;left:18px;line-height:1}
.stars{color:var(--gold);font-size:15px;margin-bottom:10px;letter-spacing:2px}
.t-text{font-size:13.5px;color:var(--text-mid);line-height:1.75;margin-bottom:16px;position:relative;z-index:1}
.t-author{display:flex;align-items:center;gap:11px}
.t-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--maroon));display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.t-name{font-family:'Cinzel',serif;font-size:13px;font-weight:600;color:var(--text-dark)}
.t-loc{font-size:12px;color:var(--text-light)}

/* TRUST BAR */
.trust-bar{background:var(--cream);border-bottom:1px solid var(--border-light);padding:16px 24px}
.trust-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:center;gap:44px;flex-wrap:wrap;align-items:center}
.trust-item{display:flex;align-items:center;gap:10px}
.trust-icon{font-size:20px}
.trust-text{font-size:13px;color:var(--text-mid);font-weight:500}
.trust-text strong{color:var(--text-dark);display:block;font-size:13.5px}

/* FILTER TABS */
.filter-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filter-tab{padding:8px 20px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:2px solid var(--border);background:var(--cream);color:var(--text-mid);font-family:'Hind',sans-serif}
.filter-tab.active,.filter-tab:hover{background:var(--saffron);border-color:var(--saffron);color:#fff}
.filter-bar{background:var(--cream);border-radius:12px;padding:16px 20px;border:1px solid var(--border-light);margin-bottom:28px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.filter-bar input,.filter-bar select{padding:9px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:'Hind',sans-serif;font-size:14px;color:var(--text-dark);background:#fff;outline:none;transition:border .2s}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--saffron)}
.filter-bar input{flex:1;min-width:200px}

/* CTA BANNER */
.cta-banner{background:linear-gradient(135deg,var(--maroon) 0%,var(--deep-maroon) 100%);padding:60px 24px;position:relative;overflow:hidden;text-align:center}
.cta-banner::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(212,160,23,.15) 0%,transparent 50%),radial-gradient(circle at 80% 50%,rgba(232,101,10,.1) 0%,transparent 50%)}
.cta-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.cta-title{font-family:'Cinzel',serif;font-size:clamp(20px,3vw,34px);font-weight:700;color:#fff;margin-bottom:12px;line-height:1.3}
.cta-title .gold{color:var(--gold-light)}
.cta-sub{font-size:15px;color:rgba(255,255,255,.7);margin-bottom:28px;line-height:1.7}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-cta-phone{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--gold),#C48A10);color:var(--deep-maroon);font-family:'Cinzel',serif;font-size:14px;font-weight:700;padding:13px 26px;border-radius:8px;transition:all .25s;box-shadow:0 4px 20px rgba(212,160,23,.3)}
.btn-cta-phone:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(212,160,23,.45)}
.btn-cta-wa{display:flex;align-items:center;gap:8px;background:#25D366;color:#fff;font-family:'Hind',sans-serif;font-size:14px;font-weight:700;padding:13px 26px;border-radius:8px;transition:all .25s;box-shadow:0 4px 20px rgba(37,211,102,.3)}
.btn-cta-wa:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.4)}

/* FOOTER */
footer{background:var(--deep-maroon);color:rgba(255,255,255,.75);padding:52px 24px 0}
.footer-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-brand-logo .main{font-family:'Cinzel Decorative',serif;font-size:18px;color:var(--gold-light);font-weight:700}
.footer-brand-logo .sub{font-size:11px;color:rgba(255,255,255,.5);letter-spacing:2px;text-transform:uppercase}
.footer-tagline{font-size:13px;line-height:1.7;color:rgba(255,255,255,.6);margin-bottom:18px;max-width:270px}
.footer-contact{display:flex;flex-direction:column;gap:7px}
.f-contact-item{font-size:13px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px}
.social-row{display:flex;gap:9px;margin-top:16px}
.social-btn{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;transition:all .2s;color:rgba(255,255,255,.7);font-weight:700}
.social-btn:hover{background:var(--saffron);border-color:var(--saffron);color:#fff}
.footer-col-title{font-family:'Cinzel',serif;font-size:13px;font-weight:600;color:var(--gold-light);margin-bottom:14px;letter-spacing:.5px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.6);transition:color .2s}
.footer-links a:hover{color:var(--gold-light)}
.footer-bottom{max-width:1280px;margin:0 auto;padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:8px}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--gold-light)}

/* FLOATING WA */
.float-wa{position:fixed;bottom:26px;right:26px;width:54px;height:54px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 4px 20px rgba(37,211,102,.5);z-index:2000;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}50%{box-shadow:0 4px 30px rgba(37,211,102,.8),0 0 0 8px rgba(37,211,102,.15)}}

/* POOJA DETAIL */
.detail-grid{display:grid;grid-template-columns:1fr 380px;gap:36px;align-items:start}
.detail-main h2{font-family:'Cinzel',serif;font-size:24px;font-weight:700;color:var(--text-dark);margin-bottom:14px}
.detail-main h3{font-family:'Cinzel',serif;font-size:17px;font-weight:600;color:var(--text-dark);margin:24px 0 10px}
.detail-main p{font-size:14.5px;color:var(--text-mid);line-height:1.8}
.detail-main ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:8px}
.detail-main ul li{font-size:14px;color:var(--text-mid);display:flex;align-items:flex-start;gap:10px;line-height:1.6}
.detail-main ul li::before{content:'✦';color:var(--saffron);flex-shrink:0;margin-top:2px;font-size:10px}
.detail-img-banner{width:100%;height:280px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:80px;margin-bottom:28px;border:1px solid var(--border-light)}
.detail-tabs{display:flex;gap:6px;border-bottom:2px solid var(--border-light);margin-bottom:24px}
.d-tab{padding:10px 18px;font-size:13.5px;font-weight:600;color:var(--text-light);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;font-family:'Hind',sans-serif}
.d-tab.active,.d-tab:hover{color:var(--saffron);border-color:var(--saffron)}
.tab-content{display:none}
.tab-content.active{display:block}

/* BOOKING CARD */
.booking-card{background:var(--cream);border:1.5px solid var(--border);border-radius:20px;padding:26px 22px;position:sticky;top:88px}
.booking-card h3{font-family:'Cinzel',serif;font-size:18px;font-weight:700;color:var(--text-dark);margin-bottom:4px}
.price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:18px}
.price-main{font-family:'Cinzel',serif;font-size:28px;font-weight:700;color:var(--saffron)}
.price-label{font-size:13px;color:var(--text-light)}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-mid);margin-bottom:6px}
.form-group input,.form-group select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;font-family:'Hind',sans-serif;font-size:14px;color:var(--text-dark);background:#fff;outline:none;transition:border .2s}
.form-group input:focus,.form-group select:focus{border-color:var(--saffron)}
.btn-book-full{width:100%;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;font-size:15px;font-weight:700;padding:14px;border-radius:10px;cursor:pointer;transition:all .2s;font-family:'Cinzel',serif;letter-spacing:.5px;margin-top:16px;box-shadow:0 4px 18px rgba(232,101,10,.3)}
.btn-book-full:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,101,10,.4)}
.includes-list{display:flex;flex-direction:column;gap:7px;margin-top:14px}
.include-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-mid)}
.include-icon{font-size:14px}
.booking-divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.pkg-tabs{display:flex;gap:6px;margin-bottom:16px}
.pkg-tab{flex:1;padding:8px;text-align:center;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--text-mid);transition:all .2s;font-family:'Hind',sans-serif}
.pkg-tab.active{background:var(--saffron);border-color:var(--saffron);color:#fff}

/* ABOUT PAGE */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-visual{display:flex;justify-content:center}
.about-visual-inner{width:360px;height:360px;border-radius:50%;background:linear-gradient(135deg,var(--cream2),var(--cream));border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:120px;box-shadow:0 12px 40px var(--shadow-gold)}
.stat-blocks{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px}
.stat-block{background:var(--cream);border:1px solid var(--border-light);border-radius:14px;padding:18px 20px;text-align:center}
.stat-block .num{font-family:'Cinzel',serif;font-size:28px;font-weight:700;color:var(--saffron)}
.stat-block .lbl{font-size:12px;color:var(--text-light);margin-top:4px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.team-card{text-align:center;background:var(--cream);border:1px solid var(--border-light);border-radius:16px;padding:28px 20px;transition:all .2s}
.team-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px var(--shadow)}
.team-avatar{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--saffron),var(--maroon));display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 14px;border:3px solid var(--border)}
.team-name{font-family:'Cinzel',serif;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:4px}
.team-role{font-size:12px;color:var(--saffron);font-weight:600}
.team-lang{font-size:12px;color:var(--text-light);margin-top:6px}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.value-card{background:#fff;border:1px solid var(--border-light);border-radius:16px;padding:26px 22px;text-align:center;box-shadow:0 2px 10px var(--shadow)}
.value-icon{font-size:44px;margin-bottom:14px}
.value-title{font-family:'Cinzel',serif;font-size:15px;font-weight:600;color:var(--text-dark);margin-bottom:8px}
.value-desc{font-size:13.5px;color:var(--text-light);line-height:1.6}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:44px}
.contact-form-card{background:var(--cream);border:1.5px solid var(--border);border-radius:20px;padding:34px 30px}
.contact-form-card h3{font-family:'Cinzel',serif;font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:9px;font-family:'Hind',sans-serif;font-size:14px;color:var(--text-dark);background:#fff;outline:none;transition:border .2s;resize:vertical;min-height:110px}
.form-group textarea:focus{border-color:var(--saffron)}
.contact-info-grid{display:flex;flex-direction:column;gap:16px}
.contact-info-card{background:var(--cream);border:1px solid var(--border-light);border-radius:14px;padding:20px 22px;display:flex;align-items:flex-start;gap:14px}
.ci-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--saffron),var(--maroon));display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ci-title{font-family:'Cinzel',serif;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:4px}
.ci-val{font-size:13.5px;color:var(--text-mid);line-height:1.6}
.faq-item{background:var(--cream);border:1px solid var(--border-light);border-radius:12px;overflow:hidden;margin-bottom:10px}
.faq-q{padding:16px 20px;font-family:'Cinzel',serif;font-size:14px;font-weight:600;color:var(--text-dark);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s}
.faq-q:hover{background:var(--cream2)}
.faq-a{padding:0 20px 16px;font-size:13.5px;color:var(--text-mid);line-height:1.7;display:none}
.faq-item.open .faq-a{display:block}
.faq-item.open .faq-q{color:var(--saffron)}

/* BLOG PAGE */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border:1px solid var(--border-light);border-radius:18px;overflow:hidden;transition:all .25s;box-shadow:0 2px 10px var(--shadow)}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px var(--shadow);border-color:var(--gold)}
.blog-img{width:100%;height:190px;display:flex;align-items:center;justify-content:center;font-size:60px;position:relative}
.blog-cat{position:absolute;top:12px;left:12px;background:var(--saffron);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px}
.blog-body{padding:18px 20px 22px}
.blog-meta{display:flex;gap:12px;margin-bottom:10px}
.blog-date,.blog-read{font-size:11.5px;color:var(--text-light)}
.blog-title{font-family:'Cinzel',serif;font-size:15px;font-weight:600;color:var(--text-dark);margin-bottom:8px;line-height:1.4}
.blog-excerpt{font-size:13px;color:var(--text-light);line-height:1.65;margin-bottom:14px}
.blog-link{font-size:13px;font-weight:600;color:var(--saffron);display:flex;align-items:center;gap:4px;transition:gap .2s}
.blog-link:hover{gap:8px}

/* ANIMATIONS */
/* fade-up: only for static HTML elements with data-animate, NOT for JS-rendered cards */
/* fade-up: animate in on page load (no scroll needed for local files) */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.fade-up{animation:fadeUp .45s ease both}
.fade-up.visible{opacity:1;transform:none}
/* cat-card animation - fires immediately */
@keyframes catCardIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}

/* ════════════════════════════════════════════════════
   RESPONSIVE — Desktop, Tablet, Mobile
   Breakpoints: 1280 / 1024 / 768 / 480
   ════════════════════════════════════════════════════ */

/* ── TABLET: 1024px ── */
@media(max-width:1024px){
  /* Layout */
  .pkg-page{grid-template-columns:1fr}
  .booking-sidebar{position:static;margin-top:24px}
  .poojas-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .deity-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-visual{display:none}
  .hero-inner,.hero{grid-template-columns:1fr}
  .hero-visual{display:none}
  /* Blog + teams */
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .value-grid{grid-template-columns:repeat(2,1fr)}
  .pandit-cards{grid-template-columns:1fr}
  /* Pkg cards */
  .pkg-cards{grid-template-columns:1fr 1fr}
  /* Cat page hero */
  .ap-hero-inner,.city-hero-inner{max-width:100%}
  /* SEO grid */
  .seo-grid{grid-template-columns:repeat(3,1fr)}
  .seo-cities-grid{grid-template-columns:repeat(3,1fr)}
  .slug-cols{grid-template-columns:repeat(2,1fr)}
  /* Other cats */
  .other-cats-grid{grid-template-columns:repeat(4,1fr)}
}

/* ── MOBILE: 768px ── */
@media(max-width:768px){
  /* Nav */
  .nav-links,.nav-actions{display:none}
  .hamburger{display:block}
  .nav-inner{padding:0 16px}
  .logo-text .main{font-size:15px}
  .logo-text .sub{font-size:9px}

  /* Hero */
  .hero{padding:40px 16px 48px}
  .hero-inner{grid-template-columns:1fr;gap:0}
  .hero-visual{display:none}
  .hero h1{font-size:clamp(24px,6vw,36px)}
  .hero-sub{font-size:14px}
  .hero-cta{gap:10px}
  .btn-gold,.btn-ghost{font-size:13px;padding:11px 20px}
  .hero-stats{gap:16px}
  .stat-num{font-size:20px}

  /* Page heroes */
  .page-hero,.cat-hero,.ap-hero,.city-hero{padding:32px 16px 36px}
  .page-hero h1,.cat-hero h1,.ap-hero h1{font-size:clamp(22px,5vw,32px)}
  .cat-hero-desc,.ap-hero-sub,.city-hero-sub{font-size:13.5px}
  .ap-stats{gap:8px}
  .ap-stat{font-size:11px;padding:4px 12px}

  /* Trust bar */
  .trust-bar{padding:12px 16px}
  .trust-inner{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .trust-item{justify-content:flex-start}

  /* Sections */
  .section{padding:32px 0}
  .section-inner{padding:0 16px}
  .section-title{font-size:clamp(20px,5vw,28px)}
  .section-header-row{flex-direction:column;gap:8px;align-items:flex-start}

  /* Filter bars */
  .filter-bar,.ap-filterbar,.cat-filterbar,.csb-inner{flex-direction:column;gap:8px}
  .filter-bar input,.ap-filterbar input,.cat-filterbar input{min-width:100%;width:100%}
  .filter-bar select,.ap-filterbar select,.cat-filterbar select{width:100%}
  .ap-sort,.cat-sort{gap:6px}
  .ap-schip,.csort-chip,.cat-sort-chip{font-size:11.5px;padding:5px 12px}
  .ap-cattabs{gap:6px}
  .ap-cattab{font-size:12px;padding:6px 14px}

  /* Cards */
  .poojas-grid{grid-template-columns:1fr 1fr;gap:14px}
  .pcard-img{height:160px}
  .pcard-name{font-size:13.5px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .cat-name{font-size:13px}
  .deity-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .deity-circle{width:52px;height:52px;font-size:22px}
  .deity-name{font-size:11px}

  /* Steps */
  .steps-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .steps-grid::before{display:none}

  /* Featured scroll */
  .featured-scroll{gap:12px}
  .f-card{width:160px}

  /* Testimonials */
  .testimonial-grid{grid-template-columns:1fr}

  /* Blog */
  .blog-grid{grid-template-columns:1fr}

  /* Package page */
  .pkg-cards{grid-template-columns:1fr}
  .pkg-page{padding:16px}
  .benefit-grid{grid-template-columns:1fr}
  .pandit-cards{grid-template-columns:1fr}
  .muhurat-grid{grid-template-columns:repeat(2,1fr)}
  .samagri-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-hero{height:240px}
  .pkg-hero-text h1{font-size:20px}
  .pkg-tabs{gap:0}
  .pkg-tab{padding:10px 14px;font-size:12px}
  .reviews-header{flex-direction:column;gap:16px}

  /* Booking sidebar */
  .booking-box-body{padding:16px}
  .date-slots{grid-template-columns:repeat(7,1fr);gap:3px}
  .date-slot{font-size:10px}
  .date-slot .day-num{font-size:12px}
  .time-slots{grid-template-columns:1fr 1fr 1fr;gap:6px}
  .time-slot{font-size:11px;padding:7px 4px}

  /* City page */
  .city-stats-inner{grid-template-columns:repeat(2,1fr)}
  .csb{top:68px}
  .csb-inner{gap:8px}
  .csb-select{font-size:12px;padding:6px 10px}
  .city-chips{gap:6px}
  .city-chip{font-size:11px;padding:4px 12px}

  /* Categories page */
  .other-cats-grid{grid-template-columns:repeat(2,1fr)}
  .seo-grid,.seo-cities-grid{grid-template-columns:repeat(2,1fr)}

  /* About */
  .stat-blocks{grid-template-columns:repeat(2,1fr)}
  .value-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}

  /* Contact */
  .contact-grid,.form-row{grid-template-columns:1fr}
  .ci-grid{grid-template-columns:1fr}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-tagline{font-size:13px}
  .cta-inner{padding:32px 20px}
  .cta-title{font-size:clamp(20px,5vw,28px)}
  .cta-actions{flex-direction:column;gap:10px;align-items:stretch}
  .btn-cta-phone,.btn-cta-wa{text-align:center;justify-content:center}

  /* Modals */
  .ys-modal{padding:24px 18px;max-height:95vh}
  .ys-otp-box{width:38px;height:44px;font-size:18px}
  .ys-booking-modal{margin:0;border-radius:16px 16px 0 0;max-height:90vh;position:fixed;bottom:0;left:0;right:0;max-width:100%}
  .ys-modal-overlay{align-items:flex-end}

  /* Slug links */
  .slug-cols{grid-template-columns:1fr 1fr}

  /* City quick links */
  .why-strip-inner{grid-template-columns:repeat(2,1fr)}
}

/* ── SMALL MOBILE: 480px ── */
@media(max-width:480px){
  /* Even tighter */
  .poojas-grid{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .deity-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .pkg-cards{grid-template-columns:1fr}
  .seo-grid,.seo-cities-grid{grid-template-columns:1fr 1fr}
  .slug-cols{grid-template-columns:1fr}
  .ap-filterbar,.cat-filterbar{gap:6px}
  .ap-sort,.cat-sort{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .ap-sort::-webkit-scrollbar,.cat-sort::-webkit-scrollbar{display:none}
  .time-slots{grid-template-columns:1fr 1fr}
  .muhurat-grid{grid-template-columns:1fr 1fr}
  .samagri-grid{grid-template-columns:1fr 1fr}
  .date-slots{grid-template-columns:repeat(7,1fr)}
  .ys-booking-actions{grid-template-columns:1fr}
  .pkg-hero-badges{display:none}
  .hero-stats{grid-template-columns:repeat(2,1fr);display:grid}
  .why-strip-inner{grid-template-columns:1fr 1fr}
  .other-cats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-col-title{font-size:14px}
  .nav-inner{height:60px}
  .mobile-menu{top:60px}
  /* Scroll sort chips on mobile */
  .ap-cattabs{overflow-x:auto;flex-wrap:nowrap}
  .ap-cattabs::-webkit-scrollbar{display:none}
}

/* ═══════════════════════════════════════════
   REAL IMAGE SUPPORT — replaces emoji placeholders
   ═══════════════════════════════════════════ */

/* Pooja card image area */
.pooja-img {
  position: relative;
  overflow: hidden;
}
.pooja-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.pooja-card:hover .pooja-img img {
  transform: scale(1.07);
}
.img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(42,20,7,0.35) 100%);
  pointer-events: none;
}

/* Featured scroll card image */
.f-img {
  overflow: hidden;
}
.f-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.f-card:hover .f-img img {
  transform: scale(1.08);
}

/* Category card image */
.cat-bg-img{position:absolute;inset:0;width:100%;height:100%;overflow:hidden}
.cat-bg-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.cat-card:hover .cat-bg-img img{transform:scale(1.07)}
/* Big category card (categories page) */
.big-cat-top {
  overflow: hidden;
  position: relative;
}
.big-cat-top img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.big-cat-card:hover .big-cat-top img {
  transform: scale(1.06);
}

/* Blog card image */
.blog-img {
  overflow: hidden;
  position: relative;
}
.blog-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.blog-card:hover .blog-img img {
  transform: scale(1.07);
}

/* Pooja detail banner image */
.detail-img-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;
}

/* Hero card image (homepage floating card) */
.hero-pooja-img {
  width: 100%;
  height: 150px;
  overflow: hidden;
  border-radius: 12px;
  margin-bottom: 14px;
}
.hero-pooja-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Focus styles */
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--saffron);outline-offset:2px;border-radius:4px}

@media print{.topbar,.float-wa,.nav-actions,.hamburger,.booking-sidebar{display:none!important}.pkg-page{grid-template-columns:1fr!important}}

/* ── BOOKMYPOOJAONLINE-STYLE POOJA CARDS ── */
.poojas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:1024px){.poojas-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.poojas-grid{grid-template-columns:1fr}}

/* Keep old classes for legacy sections */
.pooja-card{background:#fff;border:1px solid var(--border-light);border-radius:14px;overflow:hidden;transition:all .25s;box-shadow:0 2px 10px var(--shadow);cursor:pointer}
.pooja-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px var(--shadow);border-color:var(--gold)}
.pooja-img{height:180px;overflow:hidden;position:relative;background:var(--cream2)}
.pooja-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.pooja-card:hover .pooja-img img{transform:scale(1.06)}
.img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,20,7,.5) 0%,transparent 55%)}
.badge-tag{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:100px;letter-spacing:.3px}
.pooja-body{padding:14px 16px 16px}
.pooja-name{font-family:'Cinzel',serif;font-size:14.5px;font-weight:700;color:var(--text-dark);margin-bottom:7px;line-height:1.3}
.pooja-meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:7px}
.meta-chip{font-size:10.5px;color:var(--text-light);background:var(--cream2);padding:2px 7px;border-radius:100px;border:1px solid var(--border-light)}
.pooja-desc{font-size:12.5px;color:var(--text-light);line-height:1.55;margin-bottom:12px}
.pooja-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border-light);padding-top:10px}
.pooja-price{font-family:'Cinzel',serif;font-size:16px;font-weight:700;color:var(--saffron)}
.pooja-price small{display:block;font-family:'Hind',sans-serif;font-size:10px;color:var(--text-light);font-weight:400}
.btn-book{background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;padding:7px 16px;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;font-family:'Hind',sans-serif;transition:all .2s}
.btn-book:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(232,101,10,.4)}

/* NEW BookMyPooja-style cards */
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.pcard{background:#fff;border:1.5px solid var(--border-light);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .25s;box-shadow:0 2px 12px var(--shadow);animation:cardIn .35s ease both;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-6px);box-shadow:0 16px 40px var(--shadow-gold);border-color:var(--gold)}
.pcard-img{position:relative;height:195px;overflow:hidden;background:var(--cream2);flex-shrink:0}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pcard:hover .pcard-img img{transform:scale(1.07)}
.pcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,20,7,.6) 0%,transparent 50%)}
.pcard-badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px;letter-spacing:.3px;z-index:2;box-shadow:0 2px 6px rgba(232,101,10,.4)}
.pcard-body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1}
.pcard-cat{font-size:10px;font-weight:700;color:var(--saffron);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:5px}
.pcard-name{font-family:'Cinzel',serif;font-size:15px;font-weight:700;color:var(--text-dark);line-height:1.3;margin-bottom:6px}
.pcard-desc{font-size:12.5px;color:var(--text-light);line-height:1.55;margin-bottom:10px;flex:1}
.pcard-info{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.pcard-info-item{font-size:11.5px;color:var(--text-light);display:flex;align-items:center;gap:3px;background:var(--cream2);padding:3px 9px;border-radius:100px;border:1px solid var(--border-light)}
.pcard-footer{display:flex;align-items:flex-end;justify-content:space-between;border-top:1px solid var(--border-light);padding-top:10px;margin-top:auto;gap:8px}
.pcard-rating{display:flex;align-items:center;gap:4px;margin-bottom:4px}
.pcard-stars{color:#F5A623;font-size:11px;letter-spacing:1px}
.pcard-rnum{font-size:12px;font-weight:700;color:var(--text-dark)}
.pcard-rcnt{font-size:11px;color:var(--text-light)}
.pcard-price{font-family:'Cinzel',serif;font-size:17px;font-weight:700;color:var(--saffron);line-height:1}
.pcard-price span{font-family:'Hind',sans-serif;font-size:10px;font-weight:400;color:var(--text-light);display:block;margin-top:2px}
.pcard-btn{background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;padding:9px 16px;border-radius:8px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:'Hind',sans-serif;transition:all .2s;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px rgba(232,101,10,.3)}
.pcard-btn:hover{transform:translateY(-1px);box-shadow:0 5px 14px rgba(232,101,10,.5)}
.f-card{flex-shrink:0;width:200px;background:#fff;border:1.5px solid var(--border-light);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .25s;box-shadow:0 2px 8px var(--shadow)}
.f-body{padding:10px 12px 12px}
/* Staggered fade-up delays for grids */
.cat-grid .fade-up:nth-child(1),.poojas-grid .fade-up:nth-child(1){animation-delay:0ms}
.cat-grid .fade-up:nth-child(2),.poojas-grid .fade-up:nth-child(2){animation-delay:60ms}
.cat-grid .fade-up:nth-child(3),.poojas-grid .fade-up:nth-child(3){animation-delay:120ms}
.cat-grid .fade-up:nth-child(4),.poojas-grid .fade-up:nth-child(4){animation-delay:180ms}
.cat-grid .fade-up:nth-child(5),.poojas-grid .fade-up:nth-child(5){animation-delay:240ms}
.cat-grid .fade-up:nth-child(6),.poojas-grid .fade-up:nth-child(6){animation-delay:300ms}
/* pcard stagger via inline style — already handled in renderPoojaCards */
/* catCard stagger via inline style — already handled in renderCategoryCards */

/* ══════════════════════════════════════════
   LOGIN + BOOKING SUCCESS MODALS
   ══════════════════════════════════════════ */

/* Overlay */
.ys-modal-overlay{display:none;position:fixed;inset:0;background:rgba(42,20,7,.65);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(4px);padding:16px}
.ys-modal-overlay[style*="flex"]{display:flex!important}

/* Modal box */
.ys-modal{background:#fff;border-radius:22px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;position:relative;padding:32px 28px;box-shadow:0 24px 72px rgba(42,20,7,.35);animation:modalIn .28s cubic-bezier(.34,1.56,.64,1)}
@keyframes modalIn{from{opacity:0;transform:scale(.88) translateY(20px)}to{opacity:1;transform:none}}

/* Close button */
.ys-modal-close{position:absolute;top:14px;right:16px;width:32px;height:32px;border-radius:50%;background:var(--cream2);border:none;font-size:14px;cursor:pointer;color:var(--text-light);display:flex;align-items:center;justify-content:center;transition:all .2s}
.ys-modal-close:hover{background:var(--border);color:var(--text-dark)}

/* Logo */
.ys-modal-logo{text-align:center;margin-bottom:16px}

/* Tabs */
.ys-modal-tabs{display:flex;background:var(--cream2);border-radius:10px;padding:4px;margin-bottom:20px}
.ys-mtab{flex:1;border:none;background:transparent;padding:9px;border-radius:8px;font-family:'Hind',sans-serif;font-size:14px;font-weight:600;color:var(--text-light);cursor:pointer;transition:all .2s}
.ys-mtab.active{background:#fff;color:var(--saffron);box-shadow:0 2px 8px var(--shadow)}

/* Sub text */
.ys-modal-sub{font-size:13.5px;color:var(--text-light);text-align:center;margin-bottom:18px;line-height:1.5}

/* Fields */
.ys-field{margin-bottom:14px}
.ys-field label{display:block;font-size:12.5px;font-weight:600;color:var(--text-mid);margin-bottom:5px}
.ys-field input{width:100%;padding:11px 14px;border:1.5px solid var(--border-light);border-radius:9px;font-family:'Hind',sans-serif;font-size:14px;color:var(--text-dark);background:var(--cream);outline:none;transition:border .2s;box-sizing:border-box}
.ys-field input:focus{border-color:var(--saffron);background:#fff}

/* Error */
.ys-err{min-height:18px;font-size:12.5px;color:#E53935;margin-bottom:8px;text-align:center;font-weight:500}

/* Submit btn */
.ys-submit-btn{width:100%;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;padding:13px;border-radius:10px;font-family:'Cinzel',serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.5px;box-shadow:0 4px 14px rgba(232,101,10,.3);margin-top:4px}
.ys-submit-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,101,10,.4)}

/* OTP boxes */
.ys-otp-row{display:flex;gap:8px;justify-content:center;margin-bottom:10px}
.ys-otp-box{width:44px;height:50px;border:1.5px solid var(--border);border-radius:10px;text-align:center;font-size:20px;font-weight:700;font-family:'Cinzel',serif;color:var(--text-dark);outline:none;background:var(--cream);transition:border .2s}
.ys-otp-box:focus{border-color:var(--saffron);background:#fff}

/* ── BOOKING SUCCESS MODAL ── */
.ys-booking-modal{max-width:480px;padding:0;overflow:hidden}
.ys-booking-success-header{background:linear-gradient(135deg,#1B5E20,#2E7D32);padding:28px 24px 24px;text-align:center}
.ys-booking-tick{width:60px;height:60px;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;font-weight:700;margin:0 auto 12px}
.ys-booking-title{font-family:'Cinzel',serif;font-size:22px;color:#fff;margin-bottom:4px}
.ys-booking-sub{font-size:13px;color:rgba(255,255,255,.8)}
.ys-booking-body{padding:20px 22px 24px}
.ys-booking-id-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream2);border:1px solid var(--border-light);border-radius:10px;padding:10px 16px;margin-bottom:16px}
.ys-booking-id-row span{font-size:12px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.ys-booking-details{border:1px solid var(--border-light);border-radius:12px;overflow:hidden;margin-bottom:16px}
.ys-bkg-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border-light);font-size:13.5px}
.ys-bkg-row:last-child{border:none}
.ys-bkg-row span{color:var(--text-light)}
.ys-bkg-row strong{color:var(--text-dark);text-align:right;max-width:55%}

/* Steps */
.ys-booking-steps{display:flex;flex-direction:column;gap:0;margin-bottom:18px}
.ys-bstep{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed var(--border-light);position:relative}
.ys-bstep:last-child{border:none}
.ys-bstep-icon{width:32px;height:32px;border-radius:50%;background:var(--cream2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ys-bstep.done .ys-bstep-icon{background:#E8F5E9;border-color:#4CAF50;color:#2E7D32}
.ys-bstep div strong{display:block;font-size:13px;color:var(--text-dark);margin-bottom:2px}
.ys-bstep div span{font-size:11.5px;color:var(--text-light)}

/* Booking action buttons */
.ys-booking-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.ys-bkg-wa-btn{background:#25D366;color:#fff;border:none;padding:11px;border-radius:9px;font-family:'Hind',sans-serif;font-size:13px;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.ys-bkg-wa-btn:hover{background:#1da851}
.ys-bkg-print-btn{background:var(--cream2);color:var(--text-mid);border:1.5px solid var(--border);padding:11px;border-radius:9px;font-family:'Hind',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.ys-bkg-print-btn:hover{border-color:var(--saffron);color:var(--saffron)}
.ys-bkg-close-btn{width:100%;background:linear-gradient(135deg,var(--saffron),var(--deep-saffron));color:#fff;border:none;padding:12px;border-radius:9px;font-family:'Cinzel',serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 3px 12px rgba(232,101,10,.3)}
.ys-bkg-close-btn:hover{transform:translateY(-1px)}

/* Print styles for booking receipt */
@media print{
  body > *:not(#bookingSuccessModal){display:none!important}
  .ys-modal-overlay{position:static!important;background:none!important;display:block!important}
  .ys-modal{box-shadow:none!important;max-width:100%!important;border-radius:0!important}
  .ys-bkg-close-btn,.ys-booking-actions,.ys-modal-close{display:none!important}
}

/* Mobile booking sidebar specific fixes */
@media(max-width:768px){
  .booking-sidebar{position:static!important;top:auto!important}
  .pkg-page{grid-template-columns:1fr!important;padding:12px}
  .date-slots{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;overflow-x:auto}
  .samagri-grid{grid-template-columns:repeat(2,1fr)!important}
  .related-scroll{gap:10px}
  .related-card{width:160px}
  .pkg-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .pandit-cards{grid-template-columns:1fr!important}
  /* City lang bar */
  .city-lang-bar .clb-inner{flex-wrap:wrap;gap:8px}
  .clb-select{font-size:12px;padding:6px 10px}
  /* Booking form inputs */
  .booking-box-body .form-input{font-size:16px}/* prevent iOS zoom */
  select.form-input{font-size:16px}/* prevent iOS zoom */
  /* Trust mini */
  .trust-mini{display:grid;grid-template-columns:1fr 1fr;gap:8px}
}

/* iOS input zoom prevention */
@media(max-width:768px){
  input[type="text"],input[type="tel"],input[type="email"],
  input[type="password"],select,textarea{font-size:16px!important}
  .ys-otp-box{font-size:18px!important}
}

/* Nav mobile fixes */
@media(max-width:768px){
  nav{position:sticky;top:0;z-index:1000}
  .mobile-menu{z-index:999;box-shadow:0 8px 24px rgba(42,20,7,.15)}
  .topbar{font-size:11px;padding:5px 12px;line-height:1.4}
  .topbar a{color:var(--gold-light)}
}

/* ── Toast notification ── */
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ══════════════════════════════════════════════
   MOBILE RESPONSIVE — COMPLETE FIXES
   ══════════════════════════════════════════════ */

/* Cat card hover fix */
@media(hover:hover){
  .cat-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px var(--shadow)}
}

/* Featured scroll mobile */
@media(max-width:768px){
  .featured-scroll{padding:0 16px 8px}
  .f-card{width:150px}
  .f-img{height:110px}
  .f-name{font-size:12px}
  .f-price{font-size:13px}
  /* City links strip */
  .section-inner > div[style*="display:flex;align-items:center;gap:20px"]{
    flex-direction:column;align-items:flex-start!important;gap:10px!important
  }
}

/* Pooja package page mobile */
@media(max-width:768px){
  .reviews-header{flex-direction:column}
  .reviews-bars{width:100%}
  .benefit-grid{grid-template-columns:1fr}
  .pkg-cards{grid-template-columns:1fr!important}
  .slug-cols{grid-template-columns:1fr!important}
  .clb-inner{flex-wrap:nowrap!important;overflow-x:auto;gap:6px!important;-webkit-overflow-scrolling:touch}
  .clb-inner::-webkit-scrollbar{display:none}
  .city-lang-bar{padding:8px 16px}
}

/* About page mobile */
@media(max-width:768px){
  .stat-blocks{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .num{font-size:22px}
  .about-grid{grid-template-columns:1fr!important}
}

/* Categories page mobile */
@media(max-width:480px){
  .other-cats-grid{grid-template-columns:1fr 1fr!important}
  .deity-card .deity-circle{width:56px;height:56px;font-size:24px}
}

/* Contact page mobile */
@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr!important}
  .ci-grid{grid-template-columns:1fr!important}
  .form-group{margin-bottom:12px}
}

/* Blog page mobile */
@media(max-width:480px){
  .blog-grid{grid-template-columns:1fr!important}
  .blog-img{height:180px}
}

/* City page mobile */
@media(max-width:768px){
  .city-stats-inner{grid-template-columns:1fr 1fr!important}
  .seo-grid{grid-template-columns:1fr 1fr!important}
}


/* ═══════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVE — ALL INTERNAL PAGES
   Breakpoints: 1024px (tablet) | 768px (mobile) | 480px (small)
   ═══════════════════════════════════════════════════════════════ */

/* ── ALL PAGES BASE ── */
* { box-sizing: border-box; }
img { max-width: 100%; }
.section-inner { padding: 0 16px; }

/* ── TABLET: 1024px ── */
@media(max-width:1024px){
  /* Package page */
  .pkg-page { grid-template-columns:1fr!important; gap:24px; padding:20px 16px; }
  .booking-sidebar { position:static!important; top:auto!important; }
  .pkg-cards { grid-template-columns:repeat(3,1fr); }
  .pandit-cards { grid-template-columns:repeat(2,1fr); }
  .samagri-grid { grid-template-columns:repeat(3,1fr); }
  .benefit-grid { grid-template-columns:repeat(2,1fr); }
  .muhurat-grid { grid-template-columns:repeat(3,1fr); }
  /* All poojas */
  .ap-filterbar { flex-wrap:wrap; }
  /* Grids */
  .poojas-grid { grid-template-columns:repeat(2,1fr)!important; }
  .cat-grid { grid-template-columns:repeat(3,1fr); }
  .other-cats-grid { grid-template-columns:repeat(4,1fr); }
  /* Footer */
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  /* Blog */
  .blog-grid { grid-template-columns:repeat(2,1fr); }
  /* About */
  .about-grid { grid-template-columns:1fr; }
  .about-visual { display:none; }
}

/* ── MOBILE: 768px ── */
@media(max-width:768px){
  /* NAV */
  .nav-links, .nav-actions { display:none!important; }
  .hamburger { display:block!important; }
  .nav-inner { padding:0 16px; height:60px; }
  .mobile-menu { top:60px; }
  .topbar { font-size:11px; padding:5px 12px; line-height:1.5; }

  /* PAGE HEROES */
  .page-hero, .cat-hero, .ap-hero { padding:28px 16px 32px; }
  .page-hero h1, .cat-hero h1, .ap-hero h1 { font-size:clamp(20px,6vw,30px); }
  .cat-hero-desc, .ap-hero-sub { font-size:13px; }
  .ap-stats { gap:6px; }
  .ap-stat { font-size:11px; padding:4px 12px; }
  .cat-hero-pills { gap:6px; }
  .cat-pill { font-size:11px; padding:4px 12px; }

  /* SECTIONS */
  .section { padding:28px 0; }
  .section-inner { padding:0 14px; }
  .section-title { font-size:clamp(18px,5vw,26px)!important; }
  .section-header-row { flex-direction:column; gap:6px; align-items:flex-start; }

  /* GRIDS */
  .poojas-grid { grid-template-columns:1fr 1fr!important; gap:12px; }
  .cat-grid { grid-template-columns:1fr 1fr!important; gap:10px; }
  .cat-card { height:130px!important; }
  .cat-name { font-size:12px!important; }
  .cat-count { font-size:10px!important; }
  .deity-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
  .deity-circle { width:56px!important; height:56px!important; font-size:24px!important; }
  .deity-name { font-size:11px!important; }
  .testimonial-grid { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:1fr 1fr; gap:14px; }
  .steps-grid::before { display:none; }
  .trust-inner { display:grid; grid-template-columns:1fr 1fr; gap:10px; }

  /* PCARD */
  .pcard-img { height:140px!important; }
  .pcard-name { font-size:13.5px; }
  .pcard-desc { font-size:12px; -webkit-line-clamp:2; }
  .pcard-btn { padding:7px 12px; font-size:11.5px; }
  .pcard-price { font-size:15px; }

  /* FILTER BARS */
  .filter-bar, .ap-filterbar, .cat-filterbar { flex-direction:column!important; gap:8px!important; padding:12px 14px!important; }
  .filter-bar input, .ap-filterbar input, .cat-filterbar input { width:100%!important; min-width:unset!important; }
  .filter-bar select, .ap-filterbar select, .cat-filterbar select { width:100%!important; }
  .ap-sort, .cat-sort { overflow-x:auto; flex-wrap:nowrap!important; padding-bottom:4px; -webkit-overflow-scrolling:touch; }
  .ap-sort::-webkit-scrollbar, .cat-sort::-webkit-scrollbar { display:none; }
  .ap-schip, .csort-chip { font-size:11.5px!important; padding:5px 12px!important; white-space:nowrap; flex-shrink:0; }
  .ap-cattabs { overflow-x:auto!important; flex-wrap:nowrap!important; }
  .ap-cattabs::-webkit-scrollbar { display:none; }
  .ap-cattab { font-size:11.5px!important; padding:6px 12px!important; flex-shrink:0; }

  /* ALL POOJAS */
  .ap-hero-inner { text-align:left; }
  .ap-stats { justify-content:flex-start; }
  .ap-results-bar { flex-direction:column; gap:6px; }

  /* CAT PAGES */
  .other-cats-grid { grid-template-columns:repeat(2,1fr)!important; gap:10px; }
  .other-cat-icon { font-size:22px; }
  .other-cat-name { font-size:11.5px; }

  /* CITY PAGE */
  .city-hero { padding:28px 16px 32px; }
  .city-hero h1 { font-size:clamp(20px,5vw,28px); }
  .city-stats-inner { grid-template-columns:repeat(2,1fr)!important; padding:14px 16px; }
  .cstat-num { font-size:18px; }
  .csb { top:60px; padding:8px 14px; }
  .csb-inner { flex-wrap:wrap!important; gap:8px!important; }
  .csb-select { font-size:12px!important; padding:6px 10px!important; }
  .csb-url { display:none; }
  .city-chips { gap:6px; }
  .city-chip { font-size:11px; padding:4px 12px; }
  .city-search { font-size:14px; padding:12px 18px; }
  .seo-grid, .seo-cities-grid { grid-template-columns:repeat(2,1fr)!important; gap:12px; }
  .why-strip-inner { grid-template-columns:repeat(2,1fr)!important; gap:14px; }

  /* POOJA PACKAGE PAGE */
  .pkg-page { padding:12px 14px!important; gap:20px!important; }
  .pkg-hero { height:200px!important; border-radius:12px!important; }
  .pkg-hero-text h1 { font-size:18px!important; }
  .pkg-hero-badges { display:none; }
  .pkg-tabs { gap:0!important; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .pkg-tabs::-webkit-scrollbar { display:none; }
  .pkg-tab { padding:10px 12px!important; font-size:11.5px!important; flex-shrink:0; }
  .pkg-cards { grid-template-columns:1fr!important; gap:12px; }
  .samagri-grid { grid-template-columns:repeat(2,1fr)!important; }
  .benefit-grid { grid-template-columns:1fr!important; gap:10px; }
  .pandit-cards { grid-template-columns:1fr!important; }
  .muhurat-grid { grid-template-columns:repeat(2,1fr)!important; }
  .reviews-header { flex-direction:column!important; gap:14px; }
  .reviews-bars { width:100%; }
  .related-card { width:160px!important; }
  .slug-cols { grid-template-columns:repeat(2,1fr)!important; }
  /* Booking form */
  .booking-sidebar { position:static!important; }
  .booking-box-body { padding:14px 16px!important; }
  .date-slots { grid-template-columns:repeat(7,1fr)!important; gap:3px!important; }
  .date-slot { font-size:9px!important; }
  .date-slot .day-num { font-size:11px!important; }
  .date-slot .day-name { font-size:8px!important; }
  .time-slots { grid-template-columns:repeat(3,1fr)!important; gap:6px!important; }
  .time-slot { font-size:11px!important; padding:7px 4px!important; }
  .city-lang-bar { padding:8px 14px; }
  .clb-inner { flex-wrap:wrap!important; gap:6px!important; }
  .clb-select { font-size:12px; padding:6px 10px; }
  .trust-mini { grid-template-columns:1fr 1fr; display:grid; gap:8px; }
  .btn-book-now { font-size:14px!important; padding:12px!important; }
  .btn-wa-book { font-size:13px!important; }
  .rating-row { flex-wrap:wrap!important; gap:12px!important; }
  .divider-v { display:none; }

  /* BLOG PAGE */
  .blog-grid { grid-template-columns:1fr!important; }
  .blog-img { height:180px!important; }

  /* ABOUT PAGE */
  .about-grid { grid-template-columns:1fr!important; }
  .about-visual { display:none!important; }
  .stat-blocks { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
  .value-grid { grid-template-columns:1fr 1fr!important; gap:12px; }
  .team-grid { grid-template-columns:1fr 1fr!important; gap:12px; }

  /* CONTACT PAGE */
  .contact-grid { grid-template-columns:1fr!important; }
  .ci-grid { grid-template-columns:1fr!important; }
  .btn-book-full { width:100%; }

  /* FOOTER */
  .footer-grid { grid-template-columns:1fr!important; gap:28px; }
  .cta-title { font-size:clamp(18px,5vw,26px)!important; }
  .cta-actions { flex-direction:column!important; gap:10px!important; align-items:stretch!important; }
  .btn-cta-phone, .btn-cta-wa { text-align:center!important; justify-content:center!important; }

  /* MODALS */
  .ys-modal { padding:20px 16px!important; margin:8px!important; max-height:92vh; }
  .ys-booking-modal { border-radius:16px 16px 0 0!important; max-height:88vh!important; position:fixed!important; bottom:0!important; left:0!important; right:0!important; max-width:100%!important; margin:0!important; }
  .ys-modal-overlay { align-items:flex-end!important; }
  .ys-otp-row { gap:6px; }
  .ys-otp-box { width:38px!important; height:44px!important; font-size:17px!important; }
  .ys-booking-actions { grid-template-columns:1fr!important; }
  .ys-booking-body { padding:16px!important; }

  /* iOS ZOOM PREVENTION */
  input[type="text"],input[type="tel"],input[type="email"],
  input[type="password"],input[type="date"],select,textarea { font-size:16px!important; }
}

/* ── SMALL MOBILE: 480px ── */
@media(max-width:480px){
  .poojas-grid { grid-template-columns:1fr!important; gap:12px; }
  .cat-grid { grid-template-columns:1fr 1fr!important; gap:8px; }
  .cat-card { height:110px!important; }
  .deity-grid { grid-template-columns:repeat(2,1fr)!important; }
  .steps-grid { grid-template-columns:1fr!important; gap:12px; }
  .value-grid, .team-grid { grid-template-columns:1fr!important; }
  .seo-grid, .seo-cities-grid { grid-template-columns:1fr 1fr!important; }
  .other-cats-grid { grid-template-columns:1fr 1fr!important; }
  .ap-hero h1, .cat-hero h1 { font-size:clamp(18px,5.5vw,24px)!important; }
  .ap-stats { flex-wrap:wrap; }
  .pkg-cards { grid-template-columns:1fr!important; }
  .city-stats-inner { grid-template-columns:1fr 1fr!important; }
  .muhurat-grid { grid-template-columns:1fr 1fr!important; }
  .samagri-grid { grid-template-columns:1fr 1fr!important; }
  .trust-mini { grid-template-columns:1fr!important; }
  .time-slots { grid-template-columns:1fr 1fr!important; }
  .footer-col-title { font-size:13px; }
  .topbar { font-size:10.5px; }
  /* Hide non-essential topbar text on tiny screens */
  .topbar .topbar-cities { display:none; }
}
