:root {
    --bs-body-font-family: "Roobert ENEL", Arial, sans-serif;
    /*--bs-body-bg: #F7F8FB;*/
    --bs-body-bg: #EFF2F7;
    --bs-body-color: #0E141A;
    --bs-body-color-rgb: 14,20,26;
    --bs-white: #FFFFFF;
    --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
    --bs-border-width: 1px;

    --bs-link-color: var(--bs-enel);
    --bs-link-color-rgb: var(--bs-enel-rgb);
    --bs-link-hover-color: var(--bs-enel-shade-10);
    --bs-link-hover-color-rgb: var(--bs-enel-shade-20);

    --bs-secondary: #6c757d;
    --bs-secondary-rgb: 108, 117, 125;

    --bs-enel: #d3145a;
    --bs-enel-rgb: 211, 20, 90;
    --bs-enel-shade-10: #be1251;
    --bs-enel-shade-10-rgb: 190, 18, 81;
    --bs-enel-shade-20: #a91048;
    --bs-enel-shade-20-rgb: 169, 16, 72;

    --bs-mission: #0047CC;
    --bs-mission-rgb: 0, 71, 204;

    --bs-badge: #0047CC;
    --bs-badge-rgb: 0, 71, 204;

    --bs-coupon: #0047CC;
    --bs-coupon-rgb: 0, 71, 204;

    --bs-expired: #6c757d;
    --bs-expired-rgb: 108, 117, 125;

    --bs-avvento: var(--bs-enel);
    --bs-avvento-rgb: var(--bs-enel-rgb);

    --bs-tier_1: #55BE5A;
    --bs-tier_1-rgb: 85, 190, 90;
    --bs-tier_2: #0047CC;
    --bs-tier_2-rgb: 0, 71, 204;
    --bs-tier_3: #D3135A;
    --bs-tier_3-rgb: 211, 19, 90;

    --header-height: "";
    --navbar-top-height: "";
    --navbar-bottom-height: "";

    --bs-danger-rgb: 220, 53, 69;
}

.page-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    opacity: 1;
    transition: opacity 0.5s ease-out, visibility 0.5s ease-out;
}

.page-loader.hidden {
    opacity: 0;
    visibility: hidden;
}

.loader-content {
    text-align: center;
}

.spinner {
    width: 60px;
    height: 60px;
    margin: 0 auto 20px;
    border: 5px solid rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    border-top-color: var(--bs-enel);
    animation: spin 1s ease-in-out infinite;
}

.loading-text {
    color: #333;
    font-size: 1rem;
    margin: 0;
}

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

.skip-link {
    position: absolute;
    top: -50px;
    left: 10px;
    padding: 10px 15px;
    background-color: var(--bs-white);
    color: var(--bs-enel);
    border: 2px solid var(--bs-enel);
    border-radius: var(--bs-border-radius);
    z-index: 9999;
    text-decoration: none;
    transition: top 0.3s;
}

.skip-link:focus {
    top: 10px;
    outline: 3px solid var(--bs-enel);
    outline-offset: 2px;
}

.btn:focus,
.nav-link:focus {
    outline: 2px solid var(--bs-enel) !important;
    outline-offset: 2px !important;
    border-radius: var(--bs-border-radius, 4px) !important;
}

.link-light:focus {
    outline: 2px solid var(--bs-white) !important;
}

.link-enel {
    color: var(--bs-enel);
}

.box-shadow-0 {
    box-shadow: none !important;
}

#body,
#body.scrolled-up {
    padding-top: var(--header-height, 0px);
    transition: padding-top 0.3s ease-in-out;
}

#body.scrolled-down {
    padding-top: calc(-1 * var(--header-height, 100%));
    transition: padding-top 0.3s ease-in-out;
}

#body.offcanvas-open .header {
    top: 0;
    height: 100vh;
    transition: height 0.3s ease-in-out;
}

#header {
    border-bottom: 1px solid #C2CDDD;
}

.navbar.bg-body {
    --bs-navbar-bg: #EFF2F7;
    background-color: var(--bs-navbar-bg) !important;
}

