/* ═══════════════════════════════════════════════════════════
   MoroccanTransfer.com — Brand: Black / Grey / Gold
   Layout: agadir-visite.com inspired
   Version 4.0 — Avril 2026
═══════════════════════════════════════════════════════════ */

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

/* ── TOKENS ── */
:root {
  /* Brand: Black / Grey / Gold */
  --black:        #111111;
  --black-2:      #1C1C1C;
  --black-3:      #2A2A2A;
  --grey-1:       #444444;
  --grey-2:       #666666;
  --grey-3:       #888888;
  --grey-4:       #AAAAAA;
  --grey-5:       #CCCCCC;
  --grey-6:       #E8E8E8;
  --light:        #F5F5F5;
  --white:        #FFFFFF;
  --gold:         #C9A84C;
  --gold-dark:    #A8892A;
  --gold-light:   #E0C070;
  --gold-pale:    #F5EAC8;

  --font:         'DM Sans', -apple-system, sans-serif;
  --font-display: 'DM Serif Display', Georgia, serif;

  --radius:       6px;
  --radius-lg:    10px;
  --shadow:       0 2px 12px rgba(0,0,0,0.10);
  --shadow-md:    0 4px 20px rgba(0,0,0,0.14);
  --shadow-lg:    0 8px 36px rgba(0,0,0,0.20);
  --transition:   0.22s ease;
  --max-w:        1200px;
  --header-h:     100px;
  --topbar-h:     36px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px}
body{font-family:var(--font);background:var(--white);color:var(--grey-1);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit}

/* ── UTILITIES ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
.section-pad{padding:64px 0}
.section-pad-sm{padding:44px 0}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* ── SECTION HEADINGS ── */
.section-head{margin-bottom:40px}
.section-head.center{text-align:center}
.section-label{
  display:inline-block;font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--gold);
  margin-bottom:8px;
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(24px,3vw,32px);font-weight:700;
  color:var(--black);line-height:1.2;margin-bottom:10px;
}
.section-subtitle{font-size:14px;color:var(--grey-3);max-width:580px}
.section-head.center .section-subtitle{margin:0 auto}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;font-family:var(--font);font-size:13px;font-weight:700;
  padding:0 24px;height:44px;border-radius:var(--radius);
  transition:all var(--transition);white-space:nowrap;
  cursor:pointer;border:2px solid transparent;
}
.btn-primary{background:var(--gold);color:var(--black);border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,168,76,0.4)}
.btn-primary-lg{height:52px;font-size:15px;padding:0 32px}
.btn-outline{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--black)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.5)}
.btn-outline-white:hover{background:var(--white);color:var(--black)}
.btn-dark{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-dark:hover{background:var(--black-3)}
.btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-white:hover{background:var(--light)}
.btn-sm{height:36px;font-size:12px;padding:0 16px}
.btn-commander{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;background:var(--gold);
  color:var(--black);padding:8px 16px;border-radius:var(--radius);
  transition:all var(--transition);border:none;cursor:pointer;font-family:var(--font);
}
.btn-commander:hover{background:var(--gold-dark);transform:translateY(-1px)}
.btn-details{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;background:transparent;
  color:var(--grey-2);padding:8px 16px;border-radius:var(--radius);
  border:1.5px solid var(--grey-5);transition:all var(--transition);
  cursor:pointer;font-family:var(--font);
}
.btn-details:hover{border-color:var(--gold);color:var(--gold)}
.btn-details-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:13px;font-weight:600;color:var(--gold);
  padding:6px 0;border-bottom:2px solid transparent;
  transition:all var(--transition);
}
.btn-details-link:hover{border-bottom-color:var(--gold)}

