:root {
  --primary-dark: #141e48;
  --accent-yellow: #ffb933;
  --accent-blue: #008cff;
  --text-grey: #8f8f8f;
  --text-dark: #000000;
  --bg-light: #f2ede8;
  --white: #ffffff;
}

.any-btn-bg {
  background-color: rgba(20, 30, 72, 1) !important;
  color: white !important;
}
.any-btn {
  background-color: rgba(255, 185, 51, 1) !important;
  color: rgb(5, 0, 0) !important;
}

/* <!--======== Scroll up and prograss css start ========--> */
#scrollUp {
  text-align: center;
  bottom: 20px;
  cursor: pointer;
  display: none;
  position: fixed;
  right: 20px;
  z-index: 10;
  border-radius: 50%;
  background: #141e48 !important;
  padding: 1px;
  transition: all linear 0.3s;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
  border: 1px solid #fab404 !important;
}
#scrollUp .scrollprogress .progress-circle {
  transition: stroke-dashoffset 0.5s ease;
}
#scrollUp .arrowup {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
#scrollUp:hover {
  background: #0a0a0a !important;
}
.scrollprogress {
  transform: rotate(-90deg);
}
/* <!--======== Scroll up and prograss css Ends ========--> */
/* toaster css*/
#toast-container > .toast-success {
  background-color: #258d00;
  opacity: 1 !important;
  /* background-color: #48fc079f; Custom green */
  color: white;
}
#toast-container > .toast-error {
  background-color: #c00719; /* Custom red */
  color: white;
}

/* toaster css end */
.profile_btn_navber {
  /* color: #fff; */
  background-color: #ffb933;
  border: 2px solid white;
  padding: 7px 10px;
  transition: var(--transition);
  box-shadow: none;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  z-index: 0;
  line-height: 1.5;
}
.user-img-fluid {
  width: 30px;
  height: 30px;
  margin-top: 3px;
  border-radius: 50%;
}
/* service css */
.enquiry-btn {
  color: #fffdfd !important;
  background-color: #141e48 !important;
}
.enquiry-btn:hover {
  color: rgb(0, 0, 0) !important;
  background-color: #fab404 !important;
}

/*------------------------------ TOp Booking Box ------------------------------*/
.booking-box {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.4s ease-in-out;
}
.booking-box:hover {
  box-shadow: 5px 5px 8px 8px rgba(0.5, 0.5, 0.5, 0.5) !important;
  transform: translateY(-4px);
}

.booking-box .booking-img {
  height: 350px;
  width: 100%;
  object-fit: cover;
  bottom: 0px;
  display: block;
  transition: transform 0.4s ease;
}

.booking-box .booking-img:hover {
  transform: scale(1.1);
}

/* h5 and p overlayed on image */
.booking-box h5,
.booking-box p {
  position: absolute;
  left: 0;
  width: 100%;
  color: #070707;
  background: rgba(255, 184, 51, 0.786);
  margin: 0;
  padding: 5px 0;
  transition: all 0.4s ease;
}

.booking-box h5 {
  bottom: 38px;
  font-size: 20px;
  font-weight: 600;
}

.booking-box p {
  bottom: 0px;
}

/* Animate position on hover */
.booking-box:hover h5 {
  bottom: 73px;
}

.booking-box:hover p {
  bottom: 35px;
}

/* Button initially hidden */
.booking-box .btn {
  position: absolute;
  font-size: 18px;
  font-weight: 600;
  bottom: 0px;
  width: 100%;
  transform: translateX(-50%);
  color: #fff;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  transition:
    opacity 0.4s ease,
    bottom 0.4s ease;
  z-index: 2;
  border-radius: 0px;
}

/* Show button on hover */
.booking-box:hover .btn {
  opacity: 1;
  bottom: 0px;
  border-radius: 0px;
  background-color: #141e48 !important;
}

/* .booking-box .btn:hover {
  color: #070707;
  background-color: #FFB933 !important;
} */

