/* ============================================================
   YogFit India — Main Stylesheet
   ============================================================ */

/*:root {
  --primary:        #7c3aed;
  --primary-light:  #a78bfa;
  --primary-dark:   #5b21b6;
  --secondary:      #f59e0b;
  --accent:         #10b981;
  --dark:           #1a1a2e;
  --text:           #374151;
  --text-light:     #6b7280;
  --bg-light:       #faf5ff;
  --bg-section:     #f8fafc;
  --white:          #ffffff;
  --grad-primary:   linear-gradient(135deg,#7c3aed 0%,#4f46e5 50%,#7c3aed 100%);
  --grad-warm:      linear-gradient(135deg,#f59e0b 0%,#ef4444 100%);
  --shadow-sm:      0 4px 15px rgba(124,58,237,.10);
  --shadow-md:      0 8px 30px rgba(124,58,237,.15);
  --shadow-lg:      0 20px 60px rgba(124,58,237,.20);
  --radius:         16px;
  --radius-sm:      8px;
  --tr:             all .35s cubic-bezier(.4,0,.2,1);
}*/

:root {
    --primary: #b08968;
    --primary-light: #ddb892;
    --primary-dark: #7f5539;
    --secondary: #e5989b;
    --accent: #ffb4a2;
    --dark: #3a3a3a;
    --text: #4b4b4b;
    --text-light: #7a7a7a;
    --bg-light: #fff1e6;
    --bg-section: #fefae0;
    --white: #ffffff;
    --grad-primary: linear-gradient(135deg,#b08968,#ddb892);
    --grad-warm: linear-gradient(135deg,#ffb4a2,#ffcdb2);
    --shadow-sm: 0 4px 15px rgba(176,137,104,.10);
    --shadow-md: 0 8px 30px rgba(176,137,104,.15);
    --shadow-lg: 0 20px 60px rgba(176,137,104,.20);
    --radius: 16px;
    --radius-sm: 8px;
    --tr: all .35s cubic-bezier(.4,0,.2,1);
}
.text-primary {
    color: var(--primary) !important;
}
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:var(--text);background:#fff;}
h1,h2,h3,h4{font-weight:700;color:var(--dark)}
img{max-width:100%;height:auto}
a{transition:var(--tr)}

/* ── Typography helpers ───────────────────────── */
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--dark);line-height:1.2}
.section-subtitle{font-size:1.05rem;color:var(--text-light);max-width:620px;margin:0 auto}
.badge-pill{display:inline-block;background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:var(--primary);font-size:.78rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:5px 18px;border-radius:50px;margin-bottom:.8rem}
.fw-500{font-weight:500!important}
.fw-600{font-weight:600!important}
.fw-700{font-weight:700!important}
.fw-800{font-weight:800!important}

/* ── Topbar ───────────────────────────────────── */
.topbar{background:var(--dark);color:rgba(255,255,255,.8);font-size:.84rem}
.topbar .social-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;text-decoration:none;margin-left:6px;transition:var(--tr)}
.topbar .social-icon:hover{background:var(--primary);transform:translateY(-2px)}

/* ── Navbar ───────────────────────────────────── */
#mainNav{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);box-shadow:0 2px 20px rgba(0,0,0,.07);transition:var(--tr);z-index:1030;padding:.45rem 0}
#mainNav.scrolled{box-shadow:0 4px 30px rgba(124,58,237,.15)}
.logo-img{width:48px;height:48px;object-fit:cover;border-radius:50%;border:2.5px solid var(--primary-light)}
.brand-name{font-size:1.2rem;font-weight:700;background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}
.brand-tagline{font-size:.62rem;color:var(--text-light);letter-spacing:1.5px;text-transform:uppercase}

.navbar-nav .nav-link{font-weight:500;color:var(--dark)!important;padding:.55rem .85rem!important;border-radius:var(--radius-sm);transition:var(--tr);position:relative}
.navbar-nav .nav-link::after{content:'';position:absolute;bottom:2px;left:50%;width:0;height:2px;background:var(--primary);transition:var(--tr);transform:translateX(-50%);border-radius:2px}
.navbar-nav .nav-link:hover::after,.navbar-nav .nav-link.active::after{width:60%}
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--primary)!important;background:var(--bg-light)}

