: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-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-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;
}

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.95rem;
}

.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 */