/* ── TOP BAR ── */
.topbar{background:#ffffff;height:var(--topbar-h);font-size:12px;color:#666;border-bottom:1px solid #ebebeb}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:12px}
.topbar-left{display:flex;align-items:center;gap:18px}
.topbar-item{display:flex;align-items:center;gap:5px;color:#666;transition:color var(--transition)}
.topbar-item:hover{color:var(--gold)}
.topbar-item svg{opacity:0.6}
.topbar-right{display:flex;align-items:center;gap:14px}
.lang-list{display:none}
.topbar-social{display:flex;align-items:center;gap:9px}
.topbar-social a{color:#aaa;transition:color var(--transition);display:flex;align-items:center}
.topbar-social a:hover{color:var(--gold)}

/* ── HEADER / NAV ── */
.site-header{
  position:sticky;top:0;left:0;right:0;z-index:1000;
  background:#ffffff;
  border-bottom:1px solid #e8e8e8;
  box-shadow:0 2px 16px rgba(0,0,0,0.06);
}
.site-header.scrolled{box-shadow:0 4px 24px rgba(0,0,0,0.10)}
.nav-inner{
  display:flex;align-items:center;height:var(--header-h);gap:0;
}
.nav-logo{
  display:flex;align-items:center;
  flex-shrink:0;margin-right:36px;
}
.nav-logo img{
  height:96px;width:auto;
  background:transparent;
  border-radius:0;
  padding:0;
  mix-blend-mode:normal;
}
.nav-logo-text{display:none}
.nav-logo-tagline{display:none}

.nav-menu{display:flex;align-items:center;flex:1;height:100%}
.nav-item{position:relative;height:100%;display:flex;align-items:center}
.nav-link{
  display:flex;align-items:center;height:100%;
  padding:0 20px;font-size:14px;font-weight:500;
  color:#555555;transition:all var(--transition);
  white-space:nowrap;border-bottom:2px solid transparent;gap:4px;
  letter-spacing:0.2px;
}
.nav-link:hover,.nav-link.active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-link svg{transition:transform var(--transition);opacity:0.5}
.nav-item:hover>.nav-link svg{transform:rotate(180deg)}

.nav-dropdown-menu{
  position:absolute;top:100%;left:0;
  background:#ffffff;min-width:220px;
  border-top:2px solid var(--gold);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
  border-radius:0 0 var(--radius) var(--radius);
  padding:8px 0;opacity:0;pointer-events:none;
  transform:translateY(-8px);transition:all var(--transition);z-index:100;
}
.nav-item:hover .nav-dropdown-menu{opacity:1;pointer-events:all;transform:translateY(0)}
.nav-dropdown-item{
  display:block;padding:10px 20px;font-size:13px;
  color:#555;transition:all var(--transition);
  border-left:2px solid transparent;
}
.nav-dropdown-item:hover{color:var(--gold);background:#fffdf5;border-left-color:var(--gold);padding-left:24px}

.nav-cta{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0;padding-left:16px}
.nav-phone{font-size:13px;font-weight:700;color:#111;display:flex;align-items:center;gap:6px}
.nav-phone svg{color:var(--gold)}
.nav-phone small{display:block;font-size:9px;font-weight:400;color:#999;letter-spacing:0.5px;line-height:1}

.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:6px;cursor:pointer;margin-left:auto}
.nav-hamburger span{display:block;width:24px;height:2px;background:#333333;border-radius:2px;transition:all var(--transition)}

/* ── MOBILE NAV ── */
.mobile-nav{
  position:fixed;top:0;right:-100%;width:min(320px,90vw);
  height:100vh;background:var(--black);z-index:2000;
  transition:right 0.32s cubic-bezier(0.4,0,0.2,1);
  overflow-y:auto;padding:20px;
  border-left:1px solid rgba(201,168,76,0.2);
}
.mobile-nav.open{right:0}
.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:1999;opacity:0;pointer-events:none;transition:opacity 0.32s}
.mobile-nav-overlay.open{opacity:1;pointer-events:all}
.mobile-nav-close{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,0.08)}
.mobile-nav-logo{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--white)}
.mobile-nav-logo span{color:var(--gold)}
.mobile-nav-link{display:block;padding:12px 0;font-size:15px;font-weight:600;color:rgba(255,255,255,0.7);border-bottom:1px solid rgba(255,255,255,0.07);transition:color var(--transition)}
.mobile-nav-link:hover{color:var(--gold)}
.mobile-nav-sub .mobile-nav-link{font-size:13px;color:rgba(255,255,255,0.4);padding-left:14px}

/* ── HERO ── */
.hero{
  position:relative;height:75vh;min-height:480px;
  overflow:hidden;background:var(--black);
}
.hero-slider{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero-slide.active{opacity:1}
.hero-slide-bg{
  width:100%;height:100%;background-size:cover;background-position:center;
  transform:scale(1.05);transition:transform 8s ease;
}
.hero-slide.active .hero-slide-bg{transform:scale(1)}

.hero-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px}
.hero-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.45);cursor:pointer;transition:all var(--transition);border:none}
.hero-dot.active{background:var(--gold);transform:scale(1.25)}
.hero-arrows{position:absolute;bottom:20px;right:24px;z-index:3;display:flex;gap:8px}
.hero-arrow{
  width:36px;height:36px;background:rgba(0,0,0,0.35);
  border:1px solid rgba(255,255,255,0.3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;cursor:pointer;transition:all var(--transition);
}
.hero-arrow:hover{background:var(--gold);border-color:var(--gold);color:var(--black)}

/* ── HERO BELOW (text section under slider) ── */
.hero-below{background:#fff;padding:52px 0 44px;border-bottom:1px solid var(--grey-6)}
.hero-below-inner{max-width:720px;margin:0 auto;text-align:center}
.hero-badge-dark{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--gold-pale);border:1px solid rgba(201,168,76,0.4);
  color:var(--gold-dark);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:6px 14px;border-radius:20px;margin-bottom:20px;
}
.hero-below-title{
  font-family:var(--font-display);
  font-size:clamp(28px,4.5vw,48px);
  font-weight:700;color:var(--black);
  line-height:1.12;margin-bottom:16px;
}
.hero-below-title .gold{color:var(--gold)}
.hero-below-title .line{display:block}
.hero-below-subtitle{font-size:16px;color:var(--grey-2);margin-bottom:30px;line-height:1.7;max-width:560px;margin-left:auto;margin-right:auto}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px;justify-content:center}
.hero-stats-dark{
  display:flex;gap:36px;flex-wrap:wrap;justify-content:center;
  padding-top:28px;border-top:1px solid var(--grey-6);
}
.hero-stat-num{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--gold);line-height:1;display:block}
.hero-stat-label-dark{font-size:11px;color:var(--grey-3);text-transform:uppercase;letter-spacing:1px;margin-top:3px;display:block}

/* ── SERVICES BAR ── */
.services-bar{background:var(--black-2);padding:0;border-bottom:1px solid rgba(201,168,76,0.12)}
.services-bar-inner{display:grid;grid-template-columns:repeat(3,1fr)}
.service-bar-item{
  display:flex;align-items:center;gap:16px;
  padding:28px 28px;border-right:1px solid rgba(255,255,255,0.06);
  transition:background var(--transition);cursor:default;
}
.service-bar-item:last-child{border-right:none}
.service-bar-item:hover{background:rgba(201,168,76,0.05)}
.service-bar-icon{
  width:48px;height:48px;flex-shrink:0;
  background:rgba(201,168,76,0.12);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.service-bar-title{font-size:15px;font-weight:700;color:var(--white);margin-bottom:3px}
.service-bar-desc{font-size:12px;color:rgba(255,255,255,0.45);line-height:1.5}

/* ── TOUR CARDS (like agadir-visite.com) ── */
.tour-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:all var(--transition);
  display:flex;flex-direction:column;
  border:1px solid var(--grey-6);
}
.tour-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}