.btn-nav-cta{background:var(--grad-primary)!important;border:none!important;color:#fff!important;font-weight:600;font-size:.84rem;padding:.45rem 1.2rem!important;border-radius:50px!important;box-shadow:0 4px 15px rgba(124,58,237,.3);transition:var(--tr)!important}
.btn-nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(124,58,237,.4)!important}

.dropdown-menu-animated{border:none;border-radius:0 0 6px 6px;box-shadow:0 12px 40px rgba(0,0,0,.12);padding:.3rem 0;animation:dropIn .15s ease;border-top:3px solid var(--primary);min-width:248px;background:#fff}
@keyframes dropIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.dropdown-item{border-radius:0;padding:.58rem 1.3rem;font-size:.875rem;font-weight:500;transition:background .12s,padding-left .15s;color:var(--dark)}
.dropdown-item:hover{background:var(--bg-light);color:var(--primary);padding-left:1.4rem}

/* ── Buttons ──────────────────────────────────── */
.btn-primary{background:var(--grad-primary)!important;border:none!important;font-weight:600;border-radius:50px!important;padding:.65rem 1.8rem!important;box-shadow:var(--shadow-sm);transition:var(--tr)!important}
.btn-primary:hover,.btn-primary:focus{transform:translateY(-3px);box-shadow:var(--shadow-md)!important;opacity:.95}
.btn-outline-primary{border:2px solid var(--primary)!important;color:var(--primary)!important;font-weight:600;border-radius:50px!important;padding:.6rem 1.8rem!important;background:transparent!important;transition:var(--tr)!important}
.btn-outline-primary:hover{background:var(--primary)!important;color:#fff!important;transform:translateY(-3px)}
.btn-warning{background:var(--grad-warm)!important;border:none!important;color:#fff!important;font-weight:600;border-radius:50px!important}
.btn-warning:hover{transform:translateY(-2px);opacity:.92}
.btn-success{background:#25d366!important;border:none!important;font-weight:600;border-radius:50px!important}

/* ── Hero Slider ──────────────────────────────── */
.hero-swiper{position:relative;height:100vh;min-height:620px}
.hero-swiper .swiper-slide{position:relative;overflow:hidden}
.hero-slide-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 7s ease}
.swiper-slide-active .hero-slide-img{transform:scale(1)}
/*.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,26,46,.88) 0%,rgba(124,58,237,.35) 100%)}*/
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0,0,0,.45), rgba(0,0,0,.25));
}
.hero-content{position:relative;z-index:2;height:100%;display:flex;align-items:center}
.hero-badge{display:inline-block;background:rgba(245,158,11,.18);border:1px solid var(--secondary);color:var(--secondary);font-size:.78rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:5px 18px;border-radius:50px;margin-bottom:1.2rem;animation:fadeUp .8s ease .2s both}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,4.5rem);color:#fff;line-height:1.1;margin-bottom:1.2rem;animation:fadeUp .8s ease .4s both}
.hero-title span{color:var(--secondary)}
.hero-subtitle{font-size:1.08rem;color:rgba(255,255,255,.82);max-width:560px;margin-bottom:2rem;animation:fadeUp .8s ease .6s both;line-height:1.7}
.hero-buttons{animation:fadeUp .8s ease .8s both}
.hero-stats{display:flex;gap:2rem;margin-top:2.5rem;animation:fadeUp .8s ease 1s both}
.hero-stat-num{font-size:1.9rem;font-weight:800;color:var(--secondary);display:block}
.hero-stat-label{font-size:.72rem;color:rgba(255,255,255,.65);letter-spacing:1px;text-transform:uppercase}
.swiper-pagination-bullet{background:#fff;opacity:.5;width:10px;height:10px;transition:var(--tr)}
.swiper-pagination-bullet-active{background:var(--secondary);opacity:1;width:30px;border-radius:5px}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── Sections ─────────────────────────────────── */
.section-pad{padding:90px 0}
.section-pad-sm{padding:60px 0}
.bg-yoga{background:var(--bg-light)}

/* ── Service Cards ────────────────────────────── */
.service-card{background:#fff;border-radius:var(--radius);padding:2rem;height:100%;box-shadow:var(--shadow-sm);border:1px solid rgba(124,58,237,.07);transition:var(--tr);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-primary);transform:scaleX(0);transition:var(--tr);transform-origin:left}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{width:65px;height:65px;border-radius:50%;background:var(--bg-light);display:flex;align-items:center;justify-content:center;font-size:1.55rem;color:var(--primary);margin-bottom:1.2rem;transition:var(--tr)}
.service-card:hover .service-icon{background:var(--primary);color:#fff;transform:rotate(-10deg) scale(1.1)}
.service-card h5{font-size:1.12rem;margin-bottom:.55rem}
.service-card p{font-size:.88rem;color:var(--text-light);line-height:1.7}
.service-link{color:var(--primary);font-weight:600;font-size:.84rem;text-decoration:none;display:inline-flex;align-items:center;gap:5px;margin-top:.8rem;transition:var(--tr)}
.service-link:hover{gap:12px;color:var(--primary-dark)}

/* ── Feature Items ────────────────────────────── */
.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:1.1rem;background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:var(--tr);margin-bottom:1rem;border:1px solid rgba(0,0,0,.04)}
.feature-item:hover{transform:translateX(8px);box-shadow:var(--shadow-md)}
.feature-icon{width:50px;height:50px;border-radius:12px;background:var(--bg-light);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:1.25rem;flex-shrink:0;transition:var(--tr)}
.feature-item:hover .feature-icon{background:var(--primary);color:#fff}
.feature-item strong{display:block;font-size:.95rem;margin-bottom:.2rem}
.feature-item p{font-size:.83rem;margin:0;color:var(--text-light)}

/* ── Counter Section ──────────────────────────── */
.counter-section{background:var(--grad-primary)}
.counter-item{text-align:center;padding:2.2rem 1rem;border-right:1px solid rgba(255,255,255,.15)}
.counter-item:last-child{border-right:none}
.counter-num{font-size:2.8rem;font-weight:800;display:block;font-family:'Playfair Display',serif;color:#fff}
.counter-label{font-size:.88rem;color:rgba(255,255,255,.8);margin-top:.4rem;text-transform:uppercase;letter-spacing:1px}

/* ── Gallery ──────────────────────────────────── */
.gallery-filter .btn{border-radius:50px;padding:.38rem 1.3rem;font-size:.84rem;font-weight:500;margin:0 3px 6px;transition:var(--tr)}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer}
.gallery-item img{width:100%;height:240px;object-fit:cover;transition:transform .5s ease;display:block}
.gallery-item:hover img{transform:scale(1.12)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(124,58,237,.8) 0%,transparent 60%);opacity:0;transition:var(--tr);display:flex;align-items:center;justify-content:center}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay i{font-size:2rem;color:#fff}

/* ── Blog Cards ───────────────────────────────── */
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05);transition:var(--tr);height:100%;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.blog-card-img{width:100%;height:220px;object-fit:cover;transition:transform .5s ease;display:block}
.blog-card:hover .blog-card-img{transform:scale(1.06)}
.blog-card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.blog-category{display:inline-block;background:var(--bg-light);color:var(--primary);font-size:.73rem;font-weight:600;padding:3px 12px;border-radius:50px;margin-bottom:.65rem}
.blog-title{font-size:1.02rem;font-weight:700;line-height:1.45;margin-bottom:.55rem;color:var(--dark)}
.blog-title a{color:inherit;text-decoration:none}
.blog-title a:hover{color:var(--primary)}
.blog-meta{font-size:.78rem;color:var(--text-light)}

/* ── Testimonials ─────────────────────────────── */
.testimonial-card{background:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05);position:relative;height:100%}
.testimonial-card::before{content:'"';position:absolute;top:-8px;left:18px;font-size:5rem;font-family:serif;color:var(--primary-light);opacity:.25;line-height:1}
.testimonial-stars{color:var(--secondary);font-size:.88rem;margin-bottom:.8rem}
.testimonial-msg{font-size:.93rem;font-style:italic;color:var(--text);margin-bottom:1.2rem;line-height:1.75}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.15rem;flex-shrink:0}