.cab-img {
  height: 200px;
  object-fit: cover;
}

.other-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
}

.other-card:hover {
  transform: translateY(-7px);
  box-shadow: 10px 10px 10px 25px rgba(0.25, 0.25, 0.25, 0.25);
}

.other-card-body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1.5rem;
}

.other-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: #1d3557;
}

.other-text {
  font-size: 0.95rem;
  color: #6c757d;
  margin-bottom: 1rem;
}

.btn-outline-primary {
  border-radius: 50px;
  padding: 0.4rem 1rem;
}

/* @media (max-width: 768px) {
      .cab-img {
        height: 180px;
      }
    } */

/*------------------------------ holiday package ------------------------------*/
/* Domestic card enhancements */
.Domestic-card {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  /* cursor: pointer; */
  transition:
    transform 0.4s ease,
    box-shadow 0.4s ease;
}

.Domestic-card:hover {
  transform: scale(1.03);
  box-shadow: 5px 5px 8px 10px rgba(0.5, 0.5, 0.5, 0.5) !important;
}

.Domestic-card:hover .card-img-top {
  filter: brightness(0.9);
  transition: filter 0.3s ease;
}

/* Smooth hover zoom for image */
.Domestic-card .card-img-top {
  height: 180px;
  object-fit: cover;
  transition: all 0.4s ease-in-out;
}

.Domestic-card .submit-btn {
  color: white;
  background-color: #141e48 !important;
}
.Domestic-card .submit-btn:hover {
  color: #070707;
  background-color: #fab404 !important;
}
.Domestic-card .submit-btn-s {
  color: #070707;
  background-color: #fab404 !important;
}
.Domestic-card .submit-btn-s:hover {
  color: white;
  background-color: #141e48 !important;
}
/* Testimonials */
.all_review_box {
  transition:
    transform 0.4s ease,
    box-shadow 0.4s ease;
}

.all_review_box:hover {
  transform: scale(1.03);
  box-shadow: 5px 5px 10px 10px rgba(0.5, 0.5, 0.5, 0.5);
}
.testimonials_view_more .view-more {
  background-color: #141e48 !important;
  color: white !important;
  padding: 10px 20px 10px 20px !important;
  border-radius: 5px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  border: 2px solid #fab404 !important;
  transition: all 0.3s ease !important;
  display: inline-block !important;
  text-decoration: none !important;
}

.testimonials_view_more .view-more:hover {
  background-color: #141e48 !important;
  transform: scale(1.05) !important;
  box-shadow: 5px 5px 5px 5px rgba(0.4, 0.4, 0.4, 0.4);
  text-decoration: none !important;
  border: 2px solid #fab404 !important;
}

.testimonial-message {
  display: -webkit-box;
  -webkit-line-clamp: 10; /* 🔥 10 line dikhani hai */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-align: justify;
  font-size: 14px;
  position: relative;
  transition: all 0.4s ease;
}

.testimonial-message.expanded {
  -webkit-line-clamp: unset; /* 🔥 Read More pe pura expand */
}

.view-toggle {
  display: none;
  color: #ff6600;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  margin-top: 6px;
  display: inline-block;
  transition: color 0.3s ease;
}
.view-toggle:hover {
  color: #141e48;
}
/* testimonials end */

/* ====================== all enquiry module ===========================*/
.all-enquiry-btn .submit-btn {
  color: #070707;
  background-color: #fab404 !important;
}
.all-enquiry-btn .submit-btn:hover {
  color: white;
  background-color: #141e48 !important;
}

.error {
  color: red;
  font-size: 13px;
}

