/* Chrome, Safari, Edge, Opera */
#desktop_travel_booking::-webkit-outer-spin-button,
#desktop_travel_booking::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
#desktop_travel_booking[type=number] {
  -moz-appearance: textfield;
}
/* Chrome, Safari, Edge, Opera */
.number_input::-webkit-outer-spin-button,
.number_input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
.number_input[type=number] {
  -moz-appearance: textfield;
}
#snackbar {
  visibility: hidden;
  /* Hidden by default. Visible on click */
  min-width: 250px;
  /* Set a default minimum width */
  margin-left: -125px;
  /* Divide value of min-width by 2 */
  background-color: #fff;
  /* Black background color */
  color: #333;
  /* White text color */
  text-align: center;
  /* Centered text */
  border-radius: 2px;
  /* Rounded borders */
  padding: 16px;
  /* Padding */
  position: fixed;
  /* Sit on top of the screen */
  z-index: 1;
  /* Add a z-index if needed */
  left: 50%;
  /* Center the snackbar */
  bottom: 30px;
  /* 30px from the bottom */
}

#snackbar.show {
  visibility: visible;
  -webkit-animation: fadein 0.5s, fadeout 0.5s 2.5s;
  animation: fadein 0.5s, fadeout 0.5s 2.5s;
}

@-webkit-keyframes fadein {
  from {
    bottom: 0;
    opacity: 0;
  }

  to {
    bottom: 30px;
    opacity: 1;
  }
}

@keyframes fadein {
  from {
    bottom: 0;
    opacity: 0;
  }

  to {
    bottom: 30px;
    opacity: 1;
  }
}

@-webkit-keyframes fadeout {
  from {
    bottom: 30px;
    opacity: 1;
  }

  to {
    bottom: 0;
    opacity: 0;
  }
}

@keyframes fadeout {
  from {
    bottom: 30px;
    opacity: 1;
  }

  to {
    bottom: 0;
    opacity: 0;
  }
}

.body-contents-product {
  margin-top: 45px;
  margin-bottom: 37px;
  display: inline-block;
  width: 100%;
  overflow: hidden;
  padding-left: 16%;
  padding-right: 16%;
}

.body-contents-passenger {
  margin-top: 45px;
  margin-bottom: 37px;
  display: inline-block;
  width: 100%;
  overflow: hidden;
  padding-left: 13%;
  padding-right: 13%;
}

.body-filter {
  display: flex;
  width: 100%;
  overflow: hidden;
  color: #6d6d6d;
  font-family: 'Open Sans', sans-serif;
  font-size: 18px;
}

.cart-body-filter {
  display: flex;
  width: 100%;
  overflow: hidden;
  color: #6d6d6d;
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  margin-bottom: 15px;
}

.product-body {
  margin-top: 50px;
}

input[class="form-products"]:not(:checked),
input[class="form-products"]:checked {
  position: absolute;
  left: -9999%;
}

.passenger-body {
  display: none;
}

.flight-body {
  display: none;
}

input[class="form-products"]+label {
  width: 128px;
  padding: 5px;
  background: white;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  color: black;
  border: 1px solid black;
  text-align: center;
  font-size: 14px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 400;
  line-height: 28px;
}

input[class="form-products"]:checked+label {
  border: 1px solid white;
  color: white;
  background-color: var(--productprimary);
}

.products-filter-inline {
  width: 100%;
  text-align: center;
  display: inline-flex;
}

.products-filter-inline>p {
  font-size: 22.5px;
}