/* ── Team Cards ───────────────────────────────── */
.team-card{text-align:center;background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;box-shadow:var(--shadow-sm);transition:var(--tr);border:1px solid rgba(0,0,0,.05)}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.team-img{width:130px;height:130px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-light);margin:0 auto 1rem;display:block;transition:var(--tr)}
.team-card:hover .team-img{border-color:var(--primary);transform:scale(1.05)}
.team-social a{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--bg-light);color:var(--primary);font-size:.8rem;text-decoration:none;margin:0 3px;transition:var(--tr)}
.team-social a:hover{background:var(--primary);color:#fff}

/* ── About page ───────────────────────────────── */
.about-image-wrap{position:relative;display:inline-block;width:100%}
.about-img-main{width:100%;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.about-badge-float{position:absolute;bottom:-20px;right:-20px;background:var(--grad-primary);color:#fff;padding:1rem 1.5rem;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-md)}
.about-badge-float .num{font-size:2rem;font-weight:800;display:block}

/* ── Service Detail ───────────────────────────── */
.service-detail-icon{width:80px;height:80px;border-radius:50%;background:var(--grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;margin-bottom:1.5rem}
.service-content{line-height:1.85;color:var(--text)}
.service-content h3{font-size:1.25rem;color:var(--primary);margin:1.5rem 0 .7rem}
.service-content ul{padding-left:1.4rem;margin-bottom:1.1rem}
.service-content ul li{margin-bottom:.45rem}
.service-content p{margin-bottom:1.1rem}

/* ── Video Cards ──────────────────────────────── */
.video-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--tr)}
.video-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.video-thumb-wrap{position:relative;overflow:hidden}
.video-thumb{width:100%;height:200px;object-fit:cover;display:block}
.video-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.28);transition:var(--tr)}
.video-play-btn i{width:58px;height:58px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.3rem;transition:var(--tr);padding-left:4px}
.video-thumb-wrap:hover .video-play-btn{background:rgba(0,0,0,.46)}
.video-thumb-wrap:hover .video-play-btn i{transform:scale(1.1);background:var(--primary-dark)}

