/*! 
!!!!!!!!! DO NOT EDIT THIS FILE MANUALLY !!!!!!
*/
.search-preloader .load-spinner {
  display: inline-block;
  position: relative;
  width: 50px;
  height: 50px; }

.search-preloader .load-spinner div {
  -webkit-transform-origin: 40px 40px;
  transform-origin: 40px 40px;
  -webkit-animation: load-spinner 1.2s linear infinite;
  animation: load-spinner 1.2s linear infinite; }

.search-preloader .load-spinner div::after {
  content: " ";
  display: block;
  position: absolute;
  top: 5px;
  left: 35px;
  width: 5px;
  height: 20px;
  border-radius: 20%;
  background: #0b386c; }

.search-preloader .load-spinner div:nth-child(1) {
  transform: rotate(0deg);
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s; }

.search-preloader .load-spinner div:nth-child(2) {
  transform: rotate(30deg);
  -webkit-animation-delay: -1s;
  animation-delay: -1s; }

.search-preloader .load-spinner div:nth-child(3) {
  transform: rotate(60deg);
  -webkit-animation-delay: -.9s;
  animation-delay: -0.9s; }

.search-preloader .load-spinner div:nth-child(4) {
  transform: rotate(90deg);
  -webkit-animation-delay: -.8s;
  animation-delay: -0.8s; }

.search-preloader .load-spinner div:nth-child(5) {
  transform: rotate(120deg);
  -webkit-animation-delay: -.7s;
  animation-delay: -0.7s; }

.search-preloader .load-spinner div:nth-child(6) {
  transform: rotate(150deg);
  -webkit-animation-delay: -.6s;
  animation-delay: -0.6s; }

.search-preloader .load-spinner div:nth-child(7) {
  transform: rotate(180deg);
  -webkit-animation-delay: -.5s;
  animation-delay: -0.5s; }

.search-preloader .load-spinner div:nth-child(8) {
  transform: rotate(210deg);
  -webkit-animation-delay: -.4s;
  animation-delay: -0.4s; }

.search-preloader .load-spinner div:nth-child(9) {
  transform: rotate(240deg);
  -webkit-animation-delay: -.3s;
  animation-delay: -0.3s; }

.search-preloader .load-spinner div:nth-child(10) {
  transform: rotate(270deg);
  -webkit-animation-delay: -.2s;
  animation-delay: -0.2s; }

.search-preloader .load-spinner div:nth-child(11) {
  transform: rotate(300deg);
  -webkit-animation-delay: -.1s;
  animation-delay: -0.1s; }

.search-preloader .load-spinner div:nth-child(12) {
  transform: rotate(330deg);
  -webkit-animation-delay: 0s;
  animation-delay: 0s; }

.subscriber-form-container .submit-btn-mobile {
  display: none; }
.subscriber-form-container .inputs-col {
  display: flex;
  gap: 10px; }
.subscriber-form-container .form-group {
  max-width: unset !important; }
.subscriber-form-container .subscriber-email {
  width: 100%;
  padding: 10px 10px 10px 20px; }
.subscriber-form-container input, .subscriber-form-container button {
  border-radius: 7px;
  border: 0;
  height: 55px; }
.subscriber-form-container button {
  width: 72px;
  background-color: #f65623;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center; }

.subscriber-form-container.form-type_search-results {
  padding: 40px 35px;
  border-radius: 10px;
  background: #F1F3F8;
  margin-bottom: 20px !important; }
  .subscriber-form-container.form-type_search-results form {
    display: flex;
    justify-content: space-between;
    gap: 10px; }
  .subscriber-form-container.form-type_search-results label {
    max-width: 60%; }
  .subscriber-form-container.form-type_search-results .form-group {
    max-width: 350px !important; }
  .subscriber-form-container.form-type_search-results .inputs-col {
    flex-grow: 1;
    justify-content: end; }
  .subscriber-form-container.form-type_search-results .label-header {
    font-weight: 600;
    display: block;
    font-size: 22px;
    margin-bottom: 10px; }
  .subscriber-form-container.form-type_search-results .label-text {
    font-size: 18px; }
  @media (max-width: 991px) {
    .subscriber-form-container.form-type_search-results {
      padding: 30px 25px; }
      .subscriber-form-container.form-type_search-results form {
        flex-direction: column; }
      .subscriber-form-container.form-type_search-results label {
        max-width: unset; }
      .subscriber-form-container.form-type_search-results .form-group {
        max-width: unset !important; } }
  @media (max-width: 400px) {
    .subscriber-form-container.form-type_search-results .submit-btn-default {
      display: none; }
    .subscriber-form-container.form-type_search-results .submit-btn-mobile {
      display: block;
      font-weight: 500;
      flex-grow: 1; }
    .subscriber-form-container.form-type_search-results .inputs-col {
      flex-wrap: wrap; } }

.subscriber-form-container.form-type_footer {
  color: #fff;
  max-width: 366px !important; }
  .subscriber-form-container.form-type_footer .invalid-feedback {
    font-weight: 600;
    color: #f00; }
  .subscriber-form-container.form-type_footer .label-header {
    display: none; }
  .subscriber-form-container.form-type_footer label {
    margin: 10px 0; }
  .subscriber-form-container.form-type_footer input {
    color: #585C5E; }

.subscriber-create-success.form-type_footer {
  margin-top: 20px;
  font-weight: 500;
  line-height: 1.5; }

.subscriber-create-success.form-type_search-results {
  font-size: 22px;
  font-weight: 500; }

.subscriber-success-modal:not(.already-subscribed) .already-subscribed-only {
  display: none; }
.subscriber-success-modal.already-subscribed .saved-only {
  display: none; }
.subscriber-success-modal .modal-header {
  border: 0; }
.subscriber-success-modal .modal-body {
  padding-top: 0;
  padding-bottom: 30px; }
.subscriber-success-modal .icon-container {
  text-align: center;
  color: #04ad04;
  padding-bottom: 5px; }
.subscriber-success-modal .message-header {
  font-size: 22px;
  font-weight: 500;
  text-align: center;
  margin-bottom: 20px;
  line-height: 1.2; }
.subscriber-success-modal .message {
  line-height: 1.5;
  text-align: center; }

.trip-card-top-badges {
  display: none; }

.traveller-details .prepayment-if-ticket-count-warning {
    padding: 10px 15px;
    border: 1px solid #2738C9 ;
    border-radius: 10px;
    margin: 0 0 15px 0;
    background: white !important;
    font-size: 120%;
    color: #2738C9;
    font-weight: 500; }

.search-results .trip_card {
  --top-badges-height: 29px; }
  .search-results .trip_card:not(.cheapest) .badge-cheapest {
    display: none !important; }
  .search-results .trip_card:not(.fastest) .badge-fastest {
    display: none !important; }
  .search-results .trip_card.has-top-badges {
    margin-top: calc(var(--top-badges-height) + var(--trip-card-margin-bottom)); }
    .search-results .trip_card.has-top-badges .trip-card-top-badges {
      display: block; }


.info-group-seats {
    margin-bottom: 20px; }
.seat-map {
    margin: 10px 0; }
.seat-map.has-validation-error .seat-map-validation-error {
    display: block; }
.seat-map .seat-map-block-layer {
    display: none; }
.seat-map.blocked .seat-map-floors-container {
    position: relative;
    filter: blur(2px); }
.seat-map.blocked .seat-map-floors-container * {
    pointer-events: none; }
.seat-map.blocked .seat-map-floors-container .seat-map-block-layer {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: white;
    opacity: 0.6; }

.seat-map-validation-error {
    display: none;
    padding-top: 10px; }

.seat-map-warning {
    display: none;
    margin: 10px 0;
    padding-top: 10px; }
.seat-map-warning.larger-warning {
    font-size: 1.3rem;
    line-height: 1.5; }
.seat-map-warning.visible {
    display: block; }

.seat-map-floors-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    row-gap: 20px;
    column-gap: 10px;
    margin: 10px 0;
    overflow: auto;
    scrollbar-width: none; }

.seat-map-floor {
    display: block; }
.seat-map-floor .seats-floor-label-wrapper {
    display: inline-block; }
.seat-map-floor .floor-label {
    margin-bottom: 15px;
    color: #525252;
    text-align: center; }
.seat-map-floor .floor-seats {
    display: inline-flex;
    flex-direction: column;
    gap: 8px;
    padding: 50px 15px 15px 15px;
    border: 2px solid #dedede;
    border-radius: 60px 60px 20px 20px; }

.seat-map-seat-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-weight: bold; }
.seat-map-seat-row .seat-map-seat {
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    border: 2px solid #dedede;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    /*
    //for horizontal seat icons
    &.has-number {
      svg {
        position: relative;
      }
      .seat-label {
        position: relative;
        left: 4px;
        bottom: 3px;
      }
    }
    &.has-long-number {
      svg {
        left: -2px;
      }
      .seat-label {
        left: 6px;
        bottom: 5px;
      }
    }
     */ }
.seat-map-seat-row .seat-map-seat * {
    user-select: none; }
.seat-map-seat-row .seat-map-seat.always-hidden {
    opacity: 0; }
.seat-map-seat-row .seat-map-seat:not(.selectable-seat):not(.always-hidden) {
    cursor: not-allowed; }
.seat-map-seat-row .seat-map-seat .seat-icon {
    position: absolute; }
.seat-map-seat-row .seat-map-seat svg {
    color: #dedede; }
.seat-map-seat-row .seat-map-seat .seat-label {
    position: relative;
    color: #dedede; }
.seat-map-seat-row .seat-map-seat.has-icon .seat-label {
    color: #fff;
    left: 3px;
    bottom: 0; }
.seat-map-seat-row .seat-map-seat.has-icon.has-long-number .seat-label {
    left: 6px; }
.seat-map-seat-row .seat-map-seat:not(.selectable-seat) svg {
    color: #dedede; }
.seat-map-seat-row .seat-map-seat.selectable-seat svg {
    color: #2bacc0; }
.seat-map-seat-row .seat-map-seat.selected {
    border-color: #2738C9 !important;
    color: #2738C9; }
.seat-map-seat-row .seat-map-seat.selected svg {
    color: #2738C9; }
.seat-map-seat-row .seat-map-seat .seat-icon-label-container {
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center; }
.seat-map-seat-row .seat-map-seat .seat-label {
    z-index: 1; }
.seat-map-seat-row .seat-map-seat.selectable-seat {
    cursor: pointer;
    border-color: #2bacc0; }

.seat-map.no-seat-icons .seat-map-seat.seat-type-seat svg {
    display: none; }
.seat-map.no-seat-icons .seat-map-seat.selectable-seat .seat-label {
    color: #2bacc0; }
.seat-map.no-seat-icons .seat-map-seat.selectable-seat:hover {
    border-color: #2738C9 !important; }
.seat-map.no-seat-icons .seat-map-seat.selectable-seat:hover .seat-label {
    color: #2738C9; }
.seat-map.no-seat-icons .seat-map-seat.selected {
    background: #2738C9; }
.seat-map.no-seat-icons .seat-map-seat.selected .seat-label {
    color: white !important; }

.alert-danger {
    --bs-alert-color: #be061a;
    --bs-alert-bg: #ffe6e9; }




.trip-card-top-badges {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(var(--top-badges-height) * -1); }
  .trip-card-top-badges .trip-card-top-badge-heads {
    display: flex;
    gap: 10px; }
  .trip-card-top-badges .trip-card-top-badge-head {
    border-top-left-radius: 7px;
    border-top-right-radius: 7px;
    padding: 5px 15px 2px 15px;
    font-weight: 500;
    color: white;
    display: inline-block;
    text-align: center; }
  .trip-card-top-badges .trip-card-top-badges-footer {
    height: 15px;
    border-top-right-radius: 10px; }
    .trip_card.fastest .trip-card-top-badges .trip-card-top-badges-footer {
      background-color: #2A9EDD; }
    .trip_card.cheapest .trip-card-top-badges .trip-card-top-badges-footer {
      background-color: #3ABF56; }
  .trip-card-top-badges .badge-cheapest {
    background-color: #3ABF56; }
  .trip-card-top-badges .badge-fastest {
    background-color: #2A9EDD; }

body {
  background-color: rgb(242,242,247)  !important;
  --trip-card-margin-bottom: 20px; }
  body.no-scroll {
    margin: 0 !important;
    height: 100% !important;
    overflow-y: hidden !important; }

.trip_card .prepayment-badge .icon {
  margin-right: 2px; }
.trip_card .submit-bottom-text {
  color: #A7A7A7; }
.trip_card .prepayment-badge-no {
  background-color: #C9FFC7 !important;
  color: #659B63 !important; }
.trip_card .prepayment-badge-full {
  background-color: #FFC7C7 !important;
  color: #9B6363 !important; }
.trip_card .prepayment-badge-part {
  background-color: #FFFCC7 !important;
  color: #9B8E63 !important; }
.trip_card .price-text.has-promotion {
  color: #FF0000;
  display: inline-flex;
  font-size: 25px;
  align-items: center;
  flex-wrap: wrap; }
  .trip_card .price-text.has-promotion s {
    color: #A7A7A7;
    font-size: 14px;
    margin-right: 5px;
    font-weight: normal; }
.trip_card .bottom-info {
  display: flex;
  align-items: center;
  color: #313132; }
  .trip_card .bottom-info .service-icons {
    display: flex;
    align-items: center; }
    .trip_card .bottom-info .service-icons .bi {
      display: inline-block;
      margin-right: 10px; }
      .trip_card .bottom-info .service-icons .bi.hidden {
        display: none; }
      .trip_card .bottom-info .service-icons .bi::before {
        color: #A7A7A7 !important; }
      .trip_card .bottom-info .service-icons .bi:hover::before {
        color: #2738C9!important; }
      .trip_card .bottom-info .service-icons .bi.bi-tv {
        position: relative;
        top: 2px;
        /* this icon looks a bit higher */ }
    @media (min-width: 769px) {
      .trip_card .bottom-info .service-icons:hover .plus-services-text {
        display: none; }
      .trip_card .bottom-info .service-icons:hover .bi.hidden {
        display: inline-block; } }
  .trip_card .bottom-info .label {
    color: #A7A7A7; }
  .trip_card .bottom-info .service-icons, .trip_card .bottom-info .carrier {
    margin-right: 20px; }
.review-flight .trip_card .bottom-info {
  margin-top: 20px; }
@media screen and (max-width: 768px) {
  .trip_card .bottom-info {
    order: 1; }
  .trip_card .price-col {
    order: 2; }
  .trip_card .bottom-info {
    flex-direction: column;
    align-items: start;
    margin-top: 10px;
    padding: 15px 10px;
    border-top: 1px solid #E1E1E1;
    border-bottom: 1px solid #E1E1E1; }
    .trip_card .bottom-info .info-col {
      margin-bottom: 10px; }
      .trip_card .bottom-info .info-col:last-child {
        margin-bottom: 0; }
  .trip_card .top-badges-container {
    margin-bottom: 10px; }
  .trip_card .price-col, .trip_card .top-badges-container {
    padding-left: 10px; }
  .trip_card .price-col-main-row {
    display: flex; }
    .trip_card .price-col-main-row .inner-price-col {
      order: 1; }
    .trip_card .price-col-main-row .prepayment-badges-col {
      order: 2; }
      .trip_card .price-col-main-row .prepayment-badges-col .btn {
        margin-bottom: 0 !important; } }
.trip_card .trip-info-copy-btn {
  padding: 0 10px;
  display: flex;
  align-items: center;
  justify-content: center; }
  .trip_card .trip-info-copy-btn::before {
    color: #A7A7A7 !important;
    transition: color 0.1s;
    cursor: pointer; }
  .trip_card .trip-info-copy-btn:not(.pressed):hover::before {
    color: #2738C9!important; }
.trip_card .details-wrapper.details-in-modal-wrapper {
  height: 100%; }
.trip_card .details-wrapper .preloader {
  position: static;
  background: none;
  padding: 30px 0; }

.trip-card-details .main-inner-container {
  padding: 10px 20px; }
.trip-card-details .tab-details, .trip-card-details .tab-comfort, .trip-card-details .tab-route {
  padding-left: 0 !important;
  padding-right: 0 !important; }
.trip-card-details .block-heading {
  position: relative;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  width: 100%;
  margin-bottom: 15px; }
.trip-card-details .block-heading:before {
  content: "";
  display: block;
  border-top: solid 2px #D9D9D9;
  width: 100%;
  height: 2px;
  position: absolute;
  top: 50%;
  z-index: 0; }
.trip-card-details .block-heading span {
  background: #ffffff;
  padding: 0 10px;
  position: relative;
  z-index: 1; }
.trip-card-details .services {
  margin-bottom: 20px;
  max-width: 400px; }
  .trip-card-details .services .row {
    row-gap: 10px;
    justify-content: left !important; }
  .trip-card-details .services .service {
    width: 40%; }
  @media (max-width: 1200px) {
    .trip-card-details .services .service {
      width: 50%; } }
.trip-card-details.in-modal .tab-details, .trip-card-details.in-modal .tab-comfort, .trip-card-details.in-modal .tab-route {
  padding: 0 !important; }
.trip-card-details.in-modal .route-block {
  margin-bottom: 20px; }
.trip-card-details.in-modal .services {
  margin-top: 20px; }
.trip-card-details.in-modal .bus-name {
  margin-top: 20px; }
.trip-card-details .add-info {
  margin-bottom: 20px !important; }
.trip-card-details .trip-name {
  font-size: 18px;
  font-weight: 600;
  margin: 20px 0; }
.trip-card-details .trip-time-note {
  margin-bottom: 10px; }
.trip-card-details .photo-block {
  margin-top: 30px; }
.trip-card-details .first-col {
  margin-right: 10px; }
.trip-card-details .second-col {
  margin-left: 10px; }
.trip-card-details .first-col, .trip-card-details .second-col {
  width: 50%;
  max-width: 50%; }
  @media (max-width: 768px) {
    .trip-card-details .first-col, .trip-card-details .second-col {
      width: 100%;
      max-width: 100%; } }
.trip-card-details .owl-carousel {
  padding: 0 30px;
  position: relative; }
.trip-card-details .owl-nav {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: -1;
  margin-top: 0 !important; }
  .trip-card-details .owl-nav .bi::before {
    content: "";
    width: 15px;
    height: 15px;
    border-top: 4px solid black;
    border-right: 4px solid black;
    transform: rotate(45deg); }
  .trip-card-details .owl-nav .owl-prev {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0; }
    .trip-card-details .owl-nav .owl-prev .bi::before {
      transform: rotate(-135deg); }
  .trip-card-details .owl-nav .owl-next {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0; }
.trip-card-details .owl-dots {
  display: none; }
.trip-card-details .owl-item {
  height: 176px;
  display: flex;
  justify-content: center; }
.trip-card-details .owl-stage-outer, .trip-card-details .image-wrapper {
  border-radius: 10px; }
.trip-card-details .owl-item .item {
  height: 100%;
  overflow: hidden;
  display: flex;
  justify-content: center;
  width: 100% !important;
  max-width: unset !important; }
  .trip-card-details .owl-item .item .image-wrapper {
    overflow: hidden; }
  .trip-card-details .owl-item .item img {
    width: 212px !important;
    min-height: 100% !important;
    max-width: unset !important;
    max-height: unset !important; }
.trip-card-details .point-name-col {
  width: 100%;
  flex-shrink: 1;
  margin-left: 25px; }
.trip-card-details .point-row {
  flex-wrap: nowrap; }
.trip-card-details .show-interim-points-btn {
  display: none;
  color: #2738C9;
  cursor: pointer; }
.trip-card-details.interim-points-hidden .interim-points {
  display: none; }
.trip-card-details.interim-points-hidden .show-interim-points-btn {
  display: block; }
.trip-card-details .main-inner-container {
  opacity: 1;
  transition: opacity .3s ease-in-out .2s; }
  .trip-card-details .main-inner-container.hidden {
    opacity: 0; }

.trip-card-details-modal .modal-title {
  margin: 0 auto; }
.trip-card-details-modal .btn-close {
  width: 35px;
    height: 35px;
    color: black;
    border-radius: 15px;
    font-size: 35px;
    background: lightgrey;
  right: 20px; }
.trip-card-details-modal .modal-footer {
  display: flex;
  justify-content: center; }
  .trip-card-details-modal .modal-footer button, .trip-card-details-modal .modal-footer button.btn-select.btn.btn-effect {
    max-width: 300px; }
.trip-card-details-modal .container {
  max-width: unset; }

.fslightbox-container .fslightbox-toolbar-button:first-child {
  display: none; }
.fslightbox-container .fslightbox-slide-number-container {
  display: none; }

.search-results .hidden-by-filter {
  display: none; }
.search-results .search-results-heading {
  display: flex;
  align-items: center;
  margin: 0 !important; }
  .search-results .search-results-heading .heading-text {
    margin-top: 0 !important;
    margin-bottom: 0 !important; }
.search-results.no-trips-with-filter .found-trips-heading {
  opacity: 0; }
.search-results .heading-filter-container {
  display: flex;
  position: relative;
  margin-bottom: 30px; }
.search-results .no-trips-with-filter-text {
  display: none;
  text-align: center;
  margin: 40px 0; }
  .search-results .no-trips-with-filter-text .heading {
    font-size: 30px; }
.search-results.no-trips-with-filter .no-trips-with-filter-text {
  display: block; }
.search-results.no-trips .trip-search-filter {
  display: none; }
body.trip-search-preload-mode .search-results {
  position: relative;
}
  body.trip-search-preload-mode .search-results::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 100;
  }
  body.trip-search-preload-mode .search-results .preload-mode-notice {
    display: block;
  }
  body.trip-search-preload-mode .search-results .trip-date-group {
    position: relative; }
  body.trip-search-preload-mode .search-results .trip-date-group::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: white;
    opacity: 0.5; }
.search-results .preload-mode-notice {
  display: none;
  position: sticky;
  top: 0;
  z-index: 100;
  padding: 10px 0 5px 0;
  background-color: #ffffff;
  box-shadow: 0 0 10px 20px white; }
  .search-results .preload-mode-notice .notice-content {
    display: flex;
    margin: 0 !important;
    padding: 15px 20px !important; }
  .search-results .preload-mode-notice .search-preloader {
    margin-right: 15px;
    display: flex; }
    .search-results .preload-mode-notice .search-preloader .load-spinner {
      transform: scale(0.7);
      position: relative;
      top: -20%;
      left: -20%; }
  .search-results .preload-mode-notice .message {
    display: flex;
    align-items: center; }
    .search-results .preload-mode-notice .message h3 {
      margin: 0;
      padding: 0; }

.trip-search-filter {
  display: flex;
}
  @media (max-width: 1200px) {
    .trip-search-filter {
      position: static;
      margin-top: 20px;
      justify-content: left; } }
  @media (max-width: 370px) {
    .trip-search-filter {
      margin-right: 5px; } }
  .trip-search-filter .filter-main-row {
    max-width: 350px; }
  .trip-search-filter label, .trip-search-filter input, .trip-search-filter .dropdown-item {
    user-select: none;
    cursor: pointer; }
  .trip-search-filter input[type="checkbox"] {
    border-color: #2738C9!important;
    font-size: .8rem;
    border-width: 1px !important; }
  .trip-search-filter .col {
    margin-right: 10px;
    padding-right: 10px;
    display: flex; }
    .trip-search-filter .col:last-child {
      margin-right: 0; }
  .trip-search-filter .dropdown-toggle {
    padding-left: 20px !important;
    padding-right: 30px !important;
    min-width: 182px; }
  .trip-search-filter .dropdown-item {
    cursor: pointer;
    padding: 10px; }
    @media (max-width: 768px) {
      .trip-search-filter .dropdown-item {
        position: static;
        padding: 15px 10px; } }
    .trip-search-filter .dropdown-item.active {
      color: #f65623;
      background-color: #fff; }
    .trip-search-filter .dropdown-item:hover {
      background-color: #fff !important; }
  .trip-search-filter button::after {
    display: none; }

.traveller-details {
  position: relative; }
  .traveller-details .info-group-contacts {
    overflow: visible; }
  .traveller-details.loading::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: #fff;
    opacity: 0.2; }
  .traveller-details .pay-method .prepay-discount-notice {
    background-color: #219406;
    color: #fff;
    font-weight: bold;
    padding: 3px 7px;
    border-radius: 5px;
    margin-left: 10px; }
  .traveller-details .btn .prepay-discount-notice {
    font-weight: bolder; }
  .traveller-details .agreement-checkbox-container {
    padding: 15px 0 15px 0 !important; }
    .traveller-details .agreement-checkbox-container.for-privacy {
      margin-bottom: 0 !important; }
    .traveller-details .agreement-checkbox-container.for-email {
      margin-top: 0 !important; }
  .traveller-details .promo-code-success-msg, .traveller-details .promo-code-error-msg {
    margin-top: -10px;
    font-weight: 500; }
  .traveller-details .promo-code-success-msg {
    color: #40BB1E; }
  .traveller-details .promo-code-error-msg {
    color: #F62323; }
  .traveller-details.promo-code-applied .promo-code-button-container {
    display: none; }
  .traveller-details.promo-code-applied.online-payment-selected .promo-code-success-msg {
    display: block !important; }
  .traveller-details.promo-code-applied .promo-code-input {
    color: #A6A8A9 !important; }
  .traveller-details .amount-details .row + .row {
    margin-top: 10px; }

.not-enough-free-seats {
  text-align: center; }
  .not-enough-free-seats h3 {
    margin: 0; }

.preloader.transparent {
  background: transparent; }
.preloader.fully-transparent {
  opacity: 0; }

.iti:not(.iti--container) {
  width: 100%; }
  .iti:not(.iti--container) .iti__search-input {
    padding: 13px 12px; }

.iti--fullscreen-popup.iti--container {
  padding: 20% 0 0 0 !important; }
  .iti--fullscreen-popup.iti--container .iti__dropdown-content {
    border-radius: 10px 10px 0 0; }

.iti__search-input {
  padding: 12px 13px; }

.reservation_complete-popup .return-discount-block {
  margin-bottom: 20px;
  font-size: 1.5rem;
  font-weight: bold;
  border: 1px solid #f20000;
  color: #f20000;
  border-radius: 10px;
  padding: 15px; }
.reservation_complete-popup .return-discount-btn {
  margin-top: 10px;
  display: inline-block;
  padding: 5px 15px;
  border-radius: 5px;
  background: #f65623;
  color: white;
  cursor: pointer; }
.reservation_complete-popup.pay-fail .cta-container-td {
  border-color: #f20000; }
  .reservation_complete-popup.pay-fail .cta-container-td p.cta-container-td-h {
    color: #f20000; }

.transparent-errors .invalid-feedback {
  display: block !important;
  opacity: 0; }
  .transparent-errors .invalid-feedback::before {
    content: 'A'; }
.transparent-errors .is-invalid ~ .invalid-feedback {
  opacity: 1; }
  .transparent-errors .is-invalid ~ .invalid-feedback::before {
    content: ''; }



/* Desktop-only modal override */
@media (min-width: 768px) {
    .trip-card-details-modal .modal-dialog {
        margin: 0;                     /* remove centering */
        height: 100%;                  /* full height */
        max-width: 600px;              /* your requested width */
        width: 100%;
        position: fixed;
        right: 0;                      /* stick to the right */
        top: 0;
        transform: none !important;    /* disable Bootstrap centering */
    }

    .trip-card-details-modal .modal-content {
        height: 100%;
        border-radius: 0;              /* optional: flat edges like mobile */
        overflow-y: auto;
    }

    /* Optional: dim background slightly differently */
    .trip-card-details-modal.modal {
        padding-left: 0 !important;
    }
}



     /* Scrollable row of buttons */
 .tab-container {
     display: flex;
     gap: 10px;
     overflow-x: auto;
     padding: 10px 0;
     scrollbar-width: none; /* Firefox hide scroll */
 }

.tab-container::-webkit-scrollbar {
    display: none; /* Chrome hide scroll */
}

.tab-btn {
    height: 52px;
    padding: 10px 18px;
    background: #f1f1f5;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    flex-shrink: 0; /* prevents shrinking */
    white-space: nowrap;
    font-size: 15px;
    border-radius: 16px;
}

.tab-btn.active {
    background: #2738C9;
    color: white;
}

.tab-content {
    margin-top: 20px;
}


.popup-st-sup-main {
    position: relative;
    display: flex;
    align-items: flex-start;
    flex-grow: 1;
}


.popup-st-duration-container {
    display: flex;
    position: static;
    margin-right: 0px;
    flex-direction: column;
    align-items: center;
    margin-top: 8px;
    flex-grow: 1;
    padding: 0 10px;
}

.popup-st-time-row {
    display: flex;
    height: 34px;
    flex-direction: column;
}

.popup-st-duration-text {
    font-size: 14px;
    color: #666;
    margin-bottom: 8px;
    white-space: nowrap;
    background: white;
    z-index: 9;
    padding: 1px 7px;
}



.popup-st-duration-line {
    display: flex;
    align-items: center;
    width: 55%;
    right: 22%;
    top: 13px;
    position: absolute;
}


.popup-st-container {
    flex-basis: 220px;
}

.popup-st-time-row {
    display: flex;
    height: 34px;
}

.popup-st-time {
    font-size: 24px;
    font-weight: 700;
    color: #111;
}

.popup-st-date {
    align-content: center;
    height: 100%;
    width: 93px;
    white-space: nowrap;
    background: none;
    font-size: 12px;
    margin-left: 0;

    border-radius: 8px;

}

.popup-st-city {
    font-size: 18px;
    font-weight: 700;
    color: #111;
    margin-top: 20px;
}

.popup-st-address {
    font-size: 14px;
    color: #666;
    margin: 0;
    line-height: 1.4;
}


.popup-st-container.popup-st-right .popup-st-date {
    text-align: right;
}

.popup-st-container.popup-st-right {
    justify-items: flex-end;
    text-align: right;
}


.popup-st-dot-start {
    width: 12px;
    height: 12px;
    border: 2px solid #303F9F;
    border-radius: 50%;
    background-color: #fff;
    flex-shrink: 0;
}

.popup-st-dashed-line {
    flex-grow: 1;
    height: 0;
    border-bottom: 2px dashed #ccc;
    margin: 0 5px;
}

.popup-st-dot-end {
    width: 12px;
    height: 12px;
    background-color: #303F9F;
    border-radius: 50%;
    flex-shrink: 0;
}



.trip-search-date-tabs {
    margin: 30px 0 20px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}
.trip-search-date-tabs .date-tab {
    height: 45px;
    border-radius: 10px;
    flex-grow: 1;
    flex-shrink: 0;
    font-size: 16px;
    padding: 0 10px;
    color: #313132;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: default;
}
.trip-search-date-tabs .date-tab:hover, .trip-search-date-tabs .date-tab:active {
    background-color: #e8e8ff;
}
.trip-search-date-tabs .date-tab.active {
    background-color: #e8e8ff;
    border: 1px solid #2738C9;
    font-weight: 500;
}
.trip-search-date-tabs .date-tab-divider {
    width: 1px;
    height: 16px;
    background-color: #E1E1E1;
}
.trip-search-date-tabs .date-tab-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-grow: 1;
    flex-shrink: 0;
}
.trip-search-date-tabs .date-tab-wrapper.active .date-tab-divider, .trip-search-date-tabs .date-tab-wrapper:hover .date-tab-divider, .trip-search-date-tabs .date-tab-wrapper:active .date-tab-divider {
    opacity: 0;
}
.trip-search-date-tabs .date-tab-wrapper.active + .date-tab-wrapper .date-tab-divider,
.trip-search-date-tabs .date-tab-wrapper:hover + .date-tab-wrapper .date-tab-divider,
.trip-search-date-tabs .date-tab-wrapper:active + .date-tab-wrapper .date-tab-divider {
    opacity: 0;
}
@media (max-width: 991px) {
    .trip-search-date-tabs {
        overflow-x: auto;
        mask-image: linear-gradient(to right, black 0%, black calc(100% - 30px), transparent 100%);
    }
    .trip-search-date-tabs .date-tab-divider {
        display: none;
    }
    .trip-search-date-tabs .date-tab {
        border: 1px solid #E1E1E1;
    }
}

