/* ================================================================
   MaxiTravel v2 — motor override
   Applies LAST after all legacy CSS. All !important is intentional.
   DOM verified from live server output.
   ================================================================ */

:root {
  --navy:        #0d192e;
  --navy-mid:    #112240;
  --navy-dark:   #060e1e;
  --teal:        #3db3a5;
  --teal-dark:   #2a9488;
  --teal-glow:   rgba(61,179,165,.18);
  --gold:        #eda23b;
  --gold-light:  rgba(237,162,59,.12);
  --white:       #ffffff;
  --off-white:   #f4f6f9;
  --text:        #1a2744;
  --text-light:  #4a5568;
  --text-muted:  #8896aa;
  --border:      #e2e8f0;
  --card-shadow: 0 2px 24px rgba(13,25,46,.08);
  --radius-sm:   8px;
  --radius:      12px;
  --radius-lg:   18px;
  --ease:        cubic-bezier(.4,0,.2,1);
}

/* ----------------------------------------------------------------
   BASE RESET
   ---------------------------------------------------------------- */
* { box-sizing: border-box; }

html, body {
  background: var(--off-white) !important;
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
  color: var(--text) !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}

.total_body {
  background: transparent !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  min-height: 100vh !important;
}

.section_content {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  float: none !important;
}

/* ----------------------------------------------------------------
   HIDE LEGACY ELEMENTS
   ---------------------------------------------------------------- */
.menu_box, .menu_back, .menu_content,
.temperature_box, .corner_menu,
.credit_box, .footer_box,
.spacer_prefoot, .prefooter,
.footer_blue, .footer_blue_wrap,
.footer_page,
.top_header_shadow, .shadow_header,
.header_section,
.paynow_img,
.basic_tittle_content { display: none !important; }

/* ----------------------------------------------------------------
   NAV
   ---------------------------------------------------------------- */
.mxt-nav {
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  z-index: 9999 !important;
  background: var(--navy) !important;
  height: 64px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 48px !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.06), 0 4px 32px rgba(0,0,0,.4) !important;
}

.mxt-nav-spacer {
  height: 64px !important;
  display: block !important;
}

.mxt-logo img {
  height: 36px !important;
  width: auto !important;
  display: block !important;
}

.mxt-links {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

.mxt-links li { margin: 0 !important; padding: 0 !important; }

.mxt-links a,
.mxt-links a:visited {
  color: rgba(255,255,255,.75) !important;
  text-decoration: none !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: .3px !important;
  padding: 8px 14px !important;
  border-radius: var(--radius-sm) !important;
  transition: color .2s var(--ease), background .2s var(--ease) !important;
  display: block !important;
}

.mxt-links a:hover { color: var(--white) !important; background: rgba(255,255,255,.08) !important; }

.mxt-btn-contact,
.mxt-btn-contact:visited {
  background: var(--teal) !important;
  color: var(--white) !important;
  font-weight: 700 !important;
  letter-spacing: .6px !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
}

.mxt-btn-contact:hover { background: var(--teal-dark) !important; color: var(--white) !important; }

.mxt-cart,
.mxt-cart:visited {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  color: rgba(255,255,255,.7) !important;
  font-size: 13px !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: var(--radius-sm) !important;
  padding: 8px 14px !important;
  transition: all .2s var(--ease) !important;
  white-space: nowrap !important;
}

.mxt-cart:hover { border-color: var(--teal) !important; color: var(--teal) !important; }

.mxt-cart-full { border-color: var(--gold) !important; color: var(--gold) !important; }

.mxt-cart-count {
  background: var(--gold) !important;
  color: var(--navy) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 10px !important;
  border-radius: 99px !important;
  padding: 2px 7px !important;
  line-height: 1.4 !important;
}

.mxt-hamburger {
  display: none !important;
  flex-direction: column !important;
  gap: 5px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 8px !important;
}

.mxt-hamburger span {
  display: block !important;
  width: 22px !important;
  height: 2px !important;
  background: var(--white) !important;
  border-radius: 2px !important;
  transition: transform .25s var(--ease) !important;
}

/* ----------------------------------------------------------------
   TOUR DETAIL — HERO
   ---------------------------------------------------------------- */
.header_pic {
  height: 420px !important;
  background-size: cover !important;
  background-position: center !important;
  position: relative !important;
  display: block !important;
}

.header_pic::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(160deg, rgba(6,14,30,.2) 0%, rgba(6,14,30,.65) 100%) !important;
  pointer-events: none !important;
}

