/* ============================================================
   AYODHYA DIVINE TOURS — style.css
   Spiritual · Saffron · Clean · Modern
   ============================================================ */
:root{
  --saffron:#E8600A;--saffron-dark:#BF4A00;--saffron-light:#FFF0E6;
  --gold:#C9963B;--gold-light:#FDF3DC;
  --bg:#FDFAF5;--bg-alt:#F5EFE6;
  --text:#1A1108;--text-muted:#6B5B45;
  --white:#FFFFFF;--border:rgba(200,150,59,0.25);
  --shadow:0 4px 24px rgba(26,17,8,0.08);
  --shadow-lg:0 16px 56px rgba(26,17,8,0.14);
  --radius:16px;--radius-sm:10px;
  --font-display:'Cinzel',serif;--font-body:'Crimson Pro',Georgia,serif;
  --tr:0.3s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden;}
img{display:block;width:100%;object-fit:cover;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
input,select,button,textarea{font-family:var(--font-body);font-size:1rem;border:none;outline:none;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-thumb{background:var(--saffron);border-radius:99px;}

/* ======= LOADER ======= */
#loader{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#1A1108,#5C2800);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;transition:opacity 0.7s ease;}
#loader.hide{opacity:0;pointer-events:none;}
.loader-icon{font-size:4rem;animation:lPulse 1.2s ease-in-out infinite;}
.loader-text{font-family:var(--font-display);color:var(--gold-light);letter-spacing:0.3em;font-size:0.75rem;text-transform:uppercase;}
.loader-bar{width:200px;height:3px;background:rgba(255,255,255,0.15);border-radius:99px;overflow:hidden;}
.loader-fill{height:100%;background:var(--saffron);border-radius:99px;animation:lFill 2s ease forwards;}
@keyframes lPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
@keyframes lFill{from{width:0}to{width:100%}}

/* ======= NAVBAR ======= */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:var(--tr);}
.navbar.scrolled{background:rgba(253,250,245,0.96);backdrop-filter:blur(14px);padding:12px 0;box-shadow:0 1px 32px rgba(232,96,10,0.1);}
.nav-container{max-width:1200px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-icon{font-size:1.9rem;line-height:1;}
.logo-text{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--white);line-height:1.15;}
.logo-text small{font-size:0.62rem;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.65);display:block;}
.navbar.scrolled .logo-text{color:var(--saffron-dark);}
.navbar.scrolled .logo-text small{color:var(--gold);}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links li a{font-family:var(--font-display);font-size:0.76rem;letter-spacing:0.06em;color:rgba(255,255,255,0.88);padding:8px 14px;border-radius:8px;transition:var(--tr);}
.nav-links li a:hover{color:var(--white);background:rgba(255,255,255,0.15);}
.navbar.scrolled .nav-links li a{color:var(--text-muted);}
.navbar.scrolled .nav-links li a:hover{color:var(--saffron);background:var(--saffron-light);}
.btn-nav{background:var(--saffron)!important;color:var(--white)!important;padding:10px 22px!important;border-radius:var(--radius-sm)!important;}
.btn-nav:hover{background:var(--saffron-dark)!important;transform:translateY(-1px);}
.navbar.scrolled .btn-nav{color:var(--white)!important;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--tr);}
.navbar.scrolled .hamburger span{background:var(--text);}

/* ======= HERO ======= */
.hero-content{animation:fadeUp 1s ease both;}

/* special offers header adjustments */
.offers-section .sec-header.centered{margin-bottom:48px;}
.offers-section .sec-tag{color:var(--gold-light);}
.offers-section .sec-title{color:var(--white);}

/* newsletter utility */
.newsletter .sec-tag{display:block;text-align:center;}

/* utility helpers */
.hidden{display:none!important;}
#bookingFields,#groupField,#ratingField{display:none;}

/* whatsapp icon size moved from inline */
.whatsapp-icon{font-size:1.4rem;}

/* gallery load-more initially hidden */
.load-more-wrap{display:none;}

/* booking page promo area */
.promo-row{display:flex;gap:10px;}
.promo-input{flex:1;}
.promo-button{background:var(--saffron);color:var(--white);padding:0 18px;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:0.75rem;letter-spacing:0.08em;cursor:pointer;border:none;white-space:nowrap;transition:var(--tr);}
.promo-msg{font-size:0.85rem;margin-top:6px;font-style:italic;}

/* booking terms */
.terms-row{display:flex;align-items:flex-start;gap:10px;margin-top:8px;}
.terms-checkbox{width:16px;height:16px;margin-top:4px;accent-color:var(--saffron);flex-shrink:0;}
.terms-label{font-size:0.95rem;color:var(--text-muted);cursor:pointer;}
.terms-label a{color:var(--saffron);}

/* booking form nav and confirm button */
.form-nav{margin-top:24px;}
.btn-confirm{background:var(--saffron-dark);font-size:0.9rem;padding:15px 40px;}

/* booking summary discount color */
#sumDiscount{color:#2E7D32;}

.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;}
.hero-slides{position:absolute;inset:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background-size:cover;background-position:center;}
.hero-slide.active{opacity:1;}
.hero-slide:nth-child(1){background-image:url('https://picsum.photos/seed/hero-slide1/1920/1080');}
.hero-slide:nth-child(2){background-image:url('https://picsum.photos/seed/hero-slide2/1920/1080');}
.hero-slide:nth-child(3){background-image:url('https://picsum.photos/seed/hero-slide3/1920/1080');}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,17,8,0.80) 0%,rgba(191,74,0,0.45) 50%,rgba(26,17,8,0.70) 100%);}

.hero-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:820px;margin:0 auto 0;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);backdrop-filter:blur(8px);border-radius:99px;padding:6px 18px;font-family:var(--font-display);font-size:0.68rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold-light);margin-bottom:24px;}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--saffron);animation:blink 1.5s ease-in-out infinite;}
.hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,7vw,5.8rem);color:var(--white);line-height:1.04;margin-bottom:20px;text-shadow:0 4px 40px rgba(0,0,0,0.5);}
.hero h1 em{font-style:normal;color:#FFD580;display:block;}
.hero-sub{font-size:clamp(1rem,2vw,1.3rem);color:rgba(255,255,255,0.80);margin-bottom:40px;font-style:italic;max-width:580px;margin-left:auto;margin-right:auto;}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:56px;}

/* QUICK SEARCH BOX */
.quick-search{position:relative;z-index:3;width:100%;max-width:860px;margin:0 auto;padding:0 24px;}
.search-box{background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);border-radius:var(--radius);padding:8px 8px 8px 8px;box-shadow:0 20px 60px rgba(0,0,0,0.25);display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:0;overflow:hidden;}
.search-field{display:flex;flex-direction:column;padding:12px 18px;border-right:1px solid rgba(200,150,59,0.2);}
.search-field:last-of-type{border-right:none;}
.search-label{font-family:var(--font-display);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--saffron);margin-bottom:4px;}
.search-field input,.search-field select{background:none;border:none;font-size:1rem;color:var(--text);padding:0;font-family:var(--font-body);}
.search-field select option{background:var(--white);}
.search-field input::placeholder{color:#B0956E;}
.btn-search{background:var(--saffron);color:var(--white);font-family:var(--font-display);font-size:0.78rem;letter-spacing:0.1em;padding:0 28px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--tr);white-space:nowrap;min-width:120px;}
.btn-search:hover{background:var(--saffron-dark);transform:scale(1.02);}

/* Slide dots */
.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px;}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.35);cursor:pointer;transition:var(--tr);}
.hero-dot.active{background:var(--saffron);width:24px;border-radius:4px;}

/* Scroll hint */
.hero-scroll{position:absolute;bottom:32px;right:32px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,0.5);font-family:var(--font-display);font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;}
.scroll-line{width:1.5px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,0.5),transparent);animation:scPulse 1.8s ease-in-out infinite;}

/* ======= BUTTONS ======= */
.btn-primary{display:inline-block;background:var(--saffron);color:var(--white);font-family:var(--font-display);font-size:0.85rem;letter-spacing:0.08em;padding:14px 32px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--tr);border:2px solid var(--saffron);}
.btn-primary:hover{background:var(--saffron-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,96,10,0.35);}
.btn-outline{display:inline-block;background:transparent;color:var(--white);font-family:var(--font-display);font-size:0.85rem;letter-spacing:0.08em;padding:14px 32px;border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,0.55);cursor:pointer;transition:var(--tr);}
.btn-outline:hover{background:rgba(255,255,255,0.15);border-color:var(--white);}