/* Image gallery / carousel */
.tour-gallery{position:relative;height:205px;overflow:hidden;background:var(--grey-6);flex-shrink:0}
.tour-gallery-track{display:flex;height:100%;transition:transform 0.42s ease}
.tour-gallery-slide{min-width:100%;height:100%;overflow:hidden;position:relative}
.tour-gallery-slide img,.gallery-placeholder{width:100%;height:100%;object-fit:cover;display:block}
.gallery-placeholder{display:flex;align-items:center;justify-content:center;font-size:52px;background:var(--light)}

/* Carousel controls */
.gallery-prev,.gallery-next{
  position:absolute;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,0.88);
  box-shadow:0 2px 6px rgba(0,0,0,0.2);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--black);
  cursor:pointer;border:none;z-index:5;
  transition:all var(--transition);line-height:1;
  opacity:0;
}
.tour-card:hover .gallery-prev,.tour-card:hover .gallery-next{opacity:1}
.gallery-prev{left:8px}
.gallery-next{right:8px}
.gallery-prev:hover,.gallery-next:hover{background:var(--white);transform:translateY(-50%) scale(1.08)}

.gallery-dots{
  position:absolute;bottom:7px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;z-index:5;
}
.gallery-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,0.45);border:none;
  cursor:pointer;transition:background var(--transition);padding:0;
}
.gallery-dot.active{background:var(--white)}

/* Card badges */
.card-badge-cat{
  position:absolute;top:10px;left:10px;
  background:var(--gold);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:0.5px;
  padding:3px 10px;border-radius:3px;z-index:4;text-transform:uppercase;
}
.card-badge-duration{
  position:absolute;bottom:9px;right:9px;
  background:rgba(0,0,0,0.62);color:var(--white);
  font-size:11px;font-weight:600;padding:3px 10px;
  border-radius:12px;z-index:4;
  display:flex;align-items:center;gap:4px;
}
.card-wishlist{
  position:absolute;top:10px;right:10px;
  width:33px;height:33px;border-radius:50%;
  background:rgba(255,255,255,0.9);
  display:flex;align-items:center;justify-content:center;
  color:var(--grey-3);cursor:pointer;transition:all var(--transition);
  border:none;z-index:4;box-shadow:0 1px 4px rgba(0,0,0,0.12);
}
.card-wishlist:hover,.card-wishlist.wishlisted{color:#e74c3c;background:var(--white)}

/* Card body */
.card-body{padding:16px 16px 18px;flex:1;display:flex;flex-direction:column}
.card-meta{display:flex;align-items:center;gap:12px;margin-bottom:7px;flex-wrap:wrap}
.card-meta-item{font-size:11px;color:var(--grey-3);display:flex;align-items:center;gap:3px}
.card-meta-item svg{flex-shrink:0;color:var(--gold)}
.card-title{
  font-family:var(--font-display);
  font-size:16px;font-weight:600;
  color:var(--black);line-height:1.35;
  margin-bottom:7px;
}
.card-title a{color:inherit;transition:color var(--transition)}
.card-title a:hover{color:var(--gold)}
.card-excerpt{
  font-size:13px;color:var(--grey-2);line-height:1.65;
  flex:1;margin-bottom:13px;
  display:-webkit-box;-webkit-line-clamp:3;
  -webkit-box-orient:vertical;overflow:hidden;
}
.card-price{font-size:13px;color:var(--grey-3);margin-bottom:12px}
.card-price strong{font-size:17px;font-weight:800;color:var(--gold);margin-left:4px}
.card-rating{display:flex;align-items:center;gap:4px;margin-bottom:12px}
.stars{color:var(--gold);font-size:12px;letter-spacing:-1px}
.rating-num{font-size:12px;font-weight:700;color:var(--grey-1)}
.rating-count{font-size:11px;color:var(--grey-3)}
.card-actions{
  display:flex;align-items:center;gap:8px;
  padding-top:12px;border-top:1px solid var(--grey-6);
}

/* ── GRIDS ── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}

/* ── SECTION HEADER ROW ── */
.section-row{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}

/* ── DESTINATIONS ── */
.dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dest-card{
  position:relative;border-radius:var(--radius-lg);
  overflow:hidden;cursor:pointer;display:block;
}
.dest-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 35%,rgba(0,0,0,0.78) 100%);
}
.dest-card:hover .dest-img{transform:scale(1.06)}
.dest-img{width:100%;height:210px;object-fit:cover;transition:transform 0.5s ease;display:block}
.dest-placeholder{width:100%;height:210px;display:flex;align-items:center;justify-content:center;font-size:50px;transition:transform 0.5s ease}
.dest-card:hover .dest-placeholder{transform:scale(1.06)}
.dest-info{position:absolute;bottom:0;left:0;right:0;padding:16px;z-index:2}
.dest-name{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--white);margin-bottom:2px}
.dest-count{font-size:12px;color:rgba(255,255,255,0.6)}
.dest-card.featured .dest-img,.dest-card.featured .dest-placeholder{height:444px}
.dest-badge{
  position:absolute;top:12px;left:12px;z-index:3;
  background:var(--gold);color:var(--black);
  font-size:9px;font-weight:800;letter-spacing:1.5px;
  text-transform:uppercase;padding:4px 10px;border-radius:3px;
}

