﻿
.loadingOTTOverlay 
{
    display: grid;
    place-content: center;
    min-height: 50vh;
}


/*               */
/* INPUT STYLING */
/*               */

.inputBoxLogin {
    width: 100%;
    height: 46px;
    border: 1px solid;
    border-radius: 12px;
    border-color: #FFFFFF33;
    background-color: transparent;
    color: #FFFFFF;
    font-family: 'Space Grotesk';
    font-weight: 400;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0%;
    padding-left: 46px;
    padding-bottom:3px;
}

    .inputBoxLogin::placeholder {
        color: #FFFFFF4D;
        font-size: 16px;
    }

    .inputBoxLogin:hover {
        border-color: #B524FF;
    }

    .inputBoxLogin:focus {
        border-color: #B524FF;
        border: 1px solid;
    }

    .inputBoxLogin:focus-visible {
        border-color: #B524FF;
        border: 1px solid;
    }

    .inputBoxLogin:focus-within {
        border-color: #B524FF;
        border: 1px solid;
    }

input[type="password"]::-ms-reveal {
    display: none !important;
}

.inputLabelLogin {
    text-align: left;
    padding: 0px;
    margin-bottom: 4px;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 400;
    font-family: 'Open Sans';
    width: 100%;
}

.inputBoxGeneral {
    height: 40px;
    border: 1px solid;
    border-color: #DDDDDD;
    border-radius: 10px;
    background-color: white;
    color: black;
    outline: none;
    max-width: 100%;
    width: 100%;
    padding-left: 17px;
}

    .inputBoxGeneral::placeholder {
        color: rgba(214, 214, 214, 1);
        opacity: 1;
    }

    .inputBoxGeneral:hover {
        border: 2px solid #B524FF;
    }

    .inputBoxGeneral:focus {
        border-color: #B524FF;
    }

    .inputBoxGeneral:active {
        border-color: #B524FF;
    }

.inputLabelGeneral {
    font-family: 'Open Sans';
    left: 0px;
    text-align: left;
    padding: 0px;
    margin: 0px;
    color: #FFFFFF99;
    font-weight: 400;
    font-size: 14px;
    line-height: 100%;
    margin-bottom: -11px;
    width: 100%;
}

.inputError {
    height: 11px;
    color: #FF3232;
    font-size: 9px;
    text-align: start;
    z-index: 7;
    width: 100%;
    padding-right: 22px;
    padding-left: 22px;
}

.inputSuggest {
    height: 17px;
    color: #747474;
    font-size: 9px;
    text-align: start;
    z-index: 1;
    width: 100%;
}

.inputTip {
    height: 17px;
    color: #747474;
    font-size: 9px;
    text-align: start;
    z-index: 1;
    width: 100%;
    padding-right: 22px;
    background-color: #F5F0F7;
}

.inputSuccess {
    height: 17px;
    color: darkgreen;
    font-size: 9px;
    text-align: start;
}

.inputCheckbox {
    position: relative;
    display: inline-block;
    height: 17px;
    margin: 2px 4px 0px 0px;
}

.rememberMeCheckbox {
    position: relative;
    display: inline-block;
    height: 17px;
    margin: 0px;
    padding: 0px;
}

@media screen and (max-width: 390px) {
    .rememberMeCheckbox {
        left: 5px;
        top: 0px;
    }
}


@media screen and (min-width: 390px) {
    .rememberMeCheckbox {
        top: 2px;
    }
}

.rememberMeLabel {
    position: relative;
    width: 110px;
    display: inline-block;
    height: 17px;
    margin: 0px;
    padding: 0px;
    font-size: 12px;
    color: grey;
}

@media screen and (max-width: 390px) {
    .rememberMeLabel {
        left: 14px;
    }
}


@media screen and (min-width: 390px) {
    .rememberMeLabel {
        left: 7px;
    }
}


.searchContainer {
    position: relative;
    display: inline-block;
    width: 100%;
}

    .searchContainer svg {
        position: absolute;
        left: 12px;
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
        z-index: 1;
    }

.searchBox {
    width: 100%;
    height: 40px;
    border: 1px solid;
    border-radius: 12px;
    border-color: transparent;
    background-color: #FFFFFF1A;
    color: #FFFFFF66;
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk';
    padding-left: 38px;
}

.inputBox {
    width: 100%;
    height: 48px;
    border: 1px solid;
    border-radius: 12px;
    border-color: #FFFFFF33;
    background-color: transparent;
    color: #FFFFFF;
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk';
    padding-left: 21px;
}

    .inputBox::placeholder {
        color: #FFFFFF4D !important;
        opacity: 1 !important;
    }

    .inputBox:hover {
        border: 2px solid #B524FF;
    }

    .inputBox:focus {
        border-color: #B524FF;
    }

    .inputBox:active {
        border-color: #B524FF;
    }