/* ── Blog Detail ──────────────────────────────── */
.blog-detail-content{font-size:1rem;line-height:1.9;color:var(--text)}
.blog-detail-content h3,.blog-detail-content h4{color:var(--primary);margin:1.8rem 0 .8rem}
.blog-detail-content ul,.blog-detail-content ol{padding-left:1.5rem;margin-bottom:1.2rem}
.blog-detail-content li{margin-bottom:.4rem}
.blog-detail-content p{margin-bottom:1.2rem}
.blog-detail-content strong{color:var(--dark)}

/* ── CTA Section ──────────────────────────────── */
.cta-section{background:var(--grad-primary);border-radius:2rem;padding:4rem 3rem;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.06);top:-120px;right:-80px;pointer-events:none}
.cta-section::after{content:'';position:absolute;width:250px;height:250px;border-radius:50%;background:rgba(255,255,255,.04);bottom:-80px;left:-50px;pointer-events:none}

/* ── Page Header ──────────────────────────────── */
.page-header{background:linear-gradient(135deg,var(--dark) 0%,var(--primary-dark) 100%);padding:110px 0 75px;position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:rgba(124,58,237,.18);top:-200px;right:-100px;pointer-events:none}
.page-header-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,4vw,3rem);color:#fff;margin-bottom:.5rem}
.breadcrumb{background:none;padding:0;margin:0}
.breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.4)}
.breadcrumb-item a{color:rgba(255,255,255,.65);text-decoration:none}
.breadcrumb-item a:hover{color:#fff}
.breadcrumb-item.active{color:var(--secondary)}

/* ── Contact ──────────────────────────────────── */
.contact-form-card{background:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow-md)}
.form-control,.form-select{border:1.5px solid rgba(0,0,0,.1)!important;border-radius:var(--radius-sm)!important;padding:.72rem 1rem!important;font-size:.9rem;transition:var(--tr)}
.form-control:focus,.form-select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px rgba(124,58,237,.1)!important}
.contact-info-card{background:var(--grad-primary);border-radius:var(--radius);padding:2.5rem;color:#fff}
.contact-info-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.contact-info-icon{width:44px;height:44px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.05rem}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}

