/* decorative vertical line */
.hero-line{
  position:absolute;
  left:calc(var(--container-pad) + 240px);
  top:0;bottom:0;
  width:1px;
  background:linear-gradient(to bottom,transparent,rgba(192,57,43,0.5) 30%,rgba(192,57,43,0.5) 70%,transparent);
  display:none;
}
@media(min-width:900px){.hero-line{display:block;}}

.hero-inner{
  position:relative;
  z-index:2;
  width:100%;
}
.hero-content{
  max-width:660px;
  padding:var(--sp-3xl) 0 var(--sp-2xl);
}
.hero-pretitle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--ff-accent);
  font-size:var(--fs-xs);
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:var(--clr-saffron-light);
  margin-bottom:var(--sp-lg);
  opacity:0;
  animation:fadeUp 0.7s 0.3s ease forwards;
}
.hero-pretitle span{width:30px;height:1px;background:var(--clr-saffron-light);}
.hero-title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,6vw,4.5rem);
  font-weight:700;
  color:#fff;
  line-height:1.12;
  margin-bottom:var(--sp-lg);
  opacity:0;
  animation:fadeUp 0.7s 0.5s ease forwards;
}
.hero-title .accent{
  color:var(--clr-red-bright);
  font-style:italic;
}
.hero-desc{
  font-size:var(--fs-md);
  color:rgba(240,236,230,0.78);
  line-height:1.75;
  max-width:520px;
  margin-bottom:var(--sp-xl);
  opacity:0;
  animation:fadeUp 0.7s 0.7s ease forwards;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:var(--sp-xl);
  opacity:0;
  animation:fadeUp 0.7s 0.9s ease forwards;
}
.hero-trust{
  display:flex;
  align-items:center;
  gap:var(--sp-xl);
  flex-wrap:wrap;
  opacity:0;
  animation:fadeUp 0.7s 1.1s ease forwards;
}
.hero-trust-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:var(--fs-sm);
  color:rgba(240,236,230,0.68);
}
.hero-trust-item svg{width:16px;height:16px;fill:none;stroke:var(--clr-red-bright);stroke-width:2;flex-shrink:0;}

/* right panel – quick enquiry */
.hero-panel{
  position:absolute;
  right:100px;top:50%;
  transform:translateY(-50%);
  width:340px;
  background:rgba(22,20,22,0.88);
  backdrop-filter:blur(20px);
  border:1px solid var(--clr-border-red);
  border-right:none;
  border-radius:var(--r-xl);
  padding:var(--sp-xl) var(--sp-lg);
  opacity:0;
  animation:slideLeft 0.8s 1.0s ease forwards;
  z-index:3;
}
@keyframes slideLeft{
  from{opacity:0;transform:translateY(-50%) translateX(30px);}
  to{opacity:1;transform:translateY(-50%) translateX(0);}
}
.hero-panel-title{
  font-family:var(--ff-display);
  font-size:var(--fs-lg);
  color:#fff;
  font-weight:700;
  margin-bottom:4px;
}
.hero-panel-sub{
  font-size:var(--fs-xs);
  color:var(--clr-text-muted);
  margin-bottom:var(--sp-lg);
}
.hero-panel .form-group{margin-bottom:10px;}
@media(max-width:1000px){
  .hero-panel{display:none;}
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(24px);}
  to{opacity:1;transform:translateY(0);}
}

/* ── INTRO SECTION ── */
.intro-section{
  background:var(--clr-ocean-2);
  border-bottom:1px solid var(--clr-border);
}
.intro-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-3xl);
  align-items:center;
}
.intro-img-wrap{
  position:relative;
  border-radius:var(--r-xl);
  overflow:hidden;
}
.intro-img-wrap img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  display:block;
}
.intro-img-badge{
  position:absolute;
  bottom:var(--sp-lg);
  left:var(--sp-lg);
  background:var(--clr-red);
  color:#fff;
  border-radius:var(--r-lg);
  padding:10px 16px;
  font-family:var(--ff-accent);
  font-size:var(--fs-xs);
  letter-spacing:0.08em;
}
.intro-img-badge strong{
  display:block;
  font-size:var(--fs-xl);
  font-family:var(--ff-display);
  letter-spacing:0;
}
.intro-features{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:var(--sp-lg);
}
@media(max-width:768px){
  .intro-grid{grid-template-columns:1fr;}
}

/* ── HOW IT WORKS ── */
.how-section{background:var(--clr-ocean);}
.steps-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  position:relative;
  margin-top:var(--sp-2xl);
  background:var(--clr-ocean-2);
  border:1px solid var(--clr-border);
  border-radius:var(--r-xl);
  padding: 50px;
}
.steps-row::before{
  content:'';
  position:absolute;
  top:32px;left:12.5%;right:12.5%;
  height:1px;
  padding: 50px;
  background:linear-gradient(90deg,transparent,var(--clr-border-red) 20%,var(--clr-border-red) 80%,transparent);
}
.step-item{
  text-align:center;
  padding:0 var(--sp-md);
  position:relative;
}
.step-num{
  width:64px;height:64px;
  border-radius:50%;
  background:var(--clr-ocean-card);
  border:2px solid var(--clr-border-red);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto var(--sp-md);
  font-family:var(--ff-accent);
  font-size:var(--fs-lg);
  font-weight:700;
  color:var(--clr-red-bright);
  position:relative;
  z-index:1;
}
.step-title{
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  font-weight:600;
  color:#d96535;
  margin-bottom:6px;
}
.step-desc{font-size:var(--fs-sm);color:var(--clr-text-muted);line-height:1.6;}
@media(max-width:700px){
  .steps-row{grid-template-columns:1fr 1fr;gap:var(--sp-xl);}
  .steps-row::before{display:none;}
}