.inputLabel {
    width: 100%;
    font-family: 'Open Sans';
    left: 0px;
    text-align: left;
    padding: 0px;
    margin: 0px;
    color: #FFFFFF99;
    font-weight: 400;
    font-size: 14px;
    line-height: 100%;
    margin-bottom: 7px;
}

textarea {
    width: 100%;
    height: 100px;
    vertical-align: top; /* Aligns text to the top */
    padding: 11px 21px 11px 21px; /* Gives space from edges */
    box-sizing: border-box; /* Ensures padding doesn't add to width */
    resize: none; /* Optional: prevent resizing */
    border: 1px solid;
    border-radius: 12px;
    border-color: #FFFFFF33;
    background-color: transparent;
    color: #FFFFFF;
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk';
}

    textarea::placeholder {
        color: #FFFFFF4D !important;
        opacity: 1 !important;
    }

    textarea:hover {
        border: 2px solid #B524FF;
    }

    textarea:focus {
        border-color: #B524FF;
    }

    textarea:active {
        border-color: #B524FF;
    }

.custom-select {
    position: relative;
    width: 100%; /* Matches your select's width: 100% */
}

.select-button {
    width: 100%;
    height: 49px; /* Matches select height */
    border: 1px solid #FFFFFF33; /* Matches border-color */
    border-radius: 10px;
    background-color: transparent; /* Matches background */
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk', sans-serif;
    padding-left: 21px;
    padding-right: 30px;
    text-align: left;
    cursor: pointer;
    background-image: url('data:image/svg+xml;utf8,<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg"><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(0.707159 0.707054 -0.707159 0.707054 15.8291 0)" fill="%23B1AEB3"/><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(-0.707159 0.707054 -0.707159 -0.707054 11.1729 8.99902)" fill="%23B1AEB3"/></svg>');
    background-repeat: no-repeat;
    background-position: right 17px center; /* 17px from right edge */
    background-size: 18px 12px; /* Matches SVG dimensions */
    z-index: 1055;
}

    .select-button:hover {
        border: 2px solid #B524FF; /* Matches select:hover */
    }

    .select-button:focus {
        border-color: #B524FF; /* Matches select:focus */
        outline: none;
    }

.select-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%; /* Matches select's width */
    max-height: 200px; /* Customizable dropdown height */
    overflow-y: auto; /* Scroll if too many options */
    border: 1px solid #FFFFFF33;
    border-radius: 10px;
    background-color: #0B030F; /* Matches option background */
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    list-style: none; /* Removes bullet points for all <li> */
    z-index: 1054;
    padding-left: 0px;
}

.custom-select.open .select-dropdown {
    display: block;
}

.select-dropdown li {
    padding: 10px 21px;
    color: #FFFFFF; /* Matches option color */
    cursor: pointer;
}

    .select-dropdown li:hover {
        background-color: #B524FF; /* Matches selected option color */
        color: #FFFFFF;
    }

    .select-dropdown li.selected {
        background-color: #0B030F; /* Matches selected option background */
        color: #B524FF; /* Matches selected option color */
    }

    .select-dropdown li[disabled] {
        color: #FFFFFF33; /* Matches disabled option */
        cursor: not-allowed;
    }


.select-button {
    width: 100%;
    height: 49px;
    border: 1px solid #FFFFFF33;
    border-radius: 10px;
    background-color: transparent;
    color: #FFFFFF;
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk', sans-serif;
    padding-left: 21px;
    padding-right: 35px;
    text-align: left;
    cursor: pointer;
    background-image: url('data:image/svg+xml;utf8,<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg"><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(0.707159 0.707054 -0.707159 0.707054 15.8291 0)" fill="%23B1AEB3"/><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(-0.707159 0.707054 -0.707159 -0.707054 11.1729 8.99902)" fill="%23B1AEB3"/></svg>');
    background-repeat: no-repeat;
    background-position: right 17px center;
    background-size: 18px 12px;
    position: relative;
    z-index: 10;
}

    .select-button:hover {
        border: 2px solid #B524FF;
    }

    .select-button:focus {
        border-color: #B524FF;
        outline: none;
    }

.custom-select.open .select-dropdown {
    display: block;
}

.select-dropdown li {
    padding: 10px 21px;
    color: #FFFFFF;
    cursor: pointer;
    list-style: none;
}

    .select-dropdown li:hover {
        background-color: #B524FF;
        color: #FFFFFF;
    }

    .select-dropdown li.selected {
        background-color: #0B030F;
        color: #B524FF;
    }

    .select-dropdown li.disabled {
        color: #FFFFFF33;
        cursor: not-allowed;
    }

