@import "fonts.css";

:root {
    --accent-color: #fcf7b6;
    --info-color: #0bbcd3;
    --primary-color: #329c05;
    --primary-dark-color: #2e9004;
    --secondary-color: #ca9c27;
}

body,
pre {
    background: #fff;
    color: #000;
    font-family: FiraSans, Krasar, sans-serif;
    font-size: 100%;
    -webkit-font-smoothing: antialiased;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-text-size-adjust: 100%;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 700;
    line-height: 1.25;
    padding-top: 0;
}

.navbar.navbar-expand-md {
    z-index: 1;
    padding: 0;
    background: var(--primary-color);
}

h6,
.h6 {
    font-size: 1.2rem;
}

#qrcode img {
    border: 1px solid #fff;
    border-radius: 4px;
    margin: 0 auto;
    padding: 8px;
}

.datepicker {
    border-radius: 12px !important;
}

.me-n9 {
    margin-right: -11rem !important;
}

.mt-n7 {
    margin-top: -4rem !important;
}

/*.top-menu {*/
/*    box-shadow: 0 3px 0 -1px rgba(255, 255, 255, 0.4);*/
/*}*/

.top-menu::before {
    content: '';
    position: absolute;
    top: 67px;
    left: 50%;
    transform: translateX(-50%);
    height: 2px;
    width: 100%;
    background: linear-gradient(to right, transparent, #c1c1c1, transparent);
}

.navbar-nav .nav-link {
    padding: 8px 16px;
    color: #fff;
    text-transform: capitalize;
    position: relative;
}

.navbar-nav .nav-link.active {
    color: #fff;
}

.navbar-nav .nav-link.active::after {
    position: absolute;
    content: "";
    left: 0;
    right: 0;
    height: 4px;
    background: #ffd700;
    z-index: 100;
    border-radius: 4px;
    width: 100%;
    bottom: -16px;
}

.navbar-nav .nav-link .flex-column {
    align-items: center;
    justify-content: center;
}

.fs-1 {
    font-size: 0.812rem;
}

.title-gradient {
    /*background: linear-gradient(45deg, #41A400 5%, #D7A724 40%);
      -webkit-text-fill-color: transparent;*/
    line-height: 1.6;
}

.btn.btn-lg,
.form-floating>.form-control,
.form-floating>.form-control-plaintext,
.form-floating>.form-select {
    height: calc(3.8rem + 2px);
}

.text-small {
    color: #777;
    font-size: 14px;
}

.has-new {
    position: absolute;
    top: -10px;
    right: 10px;
    font-size: 10px;
    color: white;
    background: #e42e2e;
    border-radius: 4px;
    padding: 0 2px;
}

.main .lead .form-floating .form-control,
.main .lead .form-floating .form-select {
    border: 0;
    border-radius: 0.5rem;
    color: #000;
    font-size: 18px;
    font-weight: bold;
    padding-left: 10px;
}

.main .lead .form-floating .form-control,
.main .lead .form-floating .form-select:focus {
    box-shadow: none;
}

.main .lead .form-floating .form-control:disabled,
.main .lead .form-floating .form-select:disabled {
    background-color: rgba(255, 255, 255, 0.47);
}

.main .lead .form-floating {
    padding: 0 10px;
    background: #fff;
    border-radius: 6px;
    margin-bottom: 1rem;
    /*filter: drop-shadow(3px 3px 10px rgba(0, 0, 0, 0.1));*/
}

.main .lead .form-floating>label {
    margin-left: 36px;
}

.main .lead .form-floating>img {
    max-width: 30px;
}

.list-inline-item:not(:last-child) {
    margin: 0;
}

.dropdown-menu {
    background: #fff;
    border: 0;
    border-radius: 4px;
    box-shadow: 0 4px 12px rgba(8, 27, 55, 0.2);
}

.main {
    padding-bottom: 0;
}

.main .lead {
    background: var(--primary-color);
    position: relative;
}

.main .lead .pay-img img {
    filter: hue-rotate(45deg);
    height: 26px;
}

.main .lead h1 {
    font-size: 1.5rem;
    font-weight: 400;
}

.main .lead .form-floating>label {
    color: #000;
    font-size: 80%;
    opacity: 0.8;
}

.main .lead .form-floating>.form-select option {
    color: #000;
}

.btn {
    border-radius: 0.5rem;
    font-weight: 500;
    letter-spacing: 0.0178571429em;
}

.main .lead .btn.disabled,
.main .lead .btn:disabled,
.main .lead fieldset:disabled .btn {
    opacity: 1;
}

input[readonly] {
    cursor: pointer;
}

.step-wrap {
    background: #dcdcdc6e;
    border-radius: 12px;
    padding-left: 1rem;
    padding-top: 1.25rem;
}

.step-wrap ul {
    background: orange;
    float: left;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.step-wrap ul li {
    display: inline-block;
}

.text-success {
    color: var(--primary-color);
}

.branch-wraps .card-body {
    background: white;
    box-shadow: 0 0 10px 5px rgba(0, 0, 0, 0.06);
    border-radius: 12px;
}

.branch-wraps a {
    color: #000;
    text-decoration: none;
}

.branch-wraps a:hover {
    color: var(--primary-color);
}

.branch-wraps img {
    border-radius: 15px;
}

.step-wrap .col-md-4 {
    margin-bottom: 16px;
}

.mb-1 {
    margin-bottom: 0.25rem !important;
}

.step-wrap a {
    background-color: transparent;
    text-decoration: none;
}

.step-wrap .icon-circle {
    align-items: center;
    display: flex;
    height: 55px;
    justify-content: start;
    margin-right: 16px;
    width: 50px;
}

.step-wrap .icon-circle img {
    width: 42px;
}

.step-wrap h3 {
    color: #222;
    font-size: 1.2rem;
    margin-bottom: 0.25rem !important;
}

.pay-img img {
    height: 18px;
    margin-right: 1px;
}

/*.step-wrap .pay-img img {*/
/*    opacity: 0.9;*/
/*}*/

.step-wraps h4 {
    font-weight: 700;
}

.step-wrap .icon-circle i {
    color: var(--primary-color);
    font-size: 26px;
}

.step-wrap p {
    margin: 0;
}

.rate-review {
    text-align: right;
}

.rate-review li a img {
    background: rgba(0, 0, 0, 0.1);
    border: 1px solid #0dcaf0;
}

.unlisted {
    list-style: none;
    margin-bottom: 0;
    padding: 0;
}

.feature-service {
    padding: 12px 0;
}

.feature-service .unlisted li {
    align-items: center;
    display: flex;
    padding: 4px 0;
}

.feature-service .unlisted li img {
    background-color: white;
    filter: drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.1));
    object-fit: cover;
    border-radius: 50%;
    width: 38px;
}

