:root {

    --white: #ffffff;
    --off-white: #bec0c2;
    --black: #0c0c0e;
    --light-black: #101010;
    --light-black-opacity: #2626269e;
    --light-gray: #f5f5f5;
    --dark-gray: #9b9b9b;
    --blue: #1d136a;
    --green: #8AE842;

}

.str-padding {
    padding-left: 30px;
    padding-right: 30px;
}

h2 {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 40px;
    line-height: 50px;
    letter-spacing: 0%;
    color: var(--blue);

}

h3 {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 30px;
    line-height: 100%;
    letter-spacing: 0%;
    color: var(--blue);
}

.section-pedding {
    padding: 50px 0;
}

header {
    border-bottom: 2px solid var(--blue);
    padding: 20px 0;
}

.main-footer-logo {
    align-items: flex-end;
    display: flex;
    justify-content: end;
}

.main-footer-logo img {
    width: auto;
    height: 120px;
    float: right;
    max-width: 100%;
}

.social-media p {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: var(--blue);
}

.social-media ul li {
    display: inline-block;
    padding-right: 15px;
}

footer {
    border-top: 2px solid var(--blue);
    padding: 30px 0;
}

.footer-links {
    display: flex;
    gap: 50px;
}

.footer-links ul {
    padding: 0;
}

.footer-links ul li {
    list-style: none;
}

.footer-links a {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: var(--blue);
    text-decoration: none;
}

.partner-logos {
    display: flex;
    gap: 30px;
    align-items: center;
}

.short-links,
.partner-logos {
    min-width: 250px;
}

.short-links ul li {
    margin: 8px 0;
}

.copy-right-text p {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: var(--blue);
}

.copy-right-text p a {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: var(--blue);
    text-decoration: none;
}

.copy-right-block {
    display: flex;
    gap: 50px;
    margin-top: 10px;
}

.copy-right-text p {
    margin: 0;
}

.book-card-content {
    padding: 15px;
}

.book-card {
    margin: 15px 0;
}

.book-card .date-and-title {
    display: flex;
    gap: 25px;
    margin-bottom: 20px;
}

.book-card:hover {
    background-color: var(--green);
}

.book-card:hover .book-slot-btn {
    background-color: var(--blue);
    color: var(--white);
}

.cta-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 2px solid var(--blue);
    padding-top: 20px;
    margin-top: 20px;
}

.book-card .date-and-title p,
.cta-card p,
.book-card-details p {
    margin-bottom: 0;
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    color: var(--blue);

}

p.small-text {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 15px !important;
    line-height: 19px;

}

.book-slot-btn {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    text-align: center;
    border: 2px solid var(--blue);
    text-decoration: none;
    color: var(--blue);
    padding: 10px 16px 10px 16px;
    border-radius: 100px;
    display: inline-block;
}

.book-slot-btn:hover {
    color: var(--blue);
}

.dot-circle {
    background-color: var(--blue);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: block;
}

.doted-text {
    display: flex;
    align-items: center;
    gap: 5px;
}

.thankyou-msg-box p, .thankyou-msg-box ul li {
    font-family: 'ABC Diatype';
    font-weight: 400;
    font-size: 20px;
    line-height: 25px;
    letter-spacing: 0%;
    color: var(--blue);
    margin-bottom: 0;
}

.thankyou-msg-box div {
    margin-bottom: 20px;
}

.order-summery-box {
    border: 2px solid var(--blue);
    padding: 20px;
}

.order-summery-box h3 {
    border-bottom: 1px solid #D6D6D6;
    padding-bottom: 15px;
    margin-bottom: 15px;
}

.order-summery-box .sub-tag-line {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 15px;
    line-height: 19px;
    letter-spacing: 0%;
    color: var(--blue);
    opacity: 0.6;
    margin-bottom: 0;
}

.order-summery-box strong {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    letter-spacing: 0%;
    vertical-align: middle;
    color: var(--blue);
}

.order-summery-box p {
    margin-bottom: 0;
}