/* Datepicker styles (updated) */
.custom-datepicker {
    position: relative;
    width: 100%;
}

.datepicker-button {
    width: 100%;
    height: 49px;
    border: 1px solid #FFFFFF33;
    border-radius: 10px;
    background-color: transparent;
    color: #FFFFFF;
    font-size: 16px;
    font-weight: 400;
    font-family: 'Space Grotesk', sans-serif;
    padding-left: 21px;
    padding-right: 35px;
    text-align: left;
    cursor: pointer;
    background-image: url('data:image/svg+xml;utf8,<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg"><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(0.707159 0.707054 -0.707159 0.707054 15.8291 0)" fill="%23B1AEB3"/><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(-0.707159 0.707054 -0.707159 -0.707054 11.1729 8.99902)" fill="%23B1AEB3"/></svg>');
    background-repeat: no-repeat;
    background-position: right 17px center;
    background-size: 18px 12px;
    position: relative;
    z-index: 10;
}

    .datepicker-button:hover {
        border: 2px solid #B524FF;
        background-image: url('data:image/svg+xml;utf8,<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg"><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(0.707159 0.707054 -0.707159 0.707054 15.8291 0)" fill="%23B524FF"/><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(-0.707159 0.707054 -0.707159 -0.707054 11.1729 8.99902)" fill="%23B524FF"/></svg>');
    }

    .datepicker-button:focus {
        border-color: #B524FF;
        outline: none;
        background-image: url('data:image/svg+xml;utf8,<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg"><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(0.707159 0.707054 -0.707159 0.707054 15.8291 0)" fill="%23B524FF"/><rect width="3.07196" height="12.7267" rx="1.53598" transform="matrix(-0.707159 0.707054 -0.707159 -0.707054 11.1729 8.99902)" fill="%23B524FF"/></svg>');
    }

.custom-datepicker:not(.has-value) .datepicker-button {
    color: #FFFFFF33;
}

.datepicker-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: #0B030F;
    border: 1px solid #FFFFFF33;
    border-radius: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    padding: 10px;
}

.custom-datepicker.open .datepicker-dropdown {
    display: block;
}

.datepicker-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    gap: 5px; /* Added for spacing between CustomDropdown components */
}

    .datepicker-header button {
        background: none;
        border: none;
        color: #FFFFFF;
        font-size: 16px;
        cursor: pointer;
        padding: 5px 10px;
    }

.datepicker-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
}

.day {
    background: transparent;
    border: none;
    color: #FFFFFF;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 14px;
    padding: 8px;
    text-align: center;
    cursor: pointer;
}

    .day:hover {
        background-color: #B524FF;
        border-radius: 5px;
    }

    .day.selected {
        background-color: #B524FF;
        color: #FFFFFF;
        border-radius: 5px;
    }

    .day:disabled {
        color: #FFFFFF33;
        cursor: not-allowed;
    }

    .day.placeholder {
        background: transparent;
    }

/* ONBOARDING CAROUSEL */

.onboarding-carousel {
    height: 388px;
    width: 296px;
    border: 1px solid #FFFFFF33;
    border-radius: 16px;
    background: #FFFFFF1A;
    overflow: hidden;
    position: relative;
    user-select: none; /* prevents text selection during drag */
    touch-action: pan-y; /* improves touch experience */
}

.onboarding-carousel-slides-container {
    display: flex;
    height: 100%;
    flex: 0 0 296px; /* Exact width */
    min-width: 296px; /* Prevent shrinkage */
    will-change: transform; /* better performance */
    backface-visibility: hidden;
}

.onboarding-carousel-slide {
    flex: 0 0 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 20px;
    box-sizing: border-box;
}

.onboarding-carousel-content {
}

.onboarding-carousel-title {
    width: 100%;
    display: grid;
    margin-top: 12px;
}

.onboarding-carousel-description {
    width: 100%;
    display: grid;
    margin-top: 4px;
    margin-bottom: 20px;
}

.onboarding-carousel-pagination {
    position: relative;
    margin-top: 11px;
    right: -88%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
}

.onboarding-carousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: rgba(255,255,255,0.3);
    transition: all 0.25s ease;
}

    .onboarding-carousel-dot.active {
        background-color: white;
        width: 20px;
        border-radius: 8px;
    }


/* Optional: cursor feedback during drag */
.onboarding-carousel.is-dragging {
    cursor: grabbing;
}

/* OTHER CAROUSELS */

/* -------------------------------------------------
   WRAPPER – gives the carousel a concrete height
   ------------------------------------------------- */
.carousel-wrapper {
    width: 100%;
    min-height: 120px;
    max-height: 128px;
    position: relative;
}

/* -------------------------------------------------
   ROOT
   ------------------------------------------------- */
