:root{
  --ink:#1B2030;
  --ink-soft:#2A3147;
  --paper:#F7F4EC;
  --paper-dim:#EFEADD;
  --marigold:#D98F2B;
  --marigold-light:#E8A93C;
  --marigold-deep:#B8721E;
  --slate:#6B7280;
  --slate-light:#9AA0AC;
  --route-green:#2F6F4E;
  --white:#FFFFFF;
  --line:rgba(27,32,48,0.10);
  --line-on-dark:rgba(247,244,236,0.14);
  --shadow-soft:0 8px 24px rgba(27,32,48,0.08);
  --shadow-card:0 4px 14px rgba(27,32,48,0.06);
  --radius:14px;
  --radius-sm:9px;
  --ff-display:'Fraunces', serif;
  --ff-body:'Inter', system-ui, -apple-system, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--ff-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
.container{max-width:1180px;margin:0 auto;padding:0 20px;}
section{position:relative;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important;}
}

/* ===== Skip link / focus ===== */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:2.5px solid var(--marigold);
  outline-offset:2px;
  border-radius:4px;
}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:200;}
.skip-link:focus{left:10px;top:10px;}

/* ===== Top bar ===== */
.topbar{
  background:var(--ink);
  color:var(--paper);
  font-size:13px;
  padding:7px 0;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.topbar a{display:inline-flex;align-items:center;gap:6px;color:var(--paper);opacity:0.92;}
.topbar a:hover{opacity:1;color:var(--marigold-light);}
.topbar-links{display:flex;gap:18px;}
.topbar-tag{color:var(--marigold-light);font-weight:600;letter-spacing:.02em;}

/* ===== Header ===== */
header.site-header{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:saturate(1.1);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;gap:16px;}
.brand{display:flex;align-items:center;gap:10px;}
.brand img{height:38px;width:auto;}
.brand-text{font-family:var(--ff-display);font-weight:600;font-size:19px;color:var(--ink);letter-spacing:-0.01em;}
.brand-text span{color:var(--marigold-deep);}
nav.main-nav{display:flex;gap:30px;align-items:center;}
nav.main-nav a{font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:color .15s;}
nav.main-nav a:hover{color:var(--marigold-deep);}
.nav-cta{display:flex;gap:10px;align-items:center;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 20px;border-radius:30px;font-weight:600;font-size:14.5px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--marigold);color:var(--white);box-shadow:0 4px 14px rgba(217,143,43,0.35);}
.btn-primary:hover{background:var(--marigold-deep);transform:translateY(-1px);}
.btn-outline{border:1.5px solid var(--ink);color:var(--ink);}
.btn-outline:hover{background:var(--ink);color:var(--paper);}
.btn-ghost-dark{background:var(--ink);color:var(--paper);}
.btn-ghost-dark:hover{background:var(--ink-soft);}
.btn-sm{padding:8px 16px;font-size:13.5px;}
.btn svg{width:16px;height:16px;flex-shrink:0;}
.menu-toggle{display:none;background:none;border:none;padding:8px;}
.menu-toggle svg{width:24px;height:24px;}

@media (max-width:880px){
  nav.main-nav{display:none;}
  .nav-cta .btn-text{display:none;}
  .menu-toggle{display:block;}
}

/* ===== Hero / Route Strip ===== */
.hero{
  background:linear-gradient(180deg, var(--ink) 0%, var(--ink-soft) 100%);
  color:var(--paper);
  padding:52px 0 0;
  overflow:hidden;
  position:relative;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 700px 400px at 80% -10%, rgba(217,143,43,0.16), transparent 60%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--marigold-light);
  margin-bottom:18px;
}
.hero-eyebrow::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--route-green);box-shadow:0 0 0 3px rgba(47,111,78,0.25);}
.hero h1{
  font-family:var(--ff-display);
  font-weight:600;
  font-size:clamp(34px, 5.2vw, 58px);
  line-height:1.08;
  letter-spacing:-0.015em;
  max-width:780px;
  margin-bottom:18px;
}
.hero h1 em{font-style:normal;color:var(--marigold-light);}
.hero-sub{
  font-size:17px;
  color:rgba(247,244,236,0.78);
  max-width:560px;
  margin-bottom:30px;
  line-height:1.6;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px;}