/* ======= SECTION BASE ======= */
.section{padding:96px 0;}
.container{max-width:1200px;margin:0 auto;padding:0 28px;}
.sec-tag{font-family:var(--font-display);font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--saffron);display:block;margin-bottom:10px;}
.sec-title{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--text);margin-bottom:14px;line-height:1.2;}
.sec-desc{font-size:1.1rem;color:var(--text-muted);font-style:italic;max-width:560px;}
.sec-header{margin-bottom:52px;}
.sec-header.centered{text-align:center;}
.sec-header.centered .sec-desc{margin:0 auto;}
.sec-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:52px;flex-wrap:wrap;}
.view-all{font-family:var(--font-display);font-size:0.75rem;letter-spacing:0.1em;color:var(--saffron);border-bottom:1px solid var(--saffron);padding-bottom:2px;transition:var(--tr);white-space:nowrap;}
.view-all:hover{color:var(--saffron-dark);border-color:var(--saffron-dark);}

/* ======= STATS STRIP ======= */
.stats-strip{background:var(--saffron-dark);padding:0;}
.stats-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);}
.stat-item{padding:32px 24px;text-align:center;border-right:1px solid rgba(255,255,255,0.12);transition:var(--tr);}
.stat-item:last-child{border-right:none;}
.stat-item:hover{background:rgba(255,255,255,0.07);}
.stat-num{font-family:var(--font-display);font-size:2.2rem;font-weight:700;color:var(--white);line-height:1;counter-reset:none;}
.stat-label{font-size:0.9rem;color:rgba(255,255,255,0.68);margin-top:6px;font-style:italic;}

/* ======= POPULAR DESTINATIONS ======= */
.destinations-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:220px 220px;gap:16px;}
.dest-card{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;}
.dest-card:first-child{grid-row:1/3;}
.dest-card img{height:100%;transition:transform 0.5s ease;}
.dest-card:hover img{transform:scale(1.06);}
.dest-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,17,8,0.78) 0%,transparent 55%);}
.dest-info{position:absolute;bottom:0;left:0;right:0;padding:20px;}
.dest-name{font-family:var(--font-display);font-size:1rem;color:var(--white);margin-bottom:2px;}
.dest-card:first-child .dest-name{font-size:1.5rem;}
.dest-sub{font-size:0.85rem;color:rgba(255,255,255,0.7);font-style:italic;}
.dest-tag{display:inline-block;background:rgba(232,96,10,0.85);color:var(--white);font-family:var(--font-display);font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;padding:4px 10px;border-radius:99px;margin-bottom:8px;}

/* ======= TOUR PACKAGES ======= */
.packages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.pkg-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;transition:var(--tr);display:flex;flex-direction:column;}
.pkg-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.pkg-img{position:relative;height:210px;overflow:hidden;}
.pkg-img img{height:100%;transition:transform 0.5s ease;}
.pkg-card:hover .pkg-img img{transform:scale(1.06);}
.pkg-badge{position:absolute;top:14px;right:14px;font-family:var(--font-display);font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;padding:5px 12px;border-radius:99px;color:var(--white);}
.badge-hot{background:var(--saffron);}
.badge-premium{background:var(--gold);}
.badge-new{background:#2E7D32;}
.pkg-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.pkg-cat{font-family:var(--font-display);font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--saffron);margin-bottom:6px;}
.pkg-body h3{font-family:var(--font-display);font-size:1.05rem;color:var(--text);margin-bottom:10px;line-height:1.35;}
.pkg-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;}
.pkg-meta span{font-size:0.85rem;color:var(--text-muted);}
.pkg-rating{display:flex;align-items:center;gap:6px;margin-bottom:14px;}
.stars{color:var(--gold);font-size:0.82rem;letter-spacing:1px;}
.review-count{font-size:0.82rem;color:var(--text-muted);}
.pkg-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px dashed var(--border);margin-top:auto;}
.pkg-price .old{font-size:0.82rem;color:var(--text-muted);text-decoration:line-through;}
.pkg-price .new{font-family:var(--font-display);font-size:1.25rem;color:var(--saffron-dark);font-weight:700;line-height:1;}
.pkg-price small{font-size:0.68rem;color:var(--text-muted);}
.btn-pkg{background:var(--saffron-light);color:var(--saffron-dark);font-family:var(--font-display);font-size:0.72rem;letter-spacing:0.08em;padding:10px 18px;border-radius:var(--radius-sm);transition:var(--tr);border:1.5px solid rgba(232,96,10,0.2);}
.btn-pkg:hover{background:var(--saffron);color:var(--white);}

/* ======= WHY CHOOSE US ======= */
.why-section{background:linear-gradient(135deg,#1A1108 0%,#3D1500 50%,#1A1108 100%);position:relative;overflow:hidden;}
.why-section::before{content:'';position:absolute;inset:0;background:url('https://picsum.photos/seed/why-bg/1600/800') center/cover;opacity:0.08;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.why-left{position:relative;}
.why-img-main{border-radius:var(--radius);overflow:hidden;height:480px;}
.why-img-main img{height:100%;}
.why-img-float{position:absolute;bottom:-24px;right:-24px;width:200px;border-radius:var(--radius);overflow:hidden;border:4px solid rgba(255,255,255,0.1);box-shadow:0 20px 48px rgba(0,0,0,0.4);}
.why-img-float img{height:150px;}
.why-badge-overlay{position:absolute;top:24px;left:-20px;background:var(--saffron);color:var(--white);padding:16px 20px;border-radius:var(--radius-sm);box-shadow:0 8px 24px rgba(232,96,10,0.4);}
.why-badge-num{font-family:var(--font-display);font-size:1.8rem;font-weight:700;line-height:1;}
.why-badge-label{font-size:0.78rem;opacity:0.9;}
.why-right{}
.why-right .sec-tag{color:var(--gold);}
.why-right .sec-title{color:var(--white);}
.why-right .sec-desc{color:rgba(255,255,255,0.68);}
.why-features{display:flex;flex-direction:column;gap:20px;margin-top:36px;}
.why-item{display:flex;gap:16px;align-items:flex-start;}
.why-icon{width:50px;height:50px;border-radius:12px;background:rgba(232,96,10,0.15);border:1px solid rgba(232,96,10,0.3);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;transition:var(--tr);}
.why-item:hover .why-icon{background:var(--saffron);border-color:var(--saffron);}
.why-item-content h4{font-family:var(--font-display);font-size:0.9rem;color:var(--white);margin-bottom:4px;}
.why-item-content p{font-size:0.95rem;color:rgba(255,255,255,0.62);font-style:italic;line-height:1.6;}

/* ======= EXPERIENCE STRIP ======= */
.exp-strip{background:var(--gold-light);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.exp-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(5,1fr);gap:0;}
.exp-item{padding:28px 20px;text-align:center;border-right:1px solid var(--border);transition:var(--tr);}
.exp-item:last-child{border-right:none;}
.exp-item:hover{background:rgba(232,96,10,0.06);}
.exp-icon{font-size:1.8rem;margin-bottom:8px;}
.exp-label{font-family:var(--font-display);font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);}

/* ======= GALLERY TEASER ======= */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:200px 200px;gap:12px;}
.gal-item{border-radius:var(--radius-sm);overflow:hidden;position:relative;cursor:pointer;}
.gal-item:first-child{grid-column:1/3;grid-row:1/3;}
.gal-item img{height:100%;transition:transform 0.5s ease;}
.gal-item:hover img{transform:scale(1.07);}
.gal-overlay{position:absolute;inset:0;background:rgba(26,17,8,0);transition:var(--tr);display:flex;align-items:center;justify-content:center;}
.gal-item:hover .gal-overlay{background:rgba(232,96,10,0.35);}
.gal-zoom{width:44px;height:44px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.1rem;opacity:0;transform:scale(0.7);transition:var(--tr);}
.gal-item:hover .gal-zoom{opacity:1;transform:scale(1);}

/* ======= TESTIMONIALS ======= */
.testi-section{background:var(--bg-alt);}
.testi-slider{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.testi-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);border:1px solid var(--border);transition:var(--tr);position:relative;}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.testi-quote-mark{font-size:4rem;color:var(--saffron-light);font-family:Georgia,serif;line-height:0.8;margin-bottom:8px;}
.testi-text{font-size:1.02rem;color:var(--text-muted);font-style:italic;line-height:1.78;margin-bottom:20px;}
.testi-stars{color:var(--gold);font-size:0.9rem;letter-spacing:2px;margin-bottom:16px;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-avatar{width:48px;height:48px;border-radius:50%;background:var(--saffron-light);display:flex;align-items:center;justify-content:center;font-size:1.4rem;border:2px solid var(--border);flex-shrink:0;}
.testi-name{font-family:var(--font-display);font-size:0.85rem;color:var(--text);}
.testi-loc{font-size:0.8rem;color:var(--text-muted);}
.testi-verified{position:absolute;top:20px;right:20px;background:var(--gold-light);color:var(--gold);font-family:var(--font-display);font-size:0.6rem;letter-spacing:0.1em;padding:4px 10px;border-radius:99px;}

/* blog styles removed */

/* ======= SPECIAL OFFERS BANNER ======= */
.offers-section{background:linear-gradient(135deg,var(--saffron-dark) 0%,#8B3000 100%);position:relative;overflow:hidden;}
.offers-section::after{content:'✦';position:absolute;font-size:28rem;opacity:0.04;right:-60px;top:50%;transform:translateY(-50%);color:var(--gold-light);font-family:var(--font-display);}
.offers-inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;}
.offer-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius);padding:28px;transition:var(--tr);}
.offer-card:hover{background:rgba(255,255,255,0.14);transform:translateY(-4px);}
.offer-icon{font-size:2rem;margin-bottom:12px;}
.offer-tag{font-family:var(--font-display);font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold-light);margin-bottom:8px;}
.offer-card h3{font-family:var(--font-display);font-size:1.1rem;color:var(--white);margin-bottom:8px;}
.offer-card p{font-size:0.95rem;color:rgba(255,255,255,0.72);font-style:italic;line-height:1.6;margin-bottom:18px;}
.offer-card .offer-code{display:inline-block;background:rgba(255,255,255,0.15);color:var(--gold-light);font-family:var(--font-display);font-size:0.8rem;letter-spacing:0.15em;padding:6px 16px;border-radius:6px;border:1px dashed rgba(255,255,255,0.4);}