.ott4-carousel-root {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    user-select: none;
    width: 100%;
    min-height: 120px;
    max-height: 128px;
}

/* -------------------------------------------------
   TRACK
   ------------------------------------------------- */
.ott4-carousel-track {
    display: flex;
    transition: transform .5s ease;
    width: 100%;
    height: 100%;
}

/* -------------------------------------------------
   ITEM
   ------------------------------------------------- */
.ott4-carousel-item {
    flex: 0 0 100%;
    position: relative;
    width: 100%;
    height: 100%;
}

.ott4-item-inner {
    width: 100%;
    height: 100%;
    position: relative;
    border-radius: 16px;
    overflow: hidden;
}

/* -------------------------------------------------
   LINKS
   ------------------------------------------------- */
.ott4-banner-link,
.ott4-tile-link {
    display: block;
    width: 100%;
    height: 100%;
    cursor: pointer;
}

/* -------------------------------------------------
   FULL BANNER
   ------------------------------------------------- */
.ott4-carousel-root[data-type="FullBanner"] .ott4-carousel-track {
    height: 120px;
}

.ott4-carousel-root[data-type="FullBanner"] .ott4-item-inner {
    position: absolute;
    inset: 0;
}

.ott4-carousel-root[data-type="FullBanner"] img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* -------------------------------------------------
   GRID TILES (unchanged)
   ------------------------------------------------- */
.ott4-carousel-root[data-type="GridTiles"] {
    height: 128px;
    overflow: visible;
}

    .ott4-carousel-root[data-type="GridTiles"] .ott4-carousel-track {
        height: 100%;
        gap: 8px;
        display: flex;
        align-items: stretch;
    }

    .ott4-carousel-root[data-type="GridTiles"] .ott4-carousel-item {
        flex: 0 0 40%;
        max-width: 128px;
        height: 100%;
        border: 1px solid #FFFFFF33;
        border-radius: 12px;
    }

    .ott4-carousel-root[data-type="GridTiles"] .ott4-item-inner {
        position: absolute;
        inset: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        background: #222;
        border-radius: 12px;
        background-color: transparent;
        padding: 4px;
        height: 120px !important;
        width: 120px !important;
    }

    .ott4-carousel-root[data-type="GridTiles"] ott4-tile-link {
        height: 120px !important;
        width: 120px !important;
    }

    .ott4-carousel-root[data-type="GridTiles"] img {
        max-width: 120px;
        max-height: 120px;
        object-fit: contain;
        border-radius: 12px;
    }

/* -------------------------------------------------
   DOTS – NOW OUTSIDE, 11px BELOW
   ------------------------------------------------- */
.ott4-dots-wrapper {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 11px; /* exactly 11px below carousel */
    padding: 0 10px;
}

.ott4-dot {
    width: 8px;
    height: 8px;
    border-radius: 8px;
    background: rgba(255,255,255,.5);
    transition: all .3s;
    cursor: pointer;
}

    .ott4-dot.ott4-active {
        background: #fff;
        transform: scale(1.1);
        width: 17px;
        height: 8px;
    }


/* END OC CAROUSEL CODE */

.randSVG {
    position: relative;
    left: -150px;
    bottom: -31px;
}

#adumo, #ozow, #vault, #ott, #appleGoogle {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
    height: 20px;
    width: 20px;
    border: 1px solid #D9D9D9;
    border-radius: 20px;
    background-color: white;
    position: relative;
    cursor: pointer;
    top: 5px;
}

    #adumo:checked, #ozow:checked, #vault:checked, #ott:checked, #appleGoogle:checked {
        background-color: #D9D9D9;
    }

        /* Black filled circle for checked state */
        #adumo:checked::after, #ozow:checked::after, #vault:checked::after, #ott:checked::after, #appleGoogle:checked::after {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            width: 13px;
            height: 13px;
            background-color: black;
            border-radius: 50%;
            transform: translate(-50%, -50%);
        }

.voucher-radio {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
    height: 20px;
    width: 23px;
    border: 1px solid #D9D9D9;
    border-radius: 20px;
    background-color: white;
    position: relative;
    cursor: pointer;
}

    .voucher-radio:checked {
        background-color: #D9D9D9;
    }

        .voucher-radio:checked::after {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            width: 13px;
            height: 13px;
            background-color: black;
            border-radius: 50%;
            transform: translate(-50%, -50%);
        }