/* Route strip - simple horizontal scroll of route cards */
.route-strip-wrap{
  background:rgba(247,244,236,0.05);
  border-top:1px solid var(--line-on-dark);
  padding:28px 0 0;
}
.route-strip-label{
  font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--slate-light);margin-bottom:18px;
}
.route-strip{
  position:relative;
  display:flex;
  align-items:center;
  gap:0;
  overflow-x:auto;
  padding-bottom:6px;
  scrollbar-width:none;
}
.route-strip::-webkit-scrollbar{display:none;}
.route-stop{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  border-right:1px solid var(--line-on-dark);
}
.route-stop:last-child{border-right:none;}
.route-stop-thumb{
  width:36px;height:36px;border-radius:8px;
  background-size:cover;background-position:center;
  flex-shrink:0;
}
.route-stop-text{display:flex;flex-direction:column;}
.route-stop-city{font-family:var(--ff-display);font-weight:600;font-size:15.5px;line-height:1.2;white-space:nowrap;}
.route-stop-type{font-size:10.5px;color:var(--slate-light);text-transform:uppercase;letter-spacing:.04em;}
.route-stop-price{
  display:inline-flex;align-items:baseline;gap:3px;
  margin-left:4px;
}
.route-stop-price .amt{font-weight:700;font-size:15px;color:var(--marigold-light);white-space:nowrap;}
.route-stop-price .lbl{font-size:10.5px;color:var(--slate-light);}
.route-stop-link{display:flex;text-decoration:none;color:inherit;transition:background .15s;border-radius:10px;}
.route-stop-link:hover{background:rgba(247,244,236,0.06);}

/* ===== Trust strip ===== */
.trust-strip{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  padding:22px 0;
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
  text-align:center;
}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:8px;}
.trust-item svg{width:26px;height:26px;color:var(--marigold-deep);}
.trust-item span{font-size:13px;font-weight:600;color:var(--ink-soft);line-height:1.3;}
@media (max-width:760px){
  .trust-grid{grid-template-columns:repeat(2, 1fr);}
}

/* ===== Section headers ===== */
.section-pad{padding:88px 0;}
.section-pad-sm{padding:64px 0;}
.sec-eyebrow{
  font-size:12.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:var(--marigold-deep);margin-bottom:12px;display:block;
}
.sec-title{
  font-family:var(--ff-display);font-weight:600;
  font-size:clamp(28px, 3.6vw, 40px);
  letter-spacing:-0.01em;
  max-width:620px;
  margin-bottom:14px;
  line-height:1.15;
}
.sec-desc{font-size:16px;color:var(--slate);max-width:540px;line-height:1.65;}
.sec-head{margin-bottom:48px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head.center .sec-title, .sec-head.center .sec-desc{margin-left:auto;margin-right:auto;}

/* ===== Routes / pricing section ===== */
.routes-tabs{display:flex;gap:10px;margin-bottom:34px;flex-wrap:wrap;}
.tab-btn{
  padding:10px 20px;border-radius:30px;font-weight:600;font-size:14px;
  border:1.5px solid var(--line);color:var(--slate);background:var(--white);
  transition:all .15s;
}
.tab-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

.route-cards{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px;}
@media (max-width:700px){.route-cards{grid-template-columns:1fr;}}

.route-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px 24px;
  box-shadow:var(--shadow-card);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  transition:transform .18s ease, box-shadow .18s ease;
}
.route-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);}
.route-card-route{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.route-card-route .city{font-family:var(--ff-display);font-weight:600;font-size:17px;}
.route-card-route .arrow{color:var(--marigold-deep);font-size:15px;}
.route-card-note{font-size:12.5px;color:var(--slate);margin-top:4px;}
.route-card-price{text-align:right;flex-shrink:0;}
.route-card-price .price{font-family:var(--ff-display);font-weight:700;font-size:22px;color:var(--ink);}
.route-card-price .sub{font-size:11.5px;color:var(--slate);}
.route-card-cta{margin-top:10px;}

/* Route card with thumbnail image (used for one-way routes) */
.route-card-img{
  display:flex;
  align-items:center;
  gap:16px;
}
.route-card-thumb{
  width:72px;height:72px;border-radius:11px;flex-shrink:0;
  background-size:cover;background-position:center;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.06);
}
@media (max-width:480px){
  .route-card-thumb{width:56px;height:56px;}
}

