/* ============================================================
   INCREDIBLE INDIA — MAIN STYLESHEET
   India-inspired: Saffron, Ivory, Forest Green, Gold
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --saffron:     #FF6B00;
  --deep-saffron:#E85D00;
  --gold:        #C8962E;
  --gold-light:  #E8B84B;
  --ivory:       #FAF7F0;
  --cream:       #F5EFE0;
  --forest:      #1A3A2A;
  --deep-green:  #0D2218;
  --jade:        #2D6A4F;
  --navy:        #0A1628;
  --charcoal:    #1C1C1E;
  --warm-grey:   #8A7E72;
  --light-grey:  #E8E2D9;
  --white:       #FFFFFF;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'DM Sans',sans-serif; background:var(--ivory); color:var(--charcoal); overflow-x:hidden; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--cream); }
::-webkit-scrollbar-thumb { background:var(--saffron); border-radius:2px; }

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:64px; padding:0 5%;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(10,22,40,0.96); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(200,150,46,0.25);
  transition:all 0.3s;
}
.navbar.scrolled { background:rgba(10,22,40,1); box-shadow:0 4px 30px rgba(0,0,0,0.3); }
.nav-logo { font-family:'Playfair Display',serif; font-size:1.35rem; font-weight:900; color:#fff; letter-spacing:-0.5px; }
.nav-logo span { color:var(--saffron); }
.nav-links { display:flex; gap:1.8rem; list-style:none; align-items:center; }
.nav-links > li { position:relative; }
.nav-links a { color:rgba(255,255,255,0.7); font-size:0.78rem; font-weight:500; letter-spacing:0.06em; text-transform:uppercase; transition:color 0.2s; padding:0.5rem 0; display:block; }
.nav-links a:hover { color:var(--saffron); }
.nav-wa { background:var(--saffron); color:#fff !important; padding:0.45rem 1.1rem !important; border-radius:2px; white-space:nowrap; }
.nav-wa:hover { background:var(--deep-saffron) !important; color:#fff !important; }

/* Dropdown */
.has-dropdown:hover .dropdown { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown {
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--navy); border:1px solid rgba(255,255,255,0.1); border-radius:4px;
  min-width:220px; padding:0.5rem 0; opacity:0; visibility:hidden;
  transition:all 0.25s; box-shadow:0 20px 40px rgba(0,0,0,0.4);
  z-index:100;
}
.dropdown a { padding:0.6rem 1.2rem; font-size:0.75rem; color:rgba(255,255,255,0.65) !important; text-transform:none !important; letter-spacing:0.02em !important; }
.dropdown a:hover { color:var(--saffron) !important; background:rgba(255,107,0,0.08); }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.hamburger span { width:24px; height:2px; background:#fff; display:block; transition:0.3s; }
.mobile-menu { display:none; position:fixed; inset:0; top:64px; background:var(--navy); z-index:999; overflow-y:auto; padding:2rem 5%; }
.mobile-menu.open { display:block; }
.mobile-menu a { display:block; padding:1rem 0; font-size:1rem; color:rgba(255,255,255,0.8); border-bottom:1px solid rgba(255,255,255,0.08); }

/* ===== HERO ===== */
.hero {
  height:100vh; min-height:680px; position:relative;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; background:var(--navy);
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center 30%;
  opacity:0.45; animation:slowZoom 18s ease-in-out infinite alternate;
}
@keyframes slowZoom { from{transform:scale(1)} to{transform:scale(1.08)} }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(10,22,40,0.25) 0%, rgba(10,22,40,0.45) 55%, rgba(10,22,40,0.92) 100%); }
.hero-content { position:relative; z-index:2; text-align:center; max-width:950px; padding:0 2rem; animation:heroIn 1.2s ease; }
@keyframes heroIn { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
.hero-eyebrow { display:inline-block; font-size:0.68rem; letter-spacing:0.28em; text-transform:uppercase; color:var(--gold); border:1px solid rgba(200,150,46,0.4); padding:0.35rem 1.2rem; margin-bottom:1.5rem; border-radius:2px; }
.hero-title { font-family:'Playfair Display',serif; font-size:clamp(3rem,8vw,7rem); font-weight:900; line-height:1; color:#fff; letter-spacing:-2px; margin-bottom:0.4rem; }
.hero-title em { font-style:italic; color:var(--saffron); }
.hero-subtitle { font-family:'Cormorant Garamond',serif; font-size:clamp(1.05rem,2.2vw,1.45rem); font-weight:300; color:rgba(255,255,255,0.72); margin:1.4rem 0 2.5rem; font-style:italic; line-height:1.65; }
.hero-stats { display:flex; gap:3rem; justify-content:center; margin-bottom:3rem; flex-wrap:wrap; }
.hero-stat-num { font-family:'Playfair Display',serif; font-size:2rem; font-weight:900; color:var(--saffron); line-height:1; }
.hero-stat-label { font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.45); margin-top:0.3rem; }
.btn-primary { display:inline-flex; align-items:center; gap:0.6rem; background:var(--saffron); color:#fff; padding:0.85rem 2rem; border-radius:2px; font-weight:600; font-size:0.85rem; letter-spacing:0.05em; transition:all 0.25s; border:none; cursor:pointer; }
.btn-primary:hover { background:var(--deep-saffron); transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,107,0,0.35); }
.btn-outline { display:inline-flex; align-items:center; gap:0.6rem; background:transparent; color:#fff; padding:0.82rem 2rem; border-radius:2px; font-weight:500; font-size:0.85rem; letter-spacing:0.05em; transition:all 0.25s; border:1px solid rgba(255,255,255,0.3); }
.btn-outline:hover { border-color:var(--saffron); color:var(--saffron); }
.hero-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-scroll-hint { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); color:rgba(255,255,255,0.35); font-size:0.65rem; letter-spacing:0.18em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:0.5rem; animation:float 2.5s ease infinite; }
.hero-scroll-hint::after { content:''; width:1px; height:36px; background:linear-gradient(to bottom,rgba(255,255,255,0.3),transparent); }
@keyframes float { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }

/* ===== SECTIONS ===== */
section { padding:5.5rem 6%; }
.section-label { font-size:0.65rem; letter-spacing:0.28em; text-transform:uppercase; color:var(--saffron); font-weight:500; margin-bottom:0.7rem; display:block; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(1.9rem,3.8vw,3rem); font-weight:900; line-height:1.1; color:var(--charcoal); letter-spacing:-0.8px; margin-bottom:1rem; }
.section-title em { font-style:italic; color:var(--saffron); }
.section-title.light { color:#fff; }
.section-desc { font-family:'Cormorant Garamond',serif; font-size:1.12rem; color:var(--warm-grey); line-height:1.8; max-width:680px; font-style:italic; }
.section-desc.light { color:rgba(255,255,255,0.6); }
.section-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:3rem; gap:2rem; flex-wrap:wrap; }

/* ===== MANIFESTO ===== */
.manifesto { background:var(--navy); padding:7rem 6%; text-align:center; }
.manifesto-text { font-family:'Playfair Display',serif; font-size:clamp(1.45rem,3.2vw,2.6rem); font-weight:400; font-style:italic; color:#fff; max-width:900px; margin:0 auto; line-height:1.55; }
.manifesto-text strong { color:var(--saffron); font-weight:700; font-style:normal; }
.manifesto-divider { width:50px; height:2px; background:var(--saffron); margin:2.5rem auto; }
.manifesto-author { font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.3); }

/* ===== FEATURE BAR ===== */
.feature-bar { background:var(--saffron); padding:1.5rem 6%; display:flex; gap:3rem; align-items:center; overflow-x:auto; scrollbar-width:none; }
.feature-bar::-webkit-scrollbar{display:none}
.feature-item { display:flex; align-items:center; gap:0.75rem; white-space:nowrap; }
.feature-item strong { display:block; font-size:0.8rem; font-weight:700; color:#fff; }
.feature-item span { font-size:0.7rem; color:rgba(255,255,255,0.75); }

/* ===== DESTINATION CARDS ===== */
.dest-mosaic { display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:auto; gap:1.2rem; }
.dest-card { position:relative; border-radius:4px; overflow:hidden; cursor:pointer; }
.dest-card.wide { grid-column:span 2; }
.dest-card.tall { grid-row:span 2; }
.dest-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.65s ease; display:block; }
.dest-card:hover img { transform:scale(1.07); }
.dest-card-inner { aspect-ratio:4/5; }
.dest-card.wide .dest-card-inner { aspect-ratio:16/8; }
.dest-card.tall .dest-card-inner { aspect-ratio:4/7; }
.dest-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(10,22,40,0.9) 0%, rgba(10,22,40,0.15) 55%, transparent 100%); transition:opacity 0.3s; }
.dest-info { position:absolute; bottom:0; left:0; right:0; padding:1.4rem; }
.dest-region { font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--saffron); margin-bottom:0.3rem; }
.dest-name { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:#fff; line-height:1.2; }
.dest-card.wide .dest-name { font-size:1.7rem; }
.dest-teaser { font-size:0.75rem; color:rgba(255,255,255,0.0); margin-top:0.35rem; line-height:1.5; transition:color 0.3s 0.05s; max-width:340px; }
.dest-card:hover .dest-teaser { color:rgba(255,255,255,0.65); }

/* ===== STATE GRID ===== */
.states-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:3rem; }
.state-card { background:#fff; border-radius:4px; overflow:hidden; transition:transform 0.3s, box-shadow 0.3s; }
.state-card:hover { transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,0,0,0.1); }
.state-img { width:100%; height:210px; object-fit:cover; }
.state-body { padding:1.4rem; }
.state-name { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--charcoal); margin-bottom:0.3rem; }
.state-tagline { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:0.9rem; color:var(--saffron); margin-bottom:0.7rem; }
.state-tags { display:flex; flex-wrap:wrap; gap:0.35rem; }
.state-tag { font-size:0.68rem; color:var(--warm-grey); background:var(--cream); padding:0.2rem 0.55rem; border-radius:2px; }
.state-wa { display:flex; align-items:center; gap:0.4rem; margin-top:1rem; font-size:0.73rem; color:var(--jade); font-weight:500; transition:color 0.2s; }
.state-wa:hover { color:var(--saffron); }