#tsandcs, #emailComms, #smsVouchers, #emailVouchers {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
    height: 22px;
    width: 1px;
    border: 1px solid #D9D9D9;
    border-radius: 5px;
    background-color: white;
    position: relative;
    cursor: pointer;
    background-color: #D9D9D9;
    margin-right: 10px;
    padding: 10px;
}

    /* black tick for checked state */
    #tsandcs:checked::after, #emailComms:checked::after, #smsVouchers:checked::after, #emailVouchers:checked::after {
        content: "";
        position: absolute;
        left: 9px;
        top: 5px;
        width: 5px;
        height: 11px;
        border: solid black;
        border-width: 0 3px 3px 0;
        transform: rotate(45deg);
    }


/* For Webkit browsers (Chrome, Safari, Edge) */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* For Firefox */
input[type="number"] {
    -moz-appearance: textfield;
}

.radioButtonBar {
    width: 100%;
    height: 49px;
    background-color: transparent;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 500;
    font-family: 'Space Grotesk';
    padding-left: 11px;
    padding-right: 11px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: center;
    align-content: center;
    cursor: pointer;
}

.providerImageHolder {
    position: absolute;
    width: 111px;
}

.provider-row {
    gap: 12px;
}

.svg-container {
    flex-shrink: 0;
    position: absolute;
    padding-bottom: 7px;
}

.provider-content {
    flex-grow: 1;
    display: inline-flex;
    justify-content: right;
    align-items: center;
}

.radioButtonBar.selected .radioButtonBar.active .radioButtonBar:checked .radioButtonBar:hover {
    border: 1px solid #B524FF;
}

.hidden-radio {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.ottModalCardSolid {
    background-color: #0B030F;
    height: fit-content;
    width: 88%;
    max-width: 400px;
    position: absolute;
    padding: 17px;
    margin: 0px 17px;
    border: 1px solid #FFFFFF33;
    border-radius: 12px;
    z-index: 2001;
}

.ottModalBlurBehind {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Semi-transparent black */
    backdrop-filter: blur(8px); /* This blurs everything behind */
    -webkit-backdrop-filter: blur(8px); /* Safari support */
    z-index: 2000; /* Just below the modal */
    transition: opacity 0.3s ease;
}

.ottModalCardBlur {
    position: absolute;
    background-color: #0B030FB2;
    height: fit-content;
    width: 200px;
    max-width: 400px;
    padding: 11px;
    border: 1px solid #FFFFFF33;
    border-radius: 12px;
    z-index: 2001;
    backdrop-filter: blur(20px);
    top: 33%;
}

.ottModalNoBlurBehind {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: transparent;
}


/*                 */
/* BUTTON STYLING  */
/*  
*/

.buttonText {
    font-family: 'Space Grotesk';
    font-weight: 500;
    font-size: 14px;
    color: #FFFFFF;
}

.buttonIconIndex {
    z-index: 101;
}

.purpleButton {
    height: 49px;
    width: 100%;
    border: 1px transparent;
    border-radius: 48px;
    background: linear-gradient(0deg, #B524FF 0%, #B524FF 54.81%, #D788FF 100%);
    font-family: 'Space Grotesk';
    font-weight: 500;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: #FFFFFF;
    z-index: 100;
}

.whiteButton {
    height: 49px;
    width: 100%;
    border: 1px transparent;
    border-radius: 48px;
    background: linear-gradient(0deg, #E4C8F3 0%, #FFFFFF 100%);
    font-family: 'Space Grotesk';
    font-weight: 500;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: #B524FF;
    z-index: 100;
}

.redButton {
    height: 49px;
    width: 100%;
    border: 1px solid #EE3F3F;
    border-radius: 48px;
    background: transparent;
    font-family: 'Space Grotesk';
    font-weight: 500;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: #FFFFFF;
}


.button {
    font-family: 'Space Grotesk';
    font-size: 16px;
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    min-height: 40px;
    max-height: fit-content;
    padding: 14px 28px 14px 28px;
    box-shadow: none;
    border-radius: 50px;
    border: solid 0px transparent;
    color: white;
    background: linear-gradient(180deg, rgba(215, 136, 255, 1) 0%, rgba(181, 36, 255, 1) 50%, rgba(181, 36, 255, 1) 100%);
}

    .button:hover, .button:focus {
        background: linear-gradient(180deg, rgba(181, 36, 255, 1) 0%, rgba(181, 36, 255, 1) 50%, rgba(215, 136, 255, 1) 100%);
    }

    .button:active {
        background: linear-gradient(180deg, rgba(215, 136, 255, 1) 0%, rgba(181, 36, 255, 1) 50%, rgba(215, 136, 255, 1) 100%);
    }

@media screen and (max-width: 390px) {
    .button {
        max-width: 250px;
    }
}


@media screen and (min-width: 390px) {
    .button {
        max-width: 270px;
    }
}


@media screen and (max-width: 711px) {
    .button {
        font-size: 16px;
    }
}

@media screen and (min-width: 711px) {
    .button {
        font-size: 16px;
    }
}

.button-white {
    font-family: Open Sans;
    font-size: 14px;
    font-weight: 500;
    line-height: 100%;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    min-height: 40px;
    max-height: fit-content;
    padding: 1rem;
    padding: .3rem 1rem;
    box-shadow: none;
    border-radius: 50px;
    border: solid 1px #B524FF;
    color: black;
    background-color: #F5F0F7;
}

    .button-white:hover, .button-white:active, .button-white:focus {
        border: solid 2px #B524FF;
    }

@media screen and (max-width: 390px) {
    .button-white {
        max-width: 250px;
    }
}


@media screen and (min-width: 390px) {
    .button-white {
        max-width: 270px;
    }
}


@media screen and (max-width: 711px) {
    .button-white {
        font-size: 14px;
    }
}

@media screen and (min-width: 711px) {
    .button-white {
        font-size: 14px;
    }
}

.small-button {
    font-family: Open Sans;
    font-size: 10px;
    font-weight: 600;
    line-height: 19.07px;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    height: 22px;
    padding: .1rem 1rem .3rem 1rem;
    box-shadow: none;
    border-radius: 10px;
    border: solid 0px transparent;
    color: white;
    background: rgba(181, 36, 255, 1);
    background-color: rgba(181, 36, 255, 1);
}

    .small-button:hover, .small-button:active, .small-white:focus {
        background: linear-gradient(180deg, rgba(87, 26, 37, 0) 0%, rgba(87, 26, 37, 0.2) 100%), rgba(151, 16, 224, 1);
        background-blend-mode: plus-darker, normal;
    }

.small-button-white {
    font-family: Open Sans;
    font-size: 10px;
    font-weight: 600;
    line-height: 19.07px;
    text-align: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    height: 22px;
    padding: 0rem 1rem .3rem 1rem;
    box-shadow: none;
    border-radius: 10px;
    border: solid 0px transparent;
    border: solid 1px #B524FF;
    color: black;
    background-color: #F5F0F7;
}

    .small-button-white:hover, .small-button-white:active, .small-white-button:focus {
        border: solid 2px #B524FF;
    }

.menu-button-open {
    z-index: 3;
    color: black;
    margin-left: 7px;
}

.menu-button-close {
    z-index: 3;
    color: white;
    margin-left: 7px;
}

#menuButton {
    position: relative;
    font-size: 17px;
    top: 21px;
    left: 27px;
}

#notificationButton {
    position: relative;
    top: 17px;
    right: 27px;
}


#menuButton:hover {
    color: #B524FF;
}