.navbar-brand {
    --bs-navbar-brand-font-size: 1rem;
    font-size: var(--bs-navbar-brand-font-size);
}

@media (max-width: 767px) {
    .navbar-brand.position-absolute {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 1;
        font-weight: bold;
        margin: 0;
    }
}

#footer {
    --bs-footer-bg: var(--bs-body-bg);
    border-top: 1px solid #C2CDDD;
    background-color: var(--bs-footer-bg);
}

.w-inherit {
    width: inherit !important;
}

.btn {
    --bs-btn-padding-x: 1rem;
    --bs-btn-padding-y: .5rem;
    --bs-btn-font-family: var(--bs-body-font-family);
    --bs-btn-border-radius: 4px;
    /* width: 100%; */
    /* display: block; */
    white-space: nowrap;
}

@media (max-width: 767px) {
    .btn {
        width: 100%;
        display: block;
    }
}

.btn-sm, .btn-group-sm > .btn {
    --bs-btn-padding-x: 1rem;
    --bs-btn-padding-y: .5rem;
    --bs-btn-font-size: 0.875rem;
    --bs-btn-border-radius: 0;
}

.btn-light {
    --bs-btn-color: var(--bs-enel);
    --bs-btn-bg: #f8f9fa;
    --bs-btn-border-color: #f8f9fa;
    --bs-btn-hover-color: var(--bs-enel);
    --bs-btn-hover-bg: #d3d4d5;
    --bs-btn-hover-border-color: #c6c7c8;
    --bs-btn-focus-shadow-rgb: 211, 212, 213;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #c6c7c8;
    --bs-btn-active-border-color: #babbbc;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #000;
    --bs-btn-disabled-bg: #f8f9fa;
    --bs-btn-disabled-border-color: #f8f9fa;
}

.btn-enel {
    --bs-btn-color: var(--bs-white);
    --bs-btn-bg: var(--bs-enel);
    --bs-btn-border-color: var(--bs-enel);
    --bs-btn-hover-color: var(--bs-white);
    --bs-btn-hover-bg: var(--bs-enel-shade-10);
    --bs-btn-hover-border-color: var(--bs-enel-shade-10);
    --bs-btn-focus-shadow-rgb: var(--bs-enel-rgb);
    --bs-btn-active-color: var(--bs-btn-hover-color);
    --bs-btn-active-bg: var(--bs-enel-shade-20);
    --bs-btn-active-border-color: var(--bs-enel-shade-20);
}

.btn-outline-enel {
    --bs-btn-color: var(--bs-enel);
    --bs-btn-border-color: var(--bs-enel);
    --bs-btn-hover-color: var(--bs-white);
    --bs-btn-hover-bg: var(--bs-enel);
    --bs-btn-hover-border-color: var(--bs-enel);
    --bs-btn-focus-shadow-rgb: var(--bs-enel-rgb);
    --bs-btn-active-color: var(--bs-white);
    --bs-btn-active-bg: var(--bs-enel);
    --bs-btn-active-border-color: var(--bs-enel);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: var(--bs-enel);
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: var(--bs-enel);
    --bs-gradient: none;
}

.btn-link {
    text-decoration: none;
}

.bg-enel {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-enel-rgb), var(--bs-bg-opacity,1)) !important;
}

.text-bg-enel {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.text-enel {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-enel-rgb), var(--bs-text-opacity,1)) !important;
}

.text-light {
    --bs-light: #667790;
    --bs-light-rgb: 102, 119, 144;
    --bs-text-opacity: 1;
    color: rgba(var(--bs-light-rgb), var(--bs-text-opacity,1)) !important;
}

.badge {
    --bs-badge-padding-x: 1em;
    --bs-badge-padding-y: .5em;
    text-transform: none;
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-badge-rgb),var(--bs-bg-opacity,1));
}

.text-bg-secondary {
    color: #fff !important;
    background-color: RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.badge-mission {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-mission-rgb),var(--bs-bg-opacity,1))!important;
}