/* ── AIRPORTS ── */
.airports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.airport-card{
  background:var(--white);border:1px solid var(--grey-6);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all var(--transition);
}
.airport-card:hover{border-color:var(--gold);box-shadow:0 6px 24px rgba(201,168,76,0.15)}
.airport-head{
  background:var(--black);padding:18px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.airport-code{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--gold);line-height:1}
.airport-info-name{font-size:13px;font-weight:600;color:var(--white);text-align:right}
.airport-info-city{font-size:10px;color:rgba(255,255,255,0.4);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px;text-align:right}
.airport-body{padding:16px 20px}
.airport-row{
  display:flex;align-items:center;gap:9px;
  padding:7px 0;border-bottom:1px solid var(--grey-6);
  font-size:13px;color:var(--grey-1);
}
.airport-row:last-of-type{border-bottom:none}
.airport-row svg{color:var(--gold);flex-shrink:0}
.airport-price-row{
  background:var(--light);margin-top:12px;
  padding:11px 14px;border-radius:var(--radius);
  display:flex;align-items:center;justify-content:space-between;
}
.airport-price-label{font-size:11px;color:var(--grey-3);text-transform:uppercase;letter-spacing:1px}
.airport-price-val{font-size:22px;font-weight:800;color:var(--gold)}

/* ── STEPS ── */
.steps-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;margin-top:40px;position:relative;
}
.steps-grid::before{
  content:'';position:absolute;top:27px;
  left:calc(12.5% + 8px);right:calc(12.5% + 8px);
  height:2px;background:repeating-linear-gradient(90deg,var(--grey-6) 0,var(--grey-6) 8px,transparent 8px,transparent 16px);
}
.step-item{text-align:center;position:relative}
.step-num{
  width:54px;height:54px;border-radius:50%;
  background:var(--gold);color:var(--black);
  font-family:var(--font-display);font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;position:relative;z-index:1;
  box-shadow:0 4px 16px rgba(201,168,76,0.35);
}
.step-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--black);margin-bottom:8px}
.step-desc{font-size:13px;color:var(--grey-3);line-height:1.65}