/* Destination gallery grid - image-led cards for round trip destinations */
.dest-gallery{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
@media (max-width:880px){.dest-gallery{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.dest-gallery{grid-template-columns:1fr;}}

.dest-gallery-card{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  height:260px;
  background:var(--ink-soft);
  box-shadow:var(--shadow-card);
  transition:transform .2s ease, box-shadow .2s ease;
}
.dest-gallery-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.dest-gallery-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .4s ease;
}
.dest-gallery-card:hover .dest-gallery-img{transform:scale(1.05);}
.dest-gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(27,32,48,0) 35%, rgba(27,32,48,0.88) 100%);
}
.dest-gallery-content{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;color:var(--paper);}
.dest-gallery-content h4{font-family:var(--ff-display);font-size:19px;font-weight:600;margin-bottom:4px;}
.dest-gallery-meta{display:flex;justify-content:space-between;align-items:baseline;gap:10px;}
.dest-gallery-meta .price{font-size:14px;font-weight:700;color:var(--marigold-light);}
.dest-gallery-meta .type{font-size:11.5px;color:rgba(247,244,236,0.65);text-transform:uppercase;letter-spacing:.04em;}
.dest-gallery-card .btn-sm{
  position:absolute;top:14px;right:14px;
  background:rgba(247,244,236,0.92);color:var(--ink);
  padding:7px 14px;font-size:12.5px;
  opacity:0;transform:translateY(-6px);
  transition:opacity .2s, transform .2s;
}
.dest-gallery-card:hover .btn-sm{opacity:1;transform:translateY(0);}
@media (max-width:880px){
  .dest-gallery-card .btn-sm{opacity:1;transform:none;}
}

/* Fleet / driver photo gallery */
.fleet-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:36px;
}
@media (max-width:880px){.fleet-gallery{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.fleet-gallery{grid-template-columns:1fr;}}
.fleet-photo{
  border-radius:var(--radius);
  overflow:hidden;
  height:220px;
  background:var(--paper-dim);
  box-shadow:var(--shadow-card);
}
.fleet-photo img{width:100%;height:100%;object-fit:cover;display:block;}

/* Breadcrumb (route pages) */
.breadcrumb{
  font-size:13px;color:var(--slate);
  padding:18px 0 0;
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
}
.breadcrumb a{color:var(--slate);}
.breadcrumb a:hover{color:var(--marigold-deep);}
.breadcrumb .sep{color:var(--slate-light);}
.breadcrumb .current{color:var(--ink);font-weight:600;}

/* Route page mini-hero */
.route-hero{
  background:linear-gradient(180deg, var(--ink) 0%, var(--ink-soft) 100%);
  color:var(--paper);
  padding:30px 0 56px;
  position:relative;
  overflow:hidden;
}
.route-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 600px 360px at 85% 0%, rgba(217,143,43,0.18), transparent 60%);
  pointer-events:none;
}
.route-hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;
}
@media (max-width:880px){.route-hero-grid{grid-template-columns:1fr;gap:28px;}}
.route-hero-img{
  border-radius:18px;
  overflow:hidden;
  height:280px;
  box-shadow:0 20px 50px rgba(0,0,0,0.35);
}
.route-hero-img img{width:100%;height:100%;object-fit:cover;display:block;}
.route-hero h1{font-family:var(--ff-display);font-weight:600;font-size:clamp(30px,4.4vw,46px);line-height:1.1;letter-spacing:-0.01em;margin-bottom:14px;}
.route-hero-fare{
  display:inline-flex;align-items:baseline;gap:8px;
  background:rgba(217,143,43,0.14);border:1px solid rgba(217,143,43,0.32);
  padding:10px 18px;border-radius:30px;margin-bottom:20px;
}
.route-hero-fare .amt{font-family:var(--ff-display);font-weight:700;font-size:26px;color:var(--marigold-light);}
.route-hero-fare .lbl{font-size:13px;color:rgba(247,244,236,0.7);}
.route-quickfacts{display:flex;gap:22px;flex-wrap:wrap;margin-top:22px;}
.route-quickfact{display:flex;flex-direction:column;gap:2px;}
.route-quickfact .v{font-weight:700;font-size:16px;}
.route-quickfact .k{font-size:12px;color:rgba(247,244,236,0.6);text-transform:uppercase;letter-spacing:.04em;}