.theme_common_box_two {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.theme_two_box_content {
  flex-grow: 1; /* Makes content stretch to fill card */
}

/*###################### hotel and flight css #########################*/
/* .banner_one_text {
  margin-top: 0px !important;
} */
.toggle-tabs {
  background: #f8f9fa5b;
  padding: 10px;
}

.tab-btn {
  border: none;
  background: rgba(255, 228, 178, 1);
  padding: 10px 25px;
  border-radius: 50px;
  font-weight: 600;
  color: #555;
  transition: 0.3s;
}
.tab-btn.active {
  background: rgba(255, 185, 51, 1);
  color: #fff;
}
.trip-type {
  background-color: rgba(235, 239, 255, 1);
  border-radius: 50px;
  width: 350px;
}
.trip-btn,
.fare-btn {
  border: none;
  background: #ffffff;
  border-radius: 30px;
  padding: 8px 20px;
  font-weight: 500;
  transition: 0.3s;
}

.trip-btn.active {
  background: rgba(20, 30, 72, 1);
  color: rgba(255, 185, 51, 1);
}

.fare-btn {
  background: rgba(255, 228, 178, 1);
}

.fare-btn.active {
  background: rgba(255, 185, 51, 1);
  color: #fff;
}
.tab-content-box {
  max-width: 1300px;
}

.input-box {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 10px;
  padding: 10px 15px;
  box-shadow: 2px 2px 2px 4px #dbe2fb;
}
.input-label {
  display: block;
  font-size: 12px;
  color: #777;
  margin-bottom: 2px;
  text-align: start;
}
.input-box input {
  /* border: 1px solid #f4a261; */
  border: none;
  outline: none;
  font-weight: 600;
  color: #000;
  background: transparent;
}

.swap-icon {
  position: absolute;
  top: 50%;
  left: 17%;
  transform: translate(-50%, -50%);
  background: #fff;
  color: #f4a261;
  border-radius: 50%;
  width: 34px !important;
  height: 34px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #ddd;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  z-index: 5;
}
.swap-icon-2 {
  left: 25% !important;
}
.swap-icon:hover {
  background: #f4a261;
  color: #fff;
}
.swapped {
  transition:
    transform 0.3s ease,
    background-color 0.3s ease;
  background-color: #fff3cd;
  transform: scale(1.05);
}

.rotate {
  display: inline-block;
  transform: rotate(180deg);
  transition: transform 0.4s ease;
}

/* flight Details Page css */
.noUi-target,
.noUi-base {
  height: 8px !important; /* thinner line */
  border-radius: 5px;
}

.noUi-connect {
  background: orange !important;
  height: 8px !important;
}

/* Circle handles */
.noUi-handle {
  background: orange !important;
  border: 3px solid #fff;
  border-radius: 50%;
  width: 34px; /* slightly larger */
  height: 34px;
  top: 50%; /* center handle vertically */
  transform: translateY(-50%);
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
  cursor: pointer;
}

.noUi-handle:before,
.noUi-handle:after {
  display: none;
}

/* Improve handle alignment inside small containers */
.noUi-horizontal .noUi-handle {
  right: -17px;
}

.flight-page-icon {
  width: 30px;
}

.flight-page-btn {
  transition: all 0.2s ease-in-out;
}

.flight-page-btn:hover {
  transform: translateY(-2px);
  background-color: #007bff !important;
}

.flight-page-btn.active {
  background-color: #007bff !important;
  color: #fff !important;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 255, 0.15);
}

.card-flight-box {
  border: none !important; /* No visible border */
  border-radius: 1rem; /* Rounded corners */
  background-color: #f8f9fa; /* Soft background */
  transition: all 0.3s ease-in-out;
}

.card-flight-box:hover {
  border: 1px solid #ff9d00 !important;
  background-color: #fff8e6; /* Light highlight on hover */
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.1); /* Smooth shadow */
}
.card-flight-box.active {
  border: 2px solid #ffb933 !important;
  background-color: #fff9eb !important;
  color: black !important;
  transition: 0.3s;
}

.card-flight-box-sp {
  border: none !important; /* No visible border */
  border-radius: 1rem; /* Rounded corners */
  background-color: #f8f9fa; /* Soft background */
  transition: all 0.3s ease-in-out;
}