/* ======= NEWSLETTER ======= */
.newsletter{background:var(--bg);}
.newsletter-box{background:linear-gradient(135deg,var(--gold-light) 0%,var(--saffron-light) 100%);border:1px solid var(--border);border-radius:var(--radius);padding:64px;text-align:center;position:relative;overflow:hidden;}
.newsletter-box::before{content:'🛕';position:absolute;font-size:18rem;opacity:0.05;right:-40px;bottom:-40px;}
.newsletter-box .sec-title{font-size:clamp(1.6rem,3vw,2.2rem);}
.newsletter-box .sec-desc{margin:0 auto 32px;}
.newsletter-form{display:flex;gap:12px;max-width:500px;margin:0 auto;flex-wrap:wrap;}
.newsletter-form input{flex:1;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;font-size:1rem;color:var(--text);transition:var(--tr);}
.newsletter-form input:focus{border-color:var(--saffron);box-shadow:0 0 0 4px rgba(232,96,10,0.1);}
.newsletter-form input::placeholder{color:#B0956E;}
.newsletter-form button{background:var(--saffron);color:var(--white);font-family:var(--font-display);font-size:0.8rem;letter-spacing:0.1em;padding:14px 28px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--tr);border:none;}
.newsletter-form button:hover{background:var(--saffron-dark);transform:translateY(-1px);}
.newsletter-note{margin-top:14px;font-size:0.85rem;color:var(--text-muted);font-style:italic;}

/* ======= FOOTER ======= */
.footer{background:#0F0804;color:rgba(255,255,255,0.7);padding:80px 0 0;}
.footer-top{max-width:1200px;margin:0 auto;padding:0 28px 60px;display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:48px;border-bottom:1px solid rgba(255,255,255,0.08);}
.footer-brand .logo-text{color:var(--gold-light);}
.footer-brand .logo-text small{color:rgba(255,255,255,0.4);}
.footer-brand p{margin-top:16px;font-size:0.95rem;color:rgba(255,255,255,0.52);font-style:italic;line-height:1.75;}
.footer-brand .social-links{display:flex;gap:10px;margin-top:24px;}
.footer-brand .social-links a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;font-size:0.78rem;color:rgba(255,255,255,0.6);transition:var(--tr);font-weight:700;}
.footer-brand .social-links a:hover{background:var(--saffron);color:var(--white);transform:translateY(-2px);}
.footer-col h4{font-family:var(--font-display);font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}
.footer-col ul{display:flex;flex-direction:column;gap:10px;}
.footer-col a{font-size:0.93rem;color:rgba(255,255,255,0.55);transition:var(--tr);}
.footer-col a:hover{color:var(--gold-light);padding-left:5px;}
.footer-col .contact-item{display:flex;gap:10px;align-items:flex-start;font-size:0.93rem;color:rgba(255,255,255,0.55);margin-bottom:10px;}
.footer-bottom{text-align:center;padding:22px 28px;font-size:0.82rem;color:rgba(255,255,255,0.25);font-style:italic;}

/* ======= FLOATING BUTTONS ======= */
.whatsapp-btn{position:fixed;bottom:88px;right:24px;z-index:900;width:56px;height:56px;border-radius:50%;background:#25D366;color:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 20px rgba(37,211,102,0.4);transition:var(--tr);}
.whatsapp-btn:hover{transform:scale(1.1);}
.back-top{position:fixed;bottom:24px;right:24px;z-index:900;width:48px;height:48px;border-radius:50%;background:var(--saffron);color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 20px rgba(232,96,10,0.3);transition:var(--tr);opacity:0;pointer-events:none;}
.back-top.visible{opacity:1;pointer-events:all;}
.back-top:hover{background:var(--saffron-dark);transform:translateY(-3px);}

/* ======= ANIMATIONS ======= */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes scPulse{0%,100%{opacity:0.4}50%{opacity:1}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ======= RESPONSIVE ======= */
@media(max-width:1100px){
  .destinations-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}.destinations-grid .dest-card:first-child{grid-row:auto;grid-column:1/3;height:280px;}
  .why-grid{grid-template-columns:1fr;}
  .why-left{display:none;}
  .blog-grid{grid-template-columns:1fr 1fr;}.blog-grid .blog-card:first-child{grid-column:1/3;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1/3;}
}
@media(max-width:900px){
  .search-box{grid-template-columns:1fr 1fr;border-radius:var(--radius);}
  .search-field{border-right:none;border-bottom:1px solid rgba(200,150,59,0.2);}
  .search-field:nth-child(odd){border-right:1px solid rgba(200,150,59,0.2);}
  .btn-search{grid-column:1/3;border-radius:var(--radius-sm);padding:14px;}
  .packages-grid{grid-template-columns:1fr 1fr;}
  .testi-slider{grid-template-columns:1fr 1fr;}
  .offers-inner{grid-template-columns:1fr 1fr;}
  .exp-inner{grid-template-columns:repeat(3,1fr);}
  .gallery-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:160px 160px;}.gallery-grid .gal-item:first-child{grid-column:auto;grid-row:auto;}
}
@media(max-width:768px){
  .section{padding:72px 0;}
  .hamburger{display:flex;}
  .nav-links{position:fixed;top:0;right:-100%;height:100vh;width:280px;background:var(--white);flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:80px 32px 32px;gap:4px;box-shadow:-8px 0 40px rgba(0,0,0,0.15);transition:right 0.4s ease;z-index:999;}
  .nav-links.open{right:0;}
  .nav-links li{width:100%;}
  .nav-links li a{display:block;width:100%;color:var(--text-muted)!important;font-size:0.9rem;}
  .nav-links li a:not(.btn-nav):hover{background:var(--saffron-light)!important;color:var(--saffron)!important;}
  .packages-grid{grid-template-columns:1fr;}
  .testi-slider{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .blog-grid .blog-card:first-child{grid-column:auto;}
  .offers-inner{grid-template-columns:1fr;}
  .newsletter-box{padding:40px 24px;}
  .hero-btns{flex-direction:column;align-items:center;}
  .stats-inner{grid-template-columns:1fr 1fr;}
  .exp-inner{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:140px 140px 140px;}
}
@media(max-width:480px){
  .footer-top{grid-template-columns:1fr;}
  .footer-brand{grid-column:auto;}
  .search-box{grid-template-columns:1fr;}
  .search-field:nth-child(odd){border-right:none;}
  .btn-search{grid-column:auto;}
  .destinations-grid{grid-template-columns:1fr;}
  .destinations-grid .dest-card:first-child{grid-column:auto;}
  .exp-inner{grid-template-columns:1fr 1fr;}
  .stats-inner{grid-template-columns:1fr 1fr;}
}
:root {
  --saffron:       #E8600A;
  --saffron-dark:  #BF4A00;
  --saffron-light: #FFF0E6;
  --gold:          #C9963B;
  --gold-light:    #FDF3DC;
  --bg:            #FDFAF5;
  --bg-alt:        #F5EFE6;
  --text:          #1A1108;
  --text-muted:    #6B5B45;
  --white:         #FFFFFF;
  --border:        rgba(200,150,59,0.25);
  --shadow-card:   0 4px 24px rgba(26,17,8,0.08);
  --radius:        16px;
  --radius-sm:     10px;
  --font-display:  'Cinzel', serif;
  --font-body:     'Crimson Pro', Georgia, serif;
  --transition:    0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); background: var(--bg); color: var(--text); line-height: 1.7; overflow-x: hidden; }