/* Related routes strip on route pages */
.related-routes{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media (max-width:760px){.related-routes{grid-template-columns:1fr;}}
.related-route-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:10px;
  transition:border-color .15s, transform .15s;
}
.related-route-card:hover{border-color:var(--marigold);transform:translateY(-2px);}
.related-route-card .name{font-weight:600;font-size:14.5px;}
.related-route-card .price{font-weight:700;font-size:14px;color:var(--marigold-deep);}

/* Instagram strip */
.insta-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media (max-width:760px){.insta-strip{grid-template-columns:repeat(2,1fr);}}
.insta-tile{
  position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1/1;
  background:var(--paper-dim);
}
.insta-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s;}
.insta-tile:hover img{transform:scale(1.06);}
.insta-tile-overlay{
  position:absolute;inset:0;background:rgba(27,32,48,0.45);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;
}
.insta-tile:hover .insta-tile-overlay{opacity:1;}
.insta-tile-overlay svg{width:26px;height:26px;color:var(--white);}

.fare-note{
  margin-top:28px;
  background:var(--paper-dim);
  border-radius:var(--radius);
  padding:18px 22px;
  font-size:14px;
  color:var(--ink-soft);
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.fare-note svg{width:19px;height:19px;flex-shrink:0;margin-top:1px;color:var(--marigold-deep);}

/* Per-km vehicle pricing */
.vehicle-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:36px;}
@media (max-width:700px){.vehicle-cards{grid-template-columns:1fr;}}
.vehicle-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-card);
}
.vehicle-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.vehicle-name{font-family:var(--ff-display);font-weight:600;font-size:19px;}
.vehicle-seats{font-size:12.5px;color:var(--slate);margin-top:3px;}
.vehicle-rate{text-align:right;}
.vehicle-rate .amt{font-weight:700;font-size:20px;color:var(--marigold-deep);}
.vehicle-rate .per{font-size:11.5px;color:var(--slate);}
.vehicle-desc{font-size:13.5px;color:var(--slate);line-height:1.55;margin-top:8px;}

/* ===== Booking form section ===== */
.booking-section{
  background:var(--ink);
  color:var(--paper);
}
.booking-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:56px;align-items:start;}
@media (max-width:880px){.booking-grid{grid-template-columns:1fr;gap:36px;}}

