/* =========================================================================
   GK Brothers Holidays — Premium responsive stylesheet
   Theme: deep green + gold, mobile-first
   ========================================================================= */

:root{
  --green:#0b3d2e;
  --green-2:#11543f;
  --gold:#e0a82e;
  --gold-2:#c8902a;
  --wa:#25d366;
  --call:#1f7aec;
  --ink:#1c2526;
  --muted:#5d6b6b;
  --line:#e6ebe9;
  --bg:#f6f8f7;
  --white:#fff;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(11,61,46,.10);
  --shadow-lg:0 20px 50px rgba(11,61,46,.18);
  --container:1180px;
  --font:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --head:"Poppins",var(--font);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  overscroll-behavior-x:none;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--head);line-height:1.2;margin:0 0 .5em;color:var(--green)}
p{margin:0 0 1em}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 18px}
.ico{width:1em;height:1em;fill:currentColor;vertical-align:-.12em}
section{position:relative}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  font-family:var(--head);font-weight:600;font-size:.95rem;
  padding:.75rem 1.4rem;border-radius:50px;border:0;cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;line-height:1;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--gold);color:#3a2a00;box-shadow:0 8px 20px rgba(224,168,46,.35)}
.btn--primary:hover{background:var(--gold-2)}
.btn--whatsapp{background:var(--wa);color:#063a1e}
.btn--whatsapp:hover{background:#1eb957}
.btn--call{background:var(--green);color:#fff}
.btn--call:hover{background:var(--green-2)}
.btn--ghost{background:transparent;border:2px solid var(--green);color:var(--green)}
.btn--outline{background:#fff;border:1px solid var(--line);color:var(--green)}
.btn--sm{padding:.55rem 1rem;font-size:.85rem}
.btn--block{width:100%}
.btn--lg{padding:.95rem 1.8rem;font-size:1.05rem}

.section{padding:64px 0}
.section--tight{padding:44px 0}
.section__head{text-align:center;max-width:680px;margin:0 auto 38px}
.section__eyebrow{color:var(--gold-2);font-weight:700;font-family:var(--head);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem}
.section__title{font-size:clamp(1.6rem,3.4vw,2.4rem);margin:.3rem 0 .4rem}
.section__sub{color:var(--muted);margin:0}
.text-center{text-align:center}

/* ---------- Mobile header compact icon buttons (hidden on desktop) ---------- */
.hdr-mob-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;flex-shrink:0;transition:opacity .2s}
.hdr-mob-btn--call{background:var(--green);color:#fff}
.hdr-mob-btn--wa{background:var(--wa);color:#fff}
.hdr-mob-btn:hover{opacity:.85}

/* ---------- Topbar ---------- */
.topbar{background:var(--green);color:#d8e6df;font-size:.82rem}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar__right{display:flex;gap:1.2rem;align-items:center}
.topbar__item{display:inline-flex;align-items:center;gap:.4rem;color:#d8e6df}
.topbar__item:hover{color:var(--gold)}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);box-shadow:0 2px 14px rgba(0,0,0,.06)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem}
.brand__mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--green),var(--green-2));color:var(--gold);display:grid;place-items:center;font-family:var(--head);font-weight:800;font-size:1.05rem;letter-spacing:.02em}
.brand__logo{max-height:50px;max-width:220px;width:auto;display:block;object-fit:contain}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__text strong{font-family:var(--head);color:var(--green);font-size:1.12rem}
.brand__text small{color:var(--gold-2);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.62rem}
.nav{display:flex;align-items:center;gap:1.4rem}
.nav__list{display:flex;gap:.3rem}
.nav__list a{font-family:var(--head);font-weight:500;color:var(--ink);padding:.5rem .8rem;border-radius:8px;font-size:.95rem;transition:.2s}
.nav__list a:hover,.nav__list a.is-active{color:var(--green);background:rgba(11,61,46,.07)}
.nav__cta{display:none}
.nav__close{display:none}
.nav__drawer-head,.nav__drawer-foot,.nav__arrow{display:none}
.header__actions{display:flex;align-items:center;gap:.6rem}
.nav__toggle{display:none;flex-direction:column;gap:5px;width:42px;height:42px;border:0;background:transparent;cursor:pointer;align-items:center;justify-content:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.nav__toggle span{width:24px;height:2px;background:var(--green);border-radius:2px;transition:.3s}

/* ---------- Hero slider ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero__slides{position:relative;min-height:min(86vh,640px)}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity .9s ease;background-size:cover;background-position:center;display:flex;align-items:center}
.hero__slide::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,38,28,.86),rgba(7,38,28,.45))}
.hero__slide.is-active{opacity:1}
.hero__content{position:relative;z-index:2;max-width:640px;padding:40px 0}
.hero__eyebrow{display:inline-block;background:rgba(224,168,46,.2);color:var(--gold);border:1px solid rgba(224,168,46,.5);padding:.35rem .9rem;border-radius:50px;font-weight:600;font-size:.78rem;font-family:var(--head);margin-bottom:1rem}
.hero h1{color:#fff;font-size:clamp(1.9rem,5vw,3.3rem);margin-bottom:.5rem}
.hero h1 span{color:var(--gold)}
.hero__text{font-size:1.08rem;color:#e7efe9;max-width:540px;margin-bottom:1.6rem}
.hero__actions{display:flex;gap:.8rem;flex-wrap:wrap}
.hero__trust{display:flex;gap:1.6rem;margin-top:1.8rem;flex-wrap:wrap}
.hero__trust div{font-size:.85rem;color:#cfe0d8}
.hero__trust strong{display:block;font-family:var(--head);font-size:1.4rem;color:var(--gold)}
.hero__dots{position:absolute;bottom:18px;left:0;right:0;z-index:3;display:flex;gap:.5rem;justify-content:center}
.hero__dots button{width:11px;height:11px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer}
.hero__dots button.is-active{background:var(--gold);width:28px;border-radius:6px}

/* ---------- Quick search / vehicle chooser ---------- */
.chooser{margin-top:-44px;position:relative;z-index:5}
.chooser__card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:18px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.chooser__item{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:18px 10px;border-radius:var(--radius-sm);background:var(--bg);text-align:center;transition:.2s;border:1px solid transparent}
.chooser__item:hover{background:#fff;border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow)}
.chooser__icon{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-2));color:var(--gold);display:grid;place-items:center}
.chooser__icon svg{width:26px;height:26px}
.chooser__item strong{font-family:var(--head);color:var(--green);font-size:.98rem}
.chooser__item small{color:var(--muted);font-size:.78rem}

/* ---------- Cards grid ---------- */
.grid{display:grid;gap:22px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}

.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card__media{position:relative;aspect-ratio:16/10;background:#dfe7e3 center/cover}
.card__badge{position:absolute;top:12px;left:12px;background:var(--gold);color:#3a2a00;font-family:var(--head);font-weight:700;font-size:.72rem;padding:.3rem .7rem;border-radius:50px}
.card__body{padding:18px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.card__title{font-size:1.1rem;margin:0}
.card__meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;color:var(--muted);font-size:.82rem}
.card__meta span{display:inline-flex;align-items:center;gap:.3rem}
.card__desc{color:var(--muted);font-size:.9rem;margin:0}
.card__price{font-family:var(--head);color:var(--green);font-weight:700}
.card__price small{color:var(--muted);font-weight:500;font-size:.78rem}
.card__foot{display:flex;gap:.5rem;margin-top:auto;padding-top:.6rem}
.card__foot .btn{flex:1}

/* ---------- Why choose ---------- */
.why{background:linear-gradient(180deg,#fff,var(--bg))}
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:.2s}
.why__item:hover{border-color:var(--gold);box-shadow:var(--shadow)}
.why__icon{width:52px;height:52px;border-radius:13px;background:rgba(11,61,46,.08);color:var(--green);display:grid;place-items:center;margin-bottom:14px}
.why__icon svg{width:26px;height:26px}
.why__item h3{font-size:1.08rem;margin-bottom:.3rem}
.why__item p{color:var(--muted);font-size:.9rem;margin:0}

/* ---------- Destinations ---------- */
.dest-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow)}
.dest-card__bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:.4s}
.dest-card:hover .dest-card__bg{transform:scale(1.08)}
.dest-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,38,28,.85),transparent 60%)}
.dest-card__label{position:relative;z-index:2;padding:16px}
.dest-card__label strong{font-family:var(--head);font-size:1.15rem;display:block}
.dest-card__label small{color:#d8e6df;font-size:.8rem}

/* ---------- Reviews ---------- */
.review{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);border:1px solid var(--line)}
.review__stars{color:var(--gold);font-size:1rem;margin-bottom:.5rem}
.review__text{font-size:.95rem;color:var(--ink)}
.review__by{display:flex;align-items:center;gap:.7rem;margin-top:.8rem}
.review__avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-2));color:var(--gold);display:grid;place-items:center;font-family:var(--head);font-weight:700}
.review__by strong{font-size:.92rem;color:var(--green)}
.review__by small{color:var(--muted);font-size:.8rem}