.otp-container-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 7px;
    margin-bottom: 11px;
    width: 100%;
}

.otp-single-input {
    font-family: Space Grotesk;
    font-weight: 400;
    font-size: 36px;
    line-height: 100%;
    text-transform: uppercase;
    width: 77%;
    height: 49px;
    border: 2px solid #8E8E8E;
    border-top: 0px;
    border-left: 0px;
    border-right: 0px;
    border-radius: 0px;
    background-color: transparent;
    color: #FFFFFF;
    padding-left: 11px;
    text-align: center;
    letter-spacing: 14px;
}

    .otp-single-input:hover {
        border: 2px solid rgba(215, 136, 255, 1);
        border-top: 0px;
        border-left: 0px;
        border-right: 0px;
        border-radius: 0px;
    }

    .otp-single-input:focus {
        border: 2px solid rgba(215, 136, 255, 1);
        border-top: 0px;
        border-left: 0px;
        border-right: 0px;
        border-radius: 0px;
    }

    .otp-single-input:focus-visible {
        border: 2px solid rgba(215, 136, 255, 1) !important;
        border-top: 0px !important;
        border-left: 0px !important;
        border-right: 0px !important;
        border-radius: 0px !important;
        outline: 0px !important;
    }

    .otp-single-input:active {
        border: 2px solid rgba(215, 136, 255, 1);
        border-top: 0px;
        border-left: 0px;
        border-right: 0px;
        border-radius: 0px;
    }

    .otp-single-input:focus-within {
        border: 2px solid rgba(215, 136, 255, 1);
        border-top: 0px;
        border-left: 0px;
        border-right: 0px;
        border-radius: 0px;
    }

    .otp-single-input:target {
        border: 2px solid rgba(215, 136, 255, 1);
        border-top: 0px;
        border-left: 0px;
        border-right: 0px;
        border-radius: 0px;
    }

