/* =========================
   Maison Atlas — Luxury CSS
   ========================= */

:root{
  --bg:#050606;
  --card:rgba(255,255,255,.05);
  --card2:rgba(255,255,255,.035);
  --text:#f3f0e8;
  --muted:rgba(243,240,232,.72);
  --line:rgba(255,255,255,.12);
  --gold:#c9a227;
  --gold2:#e7c85f;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:
    radial-gradient(1000px 600px at 15% 10%, rgba(201,162,39,.14), transparent 65%),
    radial-gradient(900px 700px at 85% 20%, rgba(231,200,95,.10), transparent 60%),
    radial-gradient(700px 500px at 50% 85%, rgba(255,255,255,.06), transparent 70%),
    var(--bg);
  line-height:1.6;
}

a{color:var(--text);text-decoration:none}
a:hover{color:var(--gold2)}
img{max-width:100%;display:block}

.container{
  width: min(1400px, 100%);
  margin: 0 auto;
  padding: 0 28px;
}

.container.full{
  width: 100%;
  max-width: none;
  padding: 0;
}

/* ===== NAV ===== */
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 2px 18px;
  border-bottom:1px solid var(--line);
}
.brand{
  font-weight:1000;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:14px;
  opacity:.95;
}
.nav a{
  margin-left:14px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.nav a:hover{
  border-color:var(--line);
  background:rgba(255,255,255,.03);
}

/* ===== TYPO ===== */
.kicker{
  color:rgba(243,240,232,.62);
  letter-spacing:.25em;
  text-transform:uppercase;
  font-size:11px;
}
.h1{
  font-size:44px;
  line-height:1.08;
  font-weight:1000;
  margin:10px 0 0;
}
.h2{
  font-size:22px;
  font-weight:1000;
  margin:0;
}
.lead{
  color:var(--muted);
  font-size:16px;
  margin:10px 0 0;
}
.p{color:var(--muted);margin:8px 0}

/* ===== CARD / GRID ===== */
.card{
  background:linear-gradient(180deg, var(--card), var(--card2));
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  box-shadow: var(--shadow);
}
.grid{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(3, 1fr);
}
@media(max-width:900px){
  .grid{grid-template-columns:1fr}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid transparent;
  background:linear-gradient(180deg, var(--gold2), var(--gold));
  color:#111;
  font-weight:1000;
  cursor:pointer;
}
.btn:hover{filter:brightness(1.03)}
.btn:active{transform:translateY(1px)}
.btnFull{width:100%}

/* ===== FORMS ===== */
.input{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.25);
  color:var(--text);
  margin-top:10px;
}
textarea.input{min-height:120px;resize:vertical}

/* ===== FOOTER ===== */
.footer{
  margin:28px 0 10px;
  color:rgba(243,240,232,.55);
  font-size:13px;
  text-align:center;
}

/* ===========================
   SERVICE DETAIL LUXURY LAYOUT
   =========================== */
.page{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:18px;
  align-items:start;
}
@media(max-width:900px){ .page{grid-template-columns:1fr} }

.heroCard{
  padding:20px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}

.metaRow{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:12px;
}
.pill{
  border:1px solid var(--line);
  padding:8px 12px;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  background:rgba(255,255,255,.03);
}
.pill strong{color:var(--text);font-weight:1000}

/* gallery like TourRadar */
.galleryGrid{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:12px;
  margin-top:14px;
}
.galleryGrid img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:14px;
  border:1px solid var(--line);
}
.galleryStack{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:12px;
}
@media(max-width:900px){
  .galleryGrid{grid-template-columns:1fr}
  .galleryStack{grid-template-rows:none;grid-template-columns:1fr 1fr}
}

.section{margin-top:16px}
.tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
  margin-top:14px;
}
.tabBtn{
  cursor:pointer;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
}
.tabBtn.active{
  background:linear-gradient(180deg, var(--gold2), var(--gold));
  color:#111;
  border-color:transparent;
}
.tabPanel{display:none}
.tabPanel.active{display:block}

/* itinerary cards */
.itinItem{
  display:grid;
  grid-template-columns:70px 1fr;
  gap:12px;
  padding:14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  margin-bottom:10px
}
.dayBadge{
  width:70px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(201,162,39,.15);
  border:1px solid rgba(201,162,39,.35);
  color:var(--text);
  font-weight:1000;
}
.smallMuted{color:var(--muted);font-size:13px;line-height:1.6}

/* highlights list */
.listCheck{margin:0;padding-left:18px}
.listCheck li{margin:6px 0;color:var(--muted)}
.listCheck li::marker{color:var(--gold)}

/* FAQ accordion */
.accordion{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.03)
}
.accItem{border-top:1px solid var(--line)}
.accItem:first-child{border-top:none}
.accBtn{
  width:100%;
  text-align:left;
  padding:14px;
  background:transparent;
  border:0;
  color:var(--text);
  font-weight:1000;
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
}
.accBody{
  display:none;
  padding:0 14px 14px;
  color:var(--muted);
}
.accItem.open .accBody{display:block}
.chev{opacity:.7}

/* sticky booking box */
.stickyCard{
  position:sticky;
  top:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:16px;
  box-shadow: var(--shadow);
}
.priceBig{
  font-size:30px;
  font-weight:1000;
  margin:8px 0;
}
.hr{height:1px;background:var(--line);margin:14px 0}

/* TourRadar-style itinerary details */
.itinMeta{
  display:flex; gap:14px; flex-wrap:wrap;
  margin-top:10px;
}
.itinMeta .chip{
  display:flex; align-items:center; gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:13px;
}
.icon{
  width:18px; height:18px;
  display:inline-grid; place-items:center;
  border-radius:6px;
  background:rgba(201,162,39,.15);
  border:1px solid rgba(201,162,39,.35);
  color:var(--text);
  font-weight:1000;
}
.hero{
  width:100%;
  height: 62vh;
  min-height: 420px;
  max-height: 720px;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}

.hero img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}

.hero:after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75));
}

.heroInner{
  position:absolute; inset:0;
  z-index:2;
  display:flex;
  align-items:flex-end;
  padding: 42px;
}

.heroCard{
  max-width: 980px;
  background: rgba(12,12,12,.55);
  border:1px solid var(--line);
  border-radius:18px;
  padding:22px 22px;
  backdrop-filter: blur(10px);
}
/* ===== TourRadar-style itinerary ===== */
.itinCard{
  display:grid;
  grid-template-columns: 90px 1fr;
  gap:14px;
  padding:16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  margin-top:12px;
}

.itinTitle{font-weight:1000;font-size:18px}
.itinTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}

.itinMeta{
  display:flex;align-items:center;gap:8px;
  color:var(--muted);
  font-size:13px;
  white-space:nowrap;
}

.itinText{color:var(--muted);margin-top:10px}

.itinRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.chip{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:13px;
}

.ico{
  width:22px;height:22px;
  border-radius:7px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(201,162,39,.14);
  border:1px solid rgba(201,162,39,.25);
  color:var(--text);
  font-size:12px;
}

.itinSubTitle{
  margin-top:12px;
  font-weight:1000;
  display:flex;
  align-items:center;
  gap:8px;
}

.itinList{margin:8px 0 0; padding-left:0; list-style:none}
.itinList li{
  display:flex; gap:10px;
  padding:6px 0;
  color:var(--muted);
}
.tick{
  width:18px;height:18px;
  border-radius:6px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(201,162,39,.14);
  border:1px solid rgba(201,162,39,.25);
  color:var(--text);
  font-weight:1000;
  flex:0 0 auto;
}
/* ===== TourRadar-like Availability UI (Luxury) ===== */
.availabilitySection{
  margin-top:24px;
  padding:20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.availabilitySection h2{
  margin:0 0 14px 0;
  font-size:24px;
  font-weight:900;
}

.availBar{
  display:flex;
  gap:14px;
  align-items:flex-end;
  flex-wrap:wrap;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.availBar label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin-bottom:6px;
}

.availBar .input{
  width:260px;
  max-width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
  outline:none;
}

.travellersSummary{
  min-width:220px;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
}

.btnGold{
  padding:12px 16px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  background:linear-gradient(180deg,#f1d36a,#c99a27);
  color:#111;
  font-weight:900;
}

.priceBreakdownCard{
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.priceBreakdownCard h3{
  margin:0 0 10px 0;
  font-size:16px;
  font-weight:900;
}

.pbRow{
  display:flex;
  justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:14px;
}

.pbTotal{
  display:flex;
  justify-content:space-between;
  padding-top:10px;
  margin-top:8px;
  font-size:18px;
  font-weight:900;
}

.sidePriceBox .dealBadge,
.dealBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(241,211,106,.35);
  background:rgba(241,211,106,.12);
  color:#f1d36a;
  font-weight:900;
  font-size:12px;
  margin-bottom:10px;
}

.sideControls label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin:10px 0 6px;
}

.travRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.stepper{
  display:flex;
  align-items:center;
  gap:10px;
}

.stepBtn{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  color:#fff;
  font-size:18px;
  cursor:pointer;
}

.totalLine{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
}
.smallMuted{font-size:12px;opacity:.7;}
.priceWas{opacity:.6;text-decoration:line-through;margin-bottom:6px;}
.priceNow{font-size:28px;font-weight:1000;line-height:1;}
.perPerson{font-size:13px;opacity:.75;margin-left:6px;}
/* ===== TourRadar-like Availability UI (Luxury) ===== */
.availabilitySection{
  margin-top:24px;
  padding:20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.availabilitySection h2{
  margin:0 0 14px 0;
  font-size:24px;
  font-weight:900;
}

.availBar{
  display:flex;
  gap:14px;
  align-items:flex-end;
  flex-wrap:wrap;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.availBar label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin-bottom:6px;
}


.availBar .input{
  width:260px;
  max-width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
  outline:none;
}

.travellersSummary{
  min-width:220px;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
}

.btnGold{
  padding:12px 16px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  background:linear-gradient(180deg,#f1d36a,#c99a27);
  color:#111;
  font-weight:900;
}

.priceBreakdownCard{
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.priceBreakdownCard h3{
  margin:0 0 10px 0;
  font-size:16px;
  font-weight:900;
}

.pbRow{
  display:flex;
  justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:14px;
}

.pbTotal{
  display:flex;
  justify-content:space-between;
  padding-top:10px;
  margin-top:8px;
  font-size:18px;
  font-weight:900;
}

.sidePriceBox .dealBadge,
.dealBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(241,211,106,.35);
  background:rgba(241,211,106,.12);
  color:#f1d36a;
  font-weight:900;
  font-size:12px;
  margin-bottom:10px;
}

.sideControls label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin:10px 0 6px;
}

.travRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.stepper{
  display:flex;
  align-items:center;
  gap:10px;
}

.stepBtn{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  color:#fff;
  font-size:18px;
  cursor:pointer;
}

.totalLine{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
}
.smallMuted{font-size:12px;opacity:.7;}
.priceWas{opacity:.6;text-decoration:line-through;margin-bottom:6px;}
.priceNow{font-size:28px;font-weight:1000;line-height:1;}
.perPerson{font-size:13px;opacity:.75;margin-left:6px;}
.hero { position: relative; overflow: hidden; }

.hero{
  position: relative !important;
  height: 600px !important;      /* try 520 / 600 / 700 */
  overflow: hidden !important;
}

.heroMedia{
  position:absolute !important;
  inset:0 !important;
}

.heroMedia img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  display:block !important;
}
/* ===== Related Tours (MATCHES maRel1 / maRel__grid) ===== */

.maRel1{
  margin-top: 60px;
}

.maRel__title{
  font-size: 28px;
  font-weight: 800;
  margin: 0 0 22px;
}

/* GRID */
.maRel__grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch;
}

@media (max-width: 1100px){
  .maRel__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px){
  .maRel__grid{
    grid-template-columns: 1fr !important;
  }
}

/* ===== Card (hpCard) ===== */

.hpCard{
  display:block !important;
  text-decoration:none !important;
  color:#fff !important;
  border-radius:24px !important;
  overflow:hidden !important;
  background: rgba(15,15,15,.85) !important;
  border: 1px solid rgba(212,175,55,.18) !important;
  box-shadow: 0 20px 70px rgba(0,0,0,.35) !important;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
}

.hpCard:hover{
  transform: translateY(-6px) !important;
  box-shadow: 0 28px 85px rgba(0,0,0,.45) !important;
  border-color: rgba(212,175,55,.35) !important;
}

.hpCard__media{
  position:relative !important;
  height: 210px !important;
  background:#111 !important;
}

.hpCard__media img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
  transition: transform .4s ease !important;
}

.hpCard:hover .hpCard__media img{
  transform: scale(1.07) !important;
}

.hpCard__overlay{
  position:absolute !important;
  inset:0 !important;
  background:
    radial-gradient(circle at 50% 20%, rgba(255,215,140,.20), transparent 60%),
    linear-gradient(to top, rgba(0,0,0,.85), rgba(0,0,0,.15)) !important;
}

.hpCard__price{
  position:absolute !important;
  left:18px !important;
  bottom:18px !important;
  padding:10px 14px !important;
  border-radius:999px !important;
  background: rgba(0,0,0,.75) !important;
  font-weight:800 !important;
  font-size:13px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: blur(6px) !important;
}

.hpCard__body{
  padding: 18px 18px 20px !important;
}

.hpCard__title{
  font-weight: 850 !important;
  line-height: 1.2 !important;
  margin-bottom: 8px !important;

  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  min-height: 40px !important;
}
.hpCard__desc{
  font-size: 13px !important;
  color: rgba(255,255,255,.78) !important;
  line-height: 1.5 !important;
  margin-bottom: 14px !important;

  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  min-height: 36px !important;
}

.hpCard__pills{
  display:flex !important;
  gap:8px !important;
  flex-wrap:wrap !important;
  margin-bottom: 14px !important;
}

.hpPill{
  font-size: 12px !important;
  padding: 7px 11px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.95) !important;
}
.heroCard{
  position: absolute;
  left: 60px;
  bottom: 60px;
  z-index: 5;
  max-width: 820px;
  padding: 28px 34px;
  border-radius: 22px;
  background: rgba(0,0,0,.35);
  box-shadow: 0 25px 70px rgba(0,0,0,.55);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.08);
}

.heroCard .kicker{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .75;
  color: #f3c06b;
  margin-bottom: 14px;
  font-weight: 600;
}

.heroCard .hero-title{
  font-size: clamp(24px, 2.5vw, 36px);
  font-weight: 600;
  line-height: 1.2;
  margin: 0;
  color: #ffffff;
}


.heroCard .lead{
  margin-top: 18px;
  font-size: 16px;
  color: rgba(255,255,255,.85);
  max-width: 650px;
  line-height: 1.6;
}
.heroCard .hero-title::after{
  content:"";
  display:block;
  width: 70px;
  height: 3px;
  margin-top: 18px;
  background: linear-gradient(90deg, #e7c27a, #d4a64f);
  border-radius: 2px;
}
.service-tabs { margin-top: 18px; }

.tabs-nav{
  display:flex;
  gap:10px;
  margin-bottom:14px;
}

.tab-btn{
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color:#fff;
  padding:8px 14px;
  border-radius:10px;
  cursor:pointer;
  font-weight:700;
}

.tab-btn.active{
  background:#c9a227;
  border-color:#c9a227;
  color:#111;
}

.tab-panel{ display:none; }
.tab-panel.active{ display:block; }
.maRel__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:24px;
}
.maCard{
  border-radius:24px;
  overflow:hidden;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.maCard__media{ position:relative; height:180px; overflow:hidden; }
.maCard__img{ width:100%; height:100%; object-fit:cover; display:block; }
.maCard__badge{
  position:absolute; left:16px; top:16px;
  padding:8px 12px; border-radius:999px;
  background: rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.15);
}
.maCard__body{ padding:18px; }
.maCard__cta{
  margin-top:14px;
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  background:#c9a227;
  color:#111;
  font-weight:700;
}
/* Related tours - normalize card images */
.maCard__media{
  height: 220px;
  overflow: hidden;
  border-radius: 24px;
}