.order-summery-box .italic-font {
    font-family: 'ABC Diatype';
    font-weight: 500;
    font-style: Italic;
    font-size: 15px;
    line-height: 19px;
    letter-spacing: 0%;
    color: var(--blue);
}

.adult-box {
    margin-top: 15px;
}

.adult-box p {
    display: flex;
    /* gap: 5px; */
    align-items: center;
}

.adult-box p span img {
    margin-bottom: 2px;
}

.adult-box p span {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 15px;
    line-height: 19px;
    letter-spacing: 0%;
    vertical-align: middle;
    color: var(--blue);
}

.price-box {
    display: flex;
    justify-content: space-between;
}

.price-box span {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 15px;
    line-height: 19px;
    letter-spacing: 0%;
    color: var(--blue)
}

.main-price {
    display: flex;
    align-items: center;
    /* gap: 5px; */
}

.main-price img {
    margin-bottom: 2px;
}

.main-price span {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 20px;
    line-height: 25px;
    letter-spacing: 0%;
    vertical-align: middle;
    color: var(--blue);
}

.main-price-box {
    border-top: 1px solid #D6D6D6;
    border-bottom: 1px solid #D6D6D6;
    margin-top: 15px;
    padding-top: 15px;
    margin-bottom: 15px;
    padding-bottom: 15px;
}

.vat-sub-total {
    margin: 15px 0;
}

.price-total {
    border-top: 1px solid #D6D6D6;
    padding-top: 15px;
    margin-top: 15px;
}

.price-total span.full-total {
    display: flex;
    align-items: center;
}

.price-total span.full-total span {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 30px;
    line-height: 100%;
    letter-spacing: 0%;
    vertical-align: middle;
    color: var(--blue);
}

.price-total.select-slot-modal .select-selected {
    border: 0;
    padding: 0;
}

.price-total.select-slot-modal .form-group {
    margin-bottom: 0;
}

.price-total.select-slot-modal .select-selected::after {
    background-image: url(../images/c-arrow.png);
}

.price-total.select-slot-modal .select-items.show {
    display: flex;
    min-width: 100px;
    right: 0;
    left: auto;
    top: 25px;
    overflow: hidden;
}

.custom-crncy-select {
    position: relative;
}

.custom-crncy-select .select-selected {
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 10px 15px;
    cursor: pointer;
    border-radius: 6px;
    position: relative;
}

.custom-crncy-select .select-selected::after {
    content: "▼";
    right: 12px;
    top: 10px;
    font-size: 12px;
    color: #333;
}

.custom-crncy-select .select-items {
    position: absolute;
    top: 105%;
    left: 0;
    right: 0;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 6px;
    z-index: 99;
    display: none;
}

.custom-crncy-select .select-items div {
    padding: 10px 15px;
    cursor: pointer;
}

.custom-crncy-select .select-items div:hover {
    background-color: #f1f1f1;
}

.custom-crncy-select .select-items.show {
    display: block;
}

/* modal csss  */
.select-slot-modal .booking-box {
    border-top: 1px solid var(--blue);
    padding-top: 12px;
    width: 100%;
    color: var(--blue);
    position: relative;
}

.select-slot-modal .legend {
    display: flex;
    margin-bottom: 15px;
    gap: 20px;
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 14px;
    line-height: 19px;
    letter-spacing: 0%;

}

.select-slot-modal .legend .circle {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 4px;
}

.select-slot-modal .available {
    border: 1px solid var(--blue);
    background-color: transparent;
}

.select-slot-modal .booked {
    background-color: #ccc;
}

.select-slot-modal .selected {
    background-color: var(--blue);
}

.select-slot-modal .form-group {
    display: flex;
    flex-direction: column;
    margin-bottom: 15px;
    position: relative;
}

.select-slot-modal label {
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 16px;
    line-height: 25px;
    letter-spacing: 0%;
    margin-bottom: 6px;

}

/* Custom Dropdown */
.select-slot-modal .custom-select {
    position: relative;
    user-select: none;
}