/* ===== JAIN SECTION ===== */
.jain-section { background:linear-gradient(135deg, var(--deep-green), var(--forest), #0D3320); color:#fff; position:relative; overflow:hidden; }
.jain-section::before { content:'☸'; position:absolute; right:3%; top:50%; transform:translateY(-50%); font-size:22rem; opacity:0.04; pointer-events:none; line-height:1; }
.jain-grid { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; margin-top:3rem; align-items:start; }
.jain-sites-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.jain-site { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius:4px; padding:1.2rem; transition:background 0.3s; }
.jain-site:hover { background:rgba(255,255,255,0.1); border-color:rgba(200,150,46,0.4); }
.jain-site-icon { font-size:1.4rem; margin-bottom:0.5rem; }
.jain-site-name { font-family:'Playfair Display',serif; font-size:0.9rem; font-weight:700; color:#fff; margin-bottom:0.25rem; }
.jain-site-loc { font-size:0.65rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); margin-bottom:0.35rem; }
.jain-site-desc { font-size:0.75rem; color:rgba(255,255,255,0.5); line-height:1.5; }
.jain-route { background:rgba(255,255,255,0.05); border:1px solid rgba(200,150,46,0.3); border-radius:4px; padding:2rem; }
.jain-route-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--gold); margin-bottom:1.5rem; }
.route-stop { display:flex; gap:1rem; margin-bottom:0.9rem; align-items:flex-start; }
.route-dot { width:8px; height:8px; border-radius:50%; background:var(--saffron); margin-top:5px; flex-shrink:0; }
.route-city { font-size:0.82rem; font-weight:500; color:#fff; }
.route-detail { font-size:0.7rem; color:rgba(255,255,255,0.42); line-height:1.4; }
.jain-quote { margin-top:2rem; padding:1.4rem; border-left:3px solid var(--gold); background:rgba(200,150,46,0.07); }
.jain-quote p { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1rem; color:rgba(255,255,255,0.78); line-height:1.7; }

/* ===== BIHAR CIRCUIT ===== */
.bihar-section { background:var(--navy); color:#fff; }
.bihar-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-top:3rem; align-items:start; }
.bihar-day { display:grid; grid-template-columns:60px 1fr; gap:1.2rem; margin-bottom:1.8rem; position:relative; }
.bihar-day::after { content:''; position:absolute; left:28px; top:46px; width:1px; height:calc(100% + 0.8rem); background:rgba(255,107,0,0.2); }
.bihar-day:last-child::after { display:none; }
.day-num { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:900; color:var(--saffron); line-height:1; text-align:center; padding-top:0.2rem; }
.day-label { font-size:0.6rem; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,107,0,0.5); }
.bihar-day-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:0.35rem; }
.bihar-day-places { font-size:0.78rem; color:rgba(255,255,255,0.5); line-height:1.6; }
.bihar-day-food { margin-top:0.45rem; font-size:0.7rem; color:var(--gold); }
.bihar-site { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); border-radius:4px; padding:1.2rem; margin-bottom:0.9rem; transition:all 0.3s; }
.bihar-site:hover { background:rgba(255,107,0,0.08); border-color:rgba(255,107,0,0.3); }
.bihar-site-name { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:#fff; margin-bottom:0.2rem; }
.bihar-site-faith { font-size:0.62rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--saffron); margin-bottom:0.35rem; }
.bihar-site-desc { font-size:0.75rem; color:rgba(255,255,255,0.48); line-height:1.5; }