/* ----------------------------------------------------------------
   TOUR DETAIL — MAIN LAYOUT
   ---------------------------------------------------------------- */
.content_tour_detail {
  max-width: 1160px !important;
  margin: 0 auto !important;
  padding: 48px 40px 0 !important;
  background: transparent !important;
}

.detail_tour {
  display: grid !important;
  grid-template-columns: 260px 1fr !important;
  gap: 36px !important;
  align-items: start !important;
  float: none !important;
  width: 100% !important;
}

/* Left: info card */
.basic_info_box {
  background: var(--white) !important;
  border-radius: var(--radius-lg) !important;
  padding: 28px 24px !important;
  box-shadow: var(--card-shadow) !important;
  border-top: 4px solid var(--teal) !important;
  position: sticky !important;
  top: 80px !important;
  float: none !important;
}

.basic_info_content { margin-top: 0 !important; }

.duration_detail,
.location_detail,
.age_detail {
  padding: 14px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

.age_detail { border-bottom: none !important; }

.icon.time_icon_detail,
.icon.pin_icon_detail,
.icon.user_icon_detail {
  font-size: 18px !important;
  color: var(--teal) !important;
  flex-shrink: 0 !important;
  width: 20px !important;
}

.detail_tour_title {
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 10px !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  color: var(--text-muted) !important;
  display: block !important;
  width: 100% !important;
  margin-bottom: 2px !important;
}

.detail_info {
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  display: block !important;
}

/* Right: description */
.description_tour {
  float: none !important;
  width: 100% !important;
}

.description_tour_tittle {
  font-family: 'Montserrat', sans-serif !important;
  font-size: clamp(26px, 4vw, 38px) !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  margin: 0 0 18px !important;
  letter-spacing: -.8px !important;
  line-height: 1.15 !important;
}

.description_tour_content {
  font-size: 16px !important;
  line-height: 1.75 !important;
  color: var(--text-light) !important;
  margin-bottom: 28px !important;
}

.col_content_box {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 !important;
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  margin-bottom: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 1px 6px rgba(13,25,46,.06) !important;
  float: none !important;
  width: 100% !important;
}

.col_description_content {
  padding: 18px 22px !important;
  border-right: 1px solid var(--border) !important;
  float: none !important;
  width: auto !important;
}

.col_description_content:last-child { border-right: none !important; }

.sub_tittle_content {
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 9px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  display: block !important;
  margin-bottom: 6px !important;
}

.hour_tittle {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  display: block !important;
}

.include_text_tours {
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: var(--text-light) !important;
  margin-top: 4px !important;
}

/* Gallery */
.rotator_wrap {
  margin-top: 24px !important;
  border-radius: var(--radius) !important;
  overflow: hidden !important;
  box-shadow: var(--card-shadow) !important;
}

.rotator_box { background: #000 !important; }

#image-gallery { margin: 0 !important; }

/* ----------------------------------------------------------------
   BOOKING WIDGET (tours_reservation_box)
   ---------------------------------------------------------------- */
.tours_reservation_box {
  margin: 40px 0 0 !important;
  background: var(--navy) !important;
  border-radius: var(--radius-lg) !important;
  padding: 36px 40px !important;
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  gap: 40px !important;
  align-items: center !important;
  box-shadow: 0 8px 40px rgba(6,14,30,.3) !important;
  float: none !important;
  clear: both !important;
  width: 100% !important;
}

.price_detail_box {
  text-align: center !important;
  padding-right: 40px !important;
  border-right: 1px solid rgba(255,255,255,.1) !important;
  flex-shrink: 0 !important;
}

.price_detail_content {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 44px !important;
  font-weight: 900 !important;
  color: var(--gold) !important;
  line-height: 1 !important;
  letter-spacing: -1px !important;
  display: block !important;
}

.price_unit_detail {
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.45) !important;
  margin-top: 8px !important;
  display: block !important;
}

.form_reservation_box { width: 100% !important; }

.reserve_tittle {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  margin-bottom: 16px !important;
  display: block !important;
}

form.form-style-5 {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr auto !important;
  gap: 12px !important;
  align-items: end !important;
  margin: 0 !important;
  padding: 0 !important;
}

.field_box {
  display: flex !important;
  flex-direction: column !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  width: auto !important;
}

form.form-style-5 select,
form.form-style-5 input.field_reserve,
form.form-style-5 input[type="text"].field_reserve {
  width: 100% !important;
  padding: 13px 16px !important;
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  color: var(--white) !important;
  appearance: auto !important;
  -webkit-appearance: auto !important;
  transition: border-color .2s var(--ease), background .2s var(--ease) !important;
  height: 50px !important;
}

form.form-style-5 select option { background: var(--navy-dark) !important; color: var(--white) !important; }

form.form-style-5 select:focus,
form.form-style-5 input.field_reserve:focus {
  outline: none !important;
  border-color: var(--teal) !important;
  background: rgba(61,179,165,.1) !important;
}

form.form-style-5 select::placeholder,
form.form-style-5 input.field_reserve::placeholder {
  color: rgba(255,255,255,.4) !important;
}

/* The hidden field_box that wraps the other_option div */
.field_box:has(> div:empty),
.field_box:has(> div#other_option:empty) {
  display: none !important;
}

input.reserve_button {
  background: var(--teal) !important;
  color: var(--white) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 0 32px !important;
  height: 50px !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background .2s var(--ease), transform .1s var(--ease), box-shadow .2s var(--ease) !important;
  box-shadow: 0 4px 20px rgba(61,179,165,.3) !important;
}

input.reserve_button:hover {
  background: var(--teal-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 28px rgba(61,179,165,.4) !important;
}

input.reserve_button:active { transform: translateY(0) !important; }

/* ----------------------------------------------------------------
   REVIEWS
   ---------------------------------------------------------------- */
.box_reviews {
  margin-top: 56px !important;
  padding-bottom: 0 !important;
  float: none !important;
  clear: both !important;
}

.review_tittle {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  margin-bottom: 24px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--border) !important;
}

.review_item {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  padding: 24px 28px !important;
  margin-bottom: 16px !important;
  box-shadow: 0 1px 8px rgba(13,25,46,.06) !important;
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 16px !important;
  align-items: start !important;
}

.review_picture {
  width: 56px !important;
  flex-shrink: 0 !important;
}

.review_picture img {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  display: block !important;
}

.stars_box {
  grid-column: 1 / -1 !important;
  margin-bottom: 10px !important;
}

.stars_box .icon-star { color: var(--gold) !important; font-size: 14px !important; margin-right: 2px !important; }
.stars_box .icon-star-o { color: var(--border) !important; font-size: 14px !important; margin-right: 2px !important; }

.review_text {
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: var(--text-light) !important;
  font-style: italic !important;
  grid-column: 1 !important;
}

.disclaimer_box {
  margin-top: 32px !important;
  padding: 20px 24px !important;
  background: rgba(255,255,255,.6) !important;
  border-radius: var(--radius-sm) !important;
  border-left: 3px solid var(--border) !important;
  margin-bottom: 60px !important;
}

.disclaimer_content {
  font-size: 12px !important;
  line-height: 1.6 !important;
  color: var(--text-muted) !important;
}

/* ----------------------------------------------------------------
   CART — TABLE (when cart has items)
   ---------------------------------------------------------------- */
.cart_content {
  max-width: 960px !important;
  margin: 0 auto !important;
  padding: 48px 40px 80px !important;
  float: none !important;
  background: transparent !important;
}

.eC_Clean_Pacifica_Arial {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

.eC_Clean_Pacifica_Arial > div {
  background: transparent !important;
}

.cart_content h2,
.eC_Clean_Pacifica_Arial h2 {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 28px !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  margin: 0 0 32px !important;
  letter-spacing: -.5px !important;
}

table.eC_ShoppingCart {
  width: 100% !important;
  border-collapse: collapse !important;
  background: var(--white) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--card-shadow) !important;
  font-size: 14px !important;
}

table.eC_ShoppingCart th {
  background: var(--navy) !important;
  color: rgba(255,255,255,.7) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 16px 22px !important;
  text-align: left !important;
  border: none !important;
  white-space: nowrap !important;
}

table.eC_ShoppingCart td {
  padding: 20px 22px !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text) !important;
  vertical-align: middle !important;
  background: var(--white) !important;
  border-left: none !important;
  border-right: none !important;
}

