@font-face {
  font-family: "Koho";
  src: url(/Themes/eVoucher/font/KoHo-Medium.ttf) format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Koho";
  src: url(/Themes/eVoucher/font/KoHo-Bold.ttf) format("truetype");
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: Jambono;
  src: url(/Themes/eVoucher/font/JambonoMedium.ttf);
}
@font-face {
  font-family: Jambono;
  src: url(/Themes/eVoucher/font/JambonoBlack.ttf);
  font-weight: bold;
}
@font-face {
  font-family: Jambono;
  src: url(/Themes/eVoucher/font/JambonoLight.ttf);
  font-weight: 300;
}
body {
  font-family: "Koho";
}
.bg-red {
  background-color: #c30e13 !important;
}
.wrapper__header {
  box-shadow: 0px 0px 16px rgba(238, 61, 97, 0.1);
}
.navbar > .container {
  flex-wrap: nowrap;
}
.navbar-dark .navbar-toggler {
  color: #fff;
  border: none;
}
.navbar-user {
  display: flex;
  align-items: center;
}
.navbar-user > .nav-link {
  display: flex;
  align-items: center;
  color: #fff;
}
.navbar-user .user__link,
.navbar-user .btn-link {
  color: #fff;
  text-decoration: none;
}
.navbar__top .btn-link,
.navbar__top .nav-link {
  border-radius: 8px;
  border-width: 0;
}
.navbar-language {
  display: flex;
  align-items: center;
  justify-content: center;
}
.nav-lang > a {
  color: #fff;
  display: flex;
  align-items: center;
}
.navbar .navbar-collapse {
  justify-content: flex-end;
  flex-wrap: wrap;
}
.navbar__top,
.navbar__bottom {
  display: flex;
  justify-content: flex-end;
  flex-basis: 100%;
}
.navbar__top,
.navbar-user .user__link,
.navbar-user .btn-link {
  font-size: 14px;
}
.navbar-user .dropdown-menu {
  width: 220px;
}
.dropdown-item {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.navbar-dark .navbar-nav .nav-link {
  color: #fff;
}
hr {
  opacity: 0.05;
}
.mobile__menu {
  position: fixed;
  top: 50px;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: all linear 240ms;
}
.navbar__top .nav-lang .nav-link:focus,
.navbar__top .nav-lang .nav-link:hover {
  color: #fff;
}
.logged-in p {
  margin-bottom: 0;
  padding: 5px 0 5px 5px;
}
.mobile__menu .overlay {
  background-color: rgba(0, 0, 0, 0.8);
  position: absolute;
  width: 100%;
  height: 100%;
}
.active__menu .mobile__menu .overlay {
  opacity: 1;
}
.mobile__menu .navbar-nav {
  width: 100%;
}
.mobile-navbar {
  background: #fff;
  max-width: 260px;
  height: 100%;
  position: relative;
  margin-left: auto;
  padding: 15px;
  transform: translateX(220px);
  transition: all linear 240ms;
  display: inherit;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}
.mobile-navbar .navbar-user .nav-link {
  padding-left: 0;
}
.mobile__menu .navbar-user {
  margin-bottom: 15px;
  border-bottom: 1px solid #f1f1f1;
  padding-bottom: 15px;
}
.mb__user__link {
  display: flex;
  align-items: center;
  justify-content: center;
}
.mb__user__link a {
  color: #3c3c3c;
}
.btn-check:focus + .btn,
.btn:focus {
  box-shadow: none;
}
.navbar__top .nav-link:hover,
.navbar__top .btn-link:hover {
  background-color: rgb(0 0 0 / 10%);
  color: #fff !important;
}

.nav-lang .dropdown-menu {
  left: auto;
  right: 0;
}
.wrapper__header .submenu {
  box-shadow: 0 0 16px 0 rgb(0 0 0 / 15%);
  position: absolute;
  z-index: 3;
  background: #fff;
  list-style-type: none;
  padding-left: 0;
  border-radius: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
  width: 240px;
  display: none;
}
.submenu li a {
  color: #212529 !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
  display: block;
}
.submenu li a:hover {
  background-color: #f1f1f1;
}
.mobile-navbar .navbar-nav .submenu {
  padding-left: 15px;
  list-style-type: none;
  border-left: 1px solid #f1f1f1;
  margin-left: 10px;
}
.mobile-navbar .navbar-nav .submenu li a {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.navbar-nav li:hover > .submenu {
  display: block;
}
.dropdown-menu {
  box-shadow: 0 0 16px 0 rgb(0 0 0 / 15%);
  border: none;
}
.mobile-navbar a {
  color: #3c3c3c !important;
  font-size: 14px !important;
}
.active__menu .mobile__menu {
  opacity: 1;
  pointer-events: all;
}
.active__menu .mobile-navbar {
  transform: translateX(0);
}
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.5;
}
h2 {
  font-size: 1.8rem;
}
h3 {
  font-size: 1.4rem;
}
h4 {
  font-size: 1.2rem;
}
h1 {
  font-size: 2rem;
}
.text-large {
  font-size: 2.2rem;
}
.bold {
  font-weight: bold;
}
.booking__banner {
  margin-bottom: 30px;
}
.booking__banner img {
  border-radius: 8px;
}
.btn-theme-primary {
  background: linear-gradient(135deg, #eb1e68 19.57%, #fc6d05 93.6%);
  color: #fff;
  font-weight: bold;
}
.btn-theme-primary:hover {
  color: #fff;
  background: linear-gradient(135deg, #fd649b 19.57%, #ff8227 93.6%);
}
.btn-theme-primary-light {
  background-color: rgba(255, 240, 236, 1);
  color: rgba(252, 109, 5, 1);
  font-weight: bold;
}
.btn-theme-primary-light:hover {
  background: linear-gradient(135deg, #eb1e68 19.57%, #fc6d05 93.6%);
  color: #fff;
}
.btn-thirdcondary {
  background: linear-gradient(
    85.35deg,
    #0046cd -0.01%,
    #0361ee 25.7%,
    #0066ff 101.93%
  );
  border-radius: 10px;
  color: #fff;
}
.btn-thirdcondary:hover {
  color: #fff;
}
.banner__logo_2 img + img {
  max-width: 420px;
  margin: 30px auto 0;
  display: block;
  width: 100%;
}
.input-icon .input-group-icon {
  display: flex;
  align-items: center;
  padding: 10px 0 10px 15px;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  text-align: center;
  white-space: nowrap;
  border: 1px solid #ced4da;
  border-radius: 8px;
  background-color: #fff;
}
.form-control {
  border-radius: 5px;
  padding: 10px 15px;
}
.form-select {
  padding: 10px 30px 10px 15px;
  border-radius: 8px;
}
.form-control:focus {
  box-shadow: none;
  border-color: #ced4da;
}
.input-icon input {
  border-left-width: 0;
}
.wrapper__main {
  /* background: linear-gradient(154.17deg, #FFE6EA -10.9%, #FBEFE7 110.77%); */
  min-height: calc(100vh - 96px);
  background: url(/Themes/eVoucher/img/bg_may.png) no-repeat;
  background-size: cover;
  padding-bottom: 95px;
}
.title-color {
  color: #2f3492;
}
.section__header {
  margin-bottom: 30px;
}
.list__items,
.list__header,
.list__footer {
  display: table-row-group;
}
.table-div {
  display: table;
  width: 100%;
}
.locations__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #f1f1f1;
  margin-top: 10px;
  padding-top: 10px;
  flex-wrap: wrap;
}
.pagination-theme a {
  color: #000;
  border-width: 0;
  width: 36px;
  height: 36px;
  line-height: 2;
  text-align: center;
  border-radius: 4px;
  display: inline-block;
}
.page-item.current a {
  background: linear-gradient(135deg, #eb1e68 19.57%, #fc6d05 93.6%);
  color: #fff;
}
.page-item:not(:first-child) .page-link {
  margin-left: 0;
}
.wrapper__footer {
    position: relative;
    background: url(/Themes/eVoucher/img/bg-footer-2.png);
    padding: 60px 0 10px;
    background-size: cover;
    background-position: top center;
}
    .wrapper__footer::before {
        content: "";
        position: absolute;
        background-image: url(/Themes/eVoucher/img/curver_2.png);
        background-repeat: repeat-x;
        height: 95px;
        width: 100%;
        top: -95px;
        background-position: 48px top;
        /* background-size: contain; */
    }
    .wrapper__footer::after {
        content: "";
        position: absolute;
        background: url(/Themes/eVoucher/img/red-corner.png) no-repeat;
        background-size: contain;
        height: 180px;
        width: 236px;
        bottom: 0;
        right: 0;
        z-index: 9999;
    }
.col-banner img {
  width: 100%;
  margin-bottom: 20px;
}
.wrapper__footer ul {
  list-style-type: none;
}

.footer__one {
  margin-bottom: 30px;
}
.footer__one .address ul {
  margin-bottom: 0;
}
.footer__one .address ul li + li {
  margin-top: 10px;
}

.nav-lang img {
  max-width: 24px;
  vertical-align: text-bottom;
  margin-right: 5px;
  border: 1px solid #fff;
  border-radius: 50%;
}

.navbar-dark .navbar-toggler {
  border-width: 0;
  box-shadow: none;
  width: 40px;
  padding: 0;
  font-size: 16px;
}
.navbar-toggler:focus {
  box-shadow: none;
}
.navbar-toggler .bi-x {
  height: 30px;
  display: inline-block;
  line-height: 30px;
  width: 30px;
  background: rgb(0 0 0 / 10%);
  color: #fff;
  border-radius: 6px;
}
.bi-x::before {
  font-weight: 600 !important;
}
section {
  margin-bottom: 40px;
}
body.active__menu {
  overflow: hidden;
}
.wrapper__main {
  position: relative;
}

.social__follow,
.stores {
  list-style: none;
  display: flex;
  align-items: center;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
}
.social__follow li a {
  width: 30px;
  height: 30px;
  display: inline-block;
}
.social__follow li,
.stores li {
  margin-right: 6px;
  margin-bottom: 6px;
}
.footer__title {
  margin-bottom: 15px;
  font-size: 16px;
}
img {
  max-width: 100%;
}
.footer__content p {
  margin-bottom: 5px;
}
.col-ft {
  margin-bottom: 30px;
}
/*======page content======*/
.wrapper__content {
  padding-top: 60px;
}
.page__content,
.voucher__detail__template {
  background-color: #fff;
  border-radius: 10px;
  padding: 60px 160px 60px;
}
.voucher_content {
  padding: 60px;
  background-color: #fff;
  border-radius: 10px;
}
.header-page__content {
  margin-bottom: 30px;
}
.vj-title {
  font-family: Jambono;
  color: rgba(232, 49, 86, 1);
}
/*======= account page ======*/
.descriptions {
  padding-top: 30px;
}
.descriptions p {
  margin-bottom: 10px;
}
.container-850 {
  max-width: 850px;
}
.header-account__page,
.header-checkout__page {
  margin-bottom: 30px;
}
.body-account__page,
.body-template {
  background-color: #fff;
  border-radius: 10px;
  padding: 60px 30px 60px;
}
.mandatory {
  color: rgba(232, 49, 86, 1);
}
label {
  font-weight: bold;
}
label.form-check-label {
  font-weight: normal;
  cursor: pointer;
}
.form-check-label a {
  text-decoration: none;
}
.form-floating > label {
  font-weight: normal;
}
::placeholder {
  color: rgba(185, 185, 185, 1) !important;
}
.form-floating .form-control::placeholder {
  color: transparent !important;
}
.pax__form .form-floating > .form-control,
.pax__form .form-floating > .form-select {
  height: calc(3rem + 2px);
  padding: 1rem;
}
.pax__form .form-floating > .form-control:focus,
.pax__form .form-floating > .form-control:not(:placeholder-shown) {
  padding-top: 1.325rem;
  padding-bottom: 0.425rem;
  font-weight: bold;
}
.pax__form .form-floating > label {
  padding: 0.7rem 1rem;
}
.pax__form .form-floating > .form-control:focus ~ label,
.pax__form .form-floating > .form-control:not(:placeholder-shown) ~ label,
.pax__form .form-floating > .form-select ~ label {
  transform: scale(0.75) translateY(-0.35rem) translateX(0.2rem);
}
.btn-vj {
  font-family: Jambono;
  border-width: 0;
  min-height: 45px;
  min-width: 180px;
  border-radius: 10px;
  font-size: 16px;
  align-items: center;
  display: inline-flex;
  justify-content: center;
}
.btn-primary {
  background: linear-gradient(
    360deg,
    #f9a51a 0%,
    #fbb612 21.42%,
    #ffdd00 70.65%
  );
  color: #212529;
  border-width: 0;
  border-radius: 10px;
  outline: none;
}
.btn-primary:hover {
  box-shadow: 0px 3px 6px 0px rgb(0 0 0 / 10%);
  color: rgb(33 37 41);
  border-color: transparent;
}
.btn-check:active + .btn-primary:focus,
.btn-check:checked + .btn-primary:focus,
.btn-primary.active:focus,
.btn-primary:active:focus,
.show > .btn-primary.dropdown-toggle:focus {
  box-shadow: none;
}
.btn-default {
  background: linear-gradient(265.1deg, #f1f1f1 3.16%, #dfdfdf 101.49%);
  border-width: 0;
  border-radius: 10px;
}
.btn-vj:hover {
  box-shadow: 0px 3px 6px 0px rgb(0 0 0 / 10%);
  color: #212529;
}
.title {
  font-weight: bold;
}
.mr-3 {
  margin-right: 1rem;
}
.text-success {
  color: #25af60;
}

.inner__voucher {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #f1f1f1;
}
.inner__voucher .voucher-image {
  border-radius: 10px;
  overflow: hidden;
  margin: -11px -11px auto;
}
.inner__voucher .voucher-image .tbl-body-vc .table > :not(caption) > * > * {
  border-bottom-width: 0;
  padding: 1.5rem 1.5rem;
}
.inner__voucher .voucher-image img {
  width: 100%;
}
.inner__voucher {
  background-color: #ffff;
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  background-color: #c30e13;
  color: #fff;
}
.nav-pills .nav-link {
  color: #212529;
}
.page-link {
  color: #212529;
  border: none;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: 5px;
}
.page-item.active .page-link {
  background-color: #f1f1f1;
  color: #212529;
}
.page-item.disabled .page-link {
  opacity: 0.3;
}
/*========my account page========*/
.myaccount__page {
  display: flex;
  flex-wrap: wrap;
  background-color: #ffff;
  border-radius: 10px;
  padding: 20px 20px 60px;
}
.myaccount__left {
  width: 280px;
}
.myaccount__right {
  flex: 1;
  width: 100%;
}
.myaccount__left .navmenu {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.navmenu a {
  color: inherit;
  border-radius: 3px;
}
.navmenu a:hover,
.navmenu a.active {
  color: inherit;
  background: #f1f1f1;
}
.account__inform {
  display: flex;
  justify-content: center;
  border-bottom: 1px solid #f1f1f1;
  margin-bottom: 20px;
  padding-bottom: 20px;
}
.account__icon {
  width: 30px;
  height: 30px;
  background: rgb(241 241 241);
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.account__icon svg {
  fill: #7d7d7d;
}
.account__name {
  flex: 1;
  padding-left: 10px;
}
.account__name p {
  margin-bottom: 0;
  font-weight: bold;
}
.account__name .btn-logout {
  padding: 0;
  font-size: 13px;
  color: #7d7d7d;
}

.tbl-row {
  display: flex;
  padding: 10px 0px;
}
.tbl-row .label {
  width: 25%;
  font-weight: bold;
}
.tbl-row .value {
  flex: 1;
}
.tbl-row-flight .label,
.tbl-row-hotel .label {
  width: auto;
  margin-bottom: 10px;
}
.tbl-row-flight .inner,
.tbl-row-hotel .inner {
  display: block;
  background: rgb(255 247 223);
  border-radius: 8px;
  padding: 20px;
  width: 100%;
  flex: 1;
}
.tbl-row-hotel .inner {
  background-color: #e9f7ff;
}
.tbl-row-hotel .nav-pills {
  flex-wrap: nowrap;
}
.nav-pills a {
  white-space: nowrap;
}
.message > .body-message {
  padding: 20px 15px;
  margin-bottom: 30px;
  border-radius: 10px;
}
.message > .error {
  border: 1px solid #dc3545;
  background-color: rgb(255 170 187 / 10%);
}
.message > .error i.bi {
  color: #dc3545;
}
.message > .success {
  border: 1px solid #25af60;
  background-color: rgb(114 255 175 / 10%);
}
.message > .success i.bi {
  color: #25af60;
}
.message .message-icon {
  float: left;
}
.message .message-text {
  padding-left: 30px;
}
.message-text > p:last-child {
  margin-bottom: 0;
}
.text-right {
  text-align: right;
}
.text-link {
  color: #212529;
  text-decoration: none;
}

.text-link:hover {
  color: #dc3545;
}
.btn-light-danger {
  background-color: #ffe8e8;
  color: #dc3545;
}
.btn-light-danger:hover {
  color: #fff;
  background-color: #dc3545;
}
.departs__group .depart__item + .depart__item {
  margin-top: 30px;
}
.departs__group {
  padding-left: 40px;
}
.inner__passenger {
  border: 1px solid #e2e2e2;
  padding: 20px;
  border-radius: 10px;
  height: 100%;
}
.passenger__service {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.passenger__service + .passenger__service {
  margin-top: 10px;
}
.passenger__service .btn {
  width: 100px;
}
.passenger__name .bi {
  font-size: 24px;
  margin-right: 10px;
}
.v__inform tr td.label {
  width: 220px;
}
.box__notice {
    padding: 20px 30px;
    border: 1px solid #0dcaf0;
    border-radius: 10px;
    background-color: rgb(13 202 240 / 10%);
    display: flex;
    margin-top: 30px;
    word-break: break-word;
}
.notice__icon {
  font-size: 30px;
  color: #0dcaf0;
  margin-right: 30px;
}
.section__homeslide {
  padding-top: 60px;
  padding-bottom: 0;
}
.btn-viewmore {
  background-color: rgb(230 230 230 / 50%);
  border-width: 0;
  border-radius: 20px;
  font-size: 13px;
  display: flex;
  align-items: center;
}
.btn-viewmore i {
  font-size: 10px;
  margin-left: 5px;
}
.btn-viewmore:hover {
  background-color: #ffff;
}
.header__section {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__section h3 {
  margin-bottom: 0;
  font-weight: bold;
}
.header__section {
  margin-bottom: 20px;
}

.home__slider .slick-dots {
  bottom: 0;
}
.home__slider .slick-dots li button:before {
  font-size: 12px;
  color: rgb(255 255 255);
}
.slick-dots li.slick-active button:before {
  color: red;
}
.home__slider .slick-dots li {
  margin-left: 0;
  margin-right: 0;
}
.home__slider .slick-slide img {
  border-radius: 10px;
  width: 100%;
}
.btn-small.btn-vj {
  font-size: 14px;
  min-height: 45px;
  max-width: 160px;
  min-width: 140px;
}
.voucher_item {
  display: flex;
  justify-content: space-between;
  margin-bottom: 20px;
  border: 1px solid #f1f1f1;
  padding: 10px 20px;
  border-radius: 8px;
}
.vc_item__content {
  display: flex;
  align-items: center;
}
.voucher_items {
  max-width: 450px;
  margin: auto;
}
.voucher_title {
  font-size: 18px;
  height: 48px;
  line-height: 24px;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin-bottom: 10px;
  font-weight: bold;
}
.voucher_title a {
  text-decoration: none;
  color: #212529;
}
.voucher_title a:hover {
  color: #e83156;
}
.voucher_price {
  margin-bottom: 20px;
}
.is__gift {
  /* background: #f4f4f4; */
  display: block;
  /* padding: 5px 10px; */
  border-radius: 20px;
  font-size: 14px;
}
.icon_gift {
  display: inline-flex;
  width: 20px;
  height: 20px;
  align-items: center;
  vertical-align: middle;
  margin-right: 5px;
}
.btn-secondary {
  color: #eb5757;
  background-color: #ffe8e8;
  border-color: #ffe8e8;
  border-radius: 10px;
  min-width: 100px;
  font-weight: bold;
}
.btn-secondary:hover {
  color: #eb5757;
  background-color: #ffe8e8;
  border-color: #ffe8e8;
}
.voucher__buttons {
  display: flex;

  justify-content: space-between;
  width: 100%;
  max-width: 450px;
  margin: auto;
}
.voucher__buttons .btn {
  width: 49%;
  font-size: 13px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.voucher__quickview .modal-header {
  border-bottom-width: 0;
}
.voucher__details {
}
.voucher__policy {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  width: 100%;
}
.voucher__policy .bi {
  width: 30px;
  height: 30px;
  margin-right: 15px;
  font-size: 30px;
  line-height: 1;
}
.voucher__policy p {
  margin-bottom: 0;
  font-weight: bold;
}
.voucher__policy .sub {
  font-size: 13px;
}
.summary__content {
  margin-bottom: 20px;
}
.voucher__details .btn-getvoucher {
  width: 100%;
  height: 50px;
}

.voucher__note {
  font-size: 14px;
}
.voucher__note ul {
  margin-bottom: 0;
  padding-left: 20px;
}
.voucher__detail__template {
  padding: 60px 80px 60px;
}
.voucher_price:not(.is__gift) {
  background: linear-gradient(
    91.37deg,
    #fff0f0 -3.61%,
    rgba(255, 220, 220, 0) 106.92%
  );
  padding: 10px 20px;
  font-family: jambono;
}
.voucher_price ins {
  color: #c30d13;
  font-size: 1.6rem;
  display: block;
  text-decoration: none;
}
.voucher_price del {
  font-size: 1.1rem;
  opacity: 0.6;
}
.voucher_price .vc_price_currency {
  margin-left: 5px;
}
.discount_percent {
  display: inline-block;
  font-size: 12px;
  color: #c30e13;
  background: linear-gradient(
    48.72deg,
    #f9a51a 0%,
    #fbb612 21.42%,
    #ffdd00 70.65%
  );
  border-radius: 6px;
  padding: 3px 6px;
  vertical-align: text-bottom;
  margin-left: 10px;
}
.quantity {
  display: flex;
  align-items: center;
}
.quantity span {
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  border: 1px solid #f1f1f1;
  display: inline-block;
  cursor: pointer;
  background: #f1f1f1;
  border-radius: 10px;
}
.quantity span:hover {
  background-color: #c1c1c1;
}
.quantity input {
  text-align: center;
  display: inline-block;
  flex: 1;
  height: 50px;
  border-radius: 0;
  border-color: #f1f1f1;
  margin: 0 5px;
  border-radius: 10px;
}
.voucher__detail__header .btn-getvoucher {
  height: 50px;
  width: 100%;
  /* max-width: 280px; */
}
.btn-getvoucher.has_icon .bi {
  margin-right: 10px;
}
.voucher__policies {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

/* Chrome, Safari, Edge, Opera */
input.quantity__number::-webkit-outer-spin-button,
input.quantity__number::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.alert-promo {
  background-color: #fff6f7;
  border-color: #c30d13;
  border-width: 1px;
  margin-bottom: 30px;
}
/* Firefox */
input[type="number"].quantity__number {
  -moz-appearance: textfield;
}
.voucher_title_detail {
  font-size: 2rem;
  margin-bottom: 20px;
  background: linear-gradient(91.37deg, #fff2df 5%, rgb(255 220 220 / 0%) 60%);
  padding: 10px 20px;
}
.modal-content .voucher_title_detail {
  font-size: 1.6rem;
}
h1.voucher-title {
  font-size: 1.8rem;
}

.form__group {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.voucher__detail__header .form__group .voucher__quantity,
.voucher__detail__header .form__group .btn-getvoucher {
  width: 100%;
  max-width: 240px;
}
button:focus:not(:focus-visible) {
  color: inherit;
}
.modal-body.voucher__details {
  padding: 0 1rem 1rem;
}
.checkout__page {
  padding-bottom: 180px;
}
.body-checkout__page .checkout__left__col .inner__checkout__left,
.body-checkout__page .checkout__right__col .inner__checkout__right {
  background: #fff;
  border-radius: 10px;
  padding: 30px;
  height: 100%;
}
.checkout__summary {
  font-size: 14px;
  border-radius: 10px;
  background: #f1f1f1;
  padding: 10px;
}
.checkout__summary tbody td.label {
  width: 280px;
}

.checkout__summary tbody .value,
.checkout__summary thead .dvt,
.checkout__summary tfoot .value {
  text-align: right;
  font-weight: bold;
}
.checkout__summary tfoot {
  color: #c40e14;
}
.payment__item input[type="radio"] {
  display: none;
  opacity: 0;
}
.payment__item__box {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #f1f1f1;
  padding: 10px 20px;
  border-radius: 10px;
  cursor: pointer;
  margin-bottom: 10px;
}
.payment__item input:checked ~ .payment__item__box {
  border-color: rgb(0 137 74);
  background: rgb(244 254 249);
}
.payment__item__box .icon {
  width: 40px;
  height: 40px;
  margin-right: 20px;
}
.payment__item__box .payment__type__title {
  flex: 1;
  margin-bottom: 0;
  font-weight: bold;
}
.checkout__title {
  font-size: 1.3rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.sr-only {
  display: none;
  opacity: 0;
}
.checkout__alert .alert__title {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  color: #d2494e;
}
.alert__title .promo_title {
  margin-bottom: 0;
  font-weight: bold;
  font-size: 16px;
}
.checkout__alert {
  font-size: 14px;
}
.checkout__alert p {
  margin-bottom: 0;
}
.checkout__alert ul {
  margin-bottom: 0;
  padding-left: 20px;
}
.alert__title .bi {
  margin-right: 10px;
}
.beneficiary__item {
  width: 50%;
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 20px;
}
.beneficiary__item .beneficiary__inner {
  border: 1px solid #f1f1f1;
  padding: 10px;
  border-radius: 10px;
}
.beneficiary__item p {
  margin-bottom: 0;
}
.beneficiary__item .beneficiary__footer {
  text-align: right;
  margin-top: 10px;
}
.beneficiary__item .btn .bi {
  margin-right: 5px;
}
.beneficiary__item .btn {
  font-size: 12px;
}
.beneficiary__item .btn-delete {
  color: #c30e13;
}
.beneficiary__body {
  display: flex;
}
.beneficiary__body .beneficiary__icon {
  width: 30px;
}
.beneficiary__icon .bi {
  font-size: 20px;
}
.beneficiary__body .beneficiary__information {
  flex: 1;
}
.beneficiaries {
  display: flex;
  align-items: center;
  margin-left: -10px;
  margin-right: -10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.checkout__buttons .btn-primary {
  width: 100%;
}
.beneficiary__container {
  border: 1px solid #f1f1f1;
  border-radius: 10px;
  padding: 15px;
  transition: all linear 240ms;
}
.gift_note {
  padding: 10px;
  font-size: 14px;
}
.gift_note p,
.gift_note ul {
  margin-bottom: 0;
}
.gift_note ul {
  padding-left: 20px;
}
.beneficiary__container.show {
  opacity: 1;
  pointer-events: all;
  max-height: auto;
}
.beneficiary__container.hide {
  opacity: 0;
  pointer-events: none;
  max-height: 0px;
}
.template_type {
  display: flex;
  align-items: center;
  margin-left: -5px;
  margin-right: -5px;
}
.template_type_item {
  width: 80px;
  padding: 5px;
}
.template_type_item input {
  display: none;
  opacity: 0;
  pointer-events: none;
}
.template_type_item .template_type_icon {
  padding: 5px;
  border: 1px solid #f1f1f1;
  border-radius: 5px;
  cursor: pointer;
}
.template_type_item input:checked ~ .template_type_icon {
  border-color: green;
}
.pax_modal_title {
  font-size: 1.1rem;
  font-weight: bold;
}
.modalpax .modal-body {
  padding-bottom: 0;
  padding-top: 0;
}
.modalpax .modal-footer {
  border-top-width: 0;
}
.modalpax .modal-footer .btn {
  font-size: 16px;
  min-height: 40px;
  min-width: 140px;
  border-radius: 6px;
}
.modalpax .modal-header {
  border-bottom: 0;
  padding-bottom: 0;
}
.modalpax .invalid-feedback {
  font-size: 10px;
  margin-bottom: 0;
}
.voucher-box ins {
  font-size: 1.2rem;
}
.voucher-box del {
  font-size: 1rem;
}
.voucher-box .voucher_price:not(.is__gift) {
  padding: 5px 10px;
}
.voucher-box .discount_percent {
  float: right;
}
.voucher-breadcrumb {
  font-size: 13px;
}
.voucher-breadcrumb .breadcrumb {
  flex-wrap: nowrap;
}
.voucher-breadcrumb a {
  color: #3c3c3c;
  text-decoration: none;
}
.header__inform {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__inform .btn-edit {
  background: rgb(241 241 241);
  border-radius: 20px;
  font-size: 13px;
  padding: 3px 10px;
}
.header__inform h1.title,
.header-myaccount__page .title {
  font-size: 24px;
}
.btn-edit i {
  margin-right: 5px;
}
.account__information .table-inform {
  background-color: #f1f1f1;
  padding: 10px 20px;
  border-radius: 10px;
}
.tbl-vouchers .tbl-body-vc {
  font-size: 13px;
  white-space: nowrap;
}
.tbl-vouchers .btn-sm {
  font-size: 13px;
}
.tbl-body-vc .price {
  color: #00a847;
}
.pnr__page .buttons {
  text-align: center;
}

/*=====booking form======*/

.expanded .row--date--passenger {
  display: block;
}
.booking__form--buttons {
  display: flex;
  align-items: flex-end;
  margin-bottom: 15px;
  width: 30%;
}

.booking__form--row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  flex: 1;
}
.booking__form--row .booking__form--col {
  margin-bottom: 15px;
}
.booking__form--row .booking__form--depart,
.booking__form--row .booking__form--return {
  flex: 1;
}
.booking__form--destination {
  display: flex;
  align-items: center;
  flex: 1;
  position: relative;
  flex-wrap: wrap;
  margin-right: 15px;
}
.booking__form--date {
  flex-basis: 45%;
  width: 45%;
}
.booking__form--triptype {
  display: flex;
}
.booking__form--destination .booking__flight--icon {
  width: 20px;
  height: 20px;
  border-radius: 20px;
  /* border: 1px solid #ced4da; */
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  position: absolute;
  left: calc(50% - 10px);

  background-color: #fff;
}
.booking__form--destination .booking__flight--icon img {
  opacity: 0.3;
}
.booking__form .select2-container .select2-selection--single,
.trip__date .trip__date--wrap {
  padding: 5px 15px;
  height: 50px;
}
.booking__form
  .select2-container--default
  .select2-selection--single
  .select2-selection__rendered {
  line-height: inherit;
  padding: 0;
}
.booking__form
  .select2-container--default
  .select2-selection--single
  .select2-selection__arrow {
  height: 40px;
  width: 30px;
  display: none;
}
.select2-container--default .select2-results > .select2-results__options {
  max-height: 300px;
}
.select2-results__message {
  padding: 10px;
  text-align: center;
}
.booking__form__dropdown .citypare,
.booking__form .citypare {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.25;
}
.booking__form__dropdown .citypare p,
.booking__form .citypare p {
  margin-bottom: 0;
}
.booking__form__dropdown .citypare__code {
  font-weight: 900;
}
.booking__form__dropdown .select2-results__group {
  padding: 10px 15px;
  color: #f93355;
  text-transform: uppercase;
}
.booking__form__dropdown .citypare__name i,
.trip__date--icon {
  margin-right: 10px;
}
.select2-container--default
  .booking__form__dropdown
  .select2-results__option
  .select2-results__option {
  padding: 10px 15px;
}
.select2-container--default
  .booking__form__dropdown
  .select2-results__option--highlighted.select2-results__option--selectable {
  background-color: #f1f1f1;
  color: inherit;
}
.booking__form__wrapper {
  background: linear-gradient(359deg, #da1a23, #f70e4c, #ff6b6b);
  padding: 20px 30px 15px;
  border-radius: 5px;
}
.booking__form--tabs {
  margin-bottom: 20px;
}
.booking__form--tab--item {
  display: inline-flex;
  align-items: center;
  color: #fff;
  padding: 10px 15px;
  text-transform: uppercase;
  border-radius: 5px;
  font-size: 14px;
  cursor: pointer;
}
.booking__form--tab--item + .booking__form--tab--item {
  margin-left: 5px;
}
.booking__form--tab--item .tab--item--icon {
  margin-right: 5px;
  width: 26px;
  height: 26px;
}
.booking__form--tab--item.active,
.booking__form--tab--item:hover {
  background-color: rgb(0 0 0 / 10%);
}
.booking__form__row {
  margin-bottom: 15px;
}
.citypare--selection .citypare__code {
  text-align: center;
  font-weight: bold;
  background: #767676;
  border-radius: 4px;
  color: #fff;
  padding: 0 6px;
  margin-left: 10px;
}
.trip__date--text .booking__date--text,
.trip__date--text .booking__date--value {
  display: block;
}
.trip__date--text .booking__date--value {
  text-transform: capitalize;
}
.citypare--selection .citypare__name {
  text-overflow: ellipsis;
  overflow: hidden;
  font-weight: bold;
}
.booking__form .select2-container--default .select2-selection--single,
.booking__form__dropdown,
.booking__form
  .select2-container--default
  .select2-search--dropdown
  .select2-search__field {
  border-color: #fff;
  border-radius: 0px;
}
.trip__date .trip__date--depart,
.trip__date .trip__date--return,
.trip__date .trip__date--checkin,
.trip__date .trip__date--checkout {
  cursor: pointer;
  border: 1px solid #fff;
  display: flex;
  align-items: center;
  flex-basis: 50%;
  width: 50%;
}
.booking__form
  .booking__form--depart
  .select2-container--default
  .select2-selection--single,
.trip__date--wrap.trip__date--depart {
  border-right-color: #f1f1f1;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
}
.booking__form
  .booking__form--return
  .select2-container--default
  .select2-selection--single,
.trip__date--wrap.trip__date--return {
  border-left-color: #f1f1f1;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
}
.trip__date.oneway .trip__date--wrap.trip__date--depart {
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
}
.trip__date.oneway .trip__date--return {
  display: none;
  pointer-events: none;
}
.select2-search--dropdown .select2-search__field:focus-visible {
  outline: none !important;
}
.booking__form--destination .select2-selection--single {
  display: flex;
  align-items: center;
}
.province--name {
  display: block;
  font-weight: bold;
}
.citypare--name {
  font-size: 13px;
}
.booking__form .select2-container {
  width: 100% !important;
}
.booking__form .select2-container--open .select2-selection--single,
.booking__form__dropdown:not(.select2-dropdown--above),
.booking__form
  .select2-container--default
  .select2-search--dropdown
  .select2-search__field {
  box-shadow: 0px 6px 8px -4px #0000007a;
}
.booking__form__dropdown:not(.select2-dropdown--above) {
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}
.booking__form__dropdown.select2-dropdown--above {
  box-shadow: 0px -6px 8px -4px #0000007a;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}
.booking__form__dropdown {
  border-width: 0;
  overflow: hidden;
}
.select2-search--dropdown {
  padding: 10px 15px;
}
.booking__form
  .booking__form--depart
  .select2-container--open:not(.select2-container--above)
  .select2-selection--single {
  border-bottom-left-radius: 0 !important;
}
.booking__form
  .booking__form--return
  .select2-container--open:not(.select2-container--above)
  .select2-selection--single {
  border-bottom-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
}
.booking__form
  .booking__form--depart
  .select2-container--open.select2-container--above
  .select2-selection--single {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
.booking__form
  .booking__form--return
  .select2-container--open.select2-container--above
  .select2-selection--single {
  border-top-right-radius: 0 !important;
}
.select2-container--default
  .select2-selection--single
  .select2-selection__placeholder {
  display: block;
  color: inherit;
  /* transition: all linear 240ms; */
}
/* .booking__form .select2-container--open .select2-selection__placeholder, */
.booking__form .select2-selection__placeholder.selected {
  font-size: 13px;
  /* margin-top: -10px; */
}
.trip__date {
  display: flex;
  align-items: center;
  justify-content: center;
}
.header--btns .btn-outline-dark:active {
  background-color: transparent;
  color: #000;
}

.trip__date--wrap {
  flex: 1;
  background-color: #fff;
}

.trip__date--wrap .booking__date--text {
  width: 100%;
}
.trip__date--wrap.selecting .bi-calendar2-week-fill::before {
  color: #fa3656;
}
.trip__date--wrap.selected .booking__date--text {
  font-size: 13px;
}
.trip__date--text {
  overflow: hidden;
  font-size: 15px;
  line-height: 1.25;
}
.trip__date--wrap.selected .booking__date--value {
  font-weight: bold;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.booking__form--col--depart {
  padding-right: 0;
}
.booking__form--col--return {
  padding-left: 0;
}
.booking__form
  .booking__form--col--depart
  .select2-container--default
  .select2-selection--single {
  border-right-width: 0;
}
.booking__form
  .booking__form--col--return
  .select2-container--default
  .select2-selection--single {
  border-left-width: 0;
}
.btn-booking {
  height: 50px;
  padding: 0 30px;
  border-radius: 5px;
  font-family: Jambono;
  width: 100%;
}
.trip__date--icon i,
.passenger--icon i {
  color: #ced4da;
  font-size: 24px;
}
.booking__form--passenger {
  width: 40%;
  flex-basis: 40%;
  position: relative;
  padding-right: 15px;
}
.booking__form--passenger--inner {
  position: relative;
}
.booking__form--passenger--control {
  height: 50px;
  border: 1px solid #fff;
  padding: 5px 15px;
  display: flex;
  align-items: center;
  background-color: #fff;
  border-radius: 5px;
  cursor: pointer;
}
.booking__form--passenger--control .passenger--text {
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
  font-size: 15px;
  line-height: 1.25;
}
.booking__form--passenger--control .passenger--text .passenger--label {
  display: block;
  font-size: 13px;
}
.booking__form--passenger--control .passenger--icon {
  margin-right: 10px;
  pointer-events: none;
}
.open .booking__form--passenger--control {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.passenger--value {
  font-weight: bold;
  white-space: nowrap;
}

.booking__form--passenger--dropdown {
  position: absolute;
  padding: 20px;
  background-color: #fff;
  width: 100%;
  box-shadow: 0px 6px 8px -4px #0000007a;
  border-radius: 0 0 5px 5px;
  pointer-events: none;
  display: none;
  border-top: 1px solid transparent;
}
.open .booking__form--passenger--dropdown {
  display: block;
  pointer-events: all;
  z-index: 999;
  border-top-color: #939598;
}
.booking__form--passenger--dropdown--inner > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 10px;
  font-size: 15px;
}
.booking__form--passenger--dropdown--inner > div:last-of-type {
  margin-bottom: 0;
}
.children__ages.is-empty {
  margin-bottom: 0;
}
.booking__form--passenger--dropdown .line {
  width: 100%;
  height: 1px;
  background-color: #f1f1f1;
  margin-bottom: 20px;
}
.passenger__input--left {
  display: flex;
}
.passenger__input--icon {
  width: 30px;
  margin-right: 15px;
}
.passenger__input--icon img {
  width: 100%;
}
.booking__form--adult p:first-child,
.booking__form--infant p:first-child,
.booking__form--children p:first-child,
.booking__form--rooms p:first-child {
  margin-bottom: 0;
  font-weight: bold;
}
.booking__form--adult p.small,
.booking__form--infant p.small,
.booking__form--children p.small {
  font-weight: normal;
  font-size: 13px;
  margin-bottom: 0;
}
.booking__quantity {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
.booking__quantity--up,
.booking__quantity--down {
  width: 30px;
  height: 30px;
  border-radius: 2px;
  border: 1px solid #939598;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.booking__quantity--value {
  display: inline-block;
  width: 40px;
  text-align: center;
}
.booking__quantity--up:hover,
.booking__quantity--down:hover {
  border-color: #c30c13 !important;
  color: #c30c13;
}
.booking__form--promo--inner {
  position: relative;
}

.booking__form--promo--popup {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  pointer-events: none;
}

.booking__form--promo .promo-verify-input input {
  padding: 5px 15px;
  border-width: 1px;
  border-radius: 5px;
  border-top-left-radius: 5px !important;
  border-bottom-left-radius: 5px !important;
}
.promo--popup--header h3 {
  margin-bottom: 15px;
  font-size: 20px;
}
.promo--popup--header .promo-close {
  width: 40px;
  height: 40px;
  text-align: center;
  position: absolute;
  right: 0;
  top: 0;
  line-height: 40px;
  cursor: pointer;
}
.booking__form--promo {
  padding-right: 15px;
  width: 30%;
}
.overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: rgb(0 0 0 / 60%);
  opacity: 0;
  transition: all linear 320ms;
}
.promo--popup--wrapper {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: all linear 320ms;
}
.promo--popup--wrapper .promo--verify {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 450px;
  background-color: #fff;
  padding: 15px 20px;
  border-radius: 5px;
}
.form-control.is-invalid,
.was-validated .form-control:invalid {
  border-color: #dc3545;
}
.btn-apply-voucher,
.btn-apply-voucher:hover,
.btn-apply-voucher:active,
.btn-apply-voucher:focus {
  border: 1px solid #ff9800;
  color: #ff9800 !important;
}
.booking__form--promo .booking__form--control {
  background-color: #fff;
  display: flex;
  align-items: center;
  padding: 5px 15px;
  border-radius: 5px;
  height: 50px;
}
.booking__form--control .promo-icon {
  margin-right: 10px;
  width: 24px;
}
.booking__form--control .promo-icon svg,
.booking__form--control .promo-icon path {
  fill: #ced4da;
  display: block;
}
.booking__form--control .booking__form--control--input {
  position: relative;
}
.has-code label {
  display: none;
  opacity: 0;
}
.booking__form--control .booking__form--control--input label {
  position: absolute;
  margin-bottom: 0;
  height: 24px;
  left: 0;
  top: calc(50% - 12px);
  font-weight: normal;
  cursor: pointer;
}
.promocode__mask {
}
.promocode__mask .code-valid {
  font-weight: bold;
  color: green;
}
.code-valid i {
  margin-left: 5px;
  background-color: #ced4da;
  width: 16px;
  height: 16px;
  display: inline-block;
  text-align: center;
  line-height: 16px;
  border-radius: 50%;
  color: #000;
  font-size: 12px;
  opacity: 0.5;
}
.booking__form--control .booking__form--control--input {
  width: 100%;
}
.booking__form--promo.expanded .overlay,
.booking__form--promo.expanded .promo--popup--wrapper {
  opacity: 1;
}
.booking__form--promo.expanded .booking__form--promo--popup {
  pointer-events: all;
}
.booking__form--promo .booking__form--control {
  cursor: pointer;
}

.booking__form--control--input input:focus ~ label,
.booking__form--control--input input:not(:empty) ~ label {
  font-size: 13px;
  font-weight: normal;
  top: -5px;
}
.booking__form--triptype .form-check-label {
  color: #fff;
  position: relative;
  padding-left: 30px;
}
.booking__form--triptype .form-check-inline {
  padding-left: 0;
  white-space: nowrap;
}
.booking__form--triptype .form-check-label:before {
  content: "";
  width: 22px;
  height: 22px;
  display: block;
  border: 1px solid #fff;
  position: absolute;
  left: 0;
  border-radius: 30px;
  top: calc(50% - 11px);
  background-color: #fff;
  opacity: 1 !important;
}
.booking__form--triptype .form-check-label:after {
  content: "";
  position: absolute;
  border-radius: 20px;
  background-color: #fab416;
  width: 14px;
  height: 14px;
  border-width: 0;
  left: 4px;
  top: calc(50% - 7px);
  box-shadow: 0px 0px 3px -1px rgb(0 0 0 / 70%);
  opacity: 0;
  display: none;
}
.booking__form--triptype input {
  display: none;
  pointer-events: none;
}
.booking__form--triptype input:checked ~ .form-check-label:before {
  border-color: #fff;
}
.booking__form--triptype input:checked ~ .form-check-label:after {
  opacity: 1;
  display: block;
}
.booking__form--triptype input:checked ~ label {
  opacity: 1;
}
#trip__date--dropdown {
  position: relative;
}
#trip__date--dropdown .daterangepicker {
  width: 600px;
  margin-top: 1px;
}
.daterangepicker .calendar-table th:not(.month) {
  color: #ee0810 !important;
}
.daterangepicker {
  border-width: 0;
  border-radius: 5px;
  box-shadow: 0px 6px 8px -4px #0000007a;
}
.daterangepicker .calendar-table th,
.daterangepicker .calendar-table td {
  height: 40px;
  font-size: 13px;
  min-width: 40px;
}
.daterangepicker .calendar-table td.today {
  border-color: #ee0810;
}
.daterangepicker .calendar-table table {
  border-collapse: inherit;
}
.daterangepicker .drp-calendar.left {
  padding: 15px 0 15px 15px;
  width: 50%;
}
.daterangepicker .drp-calendar.right {
  padding: 15px;
  width: 50%;
}
.daterangepicker .drp-selected {
  display: none;
}
.daterangepicker .drp-calendar {
  max-width: 100%;
}

/* .in-range.available:not(.end-date), 
.in-range.available:not(.active){
    border-radius: 0 !important;
} */
.daterangepicker td.start-date.end-date {
  border-radius: 5px;
}
.daterangepicker td.off,
.daterangepicker td.off.in-range,
.daterangepicker td.off.start-date,
.daterangepicker td.off.end-date {
  text-decoration: inherit;
  opacity: 0.5;
  pointer-events: none;
  background-color: transparent !important;
  border-color: transparent !important;
  color: #999 !important;
}
.daterangepicker td.active:not(.start-date),
.daterangepicker td.active:not(.start-date):hover {
  background-color: transparent;
  border-color: #ee0810;
  color: inherit;
}
.daterangepicker .calendar-table th.month {
  font-size: 16px;
}
.daterangepicker td.start-date {
  border-radius: 5px 0 0 5px;
  background-color: #ee0810 !important;
  color: #fff !important;
}

.daterangepicker td.end-date {
  border-radius: 0 5px 5px 0;
  background-color: #ee0810 !important;
  color: #fff !important;
}
.daterangepicker .drp-buttons .btn {
  font-family: Jambono;
  height: 50px;
  min-width: 180px;
  font-size: 16px;
  border-radius: 5px;
}
.daterangepicker .drp-buttons {
  padding: 15px 20px;
}
.daterangepicker.start.opensright:after,
.daterangepicker.opensleft:after {
  content: none;
  right: 10px;
  left: auto;
}
.daterangepicker.start.opensright:before,
.daterangepicker.opensleft:before {
  content: none;
  right: 10px;
  left: auto;
}
.daterangepicker.auto-apply-bystep .drp-buttons {
  display: none;
}

.daterangepicker.opensright:after,
.daterangepicker.opensright:before,
.daterangepicker.opensleft:before,
.daterangepicker.opensleft:after {
  content: none;
}
.booking__popup {
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  pointer-events: all;
  opacity: 1;
}

.booking__popup .popup__overlay {
  background-color: rgb(0 0 0 / 60%);
  width: 100%;
  height: 100%;
  z-index: 2;
  position: absolute;
  left: 0;
  right: 0;
}
.booking__popup .popup__container {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  padding-left: 15px;
  padding-right: 15px;
}
.booking__popup .popup__content {
  background-color: #fff;
  width: 100%;
  max-width: 450px;
  padding: 20px 15px;
  border-radius: 5px;
  position: relative;
  z-index: 4;
}
.booking__popup p.icon {
  text-align: center;
  font-size: 24px;
  margin-bottom: 10px;
}
.booking__popup p.icon.error {
  color: #ffc107;
}
.booking__popup p.label {
  text-align: center;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.booking__popup p.content {
  text-align: center;
}

/*============booking hotel ==============*/

.booking__form.booking-hotel {
}

.booking__form.booking-hotel .booking__form--hotel {
  width: calc(25% - 15px);
  flex-basis: calc(25% - 15px);
  margin-right: 15px;
}
.booking__form--hotel select:disabled {
  border-color: #e9ecef;
  cursor: not-allowed;
}

.booking__form--hotel select {
  height: 50px;
  border-color: #fff;
  font-weight: bold;
  font-size: 15px;
}
.booking__form.booking-hotel .booking__form--passenger {
  width: calc(35%);
  flex-basis: calc(35%);
}
.booking__form.booking-hotel .booking__form--date {
  width: calc(40% - 15px);
  flex-basis: calc(40% - 15px);
  margin-right: 15px;
}
.booking__form.booking-hotel .booking__form--buttons {
  width: 15%;
  flex-basis: 15%;
}
.booking__form.booking-hotel .trip__date {
  border-radius: 5px;
  overflow: hidden;
}
.children-age {
  margin-bottom: 15px;
  width: 48%;
}
.children-age select {
  padding: 5px 40px 5px 10px;
  border-radius: 5px;
  font-size: 13px;
}
.label-age {
  display: block;
  width: 100%;
  flex-basis: 100%;
}
.booking__form.booking-hotel .booking__form--col {
  /* flex: 1 */
}
.booking__form--note {
  width: 100%;
  flex-basis: 100%;
  padding-right: 15px;
}
.pax--note {
  resize: none;
  border-radius: 5px;
  border-color: #fff;
  width: 100%;
  flex-basis: 100%;
}
.booking__form.booking-hotel .booking__form--inner {
  display: flex;
  flex-wrap: wrap;
  align-items: start;
}

.note-check {
  display: inline-flex;
  align-items: center;
  color: #fff;
  margin-bottom: 10px;
  cursor: pointer;
}
.note-check .checkbox {
  position: relative;
  width: 20px;
  height: 20px;
  display: inline-block;
  background-color: #fff;
  margin-right: 10px;
  border-radius: 3px;
}
.note-check .checkbox.checked:after {
  content: "";
  position: absolute;
  border-top: 2px solid #e81438;
  border-left: 2px solid #e81438;
  width: 8px;
  height: 12px;
  transform: rotate(-135deg);
  left: calc(50% - 4px);
  top: calc(50% - 6px);
}
.note-check .checkbox.checked {
  background-color: #fbb711;
}
.inner--form--note:not(.open) .form-note {
  display: none;
}
/*==== flight option=====*/
.booking__layout--header {
  background: linear-gradient(
    21.74deg,
    #f9a51a 2.28%,
    #fbb612 27.93%,
    #ffdd00 86.9%
  );
}
.booking__layout--header--status {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.status__inner {
  display: flex;
  align-items: center;
  margin: 0;
  list-style-type: none;
  padding: 0;
}
.status__inner .step {
  color: #fff;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin-right: 20px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
}
.status__inner .step span {
  display: inline-block;
  line-height: 0;
}
.status__inner .step:last-of-type {
  margin-right: 0px;
}
.status__inner .step:after {
  content: "";
  width: 20px;
  height: 1px;
  background-color: #fff;
  right: -20px;
  position: absolute;
  top: calc(50% - 0.5px);
}

.status__inner .step:last-of-type:after {
  content: none;
}
.status__inner svg,
.status__inner path {
  fill: #ffdb04;
  width: 18px;
}

.status__inner .step.current,
.status__inner .step.done,
.status__inner .step.done:after {
  background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
}
.status__inner .step.current svg,
.status__inner .step.current path,
.status__inner .step.done path,
.status__inner .step.done svg {
  fill: #fff;
}
.booking__layout--header > .container {
  padding-top: 20px;
  padding-bottom: 20px;
}
.booking__layout--header--infor {
  display: flex;
  align-items: center;
}
.booking__layout--header--infor p {
  margin-bottom: 0;
}
.booking__layout--header--infor .header--infor {
  margin-right: 20px;
}
.header--infor .destinations {
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  color: #e2192f;
}
.header--infor .destinations .icon {
  margin: 0 5px;
}
.header--infor .triptype-passengers {
  font-size: 14px;
  display: flex;
}
.booking__layout--container {
  padding-top: 30px;
}

.triptype-passengers span {
  display: inline-block;
  color: #3c3c3c;
}
.triptype-passengers span svg,
.triptype-passengers span path {
  fill: #3c3c3c;
  width: 12px;
  height: 12px;
  margin-top: -3px;
}
.triptype-passengers .status-triptype {
  margin-right: 8px;
  padding-right: 8px;
  position: relative;
}
.header--infor span.icon {
  width: 14px;
  height: 14px;
  text-align: center;
}
.triptype-passengers .status-triptype span.icon svg {
  transform: rotate(-90deg);
  margin-top: -3px;
}
.triptype-passengers .status-triptype:after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  width: 1px;
  height: 10px;
  background-color: black;
  top: calc(50% - 5px);
}
.flight-option-item {
  margin-bottom: 30px;
  border-radius: 10px;
  border: 2px solid transparent;
  overflow: hidden;
}
.booking__layout--filters {
  display: none;
  opacity: 0;
  pointer-events: none;
  margin-bottom: 15px;
}
.flight-option-bar {
  /* background-color: #fff; */
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
  z-index: 9;
  height: 120px;
}
.flight-option-bar > div {
  position: relative;
}
.flight-option-top {
  display: flex;
  align-items: center;
  padding-left: 20px;
  padding-right: 20px;
  height: 100%;
  background-color: #ffff;
  flex: 1;
  z-index: 9;
}
.flight-option-price {
  padding-right: 20px;
  width: 25%;
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
}
.flight-option-price span.line {
  position: absolute;
  width: 1px;
  top: 13px;
  bottom: 13px;
  display: block;
  border-left-width: 1px;
  border-left-style: dashed;
  border-color: transparent transparent transparent #e5e5e5;
  z-index: 2;
  left: 0;
}
.flight-option-price-wrap {
  z-index: 2;
}
.flight-option-price:after,
.flight-option-price:before,
.flight-option-infor:after,
.flight-option-infor:before {
  content: "";
  position: absolute;
  width: 26px;
  height: 26px;
  border-radius: 26px;
  background-color: transparent;
}
.flight-option-price:after {
  box-shadow: 150px -250px 0px 300px #fff,
    inset 0px 0px 4px 0px rgb(0 0 0 / 10%);
  top: -13px;
  left: -13px;
}
.flight-option-price:before {
  box-shadow: 150px 250px 0px 300px #fff, inset 0px 0px 4px 0px rgb(0 0 0 / 10%);
  bottom: -13px;
  left: -13px;
}
.flight-option-infor:after {
  box-shadow: -100px -252px 0px 300px #fff,
    inset 0px 0px 4px 0px rgb(0 0 0 / 10%);
  top: -13px;
  right: -13px;
}
.flight-option-infor:before {
  box-shadow: -100px 252px 0px 300px #fff,
    inset 0px 0px 4px 0px rgb(0 0 0 / 10%);
  bottom: -13px;
  right: -13px;
}
.flight-option-item.expanded .flight-option-infor:before,
.flight-option-item.expanded .flight-option-price:before {
  background-color: #fff;
}
.flight-option-price p {
  margin-bottom: 0;
  font-family: Jambono;
  text-align: right;
  line-height: 1;
}

.flight-option-price p.price del {
  font-size: 14px;
  color: #3c3c3c;
  opacity: 0.6;
}
.flight-option-price p.price ins {
  text-decoration: none;
  color: red;
  font-size: 26px;
}
ins .currency-symbol {
  margin-left: 5px;
  font-size: 20px;
}
del .currency-symbol {
  margin-left: 3px;
}
.flight-option-middle-inner {
  display: flex;

  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  max-width: 420px;
  height: 60px;
  margin-left: auto;
  margin-right: auto;
}
.flight-option-middle-inner:after {
  content: "";
  position: absolute;
  border-top: 1px dashed #c1c1c1;
  top: calc(50% - 0.5px);
  left: 20px;
  right: 20px;
}
.flight-option-middle-inner .flight-option-icon {
  position: relative;
  z-index: 2;
  text-align: center;
}
.flight-option-icon svg,
.flight-option-icon path {
  fill: #c1c1c1;
  width: 18px;
}
.flight-option-middle-inner .flight-option-icon .flight-code,
.flight-aircraft,
.flight-option-icon .text-label,
.flight-option-stop .text-label {
  position: absolute;
  top: -18px;
  font-size: 12px;
  width: 80px;
  height: 20px;
  left: calc(50% - 40px);
  text-align: center;
}
.flight-aircraft {
  bottom: -18px;
  top: auto;
}
.flight-option-icon .text-label,
.flight-option-stop .text-label {
  bottom: -20px;
  top: auto;
}
.flight-option-top .flight-option-time {
  font-size: 30px;
  font-weight: 300;
  display: block;
  line-height: 1.2;
}
.flight-option-top .flight-option-city,
.flight-option-top .flight-option-date,
.duration-label,
.duration-time {
  font-size: 13px;
  color: #3e3e3e;
}

.flight-option-location-time {
  text-align: left;
  width: 100px;
}
.flight-option-location-time span {
  display: block;
}
.flight-option-types {
  flex: 1;
}
.flight-option-infor {
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 14px;
  height: 100%;
  display: flex;
  align-items: center;
  z-index: 9;
  overflow: hidden;
}
.flight-option-infor ul {
  padding: 0;
  margin: 0;
  list-style-type: none;
  display: flex;
  align-items: center;
  z-index: 2;
}
.flight-option-infor ul li + li {
  margin-left: 15px;
}

.flight-option-infor p {
  margin-bottom: 0;
}
.btn-flight-option-detail {
  background: #fff;
  padding: 5px 10px;
  font-size: 13px;
  border: 1px solid #dcdcdc;
}
.btn-flight-option-detail i {
  font-size: 10px;
  display: inline-block;
  transition: all linear 480ms;
}
.expanded .btn-flight-option-detail i {
  transform: rotateX(-180deg);
}
.flight-option-icon .icon-flight {
  line-height: 1;
  background: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}

.flight-option-stop {
  position: relative;
}
.name-stop {
  position: absolute;
  width: 50px;
  left: calc(50% - 25px);
  text-align: center;
  font-weight: bold;
  top: -25px;
}

.icon-stop {
  position: relative;
  width: 14px;
  height: 14px;
  display: block;
  border-radius: 10px;
  border: 1px solid #c1c1c1;
  background-color: #fff;
  margin: 5px 0;
  z-index: 2;
}
.flight-option-types .icon-stop {
  margin-left: 60px;
  margin-right: 60px;
}
.icon-stop:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  left: calc(50% - 4px);
  top: calc(50% - 4px);
  background-color: #c1c1c1;
}
.ic-circle {
  width: 100%;
  height: 100%;
  display: block;
  background: #fff;
  border-radius: 50%;
}

.flight-option-btns {
  text-align: right;
  margin-left: auto;
  margin-top: 10px;
}
.btn-booking-selecting {
  background: linear-gradient(
    2deg,
    #f9a51a 2.28%,
    #fbb612 27.93%,
    #ffdd00 86.9%
  );
  border-width: 0;
  padding: 5px 20px;
  border-radius: 5px;
  font-size: 14px;
  box-shadow: 0px 3px 6px -4px #000000a3;
  font-family: Jambono;
}
.flight-option-dropdown {
  position: relative;
  z-index: 9;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  transition: all linear 320ms;
  height: 0;
  pointer-events: none;
  opacity: 0;
}
.flight-option-item.expanded {
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}
.flight-option-item.expanded .flight-option-dropdown {
  overflow: hidden;
  pointer-events: all;
  opacity: 1;
}
.flight-option-dropdown .dropdown-inner {
  padding: 20px;
  background: linear-gradient(to bottom, #ffe7e5 0%, #fff 15%);
}
.booking__date--bar {
  margin-bottom: 20px;
}
.booking__layout {
  background-attachment: fixed;
}
.booking__layout--title .title,
.booking__summary-header .title {
  font-size: 24px;
  margin-bottom: 0;
}
.booking__layout--title h3 {
  display: flex;
  align-items: center;
  line-height: 1.5;
  font-weight: bold;
}
.booking__layout--title .title--icon {
  display: inline-block;
  line-height: 0;
  margin: 0 10px;
}
.booking__layout--title .title--icon svg {
  width: 14px;
}
.flight-option-detail .flight-option-depart {
  position: relative;
  padding-bottom: 20px;
  padding-top: 20px;
}
.flight-option-detail .flight-option-depart:after {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #f1f1f1;
  position: absolute;
  left: 20px;
  top: 20px;
}
.flight-option-detail .flight-option-depart.depart-last:after {
  height: 50%;
}
.flight-option-detail .flight-option-depart p {
  margin-bottom: 0;
}
.flight-option-detail-inner > div > div {
  position: relative;
  padding-left: 80px;
}

.option-detail-icon .icon-stop {
  border-color: #c30c13;
}
.option-detail-icon .icon-stop:after {
  background-color: #c30c13;
}
.flight-option-detail-inner .option-detail-icon {
  position: absolute;
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 50%;
  z-index: 2;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  top: calc(50% - 20px);
  line-height: 1;
}
.flight-option-detail-inner .option-detail-icon.bottom {
  top: calc(50% - 50px);
}
.flight-option-detail-inner ul {
  list-style-type: none;
  padding-left: 0;
  margin-left: 0;
}

.flight-option-detail .flight-option-depart .option-label {
  width: 220px;
  font-weight: bold;
}
.flight-option-detail
  .flight-option-depart
  .option-detail-flight-city-airport
  + .option-detail-flight-city-airport
  ul {
  margin-bottom: 0;
}
.flight-option-detail .flight-option-depart .option-value {
  flex: 1;
}
.flight-option-detail .option-value .city {
  font-weight: bold;
}
.flight-option-detail .option-value .aircraft {
  display: flex;
  margin-top: 20px;
  color: #737373;
}
.flight-option-detail .option-value .aircraft p {
  text-transform: uppercase;
  font-size: 12px;
}
.flight-option-detail .option-value .aircraft p + p {
  margin-left: 45px;
}
.option-detail-content p.flight-code {
  color: red;
  font-weight: bold;
  text-transform: uppercase;
}
.flight-option-onstop {
  position: relative;
  padding: 10px 20px;
  background: #f1f1f1;
  margin-left: -20px;
  margin-right: -20px;
}
.flight-option-onstop .option-detail-icon {
  background-color: transparent;
}

.option-detail-icon .bi-geo-alt-fill {
  color: #81d33f;
  font-size: 22px;
}
.booking__layout--flights.flight-selected .booking__layout--date {
  display: none;
}
.booking__layout--flights.flight-selected .flight-option-item.selecting {
  border-color: green;
}

.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-price:after,
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-price:before,
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-infor:after,
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-infor:before {
  background-color: green;
}
.booking__layout--flights.flight-selected .flight-option-item:not(.selecting) {
  display: none;
  pointer-events: none;
}
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-infor:before,
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-infor:after {
}
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-price:before,
.booking__layout--flights.flight-selected
  .flight-option-item.selecting
  .flight-option-price:after {
}

.flight-selected .booking__layout--filters {
  display: block;
  opacity: 1;
  pointer-events: all;
}
.booking__layout--filters--btns {
  display: flex;
  justify-content: flex-end;
}
.booking__layout--filters--btns button i {
  margin-right: 5px;
}
.btn-status {
  display: inline-block;
  border-radius: 20px;
  color: green;
  font-size: 13px;
}
.btn-status i {
  background-color: green;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  color: #fff;
  text-align: center;
  font-size: 18px;
  float: right;
  margin-left: 5px;
  line-height: 1.1;
}
.flight-option-onstop p {
  margin-bottom: 0;
}
.option-detail-icon .icon-flight svg,
.option-detail-icon .icon-flight path {
  fill: #ff0000;
}

.option-detail-content {
  display: flex;
}
.vj__loading-container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  max-width: 150px;
  margin-left: auto;
  margin-right: auto;
}
.vj__loading-image {
  position: relative;
  width: 150px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  /* background: linear-gradient(180deg, #9fdaf4, transparent); */
  border-radius: 50%;
  overflow: hidden;
}
.vj__loading-amy {
  position: relative;
  z-index: 2;
  animation: all linear 3s infinite alternate;
  animation-name: amy;
}
.vj__loading-clouds {
  position: absolute;
  width: 100%;
  height: 100%;
}
.vj__loading-clouds > img {
  position: absolute;
  animation: linear infinite;
}
.vj__loading-clouds > img:nth-child(1) {
  top: calc(50% - 10px);
  left: 0;
  width: 20px;
  animation-name: cloudOne;
  animation-duration: 12s;
}
.vj__loading-clouds > img:nth-child(2) {
  width: 80px;
  top: 25px;
  animation-name: cloudSecond;
  animation-duration: 14s;
}
.vj__loading-clouds > img:nth-child(3) {
  width: 50px;
  left: 0px;
  bottom: 25px;
  animation-name: cloudThrird;
  animation-duration: 15s;
}
.vj__loading-clouds > img:nth-child(4) {
  width: 50px;
  top: 30px;
  right: 0;
  animation-name: cloudFour;
  animation-duration: 16s;
}
.vj__loading-clouds > img:nth-child(5) {
  right: 20px;
  width: 70px;
  bottom: 25px;
  animation-name: cloudFive;
  animation-duration: 18s;
}
.vj__loading-bottom {
  position: relative;
  width: 100%;
  max-width: 120px;
  margin-top: -30px;
  text-align: center;
  z-index: 2;
}

.vj__loading-bar {
  width: 120px;
  height: 6px;
  position: relative;
  background-color: #dc2027;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  margin-left: auto;
  margin-right: auto;
}
.vj__loading-bar-inner {
  width: 116px;
  height: 4px;
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}
.vj__loading-bar-inner:after,
.vj__loading-bar-inner:before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  border-radius: 4px;
  background-color: #fbbc0e;
  z-index: 2;
  transform: translateX(0);
  animation: 3s linear infinite;
}
.vj__loading-bar-inner:after {
  width: 120px;
  left: -125px;
  animation-name: slidingBarOne;
}

.vj__loading-text {
  font-family: Jambono;
  margin-bottom: 10px;
  display: block;
}
.vj__nodata {
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  padding: 20px 0;
  margin-bottom: 20px;
  color: #bebebe;
  border-radius: 10px;
}
.vj__nodata-container {
  text-align: center;
}
.vj__nodata-image {
  font-size: 40px;
  color: #bebebe;
}
.vj__nodata-image svg {
  width: 60px;
  height: 60px;
}
.vj__nodata-image svg,
.vj__nodata-image path {
  fill: #d3d3d3;
}
.booking__layout--buttons {
  padding: 30px 0 60px;
}
.booking__layout--button--inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.booking__layout--button--inner > button {
  display: block;
  width: 100%;
  max-width: 240px;
  height: 50px;
  box-shadow: 0px 6px 8px -4px #0000002e;
}
.booking__layout--button--inner > button:last-of-type {
  margin-left: 30px;
}
.btn-outline-back {
  border: 1px solid #000000;
  color: #000000;
}
.btn-outline-back i {
  margin-right: 5px;
}
#progressBar {
  position: fixed;
  width: 0;
  height: 2px;
  background-color: red;
  left: 0;
  bottom: 0;
  z-index: 99;
  pointer-events: none;
}

/*===== start passenger page ======*/
.col__booking--summary {
  width: 360px;
}
.col__booking--body {
  flex: 1;
  padding-right: 30px;
}
.booking__layout.noside .booking__layout--body {
  padding-right: 0;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}
.booking__summary-body {
  padding-bottom: 15px;
}

.box__summary {
  background-color: #fff;
  margin-bottom: 30px;
  border-radius: 5px;
  overflow: hidden;
}
.booking__summary ul {
  padding: 0;
  margin: 0;
  list-style-type: none;
}
.box__summary.trip--infor .box__summary--header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  text-transform: uppercase;
  font-weight: bold;
  /* text-shadow: 2px 2px 5px #c9c9c9;
    color: #f40f48 */
  background: -webkit-linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.box__summary--header p {
  margin-bottom: 0;
  padding: 10px 20px;
  font-size: 16px;
}
.summary-sub {
  font-size: 13px;
  color: #5b5b5b;
  display: flex;
  flex-wrap: nowrap;
}
.summary-sub > span + span {
  position: relative;
  padding-left: 8px;
  margin-left: 8px;
}
.summary-sub > span + span:after {
  content: "";
  position: absolute;
  width: 1px;
  height: 10px;
  background-color: darkgrey;
  display: block;
  top: calc(50% - 5px);
  left: 0;
}
.box__summary--body {
  padding: 0 20px 20px;
}

.pax__form {
  margin-bottom: 20px;
  border-radius: 5px;
  overflow: hidden;
}
.pax__form--header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #ffff;
  padding: 15px 20px;
  cursor: pointer;
}
.pax__form .form-check {
  padding-left: 0;
  margin-right: 30px;
}
.pax-select {
}

.pax__form .pax-type input {
  display: none;
  pointer-events: none;
}
.pax__form .form-check-label {
  position: relative;
  padding-left: 30px;
  font-weight: bold;
}
.pax__form .pax-type .form-check-label:before {
  content: "";
  width: 20px;
  height: 20px;
  display: block;
  border: 1px solid #1e1d1d;
  position: absolute;
  left: 0;
  border-radius: 30px;
  top: calc(50% - 11px);
  background-color: #fff;
  opacity: 0.2;
}
.pax__form .pax-type .form-check-label:after {
  content: "";
  position: absolute;
  border-radius: 16px;
  background-color: #d41b23;
  width: 12px;
  height: 12px;
  border-width: 0;
  left: 4px;
  top: calc(50% - 7px);
  box-shadow: 0px 0px 3px -1px rgb(0 0 0 / 70%);
  opacity: 0;
  display: none;
}
.pax__form .pax-type .form-check input:checked ~ .form-check-label:after {
  opacity: 1;
  display: block;
}
.pax__form .pax-type .form-check input:checked ~ .form-check-label:before {
  border-color: #d41b23;
  opacity: 1;
}

.box__summary--short-infor {
  padding: 0px 20px 10px;
  line-height: 1;
}
.box__summary--short-infor p {
  margin-bottom: 0;
}
.summary-destination {
  font-size: 13px;
  font-weight: bold;
  text-transform: uppercase;
}
.summary-destination .title--icon {
  margin: 0 10px;
}
.summary-destination .title--icon svg,
.summary-destination .title--icon path {
  fill: #a4a4a4;
  width: 16px;
  height: 16px;
}

.box__summary--stack {
  margin-bottom: 15px;
}
.box__summary--inner--body > .box__summary--stack:last-of-type {
  margin-bottom: 0;
}
.box__summary--stack--header {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  font-weight: bold;
  font-size: 14px;
}
.box__summary--stack--header p,
.box__summary--stack--body p {
  margin-bottom: 0;
  line-height: 1.3;
}
.box__summary--stack--body .stack--value {
  padding-left: 10px;
  min-width: 100px;
  text-align: right;
}

.pax__form--icon {
  background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  border-radius: 32px;
  width: 32px;
  height: 32px;
  text-align: center;
  line-height: 28px;
  margin-right: 10px;
}
.pax__form--icon svg,
.pax__form--icon path {
  fill: #fff;
  width: 22px;
  height: 22px;
}
.box__summary--stack--body ul li {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  margin-bottom: 5px;
}
.pax__form--header-text > div,
.pax__form--header-text > p {
  display: inline-block;
}
.pax__form--header-text {
  display: flex;
  align-items: center;
}
.pax__form--header-text p {
  margin-bottom: 0;
  font-weight: bold;
}

.pax__form-inputs {
  padding: 15px 20px 0px;
  background-color: #ffff;
}
/* .pax__form--row{
    display: flex;
    align-items: center;
} */
.pax__form .form-control {
  border-radius: 5px;
}
.pax__form .form-floating > .form-select {
  border-radius: 5px;
  padding-top: 1.325rem !important;
  padding-bottom: 0.325rem !important;
  font-weight: bold;
}
.pax__form--information:not(.expanded) .pax__form--body {
  height: 0;
}
.col-booking-summary {
}
.col__booking--summary .box__summary.sub--total {
  background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
}
.col__booking--summary .box__summary.sub--total p {
  color: #fff;
}
.col__booking--summary .sub-total-inner {
  padding: 15px;
}
.sub-total-inner p {
  margin-bottom: 0;
  text-align: right;
}
.sub-total-inner p.summary-label {
  font-size: 13px;
}
.sub-total-inner p.summary-value {
  font-weight: bold;
  font-size: 24px;
}
.pax__form-collapse-btn {
  cursor: pointer;
}
.flight__box {
  border-radius: 5px;
  overflow: hidden;
}
.flight__header {
  display: flex;
  align-items: center;
  padding: 15px 20px;
  background: #fff;
  /* background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b); */
  border-bottom: 1px solid #f1f1f1;
}
.flight__header h4,
.flight__header p,
.flight__header h3 {
  margin-bottom: 0;
  text-shadow: 2px 2px 5px #c9c9c9;
  text-transform: uppercase;
}

.flight__sectors {
  background: #fff;
}
.sectors--short-detail {
  padding-top: 20px;
  display: flex;
}
.flight__sectors:not(.expanded) .flight__sectors--body {
  display: none;
}
.flight__sectors--header {
  display: flex;
  justify-content: space-between;
  padding: 15px 20px;
  align-items: center;
}
.flight__sector--box {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.box__sector {
  padding-top: 15px;
  padding-bottom: 15px;
}
.flight__sector--box .box__sector + .box__sector {
  padding-left: 30px;
  margin-left: 30px;
  border-left: 1px solid #f1f1f1;
}
.box__sector--icon {
  float: left;
  width: 32px;
  height: 32px;
  background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  border-radius: 32px;
  text-align: center;
  line-height: 28px;
}

.box__sector-infor {
  padding-left: 45px;
}
.box__sector-infor p {
  margin-bottom: 5px;
}
p.box__sector-destination {
  font-weight: bold;
  text-transform: uppercase;
  font-size: 14px;
}
.box__sector--icon svg,
.box__sector--icon path {
  fill: white;
  width: 16px;
  height: 16px;
}
.flight__sector--icon {
  width: 40px;
  height: 40px;
  text-align: center;
  line-height: 40px;
  cursor: pointer;
}
.box__sector-sub {
  font-size: 13px;
  display: flex;
}
.box__sector-sub > span {
  position: relative;
}
.box__sector-sub > span + span {
  padding-left: 8px;
  margin-left: 8px;
}
.box__sector-sub > span + span:after {
  content: "";
  position: absolute;
  height: 4px;
  width: 4px;
  background-color: #e61635;
  border-radius: 4px;
  top: calc(50% - 2px);
  left: -2px;
}
.flight__sectors--body {
  padding: 20px 20px;
  border-top: 1px solid #f1f1f1;
}
.flight__sectors--body .flight__sectors {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.flight__sector--label {
  margin-bottom: 20px;
}
.flight__sector--label p {
  margin-bottom: 0;
  font-weight: bold;
  background: -webkit-linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-transform: uppercase;
}
.flight__sector--timeline {
  position: relative;
  width: 100%;
  flex-basis: 100%;
}
.flight__sector--timeline:after {
  content: "";
  position: absolute;
  width: 1px;
  height: 80%;
  display: block;
  background-color: #f1f1f1;
  top: 0;
  left: 135px;
}
.flight__sectors-inner > .flight__sector + .flight__sector {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 1px solid #f1f1f2;
}
.flight__sector--info-row {
  display: flex;
  width: 100%;
  flex: 1;
  margin-bottom: 20px;
  z-index: 2;
  position: relative;
}
.flight__sector--info-row ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}
.flight__sector--info-row p {
  margin-bottom: 0;
}
.flight__sector--info-row.row-duration {
  align-items: center;
}
.flight__sector--info-row.sector-one-stop .sector--stoptime {
  padding-left: 20px;
}
.flight__sector--info-row .flight__sector--aircraft {
  padding-top: 8px;
  padding-bottom: 8px;
  border-radius: 40px;
  color: #707070;
  flex: 1;
}
.flight__sector--info-row .flight__sector--aircraft li {
  float: left;
  font-size: 12px;
  text-transform: uppercase;
}
.flight__sector--info-row .flight__sector--aircraft li:not(li:last-of-type) {
  margin-right: 10px;
}
.flight__sector--info-row .flight__sector--date-time,
.flight__sector--info-row .flight__sector--duration {
  width: 120px;
  text-align: left;
  padding-right: 20px;
}
.flight__sector--info-row .flight__sector--date-time > span,
.flight__sector--info-row .flight__sector--duration p {
  display: block;
  font-size: 14px;
}
.flight__sector--info-row .flight__sector--date-time .flight-time {
  font-weight: bold;
}
.flight__sector--info-row .city-name {
  font-weight: bold;
}
.flight__sector--airport--info p {
  margin-bottom: 0;
}
.flight__sector--airport--info .city-airport {
  padding-left: 40px;
}
.flight__sector--aircraft {
  margin-left: 40px;
}
.flight__sector--airport--info ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.flight__sectors--body .sector-icon {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 30px;
  background-color: #fff;
  float: left;
  border-radius: 30px;
  /* background-color: #f1f1f1; */
}
.flight__sectors--body .sector-icon > svg {
  width: 16px;
  height: 16px;
  fill: #a4a4a4;
}
.sector-icon i {
  color: #a4a4a4;
}
.ic-sector-stop {
  position: relative;
  width: 14px;
  height: 14px;
  border-radius: 16px;
  border: 3px solid #a4a4a4;
  display: inline-block;
}
.flight__sector--info-row.sector-one-stop {
  /* padding-left: 160px; */
}
.sector-one-stop .flight__sector--airport--info {
  flex: 1;
  width: 100%;
}
.flight__sector--onestop--info {
  padding: 10px 15px;
  border-radius: 27px;
  font-size: 14px;
  background-color: #f1f1f1;
}
.flight__sector--info-row.sector-one-stop .sector-icon {
  background-color: transparent;
  width: auto;
  height: auto;
}
.flight__sector--info-row.sector-one-stop .sector-icon i {
  color: initial;
}
.flight__paxs {
  background: #fff;
  padding: 30px 20px;
}
.flight__paxs--body {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-left: -15px;
  margin-right: -15px;
}
.flight__pax {
  padding-left: 15px;
  padding-right: 15px;
  margin-bottom: 30px;
}
.flight__pax .flight__pax--inner {
  padding: 10px 15px;
  border: 1px solid #f1f1f1;
  border-radius: 10px;
  flex-basis: 50%;
}
.box-pax-detail .flight__pax--icon {
  background: linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  line-height: 24px;
  text-align: center;
  float: left;
}
.box-pax-detail .flight__pax--infor {
  padding-left: 40px;
}
.box-pax-detail .pax-type {
  font-size: 13px;
}
.box-pax-detail .pax-name {
  text-transform: uppercase;
  font-weight: bold;
}
.flight__pax--infor ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.box-pax-detail .flight__pax--icon svg,
.box-pax-detail .flight__pax--icon path {
  fill: #fff;
}
.flight__confirms {
  padding: 20px;
  background-color: #fff;
  text-align: justify;
}
.vj-check {
  padding-left: 0;
}
.vj-check .form-check-input {
  display: none;
  opacity: 0;
}
.vj-check .form-check-label {
  position: relative;
  padding-left: 30px;
  line-height: 1.3;
}
.vj-check .form-check-label::after,
.vj-check .form-check-label::before {
  content: "";
  position: absolute;
}
.vj-check .form-check-label:after {
  width: 20px;
  height: 20px;
  border: 2px solid #c2c2c2;
  left: 0;
  border-radius: 3px;
}
.vj-check .form-check-label:before {
  width: 8px;
  height: 12px;
  border-right: 2px solid red;
  border-bottom: 2px solid red;
  transform: rotate(45deg) scale(0.5);
  opacity: 0;
  left: 6px;
  top: 2px;
}
.vj-check .form-check-input:checked ~ .form-check-label:before {
  opacity: 1;
  transform: rotate(45deg) scale(1);
}
.vj-check .form-check-input:checked ~ .form-check-label:after {
  border-color: red;
}
.header__summary {
  display: none;
  opacity: 0;
}
.header__summary__bar {
  background-color: #ffff;
  padding: 5px 20px;
  border-radius: 50px;
}
.header__summary__bar .value,
.symbol__curency {
  color: red;
  font-family: "Jambono";
}
.header__summary__bar .label {
  font-size: 11px;
  display: block;
  line-height: 1;
}
.header__summary__bar p {
  margin-bottom: 0;
  font-size: 14px;
}
.header__summary__bar .symbol__curency {
  margin-left: 3px;
  font-size: 12px;
}
.price i {
  font-size: 12px;
}
.header__summary__bar ins {
  text-decoration: none;
}
.header__summary__dropdown {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  pointer-events: none;
}

.header__summary__dropdown--inner {
  background: #fff;
  height: 85%;
  z-index: 9;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 10px 10px 0 0;
  transform: translateY(100%);
  transition: all linear 320ms;
  padding: 15px 0 0;
}
.header__summary__dropdown--inner .booking__summary-header h3 {
  text-transform: uppercase;
  /* text-shadow: 2px 2px 5px #c9c9c9; */
}
.btn__summary__close--dropdown {
  text-align: center;
  color: #fff;
  transition: all linear 320ms;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  position: absolute;
  top: 0;
  left: calc(50% - 15px);
}

.header__summary--body {
  padding: 20px 15px 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
}
.header__summary__dropdown .overlay {
  background: rgb(0 0 0 / 70%);
  width: 100%;
  height: 100%;
  position: absolute;
  transition: all linear 320ms;
  opacity: 0;
}

.header__summary__dropdown .box__summary.trip--infor .box__summary--header p {
  padding: 0;
}
.header__summary__dropdown .box__summary--short-infor {
  padding: 0 0 10px;
}
.header__summary__dropdown .box__summary--body {
  padding-left: 0;
  padding-right: 0;
}
.header__summary__dropdown .box__summary--stack {
  margin-bottom: 0;
}
.header__summary__dropdown .box__summary:not(.sub--total) {
  border-bottom: 1px solid #f1f1f1;
  padding-top: 10px;
  margin-bottom: 10px;
  border-radius: 0;
}
.header__summary__dropdown .box__summary--body {
  padding-bottom: 10px;
}
.header__summary.expanded .header__summary__dropdown {
  opacity: 1;
  pointer-events: all;
}
.header__summary.expanded .overlay {
  opacity: 1;
}
.header__summary.expanded .header__summary__dropdown--inner {
  box-shadow: 0px 0px 20px 5px rgb(0 0 0 / 60%);
  transform: translateY(0);
}
.header__summary.expanded .btn__summary__close--dropdown {
  top: -30px;
}
/*================ THANKS YOU PAGE============*/
.bk__amy {
  max-width: 120px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 20px;
}
.bk__notice .title {
  font-family: jambono;
  font-weight: normal;
  color: red;
  text-align: center;
  font-size: 20px;
}
.flight-box-noti {
  max-width: 360px;
  margin-left: auto;
  margin-right: auto;
}
.bk__notice p {
  text-align: center;
}
.box-flight-detail-information .flight__booking__infomation {
  background-color: #ffff;
  padding: 30px 0;
}
.flight__booking__infomation--inner {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.flight__booking__info_qr {
  width: 220px;
}
.flight__booking__info__text {
  flex: 1;
  flex-basis: calc(100% - 220px);
  padding-top: 10px;
}
.flight__booking__info__text ins {
  text-decoration: none;
  color: red;
  font-weight: bold;
}
.flight__booking__info__text .sub__total .price__label {
  font-size: 13px;
}
.flight__booking__info__text .sub__total p {
  margin-bottom: 0;
}
.bk__info-list {
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
}
.bk__info-list li {
  margin-bottom: 15px;
  max-width: 380px;
}
.bk__info-list li:first-of-type {
  width: 100%;
  flex-basis: 100%;
}
.bk__info-list li + li {
  width: 50%;
}
.bk__info-list p {
  margin-bottom: 0;
}
.bk__info-list p.label {
  font-size: 13px;
  line-height: 1.3;
}
.bk__info-list p.value {
  font-weight: bold;
  line-height: 1.3;
  word-break: break-word;
}
.bk__info--pnr p.value {
  color: red;
}
.bk__info-list p.value span.local-text {
  font-size: 13px;
  display: block;
  font-weight: normal;
}
.flight__options--body-review {
  background-color: #fff;
  padding: 30px 20px 10px;
}
.flight-info-review {
  border: 1px solid #f1f1f1;
}
.flight__sector__title .sub-title {
  font-size: 18px;
  font-weight: bold;
}
.flight-info-review .flight-option-price p.price ins {
  font-size: 20px;
}
.flight-info-review ins .currency-symbol {
  font-size: 16px;
}
.flight-info-review .flight-option-top .flight-option-time {
  font-size: 24px;
}
.flight__summary-section--inner {
  padding: 30px 20px 10px;
  background-color: #fff;
}
.flight__summary-section--inner .box__summary {
  border-radius: 0;
  margin-bottom: 20px;
  padding-bottom: 20px;
}
.flight__summary-section--inner .box__summary:not(:last-of-type) {
  border-bottom: 1px solid #f1f1f1;
}

.trip__section--info,
.flight__summary-section--inner .box__summary.sub--total {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.trip__section--info .trip__section--info-detail,
.trip__section--info-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.trip__section--info-header p {
  text-transform: uppercase;
  font-weight: bold;
  margin-bottom: 0;
}

.trip__section--info .box__summary--details {
  flex: 1;
  padding-left: 30px;
}
.box__summary--stack--body ul {
  padding-left: 0;
}
.box__summary--details .box__summary--inner--body {
  max-width: 360px;
}
.box__summary--label.sm-vertical .summary-destination {
  position: relative;
}
.box__summary--label.sm-vertical .summary-destination span {
  display: block;
}
.box__summary--label.sm-vertical .summary-destination span.title-location {
  padding-left: 25px;
}
.box__summary--label.sm-vertical
  .summary-destination
  span.title-location:first-of-type {
  margin-bottom: 30px;
}
.sm-vertical .summary-destination::after {
  content: "";
  position: absolute;
  width: 1px;
  background: #f1f1f1;
  top: 10px;
  bottom: 10px;
  left: 11px;
}
.summary-destination .sm-ic {
  position: absolute;
  left: 0;
  z-index: 2;
  line-height: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background-color: #fff;
}
.summary-destination .sm-ic svg,
.summary-destination .sm-ic path {
  fill: #a4a4a4;
  width: 16px;
  height: 16px;
}
.summary-destination .ic-aircraft {
  top: 0;
}
.summary-subtotal-sector {
  text-align: right;
}
.trip__section--info-detail .box__summary--label {
  width: 100%;
  max-width: 180px;
}
.trip__section--info-detail .box__summary--inner--body {
  flex: 1;
  max-width: 380px;
}
.flight__summary-section--inner .sub-total-inner p.summary-value,
.header__summary__dropdown .sub-total-inner p.summary-value {
  background: -webkit-linear-gradient(0deg, #da1a23, #f70e4c, #ff6b6b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.flight-selected {
}
.voucher-search-form {
}
.voucher-search-form .inner-form {
  display: flex;
  flex-wrap: wrap;
}
.voucher-search-form .row {
  width: 100%;
}
.inner-form > .row {
  flex: 1;
}
.voucher-search-form .col-button {
  padding-left: 20px;
}
.voucher-search-form button {
  height: 100%;
  border-radius: 5px;
}
.search-voucher__page {
  background-color: #fff;
  padding: 30px;
  border-radius: 10px;
}
.header-page {
  margin-bottom: 20px;
}
.search-voucher__page .voucher-content .lists {
}
.search-voucher__page .voucher-content .list-item {
}
.search-voucher__page .voucher-content .list-item span {
  display: inline-block;
}
.search-voucher__page .voucher-content .list-item .label {
  width: 220px;
  font-weight: bold;
}
.search-voucher__page .voucher-content .list-item .value.price {
  color: #c30d13;
}
.search-head {
  padding: 15px 0;
}
.search-head h3 {
  font-weight: bold;
}
@keyframes slidingBarOne {
  0% {
    transform: translateX(0);
  }
  60% {
    transform: translateX(80px);
    width: 120px;
  }
  100% {
    transform: translateX(250px);
    width: 30px;
  }
}
@keyframes cloudOne {
  0% {
    transform: translateY(-4px) translateX(160px);
  }
  20% {
    transform: translateY(4px) translateX(120px);
  }
  40% {
    transform: translateY(-4px) translateX(80px);
  }
  60% {
    transform: translateY(4px) translateX(40px);
  }
  80% {
    transform: translateY(-4px) translateX(0px);
  }
  100% {
    transform: translateY(4px) translateX(-20px);
  }
}
@keyframes cloudSecond {
  0% {
    transform: translateY(-6px) translateX(160px);
  }
  20% {
    transform: translateY(6px) translateX(100px);
  }
  40% {
    transform: translateY(-6px) translateX(60px);
  }
  60% {
    transform: translateY(6px) translateX(0px);
  }
  80% {
    transform: translateY(-6px) translateX(-60px);
  }
  100% {
    transform: translateY(6px) translateX(-100px);
  }
}
@keyframes cloudThrird {
  0% {
    transform: translateY(0) translateX(160px);
  }
  100% {
    transform: translateY(16px) translateX(-60px);
  }
}
@keyframes cloudFour {
  0% {
    transform: translateY(0) translateX(90px);
  }
  100% {
    transform: translateY(16px) translateX(-170px);
  }
}
@keyframes cloudFive {
  0% {
    transform: translateY(0) translateX(100px);
  }
  100% {
    transform: translateY(16px) translateX(-120px);
  }
}
@keyframes amy {
  0% {
    transform: translateY(-4px) rotate(0);
  }
  100% {
    transform: translateY(4px) rotate(-5deg);
  }
}
@media screen and (max-width: 1399px) {
  .flight__sector--box .box__sector + .box__sector {
    padding-left: 0;
    margin-left: 0;
    border-left-width: 0;
  }
}
@media screen and (max-width: 1199px) {
  .voucher__detail__template {
    padding: 60px 30px 60px;
  }
  .flight-option-price p.price ins {
    font-size: 24px;
  }
  .flight-option-top .flight-option-time {
    font-size: 28px;
  }

  .flight-option-price {
    padding-right: 20px;
  }
  .flight-option-infor,
  .flight-option-top {
    padding-left: 20px;
    padding-right: 20px;
  }

  .flight-option-top .flight-option-city,
  .flight-option-top .flight-option-date,
  .duration-label,
  .duration-time {
    font-size: 12px;
  }
  .flight-option-item {
    margin-bottom: 20px;
  }
  .flight__sector--box .box__sector + .box__sector {
    padding-left: 0;
    margin-left: 0;
    border-left-width: 0;
  }
  .booking__form.booking-hotel .booking__form--hotel {
    width: calc(50% - 15px);
    flex-basis: calc(50% - 15px);
    margin-right: 15px;
  }
  .booking__form.booking-hotel .booking__form--passenger {
    width: 100%;
    flex-basis: 100%;
    padding-right: 0;
  }
  .booking__form.booking-hotel .booking__form--date {
    width: 50%;
    flex-basis: 50%;
    margin-right: 0;
  }
  .booking__form.booking-hotel .booking__form--buttons {
    width: 100%;
    flex-basis: 100%;
  }
}
@media screen and (max-width: 991.98px) {
  .box__notice {
    padding: 15px;
  }
  .notice__icon {
    margin-right: 15px;
  }
  .flight-option-top,
  .flight-option-price {
    padding-left: 15px;
    padding-right: 15px;
  }
  .myaccount__left {
    /* position: sticky; */
    /* top: 0; */
    width: 100%;
    margin-bottom: 30px;
    -webkit-overflow-scrolling: touch;
  }
  .myaccount__left .navmenu {
    display: flex;
    width: 100%;
    overflow-x: scroll;
    padding-bottom: 15px;
    padding-top: 15px;
  }
  .myaccount__left .navmenu .nav-link {
    white-space: nowrap;
  }
  .text-large {
    font-size: 1.6rem;
  }
  .voucher_price ins {
    font-size: 1.4rem;
  }
  h1,
  h1.voucher-title,
  .voucher_title_detail {
    font-size: 1.6rem;
  }
  h3 {
    font-size: 1.2rem;
  }
  h4 {
    font-size: 1.1rem;
  }
  .wrapper__header .navbar {
    height: 50px;
  }
  .navbar-brand img {
    max-width: 130px;
  }
  .navbar-right .nav-link {
    padding-left: 5px;
    padding-right: 5px;
  }
  .wrapper__main {
    min-height: calc(100vh - 50px);
  }

  .wrapper__footer::after {
    height: 140px;
    width: 183px;
  }
  .wrapper__footer::before {
    height: 60px;
    background-size: cover;
    top: -60px;
  }
  .wrapper__content {
    padding-top: 40px;
  }
  .page__content,
  .voucher__detail__template {
    padding: 30px 15px 30px;
  }
  .body-account__page,
  .body-template,
  .voucher_content {
    padding: 30px 15px 30px;
  }
  .mb-5 {
    margin-bottom: 2rem !important;
  }
  .btn-vj {
    width: 100%;
    min-width: auto;
  }
  .buttons {
    display: block;
  }
  .buttons .btn-default {
    margin-right: 0 !important;
  }
  .tbl-body-vc {
    overflow-x: scroll;
  }
  .tbl-body-vc .table > :not(caption) > * > * {
    padding: 0.5rem 0.5rem;
  }
  .tbl-header-vc {
    overflow-x: scroll;
  }

  .modal-content .voucher_title_detail {
    font-size: 1.4rem;
  }
  .voucher_title {
    font-size: 16px;
    line-height: 18px;
    height: 36px;
  }
  .account__inform {
    margin-bottom: 10px;
    padding-bottom: 10px;
  }

  .booking__form--inner {
    flex-wrap: wrap;
  }
  .btn-booking {
    width: 100%;
  }
  .booking__form--buttons {
    width: 100%;
  }
  .booking__form__wrapper {
    padding: 15px 20px 10px;
  }
  .row--date--passenger {
    display: block !important;
  }
  #trip__date--dropdown .daterangepicker {
    width: 100%;
  }
  .daterangepicker .calendar-table th,
  .daterangepicker .calendar-table td {
    min-width: auto;
  }
  .booking__form--destination {
    margin-right: 0;
  }
  .booking__form--passenger,
  .booking__form--promo,
  .booking__form--date {
    padding-right: 0;
    width: 100%;
    flex-basis: 100%;
  }
  .flight-option-top {
    width: 100%;
    flex-basis: 100%;
    padding-bottom: 10px;
  }
  .flight-option-price,
  .flight-option-infor {
    width: 50%;
    flex: 1;
  }
  .flight-option-infor {
    padding-left: 15px;
    padding-right: 15px;
  }
  .flight-option-top .flight-option-city,
  .flight-option-top .flight-option-date,
  .duration-label,
  .duration-time {
    font-size: 12px;
  }
  .flight-option-top
    .flight-option-location-time
    ~ .flight-option-location-time {
    text-align: right;
  }
  .flight-option-detail-inner > div > div {
    padding-left: 40px;
  }
  .flight-option-detail-inner .option-detail-icon {
    width: 30px;
    height: 30px;
    top: calc(50% - 15px);
    left: 5px;
  }
  .option-detail-icon .icon-flight svg,
  .option-detail-icon .icon-flight path {
    width: 16px;
    height: 16px;
  }
  .option-detail-icon .bi-geo-alt-fill {
    font-size: 14px;
  }
  .flight-option-dropdown .dropdown-inner {
    padding: 15px;
  }
  .flight-option-detail .flight-option-depart .option-label {
    width: 160px;
  }
  .booking__layout--title .title,
  .booking__summary-header .title {
    font-size: 20px;
  }
  .option-detail-content,
  .flight-option-detail .option-value .city,
  .flight-option-detail .option-value .time,
  .option-detail-content p.flight-code {
    font-size: 14px;
  }
  .flight-option-detail .flight-option-depart .option-label {
    font-size: 14px;
  }
  .flight-option-detail .option-value .aircraft p + p {
    margin-left: 20px;
  }
  .flight-option-item,
  .booking__date--bar {
    margin-bottom: 15px;
  }
  .flight-option-bar {
    height: auto;
    background-color: #fff;
  }
  .flight-option-price span.line {
    display: none;
  }
  .flight-option-price:after,
  .flight-option-price:before,
  .flight-option-infor:after,
  .flight-option-infor:before {
    content: none;
  }
  .flight-option-top {
    padding: 15px 15px 0;
  }
  .flight-option-price {
    padding: 10px 10px 10px 0;
  }
  .flight-option-infor {
    padding-left: 15px;
  }
  .col__booking--body {
    padding-right: calc(var(--bs-gutter-x) * 0.5);
    width: 100%;
    flex-basis: 100%;
  }
  .col__booking--summary {
    display: none;
  }
  .flight__pax {
    margin-bottom: 15px;
  }
  .flight__header,
  .flight__paxs {
    padding: 10px 15px;
  }
  .flight__header .flight__text h4 {
    font-size: 16px;
  }
  .flight__confirms--text {
    font-size: 13px;
  }
  .flight__pax--infor {
    font-size: 14px;
  }
  .vj-check {
    font-size: 14px;
  }
  .status__inner .step {
    width: 30px;
    height: 30px;
  }
  .status__inner svg,
  .status__inner path {
    width: 14px;
    height: 14px;
  }
  .booking__layout--header--infor {
    margin-bottom: 15px;
  }
  .header--infor .destinations {
    font-size: 16px;
  }
  .triptype-passengers .status-triptype,
  .triptype-passengers span,
  .header--btns .btn {
    font-size: 13px;
  }
  .booking__layout--header > .container {
    padding-top: 15px;
    padding-bottom: 15px;
  }
  .header__summary {
    display: block;
    opacity: 1;
  }
  .booking__layout--header--status {
    justify-content: space-between;
  }
  .booking__layout--button--inner > button {
    font-size: 14px;
    max-width: 180px;
    height: 45px;
  }
  .flight__summary-section--inner {
    padding-left: 15px;
    padding-right: 15px;
  }
  .bk__notice p {
    font-size: 14px;
  }
  .bk__notice .title {
    font-size: 18px;
  }

  .booking__form.booking-hotel .booking__form--hotel {
    width: 100%;
    flex-basis: 100%;
    margin-right: 0;
  }
  .booking__form.booking-hotel .booking__form--passenger {
    width: 100%;
    flex-basis: 100%;
    padding-right: 0;
  }
  .booking__form.booking-hotel .booking__form--date {
    width: 100%;
    flex-basis: 100%;
    margin-right: 0;
  }
  .booking__form.booking-hotel .booking__form--buttons {
    width: 100%;
    flex-basis: 100%;
  }
  .voucher-search-form .col-button {
    width: 100%;
    padding-left: 0;
    height: 58px;
  }
}
@media screen and (max-width: 767.98px) {
  .form__group {
    flex-wrap: wrap;
  }
  .voucher__detail__header .form__group .voucher__quantity,
  .voucher__detail__header .form__group .btn-getvoucher {
    width: 100%;
    max-width: inherit;
  }
  .voucher__detail__header .form__group .voucher__quantity {
    margin-bottom: 30px;
  }
  .section__homeslide {
    padding-top: 30px;
  }
  section {
    margin-bottom: 20px;
  }
  .banner_row {
    overflow-x: scroll;
  }
  .banner_row .row {
    flex-wrap: nowrap;
  }
  .banner_row .col-banner {
    width: 65%;
  }
  .account__information .table-inform {
    padding: 10px;
  }
  .daterangepicker .drp-calendar.left {
    width: 100%;
  }
  .daterangepicker .drp-calendar.right {
    width: 100%;
  }

  .flight-option-top .flight-option-time {
    font-size: 20px;
    font-weight: bold;
  }

  .flight-option-price p.price ins {
    font-size: 18px;
  }
  ins .currency-symbol,
  .flight-option-price p.price del,
  .btn-booking-selecting {
    font-size: 12px;
  }
  .btn-flight-option-detail {
    font-size: 11px;
  }

  .booking__layout--header > .container {
    padding-top: 15px;
    padding-bottom: 15px;
  }
  .header--infor .destinations {
    font-size: 16px;
  }
  .triptype-passengers .status-triptype,
  .triptype-passengers span,
  .header--btns .btn {
    font-size: 13px;
  }
  .booking__layout--header--status {
    justify-content: space-between;
  }
  .flight-option-icon .icon-flight {
    width: 24px;
    height: 24px;
  }
  .flight-option-icon svg,
  .flight-option-icon path {
    width: 16px;
  }
  .flight-option-types .icon-stop {
    margin-left: 40px;
    margin-right: 40px;
  }
  .flight-option-middle-inner .flight-option-icon .flight-code,
  .flight-aircraft,
  .flight-option-icon .text-label,
  .flight-option-stop .text-label {
    font-size: 11px;
  }
  .option-detail-content {
    display: block;
  }
  .flight-option-detail .option-value .aircraft p {
    font-size: 10px;
  }
  .flight-option-detail-inner ul {
    margin-bottom: 10px;
  }

  .option-detail-flight-code {
    padding-top: 20px;
  }
  .flight-option-detail-inner .option-detail-icon {
    left: 0;
  }
  .flight-option-detail .flight-option-depart:after {
    left: 15px;
  }
  .icon-stop {
    width: 12px;
    height: 12px;
  }
  .icon-stop:after {
    width: 6px;
    height: 6px;
    left: calc(50% - 3px);
    top: calc(50% - 3px);
  }
  .flight-option-detail .flight-option-depart {
    padding-top: 0;
  }
  .flight-option-detail .option-value .aircraft {
    margin-top: 10px;
  }
  .flight-option-detail-inner .option-detail-icon.bottom {
    top: calc(50% - 55px);
  }
  .flight-option-dropdown .dropdown-inner {
    padding-left: 10px;
  }
  .flight-option-detail .option-value .aircraft p + p {
    margin-left: 10px;
  }
  .booking__layout--title .title,
  .booking__summary-header .title {
    font-size: 20px;
  }
  .pax__form--header {
    padding: 10px 15px;
  }
  .pax__form-inputs {
    padding: 10px 15px 0;
  }
  .mb-4 {
    margin-bottom: 15px !important;
  }
  .flight__sector--info-row .flight__sector--date-time .flight-time,
  .flight__sector--info-row .city-name {
    font-size: 13px;
  }
  .flight__sector--info-row .flight__sector--date-time > span,
  .flight__sector--info-row .flight__sector--duration p,
  .flight__sector--airport--info p {
    font-size: 12px;
  }
  .flight__sector--info-row .flight__sector--aircraft,
  .box__sector-sub {
    font-size: 11px;
  }
  .flight__sectors--body {
    padding-left: 15px;
    padding-right: 15px;
  }
  .flight__sector--info-row .flight__sector--date-time,
  .flight__sector--info-row .flight__sector--duration {
    width: 90px;
    padding-right: 10px;
  }
  .flight__sectors--body .sector-icon {
    width: 24px;
    height: 24px;
  }
  .flight__sectors--body .sector-icon > svg,
  .ic-sector-stop {
    width: 12px;
    height: 12px;
  }
  .sector-icon i {
    font-size: 12px;
  }
  .flight__sector--timeline:after {
    left: 101px;
  }
  .flight__sector--info-row {
    margin-bottom: 15px;
  }
  .flight__sectors--header {
    padding-left: 15px;
    padding-right: 15px;
  }
  p.box__sector-destination {
    font-size: 13px;
  }
  .flight__booking__info__text {
    flex-basis: 100%;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
  }
  .flight__booking__info_qr {
    width: 100%;
    max-width: 140px;
    margin-left: auto;
    margin-right: auto;
  }
  .bk__info--pnr {
    text-align: center;
  }
  .bk__info-list li + li {
    width: 100%;
    flex-basis: 100%;
    display: flex;
  }
  .bk__info-list li + li p.label {
    width: 120px;
    text-align: right;
    padding-right: 10px;
    margin-top: 3px;
  }
  .bk__info-list li + li p.value {
    flex: 1;
    flex-basis: calc(100% - 120px);
  }
  .flight__booking__info__text .sub__total {
    text-align: center;
  }
  .box-flight-detail-information .flight__booking__infomation {
    padding-bottom: 15px;
  }
  .flight__options--body-review {
    padding-left: 15px;
    padding-right: 15px;
  }
  .trip__section--info-detail .box__summary--inner--body {
    max-width: 100%;
    flex-basis: 100%;
  }
  .bk__amy {
    max-width: 80px;
  }
  .booking__form__wrapper {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media screen and (max-width: 575.98px) {
  .voucher-breadcrumb {
    display: none;
  }
  .myaccount__page {
    padding: 10px;
  }
  .header__inform h1.title,
  .header-myaccount__page .title {
    font-size: 20px;
  }
  .tbl-row .value {
    padding-left: 10px;
  }
  .wrapper__footer::before {
    height: 40px;
    background-size: cover;
    top: -40px;
  }
  .booking__form--depart,
  .booking__form--return {
    flex-basis: 100%;
    width: 100%;
  }
  .booking__form--depart {
    margin-bottom: 1px;
    width: 100%;
    flex-basis: 100% !important;
  }
  .booking__form--return {
    width: 100%;
    flex-basis: 100% !important;
  }
  .booking__form
    .booking__form--depart
    .select2-container--default
    .select2-selection--single {
    border-top-right-radius: 5px;
    border-bottom-left-radius: 0;
  }
  .booking__form
    .booking__form--return
    .select2-container--default
    .select2-selection--single {
    border-top-right-radius: 0px;
    border-bottom-left-radius: 5px;
  }
  .header--infor .destinations {
    font-size: 16px;
  }
  .header--btns .btn {
    font-size: 13px;
  }
  .header--btns .btn i {
    font-size: 10px;
  }
  .header--infor .triptype-passengers {
    font-size: 13px;
  }
  .status__inner .step {
    width: 30px;
    height: 30px;
  }
  .status__inner svg,
  .status__inner path {
    width: 14px;
  }

  .name-stop {
    font-size: 12px;
    top: -20px;
  }
  .flight-option-onstop p {
    font-size: 13px;
  }
  .container {
    max-width: 420px;
  }
  .search-voucher__page .voucher-content .list-item span {
    display: block;
  }
}
@media (min-width: 576px) {
  .modalpax .modal-dialog {
    max-width: 650px;
  }
}
@media screen and (min-width: 992px) {
  .myaccount__right {
    padding-left: 60px;
    border-left: 1px solid #f1f1f1;
  }
  .voucher__quickview .modal-dialog {
    max-width: 850px;
  }
  .voucher__quickview .voucher__header .col-summary {
    padding-left: 40px;
  }
  .modal-body.voucher__details {
    padding: 0 2rem 2rem;
  }
  .checkout__right__col {
    padding-left: 30px;
  }
}

@media screen and (min-width: 1200px) {
  .voucher__policies .voucher__policy {
    width: 50%;
  }
  .voucher__quickview .voucher__policies .voucher__policy {
    width: 100%;
  }
  .voucher__detail__header .col-summary {
    padding-left: 60px;
  }
}
@media screen and (min-width: 991.98px) and (max-width: 1200px) {
  .voucher__section {
    height: 400px;
    overflow: hidden;
  }
  .voucher__section__buy {
    height: 430px;
  }
}