/* ===== EXPERIENCES ===== */
.exp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:3rem; }
.exp-card { position:relative; border-radius:4px; overflow:hidden; cursor:pointer; }
.exp-card.featured { grid-column:span 2; }
.exp-card-inner { height:300px; }
.exp-card.featured .exp-card-inner { height:360px; }
.exp-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.exp-card:hover img { transform:scale(1.06); }
.exp-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,0.88) 0%, transparent 65%); }
.exp-content { position:absolute; bottom:0; left:0; right:0; padding:1.6rem; }
.exp-tag { font-size:0.58rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--saffron); background:rgba(255,107,0,0.15); border:1px solid rgba(255,107,0,0.35); padding:0.18rem 0.55rem; display:inline-block; margin-bottom:0.45rem; border-radius:2px; }
.exp-title { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; color:#fff; line-height:1.2; margin-bottom:0.4rem; }
.exp-card.featured .exp-title { font-size:1.8rem; }
.exp-desc { font-size:0.75rem; color:rgba(255,255,255,0.6); line-height:1.5; }

/* ===== FOOD SECTION ===== */
.food-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:2.5rem; }
.food-card { background:#fff; border-radius:4px; padding:1.2rem; border-left:3px solid var(--light-grey); transition:all 0.3s; }
.food-card:hover { border-left-color:var(--saffron); transform:translateX(3px); box-shadow:0 8px 24px rgba(0,0,0,0.06); }
.food-city { font-size:0.62rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--saffron); margin-bottom:0.35rem; }
.food-name { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:var(--charcoal); margin-bottom:0.25rem; }
.food-desc { font-size:0.73rem; color:var(--warm-grey); line-height:1.5; }
.food-market { margin-top:0.5rem; font-size:0.67rem; color:var(--jade); font-weight:500; }