img { display: block; width: 100%; object-fit: cover; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
input, select, textarea, button { font-family: var(--font-body); font-size: 1rem; border: none; outline: none; }

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--saffron); border-radius: 99px; }

/* ---- LOADER ---- */
#loader {
  position: fixed; inset: 0; z-index: 9999;
  background: linear-gradient(135deg, #1A1108 0%, #5C2800 100%);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px;
  transition: opacity 0.6s ease;
}
#loader.hide { opacity: 0; pointer-events: none; }
.loader-icon { font-size: 4rem; animation: loaderPulse 1.2s ease-in-out infinite; }
.loader-text { font-family: var(--font-display); color: var(--gold-light); letter-spacing: 0.3em; font-size: 0.75rem; text-transform: uppercase; }
.loader-bar { width: 200px; height: 3px; background: rgba(255,255,255,0.15); border-radius: 99px; overflow: hidden; }
.loader-fill { height: 100%; background: var(--saffron); border-radius: 99px; animation: loaderFill 1.8s ease forwards; }

/* ---- CONTAINER ---- */
.container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* ---- SECTION ---- */
.section { padding: 96px 0; }
.section-header { text-align: center; margin-bottom: 64px; }
.section-tag { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--saffron); margin-bottom: 12px; }
.section-header h2 { font-family: var(--font-display); font-size: clamp(2rem,4vw,2.8rem); color: var(--text); margin-bottom: 16px; line-height: 1.2; }
.section-desc { font-size: 1.15rem; color: var(--text-muted); max-width: 560px; margin: 0 auto; font-style: italic; }
.section-header.light h2 { color: var(--white); }
.section-header.light .section-tag { color: var(--gold-light); }
.section-header.light .section-desc { color: rgba(255,255,255,0.78); }

/* ---- BUTTONS ---- */
.btn-primary {
  display: inline-block; background: var(--saffron); color: var(--white);
  font-family: var(--font-display); font-size: 0.85rem; letter-spacing: 0.08em;
  padding: 14px 32px; border-radius: var(--radius-sm); cursor: pointer;
  transition: var(--transition); border: 2px solid var(--saffron);
}
.btn-primary:hover { background: var(--saffron-dark); border-color: var(--saffron-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,96,10,0.35); }

.btn-ghost {
  display: inline-block; background: transparent; color: var(--white);
  font-family: var(--font-display); font-size: 0.85rem; letter-spacing: 0.08em;
  padding: 14px 32px; border-radius: var(--radius-sm); border: 2px solid rgba(255,255,255,0.5); cursor: pointer; transition: var(--transition);
}
.btn-ghost:hover { background: rgba(255,255,255,0.15); border-color: var(--white); }

.btn-card {
  width: 100%; background: var(--saffron-light); color: var(--saffron-dark);
  font-family: var(--font-display); font-size: 0.78rem; letter-spacing: 0.08em;
  padding: 12px 20px; border-radius: var(--radius-sm); cursor: pointer;
  transition: var(--transition); border: 1.5px solid rgba(232,96,10,0.2); margin-top: 16px;
}
.btn-card:hover { background: var(--saffron); color: var(--white); transform: translateY(-1px); }
.btn-card.small { width: auto; padding: 10px 20px; margin-top: 0; }

.btn-nav {
  background: var(--saffron); color: var(--white) !important;
  padding: 10px 22px; border-radius: var(--radius-sm);
  font-family: var(--font-display); font-size: 0.78rem; letter-spacing: 0.06em; transition: var(--transition);
}
.btn-nav:hover { background: var(--saffron-dark); transform: translateY(-1px); }
.full-width { width: 100%; text-align: center; }

/* ---- NAVBAR ---- */
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 18px 0; transition: var(--transition); }
.navbar.scrolled { background: rgba(253,250,245,0.96); backdrop-filter: blur(12px); padding: 12px 0; box-shadow: 0 1px 32px rgba(232,96,10,0.1); }
.nav-container { max-width: 1180px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.logo-icon { font-size: 1.8rem; line-height: 1; }
.logo-text { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--saffron-dark); line-height: 1.15; }
.logo-text small { font-size: 0.65rem; font-weight: 400; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); display: block; }
.nav-links { display: flex; align-items: center; gap: 8px; }
.nav-links li a { font-family: var(--font-display); font-size: 0.78rem; letter-spacing: 0.06em; color: var(--text-muted); padding: 8px 14px; border-radius: 8px; transition: var(--transition); }
.nav-links li a:not(.btn-nav):hover { color: var(--saffron); background: var(--saffron-light); }
.navbar:not(.scrolled) .nav-links li a:not(.btn-nav) { color: rgba(255,255,255,0.85); }
.navbar:not(.scrolled) .nav-links li a:not(.btn-nav):hover { color: var(--white); background: rgba(255,255,255,0.15); }
.navbar:not(.scrolled) .logo-text, .navbar:not(.scrolled) .logo-text small { color: var(--white); }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; cursor: pointer; padding: 4px; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--text); border-radius: 2px; transition: var(--transition); }
.navbar:not(.scrolled) .hamburger span { background: var(--white); }
.active-link { color: var(--saffron) !important; background: var(--saffron-light) !important; border-radius: 8px; }
.navbar:not(.scrolled) .active-link { color: var(--white) !important; background: rgba(255,255,255,0.18) !important; }

/* ---- HERO ---- */
.hero {
  position: relative; min-height: 100vh; display: flex; align-items: center;
  background: url('https://picsum.photos/seed/ayodhya99/1600/900') center center / cover no-repeat;
  overflow: hidden;
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(26,17,8,0.78) 0%, rgba(191,74,0,0.5) 50%, rgba(26,17,8,0.65) 100%);
}
.hero-content { position: relative; z-index: 2; max-width: 720px; padding: 0 24px; margin: 0 auto; text-align: center; animation: fadeUp 1s ease both; }
.hero-tag { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.3em; color: var(--gold-light); margin-bottom: 20px; text-transform: uppercase; }
.hero-content h1 { font-family: var(--font-display); font-size: clamp(2.8rem,8vw,5.5rem); font-weight: 700; color: var(--white); line-height: 1.05; margin-bottom: 24px; text-shadow: 0 4px 32px rgba(0,0,0,0.4); }
.hero-content h1 span { color: #FFD580; display: block; }
.hero-sub { font-size: clamp(1rem,2vw,1.25rem); color: rgba(255,255,255,0.82); margin-bottom: 40px; font-style: italic; line-height: 1.7; }
.hero-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.hero-scroll-hint { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; color: rgba(255,255,255,0.55); font-family: var(--font-display); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; }
.scroll-line { width: 1.5px; height: 40px; background: linear-gradient(to bottom, rgba(255,255,255,0.5), transparent); animation: scrollPulse 1.8s ease-in-out infinite; }

/* ---- STATS BAR ---- */
.stats-bar { background: var(--saffron-dark); }
.stats-inner { display: flex; align-items: stretch; max-width: 1180px; margin: 0 auto; }
.stat-item { flex: 1; padding: 32px 24px; text-align: center; border-right: 1px solid rgba(255,255,255,0.15); transition: var(--transition); }
.stat-item:last-child { border-right: none; }
.stat-item:hover { background: rgba(255,255,255,0.08); }
.stat-num { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--white); line-height: 1; }
.stat-label { font-size: 0.85rem; color: rgba(255,255,255,0.7); margin-top: 6px; font-style: italic; }