.maCard__img{
  width: 100%;
  height: 100%;
  object-fit: cover;  /* crop portrait images */
  display: block;
}
/* Related Tours - force same card image size */
.maRel__imgWrap{
  height: 180px;         /* choose 160-220 if you want */
  overflow: hidden;
  border-radius: 18px;
}

.maRel__imgWrap img{
  width: 100%;
  height: 100%;
  object-fit: cover;     /* IMPORTANT: prevents tall portrait images */
  display: block;
}
/* ===== Related Tours (stable card UI) ===== */
.relatedTours { margin: 40px 0 10px; }
.relatedTours__title { font-size: 28px; margin: 0 0 18px; }

.relatedTours__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.relatedCard{
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.relatedCard__imgWrap{
  display:block;
  position:relative;
  height: 210px;
  overflow:hidden;
}

.relatedCard__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.relatedCard__price{
  position:absolute;
  left:14px;
  top:14px;
  padding:6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 12px;
}

.relatedCard__body{
  padding: 14px 14px 16px;
}

.relatedCard__h3{
  font-size: 16px;
  margin: 0 0 8px;
  line-height: 1.3;
}
.relatedCard__h3 a{ text-decoration:none; }

.relatedCard__p{
  margin: 0 0 12px;
  opacity: .85;
  font-size: 13px;
  line-height: 1.45;
}

.relatedCard__btn{
  display:inline-block;
  padding: 10px 14px;
  border-radius: 999px;
  background: #c9a227;
  color: #111;
  font-weight: 700;
  text-decoration:none;
}
.relatedCard__btn:hover{ filter: brightness(1.05); }

@media (max-width: 1000px){
  .relatedTours__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .relatedTours__grid{ grid-template-columns: 1fr; }
  .relatedCard__imgWrap{ height: 190px; }
}
.article-hero {
  position: relative;
  padding: 40px;
  border-radius: 24px;
  background: linear-gradient(
      135deg,
      rgba(214,170,67,0.15),
      rgba(20,20,20,0.8)
  );
  border: 1px solid rgba(214,170,67,.25);
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
}

.hero-title {
  font-size: 58px;
  font-weight: 800;
  letter-spacing: -1px;
}
.prose {
  font-size: 18px;
  line-height: 2;
  max-width: 750px;
}

.content-card {
  padding: 50px;
  background: rgba(22,22,22,.8);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.06);
}

.side-box {
  background: rgba(30,30,30,.7);
  border: 1px solid rgba(214,170,67,.15);
}
.article-hero {
  background: none;
  border: none;
  box-shadow: none;
  padding: 60px 0 40px;
}

.hero-title {
  font-size: 64px;
  font-weight: 800;
  letter-spacing: -2px;
  margin-bottom: 20px;
}

.article-hero .meta-line {
  font-size: 13px;
  opacity: .6;
  margin-bottom: 14px;
}
.hero-title::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  margin-top: 18px;
  background: linear-gradient(90deg, #d6aa43, transparent);
  border-radius: 2px;
}
/* ========================================
   HOMEPAGE CLEAN REWRITE
   Scope: body.home-page only
   ======================================== */

body.home-page{
    background:#ffffff;
    color:#1f1a17;
}

/* ---------- Layout ---------- */

body.home-page .home-shell{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    padding:0 24px;
}

body.home-page .home-scale{
    zoom:1 !important;
}

body.home-page .home-section,
body.home-page .home-destinations,
body.home-page .home-featured-tours,
body.home-page .home-why-us,
body.home-page .home-reviews,
body.home-page .home-blog,
body.home-page .home-final-cta{
    padding:88px 0;
}

@media (max-width: 700px){
    body.home-page .home-section,
    body.home-page .home-destinations,
    body.home-page .home-featured-tours,
    body.home-page .home-why-us,
    body.home-page .home-reviews,
    body.home-page .home-blog,
    body.home-page .home-final-cta{
        padding:64px 0;
    }

    body.home-page .home-shell{
        padding:0 20px;
    }
}

/* ---------- Section headings ---------- */

body.home-page .home-section-head{
    margin-bottom:34px;
}

body.home-page .home-section-head--row{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:20px;
}

body.home-page .home-kicker,
body.home-page .home-section-kicker{
    display:inline-block;
    margin:0 0 10px;
    color:#b27a3d;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    line-height:1;
}

body.home-page .home-section-title{
    margin:0;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:clamp(34px, 4vw, 56px);
    line-height:1.08;
    letter-spacing:-0.03em;
    font-weight:600;
    max-width:920px;
}

body.home-page .home-section-subtitle{
    margin:12px 0 0;
    color:#62584f;
    font-size:17px;
    line-height:1.8;
    max-width:720px;
}

@media (max-width: 700px){
    body.home-page .home-section-head--row{
        flex-direction:column;
        align-items:flex-start;
    }

    body.home-page .home-section-title{
        font-size:clamp(30px, 8vw, 42px);
    }

    body.home-page .home-section-subtitle{
        font-size:16px;
    }
}

/* ---------- Buttons ---------- */

body.home-page .home-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:52px;
    padding:0 22px;
    border-radius:999px;
    text-decoration:none;
    font-size:15px;
    font-weight:600;
    transition:transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

body.home-page .home-btn:hover{
    transform:translateY(-2px);
}

body.home-page .home-btn--primary{
    background:#ffffff;
    border:1px solid #ffffff;
    color:#1f1a17;
}

body.home-page .home-btn--secondary{
    background:rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.28);
    color:#ffffff;
}

body.home-page .home-btn--dark{
    background:#1f1a17;
    border:1px solid #1f1a17;
    color:#ffffff;
}

body.home-page .home-btn--light{
    background:#ffffff;
    border:1px solid #e6ddd0;
    color:#1f1a17;
}

/* ---------- Hero ---------- */

body.home-page .home-hero{
    position:relative;
    width:100vw;
    min-height:680px;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    overflow:hidden;
    background:#1f1a17;
    padding:0;
}

body.home-page .home-hero__slider{
    position:relative;
    min-height:680px;
}

body.home-page .home-hero__slide{
    position:absolute;
    inset:0;
    background-size:cover !important;
    background-position:center center !important;
    background-repeat:no-repeat !important;
    opacity:0;
    visibility:hidden;
    transform:scale(1.08);
    transition:opacity 1s ease, transform 6s ease;
}

body.home-page .home-hero__slide--active{
    opacity:1;
    visibility:visible;
    transform:scale(1);
}

body.home-page .home-hero__overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(
        90deg,
        rgba(17,12,10,0.56) 0%,
        rgba(17,12,10,0.34) 40%,
        rgba(17,12,10,0.14) 72%,
        rgba(17,12,10,0.10) 100%
    );
    z-index:1;
}

body.home-page .home-hero__content-wrap{
    position:relative;
    z-index:2;
    min-height:680px;
    display:flex;
    align-items:center;
}

body.home-page .home-hero__content{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    padding:40px 24px;
    color:#ffffff;
}

body.home-page .home-hero__eyebrow{
    display:inline-flex;
    align-items:center;
    min-height:38px;
    padding:0 16px;
    border-radius:999px;
    background:rgba(255,255,255,0.14);
    border:1px solid rgba(255,255,255,0.26);
    color:#ffffff;
    font-size:12px;
    font-weight:700;
    letter-spacing:.12em;
    text-transform:uppercase;
}

body.home-page .home-hero__title{
    margin:20px 0 12px;
    max-width:860px;
    font-family:"Playfair Display", serif;
    font-size:clamp(48px, 7vw, 88px);
    line-height:.98;
    letter-spacing:-0.05em;
    font-weight:600;
    color:#ffffff;
}

body.home-page .home-hero__subtitle{
    margin:0;
    max-width:660px;
    color:rgba(255,255,255,0.94);
    font-size:18px;
    line-height:1.75;
}

body.home-page .home-hero__actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:28px;
}

body.home-page .home-hero__nav{
    display:none !important;
}

@media (max-width: 768px){
    body.home-page .home-hero,
    body.home-page .home-hero__slider,
    body.home-page .home-hero__content-wrap{
        min-height:580px;
    }

    body.home-page .home-hero__title{
        font-size:clamp(36px, 10vw, 54px);
        line-height:1.04;
    }

    body.home-page .home-hero__subtitle{
        font-size:16px;
    }
}
body.home-page .home-hero{
    position:relative;
    overflow:hidden;
}

body.home-page .home-hero__slider{
    position:relative;
    min-height:720px;
}

body.home-page .home-hero__slide{
    position:absolute;
    inset:0;
    opacity:0;
    visibility:hidden;
    transition:opacity .9s ease, transform 6s ease;
    transform:scale(1.03);
}

body.home-page .home-hero__slide--active{
    opacity:1;
    visibility:visible;
    transform:scale(1);
    z-index:1;
}
body.home-page .home-hero__slide::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(
        180deg,
        rgba(15, 12, 10, 0.28) 0%,
        rgba(15, 12, 10, 0.42) 45%,
        rgba(15, 12, 10, 0.58) 100%
    );
    z-index:1;
}
body.home-page .home-hero__slide img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
/* ---------- Trust bar ---------- */

body.home-page .home-trust{
    padding:14px 0 !important;
    background:rgba(255,255,255,0.94);
    border-top:1px solid rgba(184,138,68,0.10);
    border-bottom:1px solid rgba(184,138,68,0.10);
}

body.home-page .home-trust__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    padding:0 !important;
}

body.home-page .home-trust__rating{
    display:flex;
    align-items:center;
    gap:10px;
    white-space:nowrap;
}

body.home-page .home-trust__stars{
    color:#b88a44;
    font-size:14px;
    letter-spacing:2px;
    line-height:1;
}

body.home-page .home-trust__label{
    color:#1f1a17;
    font-size:15px;
    font-weight:600;
}

body.home-page .home-trust__items{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:0;
    color:#6a6258;
    font-size:14px;
}

body.home-page .home-trust__items span{
    position:relative;
    padding:0 18px;
    line-height:1.2;
}

body.home-page .home-trust__items span:not(:last-child)::after{
    content:"";
    position:absolute;
    right:0;
    top:50%;
    width:1px;
    height:14px;
    background:rgba(184,138,68,0.18);
    transform:translateY(-50%);
}

@media (max-width: 900px){
    body.home-page .home-trust__inner{
        flex-direction:column;
        align-items:flex-start;
        gap:10px;
    }

    body.home-page .home-trust__items span{
        padding:0 14px 0 0;
        margin-right:14px;
    }

    body.home-page .home-trust__items span::after{
        display:none;
    }
}

/* ---------- Travel styles ---------- */

body.home-page .home-travel-styles{
    background:#ffffff;
}

body.home-page .home-style-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:18px;
    align-items:stretch;
}

body.home-page .home-style-card{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    min-height:124px;
    padding:24px 26px;
    border:1px solid #ece4d8;
    border-radius:22px;
    background:#ffffff;
    text-decoration:none;
    box-shadow:0 10px 24px rgba(31,26,23,0.04);
    transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

body.home-page .home-style-card:hover{
    transform:translateY(-4px);
    box-shadow:0 18px 38px rgba(31,26,23,0.08);
    border-color:#e2d6c6;
}

body.home-page .home-style-icon{
    font-size:18px;
    line-height:1;
    margin-bottom:10px;
}

body.home-page .home-style-card h3{
    margin:0;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:22px;
    line-height:1.2;
    letter-spacing:-0.02em;
    font-weight:600;
}

@media (max-width: 1000px){
    body.home-page .home-style-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px){
    body.home-page .home-style-grid{
        grid-template-columns:1fr;
    }

    body.home-page .home-style-card{
        min-height:104px;
        padding:22px 22px;
    }
}



/* ---------- Destinations ---------- */

body.home-page .home-destinations{
    background:#ffffff;
}

body.home-page .home-destination-card{
    position:relative;
    flex:0 0 340px;
    height:430px;
    border-radius:24px;
    overflow:hidden;
    text-decoration:none;
    color:#ffffff;
    box-shadow:0 14px 32px rgba(31,26,23,0.10);
    transition:transform .28s ease, box-shadow .28s ease;
}

body.home-page .home-destination-card:hover{
    transform:translateY(-4px);
    box-shadow:0 22px 44px rgba(31,26,23,0.14);
}

body.home-page .home-destination-card__image{
    position:absolute;
    inset:0;
    background-size:cover;
    background-position:center;
    transition:transform .45s ease;
}

body.home-page .home-destination-card:hover .home-destination-card__image{
    transform:scale(1.05);
}

body.home-page .home-destination-card__overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.08) 18%, rgba(0,0,0,0.60) 100%);
}

body.home-page .home-destination-card__content{
    position:absolute;
    left:24px;
    right:24px;
    bottom:22px;
    z-index:2;
}

body.home-page .home-destination-card__content h3{
    margin:0 0 8px;
    font-family:"Playfair Display", serif;
    font-size:30px;
    line-height:1.05;
    font-weight:600;
    color:#ffffff;
}

body.home-page .home-destination-card__content p{
    margin:0;
    color:rgba(255,255,255,0.92);
    font-size:15px;
    line-height:1.65;
}

@media (max-width: 700px){
    body.home-page .home-destination-card{
        flex-basis:280px;
        height:360px;
    }

    body.home-page .home-destination-card__content h3{
        font-size:24px;
    }
}

/* ---------- Featured tours ---------- */

body.home-page .home-featured-tours{
    background:#ffffff;
}

body.home-page .home-tour-slider{
    display:flex;
    gap:18px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-behavior:smooth;
    scrollbar-width:none;
    -ms-overflow-style:none;
    padding-bottom:4px;
}

body.home-page .home-tour-slider::-webkit-scrollbar{
    display:none;
}

body.home-page .home-tour-card{
    flex:0 0 340px;
    border:1px solid #ece4d8;
    border-radius:22px;
    overflow:hidden;
    background:#ffffff;
    text-decoration:none;
    color:inherit;
    box-shadow:0 10px 24px rgba(31,26,23,0.05);
    transition:transform .24s ease, box-shadow .24s ease;
}

body.home-page .home-tour-card:hover{
    transform:translateY(-4px);
    box-shadow:0 18px 40px rgba(31,26,23,0.08);
}

body.home-page .home-tour-card__image{
    height:220px;
    background:#f3eee6;
    overflow:hidden;
}

body.home-page .home-tour-card__image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

body.home-page .home-tour-card__body{
    padding:20px;
}

body.home-page .home-tour-card__tag{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 10px;
    margin-bottom:12px;
    border-radius:999px;
    background:#f6f2eb;
    color:#b88a44;
    font-size:11px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
}

body.home-page .home-tour-card h3{
    margin:0 0 10px;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:22px;
    line-height:1.2;
    font-weight:600;
}

body.home-page .home-tour-card p{
    margin:0 0 14px;
    color:#68645c;
    font-size:15px;
    line-height:1.75;
}

body.home-page .home-tour-card__link{
    color:#b88a44;
    font-size:14px;
    font-weight:700;
}

/* ---------- Why us ---------- */

body.home-page .home-why-us{
    background:#ffffff;
}

body.home-page .home-why-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:20px;
    margin-top:30px;
}

body.home-page .home-why-card{
    padding:30px;
    border:1px solid #ece4d8;
    border-radius:22px;
    background:#ffffff;
    box-shadow:0 10px 24px rgba(31,26,23,0.04);
    transition:transform .24s ease, box-shadow .24s ease;
}

body.home-page .home-why-card:hover{
    transform:translateY(-4px);
    box-shadow:0 18px 40px rgba(31,26,23,0.08);
}

body.home-page .home-why-card h3{
    margin:0 0 12px;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:22px;
    line-height:1.2;
    font-weight:600;
}

body.home-page .home-why-card p{
    margin:0;
    color:#68645c;
    font-size:15px;
    line-height:1.75;
}