/* ===== FESTIVALS ===== */
.festivals-section { background:var(--charcoal); color:#fff; position:relative; overflow:hidden; }
.festivals-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0.1; }
.festivals-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:3rem; position:relative; }
.festival-card { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); border-radius:4px; padding:1.4rem; transition:all 0.3s; }
.festival-card:hover { background:rgba(255,107,0,0.1); border-color:rgba(255,107,0,0.4); transform:translateY(-3px); }
.festival-month { font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--saffron); margin-bottom:0.45rem; }
.festival-name { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:0.3rem; }
.festival-place { font-size:0.7rem; color:rgba(255,255,255,0.42); margin-bottom:0.45rem; }
.festival-why { font-size:0.73rem; color:rgba(255,255,255,0.58); line-height:1.5; }

/* ===== WILDLIFE ===== */
.wildlife-section { background:var(--forest); color:#fff; }
.wildlife-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-top:3rem; }
.wildlife-card { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); border-radius:4px; overflow:hidden; transition:transform 0.3s; }
.wildlife-card:hover { transform:translateY(-4px); }
.wildlife-img { width:100%; height:180px; object-fit:cover; }
.wildlife-body { padding:1.1rem; }
.wildlife-animal { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:0.25rem; }
.wildlife-loc { font-size:0.68rem; color:var(--gold); margin-bottom:0.35rem; letter-spacing:0.05em; }
.wildlife-desc { font-size:0.73rem; color:rgba(255,255,255,0.48); line-height:1.5; }

/* ===== LONG STAY ===== */
.ls-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-top:3rem; align-items:start; }
.ls-feature { display:flex; gap:1.1rem; margin-bottom:1.6rem; padding-bottom:1.6rem; border-bottom:1px solid var(--light-grey); }
.ls-feature:last-child { border-bottom:none; }
.ls-icon { font-size:1.7rem; flex-shrink:0; }
.ls-feat-title { font-family:'Playfair Display',serif; font-size:0.95rem; font-weight:700; color:var(--charcoal); margin-bottom:0.25rem; }
.ls-feat-desc { font-size:0.78rem; color:var(--warm-grey); line-height:1.6; }
.ls-season-box { background:var(--charcoal); border-radius:4px; padding:2.2rem; color:#fff; }
.ls-season-title { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--gold); margin-bottom:1.4rem; }
.ls-month { display:flex; justify-content:space-between; align-items:center; padding:0.75rem 0; border-bottom:1px solid rgba(255,255,255,0.07); font-size:0.82rem; }
.ls-month:last-child { border-bottom:none; }
.ls-month-name { color:rgba(255,255,255,0.7); font-weight:500; }
.ls-month-dest { font-size:0.7rem; color:rgba(255,255,255,0.4); }
.ls-month-stars { color:var(--saffron); font-size:0.7rem; }