.badge-contest {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-mission-rgb),var(--bs-bg-opacity,1))!important;
}

.badge-coupon {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-coupon-rgb),var(--bs-bg-opacity,1))!important;
}

.badge-expired {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-expired-rgb),var(--bs-bg-opacity,1))!important;
}

.badge-avvento {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-avvento-rgb),var(--bs-bg-opacity,1))!important;
}

.badge-default {
    color: #fff !important;
    background-color: RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.item-Mission_Hero-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-mission-rgb),var(--bs-bg-opacity,1))!important;
}

.main-Hero-bg {
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.main-Card-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.mission-Hero-bg {
    background-color: rgba(var(--bs-mission-rgb),var(--bs-bg-opacity,1))!important;
}

.mission-Card-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-mission-rgb),var(--bs-bg-opacity,1))!important;
}

.contest-Hero-bg {
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.contest-Card-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.coupon-Hero-bg {
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.coupon-Card-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.catalog-Hero-bg {
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.catalog-Card-bg {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-enel-rgb),var(--bs-bg-opacity,1))!important;
}

.text-bg-badge {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-badge-rgb),var(--bs-bg-opacity,1))!important;
}

.text-tier_1 {
    color: var(--bs-tier_1) !important;
}

.text-bg-tier_1 {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-tier_1-rgb),var(--bs-bg-opacity,1))!important;
}

.text-tier_2 {
    color: var(--bs-tier_2) !important;
}

.text-bg-tier_2 {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-tier_2-rgb),var(--bs-bg-opacity,1))!important;
}

.text-tier_3 {
    color: var(--bs-tier_3) !important;
}

.text-bg-tier_3 {
    color: var(--bs-white) !important;
    background-color: rgba(var(--bs-tier_3-rgb),var(--bs-bg-opacity,1))!important;
}

.card {
    --bs-border-radius: 12px;
    --bs-card-spacer-y: 1rem;
    --bs-card-spacer-x: 1rem;
    --bs-card-title-color: var(--bs-body-color);
    --bs-card-subtitle-color: #667790;
    --bs-card-border-width: var(--bs-border-width);
    --bs-card-border-color: var(--bs-border-color-translucent);
    --bs-card-border-radius: var(--bs-border-radius);
    --bs-card-box-shadow: ;
    --bs-card-cap-padding-y: 0.5rem;
    --bs-card-cap-padding-x: 1rem;
    --bs-card-cap-bg: rgba(var(--bs-body-color-rgb), 0.03);
    --bs-card-cap-color: ;
    --bs-card-inner-border-radius: var(--bs-border-radius);
    --bs-card-box-shadow: 0 0 16px 0 rgba(102, 119, 144, 0.40);
    --bs-card-bg: var(--bs-white);
    padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
    border-bottom-right-radius: var(--bs-card-inner-border-radius);
    border-bottom-left-radius: var(--bs-card-inner-border-radius);
    box-shadow: var(--bs-card-box-shadow);
    /* overflow: hidden; */
}

.card-header {
    padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
    background-color: var(--bs-card-cap-bg);
    border-bottom: 0;
}
.card-header:first-child {
    border-radius: var(--bs-card-border-radius);
}

.card-header {
    background-color: var(--bs-white);
    border: none;
    padding: 0;
    border-radius: var(--bs-border-radius);
    overflow: hidden;
}

.card-body {
    padding: var(--bs-card-spacer-y) .5rem;
}

.card-link {
    display: block;
    color: var(--bs-body-color);
}

.card-body:last-of-type {
    padding-bottom: 0 !important;
}

.card-footer {
    position: relative;
    border-radius: 4px !important;
    border-top: 0;
    width: initial;
    box-shadow: 0 2px 4px 0 rgba(102, 119, 144, 0.20);
}

.card-footer.unset-style {
    border-radius: 0 !important;
    box-shadow: none !important;
}

.card-footer.unset-style::before {
    content: none;
}