@media (max-width: 1000px){
    body.home-page .home-why-grid{
        grid-template-columns:repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px){
    body.home-page .home-why-grid{
        grid-template-columns:1fr;
    }
}

/* ---------- Reviews ---------- */

body.home-page .home-reviews{
    background:#ffffff;
}

body.home-page #homeReviews{
    display:flex;
    gap:24px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-behavior:smooth;
    scrollbar-width:none;
    -ms-overflow-style:none;
    padding-bottom:4px;
}

body.home-page #homeReviews::-webkit-scrollbar{
    display:none;
}

body.home-page #homeReviews .home-review-card{
    flex:0 0 420px;
    width:420px;
    min-width:420px;
    max-width:420px;
    padding:30px;
    border:1px solid #ece4d8;
    border-radius:22px;
    background:#ffffff;
    box-shadow:0 10px 24px rgba(31,26,23,0.04);
}

body.home-page #homeReviews .home-review-stars{
    margin-bottom:14px;
    color:#b88a44;
    font-size:18px;
    letter-spacing:2px;
}

body.home-page #homeReviews .home-review-text{
    margin:0 0 18px;
    color:#68645c;
    font-size:15px;
    line-height:1.8;
}

body.home-page #homeReviews .home-review-meta{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px;
}

body.home-page #homeReviews .home-review-meta strong{
    color:#1f1a17;
    font-size:15px;
}

body.home-page #homeReviews .home-review-badge{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 10px;
    border-radius:999px;
    background:#f6f2eb;
    color:#b88a44;
    font-size:11px;
    font-weight:700;
    letter-spacing:.04em;
    text-transform:uppercase;
}

@media (max-width: 900px){
    body.home-page #homeReviews .home-review-card{
        flex:0 0 340px;
        width:340px;
        min-width:340px;
        max-width:340px;
    }
}

@media (max-width: 600px){
    body.home-page #homeReviews .home-review-card{
        flex:0 0 280px;
        width:280px;
        min-width:280px;
        max-width:280px;
    }
}

/* ---------- Process ---------- */

body.home-page .home-process{
    background:#ffffff;
}

body.home-page .home-process .home-section-head{
    max-width:760px;
}

body.home-page .home-process .home-process-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:24px;
    align-items:stretch;
}

body.home-page .home-process .home-process-card{
    background:#ffffff;
    border:1px solid #ece4d8;
    border-radius:22px;
    padding:30px 26px;
    box-shadow:0 10px 24px rgba(31,26,23,0.04);
}

body.home-page .home-process .home-process-step{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:46px;
    height:46px;
    margin:0 0 18px;
    padding:0 12px;
    border-radius:999px;
    background:#f5eadc;
    color:#b27a3d;
    font-size:14px;
    font-weight:700;
    letter-spacing:.10em;
    line-height:1;
}

body.home-page .home-process .home-process-title{
    margin:0 0 12px;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:24px;
    line-height:1.2;
    font-weight:600;
}

body.home-page .home-process .home-process-text{
    margin:0;
    color:#5f564d;
    font-size:16px;
    line-height:1.8;
}

@media (max-width: 980px){
    body.home-page .home-process .home-process-grid{
        grid-template-columns:1fr;
    }
}

/* ---------- Blog ---------- */

body.home-page .home-blog{
    background:#ffffff;
}

body.home-page .home-blog-card{
    flex:0 0 340px;
    width:340px;
    min-width:340px;
    max-width:340px;
    border:1px solid #ece4d8;
    border-radius:22px;
    overflow:hidden;
    background:#ffffff;
    text-decoration:none;
    color:inherit;
    box-shadow:0 10px 24px rgba(31,26,23,0.05);
    transition:transform .24s ease, box-shadow .24s ease;
}

body.home-page .home-blog-card:hover{
    transform:translateY(-4px);
    box-shadow:0 18px 40px rgba(31,26,23,0.08);
}

body.home-page .home-blog-card__image{
    height:220px;
    background:#f3eee6;
    overflow:hidden;
}

body.home-page .home-blog-card__image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

body.home-page .home-blog-card__body{
    padding:20px;
}

body.home-page .home-blog-card__tag{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 10px;
    margin-bottom:12px;
    border-radius:999px;
    background:#f6f2eb;
    color:#b88a44;
    font-size:11px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
}

body.home-page .home-blog-card h3{
    margin:0 0 10px;
    color:#1f1a17;
    font-family:"Playfair Display", serif;
    font-size:22px;
    line-height:1.2;
    font-weight:600;
}

body.home-page .home-blog-card p{
    margin:0 0 14px;
    color:#68645c;
    font-size:15px;
    line-height:1.75;
}

body.home-page .home-blog-card__link{
    color:#b88a44;
    font-size:14px;
    font-weight:700;
}

@media (max-width: 700px){
    body.home-page .home-blog-card{
        flex:0 0 280px;
        width:280px;
        min-width:280px;
        max-width:280px;
    }

    body.home-page .home-blog-card__image{
        height:190px;
    }
}

/* ---------- Final CTA ---------- */

body.home-page .home-final-cta{
    background:#ffffff;
    padding:88px 0 110px;
}