/* ── Accordion / FAQ ──────────────────────────── */
.accordion-item{border:none!important;margin-bottom:10px;border-radius:var(--radius-sm)!important;overflow:hidden;box-shadow:var(--shadow-sm)}
.accordion-button{font-weight:600;background:#fff!important;color:var(--dark)!important}
.accordion-button:not(.collapsed){color:var(--primary)!important;box-shadow:none!important}

/* ── Footer ───────────────────────────────────── */
.footer-main{background:var(--dark);color:rgba(255,255,255,.78)}
.footer-top{padding:70px 0 50px}
.footer-logo{width:45px;height:45px;border-radius:50%;object-fit:cover}
.footer-desc{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.85;margin-top:.8rem}
.footer-title{color:#fff;font-weight:700;margin-bottom:1.2rem;padding-bottom:.45rem;border-bottom:2px solid var(--primary);display:inline-block}
.footer-links{list-style:none;padding:0}
.footer-links li{margin-bottom:.5rem}
.footer-links a{color:rgba(255,255,255,.55);text-decoration:none;font-size:.88rem;transition:var(--tr);display:inline-flex;align-items:center;gap:6px}
.footer-links a:hover{color:var(--secondary);padding-left:8px}
.footer-contact{list-style:none;padding:0}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;margin-bottom:.9rem;font-size:.88rem}
.footer-contact i{color:var(--secondary);margin-top:3px;flex-shrink:0}
.footer-contact a{color:rgba(255,255,255,.65);text-decoration:none;transition:var(--tr)}
.footer-contact a:hover{color:var(--secondary)}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:.88rem;text-decoration:none;margin-right:7px;transition:var(--tr)}
.footer-social a:hover{background:var(--primary);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);font-size:.83rem;color:rgba(255,255,255,.45)}

/* ── WhatsApp Float ───────────────────────────── */
.whatsapp-float{position:fixed;bottom:88px;right:24px;width:54px;height:54px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.55rem;text-decoration:none;box-shadow:0 6px 20px rgba(37,211,102,.4);z-index:998;transition:var(--tr);animation:waPulse 2.5s infinite}
.whatsapp-float:hover{transform:scale(1.12);color:#fff}
@keyframes waPulse{0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.4)}50%{box-shadow:0 6px 32px rgba(37,211,102,.72)}}

/* ── Back to Top ──────────────────────────────── */
.back-to-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--primary);color:#fff;border:none;border-radius:50%;cursor:pointer;opacity:0;visibility:hidden;transition:var(--tr);box-shadow:var(--shadow-sm);z-index:997}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{background:var(--primary-dark);transform:translateY(-3px)}