.feature-service .unlisted i {
    color: var(--primary-color);
    font-size: 16px;
    margin-right: 8px;
}

.carousel-item img,
.carousel-inner {
    border: 0;
    border-radius: 12px;
    box-shadow: 5px 5px 20px 10px #ddd;
}

h2.title {
    color: #202124;
    font-size: 1.62rem;
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.75rem;
}

.blockquote {
    background-color: #31a50552;
    border-radius: 12px;
    font-size: 16px;
    padding: 18px;
}

.blockquote h5 {
    font-size: 16px;
}

.text-info {
    color: var(--info-color);
}

.accepted-payment {
    padding: 8px 0;
    width: 100%;
}

.accepted-payment ul {
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.accepted-payment ul li {
    display: inline-block;
}

.accepted-payment ul li img {
    border: 0;
    border-radius: 4px;
    filter: grayscale(100%);
    height: 18px;
    vertical-align: middle;
}

.accepted-payment ul li img:hover {
    filter: grayscale(0%);
}

.sub-title {
    font-size: 14px;
    font-weight: 700;
    line-height: 17px;
    margin-bottom: 16px;
}

.swiper-container {
    border-radius: 4px;
    height: 100%;
    width: 100%;
}

.schedule-wraps a {
    color: #888;
    text-decoration: none;
}

.schedule-wraps a:hover {
    color: #565dff;
}

.h-20px {
    height: 20px !important;
}

.h-30px {
    height: 30px !important;
}

.h-40px {
    height: 40px !important;
}

.h-50px {
    height: 50px !important;
}

.h-60px {
    height: 60px !important;
}

.h-150px {
    height: 150px !important;
}

.h-200px {
    height: 200px !important;
}

.h-250px {
    height: 250px !important;
}

.h-300px {
    height: 300px !important;
}

.h-400px {
    height: 400px !important;
}

.h-500px {
    height: 500px !important;
}

.h-600px {
    height: 600px !important;
}

.h-700px {
    height: 700px !important;
}

.h-750px {
    height: 750px !important;
}

.swiper-slide {
    -webkit-align-items: center;
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-align: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    text-align: center;
}

.mb-n5 {
    margin-bottom: -2.5rem !important;
}

.mb-n6 {
    margin-bottom: -3.5rem !important;
}

.mb-n7 {
    margin-bottom: -4rem !important;
}

.mb-n8 {
    margin-bottom: -8rem !important;
}

.mb-n9 {
    margin-bottom: -11rem !important;
}

.ms-n1 {
    margin-left: -0.25rem !important;
}

.ms-n2 {
    margin-left: -0.5rem !important;
}

.ms-n3 {
    margin-left: -1rem !important;
}

.ms-n4 {
    margin-left: -1.6rem !important;
}

.ms-n5 {
    margin-left: -2.5rem !important;
}

.ms-n6 {
    margin-left: -3.5rem !important;
}

.ms-n7 {
    margin-left: -4rem !important;
}

.ms-n8 {
    margin-left: -8rem !important;
}

.ms-n9 {
    margin-left: -11rem !important;
}

.swiper-slide img {
    border-radius: 12px;
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.bg-grey {
    background-color: #f7f7f7;
}

.card {
    border: 0;
    border-radius: 0.5rem;
}

.card.card-schedule {
    background: #ffffff;
    margin-bottom: 1rem;
    position: relative;
    overflow: hidden;
}

.seat {
    align-items: center;
    color: #444;
    display: flex;
    font-weight: 700;
    height: 56px;
    justify-content: center;
    width: 56px;
    transition: transform 0.2s ease-in-out;
}

.seat:hover {
    transform: scale(1.24);
}

.seat i {
    align-items: center;
    display: flex;
    font-size: 14px;
    font-style: normal;
    justify-content: center;
    margin-top: 6px;
}

.seat .seat-gender {
    align-items: center;
    background: #da16d0;
    border: 0;
    border-radius: 100%;
    color: white;
    display: flex;
    font-size: 8px;
    font-weight: 300;
    height: 15px;
    justify-content: center;
    position: absolute;
    right: -7px;
    text-transform: uppercase;
    top: -7px;
    width: 15px;
}

.seat.available {
    background: url(../img/seat-icon/seat_available.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
    color: black;
}

.seat.available[data-name="selected_true"] {
    background: url(../img/seat-icon/seat_booking.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.booked {
    background: url(../img/seat-icon/seat_booked.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.busy {
    background: url(../img/seat-icon/seat_busy.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
    color: white;
}

.seat.selected {
    background: url(../img/seat-icon/seat_selected.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.available[data-night="1"] {
    background: url(../img/seat-icon/sp_seat_available.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
    color: black;
}

.seat.available[data-name="selected_true"][data-night="1"] {
    background: url(../img/seat-icon/sp_seat_booking.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.booked[data-night="1"] {
    background: url(../img/seat-icon/sp_seat_booked.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.busy[data-night="1"] {
    background: url(../img/seat-icon/sp_seat_busy.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.seat.selected[data-night="1"] {
    background: url(../img/seat-icon/sp_seat_selected.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
}

.driver {
    background: url(../img/seat-icon/driving-control.png) no-repeat center;
    background-clip: content-box;
    background-size: cover;
    opacity: 1;
}

[name="chSeat"] {
    cursor: pointer;
    height: 1rem;
    margin-top: -5px;
    width: 1rem;
}

[name="chSeat"]:hover {
    opacity: 0.6;
}

hr {
    border-top: 1px solid;
    margin: 8px 0;
    opacity: 0.2;
}

.ml-2 {
    margin-right: 2rem;
}

.sub-head-title {
    border-left: 4px solid #ffd700;
    border-radius: 0;
    font-size: 22px;
    font-weight: 400;
    padding-left: 16px;
}

h1 {
    font-size: 22px;
}

table.table-summary {
    border-collapse: collapse;
    width: 100%;
}

table.table-summary tr td {
    color: #666;
    font-size: 13px;
    padding: 2px 0;
}

.table-summary tr td:first-child {
    color: #000;
}

.sub-title {
    align-items: center;
    color: #555;
    display: flex;
    font-size: 18px;
    margin-bottom: 16px;
}

.sub-title .circle {
    align-items: center;
    background: var(--secondary-color);
    border-radius: 100%;
    color: #fff;
    display: flex;
    float: left;
    font-size: 14px;
    height: 35px;
    justify-content: center;
    margin-right: 8px;
    margin-top: -5px;
    width: 35px;
}

.form-wrap {
    margin-bottom: 2rem;
}

.p-2 {
    padding: 0.125rem !important;
}

.form-text p {
    font-size: 14px;
}

.payment-item {
    background: #fafafa;
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    cursor: pointer;
    margin-bottom: 16px;
    padding: 10px;
    position: relative;
}

.payment-item.selected {
    background-color: #f6fffb;
    border: 1px solid var(--primary-color);
}

.payment-item .media img {
    /*border-radius: 4px;*/
    height: 28px;
}

.payment-item .media-body img {
    height: 14px;
}

.payment-item .media-body h5 {
    color: #222;
    font-size: 14px;
    font-weight: 700;
    margin: 0 0 4px;
}

.payment-item .media-body p {
    color: #666;
    font-size: 13px;
    margin: 0;
    padding: 0;
}

.payment-item .trailing-wrap {
    position: absolute;
    right: 10px;
    top: 10px;
}

.radio {
    display: inline-block;
    font-size: 16px;
    line-height: 24px;
    margin: 0 0 10px;
    position: relative;
}

.radio__input {
    height: 20px;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 4px;
    width: 36px;
    z-index: 0;
}

.radio__label {
    cursor: pointer;
    display: block;
    padding: 0 0 0 24px;
}

.radio__label:before {
    background-color: transparent;
    border: 2px solid rgba(0, 0, 0, 0.54);
    border-radius: 14px;
    content: "";
    height: 16px;
    left: 0;
    position: absolute;
    top: 4px;
    transition: border-color 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    width: 16px;
    z-index: 1;
}

.radio__label:after {
    background-color: var(--primary-color);
    border-radius: 50%;
    content: "";
    height: 8px;
    left: 4px;
    position: absolute;
    top: 8px;
    transform: scale(0, 0);
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    width: 8px;
    z-index: 2;
}

.radio__input:checked+.radio__label:before {
    border-color: var(--primary-color);
}

.radio__input:checked+.radio__label:after {
    transform: scale(1, 1);
}

.checkbox {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 2px;
    box-shadow: none;
    cursor: pointer;
    display: flex;
    height: 28px;
    justify-content: center;
    margin-top: -5px;
    position: absolute;
    width: 28px;
}

.destination-block .card-body {
    background: #f6f6f6;
    border-bottom-left-radius: 16px;
    border-bottom-right-radius: 16px;
}

.destination-block .card-body .card-title {
    color: #222;
}

.bg-success {
    background: var(--primary-color) !important;
}

.figure-caption {
    font-size: 14px;
}

.rounded {
    border-radius: 12px !important;
}

.__loading {
    background: var(--primary-color);
    border-radius: 50px;
    box-shadow: 0 4px 12px rgba(8, 27, 55, 0.2);
    color: white;
    font-weight: bold;
    left: 50%;
    letter-spacing: 1.2px;
    margin-left: -50px;
    min-width: min-content;
    padding: 5px;
    position: fixed;
    text-transform: capitalize;
    top: 50%;
    z-index: 9999;
}

.__loading2 {
    align-items: center;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    bottom: 0;
    cursor: wait;
    display: flex;
    justify-content: center;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}

.no-data {
    height: 20vh;
    justify-content: center;
}

.input-group-text {
    border: none;
    background-color: transparent;
    border-radius: 22px;
}

.trip-summary {
    background-color: transparent;
}

.trip-summary .table {
    font-size: 90%;
}

.list-group-flush {
    border: 2px dashed #ddd;
    border-radius: 4px;
}

.list-group-flush>.list-group-item {
    border-style: dashed;
    padding: 8px;
}

.return-trip-icon {
    align-items: center;
    background: #0dcaf0;
    border-radius: 100%;
    color: white;
    display: flex;
    font-size: 16px;
    height: 40px;
    justify-content: center;
    width: 40px;
}

.bg-dow {
    /*background-color: #729c44;*/
    background-image: linear-gradient(#729c44, #2aaaaa);
}

.bottom-info {
    background-color: #0dcaf0;
    width: 100%;
}

.bottom-info p {
    margin: 0;
    padding: 4px 0;
}

.skeleton {
    animation: skeleton-loading 0.36s linear infinite alternate;
    opacity: 0.7;
}

.skeleton-text {
    border-radius: 0.125rem;
    height: 0.5rem;
    margin-bottom: 0.25rem;
    width: 100%;
}

.skeleton-text:last-child {
    margin-bottom: 0;
    width: 80%;
}

.qrcode {
    align-items: center;
    background: #fff;
    justify-content: center;
    margin: 0 auto;
    max-width: 300px;
    width: auto;
}

.loader {
    -webkit-animation: spin 0.52s linear infinite;
    animation: spin 0.52s linear infinite;
    border: 4px solid #fff3cd;
    border-radius: 50%;
    border-top: 4px solid #ff6e26;
    height: 50px;
    width: 50px;
}

.loader-mini {
    -webkit-animation: spin 0.52s linear infinite;
    animation: spin 0.52s linear infinite;
    border: 2px solid #fff3cd;
    border-radius: 50%;
    border-top: 2px solid #ff6e26;
    height: 16px;
    left: 50%;
    margin-top: -5px;
    width: 16px;
}

header div.top {
    background-color: var(--primary-dark-color);
    color: white;
}

@keyframes spin {
    0% {
        transform: rotate(0);
    }

    100% {
        transform: rotate(360deg);
    }
}

.loading {
    left: 50%;
    margin-left: -30px;
    margin-top: -30px;
    position: absolute;
    top: 50%;
}

@keyframes skeleton-loading {
    0% {
        background-color: hsl(200, 20%, 70%);
    }

    100% {
        background-color: hsl(200, 20%, 95%);
    }
}

.pax-form {
    background: white;
    padding: 16px;
    border: 1px solid #f0f0f0;
    border-radius: 12px;
    /*box-shadow: 0 0 8px 2px rgba(59, 59, 59, 0.05);*/
}

.pax-form .form-control {
    font-size: 1.1rem;
    padding: 8px 16px;
    border-radius: 22px;
    border: none;
    background-color: #f0f0f0;
}

.input-group> :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    border-left: 0;
}

.btn.disabled,
.btn:disabled,
fieldset:disabled .btn {
    cursor: not-allowed;
    pointer-events: inherit;
}

.btn:disabled.btn-success {
    opacity: 1;
    font-weight: bold;
    background: #979797;
    border: none;
}

.accepted-payment .sub-title {
    align-items: center;
    color: #555;
    display: flow;
    font-size: 18px;
    margin-bottom: 16px;
}

.text-end {
    text-align: right !important;
}

ul.list {
    padding-left: 15px;
}

.faq-block .card-body pre {
    font-size: 100%;
    overflow: hidden;
}

.faq-block .prefix .card {
    background-color: transparent;
    border-radius: 100%;
}

.faq-block .prefix .card-body {
    align-items: center;
    background: #f7f7f7;
    border-radius: 0.5rem;
    display: flex;
    font-size: 16px;
    height: 35px;
    justify-content: center;
    padding: 0;
    width: 35px;
}

.faq-block .message {
    border-radius: 32px;
}

.faq-block .message._q {
    background: #f5f5f5;
    border-top-left-radius: 0;
    cursor: pointer;
}

.faq-block .message a {
    color: white;
    text-decoration: none;
}

.faq-block .message._a {
    border-bottom-right-radius: 0;
}

.faq-block .message._q,
.faq-block .message._a {
    max-width: 75%;
}

.print-peg {
    background: rgb(255, 248, 246);
    border: 2px dashed #909090;
    padding: 8px;
}

.modal-footer,
.modal-header {
    padding: 8px 16px;
}

.modal-title {
    font-size: 1.25rem;
    font-weight: 400;
}

.modal-footer i.bi {
    font-size: 12px;
}

.modal-dialog-scrollable .modal-content {
    transition: all 0.2s ease;
}

.card-header {
    background-color: #ebf0f4;
    background-image: -moz-linear-gradient(top, #f6f8fa, #ebf0f4 90%);
    background-image: linear-gradient(180deg, #f6f8fa, #ebf0f4 90%);
    border-color: #ccd1d5;
    border-color: rgba(31, 35, 40, 0.15);
    padding: 12px 16px;
}

.fill-mode-2 {
    fill: #afafaf;
}

.g-4,
.gy-4 {
    --bs-gutter-y: 1.5rem;
}

.g-4,
.gx-4 {
    --bs-gutter-x: 1.5rem;
}

.me-n4 {
    margin-right: -1.6rem !important;
}

.mt-n3 {
    margin-top: -1rem !important;
}

.ms-n9 {
    margin-left: -11rem !important;
}

.end-0 {
    right: 0 !important;
}

.mt-n8 {
    margin-top: -8rem !important;
}

.fill-mode {
    fill: #fff !important;
}

.end-0 {
    right: 0 !important;
}

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

footer {
    color: #c4c5c7;
}

img {
    height: auto;
    max-width: 100%;
}

footer h6 {
    color: white;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.25;
    margin-top: 0;
}

.nav-link:hover,
.nav-link:focus {
    color: white;
    opacity: 0.8;
}

footer .nav-item .nav-link {
    color: #c4c5c7;
    font-size: 14px;
    padding: 2px 0;
}

#CDSWIDEXC {
    border-radius: 4px;
    font-family: "OpenSans", "Krasar", "KantumruyPro", Roboto, Arial, sans-serif;
    font-size: 14px;
    margin: 0 !important;
    width: inherit;
}

.text-body {
    color: rgb(222 226 230) !important;
}

.text-success {
    color: var(--primary-color) !important;
}

.btn-success {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

.badge.badge-outline-success {
    background: rgba(50, 156, 5, .1);
    color: var(--primary-color);
    border-color: var(--primary-dark-color);
}

.btn-icon {
    align-items: center;
    -webkit-box-align: center;
    -webkit-box-pack: center;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -ms-flex-align: center;
    -ms-flex-negative: 0;
    -ms-flex-pack: center;
    flex-shrink: 0;
    height: 1.8rem;
    justify-content: center;
    padding: 0;
    position: relative;
    width: 1.8rem;
}

.btn-icon.btn-xs {
    background: #515255;
    border-color: #515255;
    color: white;
    font-size: 0.8rem;
    height: 2rem;
    width: 2rem;
}

.btn-light {
    background: #3c3e41;
    border-color: #3c3e41;
    color: #fff;
}

.btn-light.active,
.btn-light:active,
.btn-light:focus,
.btn-light:hover {
    background: #3c3e41;
    border-color: #3c3e41;
    color: #fff;
}

[data-bs-theme="dark"] .dropdown-menu {
    background-color: #333;
    border-radius: 0.5rem;
    padding: 8px;
}

[data-bs-theme="dark"] .dropdown-menu .dropdown-item {
    border-radius: 8px;
    color: #c5c6cc;
}

[data-bs-theme="dark"] .dropdown-item:focus,
[data-bs-theme="dark"] .dropdown-item:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--primary-color);
}

.bg-map {
    background-image: url(../img/map.svg);
    background-position: center;
    background-size: cover;
}

.top-head {
    background: #fff;
    color: #333;
}

.discount-percentage {
    position: absolute;
    top: 6px;
    left: -28px;
    width: 100px;
    height: 27px;
    background-color: #e74c3c;
    color: #fff;
    font-weight: bold;
    font-size: 0.9rem;
    text-align: center;
    line-height: 30px;
    transform: rotate(-46deg);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    border-radius: 4px;
}

.seat-badge {
    background-color: #eef7e8;
    /* light green */
    color: #3a7d2a;
    /* green text */
    font-weight: 500;
    font-size: 0.85rem;
}

.button-ticket button {
    background-color: #e5e5e5;
    color: #0a2040;
    border-radius: 6px;
    border: 1px solid rgb(180 182 185 / 41%);
    padding: 4px 8px;
    transition: all 0.25s ease;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.button-ticket button:hover {
    background-color: #c6c6c6;
    border-color: rgba(127, 122, 129, 0.42);
    box-shadow: 0 4px 10px rgb(180 182 185 / 41%);
}

.popup {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(36, 36, 78, 0.5);
    backdrop-filter: blur(3px);
    transition: opacity 0.3s ease;
}

.popup-content {
    position: relative;
    width: 90%;
    max-width: 65%;
    animation: scaleIn 0.3s ease-out;
}

.popup-content img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 12px;
}

.close-btn {
    position: absolute;
    top: -15px;
    right: -15px;
    background: #ff4757;
    color: #fff;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    cursor: pointer;
    font-weight: bold;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

@keyframes scaleIn {
    from { transform: scale(0.9); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

div:where(.swal2-container).swal2-center>.swal2-popup {
    border-radius: 16px;
}
body.swal2-shown > [aria-hidden='true'] {
    transition: 0.1s filter;
    filter: blur(3px);
}

.avatar-img {
    width: 40px !important;
    height: 40px !important;
    object-fit: cover;
    border: 1px solid #dee2e6;
}

/* MODAL ENTER */
.modal.fade .modal-dialog {
    transform: translateY(80px) scale(0.95);
    opacity: 0;
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.35s ease, filter 0.35s ease;
}

.modal.fade.show .modal-dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.modal.fade:not(.show) .modal-dialog {
    transform: translateY(40px) scale(0.2);
    opacity: 0;
}
.modal-backdrop.show {
    opacity: 1;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    background: rgba(36, 36, 78, 0.5);
}

.table-payment thead td{
    background-color: #d8e5de !important;
}

.login-form .form-control {
    font-size: 1.1rem;
    padding: 8px 16px;
    border-radius: 22px;
    border: none;
    background-color: #f0f0f0;
}

.login-form .btn {
    font-size: 1.1rem;
    padding: 8px 16px;
    border-radius: 22px;
    border: none;
}

.login-form .btn-sm {
    font-size: 0.8rem;
    padding: 4px 8px;
    border-radius: 22px;
    border: none;
}

.btn-login-grey,
.btn-login-primary {
    transition: all 0.2s ease;
    border: none;
}

.btn-login-grey {
    background-color: #f0f0f0;
    color: #333;
}

.btn-login-grey:hover {
    background-color: #e2e2e2;
    transform: translateY(-1px);
}

.btn-login-grey:active {
    transform: scale(0.98);
}

.btn-login-primary {
    color: #ffffff;
    background-color: var(--primary-color);
}

.btn-login-primary:hover {
    color: #ffffff;
    background-color: color-mix(in srgb, var(--primary-color) 85%, black);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}

.btn-login-primary:active {
    transform: scale(0.98);
}

.btn-login-grey:disabled,
.btn-login-grey.disabled,
.btn-login-primary:disabled,
.btn-login-primary.disabled {
    background-color: #dcdcdc !important;
    color: #999 !important;
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
    opacity: 0.7;
}

.spin {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@media (min-width: 1010px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1120px;
    }
}

@media only screen and (max-width: 760px) {
    .install-wrap {
        border-radius: 1rem;
    }

    .install-wrap .image {
        max-height: 300px;
    }

    .swiper-text {
        margin-right: 43px !important;
        width: 116% !important;
    }

    .swiper-slide img {
        margin-left: 24px;
        margin-right: 23px;
    }

    #navbarCollapse {
        overflow-x: auto;
    }

    .navbar-nav {
        display: block;
        overflow: auto;
        white-space: nowrap;
        width: 100%;
    }

    .drop-lang .btn {
        background: transparent;
        border: 0;
        box-shadow: none;
    }

    .__loading {
        left: 58%;
    }

    .navbar .collapse:not(.show) {
        display: block;
    }

    .print-close {
        align-items: center !important;
        margin-right: 14px;
    }

    .footer {
        position: relative !important;
    }

    .navbar-nav [data-aos] {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    .table-print {
        display: grid;
        font-size: 11px;
    }

    .table-payment {
        font-size: 11px;
    }

    .table-payment thead td{
        background-color: #d8e5de !important;
    }

    .ticket-success .row>* {
        width: 50%;
    }

    .ticket-info-block {
        background-color: transparent;
        padding: 0;
    }

    .ticket-info-block .card {
        background-color: transparent;
        border-radius: 0;
        padding: 0;
    }

    .ticket-info-block .card-body .card-body {
        padding: 0;
    }

    .ticket-info-block .table th,
    .ticket-info-block .table td {
        white-space: nowrap;
    }

    .ticket-info-block .button-action {
        background: var(--accent-color);
        border-top: 1px solid #77730b;
        bottom: 0;
        left: 0;
        padding: 8px;
        position: fixed;
        right: 0;
        z-index: 9999;
    }

    .ticket-info-block .button-action div.p-2 {
        width: 50%;
    }

    .ticket-info-block .button-action div.p-2>a {
        width: 100%;
    }

    .main .lead {
        background: #f8f9fa;
    }

    .main .lead h1 {
        color: #000 !important;
    }

    .main .lead h3.sub-head-title {
        border-left: 0;
        border-left: 0;
        font-size: 18px;
        line-height: 1;
        padding-left: 0;
    }

    .bottom-info {
        font-size: 10px;
    }

    .title-responsive {
        color: #868686;
        font-size: 13px;
        letter-spacing: -0.6px;
        margin-bottom: 8px;
        text-transform: uppercase;
    }

    .main .lead .form-floating {
        filter: drop-shadow(3px 3px 10px rgba(0, 0, 0, 0.1));
    }

    .navbar-nav {
        padding: 0;
    }

    .offcanvas {
        width: 300px !important;
        color: #1d1d1d;
        background: #fff;
    }

    .offcanvas-header {
        border-bottom: solid 1px #dee2e6;
    }

    .offcanvas-body {
        padding: 0;
    }

    .offcanvas .nav-link {
        color: #1d1d1d;
        font-size: 18px;
        font-weight: 500;
        padding: 18px;
        border-bottom: solid 1px #dee2e6;
        transition: color 0.2s ease;
    }

    .offcanvas .nav-item .dropdown-item {
        padding: 10px 20px !important;
    }

    .offcanvas .nav-link.active {
        font-weight: 600;
        color: var(--primary-color);
    }

    .offcanvas .nav-link.active::after {
        position: absolute;
        content: "";
        left: 0;
        right: 0;
        height: 100%;
        background: var(--primary-color);
        z-index: 100;
        border-radius: 4px;
        width: 3px;
        bottom: 0;
    }

    [data-bs-toggle="collapse"] i {
        transition: transform 0.25s ease;
    }

    [data-bs-toggle="collapse"].collapsed i {
        transform: rotate(0deg);
    }

    [data-bs-toggle="collapse"]:not(.collapsed) i {
        transform: rotate(180deg);
    }

    .col-auto {
        flex: 1 0 auto;
        width: auto;
    }

    .seat {
        width: 50px;
    }

    .bus-type-image {
        margin-bottom: 16px;
    }

    .branch-map {
        margin-top: 12px;
    }

    #schedule-collapse {
        padding: 8px !important;
    }

    .trip-summary-responsive {
        margin-top: 16px;
    }

    .schedule-row {
        flex-wrap: wrap;
    }

    .schedule-row .price-action {
        width: 100%;
        text-align: center;
        /* optional */
    }

    .price-action {
        display: flex;
        align-items: center;
        justify-content: space-between;
        /* price left, button right */
        gap: 1rem;
    }

    .bg-selected-set {
        background: none;
    }

    .selected-set {
        background-color: #eaeaea;
        border-radius: 12px;
        text-align: center;
        padding: 10px;
    }

    .selected-set .bus-title {
        font-size: 18px;
        font-weight: 600;
        margin-bottom: 6px;
        color: #000;
    }

    .selected-sets {
        text-align: -webkit-center;
    }

    .seat {
        height: 42px;
        width: 42px;
        zoom: 1.2;
    }

    .legend-wrap {
        width: 2px;
        height: 22px;
        flex-shrink: 0;
        background: linear-gradient(to bottom, transparent, #a4a4a4, transparent);
    }

    .legend-box {
        position: relative;
        padding-top: 12px;
    }

    .legend-box::before {
        content: '';
        position: absolute;
        top: 6px;
        left: 50%;
        transform: translateX(-50%);
        height: 2px;
        width: 100%;
        background: linear-gradient(to right, transparent, #a4a4a4, transparent);
    }

    .seat.available[data-night="1"],
    .seat.booked[data-night="1"],
    .seat.busy[data-night="1"],
    .seat.busy[data-night="1"],
    .seat.selected[data-night="1"] {
        height: 54px;
        width: 54px;
    }

    .popup-content {
        position: relative;
        width: 100%;
        max-width: 90%;
        animation: scaleIn 0.3s ease-out;
    }

    .popup-content img {
        display: block;
        width: 100%;
        height: auto;
        border-radius: 12px;
        /*box-shadow: 0 10px 30px rgba(0,0,0,0.5);*/
    }

    .close-btn {
        position: absolute;
        top: -12px;
        right: -12px;
        background: #ff4757;
        color: #fff;
        width: 25px;
        height: 25px;
        line-height: 25px;
    }

    @keyframes scaleIn {
        from { transform: scale(0.9); opacity: 0; }
        to { transform: scale(1); opacity: 1; }
    }
}
.text-overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
}

.legend-box-set {
    position: relative;
    padding-top: 12px;
}

.legend-box-set::before {
    content: '';
    position: absolute;
    top: 6px;
    left: 50%;
    transform: translateX(-50%);
    height: 2px;
    width: 100%;
    background: linear-gradient(to right, transparent, #c1c1c1, transparent);
}

.seat-left {
    font-size: 13px;
    padding: 5px;
}

.star-rating {
    color: var(--primary-color);
    font-size: 10px;
}

.review-card {
    margin-bottom: 0.5rem;
}

.review-card.card,
.review-card .card-body {
    background: transparent;
}

.progress {
    height: 10px;
}

/* width */
.modal-body::-webkit-scrollbar {
    width: 8px;
}

/* Track */
.modal-body::-webkit-scrollbar-track {
    background: #f1f1f1;
}

/* Handle */
.modal-body::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 18px;
}

/* Handle on hover */
.modal-body::-webkit-scrollbar-thumb:hover {
    background: #555;
}

.required-star {
    border: 1px solid red;
    border-radius: 4px;
    padding: 4px;
}

.required-star a i {
    color: red;
}

#qrcode {
    background: white;
    border-radius: 4px;
    margin: 0 auto;
    max-width: max-content;
}

.accordion-item:not(:first-of-type),
.accordion-item {
    border: 1px solid #dbdbdb;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 14px;
}

.cdsROW.narrow {
    width: 100% !important;
    text-align: center;
    padding: 7px 12px 1px;
    border-radius: 12px;
}

.accordion-item .collapse.show .accordion-body {
    background-color: #fff;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

.accordion-button {
    border: 0;
    border-radius: 8px;
}

.accordion-button:not(.collapsed) {
    background-color: #f1f1f1;
    font-size: 16px;
    color: #000;
}

.accordion-button:not(.collapsed)::after {
    filter: invert(0%) sepia(100%) saturate(0%) hue-rotate(0deg) brightness(0%) contrast(100%);
}

.emoji {
    font-family: "Noto Color Emoji", "Segoe UI Emoji", "Apple Color Emoji",
        "Twemoji", sans-serif;
}

.bus-card {
    border-radius: 10px;
    background: #fff;
}

.bus-image {
    width: 100%;
    max-width: 200px;
    filter: drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.3));
}

.bus-title {
    font-size: 18px;
    font-weight: 300;
    color: #000;
}

.time {
    font-size: 1.5rem;
    font-weight: bold;
    color: #333;
}

.location-info a {
    color: #666;
    text-decoration: none;
    font-size: 14px;
}

.location-info a:hover {
    color: var(--info-color);
}

.btn-warning {
    font-weight: bold;
    border-radius: 5px;
}

.dropdown-menu.show {
    padding: 8px;
    border-radius: 0.5rem;
}

.dropdown-menu .dropdown-item {
    border-radius: 0.5rem;
}

.dropdown-item.active,
.dropdown-item:active {
    background: var(--primary-color);
    color: white;
}

.install-wrap {
    display: flex;
    flex-direction: column;
    gap: 3rem;
    padding: 1.8rem;
    border-radius: 38px;
    position: relative;
    background-image: url(../img/install-wrap.jpg);
    background-size: cover;
    background-color: rgb(100 147 7);
    background-blend-mode: overlay;
}

.app-card {
    box-shadow: 0 0 60px rgb(88, 204, 42);
}

.install-wrap .image {
    position: absolute;
    right: 0;
    bottom: 0;
    filter: drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.3));
}

.datepicker td,
.datepicker th {
    font-size: 18px;
    width: 50px;
    height: 50px;
    border-radius: 50px;
}

.datepicker th.datepicker-switch:hover,
.datepicker .next:hover,
.datepicker .prev:hover,
.datepicker tfoot tr th:hover {
    border-radius: 25px;
}

.datepicker-dropdown.datepicker-orient-left:before {
    left: 16px;
}

.datepicker table tr td.active.active,
.datepicker table tr td.active.disabled,
.datepicker table tr td.active.disabled.active,
.datepicker table tr td.active.disabled.disabled,
.datepicker table tr td.active.disabled:active,
.datepicker table tr td.active.disabled:hover,
.datepicker table tr td.active.disabled:hover.active,
.datepicker table tr td.active.disabled:hover.disabled,
.datepicker table tr td.active.disabled:hover:active,
.datepicker table tr td.active.disabled:hover:hover,
.datepicker table tr td.active.disabled:hover[disabled],
.datepicker table tr td.active.disabled[disabled],
.datepicker table tr td.active:active,
.datepicker table tr td.active:hover,
.datepicker table tr td.active:hover.active,
.datepicker table tr td.active:hover.disabled,
.datepicker table tr td.active:hover:active,
.datepicker table tr td.active:hover:hover,
.datepicker table tr td.active:hover[disabled],
.datepicker table tr td.active[disabled] {
    background-image: none;
    background-color: var(--primary-color);
    color: white;
}