body.home-page .home-final-cta__box{
    padding:48px;
    border-radius:28px;
    background:linear-gradient(135deg, #f8f4ed 0%, #f3ede3 100%);
    border:1px solid #ece4d8;
    text-align:center;
    box-shadow:0 16px 40px rgba(31,26,23,0.05);
}

body.home-page .home-final-cta__actions{
    display:flex;
    justify-content:center;
    flex-wrap:wrap;
    gap:12px;
    margin-top:26px;
}

@media (max-width: 700px){
    body.home-page .home-final-cta{
        padding:64px 0 84px;
    }

    body.home-page .home-final-cta__box{
        padding:30px 24px;
        border-radius:22px;
    }

    body.home-page .home-final-cta__actions{
        flex-direction:column;
    }

    body.home-page .home-final-cta__actions .home-btn{
        width:100%;
    }
}
/* ===== CALM SCALE (like 90%) ===== */

body.home-page .home-shell{
    max-width:1100px !important; /* was too wide */
}

body.home-page .home-section,
body.home-page .home-destinations,
body.home-page .home-featured-tours,
body.home-page .home-reviews,
body.home-page .home-blog{
    padding:70px 0 !important;
}
/* ===== TRAVEL STYLES PREMIUM POLISH ===== */

body.home-page .home-style-card{
    position:relative !important;
    min-height:132px !important;
    padding:24px 24px 22px !important;
    border-radius:22px !important;
    border:1px solid rgba(184,138,68,0.14) !important;
    background:linear-gradient(180deg, #ffffff 0%, #fcfaf7 100%) !important;
    box-shadow:0 10px 24px rgba(31,26,23,0.04) !important;
    transition:
        transform .22s ease,
        box-shadow .22s ease,
        border-color .22s ease !important;
}

body.home-page .home-style-card:hover{
    transform:translateY(-4px) !important;
    border-color:rgba(184,138,68,0.24) !important;
    box-shadow:0 18px 38px rgba(31,26,23,0.08) !important;
}

body.home-page .home-style-icon{
    width:40px !important;
    height:40px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    margin-bottom:12px !important;
    border-radius:999px !important;
    background:#f6efe4 !important;
    font-size:16px !important;
    line-height:1 !important;
}

body.home-page .home-style-card h3{
    margin:0 !important;
    color:#1f1a17 !important;
    font-family:"Playfair Display", serif !important;
    font-size:20px !important;
    line-height:1.2 !important;
    font-weight:600 !important;
    letter-spacing:-0.02em !important;
}

/* ===== WHY US PREMIUM ===== */

body.home-page .home-why-card{
    position:relative !important;
    padding:28px 26px !important;
    border-radius:24px !important;
    background:#ffffff !important;
    border:1px solid rgba(184,138,68,0.12) !important;
    box-shadow:0 12px 28px rgba(31,26,23,0.05) !important;
    transition:all .25s ease !important;
}

body.home-page .home-why-card:hover{
    transform:translateY(-5px) !important;
    box-shadow:0 20px 45px rgba(31,26,23,0.10) !important;
    border-color:rgba(184,138,68,0.25) !important;
}

/* number / icon circle */

body.home-page .home-why-card::before{
    content:"";
    position:absolute;
    top:22px;
    left:22px;
    width:42px;
    height:42px;
    border-radius:999px;
    background:#f3eadf;
}

/* title */

body.home-page .home-why-card h3{
    margin:0 0 10px 0 !important;
    padding-left:56px !important;
    font-size:20px !important;
    line-height:1.25 !important;
    letter-spacing:-0.02em !important;
}

/* text */

body.home-page .home-why-card p{
    margin:0 !important;
    padding-left:56px !important;
    font-size:14.5px !important;
    line-height:1.7 !important;
    color:#6b6258 !important;
}


/* ===== FINAL CTA – PREMIUM CONVERSION ===== */

body.home-page .home-final-cta{
    padding:90px 0 110px !important;
    background:#ffffff !important;
}

body.home-page .home-final-cta__box{
    max-width:980px !important;
    margin:0 auto !important;
    padding:56px 48px !important;
    border-radius:30px !important;
    background:linear-gradient(180deg, #f8f4ed 0%, #f3ede3 100%) !important;
    border:1px solid rgba(184,138,68,0.14) !important;
    box-shadow:0 18px 42px rgba(31,26,23,0.06) !important;
    text-align:center !important;
}

body.home-page .home-final-cta .home-kicker{
    margin-bottom:12px !important;
}

body.home-page .home-final-cta .home-section-title{
    max-width:760px !important;
    margin:0 auto !important;
    font-size:clamp(34px, 4vw, 52px) !important;
    line-height:1.1 !important;
}

body.home-page .home-final-cta .home-section-subtitle{
    max-width:680px !important;
    margin:14px auto 0 !important;
    font-size:17px !important;
    line-height:1.8 !important;
    color:#62584f !important;
}

body.home-page .home-final-cta__actions{
    display:flex !important;
    justify-content:center !important;
    gap:14px !important;
    flex-wrap:wrap !important;
    margin-top:30px !important;
}

body.home-page .home-final-cta__actions .home-btn{
    min-width:180px !important;
}

body.home-page .home-btn--dark{
    background:#1f1a17 !important;
    border:1px solid #1f1a17 !important;
    color:#ffffff !important;
    box-shadow:0 10px 24px rgba(31,26,23,0.10) !important;
}

body.home-page .home-btn--light{
    background:#ffffff !important;
    border:1px solid rgba(31,26,23,0.10) !important;
    color:#1f1a17 !important;
}

@media (max-width:700px){
    body.home-page .home-final-cta__box{
        padding:34px 24px !important;
        border-radius:22px !important;
    }

    body.home-page .home-final-cta__actions{
        flex-direction:column !important;
    }

    body.home-page .home-final-cta__actions .home-btn{
        width:100% !important;
        min-width:0 !important;
    }
}

/* ===== HOW IT WORKS – ELITE VERSION ===== */

@media (min-width:1100px){

    body.home-page .home-process .home-process-grid{
        display:grid !important;
        grid-template-columns:repeat(3,1fr) !important;
        gap:40px !important;
        position:relative;
    }

    /* connection line */

    body.home-page .home-process .home-process-grid::before{
        content:"";
        position:absolute;
        top:48px;
        left:8%;
        right:8%;
        height:1px;
        background:rgba(184,138,68,0.25);
        z-index:0;
    }

    /* cards */

    body.home-page .home-process .home-process-card{
        position:relative !important;
        z-index:1;
        background:#fff !important;
    }

    /* step circle */

    body.home-page .home-process .home-process-step{
        position:relative;
        z-index:2;
        margin-bottom:18px !important;
        box-shadow:0 0 0 6px #ffffff;
    }

}
---------------------------------------------------------------
/* =========================================================
   ABOUT PAGE — NEXT LEVEL LUXURY EDITORIAL
   ========================================================= */

body.about-page{
    background:#fcfaf6 !important;
    color:#1f1a17;
    margin:0;
    padding:0;
}
.about-page{
    background:#fcfaf6;
    color:#1f1a17;
}

/* -------------------------
   LAYOUT
------------------------- */
.home-shell{
    max-width:1180px;
    margin:0 auto;
    padding:0 28px;
}

.home-section-title{
    font-family:"Playfair Display", serif;
    font-size:clamp(34px, 4vw, 50px);
    line-height:1.12;
    letter-spacing:-0.02em;
    color:#1b1714;
    margin:0 0 16px;
}

.home-section-subtitle{
    max-width:700px;
    margin:0 auto;
    font-size:17px;
    line-height:1.85;
    color:#6a5f56;
}

.home-section-head{
    text-align:center;
    max-width:820px;
    margin:0 auto 42px;
}

.about-label,
.home-kicker{
    display:inline-block;
    margin:0 0 14px;
    font-size:12px;
    font-weight:700;
    letter-spacing:2.2px;
    text-transform:uppercase;
    color:#aa7d4d;
}

/* -------------------------
   HERO
------------------------- */
.about-hero{
    position:relative;
    padding:130px 0 92px;
    text-align:center;
    background:
        linear-gradient(180deg, #f6f0e7 0%, #fcfaf6 72%);
    overflow:hidden;
}

.about-hero::before{
    content:"";
    position:absolute;
    top:-80px;
    right:-80px;
    width:320px;
    height:320px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(184,138,68,0.12) 0%, rgba(184,138,68,0) 72%);
    pointer-events:none;
}

.about-hero::after{
    content:"";
    position:absolute;
    left:-120px;
    bottom:-100px;
    width:360px;
    height:360px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(210,190,160,0.14) 0%, rgba(210,190,160,0) 72%);
    pointer-events:none;
}

.about-title{
    max-width:920px;
    margin:0 auto 22px;
    font-family:"Playfair Display", serif;
    font-size:clamp(48px, 6vw, 82px);
    line-height:0.98;
    letter-spacing:-0.045em;
    color:#1c1714;
}

.about-subtitle{
    max-width:760px;
    margin:0 auto;
    font-size:19px;
    line-height:1.9;
    color:#5f554d;
}

/* -------------------------
   STORY
------------------------- */
.about-story{
    padding:96px 0;
    background:#fcfaf6;
}

.about-grid{
    display:grid;
    grid-template-columns:1.08fr 0.92fr;
    gap:68px;
    align-items:center;
}

.about-text{
    max-width:660px;
}

.about-text p{
    margin:0 0 18px;
    font-size:16px;
    line-height:1.95;
    color:#5d534b;
}

.about-signature{
    margin-top:30px;
    padding:22px 24px;
    background:linear-gradient(180deg, #f7f1e9 0%, #f2e9dd 100%);
    border-left:3px solid #b8894f;
    border-radius:0 18px 18px 0;
    box-shadow:0 8px 24px rgba(40,28,18,0.04);
}

.about-signature strong{
    display:block;
    margin-bottom:8px;
    font-family:"Playfair Display", serif;
    font-size:20px;
    color:#1f1a17;
}

.about-signature span{
    display:block;
    font-size:15px;
    line-height:1.8;
    color:#6b6058;
}

.about-image-wrap{
    position:relative;
}

.about-image-wrap::before{
    content:"";
    position:absolute;
    top:28px;
    left:-22px;
    width:100%;
    height:100%;
    border-radius:28px;
    border:1px solid rgba(184,138,68,0.18);
    z-index:0;
}

.about-image{
    position:relative;
    z-index:1;
    width:100%;
    height:540px;
    border-radius:28px;
    overflow:hidden;
    background:#efe7dc;
    box-shadow:0 24px 60px rgba(31,26,23,0.10);
}

.about-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

/* -------------------------
   VALUES
------------------------- */
.about-values{
    padding:104px 0;
    background:linear-gradient(180deg, #f7f2ea 0%, #f3ede3 100%);
}

.about-values-grid{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:26px;
    margin-top:42px;
}

.about-value-card{
    position:relative;
    background:linear-gradient(180deg, #ffffff 0%, #fdfbf8 100%);
    padding:34px 30px;
    border-radius:24px;
    border:1px solid rgba(184,138,68,0.10);
    box-shadow:0 16px 36px rgba(31,26,23,0.05);
    transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.about-value-card:hover{
    transform:translateY(-6px);
    box-shadow:0 22px 46px rgba(31,26,23,0.08);
    border-color:rgba(184,138,68,0.18);
}

.about-card-number{
    display:inline-block;
    margin-bottom:14px;
    font-size:12px;
    font-weight:700;
    letter-spacing:2px;
    color:#b8894f;
}

.about-value-card h3{
    margin:0 0 12px;
    font-family:"Playfair Display", serif;
    font-size:28px;
    line-height:1.15;
    color:#1d1815;
}

.about-value-card p{
    margin:0;
    font-size:15px;
    line-height:1.85;
    color:#655b53;
}

/* -------------------------
   PROCESS
------------------------- */
.about-process-section{
    padding:98px 0 88px;
    background:#fcfaf6;
}

.home-process-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:24px;
    margin-top:10px;
}

.home-process-card{
    background:linear-gradient(180deg, #fffdfa 0%, #f9f4ec 100%);
    padding:30px 26px;
    border-radius:22px;
    border:1px solid rgba(184,138,68,0.10);
    box-shadow:0 12px 28px rgba(31,26,23,0.04);
}

.home-process-step{
    display:inline-block;
    margin-bottom:14px;
    font-size:12px;
    font-weight:700;
    letter-spacing:2px;
    color:#b8894f;
}

.home-process-title{
    margin:0 0 10px;
    font-family:"Playfair Display", serif;
    font-size:24px;
    line-height:1.2;
    color:#1e1815;
}

.home-process-text{
    margin:0;
    font-size:15px;
    line-height:1.85;
    color:#665c54;
}

/* -------------------------
   CTA
------------------------- */
.about-cta{
    padding:28px 0 118px;
    background:#fcfaf6;
}

.about-cta-box{
    position:relative;
    max-width:980px;
    margin:0 auto;
    padding:70px 50px;
    text-align:center;
    border-radius:32px;
    background:linear-gradient(180deg, #f8f2e9 0%, #efe4d6 100%);
    border:1px solid rgba(184,138,68,0.14);
    box-shadow:0 24px 54px rgba(31,26,23,0.08);
    overflow:hidden;
}

.about-cta-box::before{
    content:"";
    position:absolute;
    top:-80px;
    right:-70px;
    width:240px;
    height:240px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(184,138,68,0.10) 0%, rgba(184,138,68,0) 72%);
    pointer-events:none;
}

.about-cta-box h2{
    position:relative;
    z-index:1;
    margin:0 0 16px;
    font-family:"Playfair Display", serif;
    font-size:clamp(38px, 4.2vw, 60px);
    line-height:1.04;
    color:#1c1714;
}

.about-cta-box p{
    position:relative;
    z-index:1;
    max-width:680px;
    margin:0 auto 28px;
    font-size:17px;
    line-height:1.9;
    color:#62584f;
}

.home-final-cta__actions{
    position:relative;
    z-index:1;
    display:flex;
    justify-content:center;
    gap:14px;
    flex-wrap:wrap;
}

/* -------------------------
   BUTTONS
------------------------- */
.home-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:0 24px;
    border-radius:999px;
    text-decoration:none;
    font-size:14px;
    font-weight:600;
    transition:transform .22s ease, box-shadow .22s ease, background .22s ease;
}

.home-btn:hover{
    transform:translateY(-2px);
}

.home-btn--dark{
    background:#1f1a17;
    color:#fff;
    box-shadow:0 12px 24px rgba(31,26,23,0.14);
}

.home-btn--dark:hover{
    background:#15110f;
}

.home-btn--light{
    background:rgba(255,255,255,0.78);
    color:#1f1a17;
    border:1px solid rgba(31,26,23,0.10);
    backdrop-filter:blur(4px);
}

.home-btn--light:hover{
    background:#ffffff;
}

/* -------------------------
   RESPONSIVE
------------------------- */
@media (max-width: 980px){
    .about-grid{
        grid-template-columns:1fr;
        gap:36px;
    }

    .about-text{
        max-width:none;
    }

    .about-image{
        height:420px;
    }

    .about-values-grid{
        grid-template-columns:1fr;
    }

    .home-process-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 640px){
    .home-shell{
        padding:0 20px;
    }

    .about-hero{
        padding:112px 0 76px;
    }

    .about-title{
        font-size:clamp(40px, 11vw, 58px);
        line-height:1.02;
    }

    .about-subtitle{
        font-size:16px;
        line-height:1.85;
    }

    .about-story,
    .about-values,
    .about-process-section{
        padding:76px 0;
    }

    .about-image{
        height:300px;
        border-radius:22px;
    }

    .about-image-wrap::before{
        display:none;
    }

    .about-value-card,
    .home-process-card{
        padding:26px 22px;
    }

    .about-cta{
        padding:10px 0 88px;
    }

    .about-cta-box{
        padding:46px 22px;
        border-radius:24px;
    }

    .about-cta-box h2{
        font-size:clamp(32px, 9vw, 44px);
    }

    .about-cta-box p{
        font-size:15px;
    }
}
---------------------------------------------
/* =========================================================
   CONTACT PAGE — LUXURY CLEAN STYLE
   ========================================================= */

.contact-page{
    background:#fcfaf6;
    color:#1f1a17;
}

.contact-hero{
    padding:125px 0 80px;
    text-align:center;
    background:linear-gradient(180deg, #f6f0e7 0%, #fcfaf6 72%);
}

.contact-title{
    max-width:920px;
    margin:0 auto 20px;
    font-family:"Playfair Display", serif;
    font-size:clamp(46px, 6vw, 76px);
    line-height:1.02;
    letter-spacing:-0.04em;
    color:#1d1815;
}

.contact-subtitle{
    max-width:760px;
    margin:0 auto;
    font-size:18px;
    line-height:1.9;
    color:#5f554d;
}

.contact-main{
    padding:90px 0;
}

.contact-grid{
    display:grid;
    grid-template-columns:1.15fr 0.85fr;
    gap:34px;
    align-items:start;
}

.contact-form-wrap{
    background:#fffdfa;
    border:1px solid rgba(184,138,68,0.10);
    border-radius:28px;
    padding:38px 34px;
    box-shadow:0 16px 36px rgba(31,26,23,0.05);
}

.contact-label{
    display:inline-block;
    margin:0 0 12px;
    font-size:12px;
    font-weight:700;
    letter-spacing:2px;
    text-transform:uppercase;
    color:#aa7d4d;
}

.contact-intro{
    margin:0 0 24px;
    color:#655b53;
    font-size:16px;
    line-height:1.85;
}

.contact-form{
    display:block;
}

.contact-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
    margin-bottom:18px;
}

.contact-field{
    display:flex;
    flex-direction:column;
}

.contact-field label{
    margin-bottom:8px;
    font-size:13px;
    font-weight:600;
    color:#3b312c;
}

.contact-field input,
.contact-field textarea{
    width:100%;
    border:1px solid rgba(31,26,23,0.10);
    border-radius:16px;
    background:#fff;
    padding:14px 16px;
    font-size:15px;
    color:#1f1a17;
    outline:none;
    transition:border-color .2s ease, box-shadow .2s ease;
    box-sizing:border-box;
}

.contact-field input:focus,
.contact-field textarea:focus{
    border-color:rgba(184,138,68,0.55);
    box-shadow:0 0 0 4px rgba(184,138,68,0.08);
}

.contact-field textarea{
    resize:vertical;
    min-height:170px;
}

.contact-form .contact-field:last-of-type{
    margin-bottom:22px;
}

.contact-info-card{
    background:linear-gradient(180deg, #f8f2e9 0%, #f1e6d8 100%);
    border:1px solid rgba(184,138,68,0.12);
    border-radius:28px;
    padding:34px 28px;
    box-shadow:0 18px 40px rgba(31,26,23,0.06);
}

.contact-info-card h3{
    margin:0 0 14px;
    font-family:"Playfair Display", serif;
    font-size:30px;
    line-height:1.18;
    color:#1d1815;
}

.contact-info-card p{
    margin:0 0 22px;
    font-size:15px;
    line-height:1.85;
    color:#62584f;
}

.contact-info-list{
    display:grid;
    gap:16px;
}

.contact-info-item{
    padding:16px 0;
    border-top:1px solid rgba(31,26,23,0.08);
}

.contact-info-item:first-child{
    border-top:none;
    padding-top:0;
}

.contact-info-item strong{
    display:block;
    margin-bottom:6px;
    font-size:14px;
    color:#1f1a17;
}

.contact-info-item span{
    display:block;
    font-size:15px;
    line-height:1.75;
    color:#655b53;
}

.contact-note{
    padding:0 0 110px;
}

.contact-note-box{
    max-width:920px;
    margin:0 auto;
    text-align:center;
    background:#fffdfa;
    border:1px solid rgba(184,138,68,0.10);
    border-radius:28px;
    padding:56px 34px;
    box-shadow:0 14px 34px rgba(31,26,23,0.04);
}

.contact-note-box h2{
    margin:0 0 14px;
    font-family:"Playfair Display", serif;
    font-size:clamp(34px, 4vw, 52px);
    line-height:1.1;
    color:#1d1815;
}

.contact-note-box p{
    max-width:680px;
    margin:0 auto;
    font-size:16px;
    line-height:1.9;
    color:#655b53;
}

@media (max-width: 980px){
    .contact-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 640px){
    .contact-hero{
        padding:110px 0 70px;
    }

    .contact-row{
        grid-template-columns:1fr;
    }

    .contact-form-wrap,
    .contact-info-card,
    .contact-note-box{
        padding:26px 22px;
        border-radius:22px;
    }

    .contact-title{
        font-size:clamp(40px, 11vw, 58px);
    }

    .contact-subtitle{
        font-size:16px;
    }
}
.contact-trust{
    padding:0 0 26px;
    background:#fcfaf6;
}

.contact-trust-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
    margin-top:-26px;
    position:relative;
    z-index:2;
}

.contact-trust-item{
    background:rgba(255,255,255,0.92);
    border:1px solid rgba(184,138,68,0.10);
    border-radius:22px;
    padding:24px 22px;
    box-shadow:0 14px 30px rgba(31,26,23,0.05);
    backdrop-filter:blur(6px);
}

.contact-trust-item strong{
    display:block;
    margin-bottom:8px;
    font-family:"Playfair Display", serif;
    font-size:20px;
    line-height:1.2;
    color:#1d1815;
}

.contact-trust-item span{
    display:block;
    font-size:14px;
    line-height:1.8;
    color:#655b53;
}

@media (max-width: 980px){
    .contact-trust-grid{
        grid-template-columns:1fr;
        margin-top:0;
    }
}
.contact-info-item a{
    color:#655b53;
    text-decoration:none;
    line-height:1.75;
}

.contact-info-item a:hover{
    color:#1f1a17;
}

.contact-info-note{
    margin-top:22px;
    padding:18px 18px;
    border-radius:18px;
    background:rgba(255,255,255,0.55);
    border:1px solid rgba(184,138,68,0.10);
    font-size:14px;
    line-height:1.8;
    color:#5f554d;
}
.contact-form-note{
    margin:0 0 20px;
    font-size:14px;
    line-height:1.8;
    color:#74685f;
}
.contact-success,
.contact-error{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:18px 20px;
    border-radius:16px;
    margin:0 0 22px;
    font-size:15px;
    line-height:1.75;
}

.contact-success strong,
.contact-error strong{
    display:block;
    font-size:15px;
    font-weight:700;
}

.contact-success span,
.contact-error span{
    display:block;
    font-size:14px;
    line-height:1.8;
}

.contact-success{
    background:linear-gradient(180deg, #edf8f1 0%, #e7f4ec 100%);
    border:1px solid #cfe8d6;
    color:#24543a;
    box-shadow:0 8px 20px rgba(36,84,58,0.06);
}

.contact-error{
    background:linear-gradient(180deg, #fff4f4 0%, #fff0f0 100%);
    border:1px solid #efcaca;
    color:#8b2e2e;
    box-shadow:0 8px 20px rgba(139,46,46,0.05);
}
.contact-success,
.contact-error{
    position:relative;
    padding-left:58px;
}

.contact-success::before,
.contact-error::before{
    content:"";
    position:absolute;
    top:18px;
    left:18px;
    width:24px;
    height:24px;
    border-radius:50%;
}

.contact-success::before{
    background:#2f7a52;
    box-shadow:inset 0 0 0 6px #edf8f1;
}

.contact-error::before{
    background:#b14545;
    box-shadow:inset 0 0 0 6px #fff4f4;
}
/* Add this to public/assets/css/style.css
   Then remove the inline <style> block from services.php */

.services-collection{
    padding: 32px 0 80px;
}

.services-hero{
    margin: 8px 0 34px;
    border-radius: 34px;
    overflow: hidden;
    position: relative;
    background:
        linear-gradient(135deg, rgba(53, 39, 28, 0.28), rgba(53, 39, 28, 0.08)),
        linear-gradient(180deg, #f7f1e8 0%, #efe3d4 100%);
    border: 1px solid rgba(184, 138, 68, 0.14);
    box-shadow: 0 18px 50px rgba(31, 26, 23, 0.07);
}

.services-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at top right, rgba(184,138,68,0.16), transparent 34%),
        radial-gradient(circle at bottom left, rgba(161,118,71,0.10), transparent 28%);
    pointer-events:none;
}

.services-hero__inner{
    position: relative;
    z-index: 1;
    padding: 58px 56px 54px;
    max-width: 900px;
}

.services-hero__eyebrow,
.services-filters__eyebrow,
.services-results__eyebrow{
    display: inline-block;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #b88a44;
    font-weight: 600;
    margin-bottom: 14px;
}

.services-hero__title{
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: clamp(2.3rem, 4vw, 4.2rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: #241c16;
    max-width: 760px;
}

.services-hero__text{
    margin: 18px 0 0;
    max-width: 650px;
    font-size: 16px;
    line-height: 1.75;
    color: #5f554b;
}

.services-hero__meta{
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 28px;
}

.services-hero__meta-item{
    min-width: 150px;
    padding: 14px 18px;
    border-radius: 18px;
    background: rgba(255,255,255,0.52);
    border: 1px solid rgba(184, 138, 68, 0.12);
    backdrop-filter: blur(8px);
}

.services-hero__meta-item strong{
    display: block;
    font-size: 18px;
    color: #241c16;
    margin-bottom: 4px;
}

.services-hero__meta-item span{
    font-size: 13px;
    color: #6e6459;
}

.services-layout{
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 30px;
    align-items: start;
}

.services-filters{
    position: sticky;
    top: 18px;
    padding: 26px;
    border-radius: 28px;
    border: 1px solid rgba(184, 138, 68, 0.12);
    box-shadow: 0 14px 34px rgba(31, 26, 23, 0.05);
    background: rgba(255,255,255,0.92);
}

.services-filters__head{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.services-filters__head h2{
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 28px;
    line-height: 1.15;
    color: #241c16;
}

.services-filters__count{
    white-space: nowrap;
    font-size: 13px;
    color: #7a6f63;
    padding-top: 6px;
}

.services-filters__form .field{
    margin: 0 0 14px;
}

.services-filters__grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.services-filters label{
    display: block;
    margin-bottom: 7px;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #8b7f73;
    font-weight: 600;
}

.services-filters input,
.services-filters select{
    width: 100%;
    border-radius: 15px;
    border: 1px solid rgba(184, 138, 68, 0.14);
    background: #fcfaf7;
    color: #241c16;
    padding: 12px 14px;
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.services-filters input:focus,
.services-filters select:focus{
    border-color: rgba(184, 138, 68, 0.38);
    box-shadow: 0 0 0 4px rgba(184, 138, 68, 0.10);
    background: #fff;
}

.services-filters__actions{
    display: flex;
    gap: 10px;
    margin-top: 20px;
}

.services-filters__actions .btn,
.services-filters__actions .btn-ghost{
    flex: 1;
    text-align: center;
    border-radius: 15px;
    padding: 12px 14px;
    text-decoration: none;
}

.services-filters__actions .btn-ghost{
    border: 1px solid rgba(184, 138, 68, 0.14);
    background: #fcfaf7;
    color: #5f554b;
}

.services-active-filters{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(184, 138, 68, 0.10);
}

.services-active-filters .chip{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 12px;
    border-radius: 999px;
    background: #f6efe5;
    border: 1px solid rgba(184, 138, 68, 0.12);
    color: #5f554b;
    font-size: 12px;
}

.services-results__head{
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 22px;
}

.services-results__head h2{
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 34px;
    line-height: 1.1;
    color: #241c16;
}

.services-results__meta{
    font-size: 13px;
    color: #7a6f63;
    white-space: nowrap;
}

.services-grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 26px;
}

.service-card{
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border-radius: 28px;
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(184, 138, 68, 0.12);
    box-shadow: 0 16px 40px rgba(31, 26, 23, 0.06);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.service-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 24px 60px rgba(31, 26, 23, 0.10);
    border-color: rgba(184, 138, 68, 0.26);
}

.service-card__media{
    position: relative;
    display: block;
    height: 270px;
    overflow: hidden;
    background: #efe6da;
}

.service-card__media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}

.service-card:hover .service-card__media img{
    transform: scale(1.06);
}

.service-card__overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18, 14, 11, 0.48), rgba(18, 14, 11, 0.05) 55%, transparent);
    pointer-events: none;
}

.service-card__topbar{
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    z-index: 2;
}

.service-card__location,
.service-card__price{
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.92);
    color: #241c16;
    font-size: 12px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-weight: 600;
}

.service-card__price{
    background: rgba(36, 28, 22, 0.88);
    color: #f8f2e9;
}

.service-card__body{
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 24px 24px 22px;
}

.service-card__meta{
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-bottom: 14px;
}

.service-card__meta span{
    display: inline-flex;
    align-items: center;
    padding: 7px 11px;
    border-radius: 999px;
    background: #f8f3ec;
    color: #776b5f;
    font-size: 12px;
    border: 1px solid rgba(184, 138, 68, 0.10);
}

.service-card__title{
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 28px;
    line-height: 1.12;
}

.service-card__title a{
    color: #241c16;
    text-decoration: none;
}

.service-card__excerpt{
    margin: 12px 0 0;
    color: #665d53;
    font-size: 15px;
    line-height: 1.75;
    flex: 1;
}

.service-card__footer{
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid rgba(184, 138, 68, 0.10);
}

.service-card__link{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #a77736;
    text-decoration: none;
    font-size: 13px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    font-weight: 700;
}

.service-card__link::after{
    content: "→";
    transition: transform .2s ease;
}

.service-card:hover .service-card__link::after{
    transform: translateX(3px);
}

.services-empty{
    padding: 34px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(184, 138, 68, 0.12);
    box-shadow: 0 14px 34px rgba(31, 26, 23, 0.05);
}

.services-empty h3{
    margin: 0 0 8px;
    font-family: "Playfair Display", serif;
    font-size: 30px;
    color: #241c16;
}

.services-empty p{
    margin: 0;
    color: #6a6056;
    line-height: 1.7;
}

.services-pagination{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 30px;
}

.services-pagination a,
.services-pagination .current{
    padding: 11px 15px;
    border-radius: 14px;
    border: 1px solid rgba(184, 138, 68, 0.12);
    text-decoration: none;
    background: #fff;
    color: #5f554b;
}

.services-pagination .current{
    background: #f8f3ec;
}

@media (max-width: 1100px){
    .services-layout{
        grid-template-columns: 1fr;
    }

    .services-filters{
        position: static;
    }

    .services-grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px){
    .services-collection{
        padding: 20px 0 60px;
    }

    .services-hero__inner{
        padding: 34px 24px 30px;
    }

    .services-hero__meta{
        flex-direction: column;
    }

    .services-results__head{
        flex-direction: column;
        align-items: flex-start;
    }

    .services-grid{
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .services-filters{
        padding: 22px;
    }

    .services-filters__grid{
        grid-template-columns: 1fr;
    }

    .services-filters__actions{
        flex-direction: column;
    }

    .service-card__media{
        height: 240px;
    }

    .service-card__title{
        font-size: 24px;
    }

    .service-card__topbar{
        flex-direction: column;
        align-items: flex-start;
    }
}

----related tours--------------
.related-tours{
    margin-top: 70px;
    padding-top: 24px;
}

.related-tours__head{
    max-width: 760px;
    margin-bottom: 28px;
}

.related-tours__eyebrow{
    display: inline-block;
    margin-bottom: 12px;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #b88a44;
    font-weight: 600;
}

.related-tours__head h2{
    margin: 0 0 10px;
    font-family: "Playfair Display", serif;
    font-size: 40px;
    line-height: 1.1;
    color: #241c16;
}

.related-tours__head p{
    margin: 0;
    color: #6b6156;
    line-height: 1.75;
}

.related-tours__grid{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 26px;
}

.related-tour-card{
    background: #fff;
    border: 1px solid rgba(184,138,68,0.12);
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 16px 40px rgba(31,26,23,0.06);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.related-tour-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 24px 60px rgba(31,26,23,0.10);
    border-color: rgba(184,138,68,0.22);
}

.related-tour-card__media{
    position: relative;
    display: block;
    height: 250px;
    overflow: hidden;
    background: #efe6da;
}

.related-tour-card__media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}

.related-tour-card:hover .related-tour-card__media img{
    transform: scale(1.06);
}

.related-tour-card__overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18,14,11,0.56), rgba(18,14,11,0.08) 55%, transparent);
}