table.eC_ShoppingCart tr:last-child td { border-bottom: none !important; }

table.eC_ShoppingCart tr:hover td { background: #fafbff !important; }

table.eC_ShoppingCart td.eC_PriceItem,
table.eC_ShoppingCart td.eC_FormItem {
  text-align: center !important;
}

table.eC_ShoppingCart input[type="text"],
table.eC_ShoppingCart input[type="number"] {
  width: 64px !important;
  padding: 8px 12px !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  font-size: 14px !important;
  text-align: center !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 700 !important;
}

/* Cart totals row */
.eC_Totals, .eC_Total, .eC_GrandTotal {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  padding: 20px 24px !important;
  margin-top: 16px !important;
  box-shadow: 0 2px 12px rgba(13,25,46,.06) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  color: var(--text) !important;
  text-align: right !important;
}

/* Cart action buttons */
form[action] input[type="submit"],
form[action] input[type="image"] {
  display: inline-flex !important;
  align-items: center !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 13px 28px !important;
  border-radius: var(--radius-sm) !important;
  border: none !important;
  cursor: pointer !important;
  transition: all .2s var(--ease) !important;
  margin: 8px 6px 8px 0 !important;
  min-height: 46px !important;
}

/* Checkout = primary teal */
input[name="bycom_Checkout"],
input[name="bycom_Checkout_x"] {
  background: var(--teal) !important;
  color: var(--white) !important;
  box-shadow: 0 4px 20px var(--teal-glow) !important;
}

input[name="bycom_Checkout"]:hover,
input[name="bycom_Checkout_x"]:hover {
  background: var(--teal-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 28px rgba(61,179,165,.35) !important;
}

/* Secondary buttons */
input[name*="bycom_Update"],
input[name*="bycom_Continue"],
input[name*="bycom_Clear"] {
  background: transparent !important;
  color: var(--text-light) !important;
  border: 1px solid var(--border) !important;
}

input[name*="bycom_Update"]:hover,
input[name*="bycom_Continue"]:hover {
  background: var(--off-white) !important;
  border-color: var(--text-light) !important;
}

input[name*="bycom_Clear"]:hover {
  background: #fff5f5 !important;
  border-color: #dc2626 !important;
  color: #dc2626 !important;
}

/* ----------------------------------------------------------------
   CART — EMPTY STATE
   ---------------------------------------------------------------- */

/* Wrap the empty cart content properly */
.section_content > div > .eC_Clean_Pacifica_Arial {
  max-width: 960px !important;
  margin: 0 auto !important;
  padding: 48px 40px 80px !important;
}

.header_empty_cart {
  background: var(--navy) !important;
  border-radius: var(--radius-lg) !important;
  padding: 64px 48px !important;
  text-align: center !important;
  margin-bottom: 32px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.empty_icon_cart {
  font-size: 48px !important;
  color: rgba(255,255,255,.3) !important;
  margin-bottom: 20px !important;
}

.empty_icon_cart .icon {
  font-size: 52px !important;
  color: rgba(255,255,255,.25) !important;
}

.empty_cart_text {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 12px !important;
}

.empty_cart_content {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,.7) !important;
  max-width: 360px !important;
}

/* Lead / promo section */
.lead_blue {
  background: var(--teal-glow) !important;
  border: 1px solid rgba(61,179,165,.25) !important;
  border-radius: var(--radius) !important;
  padding: 28px 32px !important;
  margin-bottom: 28px !important;
  display: block !important;
}

.lead_blue_content { position: relative !important; }
.lead_shadow { display: none !important; }

.blue_lead_text {
  text-align: center !important;
}

.white_text_lead {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  display: block !important;
}

.blue_text_lead {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--teal-dark) !important;
  display: block !important;
  margin-top: 4px !important;
}

/* Teaser cards */
.teasers_box {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  margin-top: 8px !important;
  float: none !important;
}

.teaser_item {
  background: var(--white) !important;
  border-radius: var(--radius-lg) !important;
  padding: 36px 32px !important;
  position: relative !important;
  overflow: hidden !important;
  min-height: 180px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  box-shadow: var(--card-shadow) !important;
  background-size: cover !important;
  background-position: center !important;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease) !important;
  cursor: pointer !important;
}