/* ---------- Stats strip ---------- */
.stats{background:var(--green);color:#fff}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;padding:42px 0}
.stats__grid strong{display:block;font-family:var(--head);font-size:2.1rem;color:var(--gold)}
.stats__grid span{color:#cfe0d8;font-size:.9rem}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--green),var(--green-2));color:#fff}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:46px 18px;flex-wrap:wrap}
.cta-band h2{color:#fff;margin:0 0 .3rem}
.cta-band p{color:#d8e6df;margin:0}
.cta-band__actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* ---------- Two-column lead section ---------- */
.lead-split{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center}
.lead-panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:26px}
.lead-panel h3{margin-bottom:.2rem}
.lead-panel .modal__sub,.lead-panel p.sub{color:var(--muted);margin-bottom:1rem}

/* ---------- Forms ---------- */
.lead-form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:12px}
.field label{font-size:.82rem;font-weight:600;color:var(--green);font-family:var(--head)}
.field label span{color:#d33}
.field input,.field select,.field textarea{
  width:100%;padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;
  font-family:var(--font);font-size:.92rem;background:#fbfcfb;transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(224,168,46,.18)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.lead-form__note{font-size:.85rem;margin:.6rem 0 0;text-align:center}
.lead-form__note.is-ok{color:#1a8a4a}
.lead-form__note.is-err{color:#d33}

/* ---------- Breadcrumb / page hero ---------- */
.page-hero{background:linear-gradient(120deg,var(--green),var(--green-2));color:#fff;padding:50px 0 34px}
.page-hero h1{color:#fff;font-size:clamp(1.7rem,4vw,2.5rem);margin-bottom:.4rem}
.page-hero p{color:#d8e6df;max-width:640px;margin:0}
.breadcrumb{background:#f5f7f5;border-bottom:1px solid var(--line);font-size:.82rem}
.breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:0;padding:10px 0;color:var(--muted);list-style:none;margin:0}
.breadcrumb li{display:flex;align-items:center}
.breadcrumb li::after{content:"";display:none}
.bc-sep{color:var(--muted);opacity:.7;margin:0 .3rem;font-size:.9rem}
.breadcrumb a{color:var(--green);font-weight:500;text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--green-2);text-decoration:underline}
.bc-current{color:var(--text);font-weight:600}

/* ---------- Detail pages ---------- */
.detail{display:grid;grid-template-columns:1.6fr .9fr;gap:32px;align-items:start}
.gallery-main{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/10;background:#dfe7e3 center/cover}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px}
.gallery-thumbs img{border-radius:10px;aspect-ratio:1;object-fit:cover;cursor:pointer;border:2px solid transparent}
.gallery-thumbs img:hover{border-color:var(--gold)}
.spec-list{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:1rem 0}
.spec-list li{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}
.spec-list svg{color:var(--gold-2);width:18px;height:18px;flex:none}
.price-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:sticky;top:90px}
.price-box__row{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px dashed var(--line)}
.price-box__row strong{font-family:var(--head);font-size:1.3rem;color:var(--green)}
.price-box .btn{margin-top:.6rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}
.chip{background:rgba(11,61,46,.07);color:var(--green);padding:.35rem .8rem;border-radius:50px;font-size:.82rem;font-weight:600}
.inc-exc{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.inc-exc ul li{padding:.35rem 0;font-size:.9rem;display:flex;gap:.5rem;align-items:flex-start}
.inc-exc .inc li::before{content:"✓";color:#1a8a4a;font-weight:700}
.inc-exc .exc li::before{content:"✕";color:#d33;font-weight:700}

/* ---------- FAQ accordion ---------- */
.accordion__item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.accordion__q{width:100%;text-align:left;background:none;border:0;padding:18px 20px;font-family:var(--head);font-weight:600;color:var(--green);font-size:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.accordion__q::after{content:"+";font-size:1.4rem;color:var(--gold-2);transition:.2s}
.accordion__item.is-open .accordion__q::after{content:"−"}
.accordion__a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 20px;color:var(--muted)}
.accordion__item.is-open .accordion__a{max-height:400px;padding-bottom:18px}

/* ---------- Gallery grid ---------- */
.masonry{columns:4;column-gap:14px}
.masonry img{width:100%;border-radius:12px;margin-bottom:14px;cursor:pointer;transition:.2s}
.masonry img:hover{transform:scale(1.02);box-shadow:var(--shadow)}

/* Gallery filter tabs */
.gallery-tabs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:1.8rem}
.gallery-tab{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:600;font-size:.9rem;padding:.5rem 1.2rem;border-radius:50px;cursor:pointer;transition:.2s}
.gallery-tab span{display:inline-flex;align-items:center;justify-content:center;min-width:1.3rem;height:1.3rem;padding:0 .35rem;font-size:.72rem;border-radius:50px;background:var(--line);color:var(--muted)}
.gallery-tab:hover{border-color:var(--green);color:var(--green)}
.gallery-tab.is-active{background:var(--green);border-color:var(--green);color:#fff}
.gallery-tab.is-active span{background:rgba(255,255,255,.25);color:#fff}

/* Gallery groups + section titles */
.gallery-group{margin-bottom:2.4rem}
.gallery-group:last-child{margin-bottom:0}
.gallery-group__title{font-family:var(--head);font-size:1.35rem;margin:0 0 1.1rem;padding-bottom:.5rem;border-bottom:2px solid var(--line)}
.gallery-group.is-hidden{display:none}

/* Video grid (uniform 16:9 cards) */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.video-card{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;aspect-ratio:16/9;background:#000;box-shadow:var(--shadow)}
.video-card img,.video-card video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.video-card:hover img,.video-card:hover video{transform:scale(1.06)}
.video-card__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;background:rgba(11,61,46,.78);display:flex;align-items:center;justify-content:center;transition:.25s;backdrop-filter:blur(2px)}
.video-card__play svg{margin-left:3px}
.video-card:hover .video-card__play{background:var(--gold);transform:translate(-50%,-50%) scale(1.08)}
.video-card__title{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .7rem;font-size:.85rem;font-weight:600;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.75));z-index:2}

/* ---------- Blog ---------- */
.post__meta{color:var(--muted);font-size:.82rem;margin-bottom:.4rem}
.prose{max-width:760px;margin:0 auto}
.prose h2{margin-top:1.6rem}
.prose img{border-radius:12px;margin:1rem 0}

/* ---------- Landing pages ---------- */
.lp-hero{background:linear-gradient(120deg,var(--green),var(--green-2));color:#fff;padding:46px 0}
.lp-hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center}
.lp-hero h1{color:#fff;font-size:clamp(1.8rem,4.4vw,2.7rem)}
.lp-hero ul{margin:1rem 0}
.lp-hero ul li{padding:.25rem 0;color:#e7efe9;display:flex;gap:.5rem}
.lp-hero ul li::before{content:"✓";color:var(--gold);font-weight:700}
.lp-badges{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}
.lp-badges span{background:rgba(255,255,255,.12);padding:.5rem .9rem;border-radius:10px;font-size:.85rem}
.price-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.price-table th,.price-table td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--line)}
.price-table th{background:var(--green);color:#fff;font-family:var(--head)}
.price-table tr:last-child td{border-bottom:0}

/* ---------- Travel guide grid (programmatic SEO pages) ---------- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.5rem}
.guide-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)}
.guide-card h3{margin:0 0 .6rem;font-size:1.05rem;color:var(--green)}
.guide-card p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.6}
@media(max-width:860px){.guide-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.guide-grid{grid-template-columns:1fr}}

/* ---------- Sticky conversion buttons ---------- */
.float-wa,.float-call{position:fixed;right:18px;z-index:80;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-lg);color:#fff;transition:transform .2s}
.float-wa{bottom:20px;background:var(--wa)}
.float-call{bottom:86px;background:var(--call)}
.float-wa:hover,.float-call:hover{transform:scale(1.08)}
.float-wa svg,.float-call svg{width:30px;height:30px;fill:#fff}
.float-wa__pulse{position:absolute;inset:0;border-radius:50%;border:2px solid var(--wa);animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.8);opacity:0}}

/* ---------- Mobile bottom CTA bar ---------- */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:85;background:#fff;box-shadow:0 -4px 16px rgba(0,0,0,.12);grid-template-columns:1fr 1fr 1fr}
.mobile-cta a{padding:.85rem;text-align:center;font-family:var(--head);font-weight:600;font-size:.9rem;color:var(--green);display:flex;align-items:center;justify-content:center;gap:.4rem;border-right:1px solid var(--line)}
.mobile-cta a:last-child{border-right:0}
.mobile-cta__wa{color:#0a7a37 !important}
.mobile-cta__enq{background:var(--gold);color:#3a2a00 !important}

/* ---------- Modals ---------- */
.modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:18px}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(7,38,28,.6);backdrop-filter:blur(2px)}
.modal__box{position:relative;background:#fff;border-radius:var(--radius);padding:28px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:pop .25s ease}
.modal__box img{max-width:100%;height:auto;border-radius:12px}
.modal__box--offer{text-align:center;border-top:6px solid var(--gold)}
@keyframes pop{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.modal__close{position:absolute;top:10px;right:14px;background:none;border:0;font-size:1.8rem;line-height:1;color:var(--muted);cursor:pointer}
.modal__sub{color:var(--muted);margin-bottom:1rem;font-size:.9rem}
.offer__badge{display:inline-block;background:var(--gold);color:#3a2a00;font-family:var(--head);font-weight:700;padding:.3rem .9rem;border-radius:50px;font-size:.78rem;margin-bottom:.6rem}

/* ---------- Footer ---------- */
.footer{background:#08291f;color:#bcd0c7;padding:54px 0 0;font-size:.92rem}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:30px}
.footer h4{color:#fff;font-size:1rem;margin-bottom:1rem}
.footer__col ul li{margin-bottom:.5rem}
.footer__col a:hover{color:var(--gold)}
.brand--footer .brand__text strong{color:#fff}
.footer__about{margin:1rem 0;line-height:1.7}
.footer__social{display:flex;gap:.6rem}
.footer__social a{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;font-weight:600;text-transform:uppercase;font-size:.75rem}
.footer__social a:hover{background:var(--gold);color:#3a2a00}
.footer__contact li{line-height:1.6}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:18px 18px;font-size:.82rem;flex-wrap:wrap;gap:.4rem}

.hide-sm{display:inline-flex}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:1024px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .chooser__card{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:3}
  .video-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .grid--3,.grid--2{grid-template-columns:1fr}
  .why__grid{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .lead-split,.detail,.lp-hero__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .inc-exc{grid-template-columns:1fr}
  .price-box{position:static}
  .masonry{columns:2}
  .spec-list{grid-template-columns:1fr}

  /* Hide topbar on mobile — single header bar only */
  .topbar{display:none}
  /* Show compact call/WA icon buttons in header */
  .hdr-mob-btn{display:flex}
  /* Tighten header height on mobile */
  .header__inner{height:58px}
  /* On mobile: raise header z-index and kill backdrop-filter so it does NOT
     create a new containing block for the position:fixed nav drawer. */
  .header{z-index:96;backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav__drawer-head,.nav__drawer-foot,.nav__arrow{display:flex}
  /* Mobile nav drawer — premium white slide-in (teleported to body on open → root stacking context) */
  .nav{position:fixed;inset:0 0 0 auto;width:min(85vw,340px);background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:0;transform:translateX(110%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 40px rgba(7,38,28,.22);z-index:9999;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .nav.is-open{transform:translateX(0)}

  /* Drawer: branded top bar */
  .nav__drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 16px;background:linear-gradient(135deg,var(--green),#1c5640);border-bottom:1px solid rgba(255,255,255,.12);flex-shrink:0}
  .nav__drawer-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none}
  .nav__drawer-mark{width:38px;height:38px;border-radius:10px;background:var(--gold);color:#3a2a00;display:grid;place-items:center;font-family:var(--head);font-weight:800;font-size:1rem;letter-spacing:.02em;flex-shrink:0}
  .nav__drawer-name{display:flex;flex-direction:column;line-height:1.1}
  .nav__drawer-name strong{color:#fff;font-family:var(--head);font-size:1rem}
  .nav__drawer-name small{color:rgba(224,168,46,.9);font-size:.65rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}
  .nav__close{background:rgba(255,255,255,.15);border:0;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;cursor:pointer;flex-shrink:0;transition:background .2s}
  .nav__close:hover{background:rgba(255,255,255,.28)}

  /* Drawer: nav links */
  .nav__list{flex-direction:column;gap:0;padding:10px 0;flex:1}
  .nav__list li{border-bottom:1px solid var(--line)}
  .nav__list li:last-child{border-bottom:0}
  .nav__list a{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;font-family:var(--head);font-weight:500;font-size:1rem;color:var(--ink);border-radius:0;transition:background .18s,color .18s}
  .nav__list a:hover{background:rgba(11,61,46,.06);color:var(--green)}
  .nav__list a.is-active{color:var(--green);background:rgba(11,61,46,.07);font-weight:700}
  .nav__list a.is-active .nav__arrow{color:var(--gold)}
  .nav__arrow{opacity:.4;flex-shrink:0;transition:opacity .2s,transform .2s}
  .nav__list a:hover .nav__arrow{opacity:.8;transform:translateX(2px)}

  /* Drawer: footer contact buttons */
  .nav__drawer-foot{display:flex;gap:.7rem;padding:16px 18px 20px;border-top:1px solid var(--line);flex-shrink:0;padding-bottom:max(20px,env(safe-area-inset-bottom))}
  .nav__drawer-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.75rem;border-radius:10px;font-family:var(--head);font-weight:600;font-size:.88rem;text-decoration:none;transition:opacity .2s}
  .nav__drawer-btn:hover{opacity:.85}
  .nav__drawer-btn--call{background:var(--green);color:#fff}
  .nav__drawer-btn--wa{background:#25d366;color:#fff}

  /* Hide old desktop-only elements inside drawer */
  .nav__cta{display:none}
  .nav__toggle{display:flex;position:relative}
  body.nav-open{overflow:hidden}

  .mobile-cta{display:grid}
  .float-wa{bottom:74px}
  .float-call{bottom:140px}
  .footer{padding-bottom:calc(64px + env(safe-area-inset-bottom, 0px))}
}
@media (max-width:560px){
  .section{padding:44px 0}
  .topbar .hide-sm{display:none}
  .hide-sm{display:none}
  .chooser__card{grid-template-columns:1fr 1fr;padding:12px;gap:8px}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr}
  .lead-form__row{grid-template-columns:1fr}
  .cta-band__inner{flex-direction:column;text-align:center}
  .hero__slides{min-height:78vh}
  .masonry{columns:1}
  .video-grid{grid-template-columns:1fr}
}

/* =========================================================================
   ENHANCEMENTS — overflow guards, nav overlay, image categories,
   vehicle quickbar, mega menu, responsive conversion bar
   ========================================================================= */
*{min-width:0}
html{overscroll-behavior-x:none}
html,body{max-width:100%}
img{max-width:100%;height:auto}
.container{width:100%}

/* Nav drawer overlay */
.nav-overlay{position:fixed;inset:0;background:rgba(7,38,28,.55);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .3s ease;z-index:95}
.nav-overlay.is-open{opacity:1;visibility:visible}

/* Vehicle category cards (images instead of icons) */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:1.5rem}
.cat-card{position:relative;display:block;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:linear-gradient(135deg,var(--green),var(--green-2))}
.cat-grid .cat-card:nth-child(1){background:linear-gradient(135deg,#0b3d2e,#1c6645)}
.cat-grid .cat-card:nth-child(2){background:linear-gradient(135deg,#0b2d5e,#1a5da0)}
.cat-grid .cat-card:nth-child(3){background:linear-gradient(135deg,#5e1a0b,#a03028)}
.cat-grid .cat-card:nth-child(4){background:linear-gradient(135deg,#5e3e0b,#9e6910)}
.cat-card__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s ease}
.cat-card:hover .cat-card__img{transform:scale(1.06)}
.cat-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(7,38,28,.78))}
.cat-card__body{position:absolute;left:0;right:0;bottom:0;padding:1rem 1.1rem;color:#fff;z-index:2}
.cat-card__body strong{display:block;font-family:var(--head);font-size:1.15rem;line-height:1.2}
.cat-card__body small{display:block;color:var(--gold);font-weight:600;font-size:.82rem;margin-top:.15rem}
.cat-card__cta{display:inline-block;margin-top:.5rem;font-size:.8rem;font-weight:600;color:#fff;border:1px solid rgba(255,255,255,.6);padding:.25rem .7rem;border-radius:50px}
.cat-card__icon{position:absolute;top:.9rem;left:.9rem;z-index:3;width:2.6rem;height:2.6rem;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}
.cat-card__icon svg{width:1.4rem;height:1.4rem;fill:#fff}

/* Top Places We Serve */
.place-card{position:relative;display:block;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow);background:linear-gradient(135deg,#1c5640,#0b3d2e)}
.place-card__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s ease}
.place-card:hover .place-card__img{transform:scale(1.07)}
.place-card__label{position:absolute;left:0;right:0;bottom:0;padding:.9rem 1rem;background:linear-gradient(180deg,transparent,rgba(7,38,28,.82));color:#fff;z-index:2}
.place-card__label strong{display:block;font-family:var(--head);font-size:1.05rem}
.place-card__label small{color:var(--gold);font-weight:600;font-size:.76rem}

/* Home gallery strip */
.home-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-top:1.5rem}
.home-gallery a{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow);background-color:#0b3d2e;background-size:cover;background-position:center;transition:transform .4s}
.home-gallery a:hover{transform:scale(1.04)}

/* Vehicle detail above-fold quick info bar */
.v-quickbar{display:grid;grid-template-columns:repeat(5,auto) 1fr;align-items:center;gap:1.2rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem;box-shadow:var(--shadow);margin:.4rem 0 1.2rem}
.v-quickbar__item{display:flex;flex-direction:column;line-height:1.15}
.v-quickbar__item small{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}
.v-quickbar__item strong{font-family:var(--head);color:var(--green);font-size:1.05rem}
.v-quickbar__actions{display:flex;gap:.5rem;justify-content:flex-end;flex-wrap:wrap}

/* Vehicle image slider + thumbnails */
.vgallery{position:relative}
.vgallery__main{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;background:#eef2f0;box-shadow:var(--shadow)}
.vgallery__main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .35s ease}
.vgallery__main img.is-active{opacity:1}
.vgallery__nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.9);color:var(--green);font-size:1.4rem;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);z-index:3}
.vgallery__nav--prev{left:12px}
.vgallery__nav--next{right:12px}
.vgallery__thumbs{display:flex;gap:.5rem;margin-top:.7rem;overflow-x:auto;padding-bottom:.3rem;-webkit-overflow-scrolling:touch}
.vgallery__thumbs button{flex:0 0 84px;height:60px;border-radius:10px;overflow:hidden;border:2px solid transparent;padding:0;cursor:pointer;background:#eef2f0}
.vgallery__thumbs button.is-active{border-color:var(--gold)}
.vgallery__thumbs img{width:100%;height:100%;object-fit:cover}
.vgallery__main{cursor:zoom-in}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(7,20,15,.94);z-index:1000;display:none;align-items:center;justify-content:center}
.lightbox.is-open{display:flex}
.lightbox__img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox__close{position:absolute;top:18px;right:22px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:2rem;cursor:pointer;display:grid;place-items:center}
.lightbox__nav--prev{left:16px}
.lightbox__nav--next{right:16px}
.lightbox__close:hover,.lightbox__nav:hover{background:rgba(255,255,255,.28)}
@media (max-width:560px){.lightbox__nav{width:44px;height:44px;font-size:1.6rem}}

/* Mega menu (desktop dropdown) */
.has-mega{position:relative}
.mega{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);width:min(680px,90vw);background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:1.1rem;opacity:0;visibility:hidden;transition:.22s ease;z-index:90;display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.has-mega:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega__item{display:flex;gap:.8rem;padding:.6rem;border-radius:12px;transition:background .2s}
.mega__item:hover{background:rgba(11,61,46,.06)}
.mega__thumb{flex:0 0 76px;height:56px;border-radius:9px;background:linear-gradient(135deg,var(--green),var(--green-2));background-size:cover;background-position:center}
.mega__info strong{display:block;font-family:var(--head);color:var(--green);font-size:.95rem}
.mega__info small{display:block;color:var(--muted);font-size:.8rem;margin:.1rem 0 .15rem}
.mega__info span{font-size:.78rem;color:var(--gold-2);font-weight:600}

@media (max-width:1024px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .home-gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:860px){
  /* Hide round floating buttons on mobile — sticky bottom bar handles CTAs */
  .float-wa,.float-call{display:none !important}
  .mega{display:none}
  .v-quickbar{grid-template-columns:repeat(2,1fr);gap:.8rem}
  .v-quickbar__actions{grid-column:1 / -1;justify-content:stretch}
  .v-quickbar__actions .btn{flex:1}
}
@media (max-width:560px){
  /* Mobile logo */
  .brand__logo{max-height:40px;max-width:140px}
  /* Hero buttons stack full width */
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{width:100%;justify-content:center}
  /* Popup */
  .modal{padding:12px}
  .modal__box{width:90%;padding:22px}
  /* Categories / places / gallery */
  .cat-grid{grid-template-columns:1fr 1fr;gap:.7rem}
  .place-card__label strong{font-size:.92rem}
  .home-gallery{grid-template-columns:repeat(2,1fr)}
  /* Quick bar single column */
  .v-quickbar{grid-template-columns:1fr 1fr}
  /* Sticky bar safe area for notched phones */
  .mobile-cta{padding-bottom:env(safe-area-inset-bottom)}
}
@media (max-width:380px){
  .cat-grid{grid-template-columns:1fr}
}
