/* ============================================================
   TANISHA HOLIDAYS — Global Stylesheet
   style.css
   All pages link this file. No inline CSS needed anywhere.
   ============================================================ */

/* ── VARIABLES ── */
:root{
  --primary:#1e3a8a; --primary-dark:#0f172a; --primary-light:#3b82f6;
  --accent:#f59e0b; --accent-light:#fcd34d;
  --dark:#020617; --light-bg:#f8fafc;
  --text-main:#1e293b; --text-muted:#64748b; --border:#e2e8f0;
}

/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'DM Sans',sans-serif;color:var(--text-main);background:#fff;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Playfair Display',serif;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px;}

/* ── TOPBAR ── */
.topbar{background:var(--primary-dark);color:#cbd5e1;font-size:.8rem;padding:6px 0;}
.topbar a{color:#cbd5e1;text-decoration:none;}
.topbar a:hover{color:var(--accent-light);}
.ti{color:var(--accent);margin-right:4px;}

/* ── NAVBAR ── */
.navbar-main{background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.08);padding:0;position:sticky;top:0;z-index:1040;transition:box-shadow .3s;}
.navbar-main .container{position:relative;}
.navbar-main.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.14);}
.brand-logo{display:flex;align-items:center;gap:10px;text-decoration:none;padding:10px 0;}
.brand-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;box-shadow:0 4px 12px rgba(30,58,138,.3);flex-shrink:0;}
.brand-text-main{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:var(--primary-dark);line-height:1.1;}
.brand-text-sub{font-size:.66rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:1.4px;}
.navbar-nav .nav-link{font-size:.85rem;font-weight:600;color:var(--text-main)!important;padding:22px 13px!important;text-transform:uppercase;letter-spacing:.5px;position:relative;transition:color .2s;}
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--primary)!important;}
.navbar-nav .nav-link::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:3px;background:var(--accent);border-radius:2px 2px 0 0;transition:width .3s;transform:translateX(-50%);}
.navbar-nav .nav-link:hover::after{width:65%;}
.has-mega{position:static!important;}
.mega-menu{position:absolute;left:0;right:0;background:#fff;border-top:3px solid var(--primary);box-shadow:0 20px 60px rgba(0,0,0,.15);border-radius:0 0 16px 16px;padding:28px 36px;z-index:1050;display:none;top:100%;}
.has-mega:hover .mega-menu{display:block;}
.mega-col-title{font-family:'Playfair Display',serif;font-size:.9rem;font-weight:700;color:var(--primary-dark);border-bottom:2px solid var(--accent);padding-bottom:7px;margin-bottom:10px;}
.mega-link{display:block;padding:5px 0;font-size:.82rem;color:var(--text-main);text-decoration:none;font-weight:500;transition:color .2s,padding-left .2s;}
.mega-link:hover{color:var(--primary);padding-left:6px;}
.mega-promo{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border-radius:12px;padding:18px;font-size:.83rem;}
.mega-promo h6{font-family:'Playfair Display',serif;font-size:1rem;margin-bottom:7px;}
.mega-promo .btn-mp{background:var(--accent);border:none;color:#fff;font-size:.78rem;font-weight:700;padding:7px 16px;border-radius:6px;cursor:pointer;}
.nav-cta{background:linear-gradient(135deg,var(--accent),#d97706)!important;color:#fff!important;border-radius:8px!important;padding:9px 18px!important;font-weight:700!important;font-size:.83rem!important;margin-left:6px;box-shadow:0 4px 14px rgba(245,158,11,.38);}
.nav-cta::after{display:none!important;}
.nav-cta:hover{transform:translateY(-2px)!important;}

/* ── MOBILE MENU ── */
@media(max-width:991px){
  .mega-menu{display:none!important;position:static!important;}
  .navbar-nav .nav-link{padding:12px 16px!important;border-bottom:1px solid #f1f5f9;font-size:.9rem;}
  .navbar-nav .nav-link::after{display:none;}
  .mobile-sub{display:none;padding:8px 8px 8px 20px;background:#f8fafc;border-left:3px solid var(--accent);margin:0 16px 8px;}
  .mobile-sub.open{display:block;}
  .mobile-sub a{display:block;padding:7px 10px;font-size:.83rem;color:var(--text-main);text-decoration:none;font-weight:500;transition:color .2s;}
  .mobile-sub a:hover{color:var(--primary);}
  .mobile-sub-title{font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--accent);padding:8px 10px 4px;margin-top:6px;}
  .nav-toggle-btn{display:flex;align-items:center;justify-content:space-between;width:100%;}
  .nav-toggle-btn .chevron{font-size:.65rem;transition:transform .3s;}
  .nav-toggle-btn.active .chevron{transform:rotate(180deg);}
  .nav-cta{margin:8px 16px 14px!important;display:block;text-align:center;border-radius:8px!important;}
  .topbar{display:none;}
  #navMenu{max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;}
}

/* ── PAGE HERO (inner pages) ── */
.page-hero{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);padding:72px 0 60px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:350px;height:350px;border-radius:50%;background:rgba(255,255,255,.05);}
.page-hero::after{content:'';position:absolute;bottom:-60px;left:-40px;width:250px;height:250px;border-radius:50%;background:rgba(255,255,255,.04);}
.page-hero-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:900;color:#fff;margin-bottom:12px;}
.page-hero-sub{font-size:1.05rem;color:rgba(255,255,255,.82);font-weight:300;max-width:580px;line-height:1.72;}
.breadcrumb-item a{color:var(--accent-light);text-decoration:none;}
.breadcrumb-item.active{color:rgba(255,255,255,.7);}
.breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.45);}

/* ── HERO (home page) ── */
.hero-section{position:relative;height:100vh;min-height:620px;overflow:hidden;}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease-in-out,transform 9s ease-in-out;transform:scale(1.06);}
.hero-slide.active{opacity:1;transform:scale(1);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(5,10,30,.93) 0%,rgba(15,30,90,.82) 45%,rgba(5,10,30,.65) 100%);}
.hero-content{position:relative;z-index:5;height:100%;display:flex;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(245,158,11,.18);border:1px solid var(--accent);color:var(--accent-light);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:6px 16px;border-radius:50px;margin-bottom:16px;backdrop-filter:blur(8px);}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,4rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:16px;text-shadow:0 2px 20px rgba(0,0,0,.5);}
.hero-title .aw{color:var(--accent-light);font-style:italic;}
.hero-sub{font-size:clamp(.9rem,1.8vw,1.08rem);color:rgba(255,255,255,.87);max-width:520px;margin-bottom:28px;line-height:1.75;font-weight:300;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:24px;margin-top:36px;padding-top:24px;border-top:1px solid rgba(255,255,255,.2);flex-wrap:wrap;}
.hstat-num{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:900;color:var(--accent-light);line-height:1;}
.hstat-lbl{font-size:.75rem;color:rgba(255,255,255,.7);font-weight:500;margin-top:2px;}
.hero-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:10;}
.hero-dot{width:8px;height:8px;background:rgba(255,255,255,.4);border-radius:50%;cursor:pointer;transition:all .3s;border:none;padding:0;}
.hero-dot.active{background:var(--accent);width:22px;border-radius:4px;}