.teaser_item:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 40px rgba(13,25,46,.18) !important;
}

.teaser_shadow {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(to top, rgba(6,14,30,.8) 0%, rgba(6,14,30,.15) 100%) !important;
  border-radius: var(--radius-lg) !important;
  pointer-events: none !important;
}

.teaser_icon_box,
.teaser_icon_box_right {
  position: absolute !important;
  top: 24px !important; right: 24px !important;
  font-size: 28px !important;
  color: rgba(255,255,255,.35) !important;
}

.teaser_button_box {
  position: relative !important;
  z-index: 1 !important;
}

.teaser_button {
  display: inline-block !important;
  background: var(--teal) !important;
  color: var(--white) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 12px 22px !important;
  border-radius: 99px !important;
  text-decoration: none !important;
  transition: background .2s var(--ease) !important;
}

.teaser_button:hover {
  background: var(--teal-dark) !important;
  color: var(--white) !important;
  text-decoration: none !important;
}

/* ----------------------------------------------------------------
   CHECKOUT PAGE (Stripe)
   ---------------------------------------------------------------- */
#checkout {
  max-width: 620px !important;
  margin: 48px auto 80px !important;
  padding: 0 40px !important;
}

/* ----------------------------------------------------------------
   NEW FOOTER
   ---------------------------------------------------------------- */