.summary-display {
  display: flex;
  width: 100%;
  overflow: hidden;
  color: var(--GREY, #696D6E);
  font-family: 'Open Sans', sans-serif;
  margin-bottom: 15px;
}

.body-buttons {
  width: 100%;
  text-align: center;
  margin-top: 40px;
  padding-bottom: 5px;
}

.passenger-heading {
  display: flex;
  width: 100%;
  overflow: hidden;
  padding-bottom: 5px;
  color: #6d6d6d;
  font-family: 'Open Sans', sans-serif;
  margin-top: 10px;
  font-size: 18px;
}

.summary-body {
  padding-bottom: 15px;
}

.contact-heading {
  margin-top: 15px;
  font-family: 'Open Sans', sans-serif;
  color: #6d6d6d;
  font-size: 18px;
}

.passenger-row {
  padding-bottom: 15px;
}

.flight-input-row {
  padding-bottom: 15px;
}

.terms-passenger {
  width: 100%;
  text-align: center;
  margin-top: 30px;
  font-family: 'Open Sans', sans-serif;
  font-size: 18px;
  color: #6d6d6d;
}

.body-contents-review {
  margin-top: 45px;
  margin-bottom: 37px;
  display: inline-block;
  width: 100%;
  overflow: hidden;
  padding-left: 13%;
  padding-right: 13%;
}

.review-container {
  margin-top: 25px;
  width: 100%;
  overflow: hidden;
}

.review-left {
  width: 65%;
  float: left;
}

.review-right {
  width: 35%;
  float: right;
}

.pan-container {
  width: 100%;
  padding-top: 20px;
  background-color: white;
  box-shadow: 0px 4px 7px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  padding-left: 10px;
  padding-right: 10px;
}

.payment-desktop-pan-container {
  width: 100%;
  padding-top: 20px;
  padding-right: 20px;
  background-color: white;
  box-shadow: 0px 4px 7px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  display: block;
  min-height: 300px;
}

.payment-mobile-pan-container {
  display: none;
}

.pan-payment-details-container {
  width: 100%;
  padding-top: 20px;
  overflow: hidden;
  /*margin-top: -300px;*/
}

.pan-left {
  float: left;
  width: 60%;
  padding-left: 5%;
  padding-right: 2%;
}

.pan-righ {
  float: right;
  width: 30%;
  padding-top: 20px;
}

.summary-heading {
  width: 100%;
  padding-left: 5%;
}

.information-container {
  width: 100%;
  margin-top: 50px;
  overflow: hidden;
}

.travellers-left {
  float: left;
  width: 50%;
}

.flights-right {
  float: right;
  width: 50%;
}

.summary-left {
  float: left;
  width: 50%;
}

.summary-right {
  float: right;
  width: 50%;
}

.summary-container {
  width: 50%;
}

#main-table {
  width: 100%;
}

/*
#main-table tr{
    width: 50%;
    padding-top: 8px;
    padding-bottom: 8px;
}*/
.payment-table-desktop {
  width: 100%;
  margin-top: 20px;
}


.travel-table tr td:nth-child(2n) {
  font-weight: bold;
}

.flight-table tr td:nth-child(2n) {
  font-weight: bold;
}

#summary-table tr td:nth-child(2n) {
  font-weight: bold;
  width: 50%;
  padding-left: 25px;
}

#summary-table-payment tr td:nth-child(2n) {
  font-weight: bold;
  width: 50%;
  padding-left: 25px;
}

.payment-details-table tr td:nth-child(2n) {
  width: 49%;
  padding-left: 1%;
}

#contact-table tr td:nth-child(2n) {
  font-weight: bold;
  width: 50%;
}
.mobile-contact-table tr td:nth-child(2n) {
  font-weight: bold;
  width: 50%;
}

#address-table tr td:nth-child(2n) {
  font-weight: bold;
  width: 50%;
}

.travel-table {
  display: none;
  margin-bottom: 15px;
}

.flight-table {
  display: none;
  margin-bottom: 15px;
}
.mobile-contact-table{
  margin-bottom: 15px;
}
#contact-table {
  margin-bottom: 15px;
}

#summary-table {
  margin-bottom: 15px;
  margin-right: 35px;
  margin-left: 35px;
  width: 80%;
}

#summary-table-payment {
  margin-bottom: 15px;
  margin-right: 35px;
  margin-left: 35px;
  width: 90%;
}

.payment-details-table {
  margin-bottom: 15px;
  margin-right: 35px;
  margin-left: 35px;
  border-collapse: separate;
  border-spacing: 0 15px;
}

.image-container {
  vertical-align: top;
}