.select-slot-modal .select-selected {
    border: 1.5px solid var(--blue);
    border-radius: 20px;
    padding: 10px 12px;
    color: var(--blue);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: all 0.2s ease;
    font-family: 'ABC Diatype';
    font-weight: 400;
    font-size: 16px;
    line-height: 25px;
    letter-spacing: 0%;

}

.select-slot-modal .select-selected::after {
    content: "";
    width: 20px;
    height: 20px;
    transition: transform 0.2s ease;
    background-image: url('../images/downArrow.png');
    background-size: 20px;
}

.select-slot-modal .select-selected.active::after {
    transform: rotate(180deg);
}

.select-slot-modal .select-items {
    position: absolute;
    background: #fff;
    border: 1.5px solid var(--blue);
    border-radius: 15px;
    top: 45px;
    left: 0;
    right: 0;
    z-index: 99;
    display: none;
    flex-direction: column;
    box-shadow: 0 4px 10px var(--blue);
}

.select-slot-modal .select-items div {
    padding: 10px 12px;
    cursor: pointer;
    border-bottom: 1px solid #eee;
    transition: background 0.2s;
}

.select-slot-modal .select-items div:last-child {
    border-bottom: none;
}

.select-slot-modal .select-items div:first-child:hover {
    border-radius: 15px 15px 0 0;
}

.select-slot-modal .select-items div:last-child:hover {
    border-radius: 0 0 15px 15px;
}

.select-slot-modal .select-items div:hover {
    background-color: #f2f0ff;
}

.select-slot-modal .select-items.show {
    display: flex;
}

.select-slot-modal input {
    border: 1.5px solid var(--blue);
    border-radius: 20px;
    padding: 10px 12px;
    color: var(--blue);
    font-family: 'ABC Diatype';
    font-weight: 400;
    font-size: 16px;
    line-height: 25px;
    letter-spacing: 0%;
}

.select-slot-modal input::placeholder {
    color: #a8a6c0;
}

.select-slot-modal .pay-btn {
    width: 100%;
    background-color: var(--blue);
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 12px 0;
    cursor: pointer;
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 16px;
    line-height: 25px;
    letter-spacing: 0%;
    text-align: center;

}

.select-slot-modal .pay-btn:hover {
    opacity: 0.9;
}

.select-slot-modal .modal-header {
    border: 0;
}

.select-slot-modal .modal-body {
    padding: 25px;
}

input:focus-visible,
button:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid var(--blue);
    /* your custom color */
    outline-offset: 2px;
    /* slight offset for better visibility */
    box-shadow: 0 0 0 3px rgba(29, 19, 106, 0.3);
    /* optional glow */
}

.counter {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: 'ABC Diatype';
}

.counter button {
    width: 30px;
    height: 30px;
    font-size: 20px;
    cursor: pointer;
    border: none;
    background-color: var(--blue);
    color: white;
    border-radius: 5px;
    transition: background-color 0.2s;
}

.counter button:hover {
    background-color: #3d2fa1;
}

.counter span {
    min-width: 40px;
    text-align: center;
    font-size: 18px;
    border: 1px solid var(--blue);
    height: 30px;
    line-height: 30px;
    padding: 0 5px;
}

.q-block {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: 'ABC Diatype';
    font-weight: 700;
    font-size: 16px;
    line-height: 25px;
    margin: 15px 0;
    border: 1px solid;
    padding: 10px;
    border-radius: 16px;
}

/* modal csss  */

@media screen and (max-width: 768px) {
    h2 {
        font-size: 34px;
        line-height: 40px;
    }

    .book-card .date-and-title p,
    .cta-card p,
    .book-card-details p {
        font-size: 14px;
        line-height: 18px;
    }

    .footer-links {
        flex-direction: column;
        gap: 0;
    }

    .copy-right-block {
        gap: 10px;
        margin-top: 10px;
        flex-direction: column;
    }

    .main-footer-logo img {
        float: left;
        margin-top: 0px;
        height: 180px;
    }

    p.small-text {
        font-size: 11px !important;
    }

    .book-slot-btn {
        font-size: 14px;
    }
}