.mxt-footer {
  background: var(--navy-dark) !important;
  color: rgba(255,255,255,.75) !important;
  margin-top: 80px !important;
  padding: 64px 0 0 !important;
  font-family: 'Inter', sans-serif !important;
}

.mxt-footer-inner {
  max-width: 1160px !important;
  margin: 0 auto !important;
  padding: 0 48px 56px !important;
  display: grid !important;
  grid-template-columns: 1.6fr 1fr 1fr !important;
  gap: 56px !important;
}

.mxt-footer-logo {
  height: 34px !important;
  width: auto !important;
  margin-bottom: 14px !important;
  display: block !important;
  opacity: .9 !important;
}

.mxt-footer-brand p {
  font-size: 13px !important;
  color: rgba(255,255,255,.4) !important;
  margin: 0 !important;
}

.mxt-footer-col h4 {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--teal) !important;
  margin: 0 0 18px !important;
}

.mxt-footer-col ul { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.mxt-footer-col ul li { margin-bottom: 10px !important; }

.mxt-footer-col a,
.mxt-footer-col a:visited {
  color: rgba(255,255,255,.55) !important;
  text-decoration: none !important;
  font-size: 14px !important;
  transition: color .2s var(--ease) !important;
}

.mxt-footer-col a:hover { color: var(--teal) !important; }

.mxt-footer-col p {
  font-size: 14px !important;
  color: rgba(255,255,255,.55) !important;
  margin: 0 0 8px !important;
}

.mxt-footer-col strong { color: var(--white) !important; font-weight: 600 !important; }

.mxt-social {
  display: inline-block !important;
  margin-right: 12px !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.4) !important;
  border-bottom: 1px solid rgba(255,255,255,.15) !important;
  padding-bottom: 2px !important;
  text-decoration: none !important;
}

.mxt-social:hover { color: var(--teal) !important; border-color: var(--teal) !important; }

.mxt-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.07) !important;
  padding: 22px 48px !important;
  text-align: center !important;
}

.mxt-footer-bottom p {
  font-size: 12px !important;
  color: rgba(255,255,255,.3) !important;
  margin: 0 !important;
}

/* ----------------------------------------------------------------
   RESPONSIVE
   ---------------------------------------------------------------- */
@media (max-width: 1024px) {
  .mxt-nav { padding: 0 28px !important; }
  .content_tour_detail { padding: 36px 28px 0 !important; }
  .mxt-footer-inner { padding: 0 28px 48px !important; gap: 36px !important; }
  .mxt-footer-bottom { padding: 20px 28px !important; }
}