.related-tour-card

.related-tours{
    margin-top: 72px;
    padding-top: 10px;
}

.related-tours__head{
    max-width: 760px;
    margin-bottom: 30px;
}

.related-tours__eyebrow{
    display: inline-block;
    margin-bottom: 12px;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #b88a44;
    font-weight: 600;
}

.related-tours__head h2{
    margin: 0 0 10px;
    font-family: "Playfair Display", serif;
    font-size: 46px;
    line-height: 1.08;
    color: #241c16;
}

.related-tours__head p{
    margin: 0;
    color: #6a6056;
    line-height: 1.75;
    font-size: 16px;
}

.related-tours__grid{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
}

.related-tour-card{
    display: flex;
    flex-direction: column;
    min-height: 100%;
    background: #fff;
    border: 1px solid rgba(184,138,68,0.12);
    border-radius: 30px;
    overflow: hidden;
    box-shadow: 0 16px 40px rgba(31,26,23,0.06);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.related-tour-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 24px 60px rgba(31,26,23,0.10);
    border-color: rgba(184,138,68,0.22);
}

.related-tour-card__media{
    position: relative;
    display: block;
    height: 255px;
    overflow: hidden;
    background: linear-gradient(180deg, #eee4d8 0%, #d7ccbf 100%);
}

.related-tour-card__media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .8s ease;
}

.related-tour-card:hover .related-tour-card__media img{
    transform: scale(1.06);
}

.related-tour-card__overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(18,14,11,0.58), rgba(18,14,11,0.12) 55%, transparent);
    pointer-events: none;
}

.related-tour-card__top{
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.related-tour-card__pill,
.related-tour-card__price{
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.related-tour-card__pill{
    background: rgba(255,255,255,0.92);
    color: #241c16;
}

.related-tour-card__price{
    background: rgba(36,28,22,0.88);
    color: #f8f2e9;
}

.related-tour-card__body{
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 24px 24px 22px;
}

.related-tour-card__meta{
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-bottom: 14px;
}

.related-tour-card__meta span{
    display: inline-flex;
    align-items: center;
    padding: 7px 11px;
    border-radius: 999px;
    background: #f8f3ec;
    color: #776b5f;
    font-size: 12px;
    border: 1px solid rgba(184,138,68,0.10);
}

.related-tour-card__title{
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 28px;
    line-height: 1.14;
}

.related-tour-card__title a{
    color: #241c16;
    text-decoration: none;
}

.related-tour-card__excerpt{
    margin: 12px 0 0;
    color: #665d53;
    font-size: 15px;
    line-height: 1.75;
    min-height: 78px;
}

.related-tour-card__footer{
    margin-top: auto;
    padding-top: 18px;
    border-top: 1px solid rgba(184,138,68,0.10);
}

.related-tour-card__link{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #a77736;
    text-decoration: none;
    font-size: 13px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    font-weight: 700;
}

.related-tour-card__link::after{
    content: "→";
    transition: transform .2s ease;
}

.related-tour-card:hover .related-tour-card__link::after{
    transform: translateX(3px);
}

@media (max-width: 1100px){
    .related-tours__grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px){
    .related-tours__head h2{
        font-size: 34px;
    }

    .related-tours__grid{
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .related-tour-card__media{
        height: 230px;
    }

    .related-tour-card__top{
        flex-direction: column;
        align-items: flex-start;
    }

    .related-tour-card__title{
        font-size: 24px;
    }

    .related-tour-card__excerpt{
        min-height: 0;
    }
}
/* =========================
   ACCORDION SYSTEM
   Includes / Itinerary / FAQ
   ========================= */

.included-section{
    padding-top:10px;
}

.included-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:16px;
    margin-bottom:22px;
}

.included-head h2{
    margin:0;
    font-family:"Playfair Display", serif;
    font-size:32px;
    line-height:1.15;
    color:#241c16;
}

.included-toggle-all{
    border:none;
    background:none;
    padding:0;
    color:#b88a44;
    font-size:14px;
    font-weight:600;
    cursor:pointer;
}

.included-accordion{
    border-top:1px solid rgba(36,28,22,.08);
}

.included-item{
    border-bottom:1px solid rgba(36,28,22,.08);
}

.included-trigger{
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    padding:22px 0;
    border:none;
    background:none;
    text-align:left;
    cursor:pointer;
}

.included-trigger__text{
    flex:1 1 auto;
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:8px;
}

.itinerary-day-badge{
    display:inline-block;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:#b88a44;
}

.included-trigger__title{
    display:block;
    font-family:"Playfair Display", serif;
    font-size:28px;
    line-height:1.2;
    color:#241c16;
    white-space:normal;
    overflow-wrap:break-word;
}

.included-icon{
    flex:0 0 30px;
    width:30px;
    text-align:center;
    font-size:30px;
    line-height:1;
    color:#9a7a52;
    margin-top:4px;
}

.included-panel{
    padding:0 0 22px;
}

.included-panel__content{
    max-width:820px;
    color:#5d534a;
    font-size:16px;
    line-height:1.85;
}

.included-panel[hidden]{
    display:none !important;
}
/* =========================
   SERVICE PAGE
   ========================= */

.page{
    max-width:1280px;
    margin:0 auto;
    padding:0 24px 80px;
    display:grid;
    grid-template-columns:minmax(0, 1.5fr) 360px;
    gap:44px;
    align-items:start;
}

/* Hero */
.tour-hero{
    width:100%;
    margin:0 0 42px;
}

.tour-hero__media{
    position:relative;
    width:100%;
    height:68vh;
    min-height:400px;
    max-height:700px;
    overflow:hidden;
    background:#e9dfd2;
}

.tour-hero__media img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transform:scale(1.01);
}

.tour-hero__overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(20,15,11,.46), rgba(20,15,11,.14) 42%, transparent);
}

.tour-hero__content-wrap{
    width:100%;
    background:#f4ede3;
    border-bottom:1px solid rgba(184,138,68,.08);
}

.tour-hero__content{
    max-width:1280px;
    margin:0 auto;
    padding:48px 24px 38px;
}

.tour-hero__eyebrow,
.tour-section-eyebrow{
    display:inline-block;
    margin-bottom:16px;
    font-size:11px;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:#b88a44;
    font-weight:700;
}

.tour-hero__title{
    margin:0;
    max-width:980px;
    font-family:"Playfair Display", serif;
    font-size:clamp(3.4rem, 5.3vw, 5.8rem);
    line-height:1.01;
    letter-spacing:-.035em;
    color:#241c16;
}

.tour-hero__text{
    margin:20px 0 0;
    max-width:760px;
    color:#655c52;
    font-size:17px;
    line-height:1.9;
}

.tour-hero__facts{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
    margin-top:30px;
}

.tour-hero__fact{
    min-width:170px;
    padding:16px 18px;
    border-radius:18px;
    background:rgba(255,255,255,.78);
    border:1px solid rgba(184,138,68,.10);
    backdrop-filter:blur(5px);
}

.tour-hero__fact strong{
    display:block;
    margin-bottom:4px;
    color:#241c16;
    font-size:17px;
    font-weight:600;
}

.tour-hero__fact span{
    color:#7b7064;
    font-size:12px;
    letter-spacing:.02em;
}

/* Features */
.tour-feature-list{
    display:flex;
    flex-direction:column;
    gap:12px;
    margin-top:22px;
}

.tour-feature-item{
    display:flex;
    align-items:flex-start;
    gap:12px;
    color:#5f554b;
    font-size:15px;
    line-height:1.7;
}

.tour-feature-icon{
    width:24px;
    height:24px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:#c9a227;
    color:#111;
    font-weight:700;
    font-size:13px;
    flex:0 0 24px;
    margin-top:2px;
}

/* Intro layout */
.tour-intro{
    display:grid;
    grid-template-columns:minmax(0,1fr) 330px;
    gap:30px;
    align-items:start;
    margin:32px 0 38px;
}

/* Cards */
.tour-intro__main,
.tour-intro__side,
.service-tabs,
.stickyCard{
    background:#fff;
    border:1px solid rgba(184,138,68,.10);
    border-radius:30px;
    padding:28px;
    box-shadow:0 16px 40px rgba(31,26,23,.05);
}

.tour-intro__main h2{
    margin:0 0 14px;
    font-family:"Playfair Display", serif;
    font-size:36px;
    line-height:1.12;
    letter-spacing:-.02em;
    color:#241c16;
}

/* Summary */
.tour-summary-list{
    margin:0;
    padding:0;
    list-style:none;
    border-top:1px solid rgba(184,138,68,.10);
}

.tour-summary-list li{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    padding:14px 0;
    border-bottom:1px solid rgba(184,138,68,.10);
    color:#665d53;
    line-height:1.7;
}

.tour-summary-list li:last-child{
    border-bottom:0;
}

.tour-summary-list li strong{
    color:#8b7b69;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    flex:0 0 120px;
}

.tour-summary-list li span,
.tour-summary-list li div{
    flex:1 1 auto;
    color:#241c16;
}

/* Tabs */
.tabs-nav{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:26px;
    padding-bottom:4px;
}

.tab-btn{
    border:1px solid rgba(184,138,68,.14);
    background:#f8f3ec;
    color:#6f6458;
    border-radius:999px;
    padding:12px 18px;
    cursor:pointer;
    font-weight:600;
    font-size:14px;
    line-height:1;
    transition:all .22s ease;
}

.tab-btn:hover{
    background:#f1e8dc;
    border-color:rgba(184,138,68,.24);
    color:#2d241d;
}

.tab-btn.active{
    background:#241c16;
    color:#fff;
    border-color:#241c16;
}

.tab-panel{
    display:none;
}

.tab-panel.active{
    display:block;
}

.tour-richtext{
    color:#5f554b;
    line-height:1.92;
    font-size:16px;
}

.tour-richtext p:first-child{
    margin-top:0;
}