/* ---- CARDS ---- */
.cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 32px; }
.card { background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); transition: var(--transition); border: 1px solid var(--border); }
.card:hover { transform: translateY(-8px); box-shadow: 0 20px 60px rgba(232,96,10,0.14); }
.card-img-wrap { position: relative; height: 220px; overflow: hidden; }
.card-img-wrap img { height: 100%; transition: transform 0.5s ease; }
.card:hover .card-img-wrap img { transform: scale(1.06); }
.card-badge { position: absolute; top: 16px; right: 16px; background: var(--saffron); color: var(--white); font-family: var(--font-display); font-size: 0.65rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 5px 12px; border-radius: 99px; }
.card-badge.premium { background: var(--gold); }
.card-body { padding: 24px; }
.card-body h3 { font-family: var(--font-display); font-size: 1.15rem; color: var(--text); margin-bottom: 12px; }
.card-meta { display: flex; align-items: center; justify-content: space-between; font-size: 0.92rem; color: var(--text-muted); margin-bottom: 14px; flex-wrap: wrap; gap: 8px; }
.price { font-family: var(--font-display); color: var(--saffron-dark); font-size: 1.2rem; font-weight: 600; }
.price small { font-size: 0.7rem; color: var(--text-muted); font-weight: 400; }
.card-features { margin-bottom: 4px; }
.card-features li { font-size: 0.92rem; color: var(--text-muted); padding: 3px 0; }
.stars { color: var(--gold); font-size: 1rem; margin-bottom: 10px; letter-spacing: 2px; }
.hotel-desc { font-size: 0.95rem; color: var(--text-muted); font-style: italic; margin-bottom: 12px; }

/* ---- CABS ---- */
.cabs { background: linear-gradient(135deg, var(--saffron-dark) 0%, #8B3000 100%); position: relative; overflow: hidden; }
.cabs::before { content: '🛕'; position: absolute; font-size: 22rem; opacity: 0.04; right: -60px; top: 50%; transform: translateY(-50%); pointer-events: none; }
.cab-form-wrap { background: rgba(255,255,255,0.07); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius); padding: 48px; max-width: 820px; margin: 0 auto; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.form-group { display: flex; flex-direction: column; gap: 8px; }
.form-group label { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.75); }
.cab-form input, .cab-form select { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); border-radius: var(--radius-sm); padding: 14px 16px; color: var(--white); font-size: 1rem; transition: var(--transition); }
.cab-form input::placeholder { color: rgba(255,255,255,0.4); }
.cab-form input:focus, .cab-form select:focus { border-color: var(--gold-light); background: rgba(255,255,255,0.16); }
.cab-form select option { background: var(--saffron-dark); color: var(--white); }
.cab-form input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(1) opacity(0.6); cursor: pointer; }

/* ---- TESTIMONIALS ---- */
.testimonials { background: var(--gold-light); }
.testi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 28px; }
.testi-card { background: var(--white); border-radius: var(--radius); padding: 32px; box-shadow: var(--shadow-card); border: 1px solid var(--border); transition: var(--transition); }
.testi-card:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(232,96,10,0.12); }
.testi-quote { font-size: 3rem; line-height: 1; color: var(--saffron-light); font-family: Georgia, serif; margin-bottom: -8px; }
.testi-text { font-size: 1.05rem; color: var(--text-muted); font-style: italic; line-height: 1.75; margin-bottom: 20px; }
.testi-author { display: flex; align-items: center; gap: 12px; }
.testi-avatar { width: 46px; height: 46px; border-radius: 50%; background: var(--saffron-light); display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; border: 2px solid var(--border); }
.testi-name { font-family: var(--font-display); font-size: 0.85rem; color: var(--text); }
.testi-location { font-size: 0.8rem; color: var(--text-muted); }
.testi-stars { color: var(--gold); font-size: 0.85rem; letter-spacing: 2px; margin-bottom: 4px; }

/* ---- CONTACT ---- */
.contact { background: var(--bg-alt); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.contact-info .section-tag { text-align: left; }
.contact-info h2 { font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.4rem); margin-bottom: 16px; }
.contact-info p { color: var(--text-muted); font-size: 1.05rem; font-style: italic; margin-bottom: 32px; }
.contact-details { display: flex; flex-direction: column; gap: 16px; }
.contact-item { display: flex; align-items: flex-start; gap: 14px; font-size: 1rem; color: var(--text-muted); }
.contact-icon { font-size: 1.2rem; margin-top: 2px; flex-shrink: 0; }
.contact-form-wrap { background: var(--white); border-radius: var(--radius); padding: 40px; box-shadow: var(--shadow-card); border: 1px solid var(--border); }
.contact-form-wrap .form-group { margin-bottom: 20px; }
.contact-form-wrap label { display: block; font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; }
.contact-form-wrap input, .contact-form-wrap textarea { width: 100%; background: var(--saffron-light); border: 1.5px solid transparent; border-radius: var(--radius-sm); padding: 14px 16px; color: var(--text); font-size: 1rem; transition: var(--transition); resize: vertical; }
.contact-form-wrap input::placeholder, .contact-form-wrap textarea::placeholder { color: #B0956E; }
.contact-form-wrap input:focus, .contact-form-wrap textarea:focus { border-color: var(--saffron); background: var(--white); box-shadow: 0 0 0 4px rgba(232,96,10,0.08); }
.success-msg { margin-top: 16px; background: #F0FFF4; border: 1.5px solid #4CAF50; color: #2D7A35; font-family: var(--font-display); font-size: 0.88rem; padding: 14px 20px; border-radius: var(--radius-sm); text-align: center; animation: fadeUp 0.5s ease both; }

/* ---- FLOATING BUTTONS ---- */
.whatsapp-btn {
  position: fixed; bottom: 88px; right: 24px; z-index: 900;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: var(--transition); cursor: pointer;
  animation: bounceIn 0.6s 2s both;
}
.whatsapp-btn:hover { transform: scale(1.12) translateY(-2px); }
.whatsapp-tooltip {
  position: absolute; right: 68px; top: 50%; transform: translateY(-50%);
  background: var(--text); color: var(--white); font-family: var(--font-display);
  font-size: 0.7rem; letter-spacing: 0.08em; white-space: nowrap;
  padding: 6px 12px; border-radius: 6px; opacity: 0; pointer-events: none; transition: var(--transition);
}
.whatsapp-btn:hover .whatsapp-tooltip { opacity: 1; }

.back-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 900;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--saffron); color: var(--white); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
  box-shadow: 0 4px 20px rgba(232,96,10,0.3); transition: var(--transition);
  opacity: 0; pointer-events: none;
}
.back-top.visible { opacity: 1; pointer-events: all; }
.back-top:hover { background: var(--saffron-dark); transform: translateY(-3px); }

/* ---- FOOTER ---- */
.footer { background: var(--text); color: rgba(255,255,255,0.75); padding: 72px 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1.4fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.footer-brand .logo-text { color: var(--gold-light); }
.footer-brand .logo-text small { color: rgba(255,255,255,0.45); }
.footer-brand p { margin-top: 16px; font-size: 0.98rem; line-height: 1.75; font-style: italic; color: rgba(255,255,255,0.6); }
.footer-links h4, .footer-contact h4 { font-family: var(--font-display); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); margin-bottom: 20px; }
.footer-links ul { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: 0.98rem; color: rgba(255,255,255,0.65); transition: var(--transition); }
.footer-links a:hover { color: var(--gold-light); padding-left: 4px; }
.footer-contact p { font-size: 0.95rem; margin-bottom: 8px; }
.social-links { display: flex; gap: 10px; margin-top: 20px; }
.social-links a { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center; font-size: 0.8rem; color: rgba(255,255,255,0.7); transition: var(--transition); font-weight: 700; }
.social-links a:hover { background: var(--saffron); border-color: var(--saffron); color: var(--white); transform: translateY(-2px); }
.footer-bottom { text-align: center; padding: 24px; font-size: 0.88rem; color: rgba(255,255,255,0.35); font-style: italic; }