@media (max-width: 768px) {
  /* Nav mobile */
  .mxt-nav { padding: 0 20px !important; }
  .mxt-hamburger { display: flex !important; }
  .mxt-links {
    display: none !important;
    position: absolute !important;
    top: 64px !important; left: 0 !important; right: 0 !important;
    background: var(--navy) !important;
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 16px 20px 24px !important;
    gap: 4px !important;
    box-shadow: 0 12px 32px rgba(0,0,0,.4) !important;
  }
  .mxt-nav.mxt-open .mxt-links { display: flex !important; }
  .mxt-links a { font-size: 15px !important; padding: 13px 16px !important; }

  /* Hero */
  .header_pic { height: 260px !important; }

  /* Layout */
  .content_tour_detail { padding: 24px 16px 0 !important; }
  .detail_tour { grid-template-columns: 1fr !important; gap: 24px !important; }
  .basic_info_box { position: static !important; }

  /* Booking form stacks */
  .tours_reservation_box {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 28px 24px !important;
    margin-top: 28px !important;
  }
  .price_detail_box {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,.1) !important;
    padding: 0 0 24px !important;
    text-align: left !important;
  }
  form.form-style-5 {
    grid-template-columns: 1fr !important;
  }
  input.reserve_button { width: 100% !important; }

  /* Cart */
  .cart_content,
  .section_content > div > .eC_Clean_Pacifica_Arial {
    padding: 28px 20px 60px !important;
  }
  .teasers_box { grid-template-columns: 1fr !important; }
  .header_empty_cart { padding: 48px 24px !important; }

  /* Footer */
  .mxt-footer-inner {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding: 0 20px 40px !important;
  }
  .mxt-footer-bottom { padding: 18px 20px !important; }
  #checkout { padding: 0 16px !important; }
}

@media (max-width: 480px) {
  .description_tour_tittle { font-size: 26px !important; }
  .price_detail_content { font-size: 36px !important; }
  .col_content_box { grid-template-columns: 1fr !important; }
  .col_description_content { border-right: none !important; border-bottom: 1px solid var(--border) !important; }
  .col_description_content:last-child { border-bottom: none !important; }
}

/* ----------------------------------------------------------------
   DATEPICKER OVERRIDE
   ---------------------------------------------------------------- */
.ui-datepicker {
  font-family: 'Inter', sans-serif !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: 0 12px 40px rgba(13,25,46,.2) !important;
  background: var(--navy-mid) !important;
  color: var(--white) !important;
  padding: 12px !important;
}

.ui-datepicker-header {
  background: transparent !important;
  border: none !important;
  color: var(--white) !important;
  padding-bottom: 8px !important;
}

.ui-datepicker-title {
  color: var(--white) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  letter-spacing: .5px !important;
}

.ui-datepicker-prev, .ui-datepicker-next {
  background: rgba(255,255,255,.08) !important;
  border-radius: 6px !important;
  color: var(--white) !important;
  cursor: pointer !important;
}

.ui-datepicker-prev:hover, .ui-datepicker-next:hover {
  background: var(--teal) !important;
}

.ui-datepicker td { background: transparent !important; }

.ui-datepicker td a, .ui-datepicker td span {
  color: rgba(255,255,255,.75) !important;
  background: transparent !important;
  border-radius: 6px !important;
  text-align: center !important;
  padding: 6px !important;
}

.ui-datepicker td a:hover {
  background: rgba(61,179,165,.2) !important;
  color: var(--white) !important;
}

.ui-state-active, .ui-widget-content .ui-state-active {
  background: var(--teal) !important;
  border: none !important;
  color: var(--white) !important;
  border-radius: 6px !important;
}

.ui-datepicker th {
  color: rgba(255,255,255,.4) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 6px !important;
  text-align: center !important;
  border: none !important;
}

/* ================================================================
   PATCH v2.1 — fixes from live DOM inspection
   ================================================================ */

/* --- FIX: Kill triangle background on form_reservation_box (tours.css legacy) --- */
.form_reservation_box,
.tours_reservation_box {
  background-image: none !important;
  background-color: transparent !important;
}
.triangle-topright { display: none !important; }

/* --- FIX: Price boxes — kill old navy/teal colored blocks from tours.css --- */
.price_detail_content {
  background-color: transparent !important;
  background: transparent !important;
  height: auto !important;
  line-height: 1 !important;
}
.price_unit_detail {
  background-color: transparent !important;
  background: transparent !important;
  height: auto !important;
  line-height: 1.3 !important;
  font-size: 12px !important;
}
.price_detail_box {
  margin-top: 0 !important;
}