.card-footer::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: linear-gradient(180deg,#f7f8fb,rgba(247,248,251,0));
    border-bottom: 1px solid #c2cddd;
}

.card-footer p {
    background: linear-gradient(90deg, #0047CC 0%, #3B80FF 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    letter-spacing: -1px;
    position: relative;
    z-index: 1;
}

.card-footer p.text-primary {
    background: linear-gradient(90deg, #0a57ca 0%, #3d8afd 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.card-footer p.text-secondary {
    background: linear-gradient(90deg, #565e64 0%, #899197 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.card-footer p.text-success {
    background: linear-gradient(90deg, #146c43 0%, #479f76 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

img.border-radius {
    border-radius: 12px;
}

.ribbon {
    position: absolute;
    top: 0;
    left: 10%;
    box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.25);
    transform: translateY(-16px);
    z-index: 1;
}

.ribbon-white {
    background: #EFF2F7;
}

.ribbon-yellow {
    --bs-yellow-start: #F5B500;
    --bs-yellow-end: #FFD966;
    background-image: linear-gradient(to bottom, var(--bs-yellow-start) 0%, var(--bs-yellow-end) 100%);
}

.ribbon::before {
    content: '';
    width: 8px;
    height: 16px;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(8px, -1px);
    background: url("https://d1yu433m0th68r.cloudfront.net/loyalty2025-ribbon-clip.svg") no-repeat center scroll transparent;
    background-size: cover;
}

.ribbon::after {
    content: '';
    width: 100%;
    height: 20px;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    transform: translateY(100%);
    background-size: cover;
}

.ribbon-white::after {
    background: url("https://d1yu433m0th68r.cloudfront.net/loyalty2025-ribbon-white_bottom.svg") no-repeat center scroll transparent;
}

.ribbon-yellow::after {
    background: url("https://d1yu433m0th68r.cloudfront.net/loyalty2025-ribbon-yellow_bottom.svg") no-repeat center scroll transparent;
}

.section-Hero_Homepage {
    background: url("https://d1yu433m0th68r.cloudfront.net/loyalty2025-hero-bg.jpg") no-repeat center scroll transparent;
    background-size: cover;
}

.section-Hero_Bg .card .card-body {
    color: var(--bs-white) !important;
}

@media (max-width: 767px) {
    .section-Hero_Bg {
        background-color: transparent !important;
    }
}

@media (min-width: 768px) {
    .section-Hero_Bg .card {
        border-radius: 0;
        box-shadow: none;
        border: none;
        background: none;
    }
}

img.entity-Img {
    max-height: 386px;
}

.entity-Widget {
    top: calc(var(--navbar-bottom-height) + 1rem);
}

.entity-Widget .btn {
    display: block;
}

.list-group {
    --bs-list-group-bg: var(--bs-white);
}

.list-group-item {
    padding: 0;
    border: none;
}

/* Migliora visibilità stato focus per controlli Splide */
.splide__arrow:focus,
.splide__pagination__page:focus {
    outline: 3px solid var(--bs-enel);
    outline-offset: 2px;
}

/* Assicura contrasto adeguato per i controlli di navigazione */
.splide__arrow {
    /* background: rgba(255, 255, 255, 0.9); */
    opacity: 1;
}

.splide__arrow svg,
.splide__arrow:hover:not(:disabled) svg {
    fill: var(--bs-enel);
}

.splide__arrow:disabled {
    opacity: 0 !important;
}

.splide__pagination__page {
    opacity: .9;
}
.splide__pagination__page:hover,
.splide__pagination__page.is-active {
    background: var(--bs-enel);
    opacity: 1;
}

/* navbar top autohide */
.autohide {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
    z-index: 1030;
    transition: bottom 0.3s ease-in-out;
}

.header.scrolled-down {
    transform: translateY(calc(-1 * var(--navbar-top-height, 100%)));
    transition: all 0.3s ease-in-out;
}

.header.scrolled-up {
    transform: translateY(0);
    transition: all 0.3s ease-in-out;
}

@media (max-width: 767px) {
    .header.scrolled-down .offcanvas {
        padding-top: var(--navbar-top-height, 100%);
        height: calc(100vh + var(--navbar-top-height, 100%));
    }
}

.header.scrolled-down .offcanvas-backdrop {
    height: calc(100vh + var(--navbar-top-height, 100%));
}
/* navbar top autohide */

.form-control {
    border-radius: 4px;
}

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

/* Personalizzazione checkbox */
.form-check-input {
    border-radius: 4px;
    width: 1.25rem;
    height: 1.25rem;
    border: 2px solid #c2cddd;
    cursor: pointer;
    margin-top: 0.25rem;
    position: relative;
    transition: all 0.2s ease-in-out;
}

.bg-enel .form-check-input:checked {
    background-color: var(--bs-enel);
    border-color: var(--bs-white);
}
.form-check-input:checked {
    background-color: var(--bs-enel);
    border-color: var(--bs-enel);
}

.bg-enel .form-check-input:focus {
    border-color: var(--bs-white);
    box-shadow: 0 0 0 0.25rem rgba(0, 71, 204, 0.25);
}
.form-check-input:focus {
    border-color: var(--bs-enel);
    box-shadow: 0 0 0 0.25rem rgba(0, 71, 204, 0.25);
}

.form-check-label {
    cursor: pointer;
    padding-left: 0.5rem;
    font-size: 0.85rem;
}

.bg-enel .form-check-input:hover {
    border-color: var(--bs-white);
}
.form-check-input:hover {
    border-color: var(--bs-enel);
}

/* Stile per stato disabilitato */
.form-check-input:disabled,
.form-check-input[disabled] ~ .form-check-label {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Animazione al click */
.form-check-input:active {
    transform: scale(0.85);
    transition: transform 0.1s;
}

/* Effetto checkmark personalizzato */
.form-check-input:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 6px;
    height: 10px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: translate(-50%, -60%) rotate(45deg);
    animation: checkmark 0.3s ease-in-out;
}

@keyframes checkmark {
    0% {
        opacity: 0;
        transform: translate(-50%, -60%) rotate(45deg) scale(0.5);
    }
    50% {
        opacity: 1;
        transform: translate(-50%, -60%) rotate(45deg) scale(1.2);
    }
    100% {
        opacity: 1;
        transform: translate(-50%, -60%) rotate(45deg) scale(1);
    }
}

.form-switch .form-check-input:checked::after {
    display: none;
}

.modal {
    --bs-modal-bg: var(--bs-white);
}

@media (max-width: 767px) {
    .controls {
        overflow-x: scroll;
        --bs-gutter-x: 1.5rem;
        margin-right: calc(-0.5 * var(--bs-gutter-x));
        margin-left: calc(-0.5 * var(--bs-gutter-x));
    }
}

.bg-banner_tier {
    background-color: var(--bs-body-bg);
}

.surveyForm .radioButtonContainerId {}
.surveyForm .radioButtonContainerId .form-check {
    padding-left: 0;
}
.surveyForm .radioButtonContainerId .form-check:last-of-type {
    margin-bottom: 0 !important;
}
.surveyForm .radioButtonContainerId .form-check-input {
    margin: 0;
    transform: translateY(-50%);
    top: 50%;
    left: 10px;
    position: absolute;
}
.surveyForm .radioButtonContainerId .form-check-input:checked[type=radio]:after {
    content: none;
}
.surveyForm .radioButtonContainerId label {
    padding-left: 40px;
    border-radius: 12px;
    border: 1px solid #C3CEDD;
    transition: all ease-in-out 0.2s;
    white-space: normal;
}

.surveyForm .radioButtonContainerId .form-check-input:checked+label,
.surveyForm .radioButtonContainerId .form-check-input+label:hover {
    border-color: #272C34;
    background: #F7F8FB;
    color: var(--bs-enel);
}

/* fixOld */
.text-brand {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important;
}

.hide {
    display: none !important;
}

.sr-only {
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

.sr-only:not(caption) {
    position: absolute !important;
}
/* /fixOld */