.filterRowBlock {
    width: 100%;
    z-index: 33;
    position: relative; /* Needed for z-index to work */
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.favouritesChoices {
    display: flex;
    flex-wrap: nowrap; /* Prevent wrapping */
    overflow-x: auto; /* Enable horizontal scroll */
    overflow-y: hidden;
    padding: 13px 17px 19px 17px;
    gap: 7px; /* Replaces margin-right/bottom */
    scrollbar-width: none; /* Firefox: hide scrollbar */
    -ms-overflow-style: none; /* IE/Edge: hide scrollbar */
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    scroll-behavior: smooth;
    /* Break out of constrained parents */
    position: relative;
    left: 0;
    right: 0;
    margin-left: -17px; /* Hardcode or use CSS var */
    margin-right: -17px;
    padding-left: 17px;
    padding-right: 17px;
    width: calc(100% + 34px); /* 17px * 2 */
    min-width: 0; /* Critical for flex children */
    /* Ensure it can grow beyond viewport */
    max-width: none;
}

    .favouritesChoices::-webkit-scrollbar {
        display: none; /* Chrome/Safari: hide scrollbar */
    }

@media screen and (min-width: 770px) {
    .favouritesChoices {
        flex-wrap: wrap;
    }
}

.homeCountChoices {
    display: flex;
    flex-wrap: nowrap; /* Prevent wrapping */
    overflow-x: auto; /* Enable horizontal scroll */
    overflow-y: hidden;
    padding: 0px 17px 0px 17px;
    gap: 0px; /* Replaces margin-right/bottom */
    scrollbar-width: none; /* Firefox: hide scrollbar */
    -ms-overflow-style: none; /* IE/Edge: hide scrollbar */
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    scroll-behavior: smooth;
    /* Position relative to nearest positioned ancestor or viewport */
    position: relative;
    left: 0;
    right: 0;
    margin-left: calc(-1 * var(--mobileCardSizer-padding, 17px));
    margin-right: calc(-1 * var(--mobileCardSizer-padding, 17px));
    width: calc(100% + (var(--mobileCardSizer-padding, 17px) * 2));
    /* Ensure it doesn't exceed container-custom */
    max-width: 100vw; /* or whatever your container-custom max-width is */
}

.filterChoices::-webkit-scrollbar {
    display: none; /* Chrome/Safari: hide scrollbar */
}

@media screen and (min-width: 770px) {
    .filterChoices {
        flex-wrap: wrap;
    }
}


.filterChoices {
    display: flex;
    flex-wrap: nowrap; /* Prevent wrapping */
    overflow-x: auto; /* Enable horizontal scroll */
    overflow-y: hidden;
    padding: 13px 17px 7px 17px;
    gap: 7px; /* Replaces margin-right/bottom */
    scrollbar-width: none; /* Firefox: hide scrollbar */
    -ms-overflow-style: none; /* IE/Edge: hide scrollbar */
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    scroll-behavior: smooth;
    /* Position relative to nearest positioned ancestor or viewport */
    position: relative;
    left: 0;
    right: 0;
    margin-left: calc(-1 * var(--mobileCardSizer-padding, 17px));
    margin-right: calc(-1 * var(--mobileCardSizer-padding, 17px));
    width: calc(100% + (var(--mobileCardSizer-padding, 17px) * 2));
    /* Ensure it doesn't exceed container-custom */
    max-width: 100vw; /* or whatever your container-custom max-width is */
}

    .filterChoices::-webkit-scrollbar {
        display: none; /* Chrome/Safari: hide scrollbar */
    }

@media screen and (min-width: 770px) {
    .filterChoices {
        flex-wrap: wrap;
    }
}


.filterRow {
    overflow-x: auto;
    white-space: nowrap;
    width: 100%;
    scrollbar-width: none;
    -ms-overflow-style: none;
    z-index: 33;
    position: relative; /* Needed for z-index to work */
    padding-bottom: 10px; /* Prevents margin collapse & adds space for scrolling */
    margin-bottom: -7px; /* Counteracts margin-bottom on buttons */
    padding-left: 17px;
    padding-right: 17px;
}

.draggable-scroll {
    user-select: none;
    cursor: grab;
}

    .draggable-scroll:active {
        cursor: grabbing;
    }

.scroll-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: white;
    transition: all 0.3s ease;
}

    .scroll-indicator.active {
        width: 16px; /* Double the width */
        border-radius: 4px; /* More rectangular but still rounded */
        background-color: #BDBDBD; /* Light gray */
    }

.row::-webkit-scrollbar {
    display: none;
}

.filterButton {
    height: 27px;
    min-width: fit-content;
    cursor: pointer;
    display: flex; /* Use flex for perfect centering */
    justify-content: center;
    align-items: center;
    border-radius: 15px;
    padding: 7px 14px;
    font-size: 11px;
    font-weight: 400;
    line-height: 100%;
    color: #FFFFFF;
    background-color: #FFFFFF1A;
    flex-shrink: 0; /* Prevent buttons from shrinking */
    white-space: nowrap; /* Prevent text wrap inside button */
    user-select: none; /* Optional: prevent text selection on tap */
}