/* ── DESTINATIONS ── */
.dest-section{background:var(--clr-ocean-2);}
.dest-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-lg);
  margin-top:var(--sp-2xl);
}
.dest-card{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  aspect-ratio:4/3;
  cursor:pointer;
  display:block;
}
.dest-card img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 0.6s ease;
}
.dest-card:hover img{transform:scale(1.08);}
.dest-card-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(14,10,10,0.88) 0%,rgba(0,0,0,0.10) 60%);
  transition:background 0.4s;
}
.dest-card:hover .dest-card-overlay{
  background:linear-gradient(to top,rgba(140,30,18,0.75) 0%,rgba(0,0,0,0.15) 60%);
}
.dest-card-body{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:var(--sp-lg);
}
.dest-card-region{
  font-family:var(--ff-accent);
  font-size:var(--fs-xs);
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--clr-saffron-light);
  margin-bottom:4px;
}
.dest-card-name{
  font-family:var(--ff-display);
  font-size:var(--fs-xl);
  font-weight:700;
  color:#fff;
}
.dest-card-count{
  font-size:var(--fs-xs);
  color:rgba(255,255,255,0.60);
  margin-top:4px;
}
/* big feature card */
.dest-card.featured{
  grid-column:span 2;
  aspect-ratio:16/9;
}
@media(max-width:900px){
  .dest-grid{grid-template-columns:1fr 1fr;}
  .dest-card.featured{grid-column:span 2;}
}
@media(max-width:560px){
  .dest-grid{grid-template-columns:1fr;}
  .dest-card.featured{grid-column:auto;aspect-ratio:4/3;}
}

/* ── PACKAGES PREVIEW ── */
.pkg-section{background:var(--clr-ocean);}
.pkg-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-xl);
  margin-top:var(--sp-2xl);
}
@media(max-width:900px){.pkg-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:580px){.pkg-grid{grid-template-columns:1fr;}}

/* ── CARS PREVIEW ── */
.cars-section{
  background:var(--clr-ocean-2);
}
.cars-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--sp-lg);
  margin-top:var(--sp-2xl);
}
.car-card{
  background:var(--clr-ocean);
  border:1px solid var(--clr-border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:all var(--tr-base);
  text-align:center;
}
.car-card:hover{border-color:var(--clr-border-red);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.car-card-img{
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
}
.car-card-body{padding:var(--sp-md);}
.car-card-name{
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  font-weight:700;
  color:#d96535;
  margin-bottom:4px;
}
.car-card-seats{
  font-size:var(--fs-xs);
  color:var(--clr-text-muted);
  margin-bottom:var(--sp-md);
}
@media(max-width:900px){.cars-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.cars-grid{grid-template-columns:1fr 1fr;gap:var(--sp-md);}}

/* ── TESTIMONIALS ── */
.testi-section{background:var(--clr-ocean);}
.testi-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-xl);
  margin-top:var(--sp-2xl);
}
.testi-card{
  background:var(--clr-ocean-card);
  border:1px solid var(--clr-border);
  border-radius:var(--r-lg);
  padding:var(--sp-xl);
  position:relative;
  transition:border-color var(--tr-base);
}
.testi-card:hover{border-color:var(--clr-border-red);}
.testi-quote{
  position:absolute;
  top:var(--sp-lg);right:var(--sp-lg);
  font-family:var(--ff-display);
  font-size:3rem;
  color:var(--clr-red);
  line-height:1;
  opacity:0.25;
}
.testi-stars{
  display:flex;gap:3px;margin-bottom:var(--sp-md);
}
.testi-stars svg{width:14px;height:14px;fill:var(--clr-saffron-light);}
.testi-text{
  font-size:var(--fs-sm);
  color:var(--clr-text-light);
  line-height:1.75;
  margin-bottom:var(--sp-md);
  font-style:italic;
}
.testi-author{
  display:flex;align-items:center;gap:10px;
  border-top:1px solid var(--clr-border);
  padding-top:var(--sp-md);
}
.testi-avatar{
  width:38px;height:38px;
  border-radius:50%;
  background:var(--clr-red);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-accent);
  font-size:var(--fs-sm);
  font-weight:700;
  color:#fff;
  flex-shrink:0;
}
.testi-name{
  font-size:var(--fs-sm);font-weight:600;color:#fff;line-height:1.2;
}
.testi-from{font-size:var(--fs-xs);color:var(--clr-text-muted);}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:580px){.testi-grid{grid-template-columns:1fr;}}

/* ── CTA BAND ── */
.cta-band{
  background:var(--clr-red-deep);
  position:relative;
  overflow:hidden;
  padding:var(--sp-2xl) 0;
}
.cta-band::before{
  content:'';
  position:absolute;
  top:-60px;right:-60px;
  width:320px;height:320px;
  border-radius:50%;
  background:rgba(192,57,43,0.25);
  pointer-events:none;
}
.cta-band-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--sp-xl);
  flex-wrap:wrap;
}
.cta-band-text h2{
  font-family:var(--ff-display);
  font-size:clamp(var(--fs-xl),3vw,var(--fs-2xl));
  color:#fff;font-weight:700;margin-bottom:6px;
}
.cta-band-text p{font-size:var(--fs-sm);color:rgba(255,255,255,0.75);}
.cta-band-actions{display:flex;gap:12px;flex-wrap:wrap;}