.booking-info .sec-eyebrow{color:var(--marigold-light);}
.booking-info .sec-title{color:var(--paper);}
.booking-info .sec-desc{color:rgba(247,244,236,0.7);}
.booking-points{margin-top:28px;display:flex;flex-direction:column;gap:18px;}
.booking-point{display:flex;gap:14px;align-items:flex-start;}
.booking-point-icon{
  width:38px;height:38px;border-radius:10px;background:rgba(217,143,43,0.16);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.booking-point-icon svg{width:18px;height:18px;color:var(--marigold-light);}
.booking-point h4{font-size:15px;font-weight:600;margin-bottom:3px;}
.booking-point p{font-size:13.5px;color:rgba(247,244,236,0.65);line-height:1.5;}

.booking-form-card{
  background:var(--paper);
  border-radius:18px;
  padding:32px;
  box-shadow:0 20px 60px rgba(0,0,0,0.35);
}
.booking-form-card h3{font-family:var(--ff-display);font-size:21px;font-weight:600;color:var(--ink);margin-bottom:4px;}
.booking-form-card .form-sub{font-size:13.5px;color:var(--slate);margin-bottom:22px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
@media (max-width:480px){.form-row{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-soft);}
.field input, .field select, .field textarea{
  border:1.5px solid var(--line);
  border-radius:10px;
  padding:11px 13px;
  font-size:14.5px;
  font-family:inherit;
  color:var(--ink);
  background:var(--white);
  transition:border-color .15s;
}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--marigold);outline:none;}
.field textarea{resize:vertical;min-height:70px;}
.form-submit-row{display:flex;gap:12px;margin-top:6px;flex-wrap:wrap;}
.form-note{font-size:12px;color:var(--slate);margin-top:14px;line-height:1.5;}
.form-status{font-size:13.5px;margin-top:12px;padding:10px 14px;border-radius:8px;display:none;}
.form-status.show{display:block;}
.form-status.success{background:rgba(47,111,78,0.12);color:var(--route-green);}
.form-status.error{background:rgba(200,60,60,0.1);color:#a83232;}

/* ===== Why choose / features ===== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media (max-width:880px){.features-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.features-grid{grid-template-columns:1fr;}}
.feature-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px 24px;
  transition:transform .18s, box-shadow .18s;
}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);}
.feature-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--paper-dim);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.feature-icon svg{width:22px;height:22px;color:var(--marigold-deep);}
.feature-card h3{font-family:var(--ff-display);font-size:17px;font-weight:600;margin-bottom:8px;}
.feature-card p{font-size:14px;color:var(--slate);line-height:1.6;}

/* ===== Destinations (round trip cards) ===== */
.dest-scroller{display:flex;gap:16px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none;}
.dest-scroller::-webkit-scrollbar{display:none;}
.dest-card{
  flex:0 0 auto;width:220px;
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  height:280px;
  background:var(--ink-soft);
  box-shadow:var(--shadow-card);
}
.dest-card-img{position:absolute;inset:0;background-size:cover;background-position:center;}
.dest-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(27,32,48,0) 30%, rgba(27,32,48,0.92) 100%);
}
.dest-card-content{position:absolute;left:0;right:0;bottom:0;padding:18px;color:var(--paper);}
.dest-card-content h4{font-family:var(--ff-display);font-size:18px;font-weight:600;margin-bottom:3px;}
.dest-card-content .price-tag{font-size:13px;color:var(--marigold-light);font-weight:600;}

/* ===== Testimonials ===== */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:880px){.testimonial-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.testimonial-grid{grid-template-columns:1fr;}}
.testimonial-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow-card);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.t-stars{display:flex;gap:2px;}
.t-stars svg{width:15px;height:15px;color:var(--marigold);}
.t-stars svg.empty{color:var(--line);}
.t-quote{font-size:14.5px;color:var(--ink-soft);line-height:1.65;flex-grow:1;}
.t-author{display:flex;align-items:center;gap:10px;}
.t-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--paper-dim);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-weight:600;font-size:15px;color:var(--marigold-deep);
  flex-shrink:0;
}
.t-author-name{font-size:13.5px;font-weight:600;color:var(--ink);}
.t-author-route{font-size:12px;color:var(--slate);}
.testimonial-disclaimer{
  margin-top:24px;font-size:12px;color:var(--slate-light);text-align:center;
}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:32px;}}
.about-visual{
  background:var(--ink);
  border-radius:20px;
  padding:42px 32px;
  position:relative;
  overflow:hidden;
}
.about-visual::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(217,143,43,0.25), transparent 55%);
}
.about-stat{position:relative;z-index:1;color:var(--paper);margin-bottom:26px;}
.about-stat:last-child{margin-bottom:0;}
.about-stat .num{font-family:var(--ff-display);font-size:34px;font-weight:700;color:var(--marigold-light);line-height:1;}
.about-stat .lbl{font-size:13.5px;color:rgba(247,244,236,0.7);margin-top:4px;}
.about-body p{font-size:15.5px;color:var(--slate);line-height:1.75;margin-bottom:16px;}
.about-body strong{color:var(--ink);}

/* ===== FAQ ===== */
.faq-list{max-width:760px;}
.faq-item{border-bottom:1px solid var(--line);padding:20px 0;}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-weight:600;font-size:15.5px;color:var(--ink);
  cursor:pointer;
}
.faq-q svg{width:18px;height:18px;flex-shrink:0;transition:transform .2s;color:var(--marigold-deep);}
.faq-item.open .faq-q svg{transform:rotate(45deg);}
.faq-a{font-size:14.5px;color:var(--slate);line-height:1.65;margin-top:0;max-height:0;overflow:hidden;transition:max-height .25s ease, margin-top .25s ease;}
.faq-item.open .faq-a{margin-top:12px;max-height:300px;}