/* ===== CONTACT FORM ===== */
.contact-section { background:var(--navy); color:#fff; }
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:4rem; margin-top:3rem; align-items:start; }
.contact-info { }
.contact-method { display:flex; gap:1rem; margin-bottom:1.5rem; align-items:flex-start; }
.contact-method-icon { font-size:1.5rem; }
.contact-method-title { font-weight:600; color:#fff; font-size:0.85rem; margin-bottom:0.2rem; }
.contact-method-val { font-size:0.8rem; color:rgba(255,255,255,0.5); }
.contact-form { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:4px; padding:2.5rem; }
.form-group { margin-bottom:1.2rem; }
.form-label { display:block; font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-bottom:0.5rem; }
.form-control { width:100%; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.12); border-radius:3px; padding:0.75rem 1rem; color:#fff; font-size:0.85rem; font-family:'DM Sans',sans-serif; transition:border-color 0.2s; outline:none; }
.form-control:focus { border-color:var(--saffron); }
.form-control option { background:var(--navy); color:#fff; }
textarea.form-control { resize:vertical; min-height:100px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-submit { width:100%; margin-top:1rem; font-size:0.85rem; }
.form-note { font-size:0.7rem; color:rgba(255,255,255,0.35); margin-top:0.75rem; text-align:center; }
.success-msg { background:rgba(45,106,79,0.2); border:1px solid rgba(45,106,79,0.5); border-radius:4px; padding:1rem 1.2rem; color:#a8e6c6; font-size:0.85rem; margin-bottom:1rem; display:none; }
.error-msg { background:rgba(220,53,69,0.2); border:1px solid rgba(220,53,69,0.4); border-radius:4px; padding:1rem 1.2rem; color:#f5c6cb; font-size:0.85rem; margin-bottom:1rem; display:none; }

/* ===== TRAVEL GUIDE ===== */
.guide-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.guide-card { background:#fff; border-radius:4px; padding:1.8rem; border-top:3px solid var(--saffron); box-shadow:0 2px 16px rgba(0,0,0,0.05); }
.guide-icon { font-size:2rem; margin-bottom:0.8rem; }
.guide-title { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:700; color:var(--charcoal); margin-bottom:0.75rem; }
.guide-list { list-style:none; }
.guide-list li { font-size:0.78rem; color:var(--warm-grey); padding:0.4rem 0; border-bottom:1px solid var(--light-grey); line-height:1.5; }
.guide-list li:last-child { border-bottom:none; }
.guide-list li strong { color:var(--charcoal); }

/* ===== PACKAGES ===== */
.packages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.pkg-card { background:#fff; border-radius:4px; overflow:hidden; border:1px solid var(--light-grey); transition:all 0.3s; }
.pkg-card:hover { transform:translateY(-4px); box-shadow:0 20px 50px rgba(0,0,0,0.1); border-color:var(--saffron); }
.pkg-img { width:100%; height:180px; object-fit:cover; }
.pkg-body { padding:1.4rem; }
.pkg-duration { font-size:0.65rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--saffron); margin-bottom:0.4rem; }
.pkg-name { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:700; color:var(--charcoal); margin-bottom:0.4rem; }
.pkg-includes { display:flex; flex-wrap:wrap; gap:0.3rem; margin-bottom:1rem; }
.pkg-incl-tag { font-size:0.65rem; background:var(--cream); color:var(--warm-grey); padding:0.2rem 0.5rem; border-radius:2px; }
.pkg-footer { display:flex; align-items:center; justify-content:space-between; padding-top:0.75rem; border-top:1px solid var(--light-grey); }
.pkg-price { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--charcoal); }
.pkg-price-note { font-size:0.65rem; color:var(--warm-grey); font-weight:400; }
.pkg-enquire { font-size:0.72rem; color:var(--saffron); font-weight:600; display:flex; align-items:center; gap:0.3rem; transition:gap 0.2s; }
.pkg-enquire:hover { gap:0.6rem; }

/* ===== FLOATING WA ===== */
.wa-float { position:fixed; bottom:2rem; right:2rem; z-index:999; display:flex; align-items:center; gap:0.7rem; background:#25D366; color:#fff; padding:0.8rem 1.4rem; border-radius:50px; font-weight:600; font-size:0.82rem; box-shadow:0 8px 30px rgba(37,211,102,0.4); transition:all 0.3s; white-space:nowrap; }
.wa-float:hover { background:#1ebe5c; transform:translateY(-3px); box-shadow:0 12px 40px rgba(37,211,102,0.5); color:#fff; }
.wa-float-icon { font-size:1.2rem; }

/* ===== FOOTER ===== */
.footer { background:var(--deep-green); color:#fff; padding:4rem 6% 2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-brand { }
.footer-logo { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:900; color:#fff; margin-bottom:0.8rem; }
.footer-logo span { color:var(--saffron); }
.footer-tagline { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1rem; color:rgba(255,255,255,0.5); margin-bottom:1.2rem; line-height:1.6; }
.footer-citizen { font-size:0.72rem; color:rgba(255,255,255,0.3); line-height:1.6; }
.footer-col-title { font-size:0.72rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; font-weight:600; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:0.55rem; }
.footer-links a { font-size:0.78rem; color:rgba(255,255,255,0.5); transition:color 0.2s; }
.footer-links a:hover { color:var(--saffron); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:2rem; border-top:1px solid rgba(255,255,255,0.08); font-size:0.72rem; color:rgba(255,255,255,0.3); flex-wrap:wrap; gap:1rem; }
.footer-india { color:var(--saffron); }

/* ===== PAGE HERO ===== */
.page-hero { padding:9rem 6% 4rem; background:var(--navy); color:#fff; position:relative; overflow:hidden; margin-top:0; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0.3; }
.page-hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(10,22,40,0.5), rgba(10,22,40,0.85)); }
.page-hero-content { position:relative; z-index:2; max-width:700px; }
.breadcrumb { display:flex; gap:0.5rem; font-size:0.7rem; color:rgba(255,255,255,0.4); margin-bottom:1rem; align-items:center; flex-wrap:wrap; }
.breadcrumb a { color:rgba(255,255,255,0.4); transition:color 0.2s; }
.breadcrumb a:hover { color:var(--saffron); }
.breadcrumb-sep { color:rgba(255,255,255,0.2); }
.page-hero-title { font-family:'Playfair Display',serif; font-size:clamp(2rem,5vw,3.8rem); font-weight:900; line-height:1.1; color:#fff; letter-spacing:-1px; margin-bottom:1rem; }
.page-hero-desc { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.1rem; color:rgba(255,255,255,0.65); line-height:1.7; max-width:600px; }

/* ===== UTILITIES ===== */
.bg-cream { background:var(--cream); }
.bg-white { background:#fff; }
.bg-navy { background:var(--navy); color:#fff; }
.bg-forest { background:var(--forest); color:#fff; }
.bg-charcoal { background:var(--charcoal); color:#fff; }
.text-center { text-align:center; }
.mt-2 { margin-top:2rem; }
.mt-3 { margin-top:3rem; }
.mb-2 { margin-bottom:2rem; }
.divider { width:50px; height:2px; background:var(--saffron); margin:2rem auto; }
.divider.left { margin:1.5rem 0; }

/* ===== ABOUT ===== */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-main { width:100%; height:500px; object-fit:cover; border-radius:4px; }
.about-img-badge { position:absolute; bottom:-1.5rem; right:-1.5rem; background:var(--saffron); color:#fff; padding:1.5rem; border-radius:4px; text-align:center; }
.about-badge-num { font-family:'Playfair Display',serif; font-size:2.5rem; font-weight:900; line-height:1; }
.about-badge-txt { font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; opacity:0.85; margin-top:0.3rem; }
.values-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:2rem; }
.value-item { background:var(--cream); border-radius:4px; padding:1.2rem; }
.value-icon { font-size:1.5rem; margin-bottom:0.5rem; }
.value-title { font-weight:600; font-size:0.85rem; color:var(--charcoal); margin-bottom:0.3rem; }
.value-desc { font-size:0.75rem; color:var(--warm-grey); line-height:1.5; }

/* ===== ADMIN ===== */
.admin-bar { background:var(--charcoal); color:#fff; padding:1rem 3%; display:flex; justify-content:space-between; align-items:center; }
.admin-title { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; }
.admin-table { width:100%; border-collapse:collapse; }
.admin-table th { background:var(--cream); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.1em; padding:0.75rem 1rem; text-align:left; color:var(--warm-grey); font-weight:600; }
.admin-table td { padding:0.8rem 1rem; border-bottom:1px solid var(--light-grey); font-size:0.82rem; vertical-align:top; }
.admin-table tr:hover td { background:var(--cream); }
.badge { display:inline-block; padding:0.2rem 0.55rem; border-radius:2px; font-size:0.65rem; font-weight:600; letter-spacing:0.05em; text-transform:uppercase; }
.badge-new { background:rgba(255,107,0,0.12); color:var(--saffron); }
.badge-read { background:var(--cream); color:var(--warm-grey); }

/* ===== RESPONSIVE ===== */
@media(max-width:1100px) {
  .dest-mosaic { grid-template-columns:repeat(2,1fr); }
  .dest-card.tall { grid-row:span 1; }
  .dest-card.wide { grid-column:span 2; }
  .festivals-grid { grid-template-columns:repeat(2,1fr); }
  .food-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:900px) {
  section { padding:4rem 5%; }
  .states-grid { grid-template-columns:1fr 1fr; }
  .jain-grid { grid-template-columns:1fr; }
  .bihar-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .ls-grid { grid-template-columns:1fr; }
  .packages-grid { grid-template-columns:1fr 1fr; }
  .about-grid { grid-template-columns:1fr; }
  .guide-grid { grid-template-columns:1fr 1fr; }
  .wildlife-grid { grid-template-columns:1fr 1fr; }
  .exp-grid { grid-template-columns:1fr; }
  .exp-card.featured { grid-column:span 1; }
}
@media(max-width:720px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .hero-stats { gap:1.5rem; }
  .dest-mosaic { grid-template-columns:1fr; }
  .dest-card.wide { grid-column:span 1; }
  .festivals-grid { grid-template-columns:1fr; }
  .food-grid { grid-template-columns:1fr; }
  .states-grid { grid-template-columns:1fr; }
  .packages-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .jain-sites-grid { grid-template-columns:1fr; }
  .guide-grid { grid-template-columns:1fr; }
  .wildlife-grid { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .wa-float span { display:none; }
  .wa-float { padding:0.9rem; border-radius:50%; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .hero-btns { flex-direction:column; align-items:center; }
}

/* ============================================================
   MOBILE OPTIMIZATION — Complete
   ============================================================ */

@media(max-width:768px) {

  /* NAVBAR */
  .navbar { padding:0 4%; height:56px; }
  .nav-logo { font-size:1.1rem; }

  /* HERO */
  .hero { min-height:100svh; }
  .hero-title { font-size:2.8rem; letter-spacing:-1px; }
  .hero-subtitle { font-size:0.95rem; padding:0 1rem; }
  .hero-stats { gap:1.2rem; flex-wrap:wrap; justify-content:center; }
  .hero-stat-num { font-size:1.6rem; }
  .hero-stat-label { font-size:0.6rem; }
  .hero-btns { flex-direction:column; align-items:center; gap:0.75rem; }
  .btn-primary, .btn-outline { width:100%; max-width:280px; justify-content:center; }

  /* MANIFESTO */
  .manifesto { padding:4rem 5%; }
  .manifesto-text { font-size:1.2rem; line-height:1.6; }

  /* FEATURE BAR */
  .feature-bar { gap:2rem; padding:1.2rem 4%; }
  .feature-item strong { font-size:0.72rem; }
  .feature-item span { font-size:0.62rem; }

  /* DESTINATIONS GRID */
  #destinations > div[style*="grid"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* RELIGION CIRCUITS */
  section > div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns:1fr !important;
  }

  /* EXPERIENCES GRID */
  section > div[style*="grid-template-columns:repeat(4"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* DELHI ZOO */
  section > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns:1fr !important;
    gap:2rem !important;
  }

  /* FESTIVALS */
  section > div.festivals-grid,
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* FOOD CARDS */
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr 1fr !important;
  }

  /* TRAVEL COSTS STATS */
  div[style*="display:flex;justify-content:center;gap:4rem"] {
    gap:1.5rem !important;
    flex-wrap:wrap !important;
  }

  /* CONTACT SECTION */
  div[style*="grid-template-columns:1fr 1.3fr"] {
    grid-template-columns:1fr !important;
    gap:2rem !important;
  }

  /* FORM ROWS */
  div[style*="grid-template-columns:1fr 1fr;gap:1rem"] {
    grid-template-columns:1fr !important;
  }

  /* SECTION HEADERS */
  .section-header {
    flex-direction:column !important;
    align-items:flex-start !important;
  }
  .section-title { font-size:1.8rem !important; }

  /* WHATSAPP FLOAT */
  .wa-float { 
    bottom:1.2rem; 
    right:1.2rem;
    padding:0.8rem 1.2rem;
    font-size:0.78rem;
  }

  /* DESTINATION CARDS */
  .dest-card { aspect-ratio:4/3 !important; }
  .dest-name { font-size:0.9rem !important; }

  /* FOOTER */
  .footer-grid { 
    grid-template-columns:1fr !important; 
    gap:2rem !important; 
  }
  .footer-bottom { 
    flex-direction:column !important; 
    text-align:center !important; 
    gap:0.5rem !important;
  }

  /* GENERAL SECTION PADDING */
  section { padding:3.5rem 4% !important; }
  .manifesto { padding:3.5rem 4% !important; }

  /* PAGE HERO */
  .page-hero { padding:7rem 4% 3rem !important; }
  .page-hero-title { font-size:2rem !important; }
}

@media(max-width:480px) {

  /* EXTRA SMALL PHONES */
  .hero-title { font-size:2.2rem; }
  .hero-eyebrow { font-size:0.58rem; letter-spacing:0.15em; }

  /* DESTINATIONS — single column on very small screens */
  #destinations > div[style*="grid"] {
    grid-template-columns:1fr !important;
  }

  /* EXPERIENCES — single column */
  section > div[style*="grid-template-columns:repeat(4"] {
    grid-template-columns:1fr !important;
  }

  /* FESTIVALS — single column */  
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr !important;
  }

  .manifesto-text { font-size:1.05rem; }
  .section-title { font-size:1.6rem !important; }

  /* HERO STATS — 2x2 grid */
  .hero-stats { 
    display:grid !important; 
    grid-template-columns:1fr 1fr !important;
    gap:1rem !important;
    width:100% !important;
  }
  .hero-stat { text-align:center; }

  /* RELIGION CARDS */
  section > div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns:1fr !important;
  }
}

/* TOUCH IMPROVEMENTS */
@media(hover:none) {
  .dest-card:active img { transform:scale(1.04); }
  .nav-links a { padding:0.75rem 0; }
  
  /* Remove hover-only teaser text — show always on mobile */
  .dest-teaser { 
    color:rgba(255,255,255,0.55) !important; 
    font-size:0.65rem !important;
  }
}

/* SAFE AREA for iPhone notch */
@supports(padding:max(0px)) {
  .navbar { 
    padding-left:max(4%, env(safe-area-inset-left));
    padding-right:max(4%, env(safe-area-inset-right));
  }
  .wa-float {
    bottom:max(1.2rem, env(safe-area-inset-bottom));
    right:max(1.2rem, env(safe-area-inset-right));
  }
}

/* ============================================================
   MOBILE OPTIMIZATION — Complete
   ============================================================ */

@media(max-width:768px) {

  /* NAVBAR */
  .navbar { padding:0 4%; height:56px; }
  .nav-logo { font-size:1.1rem; }

  /* HERO */
  .hero { min-height:100svh; }
  .hero-title { font-size:2.8rem; letter-spacing:-1px; }
  .hero-subtitle { font-size:0.95rem; padding:0 1rem; }
  .hero-stats { gap:1.2rem; flex-wrap:wrap; justify-content:center; }
  .hero-stat-num { font-size:1.6rem; }
  .hero-stat-label { font-size:0.6rem; }
  .hero-btns { flex-direction:column; align-items:center; gap:0.75rem; }
  .btn-primary, .btn-outline { width:100%; max-width:280px; justify-content:center; }

  /* MANIFESTO */
  .manifesto { padding:4rem 5%; }
  .manifesto-text { font-size:1.2rem; line-height:1.6; }

  /* FEATURE BAR */
  .feature-bar { gap:2rem; padding:1.2rem 4%; }
  .feature-item strong { font-size:0.72rem; }
  .feature-item span { font-size:0.62rem; }

  /* DESTINATIONS GRID */
  #destinations > div[style*="grid"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* RELIGION CIRCUITS */
  section > div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns:1fr !important;
  }

  /* EXPERIENCES GRID */
  section > div[style*="grid-template-columns:repeat(4"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* DELHI ZOO */
  section > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns:1fr !important;
    gap:2rem !important;
  }

  /* FESTIVALS */
  section > div.festivals-grid,
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr 1fr !important;
    gap:0.75rem !important;
  }

  /* FOOD CARDS */
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr 1fr !important;
  }

  /* TRAVEL COSTS STATS */
  div[style*="display:flex;justify-content:center;gap:4rem"] {
    gap:1.5rem !important;
    flex-wrap:wrap !important;
  }

  /* CONTACT SECTION */
  div[style*="grid-template-columns:1fr 1.3fr"] {
    grid-template-columns:1fr !important;
    gap:2rem !important;
  }

  /* FORM ROWS */
  div[style*="grid-template-columns:1fr 1fr;gap:1rem"] {
    grid-template-columns:1fr !important;
  }

  /* SECTION HEADERS */
  .section-header {
    flex-direction:column !important;
    align-items:flex-start !important;
  }
  .section-title { font-size:1.8rem !important; }

  /* WHATSAPP FLOAT */
  .wa-float { 
    bottom:1.2rem; 
    right:1.2rem;
    padding:0.8rem 1.2rem;
    font-size:0.78rem;
  }

  /* DESTINATION CARDS */
  .dest-card { aspect-ratio:4/3 !important; }
  .dest-name { font-size:0.9rem !important; }

  /* FOOTER */
  .footer-grid { 
    grid-template-columns:1fr !important; 
    gap:2rem !important; 
  }
  .footer-bottom { 
    flex-direction:column !important; 
    text-align:center !important; 
    gap:0.5rem !important;
  }

  /* GENERAL SECTION PADDING */
  section { padding:3.5rem 4% !important; }
  .manifesto { padding:3.5rem 4% !important; }

  /* PAGE HERO */
  .page-hero { padding:7rem 4% 3rem !important; }
  .page-hero-title { font-size:2rem !important; }
}

@media(max-width:480px) {

  /* EXTRA SMALL PHONES */
  .hero-title { font-size:2.2rem; }
  .hero-eyebrow { font-size:0.58rem; letter-spacing:0.15em; }

  /* DESTINATIONS — single column on very small screens */
  #destinations > div[style*="grid"] {
    grid-template-columns:1fr !important;
  }

  /* EXPERIENCES — single column */
  section > div[style*="grid-template-columns:repeat(4"] {
    grid-template-columns:1fr !important;
  }

  /* FESTIVALS — single column */  
  div[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr !important;
  }

  .manifesto-text { font-size:1.05rem; }
  .section-title { font-size:1.6rem !important; }

  /* HERO STATS — 2x2 grid */
  .hero-stats { 
    display:grid !important; 
    grid-template-columns:1fr 1fr !important;
    gap:1rem !important;
    width:100% !important;
  }
  .hero-stat { text-align:center; }

  /* RELIGION CARDS */
  section > div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns:1fr !important;
  }
}

/* TOUCH IMPROVEMENTS */
@media(hover:none) {
  .dest-card:active img { transform:scale(1.04); }
  .nav-links a { padding:0.75rem 0; }
  
  /* Remove hover-only teaser text — show always on mobile */
  .dest-teaser { 
    color:rgba(255,255,255,0.55) !important; 
    font-size:0.65rem !important;
  }
}

/* SAFE AREA for iPhone notch */
@supports(padding:max(0px)) {
  .navbar { 
    padding-left:max(4%, env(safe-area-inset-left));
    padding-right:max(4%, env(safe-area-inset-right));
  }
  .wa-float {
    bottom:max(1.2rem, env(safe-area-inset-bottom));
    right:max(1.2rem, env(safe-area-inset-right));
  }
}

/* CRITICAL MOBILE OVERFLOW FIX */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

* {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.hero-content {
  width: 100% !important;
  padding: 0 5% !important;
}

.hero-eyebrow {
  word-break: break-word !important;
  white-space: normal !important;
}

@media(max-width:768px) {
  .feature-bar {
    overflow-x: scroll !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  section {
    overflow-x: hidden !important;
  }
}