.bigFilterButton {
    height: 31px;
    width: 100px;
    cursor: pointer;
    display: flex; /* Use flex for perfect centering */
    justify-content: center;
    align-items: center;
    border-radius: 15px;
    padding: 7px 0px;
    font-size: 14px;
    font-weight: 400;
    line-height: 100%;
    color: #FFFFFF;
    background-color: #FFFFFF1A;
    flex-shrink: 0; /* Prevent buttons from shrinking */
    white-space: nowrap; /* Prevent text wrap inside button */
    user-select: none; /* Optional: prevent text selection on tap */
}

.qrCodeImage {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
}

.qrCodeContainer {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 7px;
    margin: 0px 44px;
    margin-top: -17px;
    cursor: pointer;
    border-radius: 17px;
    background-color: white;
    box-shadow: 0px 5px 10px 0px #00000026 !important;
}

.affiliateCodeContainer {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 12px;
    cursor: pointer;
}

.affiliateCodeText {
    margin: 0;
}

.pinContainer {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 12px;
    cursor: pointer;
}

.pinText {
    margin: 0;
}

.textCopied {
    color: #B524FF !important;
}

.dateDiv {
    display: flex;
    justify-content: space-evenly;
    align-content: center;
    text-align: center;
    align-items: center;
    width: 30%;
    max-width: 122px;
    height: 49px;
    background-color: white;
    border-radius: 15px;
    padding: 9px
}

.pageLeft {
    background-color: white;
    border-radius: 22px;
    height: 27px;
    width: 27px;
    padding: 0px 7px 0px 0px;
    margin: 0px;
    display: flex;
    justify-content: center;
    text-align: center;
    align-items: center;
    cursor: pointer;
}

.pageRight {
    background-color: white;
    border-radius: 22px;
    height: 27px;
    width: 27px;
    padding: 0px 0px 0px 0px;
    margin: 0px 0px 0px 7px;
    display: flex;
    justify-content: center;
    text-align: center;
    align-items: center;
    cursor: pointer;
}

.noItemsFound {
    font-family: 'Open Sans';
    font-weight: 400;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    color: #FFFFFF33;
}

/*                   */
/* SIDE MENU STYLING */
/*                   */

#menuLinks {
    width: 100%;
    padding: 0 0 0 0;
    margin-bottom: 1em;
    font-family: 'Trebuchet MS', 'Lucida Grande', Verdana, Lucida, Geneva, Helvetica, Arial, sans-serif;
    background-color: transparent;
    z-index: 7;
    overflow: hidden; /* hides both horizontal and vertical scrollbars */
}

    #menuLinks ul {
        list-style: none;
        margin: 0;
        padding: 0;
        border: none;
    }

    #menuLinks li {
        margin: 0;
    }

        #menuLinks li a {
            display: block;
            padding: 5px 5px 5px 0.5em;
            background-color: transparent;
            text-decoration: none;
            width: 100%;
        }

        html > body #menuLinks li a {
            width: auto;
        }

            #menuLinks li a:hover {
                color: #B524FF;
            }

#menuItemHeaders a {
    padding: 5px 5px 5px 0 !important;
    color: white;
    font-weight: 500;
    line-height: 21.79px;
}


#menuItems a {
    padding-left: 22px !important;
    color: rgba(255, 255, 255, 0.7);
}

.sidebar-logoff {
    color: rgba(255, 255, 255, 0.7);
    font-weight: 700;
}


    .sidebar-logoff:hover {
        color: #B524FF;
    }


.sidebar-logoff-text {
    margin: 0;
    margin-left: 3px;
    padding: 0;
    display: inline-block;
}


.game-option:checked {
    background-color: #yourCheckedColor !important;
    position: relative;
}

    /* Optional: Add a checkmark for better UX */
    .game-option:checked::after {
        content: "✓";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: black;
        font-size: 12px;
    }


/* INFO LAYER STYLINMG */

.ott-popup {
    position: fixed;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1000; /* Ensure it's above the overlay */

    background: rgba(255, 255, 255, 0.77);
    padding: 17px 14px;
    border-radius: 12px;
    width: 270px;
    line-height: 1;
    display: block;
    box-shadow: 0px 10px 20px 4px #00000066;
    backdrop-filter: blur(12px)
}



/* The overlay to dim the background */

.ott-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.44); /* Black with 50% opacity */

    z-index: 999; /* Below the modal-div but above other content */
    /* Initially hidden, show it with JavaScript or by removing a class */

    display: block;
}

input[type="password"] {
    -webkit-text-security: disc !important; /* disc = asterisk */
    text-security: disc !important;
}