/* ── TRUST STRIP ── */
.trust-strip{background:var(--black-3);padding:0;border-top:1px solid rgba(201,168,76,0.12);border-bottom:1px solid rgba(201,168,76,0.12)}
.trust-strip-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-item{
  display:flex;align-items:center;gap:14px;
  padding:22px 24px;border-right:1px solid rgba(255,255,255,0.06);
  transition:background var(--transition);
}
.trust-item:last-child{border-right:none}
.trust-item:hover{background:rgba(201,168,76,0.06)}
.trust-icon{
  width:44px;height:44px;flex-shrink:0;
  background:rgba(201,168,76,0.12);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.trust-title{font-size:13px;font-weight:700;color:var(--white);margin-bottom:2px}
.trust-desc{font-size:11px;color:rgba(255,255,255,0.4)}

/* ── TRIPADVISOR REVIEWS CAROUSEL ── */
.ta-reviews-section{background:#f5f5f5}
.ta-reviews-header{display:flex;align-items:center;gap:40px;margin-bottom:36px;flex-wrap:wrap}
.ta-summary-box{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  background:#fff;border-radius:12px;padding:20px 28px;
  box-shadow:0 2px 12px rgba(0,0,0,.07);min-width:160px;flex-shrink:0;
}
.ta-summary-label{font-size:20px;font-weight:800;color:#111;letter-spacing:1px;text-transform:uppercase}
.ta-summary-bubbles svg{display:block}
.ta-summary-count{font-size:12px;color:#555}
.ta-logo-link{display:block;margin-top:4px}
.ta-reviews-title-wrap{flex:1;min-width:220px}
.ta-carousel-wrap{position:relative;display:flex;align-items:center;gap:0}
.ta-carousel-track-outer{overflow:hidden;flex:1}
.ta-carousel-track{
  display:flex;gap:16px;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
}
.ta-card{
  flex:0 0 calc(20% - 13px);min-width:0;
  background:#fff;border-radius:10px;border:1px solid #e0e0e0;
  padding:18px;text-decoration:none;color:inherit;
  transition:box-shadow .25s,border-color .25s;
  display:flex;flex-direction:column;gap:8px;cursor:pointer;
}
.ta-card:hover{box-shadow:0 6px 24px rgba(0,170,108,.15);border-color:#00AA6C}
.ta-card-top{display:flex;align-items:center;gap:10px}
.ta-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:700;
}
.ta-card-meta{flex:1;min-width:0}
.ta-card-name{font-size:13px;font-weight:700;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ta-card-date{font-size:11px;color:#888}
.ta-card-logo{flex-shrink:0}
.ta-card-bubbles{color:#00AA6C;font-size:15px;letter-spacing:1px}
.ta-card-text{
  font-size:13px;color:#444;line-height:1.65;flex:1;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.ta-card-more{font-size:12px;color:#00AA6C;font-weight:600;margin-top:4px}
.ta-carousel-btn{
  background:#fff;border:1px solid #ddd;border-radius:50%;
  width:42px;height:42px;font-size:26px;line-height:1;
  cursor:pointer;color:#333;flex-shrink:0;
  transition:background .2s,border-color .2s,color .2s;
  display:flex;align-items:center;justify-content:center;
  z-index:2;
}
.ta-carousel-btn:hover{background:#00AA6C;border-color:#00AA6C;color:#fff}
.ta-prev{margin-right:12px}
.ta-next{margin-left:12px}
.ta-reviews-footer{text-align:center;margin-top:28px}
.btn-outline-ta{
  display:inline-block;padding:12px 28px;border:2px solid #00AA6C;
  border-radius:6px;color:#00AA6C;font-weight:700;font-size:14px;
  text-decoration:none;transition:all .2s;
}
.btn-outline-ta:hover{background:#00AA6C;color:#fff}

/* ── FLEET VEHICLES ── */
.fleet-section{background:var(--white)}
.fleet-vehicles-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.fleet-vehicle-card{
  background:var(--white);border:1px solid var(--grey-6);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all var(--transition);display:flex;flex-direction:column;
}
.fleet-vehicle-card:hover{box-shadow:var(--shadow-md);border-color:var(--gold);transform:translateY(-4px)}
.fleet-vehicle-img{position:relative;height:200px;overflow:hidden;background:var(--light)}
.fleet-vehicle-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.fleet-vehicle-card:hover .fleet-vehicle-img img{transform:scale(1.06)}
.fleet-vehicle-badge{
  position:absolute;top:12px;right:12px;
  background:var(--gold);color:#fff;
  font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;
}
.fleet-vehicle-body{padding:20px;flex:1;display:flex;flex-direction:column;gap:10px}
.fleet-vehicle-name{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--black)}
.fleet-vehicle-desc{font-size:13px;color:var(--grey-2);line-height:1.65;flex:1}
.fleet-vehicle-features{list-style:none;display:flex;flex-direction:column;gap:5px;margin:0;padding:0}
.fleet-vehicle-features li{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--grey-2)}
.fleet-vehicle-features svg{color:var(--gold);flex-shrink:0}
.fleet-vehicle-btn{
  display:inline-block;margin-top:14px;padding:10px 0;text-align:center;
  background:var(--black);color:#fff;border-radius:6px;
  font-size:13px;font-weight:700;text-decoration:none;
  transition:background var(--transition);
}
.fleet-vehicle-btn:hover{background:var(--gold);color:#fff}
.fleet-cta-row{text-align:center}

/* ── FLEET ── */
.fleet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fleet-card{background:var(--white);border:1px solid var(--grey-6);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.fleet-card:hover{box-shadow:var(--shadow-md);border-color:var(--gold-pale)}
.fleet-img{height:175px;background:var(--light);display:flex;align-items:center;justify-content:center;font-size:60px;overflow:hidden}
.fleet-img img{width:100%;height:100%;object-fit:cover}
.fleet-body{padding:16px}
.fleet-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--black);margin-bottom:5px}
.fleet-pax{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--gold-dark);font-weight:600;background:var(--gold-pale);padding:2px 10px;border-radius:12px;margin-bottom:10px}
.fleet-tags{display:flex;flex-wrap:wrap;gap:5px}
.fleet-tag{font-size:11px;color:var(--grey-2);background:var(--light);padding:3px 9px;border-radius:12px;border:1px solid var(--grey-6)}

/* ── PROMO BANNER ── */
.promo-banner{background:var(--gold);padding:14px 0}
.promo-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.promo-text{font-size:14px;color:var(--black);font-weight:600;display:flex;align-items:center;gap:10px}
.promo-text strong{font-size:17px;font-weight:800}
.promo-code{background:rgba(0,0,0,0.15);padding:3px 12px;border-radius:4px;font-size:15px;font-weight:800;font-family:monospace;letter-spacing:2px}

/* ── NEWSLETTER ── */
.newsletter-section{background:var(--black-2);padding:50px 0;border-top:1px solid rgba(201,168,76,0.15)}
.newsletter-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.newsletter-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--white);margin-bottom:7px}
.newsletter-desc{font-size:13px;color:rgba(255,255,255,0.5)}
.newsletter-form{display:flex;gap:0}
.newsletter-input{
  flex:1;height:48px;border:2px solid rgba(201,168,76,0.25);border-right:none;
  background:rgba(255,255,255,0.06);padding:0 16px;font-size:13px;color:var(--white);
  outline:none;border-radius:var(--radius) 0 0 var(--radius);
}
.newsletter-input::placeholder{color:rgba(255,255,255,0.3)}
.newsletter-input:focus{border-color:var(--gold);background:rgba(255,255,255,0.1)}
.newsletter-btn{
  height:48px;background:var(--gold);color:var(--black);
  font-size:13px;font-weight:700;padding:0 22px;
  border:none;cursor:pointer;border-radius:0 var(--radius) var(--radius) 0;
  transition:background var(--transition);white-space:nowrap;font-family:var(--font);
}
.newsletter-btn:hover{background:var(--gold-dark)}

/* ── BLOG CAROUSEL (homepage) ── */
.blog-carousel-wrap{position:relative;display:flex;align-items:center;gap:0}
.blog-carousel-outer{overflow:hidden;flex:1}
.blog-carousel{
  display:flex;gap:24px;
  transition:transform 0.55s cubic-bezier(.25,.46,.45,.94);
  will-change:transform;
}
.blog-carousel-card{
  flex:0 0 calc(33.333% - 16px);
  background:var(--white);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow);
  transition:transform var(--transition),box-shadow var(--transition);
  display:flex;flex-direction:column;
}
.blog-carousel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-carousel-img{position:relative;height:190px;overflow:hidden;background:var(--grey-6)}
.blog-carousel-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.blog-carousel-card:hover .blog-carousel-img img{transform:scale(1.06)}
.blog-carousel-cat{
  position:absolute;top:12px;left:12px;
  background:var(--gold);color:var(--black);
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 9px;border-radius:20px;
}
.blog-carousel-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}
.blog-carousel-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--black);margin-bottom:9px;line-height:1.35}
.blog-carousel-title a{color:inherit;transition:color var(--transition)}
.blog-carousel-title a:hover{color:var(--gold)}
.blog-carousel-excerpt{font-size:13px;color:var(--grey-2);line-height:1.65;flex:1;margin-bottom:12px}
.blog-carousel-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--grey-4);margin-top:auto}
.blog-carousel-btn{
  flex-shrink:0;
  width:40px;height:40px;border-radius:50%;
  background:#fff;border:1px solid var(--grey-6);
  box-shadow:0 2px 10px rgba(0,0,0,0.12);
  display:flex;align-items:center;justify-content:center;
  color:var(--grey-1);cursor:pointer;transition:all var(--transition);z-index:2;
}
.blog-carousel-btn:hover{background:var(--gold);border-color:var(--gold);color:var(--black)}
.blog-carousel-prev{margin-right:12px}
.blog-carousel-next{margin-left:12px}