/* --- FIX: Info card items — CSS Grid so icon spans both label+value rows --- */
.duration_detail,
.location_detail,
.age_detail {
  display: grid !important;
  grid-template-columns: 28px 1fr !important;
  grid-template-rows: auto auto !important;
  column-gap: 12px !important;
  row-gap: 0 !important;
  align-items: center !important;
  flex-wrap: unset !important;
}
.icon.time_icon_detail,
.icon.pin_icon_detail,
.icon.user_icon_detail {
  grid-column: 1 !important;
  grid-row: 1 / 3 !important;
  align-self: center !important;
  font-size: 16px !important;
}
.detail_tour_title {
  grid-column: 2 !important;
  grid-row: 1 !important;
  width: auto !important;
  display: block !important;
}
.detail_info {
  grid-column: 2 !important;
  grid-row: 2 !important;
  display: block !important;
  margin-top: 1px !important;
}

/* --- FIX: Form grid — 4 cols (hotel / date / persons / button) --- */
form.form-style-5 {
  grid-template-columns: 1fr 160px 130px auto !important;
  align-items: end !important;
}
/* collapse the empty plugin div that breaks column count */
.field_box:has(> div:only-child:empty) { display: none !important; }
#other_option:empty { display: none !important; }
#other_option { grid-column: 1 / -1 !important; }

/* ================================================================
   GALLERY — Modern editorial look via lightSlider classes
   (lightSlider injects these at runtime via JS)
   ================================================================ */

/* Outer wrapper */
.lSSlideOuter {
  border-radius: var(--radius) !important;
  overflow: hidden !important;
  background: var(--navy-dark) !important;
  box-shadow: 0 8px 40px rgba(6,14,30,.25) !important;
}

/* Main slides */
.lSSlide li img,
.lSSlideWrapper img {
  width: 100% !important;
  height: 400px !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
}

/* Prev/Next arrows — minimal pill overlay */
.lSAction {
  position: absolute !important;
  top: 50% !important;
  width: 100% !important;
  transform: translateY(-50%) !important;
  pointer-events: none !important;
  z-index: 10 !important;
}
.lSAction > a {
  pointer-events: all !important;
  position: absolute !important;
  width: 36px !important; height: 36px !important;
  background: rgba(255,255,255,.15) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  border-radius: 50% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  transition: background .2s var(--ease) !important;
  text-decoration: none !important;
  border: 1px solid rgba(255,255,255,.2) !important;
}
.lSAction > a:hover { background: rgba(61,179,165,.5) !important; }
.lSAction > a.lSPrev { left: 14px !important; }
.lSAction > a.lSNext { right: 14px !important; }
.lSAction > a::before {
  content: '' !important;
  border: solid rgba(255,255,255,.9) !important;
  border-width: 0 2px 2px 0 !important;
  display: inline-block !important;
  padding: 4px !important;
}
.lSAction > a.lSPrev::before { transform: rotate(135deg) translateX(1px) !important; }
.lSAction > a.lSNext::before { transform: rotate(-45deg) translateX(-1px) !important; }

/* Thumbnail strip */
.lSPager.lSpg {
  display: flex !important;
  gap: 6px !important;
  padding: 12px 14px !important;
  margin: 0 !important;
  list-style: none !important;
  background: rgba(6,14,30,.85) !important;
  overflow-x: auto !important;
  scrollbar-width: thin !important;
  justify-content: flex-start !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
}
.lSPager.lSpg::-webkit-scrollbar { height: 3px !important; }
.lSPager.lSpg::-webkit-scrollbar-track { background: transparent !important; }
.lSPager.lSpg::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2) !important; border-radius: 3px !important; }

.lSPager.lSpg > li {
  flex-shrink: 0 !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  opacity: .5 !important;
  transition: opacity .2s var(--ease), box-shadow .2s var(--ease) !important;
  cursor: pointer !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.lSPager.lSpg > li:hover { opacity: .8 !important; }
.lSPager.lSpg > li.active {
  opacity: 1 !important;
  box-shadow: 0 0 0 2px var(--teal) !important;
}
.lSPager.lSpg > li img {
  width: 72px !important;
  height: 48px !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
}

/* Hide lightSlider dot pager if any */
.lSPager:not(.lSpg) { display: none !important; }