/* ── Page Loader ──────────────────────────────── */
.page-loader{position:fixed;inset:0;background:#fff;z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .5s ease}
.page-loader.hidden{opacity:0;pointer-events:none}
.loader-spin{font-size:3.5rem;animation:loaderSpin 1.2s linear infinite}
@keyframes loaderSpin{to{transform:rotate(360deg)}}

/* ── Responsive ───────────────────────────────── */
@media(max-width:991px){
  .about-badge-float{position:static;margin-top:1.5rem;display:inline-block}
  .counter-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .counter-item:last-child{border-bottom:none}
}
@media(max-width:768px){
  .hero-swiper{height:80vh;min-height:560px}
  .hero-stats{gap:1.5rem}
  .hero-stat-num{font-size:1.5rem}
  .section-pad{padding:60px 0}
  .page-header{padding:90px 0 55px}
  .cta-section{padding:2.5rem 1.5rem;border-radius:1.2rem}
  .contact-form-card{padding:1.6rem}
  .gallery-item img{height:180px}
}

/* ============================================================
   Additions v2-v5: Loader, mobile nav, events, booking, captcha
   ============================================================ */

/* ── LOADER FIX ──────────────────────────────────────────────── */
.page-loader{position:fixed;inset:0;background:#fff;z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.loader-spin{font-size:3.5rem;animation:loaderSpin 1.2s linear infinite;display:block}
.loader-text{color:var(--primary);font-weight:600;letter-spacing:1px;margin-top:.8rem;font-size:1rem}
@keyframes loaderSpin{to{transform:rotate(360deg)}}

/* ── NO HORIZONTAL SCROLL ────────────────────────────────────── */
/* overflow-x on html/body removed - it breaks position:sticky */
/* Use overflow:clip on non-sticky containers instead */
body{overflow-x:clip}

/* ── NAVBAR: sticky, always visible ─────────────────────────── */
#mainNav{position:sticky!important;top:0!important;transform:translateZ(0)!important;transition:box-shadow .3s ease,background .3s ease!important;will-change:box-shadow;z-index:1030!important}
#mainNav.scrolled{box-shadow:0 4px 20px rgba(176,137,104,.18)!important;background:rgba(255,255,255,.99)!important}

/* ── CUSTOM TOGGLER ──────────────────────────────────────────── */
.custom-toggler{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:0;cursor:pointer;background:var(--bg-light)!important;border-radius:8px!important}
.custom-toggler span{display:block;height:2px;width:22px;margin:0 auto;background:var(--primary);border-radius:2px;transition:all .3s ease}
.custom-toggler[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.custom-toggler[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.custom-toggler[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── NAV DROPDOWN ARROW ─────────────────────────────────────── */
.nav-has-dropdown{display:flex!important;align-items:center;gap:4px}
.nav-has-dropdown .dd-arrow{font-size:.6rem;transition:transform .25s ease;margin-left:2px!important;flex-shrink:0}

/* ── NAV MOBILE ICON ─────────────────────────────────────────── */
.nav-mob-icon{display:none!important}

/* ── DESKTOP DROPDOWN: hover-open, sharp, theme-colored ─────── */
@media(min-width:992px){
  /* Hover opens dropdown */
  .navbar-nav .dropdown:hover > .dropdown-menu-animated{display:block!important}

  /* Sharp clean dropdown matching amber/brown theme */
  .dropdown-menu-animated{
    border:none!important;
    border-radius:0 0 6px 6px!important;
    border-top:3px solid var(--primary)!important;
    box-shadow:0 12px 40px rgba(0,0,0,.12)!important;
    padding:.3rem 0!important;
    min-width:248px;
    animation:dropIn .15s ease!important;
    background:#fff!important;
  }
  .dropdown-item{
    border-radius:0!important;
    padding:.58rem 1.3rem!important;
    font-size:.875rem;
    font-weight:500;
    color:var(--dark)!important;
    transition:background .12s,padding-left .15s;
  }
  .dropdown-item:hover{
    background:var(--bg-light)!important;
    color:var(--primary)!important;
    padding-left:1.7rem!important;
  }
  /* Icon color in dropdown */
  .dropdown-item i{color:var(--primary)!important}
  .dropdown-divider{margin:.2rem 0}

  /* Arrow rotates down on hover */
  .navbar-nav .dropdown:hover > .nav-has-dropdown .dd-arrow{transform:rotate(180deg)!important}
  .nav-has-dropdown[aria-expanded="true"] .dd-arrow{transform:rotate(0deg)!important}
}

/* ── MOBILE NAV: accordion style with icons ─────────────────── */
@media(max-width:991px){
  #navbarMain{background:#fff;border-top:2px solid var(--bg-light);padding:.5rem 0;max-height:85vh;overflow-y:auto}
  .navbar-nav{padding:0 .5rem}
  .navbar-nav .nav-item{border-bottom:1px solid rgba(0,0,0,.05)}
  .navbar-nav .nav-item:last-child{border-bottom:none}
  .navbar-nav .nav-link{display:flex!important;align-items:center;gap:10px;padding:.75rem 1rem!important;border-radius:10px;font-size:.95rem;font-weight:500;color:var(--dark)!important}
  .navbar-nav .nav-link:hover{background:var(--bg-light)}
  .nav-mob-icon{display:inline-flex!important;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:var(--bg-light);color:var(--primary);font-size:.85rem;flex-shrink:0}

  /* Mobile dropdown via .mob-open (JS controlled) */
  /* Mobile dropdown — theme warm amber colors */
  .dropdown-menu-animated{
    display:none!important;
    position:static!important;float:none;
    box-shadow:none!important;
    border:none!important;
    border-radius:0!important;
    background:var(--bg-light)!important;  /* warm cream bg */
    padding:.25rem .4rem .5rem 2.2rem!important;
    margin:0!important;
    animation:none!important;
    border-left:3px solid var(--primary)!important; /* amber left border */
    margin-left:.85rem!important;
  }
  .dropdown-menu-animated.mob-open{display:block!important}

  .nav-has-dropdown .dd-arrow{margin-left:auto!important;font-size:.7rem;color:var(--primary)}
  .nav-has-dropdown.mob-active .dd-arrow{transform:rotate(180deg)!important}

  /* Mobile dropdown items — theme colors */
  .dropdown-menu-animated .dropdown-item{
    border-radius:6px!important;
    padding:.52rem .75rem!important;
    font-size:.875rem;
    color:var(--text)!important;
    background:transparent!important;
    margin-bottom:1px;
  }
  .dropdown-menu-animated .dropdown-item:hover{
    background:rgba(176,137,104,.12)!important;
    color:var(--primary)!important;
    padding-left:1.1rem!important;
  }
  .dropdown-menu-animated .dropdown-item i{
    color:var(--primary)!important;
    opacity:.85;
  }

  .btn-nav-cta{display:block!important;text-align:center!important;margin:.5rem 1rem!important;border-radius:10px!important}
  .navbar-nav .nav-item.ms-lg-2{border-bottom:none!important}
}

/* ── EVENTS ──────────────────────────────────────────────────── */
.event-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05);transition:var(--tr);height:100%;display:flex;flex-direction:column}
.event-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.event-card-img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .5s ease}
.event-card:hover .event-card-img{transform:scale(1.06)}
.event-date-badge{position:absolute;top:12px;left:12px;background:var(--primary);color:#fff;border-radius:10px;padding:6px 12px;text-align:center;line-height:1.2}
.event-date-badge .day{font-size:1.4rem;font-weight:800;display:block}
.event-date-badge .month{font-size:.7rem;text-transform:uppercase;letter-spacing:1px}
.event-type-badge{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.6);color:#fff;font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:50px}
.event-body{padding:1.3rem;flex:1;display:flex;flex-direction:column}
.event-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:.8rem}
.event-meta span{font-size:.8rem;color:var(--text-light);display:flex;align-items:center;gap:4px}
.event-price{font-size:1.2rem;font-weight:800;color:var(--primary)}
.event-price.free{color:var(--accent)}
.event-seats{font-size:.78rem;color:var(--text-light)}

/* ── BOOKING SLOT BUTTONS ────────────────────────────────────── */
.booking-slot-btn{border:2px solid #e5e7eb;border-radius:10px;padding:.6rem 1.2rem;cursor:pointer;text-align:center;font-size:.88rem;font-weight:500;color:var(--text);transition:var(--tr);background:#fff;width:100%}
.booking-slot-btn:hover,.booking-slot-btn.selected{border-color:var(--primary);background:var(--bg-light);color:var(--primary);font-weight:600}
.booking-slot-btn.selected{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}

/* ── CAPTCHA ─────────────────────────────────────────────────── */
.captcha-wrap{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--bg-light);border-radius:12px;padding:12px}
.captcha-img{border-radius:8px;border:1.5px solid rgba(176,137,104,.3);cursor:pointer}
.captcha-refresh{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:5px;padding:.3rem .8rem;border-radius:8px;transition:var(--tr)}
.captcha-refresh:hover{background:var(--primary);color:#fff}
.captcha-input{border:1.5px solid #e5e7eb!important;border-radius:8px!important;font-size:1rem!important;font-weight:700!important;letter-spacing:3px!important;width:120px!important;text-transform:uppercase!important}
.captcha-input:focus{border-color:var(--primary)!important}

/* ── SERVICE CARD WITH IMAGE ─────────────────────────────────── */
.service-card.has-image{padding:0}
.service-card-img-wrap{overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;height:200px}
.service-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.service-card:hover .service-card-img-wrap img{transform:scale(1.08)}
.service-card.has-image .service-card-content{padding:1.4rem}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:768px){
  .hero-swiper{height:80vh;min-height:560px}
  .section-pad{padding:60px 0}
  .page-header{padding:90px 0 55px}
  .cta-section{padding:2.5rem 1.5rem;border-radius:1.2rem}
}