/* Legacy itinerary / faq cards if still present */
.itinerary-list,
.faq-list{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.itinerary-item,
.faq-item,
.tour-empty-block{
    border:1px solid rgba(184,138,68,.10);
    border-radius:24px;
    padding:24px;
    background:#fcfaf7;
}

.itinerary-item{
    display:grid;
    grid-template-columns:88px 1fr;
    gap:18px;
}

.itinerary-item__day{
    font-size:12px;
    font-weight:700;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:#b88a44;
}

.itinerary-item__content h3,
.faq-item h3{
    margin:0 0 8px;
    font-family:"Playfair Display", serif;
    font-size:25px;
    line-height:1.18;
    color:#241c16;
}

.itinerary-item__content p,
.faq-item__answer{
    margin:0;
    color:#665d53;
    line-height:1.85;
}

/* Booking */
.stickyCard{
    position:sticky;
    top:110px;
}

.booking-trust{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:20px 0 22px;
}

.booking-trust__item{
    padding:11px 13px;
    border-radius:14px;
    background:#f8f3ec;
    border:1px solid rgba(184,138,68,.10);
    color:#6d6257;
    font-size:14px;
    line-height:1.55;
}

.booking-note{
    margin-top:14px;
    color:#6f6458;
    font-size:13px;
    line-height:1.8;
}

/* Related tours */
.related-tours{
    margin-top:84px;
}

.related-tours__head{
    max-width:760px;
    margin-bottom:30px;
}

.related-tours__eyebrow{
    display:inline-block;
    margin-bottom:12px;
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:#b88a44;
    font-weight:700;
}

.related-tours__head h2{
    margin:0 0 10px;
    font-family:"Playfair Display", serif;
    font-size:42px;
    line-height:1.08;
    letter-spacing:-.02em;
    color:#241c16;
}

.related-tours__head p{
    margin:0;
    color:#6b6156;
    line-height:1.8;
}

.related-tours__grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:28px;
}

.related-tour-card{
    background:#fff;
    border:1px solid rgba(184,138,68,.12);
    border-radius:30px;
    overflow:hidden;
    box-shadow:0 16px 42px rgba(31,26,23,.06);
    transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.related-tour-card:hover{
    transform:translateY(-6px);
    box-shadow:0 24px 62px rgba(31,26,23,.10);
    border-color:rgba(184,138,68,.22);
}

.related-tour-card__media{
    position:relative;
    display:block;
    height:260px;
    overflow:hidden;
    background:linear-gradient(180deg, #eee4d8 0%, #d7ccbf 100%);
}

.related-tour-card__media img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .8s ease;
}

.related-tour-card:hover .related-tour-card__media img{
    transform:scale(1.06);
}

.related-tour-card__overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(18,14,11,.56), rgba(18,14,11,.08) 55%, transparent);
}

.related-tour-card__top{
    position:absolute;
    left:18px;
    right:18px;
    bottom:18px;
    z-index:2;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
}

.related-tour-card__pill,
.related-tour-card__price{
    display:inline-flex;
    align-items:center;
    min-height:36px;
    padding:8px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
    letter-spacing:.05em;
    text-transform:uppercase;
}

.related-tour-card__pill{
    background:rgba(255,255,255,.92);
    color:#241c16;
}

.related-tour-card__price{
    background:rgba(36,28,22,.88);
    color:#f8f2e9;
}

.related-tour-card__body{
    display:flex;
    flex-direction:column;
    flex:1;
    padding:25px 24px 22px;
}

.related-tour-card__meta{
    display:flex;
    flex-wrap:wrap;
    gap:9px;
    margin-bottom:14px;
}

.related-tour-card__meta span{
    display:inline-flex;
    align-items:center;
    padding:7px 11px;
    border-radius:999px;
    background:#f8f3ec;
    color:#776b5f;
    font-size:12px;
    border:1px solid rgba(184,138,68,.10);
}

.related-tour-card__title{
    margin:0;
    font-family:"Playfair Display", serif;
    font-size:29px;
    line-height:1.14;
}

.related-tour-card__title a{
    color:#241c16;
    text-decoration:none;
}

.related-tour-card__excerpt{
    margin:12px 0 0;
    color:#665d53;
    font-size:15px;
    line-height:1.78;
    min-height:78px;
}

.related-tour-card__footer{
    margin-top:auto;
    padding-top:18px;
    border-top:1px solid rgba(184,138,68,.10);
}

.related-tour-card__link{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#a77736;
    text-decoration:none;
    font-size:13px;
    letter-spacing:.10em;
    text-transform:uppercase;
    font-weight:700;
}

.related-tour-card__link::after{
    content:"→";
}

@media (max-width:1100px){
    .page,
    .tour-intro{
        grid-template-columns:1fr;
    }

    .page{
        gap:36px;
    }

    .related-tours__grid{
        grid-template-columns:repeat(2, minmax(0,1fr));
    }

    .stickyCard{
        position:relative;
        top:auto;
    }
}

@media (max-width:760px){
    .page{
        padding:0 16px 56px;
    }

    .tour-hero__media{
        height:44vh;
        min-height:280px;
        max-height:380px;
    }

    .tour-hero__content{
        padding:30px 16px 24px;
    }

    .tour-hero__title{
        font-size:42px;
    }

    .tour-intro__main,
    .tour-intro__side,
    .service-tabs,
    .stickyCard{
        padding:22px 20px;
        border-radius:24px;
    }

    .tour-intro__main h2{
        font-size:29px;
    }

    .itinerary-item{
        grid-template-columns:1fr;
    }

    .related-tours__grid{
        grid-template-columns:1fr;
        gap:22px;
    }

    .related-tour-card__media{
        height:220px;
    }

    .related-tour-card__top{
        flex-direction:column;
        align-items:flex-start;
    }

    .related-tour-card__title{
        font-size:25px;
    }

    .related-tour-card__excerpt{
        min-height:0;
    }
}
/* =========================
   SERVICE PAGE FINAL SYSTEM
   ========================= */

body.tour-page{
    background:#f7f3ed;
    color:#5d534a;
}

.page{
    max-width:1240px;
    margin:0 auto;
    padding:0 24px 72px;
    display:grid;
    grid-template-columns:minmax(0, 1.6fr) 370px;
    gap:54px;
    align-items:start;
    background:transparent;
}

/* Hero */
.tour-hero{
    width:100%;
    margin:0 0 38px;
}

.tour-hero__media{
    position:relative;
    width:100%;
    height:62vh;
    min-height:380px;
    max-height:640px;
    overflow:hidden;
}

.tour-hero__media img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.tour-hero__overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(18,14,11,.42), rgba(18,14,11,.12) 40%, transparent);
}

.tour-hero__content-wrap{
    width:100%;
    background:#f3ede4;
    border-bottom:1px solid rgba(184,138,68,.08);
}

.tour-hero__content{
    max-width:1320px;
    margin:0 auto;
    padding:44px 20px 36px;
}

.tour-hero__eyebrow,
.tour-section-eyebrow{
    display:inline-block;
    margin-bottom:14px;
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:#b88a44;
    font-weight:600;
}

.tour-hero__title{
    margin:0;
    max-width:980px;
    font-family:"Playfair Display", serif;
    font-size:clamp(3.2rem, 5vw, 5.3rem);
    line-height:1.02;
    letter-spacing:-.03em;
    color:#241c16;
}

.tour-hero__text{
    margin:18px 0 0;
    max-width:760px;
    color:#655c52;
    font-size:17px;
    line-height:1.85;
}

/* Main cards */
.tour-intro__main,
.tour-intro__side,
.service-tabs,
.stickyCard{
    background:#fff;
    border:1px solid rgba(184,138,68,.10);
    border-radius:28px;
    padding:26px;
    box-shadow:0 14px 34px rgba(31,26,23,.05);
}

.tour-intro{
    display:grid;
    grid-template-columns:minmax(0,1fr) 330px;
    gap:28px;
    align-items:start;
    margin:30px 0 36px;
}

.tour-intro__main h2,
.included-head h2,
.availabilitySection h2{
    margin:0 0 14px;
    font-family:"Playfair Display", serif;
    font-size:32px;
    line-height:1.15;
    color:#241c16;
}

.tour-richtext,
.tab-panel,
.tab-panel p,
.tab-panel li{
    color:#5d534a;
    font-size:16px;
    line-height:1.9;
}

/* Summary */
.tour-summary-list{
    margin:0;
    padding:0;
    list-style:none;
    border-top:1px solid rgba(36,28,22,.08);
}

.tour-summary-list li{
    display:flex;
    justify-content:space-between;
    gap:16px;
    padding:14px 0;
    border-bottom:1px solid rgba(36,28,22,.08);
    color:#241c16;
}

.tour-summary-list li strong{
    color:#8d7b68;
    font-size:13px;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
}

/* Tabs */
.tabs-nav{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-bottom:26px;
}

.tab-btn{
    border:1px solid rgba(184,138,68,.16);
    background:transparent;
    color:#6b6158;
    border-radius:999px;
    padding:11px 18px;
    font-weight:600;
    cursor:pointer;
    transition:all .22s ease;
}

.tab-btn:hover{
    border-color:rgba(184,138,68,.28);
    color:#241c16;
}

.tab-btn.active{
    background:#2b1d14;
    color:#fff;
    border-color:#2b1d14;
}

.tab-panel{
    display:none;
}

.tab-panel.active{
    display:block;
}

/* Booking card */
.stickyCard{
    position:sticky;
    top:110px;
}

.priceWas{
    color:#9f9183;
    text-decoration:line-through;
    margin-bottom:8px;
    font-size:15px;
}

.priceNow{
    font-family:"Playfair Display", serif;
    font-size:46px;
    line-height:1;
    color:#241c16;
    font-weight:700;
}

.perPerson{
    color:#6e6358;
    font-size:14px;
}

.travRow{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:14px 0;
    border-bottom:1px solid rgba(36,28,22,.08);
}

.travRow:last-of-type{
    border-bottom:none;
}

.travRow > div:first-child{
    color:#3f362f;
    font-size:16px;
}

.stepper{
    display:flex;
    align-items:center;
    gap:12px;
}

.stepBtn{
    width:38px;
    height:38px;
    border:none;
    border-radius:50%;
    background:#b7aea5;
    color:#fff;
    font-size:20px;
    line-height:1;
    cursor:pointer;
}

.stepper span{
    min-width:12px;
    text-align:center;
    font-size:18px;
    color:#3f362f;
}

.totalLine{
    margin-top:14px;
    padding:14px 16px;
    border-radius:14px;
    border:1px solid rgba(184,138,68,.10);
    background:#ece3d8;
    color:#241c16;
    font-weight:600;
}

.smallMuted{
    color:#9b8f83;
    font-size:12px;
    margin-top:8px;
}

/* Trust */
.booking-trust{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:18px 0 20px;
}

.booking-trust__item{
    padding:12px 14px;
    border-radius:14px;
    background:#f7f1e8;
    border:1px solid rgba(184,138,68,.10);
    color:#6b6158;
    font-size:14px;
}

/* Availability */
.availabilitySection{
    margin-top:28px;
    padding:22px;
    border-radius:22px;
    border:1px solid rgba(184,138,68,.10);
    background:#fffaf4;
}

.availBar{
    display:flex;
    gap:14px;
    align-items:flex-end;
    flex-wrap:wrap;
    padding:14px;
    border-radius:16px;
    border:1px solid rgba(184,138,68,.10);
    background:#ece4da;
}

.availBar label{
    display:block;
    margin-bottom:6px;
    font-size:13px;
    color:#7d7064;
}

.availBar .input,
.travellersSummary{
    min-height:56px;
    border-radius:14px;
    border:1px solid rgba(184,138,68,.12);
    background:#9f9a95;
    color:#fff;
    padding:14px 16px;
}

.btnGold{
    min-height:56px;
    padding:0 24px;
    border:none;
    border-radius:999px;
    cursor:pointer;
    background:#d4a62a;
    color:#1f1a16;
    font-weight:700;
}

/* Related */
.related-tours{
    margin-top:72px;
}

.related-tours__head h2{
    margin:0 0 10px;
    font-family:"Playfair Display", serif;
    font-size:40px;
    line-height:1.1;
    color:#241c16;
}

.related-tour-card__title{
    margin:0;
    font-family:"Playfair Display", serif;
    font-size:28px;
    line-height:1.14;
}

/* Responsive */
@media (max-width:1100px){
    .page,
    .tour-intro{
        grid-template-columns:1fr;
    }

    .page{
        gap:36px;
    }

    .stickyCard{
        position:relative;
        top:auto;
    }
}

@media (max-width:760px){
    .page{
        padding:0 16px 52px;
    }

    .tour-hero__media{
        height:42vh;
        min-height:260px;
        max-height:360px;
    }

    .tour-hero__content{
        padding:30px 16px 24px;
    }

    .tour-hero__title{
        font-size:42px;
    }

    .tour-intro__main,
    .tour-intro__side,
    .service-tabs,
    .stickyCard{
        padding:20px;
    }

    .tour-intro__main h2,
    .included-head h2,
    .availabilitySection h2{
        font-size:28px;
    }

    .included-trigger{
        gap:16px;
        padding:18px 0;
    }

    .included-trigger__title{
        font-size:23px;
    }

    .included-icon{
        width:24px;
        flex-basis:24px;
        font-size:26px;
    }

    .related-tour-card__title{
        font-size:24px;
    }
}
body.home-page .home-carousel__nav{
    display:flex;
    gap:10px;
}

body.home-page .home-carousel__arrow{
    width:42px;
    height:42px;
    border:none;
    border-radius:999px;
    background:#f3eee6;
    color:#1f1a17;
    font-size:18px;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
}

body.home-page .home-carousel__arrow:disabled{
    opacity:.45;
    cursor:not-allowed;
}

body.home-page .home-carousel__track{
    display:flex;
    gap:24px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-behavior:smooth;
    scrollbar-width:none;
}

body.home-page .home-carousel__track::-webkit-scrollbar{
    display:none;
}
/* =========================
   Maison Atlas — Luxury CSS
   ========================= */

:root{
  --bg:#050606;
  --card:rgba(255,255,255,.05);
  --card2:rgba(255,255,255,.035);
  --text:#f3f0e8;
  --muted:rgba(243,240,232,.72);
  --line:rgba(255,255,255,.12);
  --gold:#c9a227;
  --gold2:#e7c85f;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:
    radial-gradient(1000px 600px at 15% 10%, rgba(201,162,39,.14), transparent 65%),
    radial-gradient(900px 700px at 85% 20%, rgba(231,200,95,.10), transparent 60%),
    radial-gradient(700px 500px at 50% 85%, rgba(255,255,255,.06), transparent 70%),
    var(--bg);
  line-height:1.6;
}

a{color:var(--text);text-decoration:none}
a:hover{color:var(--gold2)}
img{max-width:100%;display:block}

.container{
  width: min(1400px, 100%);
  margin: 0 auto;
  padding: 0 28px;
}

.container.full{
  width: 100%;
  max-width: none;
  padding: 0;
}

/* ===== NAV ===== */
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 2px 18px;
  border-bottom:1px solid var(--line);
}
.brand{
  font-weight:1000;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:14px;
  opacity:.95;
}
.nav a{
  margin-left:14px;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.nav a:hover{
  border-color:var(--line);
  background:rgba(255,255,255,.03);
}

/* ===== TYPO ===== */
.kicker{
  color:rgba(243,240,232,.62);
  letter-spacing:.25em;
  text-transform:uppercase;
  font-size:11px;
}
.h1{
  font-size:44px;
  line-height:1.08;
  font-weight:1000;
  margin:10px 0 0;
}
.h2{
  font-size:22px;
  font-weight:1000;
  margin:0;
}
.lead{
  color:var(--muted);
  font-size:16px;
  margin:10px 0 0;
}
.p{color:var(--muted);margin:8px 0}

/* ===== CARD / GRID ===== */
.card{
  background:linear-gradient(180deg, var(--card), var(--card2));
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px;
  box-shadow: var(--shadow);
}
.grid{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(3, 1fr);
}
@media(max-width:900px){
  .grid{grid-template-columns:1fr}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid transparent;
  background:linear-gradient(180deg, var(--gold2), var(--gold));
  color:#111;
  font-weight:1000;
  cursor:pointer;
}
.btn:hover{filter:brightness(1.03)}
.btn:active{transform:translateY(1px)}
.btnFull{width:100%}

/* ===== FORMS ===== */
.input{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.25);
  color:var(--text);
  margin-top:10px;
}
textarea.input{min-height:120px;resize:vertical}

