/* =========================================================
   Gill Luxury Travel – Full Cross-Browser Stylesheet
   Updated: 2025-05-21  (includes tagline colour override)
========================================================= */

/* ---------- Variables ---------- */
:root{
  --navy:#0A1931;
  --gold:#D4AF37;
  --white:#ffffff;
  --gray:#f4f6fa;
  --footer-bg:#0A1931;
  --hero-gradient:linear-gradient(120deg,#0A1931 72%,#D4AF37 170%);
}

*{box-sizing:border-box;margin:0;padding:0}

body{
  font-family:'Montserrat',sans-serif;
  color:var(--navy);
  background:var(--gray);
  background-image:linear-gradient(120deg,#e8eaf6 0%,#f7f3e7 90%);
  background-attachment:fixed;
  min-height:100vh;
  font-size:16px;line-height:1.6;
}

.container{width:min(92%,1200px);margin:0 auto}

a{color:var(--gold);text-decoration:none}
a:hover{color:#a6831b;text-decoration:underline}

/* =========================================================
   HEADER & NAV
========================================================= */
header{position:fixed;inset:0 0 auto;background:var(--navy);color:#fff;width:100vw;box-shadow:0 2px 14px #0002;z-index:1002}
.header-inner{display:flex;align-items:center;min-height:66px;padding:0 8px}
.logo img{height:52px;width:52px;border:2px solid var(--gold);border-radius:50%;object-fit:cover;background:#fff}
nav{margin-left:auto}
.nav-list{display:flex;gap:32px;align-items:center;list-style:none;font-family:'Playfair Display',serif}
.nav-list li a{font-weight:700;color:#fff;font-size:1.08rem;padding:7px 16px;border-radius:6px;transition:.2s}
.nav-list li a:hover{background:var(--gold);color:var(--navy)}
.mobile-toggle{display:none;font-size:2.1rem;margin-left:22px;color:var(--gold);cursor:pointer}

/* Mobile nav */
.mobile-nav-overlay{display:none;position:fixed;inset:0;background:rgba(10,25,49,.98);z-index:2002}
.mobile-nav-content{background:var(--navy);width:80vw;max-width:340px;height:100%;box-shadow:-2px 0 32px #0006;padding:40px 30px;font-family:'Playfair Display',serif}
.close-mobile-nav{font-size:2.3rem;color:var(--gold);float:right;margin-bottom:24px;cursor:pointer}
.mobile-nav-content ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:30px}
.mobile-nav-content a{color:var(--gold);font-size:1.24rem;font-weight:700}
.mobile-nav-content a:hover{color:#fff}

/* =========================================================
   HERO  (tiny banner)
========================================================= */
.hero,.pro-hero{
  margin-top:66px;
  position:relative;
  background:var(--hero-gradient);
  overflow:hidden;
  box-shadow:0 8px 20px #0003;
}
.hero-bg,.hero-img-fallback{
  width:100%;
  height:180px;max-height:180px;
  object-fit:cover;
  filter:brightness(.68) contrast(1.05);
  display:block;                 /* removes inline gap */
}
@media (max-width:600px){
  .hero-bg,.hero-img-fallback{height:110px;max-height:110px}
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,25,49,.74) 65%,rgba(212,175,55,.07) 100%)}

/* =========================================================
   MINI-HERO CAPTION
========================================================= */
.lux-headline{font-family:'Playfair Display',serif;font-weight:900;font-size:2.2rem;line-height:1.15;margin-bottom:16px;text-shadow:0 3px 12px #0008;color:var(--navy)}
.lux-gold{color:var(--gold)}
.lux-desc{font-size:1rem;margin-bottom:24px;color:var(--navy)}
.btn-lux,.btn-lux-alt{
  background:linear-gradient(90deg,#D4AF37 10%,#b79527 90%);
  color:var(--navy);padding:12px 30px;font-size:1rem;border-radius:10px;font-weight:800;
  border:none;box-shadow:0 4px 18px #d4af3744;cursor:pointer;transition:.2s
}
.btn-lux:hover,.btn-lux-alt:hover{background:var(--navy);color:var(--gold);border:2px solid var(--gold)}
.btn-lux-alt{background:#f9f5ee;color:var(--navy);border:2px solid #e7c37b}
.btn-lux-alt:hover{background:var(--gold);color:#fff}

/* =========================================================
   SECTIONS
========================================================= */
.section{padding:80px 0}
.section h2{font-family:'Playfair Display',serif;font-size:2.1rem;font-weight:900;text-align:center;color:var(--navy);margin-bottom:38px}

/* Why / Services */
.why-grid,.services-grid{display:grid;gap:28px}
.why-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));text-align:center}
.why-grid i{font-size:2rem;color:var(--gold);margin-bottom:8px}
.why-grid h4{font-size:1.1rem;margin-bottom:6px}
.services-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.service-card{background:#fffefb;border:1px solid #ece6d8;border-radius:16px;padding:26px 22px;box-shadow:0 4px 20px #d4af3733;transition:.2s}
.service-card:hover{transform:translateY(-6px);box-shadow:0 14px 34px #d4af3760;background:#f6f3ed}
.service-card h3{font-family:'Playfair Display',serif;font-size:1.2rem;margin-bottom:10px}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:17px}
.gallery-grid img{width:100%;height:160px;object-fit:cover;border-radius:12px;box-shadow:0 2px 14px #d4af3733;background:#fff;cursor:pointer;transition:.25s}
.gallery-grid img:hover{transform:scale(1.04) rotate(-.6deg);box-shadow:0 8px 30px #d4af373c}

/* Lightbox */
#lightbox{display:none;position:fixed;inset:0;background:rgba(10,25,49,.97);z-index:2222;align-items:center;justify-content:center}
#lightbox img{max-width:94vw;max-height:84vh;border:4px solid var(--gold);border-radius:14px;box-shadow:0 8px 36px #000a}

/* Testimonials */
.testimonial-slider{text-align:center;margin-top:8px}
.testimonial-slider blockquote{background:#fff;border-left:6px solid var(--gold);border-radius:15px;padding:24px 20px;font-style:italic;font-size:1.05rem;box-shadow:0 2px 18px #d4af3722;max-width:620px;margin:0 auto}
.testimonial-slider footer{text-align:right;font-weight:600;margin-top:10px;font-size:.95rem}
.slick-dots li button:before{font-size:16px;color:var(--gold);opacity:.75}
.slick-dots li.slick-active button:before{color:var(--navy);opacity:1}

/* Contact */
.contact-buttons{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-bottom:24px}
.contact form{max-width:480px;margin:0 auto 20px;display:grid;gap:14px}
.contact input,.contact textarea{padding:12px;border:2px solid var(--navy);border-radius:8px;font-size:1rem;background:#f9f8f4}
.contact textarea{resize:vertical;min-height:110px}
.contact-info{text-align:center;font-size:1.05rem;margin-top:16px;color:var(--navy)}

/* Footer */
.footer{background:var(--footer-bg);color:#fff;text-align:center;padding:22px 0;font-size:.95rem;box-shadow:0 -2px 12px #0002}

/* Chat buttons */
.float-btn{position:fixed;bottom:30px;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.1rem;cursor:pointer;box-shadow:0 4px 22px #0a19313a;background:var(--gold);color:var(--navy);z-index:3000;transition:.2s}
.float-btn:hover{background:var(--navy);color:var(--gold)}
.whatsapp-btn{right:26px;background:#25d366;color:#fff}
.whatsapp-btn:hover{background:#128c7e;color:#fff}
.insta-btn{right:94px;bottom:98px;background:#E4405F;color:#fff}
.insta-btn:hover{background:#fff;color:#E4405F}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width:1200px){.container{width:98%}}
@media (max-width:900px){.services-grid,.gallery-grid,.why-grid{grid-template-columns:1fr 1fr}}
@media (max-width:850px){.nav-list{display:none !important}.mobile-toggle{display:block}}
@media (max-width:700px){
  .container{width:99%}
  .why-grid,.gallery-grid,.services-grid{grid-template-columns:1fr;gap:18px}
}
@media (max-width:600px){
  body{font-size:18px;line-height:1.7}
  .gallery-grid img{height:110px}
  .service-card p,.why-grid p{font-size:1.05rem}
  .btn-lux,.btn-lux-alt{font-size:1.05rem;padding:14px 26px}
  .logo img{height:42px;width:42px}
  .lux-headline{font-size:clamp(1.8rem,6vw,2.2rem);line-height:1.15}
  .lux-desc{font-size:.95rem;margin-bottom:18px}
}

/* =========================================================
   TAGLINE FORCE-WHITE  (wins in every browser)
========================================================= */
.mini-hero-caption .lux-desc{
  color:#ffffff !important;
  text-shadow:0 2px 4px rgba(0,0,0,.45) !important;
  font-weight:500 !important;
}

/* =========================================================
   KEYFRAMES
========================================================= */
@keyframes fadeInDown{0%{opacity:0;transform:translateY(-52px)}100%{opacity:1;transform:none}}
@keyframes fadeIn{0%{opacity:0}100%{opacity:1}}
/* ═════════ Chrome-specific clutch overrides ═════════ */

/* — Hero banner: never taller than 180 px (110 px on phones) — */
.hero,
.pro-hero{
  height:180px !important;          /* desktop & tablet */
  max-height:180px !important;
}
.hero-bg,
.hero-img-fallback{
  height:100% !important;           /* fill the 180 px box */
  object-fit:cover !important;
}
@media (max-width:600px){
  .hero,
  .pro-hero{
    height:110px !important;
    max-height:110px !important;
  }
}

/* — Gallery thumbnails: cap height and keep aspect ratio — */
.gallery-grid img{
  height:160px !important;          /* desktop thumbnail */
  width:100% !important;
  object-fit:cover !important;
}
@media (max-width:600px){
  .gallery-grid img{height:110px !important;}
}