/* ---- MODAL ---- */
.modal-overlay { position: fixed; inset: 0; background: rgba(26,17,8,0.65); backdrop-filter: blur(6px); z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.modal-overlay.active { opacity: 1; pointer-events: all; }
.modal { background: var(--white); border-radius: var(--radius); padding: 48px 40px; max-width: 440px; width: 100%; text-align: center; position: relative; transform: scale(0.9) translateY(20px); transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1); box-shadow: 0 32px 80px rgba(0,0,0,0.2); }
.modal-overlay.active .modal { transform: scale(1) translateY(0); }
.modal-close { position: absolute; top: 16px; right: 16px; background: var(--saffron-light); border: none; width: 32px; height: 32px; border-radius: 50%; cursor: pointer; font-size: 0.8rem; color: var(--saffron-dark); transition: var(--transition); }
.modal-close:hover { background: var(--saffron); color: var(--white); }
.modal-icon { font-size: 3rem; margin-bottom: 16px; }
.modal h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--text); margin-bottom: 12px; }
.modal p { color: var(--text-muted); font-size: 1.05rem; font-style: italic; margin-bottom: 28px; line-height: 1.7; }

/* ---- ANIMATIONS ---- */
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes scrollPulse { 0%,100%{opacity:0.4;} 50%{opacity:1;} }
@keyframes loaderPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.15);} }
@keyframes loaderFill { from{width:0%} to{width:100%} }
@keyframes bounceIn { 0%{opacity:0;transform:scale(0.3);} 60%{opacity:1;transform:scale(1.1);} 80%{transform:scale(0.95);} 100%{transform:scale(1);} }

.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: 1 / -1; }
  .stats-inner { flex-wrap: wrap; }
  .stat-item { flex: 1 1 50%; border-bottom: 1px solid rgba(255,255,255,0.1); }
}
@media (max-width: 768px) {
  .section { padding: 72px 0; }
  .hamburger { display: flex; }
  .nav-links { position: fixed; top: 0; right: -100%; height: 100vh; width: 280px; background: var(--white); flex-direction: column; align-items: flex-start; justify-content: flex-start; padding: 80px 32px 32px; gap: 4px; box-shadow: -8px 0 40px rgba(0,0,0,0.12); transition: right 0.4s cubic-bezier(0.4,0,0.2,1); z-index: 999; }
  .nav-links.open { right: 0; }
  .nav-links li { width: 100%; }
  .nav-links li a { display: block; width: 100%; color: var(--text-muted) !important; font-size: 0.9rem; }
  .nav-links li a:not(.btn-nav) { background: none !important; }
  .nav-links li a.btn-nav { text-align: center; margin-top: 12px; }
  .form-row { grid-template-columns: 1fr; }
  .cab-form-wrap { padding: 32px 24px; }
  .cards-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .testi-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .footer-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero-content h1 { font-size: 2.4rem; }
  .hero-actions { flex-direction: column; align-items: center; }
  .btn-primary, .btn-ghost { width: 100%; text-align: center; }
  .contact-form-wrap { padding: 28px 20px; }
  .modal { padding: 36px 24px; }
}

/* ---- PAGE-SPECIFIC STYLES ---- */

/* Contact Page Extras */
.page-hero { position: relative; padding: 160px 24px 80px; text-align: center; background: linear-gradient(135deg, rgba(26,17,8,0.85) 0%, rgba(191,74,0,0.65) 55%, rgba(26,17,8,0.75) 100%), url('https://picsum.photos/seed/contact-hero/1600/600') center/cover no-repeat; overflow: hidden; }
.page-hero::after, .page-hero::before { position: absolute; opacity: 0.04; pointer-events: none; line-height: 1; }
.page-hero::after { content: '🛕'; font-size: 26rem; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.page-hero::before { content: '✦'; font-size: 28rem; top: 50%; left: 50%; transform: translate(-50%,-50%); color: var(--gold); font-family: var(--font-display); }
.page-hero-tag, .hero-tag { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold-light); margin-bottom: 14px; }
.page-hero h1 { font-family: var(--font-display); font-size: clamp(2.2rem,5vw,3.8rem); color: var(--white); line-height: 1.1; margin-bottom: 14px; text-shadow: 0 4px 24px rgba(0,0,0,0.4); }
.page-hero h1 span { color: #FFD580; }
.page-hero p { font-size: 1.15rem; color: rgba(255,255,255,0.78); max-width: 520px; margin: 0 auto; font-style: italic; }

.info-cards-section { background: var(--saffron-dark); padding: 56px 24px; }
.info-cards-inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.info-card { background: rgba(255,255,255,0.09); border: 1px solid rgba(255,255,255,0.15); border-radius: var(--radius); padding: 28px 20px; text-align: center; transition: var(--transition); cursor: default; }
.info-card:hover { background: rgba(255,255,255,0.16); transform: translateY(-4px); }
.info-card-icon { font-size: 2rem; margin-bottom: 12px; }
.info-card h3 { font-family: var(--font-display); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-light); margin-bottom: 8px; }
.info-card p { font-size: 0.98rem; color: rgba(255,255,255,0.82); font-style: italic; line-height: 1.5; }
.info-card a { color: rgba(255,255,255,0.9); transition: var(--transition); }
.info-card a:hover { color: var(--gold-light); }

.contact-main { max-width: 1180px; margin: 0 auto; padding: 80px 24px 96px; display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; align-items: start; }
.contact-form-wrap { background: var(--white); border-radius: var(--radius); padding: 40px; box-shadow: var(--shadow-card); border: 1px solid var(--border); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; }
.form-group input, .form-group textarea, .form-group select { width: 100%; background: var(--saffron-light); border: 1.5px solid transparent; border-radius: var(--radius-sm); padding: 14px 16px; color: var(--text); font-size: 1rem; transition: var(--transition); }
.form-group textarea { resize: vertical; }
.form-group input::placeholder, .form-group textarea::placeholder { color: #B0956E; }
.form-group input:focus, .form-group textarea:focus { border-color: var(--saffron); background: var(--white); box-shadow: 0 0 0 4px rgba(232,96,10,0.08); }

.tab-buttons { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.tab-btn { background: var(--white); border: 1.5px solid var(--border); color: var(--text-muted); font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 12px 16px; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); }
.tab-btn:hover { border-color: var(--saffron); color: var(--saffron); }
.tab-btn.active { background: var(--saffron); color: var(--white); border-color: var(--saffron); }

#starRating { display: flex; gap: 8px; margin: 20px 0; }
#starRating span { font-size: 2rem; cursor: pointer; opacity: 0.4; transition: var(--transition); }
#starRating span.active { opacity: 1; }

.char-count { display: block; font-size: 0.8rem; color: var(--text-muted); margin-top: 6px; }
.faq-item { margin-bottom: 16px; border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; }
.faq-header { background: var(--saffron-light); padding: 16px 20px; cursor: pointer; transition: var(--transition); display: flex; justify-content: space-between; align-items: center; }
.faq-question { flex: 1; }
.faq-icon { font-size: 1.2rem; color: var(--saffron); transition: var(--transition); }
.faq-header:hover { background: var(--saffron); color: var(--white); }
.faq-header:hover .faq-icon { color: var(--white); }
.faq-item.open .faq-header { background: var(--saffron); color: var(--white); }
.faq-item.open .faq-header .faq-icon { color: var(--white); }
.faq-content { background: var(--white); padding: 20px; display: none; }
.faq-item.open .faq-content { display: block; }

.map-header { text-align: center; margin-bottom: 32px; }
.map-header .panel-tag { text-align: center; }
.map-header h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); text-align: center; margin-top: 8px; }

.map-section { background: #F9F6F1; padding: 80px 24px 96px; }
.map-inner { max-width: 1200px; margin: 0 auto; }
.map-frame { position: relative; width: 100%; height: 450px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); background: var(--white); }
.map-frame iframe { width: 100%; height: 100%; border: none; display: block; }
.map-placeholder { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 20px; text-align: center; background: linear-gradient(135deg, #FFF5EB 0%, #FFE8D6 100%); }
.map-icon { font-size: 3rem; margin-bottom: 16px; }
.map-placeholder h3 { font-family: var(--font-display); font-size: 1.3rem; color: var(--text); margin-bottom: 8px; }
.map-placeholder p { color: var(--text-muted); margin-bottom: 16px; max-width: 300px; }
.map-placeholder a { display: inline-block; padding: 10px 20px; background: var(--saffron); color: var(--white); text-decoration: none; border-radius: var(--radius-sm); font-weight: 500; transition: var(--transition); }

.faq-section-header { text-align: center; margin-bottom: 32px; }
.faq-section-header .panel-tag { text-align: center; }
.faq-section-header h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); text-align: center; margin-top: 8px; }

#formSuccess { display: none; padding: 20px; background: #F0FFF4; border: 1.5px solid #4CAF50; border-radius: var(--radius-sm); color: #2D7A35; text-align: center; }