.radio-display {
  color: var(--GREY, #696D6E);
}

@media only screen and (max-width: 1475px) {
  .body-filter {
    display: flex;
    width: 100%;
    overflow: hidden;
    color: #6d6d6d;
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
    white-space: normal;
  }
  .body-contents-review {
    margin-top: 45px;
    margin-bottom: 37px;
    display: inline-block;
    width: 100%;
    overflow: hidden;
    padding-left: 8%;
    padding-right: 8%;
  }
}
#payment_row{
  width: 50%;
  vertical-align:top;
}
@media only screen and (max-width: 700px) {
  #payment_row{
    width: 100%;
    vertical-align:top;
    padding-top: 25px;
  }
  input[class="form-products"]+label {
    width: 115px;
    padding: 5px;
    background: white;
    border-radius: 50px;
    justify-content: center;
    align-items: center;
    color: black;
    border: 1px solid black;
    text-align: center;
    font-size: 12px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    line-height: 28px;
  }

  .body-contents-product {
    padding-left: 25px;
    padding-right: 25px;
  }

  .review-left {
    width: 100%;
  }

  .body-contents-review {
    margin-top: 20px;
    margin-bottom: -10px;
    display: inline-block;
    width: 100%;
    overflow: hidden;
    padding-left: 30px;
    padding-right: 30px;
  }

  #summary-table tr td:nth-child(2n) {
    font-weight: bold;
    width: 50%;
    padding-left: 25px;
  }

  #summary-table {
    margin-bottom: 15px;
    margin-right: 10px;
    margin-left: 10px;
  }

  #contact-table {
	margin-bottom: 15px;
	width: 100%;
  }
  .mobile-contact-table {
    margin-bottom: 15px;
    width: 100%;
    }

  #summary-table-payment {
    margin-bottom: 15px;
    margin-right: 10px;
    margin-left: 10px;
  }
  #mobile-summary-table-payment tr td:nth-child(2n) {
    font-weight: bold;
    width: 50%;
    padding-left: 25px;
  }
  .summary_cart_products{
    font-weight: 600;
    font-family: 'Open Sans', sans-serif;
    color: var(--GREY, #696D6E);
    padding-bottom: 15px;
  }
  .products_left{
    width:70%;
  }
  .products_left_error{
    width:70%;
    color: #A94442;
  }
  .products_right{
    text-align:right;
    width: 30%;
  }
  .products_right_error{
    text-align:right;
    width: 30%;
    color: #A94442;
  }
  .summary_cart_body{
    font-weight: 400;
    font-family: 'Open Sans', sans-serif;
    color: var(--GREY, #696D6E);
    padding-bottom: 15px;
  }
  #cart_summary tr td:nth-child(2n) {
    font-weight: 600;
    text-align:right; width: 30%;
  }
  #mobile-summary-table-payment {
    margin-bottom: 15px;
    margin-right: 10px;
    margin-left: 10px;
    width: 90%;
    table-layout:fixed;
    word-break:break-all;
  }
  #cart_btn_close{
    color: var(--GREY, #696D6E);
    border-color: var(--GREY, #696D6E);
    border: 0.5px black solid;
    background-color: #fff;
    border-radius: 50px;
    font-family: 'Open Sans', sans-serif;
  }

  .mobile-travel-table tr td:nth-child(2n) {
    font-weight: bold;
    width: 50%;
    padding-bottom: 8px;
  }

  .mobile-travel-table {
    display: block;
    margin-bottom: 15px;
    width: 100%;
    table-layout:fixed;
    word-break:break-all;
  }

  .mobile-flight-table tr td:nth-child(2n) {
    font-weight: bold;
    width: 50%;
    padding-bottom: 8px;
  }

  #mobile-address-table tr td:nth-child(2n) {
    font-weight: bold;
    width: 50%;
    padding-bottom: 8px;
  }

  .mobile-flight-table {
    display: block;
    margin-bottom: 15px;
  }

  #mobile-address-table {
    display: block;
    margin-bottom: 15px;
  }

  .pan-payment-details-container-mobile {
    width: 100%;
    padding-top: 20px;
    overflow: hidden;
  }

  .payment-mobile-pan-container {
    width: 100%;
    padding-top: 20px;
    background-color: white;
    box-shadow: 0px 4px 7px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    display: block;
  }
  
  .payment-details-table {
	  margin-bottom: 15px;
	  margin-right: 35px;
	  margin-left: 35px;
	  border-collapse: separate;
	  border-spacing: 0 15px;
	  margin-top: -50px;
	}

  .payment-desktop-pan-container {
    display: none;
  }

  .terms-passenger {
    width: 100%;
    text-align: center;
    margin-top: 0px;
    font-size: 14px;
    color: #6d6d6d;
  }

  .payment-details-table-mobile tr td:nth-child(2n) {
    width: 49%;
    padding-left: 1%;
  }

  .payment-details-table-mobile {
    margin-bottom: 15px;
    margin-right: 35px;
    border-collapse: separate;
    border-spacing: 0 15px;
  }

  .payment-table-mobile {
    width: 100%;
  }
}

/* ****Mobile travel details CSS****
 - Mobile travel details
*/
.datepicker td, th {
  color: grey;
}

.ui-datepicker .ui-datepicker-today .ui-state-highlight {
  background: grey;
  border: 1px solid #EFEFEF;
  color: #FFFFFF;
}

a.ui-state-default.ui-state-active.ui-state-active {
  border: 1px solid #4169E1;
  background: #63A4D8;
  color: #FFFFFF;
}

.form-group {
  margin-bottom: 1rem;
}

#ui-datepicker-div table thead {
  display: block;
}

#ui-datepicker-div table thead th {
 padding: 0 0.7em;
}

#banner_container {
  width: 360px;
  margin: 0 auto;
  position: relative;
}

button.carousel-control-prev span.carousel-control-prev-icon {
  position: relative;
  left: -15px;
}

button.carousel-control-next span.carousel-control-next-icon {
  position: relative;
  right: -15px;
}

div.carousel-indicators {
  position: relative;
  top: 0px;
}