/* legacy blog grid (kept for compatibility) */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:var(--white);border:1px solid var(--grey-6);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.blog-img-wrap{height:175px;overflow:hidden;background:var(--light)}
.blog-img{width:100%;height:100%;object-fit:cover;transition:transform 0.45s ease}
.blog-cat{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold-dark);margin-bottom:7px}
.blog-body{padding:16px}
.blog-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--black);margin-bottom:8px;line-height:1.4}
.blog-title a{color:inherit;transition:color var(--transition)}
.blog-title a:hover{color:var(--gold)}
.blog-excerpt{font-size:13px;color:var(--grey-3);line-height:1.65;margin-bottom:13px}
.blog-meta{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--grey-4)}

/* ── FOOTER ── */
.site-footer{background:var(--black);padding-top:52px;border-top:1px solid rgba(201,168,76,0.15)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.07)}
.footer-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-logo-row img{height:96px;width:auto;mix-blend-mode:screen}
.footer-brand{display:none}
.footer-desc{font-size:13px;color:rgba(255,255,255,0.38);line-height:1.75;margin-bottom:20px;max-width:270px}
.footer-social{display:flex;gap:8px}
.social-btn{
  width:34px;height:34px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,0.12);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.4);transition:all var(--transition);
}
.social-btn:hover{background:var(--gold);border-color:var(--gold);color:var(--black)}
.footer-col-title{
  font-size:13px;font-weight:700;color:var(--white);
  margin-bottom:16px;padding-bottom:10px;
  border-bottom:2px solid var(--gold);display:inline-block;
}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-link{font-size:13px;color:rgba(255,255,255,0.4);transition:color var(--transition);display:flex;align-items:center;gap:6px}
.footer-link::before{content:'›';color:var(--gold);font-size:14px}
.footer-link:hover{color:rgba(255,255,255,0.85)}
.footer-contact-list{display:flex;flex-direction:column;gap:11px}
.footer-contact-item{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:rgba(255,255,255,0.4)}
.footer-contact-item svg{color:var(--gold);flex-shrink:0;margin-top:2px}
.footer-contact-item a{color:rgba(255,255,255,0.6);transition:color var(--transition)}
.footer-contact-item a:hover{color:var(--gold)}
.footer-bottom{
  padding:16px 0;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.25)}
.footer-copy a{color:rgba(201,168,76,0.55);transition:color var(--transition)}
.footer-copy a:hover{color:var(--gold)}
.footer-payment-icons{display:flex;align-items:center;gap:6px}
.payment-icon{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);padding:3px 9px;font-size:10px;font-weight:700;color:rgba(255,255,255,0.4);letter-spacing:0.5px;border-radius:3px}
.footer-lang-list{display:flex;gap:6px}
.footer-lang-btn{
  font-size:10px;font-weight:700;color:rgba(255,255,255,0.3);
  background:none;border:1px solid rgba(255,255,255,0.1);
  padding:3px 8px;border-radius:3px;cursor:pointer;
  transition:all var(--transition);text-transform:uppercase;font-family:var(--font);
}
.footer-lang-btn:hover,.footer-lang-btn.active{color:var(--gold);border-color:var(--gold)}

/* ── BREADCRUMB ── */
.breadcrumb{background:var(--light);border-bottom:1px solid var(--grey-6);padding:11px 0}
.breadcrumb-inner{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--grey-3)}
.breadcrumb-item{color:var(--grey-3)}
.breadcrumb-item a{color:var(--gold-dark)}
.breadcrumb-item a:hover{color:var(--gold);text-decoration:underline}
.breadcrumb-item.active{color:var(--grey-1);font-weight:600}
.breadcrumb-sep{color:var(--grey-5)}

/* ── PAGE HERO ── */
.page-hero{
  background:linear-gradient(135deg,var(--black) 0%,var(--black-3) 100%);
  padding:56px 0 46px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23C9A84C' fill-opacity='0.04'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.page-hero-content{position:relative;z-index:1}
.page-hero-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:10px}
.page-hero-title{font-family:var(--font-display);font-size:clamp(26px,4vw,38px);font-weight:700;color:var(--white);margin-bottom:12px;line-height:1.15}
.page-hero-desc{font-size:14px;color:rgba(255,255,255,0.55);max-width:560px}

