:root {
        --ui-radius-xs: .625rem;
        --ui-radius-sm: .75rem;
        --ui-radius-md: .875rem;
        --ui-radius-lg: 1rem;
        --ui-radius-xl: 1.125rem;
        --ui-radius-2xl: 1.375rem;

        --ui-text: var(--color2, rgba(255,255,255,.96));
        --ui-text-soft: rgba(255,255,255,.78);
        --ui-text-muted: rgba(255,255,255,.60);

        --ui-surface: rgba(255,255,255,.04);
        --ui-surface-soft: rgba(255,255,255,.03);
        --ui-surface-strong: rgba(255,255,255,.08);

        --ui-border: rgba(255,255,255,.08);
        --ui-border-soft: rgba(255,255,255,.06);
        --ui-border-strong: rgba(255,255,255,.12);

        --ui-shadow-sm: 0 .375rem .875rem rgba(0,0,0,.18);
        --ui-shadow-md: 0 .75rem 1.75rem rgba(0,0,0,.22);
        --ui-shadow-lg: 0 1.5rem 5rem rgba(0,0,0,.46);

        --ui-fs-xs: .6875rem;
        --ui-fs-sm: .75rem;
        --ui-fs-base: .875rem;
        --ui-fs-md: .9375rem;
        --ui-fs-lg: 1rem;
        --ui-fs-xl: 1.125rem;
        --ui-fs-2xl: 1.375rem;

        --ui-title-page: 2rem;
        --ui-title-section: 1.5rem;
        --ui-title-card: 1.125rem;
    }

    /* =========================================================
       VERTICAL GAMES GRID
    ========================================================= */

    .games-grid.vertical-grid {
        width: 100%;
        margin-top: 1rem;
        margin-bottom: 1rem;
    }

    .games-grid.vertical-grid #games-load-container {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(10.625rem, 1fr));
        gap: .875rem;
        align-items: start;
        width: 100%;
    }

    .vertical-game-card {
        position: relative;
        width: 100%;
        border-radius: var(--ui-radius-md);
        overflow: visible;
        background: transparent;
        transition: transform .22s ease, box-shadow .22s ease;
        will-change: transform;
    }

    .vertical-game-inner {
        position: relative;
        width: 100%;
        aspect-ratio: 2 / 3;
        overflow: hidden;
        background: #111827;
        border-radius: .625rem;
        box-shadow: var(--ui-shadow-sm);
    }

    .vertical-game-link {
        display: block;
        width: 100%;
        height: 100%;
        text-decoration: none;
        color: inherit;
    }

    .vertical-game-image {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
        transition: transform .28s ease, opacity .25s ease;
        opacity: 0;
    }

    .vertical-game-image.lazy-loaded {
        opacity: 1;
    }

    .vertical-game-overlay {
        position: absolute;
        inset: 0;
        z-index: 3;
        pointer-events: none;
    }

    .vertical-game-overlay::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0);
        transition: background .22s ease;
    }

    .vertical-game-top {
        position: absolute;
        top: .5rem;
        left: .5rem;
        right: .5rem;
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        z-index: 6;
        pointer-events: none;
    }

    .vertical-tournament-icon {
        width: 1.75rem;
        height: 1.75rem;
        border-radius: 50%;
        background: rgba(0, 0, 0, .55);
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .vertical-tournament-icon svg {
        width: 1rem;
        height: 1rem;
    }

    .vertical-game-center {
        position: absolute;
        inset: 0;
        z-index: 5;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: .625rem;
        padding: .75rem;
        pointer-events: none;
    }

    .vertical-game-title {
        text-align: center;
        color: #fff;
        font-size: var(--ui-fs-base);
        font-weight: 700;
        line-height: 1.3;
        opacity: 0;
        transform: translateY(.5rem);
        transition: opacity .2s ease, transform .2s ease;
        max-width: 90%;
        text-shadow: 0 .125rem .5rem rgba(0, 0, 0, .65);
    }

    .vertical-play-btn {
        width: 3.625rem;
        height: 3.625rem;
        border-radius: 50%;
        background: rgba(0, 0, 0, .62);
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0;
        transform: scale(.86);
        transition: opacity .2s ease, transform .2s ease;
        pointer-events: none;
    }

    .vertical-play-btn svg {
        width: 70%;
        height: 70%;
    }

    .vertical-play-btn .circle,
    .vertical-play-btn .triangle {
        stroke: #fff !important;
        fill: none !important;
        stroke-width: 10 !important;
    }

    @media (hover: hover) and (pointer: fine) {
        .vertical-game-card:hover {
            transform: translateY(-.375rem);
        }

        .vertical-game-card:hover .vertical-game-image {
            transform: none;
        }

        .vertical-game-card:hover .vertical-game-overlay::before {
            background: rgba(0, 0, 0, 0.42);
        }

        .vertical-game-card:hover .vertical-game-title {
            opacity: 1;
            transform: translateY(0);
        }

        .vertical-game-card:hover .vertical-play-btn {
            opacity: 1;
            transform: scale(1);
        }
    }

    .games-grid.vertical-grid #games-load-container > .no-games-found,
    .games-grid.vertical-grid #games-load-container > h2 {
        grid-column: 1 / -1;
        width: 100%;
        text-align: center;
    }

    @media (max-width: 75rem) {
        .games-grid.vertical-grid #games-load-container {
            grid-template-columns: repeat(auto-fill, minmax(9.375rem, 1fr));
            gap: .75rem;
        }
    }

    @media (max-width: 48rem) {
        .games-grid.vertical-grid {
            margin-top: .75rem;
        }

        .games-grid.vertical-grid #games-load-container {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: .5rem;
            padding: 0 .5rem;
            box-sizing: border-box;
        }

        .vertical-game-card,
        .vertical-game-inner {
            border-radius: .5rem;
        }

        .vertical-game-card:hover {
            transform: none !important;
        }

        .vertical-game-image {
            transform: none !important;
        }

        .vertical-game-title,
        .vertical-play-btn {
            display: none !important;
            opacity: 0 !important;
        }

        .vertical-game-overlay::before,
        .vertical-game-card:hover .vertical-game-overlay::before {
            background: transparent !important;
        }

        .vertical-tournament-icon {
            width: 1.5rem;
            height: 1.5rem;
        }

        .vertical-tournament-icon svg {
            width: .875rem;
            height: .875rem;
        }

        .games-grid.vertical-grid #games-load-container-provider,
        .games-grid.vertical-grid #games-load-container-recent {
            grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
            gap: .5rem !important;
        }
    }

    @media (max-width: 30rem) {
        .games-grid.vertical-grid #games-load-container {
            gap: .4375rem;
            padding: 0 .375rem;
        }

        .games-grid.vertical-grid #games-load-container-provider,
        .games-grid.vertical-grid #games-load-container-recent {
            gap: .4375rem !important;
        }
    }

    /* =========================================================
       WORD CAROUSEL
    ========================================================= */

    .wordCarousel {
        display: flex;
        align-items: stretch;
        margin: .625rem;
        font-size: var(--ui-fs-md);
        color: #eee;
    }

    .wordCarousel h1 {
        width: 10%;
        margin: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 0 .625rem;
        border-top-left-radius: .625rem;
        border-bottom-left-radius: .625rem;
        color: #fbb104;
        font-size: .875rem;
        font-weight: 700;
        line-height: 1.2;
    }

    .wordCarousel div {
        position: relative;
        overflow: hidden;
        display: flex;
        width: 90%;
        height: 2.5rem;
        margin: 0;
        padding-top: 0;
        border-top-right-radius: .4375rem;
        border-bottom-right-radius: .4375rem;
        background: rgba(255,255,255,.05);
    }

    .wordCarousel div > ul {
        padding-left: 0;
        width: calc(17% - 2px);
        margin-left: .0625rem;
        margin-bottom: 0;
    }

    .wordCarousel div > ul > li > span {
        margin-left: .625rem;
        color: #fbb104;
        font-weight: 700;
    }

    .wordCarousel div li {
        display: flex;
        justify-content: center;
        align-items: center;
        height: 2.5rem;
        line-height: 2.5rem;
        margin-bottom: 3.125rem;
        padding: 0 .625rem;
        color: #eee;
        font-weight: 400;
    }

    .flip5 {
        -webkit-animation: flip5 50s cubic-bezier(0.23, 1, 0.32, 1.1) infinite;
        animation: flip5 50s cubic-bezier(0.23, 1, 0.32, 1.1) infinite;
        margin-bottom: 0;
    }

    .first-t { animation-delay: 1s !important; }
    .second-t { animation-delay: 2s !important; }
    .third-t { animation-delay: 3s !important; }
    .forty-t { animation-delay: 4s !important; }
    .five-t { animation-delay: 5s !important; }
    .six-t { animation-delay: 6s !important; }

    @-webkit-keyframes flip5 {
        0% { margin-top: -16.875rem; }
        5% { margin-top: -11.25rem; }
        33% { margin-top: -11.25rem; }
        38% { margin-top: -5.625rem; }
        66% { margin-top: -5.625rem; }
        71% { margin-top: 0; }
        99.99% { margin-top: 0; }
        100% { margin-top: -16.875rem; }
    }

    @keyframes flip5 {
        0% { margin-top: -16.875rem; }
        5% { margin-top: -11.25rem; }
        33% { margin-top: -11.25rem; }
        38% { margin-top: -5.625rem; }
        66% { margin-top: -5.625rem; }
        71% { margin-top: 0; }
        99.99% { margin-top: 0; }
        100% { margin-top: -16.875rem; }
    }

    @media only screen and (max-width: 37.5rem) {
        .wordCarousel h1 {
            width: 40%;
            font-size: 1rem;
        }

        .wordCarousel div {
            width: 70%;
        }

        .wordCarousel div > ul {
            width: calc(100% - 2px);
        }
    }

    /* =========================================================
       NG CARDS / SQUARE GAMES
    ========================================================= */

    .ng-card-image {
        opacity: 0;
    }

    .ng-card-image.lazy-loaded {
        opacity: 1;
    }

    .square-box-casino {
        position: relative !important;
        overflow: visible !important;
    }

    .ng-card-link {
        display: block !important;
        position: absolute !important;
        inset: .3125rem !important;
        overflow: hidden !important;
        border-radius: .875rem !important;
        text-decoration: none !important;
        background: var(--color6) !important;
        box-shadow: 0 0 .625rem 0 rgb(44 57 79 / 80%) !important;
        border: .0625rem solid rgb(255 255 255 / 11%) !important;
        transition: transform .28s ease, box-shadow .28s ease !important;
        transform-origin: center bottom !important;
        will-change: transform !important;
    }

    .ng-card-link:hover {
        z-index: 5 !important;
        transform: translateY(-.5rem) !important;
        box-shadow: 0 .875rem 1.75rem rgba(0,0,0,.28) !important;
    }

    .ng-card-shell {
        position: relative !important;
        width: 100% !important;
        height: 100% !important;
    }

    .ng-card-image {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
        transition: opacity .25s ease, filter .28s ease !important;
    }

    .ng-card-fade {
        position: absolute !important;
        inset: 0 !important;
        background: linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,.18)) !important;
        opacity: 0 !important;
        transition: opacity .25s ease !important;
        z-index: 1 !important;
    }

    .ng-card-meta {
        position: absolute !important;
        left: .75rem !important;
        right: .75rem !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        text-align: center !important;
        z-index: 3 !important;
        opacity: 0 !important;
        transition: opacity .25s ease, top .25s ease !important;
        pointer-events: none !important;
    }

    .ng-card-title {
        font-size: .9375rem !important;
        font-weight: 700 !important;
        color: #fff !important;
        letter-spacing: .0125rem !important;
        text-shadow: 0 .125rem .625rem rgba(0,0,0,.8) !important;
        margin-bottom: .625rem !important;
    }

    .ng-card-provider {
        display: none !important;
    }

    .ng-card-play {
        width: 3.625rem !important;
        height: 3.625rem !important;
        margin: 0 auto !important;
        border-radius: 50% !important;
        background: rgba(0,0,0,.58) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transform: scale(.92) !important;
        transition: transform .25s ease, background .25s ease !important;
    }

    .ng-card-play svg {
        width: 72% !important;
        height: 72% !important;
    }

    .ng-card-play .circle,
    .ng-card-play .triangle {
        stroke: #fff !important;
        fill: none !important;
    }

    .ng-card-link:hover .ng-card-image {
        filter: brightness(.68) !important;
    }

    .ng-card-link:hover .ng-card-fade {
        opacity: 1 !important;
    }

    .ng-card-link:hover .ng-card-meta {
        opacity: 1 !important;
        top: 50% !important;
    }

    .ng-card-link:hover .ng-card-play {
        transform: scale(1) !important;
        background: rgba(0,0,0,.68) !important;
    }

    @media (max-width: 40rem) {
        .ng-card-link {
            inset: .3125rem !important;
            border-radius: .875rem !important;
            transform: none !important;
        }

        .ng-card-fade,
        .ng-card-meta {
            display: none !important;
        }

        .ng-card-link:hover {
            transform: none !important;
            box-shadow: 0 0 .625rem 0 rgb(44 57 79 / 80%) !important;
        }

        .ng-card-link:hover .ng-card-image {
            filter: none !important;
        }
    }

    /* =========================================================
       AUTH MODAL
    ========================================================= */

    .auth-modal {
        background: rgba(0, 0, 0, 0.82);
        backdrop-filter: blur(.375rem);
        -webkit-backdrop-filter: blur(.375rem);
        overflow-y: auto !important;
    }

    body.modal-open {
        overflow: hidden !important;
    }

    .auth-modal-dialog {
        width: calc(100% - 2rem);
        max-width: 32.5rem;
        margin: 1.5rem auto;
    }

    .auth-modal-dialog--login,
    .auth-modal-dialog--recovery {
        max-width: 28.75rem;
    }

    .auth-modal-dialog--signup {
        max-width: 47.5rem;
    }

    .auth-modal-dialog--promo {
        max-width: 67.5rem;
    }

    .auth-modal-dialog--signup,
    .auth-modal-dialog--promo {
        display: flex;
        align-items: center;
        min-height: calc(100vh - 2rem);
    }

    .auth-modal-card {
        position: relative;
        overflow: hidden;
        border-radius: var(--ui-radius-2xl);
        background: linear-gradient(180deg, color-mix(in srgb, var(--color5) 72%, #ffffff 6%) 0%, var(--color6) 100%);
        border: .0625rem solid rgba(255,255,255,0.08);
        box-shadow: var(--ui-shadow-lg);
        padding: 0 !important;
        width: 100%;
        text-align: left;
    }

    .auth-modal-card::before {
        content: "";
        position: absolute;
        inset: 0;
        pointer-events: none;
        background:
                linear-gradient(180deg, rgba(255,255,255,0.05) 0%, transparent 8.75rem),
                radial-gradient(circle at top center, rgba(255,255,255,0.05), transparent 40%);
    }

    .auth-modal-dialog--signup .auth-modal-card,
    .auth-modal-dialog--promo .auth-modal-card {
        height: 100%;
        max-height: 100%;
        display: flex;
        flex-direction: column;
        overflow: hidden !important;
    }

    .auth-modal-dialog--login .auth-modal-card,
    .auth-modal-dialog--recovery .auth-modal-card {
        max-height: calc(100vh - 3rem);
        overflow-y: auto;
    }

    .auth-modal-card__header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 1.375rem 1.5rem 1rem;
        background: linear-gradient(180deg, rgba(255,255,255,0.025) 0%, rgba(255,255,255,0) 100%);
        text-align: left;
    }

    .auth-modal-card__title {
        margin: 0;
        font-size: var(--ui-title-section);
        line-height: 1.1;
        font-weight: 800;
        color: var(--color2);
        letter-spacing: -0.02em;
        text-align: left;
    }

    .auth-modal-card__close {
        width: 2.5rem;
        height: 2.5rem;
        border: 0;
        border-radius: .75rem;
        background: rgba(255,255,255,0.08);
        color: var(--color2);
        font-size: 1.75rem;
        line-height: 1;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        transition: all .18s ease;
    }

    .auth-modal-card__close:hover {
        background: rgba(255,255,255,0.14);
        transform: scale(1.03);
    }

    .auth-modal-card__divider {
        height: .0625rem;
        margin: 0 1.5rem;
        background: linear-gradient(90deg, transparent, rgba(255,255,255,0.14), transparent);
    }

    .auth-modal-card__body {
        padding: 1.25rem 1.5rem 1.375rem;
        color: var(--color2);
        text-align: left;
    }

    .auth-modal-card__body--signup {
        padding-top: 1.125rem;
    }

    .auth-modal-dialog--signup .auth-modal-card__body,
    .auth-modal-dialog--promo .auth-modal-card__body {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch;
    }

    .auth-form,
    .auth-signup-form,
    .auth-signup-shell,
    .auth-signup-main,
    .auth-signup-promo {
        width: 100%;
        min-width: 0;
    }

    .auth-field {
        width: 100%;
        margin-bottom: .875rem;
        min-width: 0;
        display: flex;
        flex-direction: column;
    }

    .auth-label {
        display: block;
        margin: 0 0 .4375rem;
        color: rgba(255,255,255,0.88);
        font-size: var(--ui-fs-xs);
        font-weight: 700;
        line-height: 1.2;
        text-align: left !important;
    }

    .auth-input,
    .auth-form .form-control,
    .auth-signup-form .form-control,
    .auth-signup-form select,
    .auth-signup-form input:not([type="checkbox"]):not([type="radio"]),
    .auth-signup-form textarea {
        display: block;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        min-height: 3.25rem;
        height: 3.25rem !important;
        margin: 0 !important;
        padding: 0 1rem !important;
        border-radius: .75rem !important;
        border: .0625rem solid rgba(255,255,255,0.12) !important;
        background: rgba(255,255,255,0.92) !important;
        color: #1b2430 !important;
        font-size: var(--ui-fs-md) !important;
        font-weight: 600;
        line-height: 3.25rem !important;
        box-shadow: none !important;
        transition: all .18s ease;
    }

    .auth-input::placeholder,
    .auth-signup-form .form-control::placeholder {
        color: #6f7984;
        opacity: 1;
    }

    .auth-input:focus,
    .auth-signup-form .form-control:focus,
    .auth-signup-form select:focus {
        border-color: var(--color1) !important;
        background: #ffffff !important;
        color: #141b24 !important;
        box-shadow: 0 0 0 .1875rem rgba(255,255,255,0.05) !important;
        outline: none !important;
    }

    .auth-select {
        padding-right: 2.625rem !important;
    }

    .auth-btn {
        appearance: none;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        min-height: 3.375rem;
        padding: 0 1.125rem;
        border-radius: .75rem;
        font-size: 1rem;
        font-weight: 800;
        line-height: 1;
        text-align: center !important;
        border: .0625rem solid transparent;
        transition: all .18s ease;
        cursor: pointer;
        text-decoration: none !important;
    }

    .auth-btn--primary,
    .auth-btn--primary:visited,
    .auth-btn--primary:focus,
    .auth-btn--primary:active,
    .auth-btn--primary:hover {
        background: var(--color1) !important;
        border-color: var(--color1) !important;
        color: var(--color8) !important;
        text-decoration: none !important;
    }

    .auth-btn--primary:hover,
    .auth-btn--primary:focus,
    .auth-btn--primary:active {
        transform: translateY(-.0625rem);
        box-shadow: 0 0 0 .1875rem rgba(255,255,255,0.06), 0 .75rem 1.75rem rgba(0,0,0,0.22) !important;
        outline: none !important;
    }

    .auth-btn--secondary,
    .auth-btn--secondary:visited {
        background: transparent;
        border-color: rgba(255,255,255,0.14);
        color: var(--color2) !important;
        min-height: 3.125rem;
        font-size: var(--ui-fs-md);
        font-weight: 700;
        text-decoration: none !important;
    }

    .auth-btn--secondary:hover,
    .auth-btn--secondary:focus,
    .auth-btn--secondary:active {
        background: rgba(255,255,255,0.04) !important;
        border-color: rgba(255,255,255,0.18) !important;
        color: var(--color2) !important;
        text-decoration: none !important;
        box-shadow: none !important;
        outline: none !important;
    }

    .auth-alert,
    .auth-signup-form .auth-alert,
    .auth-modal .auth-alert,
    #signupformErrori,
    #signinFormErrori,
    #passwordresetFormErrori,
    #passwordresetFormSuccess {
        width: 100%;
        margin: 0 0 1.125rem 0 !important;
        padding: 1rem 1.125rem !important;
        border-radius: .875rem !important;
        border: .0625rem solid rgba(255,255,255,0.10) !important;
        font-size: var(--ui-fs-md) !important;
        line-height: 1.45 !important;
        text-align: left !important;
        box-shadow: none !important;
    }

    #signupformErrori,
    #signinFormErrori,
    #passwordresetFormErrori {
        background: #f3cfd5 !important;
        color: #7a1f2d !important;
    }

    #passwordresetFormSuccess {
        background: rgba(34, 197, 94, 0.18) !important;
        color: #d8ffe5 !important;
    }

    .auth-confirm-email {
        width: 100%;
        min-height: 18rem;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 1rem;
        padding: 1.75rem 1rem 1.25rem;
        color: var(--color2, #fff);
        text-align: center;
    }

    .auth-confirm-email__icon {
        width: 5rem;
        height: 5rem;
        border-radius: 1.25rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border: .0625rem solid var(--color1, #00bcd4);
        color: var(--color1, #00bcd4);
        background: rgba(255,255,255,.04);
        box-shadow: 0 1rem 2.5rem rgba(0,0,0,.24);
        font-size: 2.25rem;
    }

    .auth-confirm-email h3 {
        margin: .25rem 0 0 !important;
        color: var(--color2, #fff) !important;
        font-size: 1.5rem !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-align: center !important;
    }

    .auth-confirm-email p {
        max-width: 28rem;
        margin: 0 !important;
        color: rgba(255,255,255,.78) !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
        line-height: 1.55 !important;
        text-align: center !important;
    }

    .auth-alert .alert-text,
    #signupformErrori .alert-text,
    #signinFormErrori .alert-text,
    #passwordresetFormErrori .alert-text,
    #passwordresetFormSuccess .alert-text,
    #signupformErroriLista,
    #signinFormErroriLista,
    #passwordresetFormErroriLista,
    #passwordresetFormSuccessText {
        font-size: var(--ui-fs-md) !important;
        font-weight: 700 !important;
        line-height: 1.45 !important;
        text-align: left !important;
    }

    .auth-foot-link,
    .auth-foot-link--muted {
        margin: .875rem 0 0;
        text-align: center !important;
        color: rgba(255,255,255,0.86) !important;
        font-size: .9375rem !important;
        font-weight: 500;
        line-height: 1.45 !important;
    }

    .auth-foot-link a,
    .auth-foot-link--muted a,
    .auth-link,
    .auth-link:visited {
        color: var(--color1) !important;
        font-weight: 700 !important;
        font-size: 1rem;
        text-decoration: none !important;
        border-bottom: .0625rem solid rgba(243,196,0,0.35) !important;
        box-shadow: none !important;
        outline: none !important;
    }

    .auth-foot-link a:hover,
    .auth-foot-link a:focus,
    .auth-foot-link a:active,
    .auth-foot-link--muted a:hover,
    .auth-foot-link--muted a:focus,
    .auth-foot-link--muted a:active,
    .auth-link:hover,
    .auth-link:focus,
    .auth-link:active {
        color: var(--color1) !important;
        border-bottom-color: var(--color1) !important;
        text-decoration: none !important;
        outline: none !important;
        filter: brightness(1.05);
    }

    .auth-note {
        margin-bottom: 1rem;
        padding: .875rem 1rem;
        border-radius: .75rem;
        background: rgba(255,255,255,0.04);
        border: .0625rem solid rgba(255,255,255,0.06);
        text-align: left !important;
    }

    .auth-note ul {
        margin: 0;
        padding-left: 1.25rem;
        color: rgba(255,255,255,0.76);
        font-size: var(--ui-fs-sm);
        line-height: 1.5;
        text-align: left !important;
    }

    .auth-note li {
        margin-bottom: .375rem;
        text-align: left !important;
    }

    .auth-brand-block {
        margin-top: 1.125rem;
        padding-top: 1.125rem;
        border-top: .0625rem solid rgba(255,255,255,0.10);
        text-align: center;
    }

    .auth-brand-logo {
        width: 7.5rem;
        max-width: 70%;
        display: block;
        margin: 0 auto .375rem;
    }

    .auth-brand-text {
        text-align: center !important;
        margin: 0 0 .75rem 0 !important;
        color: rgba(255,255,255,0.72);
        font-size: var(--ui-fs-base);
    }

    .auth-signup-shell--promo {
        display: grid;
        grid-template-columns: 20rem minmax(0, 1fr);
        gap: 1.375rem;
        align-items: start;
    }

    .auth-signup-promo__title {
        margin: 0 0 .875rem;
        font-size: 1.375rem;
        font-weight: 800;
        color: var(--color2);
    }

    .auth-signup-promo__title svg {
        width: 1.25rem;
        height: 1.25rem;
        margin: 0 .5rem .1875rem 0;
        fill: var(--color1);
    }

    .auth-signup-promo__card {
        overflow: hidden;
        border-radius: var(--ui-radius-xl);
        background: rgba(255,255,255,0.04);
        border: .0625rem solid rgba(255,255,255,0.08);
        box-shadow: var(--ui-shadow-md);
    }

    .auth-signup-promo__card img {
        display: block;
        width: 100%;
    }

    .auth-signup-promo__content {
        padding: 1rem;
    }

    .auth-signup-promo__content h5 {
        margin: 0 0 .5rem;
        color: var(--color2);
        font-size: var(--ui-fs-xl);
        font-weight: 700;
    }

    .auth-signup-promo__content p {
        margin: 0;
        color: rgba(255,255,255,0.72);
        font-size: var(--ui-fs-base);
        line-height: 1.45;
    }

    .auth-form-section,
    .auth-signup-form .auth-form-section {
        margin: 0 0 1rem 0 !important;
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .auth-form-section:last-child,
    .auth-signup-form .auth-form-section:last-child {
        margin-bottom: 0 !important;
    }

    .auth-grid,
    .auth-signup-form .auth-grid {
        display: grid;
        width: 100%;
        gap: 1rem !important;
        align-items: start;
    }

    .auth-grid--1,
    .auth-signup-form .auth-grid--1 {
        grid-template-columns: 1fr;
    }

    .auth-grid--2,
    .auth-signup-form .auth-grid--2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .auth-grid--address,
    .auth-signup-form .auth-grid--address {
        grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    }

    .auth-grid--birthday,
    .auth-signup-form .auth-grid--birthday {
        grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    }

    .auth-inline-selects,
    .auth-signup-form .auth-inline-selects {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: .625rem;
        width: 100%;
    }

    .auth-inline-selects > *,
    .auth-signup-form .auth-inline-selects > * {
        min-width: 0;
    }

    .auth-input-group {
        display: flex;
        align-items: stretch;
        width: 100%;
        flex-wrap: nowrap !important;
    }

    .auth-input-group .auth-input,
    .auth-input-group .form-control {
        flex: 1 1 auto;
        width: 1% !important;
        min-width: 0 !important;
        margin: 0 !important;
        border-top-right-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
    }

    .auth-input-group__append {
        display: flex;
        flex: 0 0 auto;
    }

    .auth-input-group__text {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 3.375rem;
        min-width: 3.375rem;
        height: 3.25rem;
        padding: 0 !important;
        border: .0625rem solid rgba(255,255,255,0.12);
        border-left: 0 !important;
        background: rgba(255,255,255,0.92);
        color: #273241;
        border-top-right-radius: .75rem !important;
        border-bottom-right-radius: .75rem !important;
        box-sizing: border-box;
    }

    .auth-input-group__text a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        color: #16d4d4;
        text-decoration: none;
    }

    .auth-checks {
        display: grid !important;
        gap: .875rem !important;
        margin-top: 1rem !important;
        margin-bottom: .875rem !important;
        text-align: left !important;
        align-items: flex-start !important;
    }

    .auth-check {
        display: grid !important;
        grid-template-columns: 1.625rem minmax(0, 1fr) !important;
        column-gap: .75rem !important;
        align-items: start !important;
        justify-content: flex-start !important;
        color: rgba(255,255,255,0.92) !important;
        font-size: 1rem !important;
        line-height: 1.45 !important;
        cursor: pointer;
        user-select: none;
        -webkit-tap-highlight-color: transparent;
        text-align: left !important;
    }

    .auth-check span {
        display: block !important;
        min-width: 0;
        font-size: 1rem !important;
        line-height: 1.45 !important;
        color: rgba(255,255,255,0.92) !important;
    }

    .auth-check input[type="checkbox"],
    .auth-signup-form input[type="checkbox"] {
        appearance: none !important;
        -webkit-appearance: none !important;
        width: 1.375rem !important;
        height: 1.375rem !important;
        min-width: 1.375rem !important;
        min-height: 1.375rem !important;
        max-width: 1.375rem !important;
        max-height: 1.375rem !important;
        margin: .0625rem 0 0 0 !important;
        padding: 0 !important;
        border-radius: .3125rem !important;
        border: .125rem solid rgba(255,255,255,0.72) !important;
        background: rgba(255,255,255,0.96) !important;
        box-shadow: none !important;
        position: relative;
        cursor: pointer;
        flex: 0 0 1.375rem !important;
    }

    .auth-check input[type="checkbox"]:checked,
    .auth-signup-form input[type="checkbox"]:checked {
        background: var(--color1) !important;
        border-color: var(--color1) !important;
    }

    .auth-check input[type="checkbox"]:checked::after,
    .auth-signup-form input[type="checkbox"]:checked::after {
        content: "";
        position: absolute;
        left: .375rem;
        top: .0625rem;
        width: .3125rem;
        height: .625rem;
        border: solid #1b2430;
        border-width: 0 .125rem .125rem 0;
        transform: rotate(45deg);
    }

    .auth-check input[type="checkbox"]:focus,
    .auth-signup-form input[type="checkbox"]:focus {
        outline: none !important;
        box-shadow: 0 0 0 .1875rem rgba(255,255,255,0.08) !important;
    }

    .auth-check a,
    .auth-check a:visited {
        color: var(--color1) !important;
        text-decoration: none !important;
        border-bottom: .0625rem solid rgba(243,196,0,0.35) !important;
        font-weight: 700 !important;
    }

    .auth-check a:hover,
    .auth-check a:focus,
    .auth-check a:active {
        color: var(--color1) !important;
        border-bottom-color: var(--color1) !important;
        text-decoration: none !important;
        outline: none !important;
    }

    .auth-signup-form .row,
    .auth-signup-form .margin-regulation,
    .auth-signup-form .margin-regulation2,
    .auth-signup-form .pd-l-2,
    .auth-signup-form .pd-r-2,
    .auth-signup-form .margin-bottom-5,
    .auth-signup-form .color-top {
        all: unset;
    }

    .auth-signup-form span#residence_selprovmsg,
    .auth-signup-form span#selprovmsg,
    .auth-signup-form span#cliente_city_residence_box,
    .auth-signup-form span#cliente_citta,
    .auth-signup-form .auth-dynamic-slot,
    .auth-signup-form #residence_selprovmsg,
    .auth-signup-form #selprovmsg,
    .auth-signup-form #cliente_city_residence_box,
    .auth-signup-form #cliente_citta {
        display: block;
        width: 100%;
        margin: 0 !important;
        padding: 0 !important;
    }

    .auth-signup-form #residence_selprovmsg select,
    .auth-signup-form #selprovmsg select,
    .auth-signup-form #cliente_city_residence_box select,
    .auth-signup-form #cliente_citta select,
    .auth-signup-form #cliente_city_residence_box input,
    .auth-signup-form #cliente_citta input {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        min-height: 3.125rem !important;
        height: 3.125rem !important;
        margin: 0 !important;
        padding: 0 2.5rem 0 1rem !important;
        border-radius: .75rem !important;
        border: .0625rem solid rgba(255,255,255,0.12) !important;
        background: rgba(255,255,255,0.92) !important;
        color: #1b2430 !important;
        font-size: .875rem !important;
        font-weight: 600 !important;
        line-height: 3.125rem !important;
        box-shadow: none !important;
    }

    .auth-signup-form #residence_selprovmsg select:focus,
    .auth-signup-form #selprovmsg select:focus,
    .auth-signup-form #cliente_city_residence_box select:focus,
    .auth-signup-form #cliente_citta select:focus,
    .auth-signup-form #cliente_city_residence_box input:focus,
    .auth-signup-form #cliente_citta input:focus {
        border-color: var(--color1) !important;
        background: #ffffff !important;
        color: #141b24 !important;
        box-shadow: 0 0 0 .1875rem rgba(255,255,255,0.05) !important;
        outline: none !important;
    }

    .auth-signup-form .geo_residence_italy[style*="display:none"],
    .auth-signup-form .geo_residence_estero[style*="display:none"],
    .auth-signup-form .geo_italy[style*="display:none"],
    .auth-signup-form .geo_estero[style*="display:none"],
    .auth-signup-form #residence_selprovmsg[style*="display:none"],
    .auth-signup-form #selprovmsg[style*="display:none"],
    .auth-signup-form #cliente_city_residence_box[style*="display:none"],
    .auth-signup-form #cliente_citta[style*="display:none"] {
        display: none !important;
    }

    .auth-signup-form #city_residence_wrapper,
    .auth-signup-form #div_cliente_citta {
        gap: 0 !important;
    }

    .auth-signup-form #city_residence_wrapper > .auth-label,
    .auth-signup-form #div_cliente_citta > .auth-label {
        margin-bottom: .375rem !important;
    }

    .auth-signup-form #fiscal_code_area .auth-input-group {
        display: flex !important;
        align-items: stretch !important;
        width: 100% !important;
        flex-wrap: nowrap !important;
    }

    .auth-signup-form #fiscal_code_area .auth-input-group > .auth-input,
    .auth-signup-form #fiscal_code_area .auth-input-group > .form-control,
    .auth-signup-form #fiscal_code_area .auth-input-group input#fiscal_code {
        flex: 1 1 auto !important;
        width: 1% !important;
        min-width: 0 !important;
        margin: 0 !important;
        border-top-right-radius: 0 !important;
        border-bottom-right-radius: 0 !important;
        border-right: 0 !important;
    }

    .auth-signup-form #fiscal_code_area .auth-input-group__append {
        display: flex !important;
        flex: 0 0 3.375rem !important;
        width: 3.375rem !important;
        min-width: 3.375rem !important;
        max-width: 3.375rem !important;
        margin: 0 !important;
    }

    .auth-signup-form #fiscal_code_area .auth-input-group__text {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 3.375rem !important;
        min-width: 3.375rem !important;
        height: 3.25rem !important;
        padding: 0 !important;
        margin: 0 !important;
        border: .0625rem solid rgba(255,255,255,0.12) !important;
        border-left: 0 !important;
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: 0 !important;
        border-top-right-radius: .75rem !important;
        border-bottom-right-radius: .75rem !important;
        background: rgba(255,255,255,0.92) !important;
        box-sizing: border-box !important;
    }

    .auth-signup-form #fiscal_code_area .auth-input-group__text a {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        height: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        text-decoration: none !important;
    }

    .auth-link-back {
        display: block;
        text-align: center;
    }

    @media all and (max-width: 61.9375rem) {
        .auth-modal-dialog {
            width: calc(100% - 1.5rem);
        }

        .auth-signup-shell--promo {
            grid-template-columns: 1fr;
        }
    }

    @media all and (max-width: 36rem) {
        .auth-modal-dialog {
            width: calc(100% - 1rem);
            margin: .5rem auto;
        }

        .auth-modal-dialog--signup,
        .auth-modal-dialog--promo {
            height: calc(100vh - 1rem);
            max-height: calc(100vh - 1rem);
            margin: .5rem auto;
        }

        .auth-modal-card {
            border-radius: 1.125rem;
        }

        .auth-modal-card__header {
            padding: 1.125rem 1rem .875rem;
        }

        .auth-modal-card__body {
            padding: 1rem 1rem 1.125rem;
        }

        .auth-modal-dialog--signup .auth-modal-card__body,
        .auth-modal-dialog--promo .auth-modal-card__body {
            padding-bottom: 1.75rem !important;
        }

        .auth-modal-card__divider {
            margin: 0 1rem;
        }

        .auth-modal-card__title {
            font-size: 1.3125rem;
        }

        .auth-modal-card__close {
            width: 2.375rem;
            height: 2.375rem;
            font-size: 1.625rem;
            border-radius: .625rem;
        }

        .auth-input,
        .auth-form .form-control,
        .auth-signup-form .form-control,
        .auth-signup-form select,
        .auth-signup-form input:not([type="checkbox"]):not([type="radio"]),
        .auth-signup-form textarea {
            min-height: 3rem;
            height: 3rem !important;
            line-height: 3rem !important;
            font-size: .9375rem !important;
            border-radius: .625rem !important;
            padding: 0 .875rem !important;
        }

        .auth-btn {
            min-height: 3.25rem;
            border-radius: .625rem;
            font-size: 1.0625rem;
        }

        .auth-grid--2,
        .auth-grid--address,
        .auth-grid--birthday,
        .auth-signup-form .auth-grid--2,
        .auth-signup-form .auth-grid--address,
        .auth-signup-form .auth-grid--birthday {
            grid-template-columns: 1fr;
        }

        .auth-inline-selects,
        .auth-signup-form .auth-inline-selects {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: .5rem;
        }

        .auth-brand-logo {
            width: 6.875rem;
        }

        .auth-alert,
        .auth-signup-form .auth-alert,
        #signupformErrori,
        #signinFormErrori,
        #passwordresetFormErrori,
        #passwordresetFormSuccess {
            padding: .875rem .875rem !important;
            margin-bottom: 1rem !important;
            border-radius: .75rem !important;
        }

        .auth-alert .alert-text,
        #signupformErrori .alert-text,
        #signinFormErrori .alert-text,
        #passwordresetFormErrori .alert-text,
        #passwordresetFormSuccess .alert-text,
        #signupformErroriLista,
        #signinFormErroriLista,
        #passwordresetFormErroriLista,
        #passwordresetFormSuccessText {
            font-size: .875rem !important;
            line-height: 1.45 !important;
        }

        .auth-checks {
            gap: 1rem !important;
            margin-top: 1.125rem !important;
            margin-bottom: 1rem !important;
        }

        .auth-check {
            grid-template-columns: 1.75rem minmax(0, 1fr) !important;
            column-gap: .75rem !important;
            font-size: .9375rem !important;
            line-height: 1.5 !important;
        }

        .auth-check span {
            font-size: .9375rem !important;
            line-height: 1.5 !important;
        }

        .auth-check input[type="checkbox"],
        .auth-signup-form input[type="checkbox"] {
            width: 1.5rem !important;
            height: 1.5rem !important;
            min-width: 1.5rem !important;
            min-height: 1.5rem !important;
            max-width: 1.5rem !important;
            max-height: 1.5rem !important;
            flex: 0 0 1.5rem !important;
            border-radius: .375rem !important;
        }

        .auth-check input[type="checkbox"]:checked::after,
        .auth-signup-form input[type="checkbox"]:checked::after {
            left: .4375rem;
            top: .125rem;
        }

        .auth-signup-form #residence_selprovmsg select,
        .auth-signup-form #selprovmsg select,
        .auth-signup-form #cliente_city_residence_box select,
        .auth-signup-form #cliente_citta select,
        .auth-signup-form #cliente_city_residence_box input,
        .auth-signup-form #cliente_citta input {
            min-height: 3rem !important;
            height: 3rem !important;
            line-height: 3rem !important;
            padding: 0 2.25rem 0 .75rem !important;
            border-radius: .625rem !important;
            font-size: .875rem !important;
        }

        .auth-input-group__text {
            height: 3rem;
            width: 3.125rem;
            min-width: 3.125rem;
            border-top-right-radius: .625rem !important;
            border-bottom-right-radius: .625rem !important;
        }

        .auth-signup-form #fiscal_code_area .auth-input-group__append {
            flex: 0 0 3.125rem !important;
            width: 3.125rem !important;
            min-width: 3.125rem !important;
            max-width: 3.125rem !important;
        }

        .auth-signup-form #fiscal_code_area .auth-input-group__text {
            width: 3.125rem !important;
            min-width: 3.125rem !important;
            height: 3rem !important;
            border-top-right-radius: .625rem !important;
            border-bottom-right-radius: .625rem !important;
        }

        .auth-foot-link,
        .auth-foot-link--muted {
            font-size: .9375rem !important;
        }

        .auth-foot-link .auth-link,
        .auth-foot-link--muted .auth-link {
            font-size: .9375rem !important;
        }
    }