/* ── HERO FORM ── */
.hero-form-card{background:rgba(255,255,255,.97);border-radius:18px;padding:24px 22px;box-shadow:0 20px 60px rgba(0,0,0,.4);border-top:4px solid var(--accent);}
.hf-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--primary-dark);margin-bottom:14px;}
.hf-lbl{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);display:block;margin-bottom:4px;}
.hf-inp{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.85rem;color:var(--text-main);font-family:'DM Sans',sans-serif;transition:border-color .2s;outline:none;background:#fff;appearance:auto;}
.hf-inp:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,58,138,.1);}
.hf-btn{width:100%;background:linear-gradient(135deg,#25D366,#1da851);color:#fff;border:none;border-radius:10px;padding:12px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s;font-family:'DM Sans',sans-serif;box-shadow:0 4px 14px rgba(37,211,102,.38);}
.hf-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(37,211,102,.5);}
.hero-form-mobile{background:#fff;padding:20px;margin:-10px 0 0;}

/* ── BOOKING BAR ── */
.booking-bar-wrap{background:#f1f5f9;padding:0 0 48px;}
.booking-bar{background:#fff;box-shadow:0 8px 40px rgba(0,0,0,.1);border-radius:16px;margin-top:-50px;position:relative;z-index:100;padding:22px 28px;border-top:4px solid var(--primary);}
.bb-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--primary-dark);margin-bottom:16px;}
.bb-lbl{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:4px;display:block;}
.booking-bar .form-control,.booking-bar .form-select{border:1.5px solid var(--border);border-radius:8px;font-size:.86rem;padding:10px 13px;color:var(--text-main);transition:border-color .2s;}
.booking-bar .form-control:focus,.booking-bar .form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,58,138,.1);outline:none;}
.btn-bb-submit{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:10px;padding:12px;font-weight:700;font-size:.93rem;width:100%;transition:all .3s;box-shadow:0 4px 14px rgba(30,58,138,.28);cursor:pointer;}
.btn-bb-submit:hover{background:var(--primary-dark);transform:translateY(-2px);}