/* ── BOOKING SIDEBAR ── */
.booking-sidebar{background:var(--white);border:1px solid var(--grey-6);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.booking-sidebar-head{background:var(--black);padding:16px 18px}
.booking-sidebar-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--white)}
.booking-sidebar-price-row{display:flex;align-items:baseline;gap:4px;margin-top:4px}
.booking-sidebar-from{font-size:11px;color:rgba(255,255,255,0.4)}
.booking-sidebar-amount{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--gold)}
.booking-sidebar-body{padding:18px}
.booking-field{margin-bottom:13px}
.booking-field label{display:block;font-size:11px;font-weight:700;color:var(--grey-3);margin-bottom:5px;text-transform:uppercase;letter-spacing:0.5px}
.booking-field input,.booking-field select,.booking-field textarea{
  width:100%;border:1.5px solid var(--grey-6);border-radius:var(--radius);
  padding:9px 12px;font-size:13px;color:var(--grey-1);background:var(--white);
  outline:none;transition:border-color var(--transition);appearance:none;
}
.booking-field input:focus,.booking-field select:focus,.booking-field textarea:focus{border-color:var(--gold)}
.booking-row{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.pax-selector{display:flex;align-items:center;border:1.5px solid var(--grey-6);border-radius:var(--radius);overflow:hidden}
.pax-selector button{width:36px;height:36px;background:var(--light);font-size:18px;color:var(--gold-dark);display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0;line-height:1}
.pax-selector button:hover{background:var(--grey-6)}
.pax-selector button:disabled{opacity:0.35}
.pax-count{flex:1;text-align:center;font-size:15px;font-weight:700;color:var(--grey-1)}
.booking-total{background:var(--light);border-radius:var(--radius);padding:13px;margin-bottom:13px}
.booking-total-row{display:flex;justify-content:space-between;font-size:13px;color:var(--grey-3);padding:3px 0}
.booking-total-row.total{font-size:15px;font-weight:800;color:var(--black);border-top:1px solid var(--grey-6);margin-top:7px;padding-top:9px}
.booking-total-row.total span:last-child{color:var(--gold)}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:13px;font-weight:700;color:var(--grey-1);margin-bottom:5px}
.form-control{
  width:100%;border:1.5px solid var(--grey-6);border-radius:var(--radius);
  padding:10px 13px;font-size:14px;color:var(--grey-1);background:var(--white);
  outline:none;transition:border-color var(--transition);appearance:none;
}
.form-control:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,0.12)}
.form-control::placeholder{color:var(--grey-4)}
textarea.form-control{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-check{display:flex;align-items:flex-start;gap:9px}
.form-check input{width:16px;height:16px;margin-top:2px;flex-shrink:0;accent-color:var(--gold)}
.form-check label{font-size:13px;color:var(--grey-3);line-height:1.5}
.form-errors{background:#FEF2F2;border:1px solid #FECACA;border-radius:var(--radius);padding:12px 16px;margin-bottom:14px;display:none}
.form-errors li{font-size:13px;color:#DC2626;padding:2px 0}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:var(--white);border:1px solid var(--grey-6);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition)}
.faq-item.open{border-color:var(--gold)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;cursor:pointer;font-size:14px;font-weight:600;color:var(--grey-1);gap:12px;user-select:none;transition:color var(--transition)}
.faq-question:hover{color:var(--gold-dark)}
.faq-item.open .faq-question{color:var(--gold-dark)}
.faq-icon{width:22px;height:22px;border-radius:50%;background:var(--light);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;color:var(--grey-3);transition:all var(--transition)}
.faq-item.open .faq-icon{background:var(--gold);color:var(--black);transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-answer-inner{padding:0 18px 16px;font-size:13px;color:var(--grey-3);line-height:1.75}

/* ── FILTER BAR ── */
.filter-bar{background:var(--white);border-bottom:1px solid var(--grey-6);padding:12px 0;position:sticky;top:var(--header-h);z-index:100;box-shadow:0 2px 8px rgba(0,0,0,0.05)}
.filter-bar-inner{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.filter-btn{
  font-size:13px;font-weight:600;color:var(--grey-3);
  padding:7px 15px;border:1.5px solid var(--grey-6);
  border-radius:20px;cursor:pointer;transition:all var(--transition);
  background:var(--white);font-family:var(--font);
}
.filter-btn:hover,.filter-btn.active{background:var(--black);border-color:var(--black);color:var(--white)}
.filter-sort{margin-left:auto;display:flex;align-items:center;gap:8px}
.filter-sort label{font-size:12px;color:var(--grey-3);white-space:nowrap}
.filter-sort select{border:1.5px solid var(--grey-6);border-radius:var(--radius);padding:7px 12px;font-size:13px;color:var(--grey-1);background:var(--white);outline:none;cursor:pointer;font-family:var(--font);appearance:none}
.view-toggle{display:flex;gap:4px}
.view-btn{width:34px;height:34px;border:1.5px solid var(--grey-6);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--grey-3);cursor:pointer;transition:all var(--transition);background:var(--white)}
.view-btn.active,.view-btn:hover{background:var(--black);border-color:var(--black);color:var(--white)}
.filters-sidebar{background:var(--white);border:1px solid var(--grey-6);border-radius:var(--radius-lg);padding:18px}
.filters-group{border-bottom:1px solid var(--grey-6);padding-bottom:16px;margin-bottom:16px}
.filters-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.filters-group-title{font-size:13px;font-weight:700;color:var(--grey-1);margin-bottom:10px}
.filter-checkbox{display:flex;align-items:center;gap:8px;padding:4px 0;cursor:pointer}
.filter-checkbox input{accent-color:var(--gold);width:14px;height:14px}
.filter-checkbox label{font-size:13px;color:var(--grey-3);cursor:pointer;flex:1}
.filter-checkbox .count{font-size:11px;color:var(--grey-4);background:var(--light);padding:1px 6px;border-radius:10px}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:32px 0 8px}
.page-btn{
  width:36px;height:36px;border:1.5px solid var(--grey-6);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;color:var(--grey-3);
  cursor:pointer;transition:all var(--transition);background:var(--white);font-family:var(--font);
}
.page-btn:hover,.page-btn.active{background:var(--black);border-color:var(--black);color:var(--white)}

/* ── WHATSAPP / SCROLL ── */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;width:54px;height:54px;
  background:#25D366;color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  z-index:999;box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:all var(--transition);cursor:pointer;
}
.whatsapp-float:hover{background:#1ebe5d;transform:scale(1.08)}
.whatsapp-pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;animation:wa-pulse 2s ease infinite}
@keyframes wa-pulse{0%{transform:scale(1);opacity:0.5}100%{transform:scale(1.65);opacity:0}}
.scroll-top{
  position:fixed;bottom:24px;left:24px;width:40px;height:40px;
  background:var(--black);color:var(--gold);
  border:1px solid rgba(201,168,76,0.35);
  border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;pointer-events:none;
  transition:all var(--transition);z-index:998;box-shadow:var(--shadow-md);
}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}

/* ── LIGHTBOX ── */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.94);z-index:9999;display:none;align-items:center;justify-content:center}
.lightbox-overlay.open{display:flex}
.lightbox-close{position:absolute;top:20px;right:22px;font-size:28px;color:rgba(255,255,255,0.5);cursor:pointer;background:none;border:none;transition:color var(--transition)}
.lightbox-close:hover{color:#fff}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);font-size:36px;color:rgba(255,255,255,0.55);cursor:pointer;background:rgba(255,255,255,0.08);border:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,0.18);color:#fff}
.lightbox-prev{left:18px}.lightbox-next{right:18px}
.lightbox-img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:var(--radius)}
.lightbox-caption{color:rgba(255,255,255,0.45);font-size:13px;margin-top:12px;text-align:center}