/* ===== Final CTA ===== */
.final-cta{
  background:linear-gradient(135deg, var(--marigold-deep), var(--marigold));
  color:var(--white);
  text-align:center;
  padding:64px 0;
}
.final-cta h2{font-family:var(--ff-display);font-size:clamp(26px,3.6vw,36px);font-weight:600;margin-bottom:12px;}
.final-cta p{font-size:16px;color:rgba(255,255,255,0.92);margin-bottom:28px;max-width:480px;margin-left:auto;margin-right:auto;}
.final-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.final-cta .btn-primary{background:var(--ink);box-shadow:0 6px 20px rgba(0,0,0,0.25);}
.final-cta .btn-primary:hover{background:var(--ink-soft);}
.final-cta .btn-outline{border-color:var(--white);color:var(--white);}
.final-cta .btn-outline:hover{background:var(--white);color:var(--marigold-deep);}

/* ===== Footer ===== */
footer{background:var(--ink);color:rgba(247,244,236,0.75);padding:56px 0 24px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px;}
@media (max-width:880px){.footer-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.footer-brand img{height:32px;}
.footer-brand-text{font-family:var(--ff-display);font-weight:600;font-size:17px;color:var(--paper);}
.footer-tagline{font-size:13.5px;color:rgba(247,244,236,0.5);margin-bottom:18px;}
.footer-social{display:flex;gap:10px;}
.footer-social a{
  width:34px;height:34px;border-radius:50%;background:rgba(247,244,236,0.08);
  display:flex;align-items:center;justify-content:center;transition:background .15s;
}
.footer-social a:hover{background:var(--marigold);}
.footer-social svg{width:16px;height:16px;}
.footer-col h5{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--paper);margin-bottom:16px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col a{font-size:14px;transition:color .15s;}
.footer-col a:hover{color:var(--marigold-light);}
.footer-bottom{
  border-top:1px solid var(--line-on-dark);
  padding-top:22px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  font-size:12.5px;color:rgba(247,244,236,0.45);
}

/* ===== Sticky mobile contact bar ===== */
.sticky-contact{
  position:fixed;bottom:0;left:0;right:0;z-index:150;
  background:var(--white);
  border-top:1px solid var(--line);
  box-shadow:0 -6px 20px rgba(0,0,0,0.08);
  display:flex;
  padding:10px 14px;
  gap:10px;
}
.sticky-contact a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px;border-radius:12px;font-weight:700;font-size:14.5px;
}
.sticky-contact .call{background:var(--ink);color:var(--paper);}
.sticky-contact .wa{background:#25D366;color:var(--white);}
.sticky-contact svg{width:18px;height:18px;}
@media (min-width:880px){.sticky-contact{display:none;}}
body{padding-bottom:0;}
@media (max-width:879px){body{padding-bottom:70px;}}

/* Desktop floating WhatsApp */
.float-wa{
  position:fixed;bottom:28px;right:28px;z-index:150;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(37,211,102,0.4);
  transition:transform .15s;
}
.float-wa:hover{transform:scale(1.08);}
.float-wa svg{width:28px;height:28px;}
@media (max-width:879px){.float-wa{display:none;}}

/* Mobile nav drawer */
.mobile-drawer{
  position:fixed;inset:0;background:rgba(27,32,48,0.5);z-index:300;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.mobile-drawer.open{opacity:1;pointer-events:all;}
.mobile-drawer-panel{
  position:absolute;top:0;right:0;bottom:0;width:78%;max-width:320px;
  background:var(--paper);
  padding:24px;
  transform:translateX(100%);transition:transform .25s ease;
  display:flex;flex-direction:column;gap:4px;
}
.mobile-drawer.open .mobile-drawer-panel{transform:translateX(0);}
.mobile-drawer-close{align-self:flex-end;padding:8px;margin-bottom:10px;}
.mobile-drawer-panel a{padding:14px 4px;font-size:16px;font-weight:600;border-bottom:1px solid var(--line);}
.mobile-drawer-panel .btn{margin-top:16px;}

.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}


/* ===== Popular Destinations - Horizontal Scroll ===== */
.popular-destinations {
  background: var(--white);
  padding-top: 40px;
  padding-bottom: 40px;
}

.dest-scroll-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
}