/* ── SECTION HELPERS ── */
.sec-py{padding:78px 0;}
.sec-py-sm{padding:54px 0;}
.bg-lt{background:#f1f5f9;}
.bg-cr{background:var(--light-bg);}
.sec-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(30,58,138,.09);color:var(--primary);font-size:.73rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:50px;margin-bottom:10px;}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3.5vw,2.7rem);font-weight:900;color:var(--primary-dark);margin-bottom:12px;line-height:1.15;}
.sec-sub{font-size:1rem;color:var(--text-muted);max-width:590px;line-height:1.72;font-weight:300;}
.acc-line{width:56px;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:2px;margin:12px 0;}
.acc-line.c{margin:12px auto;}

/* ── BUTTONS ── */
.btn-hp{background:linear-gradient(135deg,var(--accent),#d97706);color:#fff;font-weight:700;padding:13px 28px;border-radius:10px;border:none;font-size:.92rem;box-shadow:0 6px 22px rgba(245,158,11,.45);transition:all .3s;text-decoration:none;display:inline-block;cursor:pointer;}
.btn-hp:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(245,158,11,.6);color:#fff;}
.btn-ho{background:rgba(255,255,255,.12);color:#fff;font-weight:600;padding:13px 28px;border-radius:10px;border:2px solid rgba(255,255,255,.5);font-size:.92rem;backdrop-filter:blur(8px);transition:all .3s;text-decoration:none;display:inline-block;}
.btn-ho:hover{background:rgba(255,255,255,.22);border-color:#fff;color:#fff;}
.btn-cw{background:#fff;color:var(--primary-dark);font-weight:700;padding:13px 30px;border-radius:10px;border:none;font-size:.92rem;transition:all .3s;text-decoration:none;display:inline-block;cursor:pointer;}
.btn-cw:hover{background:var(--accent-light);transform:translateY(-2px);}
.btn-co{background:transparent;color:#fff;font-weight:700;padding:13px 30px;border-radius:10px;border:2px solid rgba(255,255,255,.5);font-size:.92rem;transition:all .3s;text-decoration:none;display:inline-block;}
.btn-co:hover{border-color:#fff;background:rgba(255,255,255,.15);color:#fff;}

/* ── WHY STRIP ── */
.why-strip{background:linear-gradient(135deg,var(--primary-dark),var(--primary));padding:38px 0;overflow:hidden;}
.why-item{display:flex;align-items:center;gap:14px;color:#fff;padding:10px 18px;}
.why-icon{width:50px;height:50px;background:rgba(255,255,255,.14);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.why-title{font-weight:700;font-size:.92rem;margin-bottom:2px;}
.why-sub{font-size:.77rem;color:rgba(255,255,255,.7);}
.why-div{width:1px;background:rgba(255,255,255,.18);height:54px;}

/* ── DEST CARDS ── */
.dest-card{border-radius:16px;overflow:hidden;position:relative;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px rgba(0,0,0,.1);}
.dest-card:hover{transform:translateY(-6px);box-shadow:0 16px 44px rgba(0,0,0,.2);}
.dest-card-img{width:100%;height:260px;object-fit:cover;display:block;transition:transform .5s;}
.dest-card:hover .dest-card-img{transform:scale(1.06);}
.dco{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(2,6,23,.92) 0%,transparent 100%);padding:18px;}
.dco-tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent-light);margin-bottom:3px;}
.dco-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:3px;}
.dco-count{font-size:.77rem;color:rgba(255,255,255,.7);}

/* ── TOUR CARDS ── */
.tour-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 18px rgba(0,0,0,.07);transition:all .3s;border:1px solid var(--border);height:100%;display:flex;flex-direction:column;}
.tour-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.12);transform:translateY(-4px);}
.tci{position:relative;overflow:hidden;}
.tour-card-img{width:100%;height:210px;object-fit:cover;transition:transform .5s;display:block;}
.tour-card:hover .tour-card-img{transform:scale(1.05);}
.t-badge{position:absolute;top:12px;left:12px;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;padding:4px 11px;border-radius:20px;text-transform:uppercase;letter-spacing:.7px;}
.t-badge.hot{background:#ef4444;}
.t-badge.new{background:var(--accent);}
.t-badge.gem{background:#7c3aed;}
.t-body{padding:18px;flex:1;display:flex;flex-direction:column;}
.t-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--primary-dark);margin-bottom:7px;line-height:1.3;}
.t-meta{display:flex;gap:12px;margin-bottom:10px;flex-wrap:wrap;}
.t-mi{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-muted);font-weight:500;}
.t-mi i{color:var(--primary);}
.t-desc{font-size:.83rem;color:var(--text-muted);line-height:1.65;flex:1;margin-bottom:12px;}
.t-tags{display:flex;flex-wrap:wrap;gap:5px;}
.t-tag{background:#f1f5f9;color:var(--primary-dark);font-size:.7rem;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid var(--border);}
.t-foot{display:flex;gap:8px;padding:13px 18px;border-top:1px solid var(--border);background:var(--light-bg);}
.btn-exp{flex:1;background:transparent;color:var(--primary);font-weight:700;border:1.5px solid var(--primary);border-radius:8px;padding:9px 10px;font-size:.79rem;text-align:center;text-decoration:none;transition:all .2s;display:block;font-family:'DM Sans',sans-serif;cursor:pointer;}
.btn-exp:hover{background:var(--primary);color:#fff;}
.btn-bk{flex:1;background:linear-gradient(135deg,var(--accent),#d97706);color:#fff;font-weight:700;border:none;border-radius:8px;padding:9px 10px;font-size:.79rem;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;}
.btn-bk:hover{background:var(--primary-dark);}

/* ── WILDLIFE CARDS ── */
.wc{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;}
.wc img{width:100%;height:185px;object-fit:cover;transition:transform .4s;display:block;}
.wc:hover img{transform:scale(1.08);}
.wco{position:absolute;inset:0;background:linear-gradient(to top,rgba(2,6,23,.85) 0%,transparent 60%);display:flex;align-items:flex-end;padding:12px;}
.wc-name{font-family:'Playfair Display',serif;font-weight:700;color:#fff;font-size:.93rem;}

/* ── GALLERY ── */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:195px 195px;gap:10px;overflow:hidden;}
.gi{overflow:hidden;border-radius:12px;cursor:pointer;position:relative;}
.gi.s2{grid-column:span 2;}
.gi.r2{grid-row:span 2;}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .5s;display:block;}
.gi:hover img{transform:scale(1.09);}
.gi-hover{position:absolute;inset:0;background:rgba(30,58,138,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;color:#fff;font-size:1.8rem;}
.gi:hover .gi-hover{opacity:1;}

/* ── ACTIVITY CARDS ── */
.ac{background:#fff;border-radius:14px;padding:22px 16px;text-align:center;border:1.5px solid var(--border);transition:all .3s;cursor:pointer;}
.ac:hover{border-color:var(--primary);box-shadow:0 8px 28px rgba(30,58,138,.1);transform:translateY(-4px);}
.ac-icon{width:62px;height:62px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.7rem;margin:0 auto 12px;transition:all .3s;}
.ac:hover .ac-icon{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;}
.ac-name{font-weight:700;font-size:.92rem;color:var(--primary-dark);margin-bottom:3px;}
.ac-sub{font-size:.77rem;color:var(--text-muted);}

/* ── TESTIMONIALS ── */
.testimonial-card{background:#fff;border-radius:16px;padding:26px;box-shadow:0 4px 24px rgba(0,0,0,.07);border:1px solid var(--border);position:relative;}
.tq{font-size:2.8rem;line-height:1;color:var(--accent);font-family:'Playfair Display',serif;position:absolute;top:14px;right:20px;opacity:.3;}
.tt{font-size:.9rem;line-height:1.75;color:var(--text-muted);margin-bottom:16px;font-style:italic;}
.ta{display:flex;align-items:center;gap:11px;}
.tav{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;flex-shrink:0;}
.tn{font-weight:700;font-size:.87rem;color:var(--primary-dark);}
.tl{font-size:.75rem;color:var(--text-muted);}
.sr{color:var(--accent);font-size:.83rem;}

/* ── BLOG CARDS ── */
.blog-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 15px rgba(0,0,0,.06);transition:all .3s;border:1px solid var(--border);}
.blog-card:hover{box-shadow:0 10px 33px rgba(0,0,0,.11);transform:translateY(-3px);}
.blog-card img{width:100%;height:175px;object-fit:cover;display:block;}
.blog-body{padding:16px;}
.bc{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary);margin-bottom:5px;}
.bt{font-family:'Playfair Display',serif;font-size:.97rem;font-weight:700;color:var(--primary-dark);margin-bottom:7px;line-height:1.35;}
.brm{color:var(--primary);font-size:.8rem;font-weight:700;text-decoration:none;}
.brm:hover{color:var(--accent);}

/* ── CTA ── */
.cta-section{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,var(--primary-light) 100%);position:relative;overflow:hidden;padding:80px 0;max-width:100vw;}
.cta-section::before{content:'';position:absolute;top:-60px;right:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.05);}

/* ── MODAL ── */
.modal-content{border-radius:20px;border:none;overflow:hidden;}
.modal-hdr{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;padding:22px 26px;border:none;}
.modal-hdr h5{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;}
.modal .modal-body{padding:26px;}
.fl{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:5px;display:block;}
.fc{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 13px;font-size:.86rem;font-family:'DM Sans',sans-serif;color:var(--text-main);transition:border-color .2s;outline:none;background:#fff;appearance:auto;}
.fc:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,58,138,.1);}
.btn-fs{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:10px;padding:13px;font-weight:700;font-size:.95rem;width:100%;transition:all .3s;cursor:pointer;font-family:'DM Sans',sans-serif;}
.btn-fs:hover{background:var(--primary-dark);transform:translateY(-2px);}

/* ── LEAD FORM ── */
.lf-card{background:#fff;border-radius:20px;padding:36px;box-shadow:0 8px 40px rgba(0,0,0,.08);border-top:5px solid var(--primary);}

/* ── COUNTER ── */
.counter-section{background:linear-gradient(135deg,var(--primary-dark),var(--primary));padding:56px 0;overflow:hidden;}
.c-num{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,4vw,3rem);font-weight:900;color:var(--accent-light);line-height:1;}
.c-lbl{font-size:.87rem;color:rgba(255,255,255,.75);margin-top:6px;font-weight:500;}

/* ── FILTER TABS ── */
.filter-tabs{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:28px;}
.filter-tab{padding:7px 18px;border-radius:50px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;border:1.5px solid var(--border);background:#fff;color:var(--text-muted);font-family:'DM Sans',sans-serif;}
.filter-tab:hover,.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);}

/* ── TRUST ── */
.trust-section{background:#fff;padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.trust-icon{font-size:1.9rem;color:var(--primary);margin-bottom:5px;}
.trust-title{font-weight:700;font-size:.85rem;color:var(--primary-dark);}
.trust-sub{font-size:.75rem;color:var(--text-muted);}

/* ── REGION PILLS ── */
.rpill{display:inline-flex;align-items:center;gap:7px;padding:8px 17px;background:#fff;border:1.5px solid var(--border);border-radius:50px;font-size:.82rem;font-weight:600;color:var(--primary-dark);cursor:pointer;transition:all .2s;text-decoration:none;}
.rpill:hover{background:var(--primary);color:#fff;border-color:var(--primary);}

/* ── WHATSAPP FLOAT ── */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:9px;}
.wa-btn{width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.65rem;box-shadow:0 6px 24px rgba(37,211,102,.48);cursor:pointer;transition:all .3s;text-decoration:none;animation:wap 2.5s infinite;}
@keyframes wap{0%,100%{box-shadow:0 6px 24px rgba(37,211,102,.48);}50%{box-shadow:0 6px 34px rgba(37,211,102,.72),0 0 0 10px rgba(37,211,102,.1);}}
.wa-btn:hover{transform:scale(1.1);color:#fff;}
.wa-bubble{background:#fff;border-radius:12px;padding:8px 14px;font-size:.78rem;font-weight:600;color:var(--primary-dark);box-shadow:0 4px 18px rgba(0,0,0,.14);white-space:nowrap;display:none;max-width:calc(100vw - 100px);}
.wa-float:hover .wa-bubble{display:block;}

/* ── FOOTER ── */
.footer{background:var(--dark);color:rgba(255,255,255,.75);}
.footer-top{padding:56px 0 36px;}
.fb{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:#fff;}
.fdesc{font-size:.82rem;line-height:1.76;color:rgba(255,255,255,.6);margin:12px 0 16px;}
.fsoc a{width:34px;height:34px;background:rgba(255,255,255,.09);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.67);text-decoration:none;font-size:.9rem;transition:all .2s;margin-right:5px;}
.fsoc a:hover{background:var(--primary);color:#fff;}
.fct{font-weight:700;font-size:.84rem;text-transform:uppercase;letter-spacing:1.4px;color:var(--accent-light);margin-bottom:14px;}
.fl2{list-style:none;padding:0;margin:0;}
.fl2 li{margin-bottom:8px;}
.fl2 a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.82rem;transition:color .2s,padding-left .2s;display:flex;align-items:center;gap:5px;}
.fl2 a::before{content:'›';color:var(--accent);}
.fl2 a:hover{color:var(--accent-light);padding-left:4px;}
.fci{display:flex;align-items:flex-start;gap:9px;margin-bottom:10px;font-size:.81rem;color:rgba(255,255,255,.63);}
.fci i{color:var(--accent);margin-top:2px;flex-shrink:0;}
.fbot{border-top:1px solid rgba(255,255,255,.09);padding:17px 0;font-size:.78rem;color:rgba(255,255,255,.42);}
.fbot a{color:rgba(255,255,255,.55);text-decoration:none;}
.fbot a:hover{color:var(--accent-light);}

/* ── LOADER ── */
#loader{position:fixed;inset:0;background:var(--primary-dark);z-index:99999;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .5s,visibility .5s;}
#loader.gone{opacity:0;visibility:hidden;pointer-events:none;}
.llogo{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:900;color:#fff;margin-bottom:18px;}
.lbar{width:190px;height:3px;background:rgba(255,255,255,.18);border-radius:2px;overflow:hidden;}
.lfill{height:100%;background:var(--accent);width:0;transition:width 1.6s ease;}

/* ── SCROLL ANIMATIONS ── */
.anim{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease;}
.anim.vis{opacity:1;transform:translateY(0);}
.d1{transition-delay:.1s;}.d2{transition-delay:.2s;}.d3{transition-delay:.3s;}.d4{transition-delay:.4s;}.d5{transition-delay:.5s;}

/* ── RESPONSIVE ── */
@media(max-width:767px){
  .sec-py{padding:50px 0;}
  .hero-stats{gap:12px;}
  .hstat-num{font-size:1.3rem;}
  .booking-bar{margin-top:-24px;padding:16px;border-radius:12px;}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .gi.s2,.gi.r2{grid-column:span 1;grid-row:span 1;}
  .gi img{height:160px;}
  .hero-btns{flex-direction:column;}
  .hero-btns .btn-hp,.hero-btns .btn-ho{text-align:center;max-width:280px;}
  .t-foot{flex-direction:column;}
  .lf-card{padding:20px;}
}
@media(max-width:575px){
  .hero-title{font-size:1.85rem;}
  .gallery-grid{grid-template-columns:1fr;}
  .gi img{height:200px;}
  .hero-stats{flex-wrap:wrap;}
  .sec-title{font-size:1.75rem;}
  .page-hero-title{font-size:1.95rem;}
}