.card-flight-box-sp:hover {
  border: 1px solid #ff9d00 !important;
  background-color: #fff8e6; /* Light highlight on hover */
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.1); /* Smooth shadow */
}
.card-flight-box-sp.active {
  border: 2px solid #ffb933 !important;
  background-color: #fff9eb !important;
  color: black !important;
  transition: 0.3s;
}
/* .card-flight-box:hover {
  border: 2px solid #ff9d00 !important;
  background-color: #f8f9fa;
} */

/* flight booking details page */
.addon-btn {
  min-width: 150px;
  text-align: center;
  margin-right: 10px;
  border-radius: 40px;
  padding: 6px 12px;
}
.addon-btn:hover {
  border: 2px solid black !important;
  background-color: #ff9d00 !important;
  color: black !important;
}
.addon-btn.active {
  background-color: #ff9d00 !important;
  color: #000 !important;
}
.baggage-btn:hover {
  background-color: #ff9d00 !important;
  color: black !important;
}

.veg-nonveg-img {
  width: 70px;
  height: 65px;
}
/* Remove Flight Button */
.remove-flight {
  width: 28px !important;
  height: 28px;
  padding: 0 !important;
  border-radius: 50% !important;
  background-color: #ffa726 !important;
  /* your given yellow/orange */
  border: none !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

.remove-flight i {
  color: white;
  font-size: 14px;
  line-height: 1;
}
.roundtrip-flight .round-flight-summary {
  background-color: #ffb933;
  color: #000000;
  display: none;
  border: 1px solid #0223fd;
  bottom: 20px;
  position: fixed;
  width: 50%;
  z-index: 2;
}

/* ===== Responsive ===== */
@media (min-width: 1200px) and (max-width: 1300px) {
  .roundtrip-flight .round-flight-summary {
    width: 50%;
  }
  .total-next-btn {
    margin-right: 30px;
  }
}
@media (max-width: 1199px) {
  .roundtrip-flight .round-flight-summary {
    width: 60%;
  }
}
@media (max-width: 767px) {
  .swap-icon {
    top: 80px !important;
    left: 50% !important;
    margin: 0px;
  }
  .roundtrip-flight .round-flight-summary {
    width: 80%;
  }
}
@media (max-width: 991px) {
  .swap-icon {
    top: 50px;
    left: 50% !important;
    margin: 0px;
  }
  .input-box {
    width: 100%;
  }

  .info-details h6 {
    font-size: 13px;
  }

  .info-details p {
    font-size: 11px;
  }
  .flight-edit-btn {
    font-size: 12px !important;
  }
  /* Sidebar behavior */
  #filterSidebar, #spFilterSidebar {
    position: fixed;
    top: 0;
    left: -100%;
    width: 45%;
    height: 100vh;
    background: #fff;
    z-index: 1050;
    overflow-y: auto;
    transition: left 0.4s ease;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
    display: block;
  }

  #filterSidebar.active, #spFilterSidebar.active {
    left: 0;
  }

  /* Dark overlay */
  .filter-overlay, .filter-overlay-sp {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1040;
    display: none;
  }

  .filter-overlay.active, .filter-overlay-sp.active {
    display: block;
  }

  /* 🔶 Vertical FILTERS tab */
  .filter-tab, .filter-tab-sp {
    position: fixed;
    top: 40%;
    left: 0;
    background: #ffb300;
    color: #000;
    font-weight: 700;
    padding: 10px 8px;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
    cursor: pointer;
    z-index: 1100;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3px;
    font-size: 0.85rem;
    letter-spacing: 1px;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.3);
    width: 32px !important;
    height: 80px;
  }

  /* .filter-tab, .filter-tab-sp i {
    transform: rotate(180deg);
    font-size: 1rem;
  } */

  /* Hover effect */
  .filter-tab:hover, .filter-tab-sp:hover {
    background: #ff9d00;
  }
 
 
}
@media (max-width: 667px) {
  #filterSidebar, #spFilterSidebar {
    width: 70%;
  }
 
}