/* Booking Page Extras */
.steps-bar { background: var(--white); border-bottom: 1px solid var(--border); padding: 24px 0; position: sticky; top: 60px; z-index: 100; box-shadow: 0 2px 16px rgba(26,17,8,0.06); }
.steps-inner { max-width: 860px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: center; gap: 0; }
.step { display: flex; flex-direction: column; align-items: center; gap: 6px; flex: 1; position: relative; }
.step::after { content: ''; position: absolute; top: 18px; left: 50%; right: -50%; height: 2px; background: var(--border); z-index: -1; }
.step:last-child::after { display: none; }
.step-circle { width: 36px; height: 36px; border-radius: 50%; border: 2px solid var(--border); background: var(--white); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 0.78rem; color: var(--text-muted); transition: var(--transition); position: relative; z-index: 1; }
.step.active .step-circle { background: var(--saffron); border-color: var(--saffron); color: var(--white); box-shadow: 0 4px 12px rgba(232,96,10,0.3); }
.step.done .step-circle { background: var(--saffron-dark); border-color: var(--saffron-dark); color: var(--white); }
.step.done::after { background: var(--saffron); }
.step-label { font-family: var(--font-display); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); }
.step.active .step-label { color: var(--saffron); }

.booking-layout { max-width: 1100px; margin: 0 auto; padding: 56px 24px 96px; display: grid; grid-template-columns: 1fr 360px; gap: 40px; align-items: start; }
.booking-form-wrap {}
.step-panel { display: none; }
.step-panel.active { display: block; animation: fadeUp 0.4s ease both; }

.panel-title { font-family: var(--font-display); font-size: 1.4rem; color: var(--text); margin-bottom: 6px; }
.panel-sub { font-size: 1rem; color: var(--text-muted); font-style: italic; margin-bottom: 32px; }

.pkg-select-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px; }
.pkg-select-card { border: 2px solid var(--border); border-radius: var(--radius); padding: 18px; cursor: pointer; transition: var(--transition); background: var(--white); }
.pkg-select-card:hover { border-color: var(--saffron); background: var(--saffron-light); }
.pkg-select-card.selected { border-color: var(--saffron); background: var(--saffron-light); box-shadow: 0 0 0 4px rgba(232,96,10,0.1); }
.pkg-select-card input[type="radio"] { display: none; }
.pkg-card-icon { font-size: 1.5rem; margin-bottom: 8px; }
.pkg-card-name { font-family: var(--font-display); font-size: 0.85rem; color: var(--text); margin-bottom: 4px; }
.pkg-card-price { font-size: 0.9rem; color: var(--saffron-dark); font-weight: 600; }
.pkg-card-dur { font-size: 0.82rem; color: var(--text-muted); }

.form-section-title { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--saffron); margin-bottom: 16px; padding-bottom: 8px; border-bottom: 1px dashed var(--border); }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.booking-sidebar { background: var(--white); border-radius: var(--radius); border: 1px solid var(--border); padding: 32px 24px; position: sticky; top: 88px; box-shadow: var(--shadow-card); }
.booking-summary { margin-bottom: 0; }
.summary-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; font-size: 0.98rem; }
.summary-label { color: var(--text-muted); }
.summary-value { font-family: var(--font-display); color: var(--text); font-weight: 600; }
.summary-total { border-top: 1px dashed var(--border); padding-top: 16px; margin-top: 16px; font-size: 1.1rem; color: var(--saffron-dark); }

.addon-card { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 16px; border: 1px solid var(--border); border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); margin-bottom: 12px; }
.addon-card:hover { border-color: var(--saffron); background: var(--saffron-light); }
.addon-card.selected { border-color: var(--saffron); background: var(--saffron-light); }
.addon-card input { display: none; }

.pay-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.pay-card { border: 2px solid var(--border); border-radius: var(--radius-sm); padding: 16px; text-align: center; cursor: pointer; transition: var(--transition); }
.pay-card:hover { border-color: var(--saffron); }
.pay-card.selected { border-color: var(--saffron); background: var(--saffron-light); }
.pay-icon { font-size: 1.8rem; margin-bottom: 8px; }
.pay-label { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text); }

.promo-code { display: flex; gap: 8px; margin-bottom: 16px; }
.promo-code input { flex: 1; }
.promo-code button { background: var(--saffron); color: var(--white); font-family: var(--font-display); padding: 12px 16px; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); }
.promo-code button:hover { background: var(--saffron-dark); }
#promoMsg { font-size: 0.85rem; margin-top: 6px; }

.btn-proceed { width: 100%; background: var(--saffron); color: var(--white); font-family: var(--font-display); padding: 14px; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); font-weight: 600; border: none; margin-top: 16px; }
.btn-proceed:hover { background: var(--saffron-dark); }

#confirmationWrap { display: none; max-width: 500px; margin: 80px auto; text-align: center; }
#confirmationWrap.show { display: block; animation: fadeUp 0.5s ease both; }
.confirmation-icon { font-size: 4rem; margin-bottom: 16px; }
.confirmation-card { background: var(--white); border-radius: var(--radius); padding: 40px 32px; box-shadow: var(--shadow-card); border: 1px solid var(--border); }

/* Gallery Page Extras */
.filter-section { padding: 48px 24px 32px; max-width: 1180px; margin: 0 auto; }
.filter-top { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; margin-bottom: 28px; }
.filter-top h2 { font-family: var(--font-display); font-size: clamp(1.6rem,3vw,2.2rem); color: var(--text); }
.photo-count { font-size: 0.95rem; color: var(--text-muted); font-style: italic; }
.photo-count strong { color: var(--saffron-dark); font-family: var(--font-display); }

.filter-tabs { display: flex; flex-wrap: wrap; gap: 10px; }
.filter-tab { background: var(--white); border: 1.5px solid var(--border); border-radius: 99px; padding: 9px 20px; font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); transition: var(--transition); }
.filter-tab:hover { border-color: var(--saffron); color: var(--saffron); }
.filter-tab.active { background: var(--saffron); border-color: var(--saffron); color: var(--white); }

.gallery-section { padding: 0 24px 96px; max-width: 1180px; margin: 0 auto; }
.masonry { columns: 4; column-gap: 16px; }
.masonry-item { break-inside: avoid; margin-bottom: 16px; border-radius: var(--radius-sm); overflow: hidden; position: relative; cursor: pointer; background: var(--bg-alt); }
.masonry-item img { display: block; width: 100%; transition: transform 0.5s ease; }
.masonry-item:hover img { transform: scale(1.05); }
.masonry-item.hidden { display: none; }

.masonry-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(26,17,8,0.75) 0%, transparent 50%); opacity: 0; transition: var(--transition); display: flex; align-items: flex-end; padding: 14px; }
.masonry-item:hover .masonry-overlay { opacity: 1; }
.masonry-caption { color: var(--white); font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; }
.masonry-category-tag { position: absolute; top: 10px; left: 10px; background: rgba(232,96,10,0.9); color: var(--white); font-family: var(--font-display); font-size: 0.6rem; letter-spacing: 0.12em; padding: 3px 10px; border-radius: 99px; text-transform: uppercase; opacity: 0; transition: var(--transition); }
.masonry-item:hover .masonry-category-tag { opacity: 1; }
.masonry-zoom { position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,0.9); display: flex; align-items: center; justify-content: center; font-size: 0.9rem; opacity: 0; transition: var(--transition); }
.masonry-item:hover .masonry-zoom { opacity: 1; }

.masonry-item.tall img { aspect-ratio: 3/4; }
.masonry-item.wide img { aspect-ratio: 16/9; }
.masonry-item.square img { aspect-ratio: 1/1; }
.masonry-item.portrait img { aspect-ratio: 2/3; }

.load-more-wrap { text-align: center; padding: 0 0 32px; }
.btn-load { background: var(--white); border: 2px solid var(--saffron); color: var(--saffron); font-family: var(--font-display); font-size: 0.82rem; letter-spacing: 0.1em; padding: 14px 40px; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); }
.btn-load:hover { background: var(--saffron); color: var(--white); }