/* ── TOAST ── */
.toast{position:fixed;bottom:80px;right:24px;background:var(--black);color:#fff;padding:12px 20px;border-radius:var(--radius);font-size:14px;z-index:9000;opacity:0;transform:translateY(10px);transition:all 0.3s;box-shadow:var(--shadow-lg)}
.toast.visible{opacity:1;transform:translateY(0)}
.toast-success{background:#27AE60}
.toast-error{background:#E74C3C}

/* ── SCROLL REVEAL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-left.revealed{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-right.revealed{opacity:1;transform:translateX(0)}
.delay-1{transition-delay:0.1s}
.delay-2{transition-delay:0.2s}
.delay-3{transition-delay:0.3s}
.delay-4{transition-delay:0.4s}
.delay-5{transition-delay:0.5s}
.delay-6{transition-delay:0.6s}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .dest-grid{grid-template-columns:repeat(2,1fr)}
  .fleet-grid{grid-template-columns:repeat(2,1fr)}
  .fleet-vehicles-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .blog-carousel-card{flex:0 0 calc(50% - 12px)}
  .airports-grid{grid-template-columns:repeat(2,1fr)}
  .ta-card{flex:0 0 calc(33.333% - 11px)}
  .trust-strip-inner{grid-template-columns:repeat(2,1fr)}
  .services-bar-inner{grid-template-columns:1fr}
  .service-bar-item{border-right:none;border-bottom:1px solid rgba(255,255,255,0.06)}
  .service-bar-item:last-child{border-bottom:none}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .steps-grid::before{display:none}
  .newsletter-inner{grid-template-columns:1fr;gap:22px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .nav-phone{display:none}
}
@media(max-width:768px){
  .container{padding:0 16px}
  .section-pad{padding:44px 0}
  .topbar{display:none}
  .nav-menu{display:none}
  .nav-cta .btn{display:none}
  .nav-hamburger{display:flex}
  .nav-inner{height:58px}
  .hero{height:56vh;min-height:320px}
  .hero-below{padding:36px 0 32px}
  .hero-below-title{font-size:26px}
  .hero-stats-dark{gap:20px}
  .grid-3,.grid-4{grid-template-columns:1fr}
  .dest-grid{grid-template-columns:1fr}
  .dest-card.featured .dest-img,.dest-card.featured .dest-placeholder{height:220px}
  .airports-grid{grid-template-columns:1fr}
  .ta-card{flex:0 0 calc(100% - 0px)}
  .fleet-grid{grid-template-columns:1fr}
  .fleet-vehicles-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .blog-carousel-card{flex:0 0 calc(100% - 0px)}
  .blog-carousel-btn{display:none}
  .footer-grid{grid-template-columns:1fr;gap:22px}
  .trust-strip-inner{grid-template-columns:1fr 1fr}
  .steps-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .newsletter-form{flex-direction:column}
  .newsletter-input{border-right:2px solid rgba(201,168,76,0.25);border-radius:var(--radius)}
  .newsletter-btn{border-radius:var(--radius);width:100%}
  .section-row{flex-direction:column;align-items:flex-start}
  .promo-inner{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .hero-title{font-size:24px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%;justify-content:center;text-align:center}
  .trust-strip-inner{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center;gap:12px}
  .footer-payment-icons{justify-content:center}
  .footer-grid{grid-template-columns:1fr}
  .section-pad{padding:32px 0}
  .container{padding:0 12px}
  .card-img{height:180px}
  .page-hero{padding:60px 0 40px}
  .page-hero-title{font-size:clamp(22px,6vw,32px)}
  .section-title{font-size:clamp(20px,5vw,28px)}
  .btn{padding:11px 20px;font-size:13px}
  .hero-below-title{font-size:22px}
  .hero-stats-dark{flex-direction:column;align-items:center;gap:16px}
  .hero-stat-divider{display:none}
  .promo-inner{padding:28px 16px}
  .newsletter-inner{padding:28px 16px}
  .ta-strip{padding:16px 0}
  .tour-card{margin-bottom:0}
}

/* ── Extra small (320px) ── */
@media(max-width:360px){
  .container{padding:0 10px}
  .nav-logo img{height:72px}
  .hero{height:50vh;min-height:280px}
  .footer-copy{font-size:11px}
}