/* ===== FOOTER ===== */
.footer{
  margin:28px 0 10px;
  color:rgba(243,240,232,.55);
  font-size:13px;
  text-align:center;
}

/* ===========================
   SERVICE DETAIL LUXURY LAYOUT
   =========================== */
.page{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:18px;
  align-items:start;
}
@media(max-width:900px){ .page{grid-template-columns:1fr} }

.heroCard{
  padding:20px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}

.metaRow{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:12px;
}
.pill{
  border:1px solid var(--line);
  padding:8px 12px;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  background:rgba(255,255,255,.03);
}
.pill strong{color:var(--text);font-weight:1000}

/* gallery like TourRadar */
.galleryGrid{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:12px;
  margin-top:14px;
}
.galleryGrid img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:14px;
  border:1px solid var(--line);
}
.galleryStack{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:12px;
}
@media(max-width:900px){
  .galleryGrid{grid-template-columns:1fr}
  .galleryStack{grid-template-rows:none;grid-template-columns:1fr 1fr}
}

.section{margin-top:16px}
.tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
  margin-top:14px;
}
.tabBtn{
  cursor:pointer;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
}
.tabBtn.active{
  background:linear-gradient(180deg, var(--gold2), var(--gold));
  color:#111;
  border-color:transparent;
}
.tabPanel{display:none}
.tabPanel.active{display:block}

/* itinerary cards */
.itinItem{
  display:grid;
  grid-template-columns:70px 1fr;
  gap:12px;
  padding:14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  margin-bottom:10px
}
.dayBadge{
  width:70px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(201,162,39,.15);
  border:1px solid rgba(201,162,39,.35);
  color:var(--text);
  font-weight:1000;
}
.smallMuted{color:var(--muted);font-size:13px;line-height:1.6}

/* highlights list */
.listCheck{margin:0;padding-left:18px}
.listCheck li{margin:6px 0;color:var(--muted)}
.listCheck li::marker{color:var(--gold)}

/* FAQ accordion */
.accordion{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.03)
}
.accItem{border-top:1px solid var(--line)}
.accItem:first-child{border-top:none}
.accBtn{
  width:100%;
  text-align:left;
  padding:14px;
  background:transparent;
  border:0;
  color:var(--text);
  font-weight:1000;
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
}
.accBody{
  display:none;
  padding:0 14px 14px;
  color:var(--muted);
}
.accItem.open .accBody{display:block}
.chev{opacity:.7}

/* sticky booking box */
.stickyCard{
  position:sticky;
  top:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  padding:16px;
  box-shadow: var(--shadow);
}
.priceBig{
  font-size:30px;
  font-weight:1000;
  margin:8px 0;
}
.hr{height:1px;background:var(--line);margin:14px 0}

/* TourRadar-style itinerary details */
.itinMeta{
  display:flex; gap:14px; flex-wrap:wrap;
  margin-top:10px;
}
.itinMeta .chip{
  display:flex; align-items:center; gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:13px;
}
.icon{
  width:18px; height:18px;
  display:inline-grid; place-items:center;
  border-radius:6px;
  background:rgba(201,162,39,.15);
  border:1px solid rgba(201,162,39,.35);
  color:var(--text);
  font-weight:1000;
}
.hero{
  width:100%;
  height: 62vh;
  min-height: 420px;
  max-height: 720px;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}

.hero img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.05) contrast(1.05);
}

.hero:after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75));
}

.heroInner{
  position:absolute; inset:0;
  z-index:2;
  display:flex;
  align-items:flex-end;
  padding: 42px;
}

.heroCard{
  max-width: 980px;
  background: rgba(12,12,12,.55);
  border:1px solid var(--line);
  border-radius:18px;
  padding:22px 22px;
  backdrop-filter: blur(10px);
}
/* ===== TourRadar-style itinerary ===== */
.itinCard{
  display:grid;
  grid-template-columns: 90px 1fr;
  gap:14px;
  padding:16px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  margin-top:12px;
}

.itinTitle{font-weight:1000;font-size:18px}
.itinTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}

.itinMeta{
  display:flex;align-items:center;gap:8px;
  color:var(--muted);
  font-size:13px;
  white-space:nowrap;
}

.itinText{color:var(--muted);margin-top:10px}

.itinRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.chip{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:13px;
}

.ico{
  width:22px;height:22px;
  border-radius:7px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(201,162,39,.14);
  border:1px solid rgba(201,162,39,.25);
  color:var(--text);
  font-size:12px;
}

.itinSubTitle{
  margin-top:12px;
  font-weight:1000;
  display:flex;
  align-items:center;
  gap:8px;
}

.itinList{margin:8px 0 0; padding-left:0; list-style:none}
.itinList li{
  display:flex; gap:10px;
  padding:6px 0;
  color:var(--muted);
}
.tick{
  width:18px;height:18px;
  border-radius:6px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(201,162,39,.14);
  border:1px solid rgba(201,162,39,.25);
  color:var(--text);
  font-weight:1000;
  flex:0 0 auto;
}
/* ===== TourRadar-like Availability UI (Luxury) ===== */
.availabilitySection{
  margin-top:24px;
  padding:20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.availabilitySection h2{
  margin:0 0 14px 0;
  font-size:24px;
  font-weight:900;
}

.availBar{
  display:flex;
  gap:14px;
  align-items:flex-end;
  flex-wrap:wrap;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.availBar label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin-bottom:6px;
}

.availBar .input{
  width:260px;
  max-width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
  outline:none;
}

.travellersSummary{
  min-width:220px;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
}

.btnGold{
  padding:12px 16px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  background:linear-gradient(180deg,#f1d36a,#c99a27);
  color:#111;
  font-weight:900;
}

.priceBreakdownCard{
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.priceBreakdownCard h3{
  margin:0 0 10px 0;
  font-size:16px;
  font-weight:900;
}

.pbRow{
  display:flex;
  justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:14px;
}

.pbTotal{
  display:flex;
  justify-content:space-between;
  padding-top:10px;
  margin-top:8px;
  font-size:18px;
  font-weight:900;
}

.sidePriceBox .dealBadge,
.dealBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(241,211,106,.35);
  background:rgba(241,211,106,.12);
  color:#f1d36a;
  font-weight:900;
  font-size:12px;
  margin-bottom:10px;
}

.sideControls label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin:10px 0 6px;
}

.travRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.stepper{
  display:flex;
  align-items:center;
  gap:10px;
}

.stepBtn{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  color:#fff;
  font-size:18px;
  cursor:pointer;
}

.totalLine{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
}
.smallMuted{font-size:12px;opacity:.7;}
.priceWas{opacity:.6;text-decoration:line-through;margin-bottom:6px;}
.priceNow{font-size:28px;font-weight:1000;line-height:1;}
.perPerson{font-size:13px;opacity:.75;margin-left:6px;}
/* ===== TourRadar-like Availability UI (Luxury) ===== */
.availabilitySection{
  margin-top:24px;
  padding:20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.availabilitySection h2{
  margin:0 0 14px 0;
  font-size:24px;
  font-weight:900;
}

.availBar{
  display:flex;
  gap:14px;
  align-items:flex-end;
  flex-wrap:wrap;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.availBar label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin-bottom:6px;
}


.availBar .input{
  width:260px;
  max-width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
  outline:none;
}

.travellersSummary{
  min-width:220px;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  color:#fff;
}

.btnGold{
  padding:12px 16px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  background:linear-gradient(180deg,#f1d36a,#c99a27);
  color:#111;
  font-weight:900;
}

.priceBreakdownCard{
  margin-top:14px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.priceBreakdownCard h3{
  margin:0 0 10px 0;
  font-size:16px;
  font-weight:900;
}

.pbRow{
  display:flex;
  justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-size:14px;
}

.pbTotal{
  display:flex;
  justify-content:space-between;
  padding-top:10px;
  margin-top:8px;
  font-size:18px;
  font-weight:900;
}

.sidePriceBox .dealBadge,
.dealBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(241,211,106,.35);
  background:rgba(241,211,106,.12);
  color:#f1d36a;
  font-weight:900;
  font-size:12px;
  margin-bottom:10px;
}

.sideControls label{
  display:block;
  font-size:12px;
  opacity:.75;
  margin:10px 0 6px;
}

.travRow{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.stepper{
  display:flex;
  align-items:center;
  gap:10px;
}

.stepBtn{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  color:#fff;
  font-size:18px;
  cursor:pointer;
}

.totalLine{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
}
.smallMuted{font-size:12px;opacity:.7;}
.priceWas{opacity:.6;text-decoration:line-through;margin-bottom:6px;}
.priceNow{font-size:28px;font-weight:1000;line-height:1;}
.perPerson{font-size:13px;opacity:.75;margin-left:6px;}
.hero { position: relative; overflow: hidden; }

.hero{
  position: relative !important;
  height: 600px !important;      /* try 520 / 600 / 700 */
  overflow: hidden !important;
}

.heroMedia{
  position:absolute !important;
  inset:0 !important;
}

.heroMedia img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  display:block !important;
}
/* ===== Related Tours (MATCHES maRel1 / maRel__grid) ===== */

.maRel1{
  margin-top: 60px;
}

.maRel__title{
  font-size: 28px;
  font-weight: 800;
  margin: 0 0 22px;
}

/* GRID */
.maRel__grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch;
}

@media (max-width: 1100px){
  .maRel__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px){
  .maRel__grid{
    grid-template-columns: 1fr !important;
  }
}

/* ===== Card (hpCard) ===== */

.hpCard{
  display:block !important;
  text-decoration:none !important;
  color:#fff !important;
  border-radius:24px !important;
  overflow:hidden !important;
  background: rgba(15,15,15,.85) !important;
  border: 1px solid rgba(212,175,55,.18) !important;
  box-shadow: 0 20px 70px rgba(0,0,0,.35) !important;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease !important;
}

.hpCard:hover{
  transform: translateY(-6px) !important;
  box-shadow: 0 28px 85px rgba(0,0,0,.45) !important;
  border-color: rgba(212,175,55,.35) !important;
}

.hpCard__media{
  position:relative !important;
  height: 210px !important;
  background:#111 !important;
}

.hpCard__media img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
  transition: transform .4s ease !important;
}

.hpCard:hover .hpCard__media img{
  transform: scale(1.07) !important;
}

.hpCard__overlay{
  position:absolute !important;
  inset:0 !important;
  background:
    radial-gradient(circle at 50% 20%, rgba(255,215,140,.20), transparent 60%),
    linear-gradient(to top, rgba(0,0,0,.85), rgba(0,0,0,.15)) !important;
}

.hpCard__price{
  position:absolute !important;
  left:18px !important;
  bottom:18px !important;
  padding:10px 14px !important;
  border-radius:999px !important;
  background: rgba(0,0,0,.75) !important;
  font-weight:800 !important;
  font-size:13px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  backdrop-filter: blur(6px) !important;
}

.hpCard__body{
  padding: 18px 18px 20px !important;
}

.hpCard__title{
  font-weight: 850 !important;
  line-height: 1.2 !important;
  margin-bottom: 8px !important;

  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  min-height: 40px !important;
}
.hpCard__desc{
  font-size: 13px !important;
  color: rgba(255,255,255,.78) !important;
  line-height: 1.5 !important;
  margin-bottom: 14px !important;

  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  min-height: 36px !important;
}

.hpCard__pills{
  display:flex !important;
  gap:8px !important;
  flex-wrap:wrap !important;
  margin-bottom: 14px !important;
}

.hpPill{
  font-size: 12px !important;
  padding: 7px 11px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.95) !important;
}
.heroCard{
  position: absolute;
  left: 60px;
  bottom: 60px;
  z-index: 5;
  max-width: 820px;
  padding: 28px 34px;
  border-radius: 22px;
  background: rgba(0,0,0,.35);
  box-shadow: 0 25px 70px rgba(0,0,0,.55);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.08);
}

.heroCard .kicker{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .75;
  color: #f3c06b;
  margin-bottom: 14px;
  font-weight: 600;
}

.heroCard .hero-title{
  font-size: clamp(24px, 2.5vw, 36px);
  font-weight: 600;
  line-height: 1.2;
  margin: 0;
  color: #ffffff;
}


.heroCard .lead{
  margin-top: 18px;
  font-size: 16px;
  color: rgba(255,255,255,.85);
  max-width: 650px;
  line-height: 1.6;
}
.heroCard .hero-title::after{
  content:"";
  display:block;
  width: 70px;
  height: 3px;
  margin-top: 18px;
  background: linear-gradient(90deg, #e7c27a, #d4a64f);
  border-radius: 2px;
}
.service-tabs { margin-top: 18px; }

.tabs-nav{
  display:flex;
  gap:10px;
  margin-bottom:14px;
}

.tab-btn{
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color:#fff;
  padding:8px 14px;
  border-radius:10px;
  cursor:pointer;
  font-weight:700;
}

.tab-btn.active{
  background:#c9a227;
  border-color:#c9a227;
  color:#111;
}

.tab-panel{ display:none; }
.tab-panel.active{ display:block; }
.maRel__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:24px;
}
.maCard{
  border-radius:24px;
  overflow:hidden;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.maCard__media{ position:relative; height:180px; overflow:hidden; }
.maCard__img{ width:100%; height:100%; object-fit:cover; display:block; }
.maCard__badge{
  position:absolute; left:16px; top:16px;
  padding:8px 12px; border-radius:999px;
  background: rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.15);
}
.maCard__body{ padding:18px; }
.maCard__cta{
  margin-top:14px;
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  background:#c9a227;
  color:#111;
  font-weight:700;
}
/* Related tours - normalize card images */
.maCard__media{
  height: 220px;
  overflow: hidden;
  border-radius: 24px;
}

.maCard__img{
  width: 100%;
  height: 100%;
  object-fit: cover;  /* crop portrait images */
  display: block;
}
/* Related Tours - force same card image size */
.maRel__imgWrap{
  height: 180px;         /* choose 160-220 if you want */
  overflow: hidden;
  border-radius: 18px;
}

.maRel__imgWrap img{
  width: 100%;
  height: 100%;
  object-fit: cover;     /* IMPORTANT: prevents tall portrait images */
  display: block;
}
/* ===== Related Tours (stable card UI) ===== */
.relatedTours { margin: 40px 0 10px; }
.relatedTours__title { font-size: 28px; margin: 0 0 18px; }

.relatedTours__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.relatedCard{
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.relatedCard__imgWrap{
  display:block;
  position:relative;
  height: 210px;
  overflow:hidden;
}

.relatedCard__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.relatedCard__price{
  position:absolute;
  left:14px;
  top:14px;
  padding:6px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 12px;
}

.relatedCard__body{
  padding: 14px 14px 16px;
}

.relatedCard__h3{
  font-size: 16px;
  margin: 0 0 8px;
  line-height: 1.3;
}
.relatedCard__h3 a{ text-decoration:none; }

.relatedCard__p{
  margin: 0 0 12px;
  opacity: .85;
  font-size: 13px;
  line-height: 1.45;
}

.relatedCard__btn{
  display:inline-block;
  padding: 10px 14px;
  border-radius: 999px;
  background: #c9a227;
  color: #111;
  font-weight: 700;
  text-decoration:none;
}
.relatedCard__btn:hover{ filter: brightness(1.05); }

@media (max-width: 1000px){
  .relatedTours__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .relatedTours__grid{ grid-template-columns: 1fr; }
  .relatedCard__imgWrap{ height: 190px; }
}
.article-hero {
  position: relative;
  padding: 40px;
  border-radius: 24px;
  background: linear-gradient(
      135deg,
      rgba(214,170,67,0.15),
      rgba(20,20,20,0.8)
  );
  border: 1px solid rgba(214,170,67,.25);
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
}

.hero-title {
  font-size: 58px;
  font-weight: 800;
  letter-spacing: -1px;
}
.prose {
  font-size: 18px;
  line-height: 2;
  max-width: 750px;
}

.content-card {
  padding: 50px;
  background: rgba(22,22,22,.8);
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.06);
}