#lightbox { position: fixed; inset: 0; background: rgba(26,17,8,0.95); z-index: 2000; display: none; align-items: center; justify-content: center; }
#lightbox.open { display: flex; }
.lightbox-content { position: relative; max-width: 86vw; max-height: 90vh; }
.lightbox-img { max-width: 100%; max-height: 100%; }
.lightbox-nav { position: absolute; top: 50%; width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 0 20px; }
.lightbox-nav button { background: rgba(255,255,255,0.2); color: var(--white); border: none; width: 48px; height: 48px; border-radius: 50%; font-size: 1.2rem; cursor: pointer; transition: var(--transition); }
.lightbox-nav button:hover { background: rgba(255,255,255,0.4); }
.lightbox-info { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0,0,0,0.8), transparent); color: var(--white); padding: 40px 24px 24px; text-align: center; }
.lightbox-close { position: absolute; top: 20px; right: 20px; background: none; border: none; color: var(--white); font-size: 2rem; cursor: pointer; }

/* Packages Page Extras */
.packages-layout { max-width: 1180px; margin: 0 auto; padding: 56px 24px 96px; display: grid; grid-template-columns: 280px 1fr; gap: 40px; align-items: start; }

.sidebar { position: sticky; top: 88px; }
.filter-box { background: var(--white); border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow-card); overflow: hidden; margin-bottom: 20px; }
.filter-header { background: var(--saffron-dark); padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; }
.filter-header h3 { font-family: var(--font-display); font-size: 0.8rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--white); }
.filter-clear { font-family: var(--font-display); font-size: 0.65rem; letter-spacing: 0.1em; color: rgba(255,255,255,0.65); cursor: pointer; border: 1px solid rgba(255,255,255,0.3); padding: 4px 10px; border-radius: 99px; transition: var(--transition); background: none; }
.filter-clear:hover { color: var(--white); border-color: var(--white); }
.filter-body { padding: 20px; }
.filter-group { margin-bottom: 20px; }
.filter-group:last-child { margin-bottom: 0; }
.filter-group-title { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--saffron); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px dashed var(--border); }
.filter-checkbox { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; cursor: pointer; }
.filter-checkbox input { cursor: pointer; }
.filter-checkbox label { cursor: pointer; font-size: 0.88rem; }

.price-slider { width: 100%; }
#priceLabel { font-family: var(--font-display); font-size: 0.9rem; color: var(--saffron-dark); font-weight: 600; }

.filter-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.chip { background: var(--saffron-light); color: var(--saffron-dark); font-size: 0.8rem; padding: 6px 12px; border-radius: 99px; display: flex; align-items: center; gap: 6px; font-family: var(--font-display); }
.chip-remove { cursor: pointer; font-weight: bold; }

.pkg-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 28px; }
.pkg-card { background: var(--white); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); border: 1px solid var(--border); transition: var(--transition); position: relative; }
.pkg-card:hover { transform: translateY(-8px); box-shadow: 0 20px 60px rgba(232,96,10,0.14); }
.pkg-card.hidden { display: none; }
.pkg-img-wrap { position: relative; height: 240px; overflow: hidden; }
.pkg-img-wrap img { height: 100%; transition: transform 0.5s ease; }
.pkg-card:hover .pkg-img-wrap img { transform: scale(1.08); }
.pkg-badge { position: absolute; top: 16px; left: 16px; background: var(--saffron); color: var(--white); font-family: var(--font-display); font-size: 0.65rem; letter-spacing: 0.12em; padding: 5px 12px; border-radius: 99px; text-transform: uppercase; }
.pkg-wish { position: absolute; top: 16px; right: 16px; background: rgba(255,255,255,0.9); border: none; font-size: 1.3rem; width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: var(--transition); }
.pkg-wish:hover { background: var(--white); }
.pkg-wish.active { }

.pkg-body { padding: 24px; }
.pkg-title { font-family: var(--font-display); font-size: 1.15rem; color: var(--text); margin-bottom: 8px; }
.pkg-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; flex-wrap: wrap; gap: 8px; }
.pkg-meta-item { font-size: 0.85rem; color: var(--text-muted); }
.pkg-price { font-family: var(--font-display); font-size: 1.3rem; color: var(--saffron-dark); font-weight: 600; margin-bottom: 16px; }
.pkg-includes { list-style: none; margin-bottom: 16px; }
.pkg-includes li { font-size: 0.88rem; color: var(--text-muted); padding: 4px 0; }
.pkg-includes li::before { content: '✔ '; color: var(--saffron); font-weight: bold; }

.sort-wrap { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.sort-wrap label { font-family: var(--font-display); font-size: 0.85rem; letter-spacing: 0.08em; }
.sort-wrap select { background: var(--white); border: 1px solid var(--border); padding: 8px 12px; border-radius: var(--radius-sm); }

#noResults { text-align: center; padding: 60px 24px; color: var(--text-muted); font-size: 1.1rem; }
#resultCount { font-family: var(--font-display); color: var(--saffron-dark); font-weight: 600; }

#toast { position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%); background: var(--saffron); color: var(--white); padding: 16px 24px; border-radius: var(--radius-sm); box-shadow: 0 8px 24px rgba(232,96,10,0.3); font-size: 0.95rem; opacity: 0; transition: opacity 0.3s ease; z-index: 1500; }
#toast.show { opacity: 1; }

.modal-overlay { position: fixed; inset: 0; background: rgba(26,17,8,0.65); backdrop-filter: blur(6px); z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.modal-overlay.active { opacity: 1; pointer-events: all; }
.modal-detail-label { font-family: var(--font-display); font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.modal-detail-val { font-size: 0.98rem; color: var(--text); }
.modal-details { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }
.modal-detail { }
#modalIncludes { list-style: none; margin-top: 16px; text-align: left; }
#modalIncludes li { font-size: 0.95rem; color: var(--text-muted); padding: 8px 0; }
#modalIncludes li::before { content: '✔ '; color: var(--saffron); font-weight: bold; }

@media (max-width: 1024px) {
  .packages-layout { grid-template-columns: 1fr; }
  .sidebar { position: relative; top: auto; }
  .pkg-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
  .masonry { columns: 3; }
}

@media (max-width: 768px) {
  .contact-main { grid-template-columns: 1fr; gap: 32px; }
  .packages-layout { padding: 40px 16px 80px; }
  .pkg-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
  .form-row { grid-template-columns: 1fr; }
  .form-row-2 { grid-template-columns: 1fr; }
  .pkg-select-grid { grid-template-columns: 1fr; }
  .pay-cards { grid-template-columns: 1fr; }
  .booking-layout { grid-template-columns: 1fr; }
  .step { gap: 3px; }
  .step-label { font-size: 0.5rem; }
  .masonry { columns: 2; }
  .info-cards-inner { grid-template-columns: repeat(2, 1fr); }
}

/* ===== DJANGO MESSAGES ===== */
.django-messages{position:fixed;top:80px;right:20px;z-index:5000;display:flex;flex-direction:column;gap:8px;max-width:380px;}
.dmsg{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-radius:10px;font-size:0.95rem;animation:fadeUp 0.4s ease;box-shadow:0 4px 20px rgba(0,0,0,0.12);}
.dmsg button{background:none;border:none;cursor:pointer;opacity:0.6;font-size:1rem;flex-shrink:0;padding:0 4px;}
.dmsg-success{background:#E8F5E9;color:#2E7D32;border:1px solid #A5D6A7;}
.dmsg-error{background:#FFEBEE;color:#C62828;border:1px solid #FFCDD2;}
.dmsg-info{background:#E3F2FD;color:#1565C0;border:1px solid #90CAF9;}
.dmsg-warning{background:#FFF8E1;color:#F57F17;border:1px solid #FFE082;}
/* ===== REGISTER FORM INPUT STYLING ===== */
#id_username,#id_password1,#id_password2,#id_first_name,#id_last_name,#id_email,#id_phone,#id_city{width:100%;background:var(--saffron-light);border:1.5px solid transparent;border-radius:var(--radius-sm);padding:13px 16px;font-family:var(--font-body);font-size:1rem;color:var(--text);outline:none;transition:var(--tr);box-sizing:border-box;}
#id_username:focus,#id_password1:focus,#id_password2:focus,#id_first_name:focus,#id_last_name:focus,#id_email:focus,#id_phone:focus,#id_city:focus{border-color:var(--saffron);background:var(--white);box-shadow:0 0 0 4px rgba(232,96,10,0.08);}
/* ===== BTN APPLY (promo) ===== */
.btn-apply{background:var(--saffron);color:var(--white);padding:0 18px;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:0.75rem;letter-spacing:0.08em;cursor:pointer;border:none;white-space:nowrap;transition:var(--tr);}
.btn-apply:hover{background:var(--saffron-dark);}