.dest-scroll-container {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  overflow-y: visible;
  scroll-behavior: smooth;
  padding: 8px 4px 16px 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--marigold) var(--paper-dim);
  flex: 1;
  -webkit-overflow-scrolling: touch;
}

.dest-scroll-container::-webkit-scrollbar {
  height: 6px;
}

.dest-scroll-container::-webkit-scrollbar-track {
  background: var(--paper-dim);
  border-radius: 10px;
}

.dest-scroll-container::-webkit-scrollbar-thumb {
  background: var(--marigold);
  border-radius: 10px;
}

.dest-scroll-container::-webkit-scrollbar-thumb:hover {
  background: var(--marigold-deep);
}

/* Scroll arrows */
.scroll-arrow {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--white);
  border: 1.5px solid var(--line);
  box-shadow: var(--shadow-card);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  z-index: 5;
  color: var(--ink-soft);
}

.scroll-arrow:hover {
  background: var(--marigold);
  color: var(--white);
  border-color: var(--marigold);
  transform: scale(1.05);
}

.scroll-arrow svg {
  width: 20px;
  height: 20px;
}

.scroll-arrow:active {
  transform: scale(0.92);
}

/* Hide scroll arrows on mobile if needed */
@media (max-width: 600px) {
  .scroll-arrow {
    width: 36px;
    height: 36px;
  }
  .scroll-arrow svg {
    width: 16px;
    height: 16px;
  }
}

/* Individual destination card */
.dest-scroll-card {
  flex: 0 0 auto;
  width: 240px;
  height: 320px;
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  text-decoration: none;
  color: var(--white);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  box-shadow: var(--shadow-card);
  cursor: pointer;
}

.dest-scroll-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 16px 40px rgba(27, 32, 48, 0.18);
}

.dest-scroll-card:active {
  transform: scale(0.96);
}

.dest-scroll-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.4s ease;
}

.dest-scroll-card:hover .dest-scroll-bg {
  transform: scale(1.08);
}

.dest-scroll-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(27, 32, 48, 0.15) 0%, rgba(27, 32, 48, 0.85) 100%);
  z-index: 1;
}

.dest-scroll-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px 18px 18px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.dest-scroll-route {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: rgba(247, 244, 236, 0.75);
  margin-bottom: 2px;
}

.dest-scroll-route .from {
  font-weight: 400;
}

.dest-scroll-route .arrow {
  color: var(--marigold-light);
  font-weight: 300;
}

.dest-scroll-route .to {
  font-weight: 600;
  color: var(--white);
  font-size: 14px;
}

.dest-scroll-price {
  font-family: var(--ff-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--marigold-light);
  letter-spacing: -0.01em;
  line-height: 1.1;
}

.dest-scroll-type {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

.dest-scroll-type .badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dest-scroll-type .badge-oneway {
  background: rgba(217, 143, 43, 0.25);
  color: var(--marigold-light);
  border: 1px solid rgba(217, 143, 43, 0.3);
}

.dest-scroll-type .badge-roundtrip {
  background: rgba(47, 111, 78, 0.3);
  color: #6fcf97;
  border: 1px solid rgba(47, 111, 78, 0.3);
}

.dest-scroll-type .distance {
  font-size: 11px;
  color: rgba(247, 244, 236, 0.55);
  font-weight: 400;
}

/* Responsive card sizes */
@media (max-width: 768px) {
  .dest-scroll-card {
    width: 200px;
    height: 280px;
  }
  .dest-scroll-price {
    font-size: 22px;
  }
  .dest-scroll-route {
    font-size: 12px;
  }
  .dest-scroll-route .to {
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .dest-scroll-card {
    width: 170px;
    height: 250px;
  }
  .dest-scroll-price {
    font-size: 19px;
  }
  .dest-scroll-content {
    padding: 14px 14px 14px;
  }
  .dest-scroll-route {
    font-size: 11px;
    gap: 4px;
  }
  .dest-scroll-route .to {
    font-size: 12px;
  }
}