.side-box {
  background: rgba(30,30,30,.7);
  border: 1px solid rgba(214,170,67,.15);
}
.article-hero {
  background: none;
  border: none;
  box-shadow: none;
  padding: 60px 0 40px;
}

.hero-title {
  font-size: 64px;
  font-weight: 800;
  letter-spacing: -2px;
  margin-bottom: 20px;
}

.article-hero .meta-line {
  font-size: 13px;
  opacity: .6;
  margin-bottom: 14px;
}
.hero-title::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  margin-top: 18px;
  background: linear-gradient(90deg, #d6aa43, transparent);
  border-radius: 2px;
}
/* ========================================
/* =========================================================
   SERVICE PAGE – TOURRADAR INSPIRED
   ========================================================= */

body.tour-page {
    background: #f8f6f3 !important;
    color: #2c2c2c;
}

/* Hero section */
.tour-hero {
    background: #ffffff;
    border-bottom: 1px solid #eae6e0;
    margin-bottom: 24px;
}
.tour-hero__media {
    height: 480px;
}
.tour-hero__content-wrap {
    background: #ffffff;
}
.tour-hero__content {
    padding: 32px 0;
}
.tour-hero__eyebrow {
    color: #b87a4b;
    font-size: 12px;
    letter-spacing: 2px;
}
.tour-hero__title {
    font-size: 42px;
    font-weight: 700;
    color: #1e1e1e;
    margin: 8px 0 16px;
}
.tour-hero__text {
    font-size: 16px;
    line-height: 1.6;
    color: #5f5b56;
}
.tour-hero__facts {
    gap: 16px;
    margin-top: 24px;
}
.tour-hero__fact {
    background: #faf8f5;
    border: 1px solid #eae6e0;
    border-radius: 12px;
    padding: 12px 16px;
    min-width: auto;
}
.tour-hero__fact strong {
    color: #1e1e1e;
    font-size: 18px;
}
.tour-hero__fact span {
    color: #7e7a74;
    font-size: 12px;
}

/* Main layout – two columns */
.page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px 60px;
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) 340px;
    gap: 40px;
}
@media (max-width: 900px) {
    .page {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}

/* Left column – cards */
.service-tabs,
.tour-intro__main {
    background: #ffffff;
    border-radius: 20px;
    border: 1px solid #eae6e0;
    padding: 24px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.04);
}

/* Tabs */
.tabs-nav {
    border-bottom: 1px solid #eae6e0;
    padding-bottom: 8px;
    margin-bottom: 24px;
}
.tab-btn {
    background: transparent;
    border: none;
    color: #7e7a74;
    font-weight: 600;
    padding: 10px 20px;
    border-radius: 40px;
    font-size: 15px;
    transition: all 0.2s;
}
.tab-btn:hover {
    background: #f2eee9;
    color: #1e1e1e;
}
.tab-btn.active {
    background: #1e1e1e;
    color: #ffffff;
}

/* Content */
.tour-richtext {
    font-size: 16px;
    line-height: 1.7;
    color: #3a3a3a;
}
.tour-richtext h2 {
    font-size: 26px;
    margin-top: 1.8em;
    margin-bottom: 0.8em;
    color: #1e1e1e;
}
.tour-richtext h3 {
    font-size: 20px;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    color: #1e1e1e;
}
.tour-richtext p {
    margin-bottom: 1.2em;
}

/* Itinerary & FAQ cards */
.itinerary-item, .faq-item {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 16px;
    margin-bottom: 16px;
    padding: 20px;
}
.itinerary-item h3, .faq-item h3 {
    font-size: 20px;
    margin-top: 0;
    margin-bottom: 8px;
    color: #1e1e1e;
}
.itinerary-item__day {
    color: #b87a4b;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    margin-bottom: 8px;
}

/* What's Included accordion */
.included-section {
    margin-top: 24px;
}
.included-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.included-head h2 {
    font-size: 26px;
    margin: 0;
}
.included-toggle-all {
    color: #b87a4b;
    font-weight: 600;
    background: none;
    border: none;
    cursor: pointer;
}
.included-accordion {
    border-top: 1px solid #eae6e0;
}
.included-item {
    border-bottom: 1px solid #eae6e0;
}
.included-trigger {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 0;
    background: none;
    border: none;
    cursor: pointer;
}
.included-trigger__title {
    font-weight: 600;
    font-size: 18px;
    color: #1e1e1e;
}
.included-icon {
    font-size: 24px;
    color: #b87a4b;
}
.included-panel {
    padding-bottom: 18px;
    color: #5f5b56;
    line-height: 1.7;
}

/* Right column – sticky booking card */
.stickyCard {
    position: sticky;
    top: 20px;
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 24px;
    padding: 24px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}
.kicker {
    color: #b87a4b;
    font-size: 12px;
    letter-spacing: 1px;
    margin-bottom: 12px;
}
.priceNow {
    font-size: 38px;
    font-weight: 800;
    color: #1e1e1e;
    margin: 8px 0;
}
.perPerson {
    font-size: 14px;
    color: #7e7a74;
}
.priceWas {
    color: #9c9790;
    text-decoration: line-through;
    font-size: 14px;
}
.dealBadge {
    background: #fff0e5;
    color: #b87a4b;
    padding: 4px 12px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 600;
    display: inline-block;
    margin-bottom: 12px;
}
.travRow {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid #eae6e0;
}
.stepper {
    display: flex;
    align-items: center;
    gap: 12px;
}
.stepBtn {
    width: 32px;
    height: 32px;
    border-radius: 30px;
    background: #f2eee9;
    border: none;
    font-size: 18px;
    cursor: pointer;
    color: #1e1e1e;
}
.totalLine {
    background: #faf8f5;
    padding: 12px;
    border-radius: 12px;
    margin: 16px 0;
    font-weight: 600;
    color: #1e1e1e;
}
.booking-trust {
    margin: 20px 0;
}
.booking-trust__item {
    background: #faf8f5;
    padding: 12px;
    border-radius: 12px;
    margin-bottom: 8px;
    font-size: 13px;
    color: #5f5b56;
}
.stickyCard .input {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 12px;
    padding: 12px;
    width: 100%;
    margin-bottom: 12px;
}
.stickyCard .btnFull {
    background: #b87a4b;
    color: #ffffff;
    border: none;
    border-radius: 40px;
    padding: 14px;
    width: 100%;
    font-weight: 600;
    cursor: pointer;
}
.stickyCard .btnFull:hover {
    background: #9e643c;
}

/* Availability section */
.availabilitySection {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 24px;
    padding: 24px;
    margin-top: 24px;
}
.availabilitySection h2 {
    font-size: 24px;
    margin-bottom: 16px;
}
.availBar {
    background: #faf8f5;
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: flex-end;
}
.availBar .input,
.travellersSummary {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 12px;
    padding: 10px;
}
.btnGold {
    background: #b87a4b;
    border: none;
    border-radius: 40px;
    padding: 10px 20px;
    color: #ffffff;
    font-weight: 600;
}
.departureCard {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 20px;
    padding: 16px;
    margin-bottom: 12px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
    align-items: center;
}
.departureCard label {
    font-size: 12px;
    color: #7e7a74;
}
.departureCard strong {
    font-size: 14px;
    color: #1e1e1e;
}

/* Journey summary */
.tour-intro__side {
    margin-top: 24px;
}
.tour-summary-card {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 20px;
    padding: 20px;
}
.tour-section-eyebrow {
    color: #b87a4b;
    font-size: 12px;
    letter-spacing: 1px;
}
.tour-summary-list {
    margin-top: 12px;
    list-style: none;
    padding: 0;
}
.tour-summary-list li {
    display: flex;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid #eae6e0;
    color: #5f5b56;
}
.tour-summary-list li strong {
    color: #1e1e1e;
    font-weight: 600;
}

/* Related tours (optional, adjust if needed) */
.related-tours {
    margin-top: 60px;
}
.related-tours__head h2 {
    font-size: 28px;
}
.related-tours__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.related-tour-card {
    border: 1px solid #eae6e0;
    border-radius: 20px;
    background: #ffffff;
    overflow: hidden;
}
.related-tour-card__media {
    height: 200px;
}
.related-tour-card__title a {
    color: #1e1e1e;
    font-weight: 600;
}
.related-tour-card__excerpt {
    color: #5f5b56;
}
.related-tour-card__link {
    color: #b87a4b;
}
@media (max-width: 800px) {
    .related-tours__grid {
        grid-template-columns: 1fr;
    }
}
/* =========================================================
   REVIEWS – ELEGANT STYLE
   ========================================================= */

/* Overall reviews section */
.reviews-section {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid #eae6e0;
}
.reviews-section .tour-section-eyebrow {
    font-size: 12px;
    letter-spacing: 1.5px;
    color: #b87a4b;
    display: block;
    margin-bottom: 12px;
}

/* Summary (average rating) */
.reviews-summary {
    text-align: center;
    margin-bottom: 28px;
    background: #fefbf7;
    padding: 20px;
    border-radius: 24px;
    border: 1px solid #f0e7db;
}
.avg-rating {
    font-size: 48px;
    font-weight: 800;
    color: #1e1e1e;
    line-height: 1;
}
.avg-rating .rating-stars {
    font-size: 20px;
    letter-spacing: 2px;
    margin-left: 8px;
    vertical-align: middle;
}
.review-count {
    font-size: 14px;
    color: #7e7a74;
    margin-left: 8px;
}

/* Individual review cards */
.reviews-list {
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.review-card {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 20px;
    padding: 20px;
    transition: box-shadow 0.2s;
}
.review-card:hover {
    box-shadow: 0 6px 18px rgba(0,0,0,0.05);
}
.review-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 12px;
}
.reviewer-name {
    font-weight: 700;
    font-size: 16px;
    color: #1e1e1e;
}
.small-stars {
    font-size: 14px;
    color: #f5b042;
    letter-spacing: 1px;
}
.review-title {
    margin: 0 0 10px;
    font-size: 18px;
    font-weight: 600;
    color: #1e1e1e;
}
.review-content {
    font-size: 15px;
    line-height: 1.65;
    color: #5f5b56;
    margin-bottom: 12px;
}
.review-date {
    font-size: 12px;
    color: #9c9790;
    margin-top: 8px;
}

/* Operator reply */
.review-operator-reply {
    margin-top: 16px;
    padding: 14px 16px;
    background: #faf8f5;
    border-left: 3px solid #b87a4b;
    border-radius: 12px;
    font-size: 14px;
    color: #5f5b56;
    line-height: 1.6;
}
.review-operator-reply strong {
    display: block;
    margin-bottom: 6px;
    color: #b87a4b;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* See all reviews link */
.see-all-reviews {
    display: inline-block;
    margin-top: 20px;
    font-size: 14px;
    font-weight: 600;
    color: #b87a4b;
    text-decoration: none;
    border-bottom: 1px solid #b87a4b;
}
.see-all-reviews:hover {
    color: #9e643c;
    border-bottom-color: #9e643c;
}
/* =========================================================
   OPEN AVAILABILITY – ELEGANT LAYOUT
   ========================================================= */

.open-availability {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 24px;
    padding: 24px;
    margin: 24px 0;
}

.open-availability__row {
    display: flex;
    flex-wrap: nowrap; /* force all items on one line on desktop */
    gap: 20px;
    align-items: flex-end;
    margin-bottom: 16px;
}

.open-availability__field {
    flex: 1;
    min-width: 0; /* allow shrinking */
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* Button field – don't stretch */
.open-availability__field:last-child {
    flex: 0 0 auto;
    min-width: auto;
}

.open-availability__field label {
    font-size: 12px;
    font-weight: 500;
    color: #7e7a74;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0;
}

.open-availability__input {
    width: 100%;
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 14px;
    padding: 12px 14px;
    font-size: 14px;
    color: #1e1e1e;
    box-sizing: border-box;
    transition: border-color 0.2s;
}
.open-availability__input:focus {
    border-color: #b87a4b;
    outline: none;
    box-shadow: 0 0 0 2px rgba(184,122,75,0.1);
}
.open-availability__end {
    background: #faf8f5;
    cursor: default;
}

.travellersSummary {
    background: #ffffff;
    border: 1px solid #eae6e0;
    border-radius: 14px;
    padding: 12px 14px;
    font-size: 14px;
    font-weight: 500;
    color: #1e1e1e;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}

.open-availability__cta {
    background: #b87a4b;
    border: none;
    border-radius: 40px;
    padding: 12px 24px;
    font-weight: 600;
    color: #ffffff;
    cursor: pointer;
    transition: background 0.2s;
    white-space: nowrap;
}
.open-availability__cta:hover {
    background: #9e643c;
}
.open-availability__cta:active {
    transform: translateY(1px);
}

.open-availability__note {
    font-size: 12px;
    color: #9c9790;
    text-align: center;
    margin-top: 12px;
}

/* Responsive */
@media (max-width: 800px) {
    .open-availability__row {
        flex-wrap: wrap;
    }
    .open-availability__field {
        min-width: 160px;
        flex: 1 1 auto;
    }
    .open-availability__field:last-child {
        flex: 1 1 auto;
    }
    .open-availability__cta {
        width: 100%;
        white-space: normal;
    }
}
.open-availability__row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    align-items: end;
    margin-bottom: 16px;
}
.open-availability__field:last-child {
    grid-column: 1 / -1; /* button spans full width */
    display: flex;
    justify-content: center; /* center the button horizontally */
}
.open-availability__field:last-child .open-availability__cta {
    width: auto;
    min-width: 200px; /* optional, ensures button not too small */
}
/* Itinerary day details – TourRadar style */
.day-description {
    font-size: 15px;
    line-height: 1.65;
    color: #5f5b56;
    margin-bottom: 16px;
}
.day-times {
    display: flex;
    gap: 8px;
    align-items: center;
    background: #faf8f5;
    padding: 8px 12px;
    border-radius: 12px;
    margin-bottom: 12px;
    font-size: 14px;
    color: #1e1e1e;
}
.day-time-arrow {
    color: #b87a4b;
}
.day-meals {
    background: #faf8f5;
    padding: 8px 12px;
    border-radius: 12px;
    margin-bottom: 12px;
    font-size: 14px;
}
.day-meals strong {
    color: #b87a4b;
}
.day-included {
    margin-top: 12px;
}
.day-included strong {
    display: block;
    font-size: 14px;
    color: #1e1e1e;
    margin-bottom: 8px;
}
.day-included ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.day-included li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 8px;
    font-size: 14px;
    color: #5f5b56;
    line-height: 1.5;
}
.day-included li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #b87a4b;
}
/* Language switcher */--------------------------------------------------
/* Language switcher – simple select */
.language-switcher {
    display: inline-block;
    margin-left: 20px;
}
.language-switcher select {
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 30px;
    padding: 6px 12px;
    color: inherit;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s;
}
.language-switcher select:hover {
    background: rgba(255,255,255,0.2);
}
.language-switcher select option {
    background: #fff;
    color: #1e1e1e;
}
@media (max-width: 700px) {
    .language-switcher {
        margin-left: 10px;
    }
    .language-switcher select {
        padding: 4px 10px;
        font-size: 12px;
    }
}
/* Language switcher */
.language-switcher {
    display: inline-block;
    margin-left: 20px;
}
.language-switcher select {
    background: rgba(0,0,0,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 30px;
    padding: 6px 12px;
    color: inherit;
    font-size: 14px;
    cursor: pointer;
}
.language-switcher select option {
    background: #fff;
    color: #1e1e1e;
}
@media (max-width: 700px) {
    .language-switcher select {
        padding: 4px 10px;
        font-size: 12px;
    }
}