:root {
    --tj-ff-body: "Aktiv Grotesk", sans-serif;
    --tj-ff-heading: "Aktiv Grotesk", sans-serif;
}

html[dir="ltr"],
html[dir="ltr"] body {
    direction: ltr;
    font-family: "Aktiv Grotesk", sans-serif;
}

html[dir="ltr"] #tj-back-to-top {
    inset-inline-end: auto;
    right: auto;
    left: 40px;
}

@media only screen and (min-width: 992px) and (max-width: 1199px) {
    html[dir="left"] #tj-back-to-top {
        left: 30px;
        right: auto;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px),
only screen and (min-width: 576px) and (max-width: 767px),
(max-width: 575px) {
    html[dir="rtl"] #tj-back-to-top {
        left: 20px;
        right: auto;
    }
}



@media (max-width: 767px) {}

@media (max-width: 375px) {}



.sos-about-grid {

    direction: ltr;
}

.sos-about-text {
    text-align: left;
    direction: ltr;
}


.sos-about-image img {
    display: block;
    width: 100%;
    height: auto;
}

.sos-about-callout {

    margin-right: 18px;
    margin-left: auto;

}

.newsletter-subscribe-form {
    position: relative;
}

.newsletter-submit-spinner {
    display: none;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: newsletter-spin 0.75s linear infinite;
}

.newsletter-subscribe-form.is-loading .newsletter-submit-icon {
    display: none;
}

.newsletter-subscribe-form.is-loading .newsletter-submit-spinner {
    display: inline-block;
}

.newsletter-subscribe-form button[disabled] {
    cursor: not-allowed;
    opacity: 0.9;
}

.newsletter-feedback {
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.6;
}

.newsletter-feedback.is-success {
    color: #d2ffdc;
}

.newsletter-feedback.is-error {
    color: #ffd2d2;
}

@keyframes newsletter-spin {
    to {
        transform: rotate(360deg);
    }
}


@media (max-width: 575px) {
    .sos-about-image {
        border-top-right-radius: 120px;
    }

    .sos-about-text p {
        font-size: 16px;
    }

    .sos-about-callout {
        border-bottom-left-radius: 15px;
        border-bottom-right-radius: 56px;
    }
}




@media (max-width: 767px) {
    .ramadan-feature-card {

        border-bottom-left-radius: 120px;
        border-bottom-right-radius: 20px;
    }


}


.contact-form .form-input .nice-select .list {
    height: 200px;
    overflow: scroll;
}

.nice-select.open .list {
    height: 300px;
    overflow: auto;
}

.form-check-input[type=checkbox] {
    border-radius: .25em;
    width: auto;
    min-height: auto;
    padding: 10px;
    margin: 0;
}

.form-check-input:checked {
    background-color: #22b7f2;
}

.package-recurring-check {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 40px 0 0
}

.package-recurring-check .form-check-label {
    margin: 0;
    font-weight: 500;
    color: #133b64;
}

/* Recurring payment toggle switch */
.pkg-toggle-switch {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 28px;
    flex-shrink: 0;
    margin: 0;
    cursor: pointer;
}

.pkg-toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.pkg-toggle-slider {
    position: absolute;
    inset: 0;
    background-color: #9e9e9e;
    border-radius: 28px;
    transition: background-color 0.25s ease;
}

.pkg-toggle-slider::before {
    content: '';
    position: absolute;
    width: 22px;
    height: 22px;
    left: 3px;
    top: 50%;
    transform: translateY(-50%);
    background-color: #fff;
    border-radius: 50%;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .2);
    transition: left 0.25s ease;
}

.pkg-toggle-switch input:checked+.pkg-toggle-slider {
    background-color: #22b7f2;
}

.pkg-toggle-switch input:checked+.pkg-toggle-slider::before {
    left: calc(100% - 25px);
}

.pkg-toggle-label {
    margin: 0;
    font-weight: 500;
    color: #133b64;
    cursor: pointer;
}

.package-recurring-day-select {
    font-size: 1rem;
    border-radius: 17px;
    line-height: 2;
}