/* path: wp-content/plugins/Bizdash/assets/css/wizard-front.css */
/* ======================================================================
   BIZDASH · WIZARD FRONT – GOLD STANDARD UI
   Usa Bizdash Design System (BDS) con variabili --bz-*.
   ---------------------------------------------------------------------- */

/* ========================= TOKENS & THEME VARS ========================= */
.promo-banner-capitolo{
  /* GLASS - basato su tertiary */
  --glass-blur: 28px;
  --glass-bg: color-mix(in srgb, var(--bz-secondary-dark-4) 90%, transparent);
  --glass-border: var(--bz-light-20);
  --glass-shadow: var(--bz-shadow-xl);
  --glass-radius: var(--bz-radius-xl);
  --glass-inner-glow: inset 0 1px 0 var(--bz-light-15);

  color-scheme: dark;
}

/* Design tokens locali - mapped to BDS where possible */
.promo-banner-capitolo{
  /* Typography - mapped to BDS scale */
  --ff: var(--bz-font-body);
  --fs-body:  var(--bz-text-base);           /* 16px */
  --fs-small: var(--bz-text-sm);             /* 14px */
  --fs-cta:   var(--bz-text-lg);             /* 18px */
  --fs-h1:    var(--bz-text-2xl);            /* 24px */
  --fs-lead-title: var(--bz-text-lg);        /* 18px */

  /* Line heights - BDS scale */
  --lh-tight: var(--bz-leading-tight);       /* 1.15 */
  --lh-body:  var(--bz-leading-relaxed);     /* 1.65 */

  /* CTA heights - BDS button scale */
  --cta-h: var(--bz-btn-height-md);          /* 44px WCAG minimum */
  --radius-pill: var(--bz-radius-full);      /* 9999px */

  /* Borders */
  --border-strong: 2px;
  --border-regular: 1px;

  /* Shadows - BDS scale */
  --shadow-1: var(--bz-shadow-md);
  --shadow-2: var(--bz-shadow-xl);

  /* Transitions */
  --dur-1: .18s;
  --dur-2: .45s;
  --ease-std: cubic-bezier(.2,.6,.2,1);

  /* Media sizing */
  --media-w: clamp(200px, 25vw, 320px);
  --media-brd: 3px;
}

/* ============================== LAYOUT BASE ============================= */
.promo-banner-capitolo{
  position: relative;
  display: flex !important;
  align-items: center;
  gap: var(--bz-space-4);
  color: #ffffff;
  padding: var(--bz-space-6);
  margin: var(--bz-space-3) 0;
  overflow: hidden;
  overflow-x: hidden !important;
  font: 400 var(--bz-text-base)/1.5 inherit;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;

  /* GLASSMORPHISM BASE */
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--glass-radius);
  box-shadow: var(--glass-shadow), var(--glass-inner-glow);
}

/* RESPONSIVE: tutti gli elementi interni rispettano il contenitore */
.promo-banner-capitolo *{
  max-width: 100%;
  box-sizing: border-box;
}

/* Riga interna: media + colonna testi (tutto il wizard) */
.promo-banner-capitolo .wb-scroll{
  display: flex;
  align-items: center;
  gap: clamp(var(--bz-space-3), 2vw, var(--bz-space-4));
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

/* Durante il fade blocchiamo l'interazione */
.promo-banner-capitolo.-is-fading .wb-scroll{ pointer-events: none; }

/* Se esiste un tasto Exit, riserva spazio (fallback legacy con classe) */
.promo-banner-capitolo.has-exit{
  padding-bottom: calc(clamp(10px, 1.8vw, 16px) + 52px);
}

/* Chrome (X) solo per il popup */
.promo-banner-capitolo .wb-chrome{ display: none; }

/* Inline: FULL-WIDTH RIBBON - punto di conversione */
.promo-banner-capitolo:not(.in-popup){
  /* Full width - nessun limite */
  max-width: 100%;
  width: 100%;
  margin: 0;
  border-radius: 0;

  /* Bordo top accent forte */
  border: none;
  border-top: 5px solid var(--bz-accent);
  border-bottom: 1px solid rgba(255,255,255,0.1);

  /* Ombra interna per profondità */
  box-shadow:
    inset 0 4px 20px rgba(0,0,0,0.15),
    0 4px 20px rgba(0,0,0,0.2);

  /* Nessun outline */
  outline: none;

  /* Padding generoso verticale, orizzontale per centrare */
  padding: var(--bz-space-12) var(--bz-space-4);

  /* Sfondo ricco gradient */
  background: linear-gradient(180deg, var(--bz-secondary-dark-4) 0%, var(--bz-secondary-dark-6) 100%);

  position: relative;
  overflow: hidden;
  overflow-x: hidden !important;
}

/* Contenuto interno centrato con max-width */
.promo-banner-capitolo:not(.in-popup) .wb-scroll{
  max-width: min(1100px, 100%);
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

/* ====== TABLET (641px-1024px) - RESPONSIVE COMPLETO ====== */
@media (min-width: 641px) and (max-width: 1024px){
  .promo-banner-capitolo{
    overflow: hidden !important;
    overflow-x: hidden !important;
  }
  .promo-banner-capitolo:not(.in-popup){
    padding: var(--bz-space-8) var(--bz-space-4);
  }
  .promo-banner-capitolo:not(.in-popup) .wb-scroll{
    max-width: 100%;
    width: 100%;
    padding: 0;
    box-sizing: border-box;
    gap: var(--bz-space-4);
  }
  .promo-banner-capitolo .wb-media{
    --media-w: clamp(140px, 20vw, 200px);
    flex-shrink: 0;
  }
  .promo-banner-capitolo .wb-screens{
    min-width: 0;
    flex: 1 1 0%;
    width: auto;
    max-width: 100%;
  }
  .promo-banner-capitolo .promo-text-capitolo{
    min-width: 0;
    width: 100%;
  }
  .promo-banner-capitolo .promo-text-capitolo p{
    max-width: 100%;
  }
}

/* ====== TABLET/DESKTOP - Media proporzionale alla larghezza (sempre quadrato) ====== */
@media (min-width: 769px){
  /* Layout side-by-side: immagine proporzionale, contenuto centrato verticalmente */
  .promo-banner-capitolo:not(.in-popup) .wb-scroll{
    align-items: center; /* Centra verticalmente */
  }
  .promo-banner-capitolo:not(.in-popup) .wb-media{
    /* Larghezza proporzionale al container, sempre quadrata */
    width: clamp(180px, 28%, 300px); /* 28% del banner, min 180px, max 300px */
    flex: 0 0 auto;
    aspect-ratio: 1 / 1;
    align-self: center; /* Centrato verticalmente */
  }
  .promo-banner-capitolo:not(.in-popup) .wb-screens{
    flex: 1 1 0%;
    min-width: 0;
    align-self: center; /* Centrato verticalmente */
  }
}

/* ====== SMALL TABLET (641px-768px) - Stack verticale, immagine sopra ====== */
@media (min-width: 641px) and (max-width: 768px){
  .promo-banner-capitolo .wb-scroll{
    flex-direction: column;
    align-items: center;
  }
  .promo-banner-capitolo .wb-media{
    width: clamp(160px, 40%, 220px); /* Proporzionale, sempre quadrata */
    aspect-ratio: 1 / 1;
    margin: 0 auto;
    flex-shrink: 0;
  }
  .promo-banner-capitolo .promo-text-capitolo{
    text-align: center;
    align-items: center;
  }
  .promo-banner-capitolo .promo-text-capitolo strong:not(.wb-lead-title),
  .promo-banner-capitolo .promo-text-capitolo p{
    text-align: center;
  }
  .promo-banner-capitolo .promo-actions{
    justify-content: center;
  }
}

/* Nessun hover lift per ribbon full-width */
.promo-banner-capitolo:not(.in-popup):hover{
  transform: none;
}

/* Nessuna animazione wizard per ribbon full-width - l'attenzione è sui CTA */

/* Nessuno sfondo immagine se non c'è immagine */
.promo-banner-capitolo.-no-media:not(.in-popup)::before{
  display: none;
}

/* ============================== MEDIA BLOCK ============================= */
.promo-banner-capitolo .wb-media{
  position: relative;
  flex: 0 0 auto;
  width: var(--media-w);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: transparent;
  border: 3px solid var(--bz-accent);
  border-radius: var(--bz-radius-lg);
  box-sizing: border-box;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease;
}
.promo-banner-capitolo .wb-media:hover{
  transform: scale(1.02) translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.25);
}

/* ====== LAYOUT SENZA IMMAGINE ====== */
/* Quando wb-media è vuoto o nascosto, centra il contenuto */
.promo-banner-capitolo .wb-media:empty,
.promo-banner-capitolo .wb-media:not(:has(img)):not(:has(video)){
  display: none !important;
}
.promo-banner-capitolo .wb-scroll:has(.wb-media:empty),
.promo-banner-capitolo .wb-scroll:has(.wb-media:not(:has(img)):not(:has(video))){
  justify-content: center;
}
.promo-banner-capitolo .wb-scroll:has(.wb-media:empty) .promo-text-capitolo,
.promo-banner-capitolo .wb-scroll:has(.wb-media:not(:has(img)):not(:has(video))) .promo-text-capitolo{
  text-align: center;
  align-items: center;
}
.promo-banner-capitolo .wb-scroll:has(.wb-media:empty) .promo-actions,
.promo-banner-capitolo .wb-scroll:has(.wb-media:not(:has(img)):not(:has(video))) .promo-actions{
  justify-content: center;
}
/* Fallback per browser senza :has() - classe aggiunta via JS */
.promo-banner-capitolo.-no-media .wb-media{ display: none !important; }
.promo-banner-capitolo.-no-media .wb-scroll{ justify-content: center; }
.promo-banner-capitolo.-no-media .promo-text-capitolo{ text-align: center; align-items: center; }
.promo-banner-capitolo.-no-media .promo-actions{ justify-content: center; }
.promo-banner-capitolo.-no-media .wb-exit-wrap{ justify-content: center; }
.promo-banner-capitolo .wb-media img,
.promo-banner-capitolo .wb-media video{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  border: 0 !important;
  border-radius: 0 !important;
}
.promo-banner-capitolo .wb-media video{ opacity: 0; pointer-events: none; transition: opacity var(--dur-1) var(--ease-std); }
.promo-banner-capitolo .wb-media.is-playing video{ opacity: 1; pointer-events: auto; }
.promo-banner-capitolo .wb-media.is-playing img{ opacity: 0; }

/* Play badge */
.promo-banner-capitolo .wb-media .wb-play{
  all: unset;
  position: absolute; left: 12px; bottom: 12px;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  background: rgba(0,0,0,.55); color: #fff;
  font: 700 var(--fs-small)/1 var(--ff);
  border-radius: 10px; cursor: pointer; backdrop-filter: blur(2px);
}
.promo-banner-capitolo .wb-media .wb-play::before{
  content: ''; width: 0; height: 0;
  border-left: 14px solid currentColor;
  border-top: 8px solid transparent; border-bottom: 8px solid transparent;
}
.promo-banner-capitolo .wb-media.is-playing .wb-play{ opacity: 0; }

/* Play grande */
.promo-banner-capitolo .wb-media .wb-playbig{
  all: unset;
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: clamp(64px, 9vw, 80px);
  aspect-ratio: 1 / 1;
  pointer-events: none; z-index: 3;
}
.promo-banner-capitolo .wb-media .wb-playbig::before{
  content: ''; position: absolute; inset: 0;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,.58);
  backdrop-filter: blur(2px);
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
}
.promo-banner-capitolo .wb-media .wb-playbig::after{
  content: ''; position: absolute; left: 50%; top: 50%;
  width: 42%; aspect-ratio: 1 / 1;
  transform: translate(-40%, -50%) scaleX(-1);
  background: rgba(0,0,0,.86);
  clip-path: polygon(0% 50%, 100% 0%, 100% 100%);
}
.promo-banner-capitolo .wb-media.is-playing .wb-playbig{ opacity: 0; }
/* Nascondi sempre il play button grande centrale */
.promo-banner-capitolo .wb-media .wb-playbig{ display: none !important; }

/* ============================== TEXT COLUMN ============================= */
/* Wrapper delle card (statico, niente overlay) */
.promo-banner-capitolo .wb-screens{
  position: relative;
  flex: 1 1 0%;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  overflow: hidden;
}

/* Le card */
.promo-banner-capitolo .wb-screens{
  position: relative;
}
.promo-banner-capitolo .wb-screens > .screen[hidden]{
  display: none !important;
}
.promo-banner-capitolo .screen[aria-hidden="true"] * { pointer-events: none; }
.promo-banner-capitolo .screen[aria-hidden="false"] *{ pointer-events: auto !important; }

/* ===== TRANSIZIONI PREMIUM ===== */
/* Contenuto interno con transizione opacity */
.promo-banner-capitolo .wb-scroll{
  transition: opacity 0.22s ease-out;
}
/* Classe per fade-out (usata sia per card che wizard switch) */
.promo-banner-capitolo.-fade-out .wb-scroll{
  opacity: 0;
  pointer-events: none;
}
/* Classe per fade-in */
.promo-banner-capitolo.-fade-in .wb-scroll{
  opacity: 1;
}
/* Durante transizioni disabilita animazioni pulsanti */
.promo-banner-capitolo.-fade-out .promo-button-capitolo,
.promo-banner-capitolo.-fade-in .promo-button-capitolo{
  animation: none !important;
}


.promo-text-capitolo{
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--bz-space-4); /* 16px - spacing armonizzato */
  color: #ffffff;
  text-align: left;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  overflow: visible;
  overflow-x: clip;
  word-wrap: break-word;
  overflow-wrap: break-word;
  padding-bottom: var(--bz-space-2-5); /* spazio per glow CTA */
}
.promo-text-capitolo strong:not(.wb-lead-title){
  display: block;
  font-family: var(--bz-font-heading);
  font-weight: 800;
  font-size: clamp(var(--bz-text-2xl), 3vw, var(--bz-text-4xl));
  line-height: var(--bz-leading-tight);
  color: #ffffff;
  letter-spacing: var(--bz-tracking-tight);
  text-wrap: balance;
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
  margin-bottom: var(--bz-space-2);
  max-width: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.promo-text-capitolo p{
  margin: 0;
  font-size: clamp(var(--bz-text-base), 1.4vw, var(--bz-text-lg));
  line-height: var(--bz-leading-relaxed);
  color: var(--bz-light-90);
  max-width: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* (wb-lead-title ora dentro wb-leadgen - vedi sezione lead form) */

/* Divider tra CTA e pre‑lead */
.promo-banner-capitolo .wb-divider{
  border: 0;
  height: 0;
  border-top: 1px solid rgba(0,0,0,.14);
  margin: var(--bz-space-4) 0 var(--bz-space-3);
  opacity: 1;
}
@media (min-width: 768px){
  .promo-banner-capitolo .wb-divider{
    margin: var(--bz-space-5) 0 var(--bz-space-4);
  }
}
@supports (color: color-mix(in srgb, white, black)) {
  .promo-banner-capitolo .wb-divider{
    border-top-color: color-mix(in srgb, var(--bz-accent) 35%, transparent);
  }
}

/* ============================== CTA BUTTONS ============================ */
/* Desktop (>1024px): tutti su una linea */
.promo-actions{
  display: flex;
  flex-wrap: wrap;
  gap: var(--bz-space-2-5); /* 10px - BDS spacing */
  margin-top: var(--bz-space-4);
  margin-bottom: 0; /* Evita spaziatura extra sotto */
  justify-content: flex-start;
  width: 100%;
  max-width: 100%;
}

/* INLINE: sempre un pulsante per riga */
.promo-banner-capitolo:not(.in-popup) .promo-actions{
  flex-direction: column;
  align-items: stretch;
  gap: var(--bz-space-4); /* 16px - spacing confortevole tra pulsanti stacked */
}
.promo-banner-capitolo:not(.in-popup) .promo-actions .promo-button-capitolo{
  width: 100%;
  justify-content: center;
}
/* INLINE: secondary buttons leggermente più piccoli (come popup) */
.promo-banner-capitolo:not(.in-popup) .promo-actions .promo-button-capitolo.secondary{
  font-size: clamp(15px, 1.5vw, 17px);
  min-height: var(--bz-btn-height-lg);  /* 52px - CTA secondarie */
  padding: 0 24px;
}

/* Small Tablet (641-768px): impilati */
@media (min-width: 641px) and (max-width: 768px){
  .promo-actions{
    display: flex;
    flex-direction: column;
    gap: var(--bz-space-4); /* 16px - spacing confortevole */
    width: 100%;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }
  .promo-actions .promo-button-capitolo{
    width: 100%;
    justify-content: center;
  }
}

/* Mobile (<640px): impilati verticalmente */
@media (max-width: 640px){
  .promo-actions{
    display: flex;
    flex-direction: column;
    gap: var(--bz-space-4); /* 16px - spacing confortevole */
    width: 100%;
    max-width: 100%;
  }
  .promo-actions .promo-button-capitolo{
    width: 100%;
    max-width: 100%;
    justify-content: center;
  }
}

.promo-button-capitolo{
  all: unset;
  display: inline-flex; align-items: center; justify-content: center;
  min-height: var(--bz-btn-height-lg);  /* 52px - CTA primarie */
  padding: 0 32px;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  font: 800 clamp(15px, 1.6vw, 20px)/1 var(--ff);
  cursor: pointer; white-space: nowrap; text-align: center;
  color: var(--banner-fg);
  box-shadow: 0 4px 16px rgba(0,0,0,0.15), 0 2px 4px rgba(0,0,0,0.1);
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
  max-width: 100%;
  box-sizing: border-box;
}
/* Effetto shine sui pulsanti primary */
.promo-button-capitolo.primary::before{
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transition: left 0.5s ease;
}
.promo-button-capitolo.primary:hover::before{
  left: 100%;
}
.promo-button-capitolo .price{
  display: inline-block; margin-left: 12px; padding-left: 12px;
  border-left: 2px solid rgba(0,0,0,.2); opacity: .95; font-weight: 800;
}

.promo-button-capitolo.primary{
  background: var(--bz-accent);
  border: none;
  color: #1a1a1a !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.25);
  font-size: clamp(18px, 1.8vw, 22px) !important;
  font-weight: 800;
  padding: 0 36px;
  min-height: var(--bz-btn-height-xl);  /* 60px - Hero CTA */
  box-shadow:
    0 6px 24px rgba(212, 168, 83, 0.4),
    0 2px 8px rgba(0,0,0,0.15);
}
.promo-button-capitolo.primary:hover{
  background: var(--bz-accent-light);
  box-shadow:
    0 12px 40px rgba(212, 168, 83, 0.5),
    0 6px 16px rgba(0,0,0,0.2);
  transform: translateY(-5px) scale(1.03);
}
.promo-button-capitolo.secondary{
  background: rgba(255,255,255,0.12);
  border: 2px solid var(--bz-accent);
  color: #ffffff;
  backdrop-filter: blur(12px);
}
.promo-button-capitolo.secondary:hover{
  background: rgba(255,255,255,0.2);
  border-color: var(--bz-accent-light);
}
.promo-button-capitolo:hover{
  transform: translateY(-4px) scale(1.02);
}
.promo-button-capitolo:active{
  transform: translateY(-1px) scale(0.99);
}
.promo-button-capitolo:focus-visible{
  outline: 3px solid var(--bz-accent); outline-offset: 3px;
}

/* Icona ↗ sui link esterni */
.promo-button-capitolo[data-action="out-link"]{
  flex-direction: row !important;
  flex-wrap: nowrap !important;
}
.promo-button-capitolo[data-action="out-link"]::after{
  content: "↗";
  font: inherit;
  font-size: 0.85em;
  margin-left: 0.35em;
  flex: 0 0 auto;
  order: 99;
}

/* ================================ EXIT BTN ============================= */
.promo-banner-capitolo .wb-exit-wrap{
  display: flex;
  justify-content: flex-start;
  margin-top: var(--bz-space-4);
  width: 100%;
}
.promo-banner-capitolo .wb-exit{
  all: unset;
  display: inline-flex;
  align-items: center;
  gap: var(--bz-space-2);
  padding: var(--bz-space-3) var(--bz-space-5);
  border-radius: var(--bz-radius-lg);
  border: 2px solid var(--bz-accent);
  background: rgba(255,255,255,.08);
  color: var(--bz-accent);
  font: 600 var(--bz-text-sm)/1.2 var(--bz-font-body);
  cursor: pointer;
  transition: background .2s, transform .15s, box-shadow .2s;
}
.promo-banner-capitolo .wb-exit:hover{
  background: rgba(255,255,255,.15);
  transform: translateY(-2px);
  box-shadow: var(--bz-shadow-md);
}
.promo-banner-capitolo .wb-exit .label{ white-space: nowrap; }
.promo-banner-capitolo .wb-exit .icon{
  display: inline-flex;
  font-size: 1.1em;
  opacity: 0.9;
}

/* ================================ LEAD FORM ============================ */
/* Semplificato: niente pill, input e submit stessa altezza, larga quanto i pulsanti */

.promo-banner-capitolo .wb-leadgen form fieldset,
.promo-banner-capitolo .wb-leadgen form{
  display: flex;
  flex-direction: column;
  gap: var(--bz-space-3); /* 12px - più respiro tra campi */
  padding: 0;
  border: none;
  background: transparent;
}
.promo-banner-capitolo .wb-leadgen .ff-el-input--label,
.promo-banner-capitolo .wb-leadgen .ff-el-group.ff-el-form-top .ff-el-input--label{ display: none !important; }
.promo-banner-capitolo .wb-leadgen .ff-el-group{ margin: 0 !important; }

.promo-banner-capitolo .wb-leadgen .ff-el-form-control,
.promo-banner-capitolo .wb-leadgen input[type="email"],
.promo-banner-capitolo .wb-leadgen input[type="text"]{
  width: 100%;
  height: var(--cta-h) !important;
  min-height: var(--cta-h) !important;
  padding: 0 18px !important;
  border: 2px solid var(--bz-primary) !important;
  border-radius: var(--radius-pill) !important;
  background: #fff !important;
  color: #111 !important;
  font-family: var(--ff) !important;
  font-size: var(--fs-cta) !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  outline: none !important;
}
.promo-banner-capitolo .wb-leadgen .ff-el-form-control::placeholder,
.promo-banner-capitolo .wb-leadgen input[type="email"]::placeholder,
.promo-banner-capitolo .wb-leadgen input[type="text"]::placeholder{
  color: #888 !important;
}

.promo-banner-capitolo .wb-leadgen .ff-btn-submit,
.promo-banner-capitolo .wb-leadgen button[type="submit"]{
  all: unset !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: var(--cta-h) !important;
  min-height: var(--cta-h) !important;
  padding: 0 22px !important;
  border-radius: var(--radius-pill) !important;
  border: none !important;
  background: var(--bz-primary) !important;
  color: #fff !important;
  font-family: var(--ff) !important;
  font-size: var(--fs-cta) !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: filter var(--dur-1) var(--ease-std) !important;
  box-sizing: border-box !important;
}
.promo-banner-capitolo .wb-leadgen .ff-btn-submit:hover,
.promo-banner-capitolo .wb-leadgen button[type="submit"]:hover{
  filter: brightness(1.1) !important;
}

.promo-banner-capitolo .wb-leadgen .ff-error{
  color: #b32d2e; font-size: 14px; font-weight: 600; margin-top: 6px;
}

/* ================================ WRAPPER =============================== */
.fbiz-wizard-wrap {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
  overflow-x: hidden !important;
  background: transparent;
}
/* Forza tutti gli elementi interni a rispettare il contenitore */
.fbiz-wizard-wrap *,
.fbiz-wizard-wrap *::before,
.fbiz-wizard-wrap *::after {
  box-sizing: border-box;
  max-width: 100%;
}
/* Responsive wrapper */
.fbiz-wizard-wrap > .promo-banner-capitolo {
  width: 100% !important;
  max-width: 100% !important;
}

/* ================================ MOBILE (<640px) =============================== */
@media (max-width: 640px){
  .promo-banner-capitolo{
    flex-direction: column;
    text-align: center;
    padding: var(--bz-space-6) var(--bz-space-3) var(--bz-space-8);
    margin: 0;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    overflow-x: hidden !important;
    border-radius: 0;
  }
  .promo-banner-capitolo .wb-scroll{
    flex-direction: column;
    align-items: center;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    gap: var(--bz-space-4);
  }
  .promo-banner-capitolo .wb-screens{
    flex: 1 1 auto;
    min-width: 0;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }
  .promo-banner-capitolo .promo-text-capitolo{
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    overflow-x: clip !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
    text-align: center;
    align-items: center;
  }
  .promo-banner-capitolo .wb-media{
    width: clamp(160px, 50%, 220px) !important; /* Proporzionale, sempre quadrata */
    max-width: 220px !important;
    aspect-ratio: 1 / 1;
    margin: 0 auto !important;
    flex: 0 0 auto !important;
  }
  .promo-banner-capitolo .wb-media img,
  .promo-banner-capitolo .wb-media video{
    width: 100% !important;
    height: 100% !important;
  }
  .promo-text-capitolo strong:not(.wb-lead-title){
    text-align: center !important;
    margin-top: 8px;
    font-size: clamp(1.3rem, 5vw, 1.8rem) !important;
  }
  .promo-text-capitolo p{
    text-align: center !important;
    font-size: clamp(0.9rem, 3.5vw, 1rem) !important;
  }

  /* CTA mobile */
  .promo-actions{
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }
  .promo-actions .promo-button-capitolo{
    min-height: 52px !important;
    font-size: 16px !important;
    padding: 0 20px !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .promo-actions .promo-button-capitolo.primary{
    min-height: 56px !important;
    font-size: 17px !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.2);
  }

  .promo-banner-capitolo .wb-exit-wrap{
    justify-content: center;
    width: 100% !important;
    max-width: 100% !important;
  }

  .promo-banner-capitolo .wb-leadgen{
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }
  .promo-banner-capitolo .wb-leadgen form,
  .promo-banner-capitolo .wb-leadgen form fieldset{
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    width: 100%;
    max-width: 100%;
  }

  /* === MOBILE: input e submit === */
  .promo-banner-capitolo .wb-leadgen .ff-el-form-control,
  .promo-banner-capitolo .wb-leadgen input[type="email"],
  .promo-banner-capitolo .wb-leadgen input[type="text"]{
    width: 100% !important;
    max-width: 100% !important;
    min-height: 52px !important;
    padding: 12px 16px !important;
    border: 2px solid var(--bz-primary) !important;
    border-radius: var(--radius-pill) !important;
    background: #fff !important;
    color: #111 !important;
    font-size: 16px !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
  }
  .promo-banner-capitolo .wb-leadgen .ff-el-form-control::placeholder,
  .promo-banner-capitolo .wb-leadgen input[type="email"]::placeholder{
    color: #666 !important;
  }
  .promo-banner-capitolo .wb-leadgen .ff-btn-submit,
  .promo-banner-capitolo .wb-leadgen button[type="submit"]{
    width: 100% !important;
    max-width: 100% !important;
    min-height: 56px !important;
    font-family: var(--ff) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    border: var(--border-strong) solid var(--bz-primary) !important;
    background: var(--bz-primary) !important;
    color: #fff !important;
    box-shadow: 0 10px 20px rgba(0,0,0,.08);
    box-sizing: border-box !important;
  }

  /* Mobile: leadgen responsive */
  .promo-banner-capitolo .wb-leadgen{
    margin-top: var(--bz-space-3) !important;
  }
  .promo-banner-capitolo .wb-leadgen *,
  .promo-banner-capitolo .ff-el-group,
  .promo-banner-capitolo .ff_submit_btn_wrapper,
  .promo-banner-capitolo .fluentform{
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* ================================ POPUP ================================ */
.fbiz-sticky{
  position: fixed; left: 0; right: 0; bottom: 0; width: 100%;
  z-index: 100000;
  isolation: isolate; /* crea nuovo stacking context, protegge dal blur sottostante */
  transform: translateY(110%); opacity: 0;
  transition: transform var(--dur-2) var(--ease-std), opacity var(--dur-2) var(--ease-std);
  text-align: center;

  /* Variabili di spacing del pop-up (override in mobile) */
  --pop-pad: clamp(12px, 2vw, 18px);
  --pop-top-extra: 36px;          /* extra spazio sopra il contenuto per la X (anche desktop) */
  --pop-bottom-pad: var(--pop-pad);
}
.fbiz-sticky.show{ transform: translateY(0); opacity: 1; }

.fbiz-sticky .promo-banner-capitolo{
  /* POPUP - stesso colore dell'inline */
  background: color-mix(in srgb, var(--bz-secondary-dark-4) 95%, transparent);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color: #ffffff;
  border: 1px solid var(--bz-light-20);
  border-radius: var(--glass-radius);
  /* nuovo schema padding: top = pad + extra; bottom riducibile */
  padding: calc(var(--pop-pad) + var(--pop-top-extra)) var(--pop-pad) var(--pop-bottom-pad);
  margin: var(--bz-space-4) auto var(--pop-bottom-pad);
  display: inline-block !important; /* FIX: sovrascrive il flex !important dell'inline */
  width: auto;
  max-width: min(720px, 95%);
  box-shadow: var(--bz-shadow-xl);
}

/* POP‑UP: contenuto centrato (testi e CTA) */
.fbiz-sticky .promo-text-capitolo,
.fbiz-sticky .promo-text-capitolo p,
.fbiz-sticky .promo-text-capitolo strong:not(.wb-lead-title){
  text-align: center;
}

/* POP-UP: font size = inline wizard (stessa tipografia) */
.fbiz-sticky .promo-text-capitolo strong:not(.wb-lead-title){
  font-size: 1.5em !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}
.fbiz-sticky .promo-text-capitolo p{
  font-size: 1em !important;
  line-height: 1.5 !important;
  max-width: 90%;
  margin-left: auto;
  margin-right: auto;
}
.fbiz-sticky .promo-actions{
  justify-content: center;
  flex-wrap: wrap !important; /* Permette ai bottoni di andare a capo */
  gap: var(--bz-space-4) !important; /* 16px - spacing confortevole */
  width: 100%;
  max-width: 100%;
  overflow: visible !important;
}
.fbiz-sticky .promo-actions .promo-button-capitolo{
  font-size: clamp(15px, 1.5vw, 17px) !important;
  min-height: var(--bz-btn-height-lg);  /* 52px - CTA standard popup */
  padding: 0 24px;
  white-space: nowrap;
  flex-shrink: 0;
}
.fbiz-sticky .promo-actions .promo-button-capitolo.primary{
  font-size: clamp(16px, 1.6vw, 18px) !important;
  min-height: var(--bz-btn-height-lg);  /* 52px - CTA primaria popup */
  padding: 0 28px;
}
.fbiz-sticky .wb-exit-wrap{
  justify-content: center;
  margin-top: var(--bz-space-3);
}
.fbiz-sticky .wb-exit{
  padding: var(--bz-space-2-5) var(--bz-space-4);
  font-size: var(--bz-text-sm);
}

/* altezza scrollabile: considera anche l'extra top e il bottom pad */
.fbiz-sticky .promo-banner-capitolo{
  max-height: var(--fbiz-pop-vh, 85vh);
  overflow: visible !important; /* Permette ai contenuti di non essere tagliati */
}
.fbiz-sticky .promo-banner-capitolo .wb-scroll{
  max-height: calc(
    var(--fbiz-pop-vh, 85vh) - (var(--pop-pad) + var(--pop-top-extra) + var(--pop-bottom-pad))
  );
  overflow-y: auto;
  overflow-x: visible; /* Non taglia i bottoni */
  -webkit-overflow-scrolling: touch;
}
.fbiz-sticky .promo-banner-capitolo .wb-screens{
  width: 100%;
}
.fbiz-sticky .promo-banner-capitolo .screen{
  overflow: visible !important;
}

.fbiz-sticky .promo-banner-capitolo .wb-chrome{
  position: absolute; inset: 0; pointer-events: none; z-index: 3; display: block;
}
.fbiz-sticky .promo-banner-capitolo .wb-chrome .promo-close-capitolo{
  all: unset;
  position: absolute; top: 10px; right: 10px;
  width: 32px; height: 32px; display: grid; place-items: center;
  background: var(--bz-light-10);
  color: #ffffff;
  border: 1px solid var(--bz-light-20);
  font: 900 18px/1 inherit;
  border-radius: var(--bz-radius-md); cursor: pointer;
  box-shadow: var(--bz-shadow-sm);
  pointer-events: auto;
  transition: background 0.15s;
}
.fbiz-sticky .promo-banner-capitolo .wb-chrome .promo-close-capitolo:hover{
  background: var(--bz-light-20);
}

.fbiz-sticky .promo-text-capitolo{ color: #ffffff; }
.fbiz-sticky .promo-button-capitolo.primary{
  background: var(--bz-accent);
  border-color: var(--bz-accent);
  color: #1a1a1a !important;
}
.fbiz-sticky .promo-button-capitolo.secondary{
  border-color: var(--bz-accent);
  color: #ffffff !important;
}

/* Popup: lead semplificato */
.fbiz-sticky .promo-banner-capitolo .wb-leadgen .wb-lead-title{
  color: var(--bz-primary) !important;
}
.fbiz-sticky .promo-banner-capitolo .wb-leadgen form,
.fbiz-sticky .promo-banner-capitolo .wb-leadgen form fieldset{
  border: none !important;
  padding: 0 !important;
  background: transparent !important;
}
.fbiz-sticky .promo-banner-capitolo .wb-leadgen .ff-el-form-control,
.fbiz-sticky .promo-banner-capitolo .wb-leadgen input[type="email"],
.fbiz-sticky .promo-banner-capitolo .wb-leadgen input[type="text"]{
  height: var(--cta-h) !important;
  min-height: var(--cta-h) !important;
  background: #fff !important;
  color: #111 !important;
  border: 2px solid var(--bz-primary) !important;
}
.fbiz-sticky .promo-banner-capitolo .wb-leadgen .ff-el-form-control::placeholder,
.fbiz-sticky .promo-banner-capitolo .wb-leadgen input::placeholder{
  color: #888 !important;
}
.fbiz-sticky .promo-banner-capitolo .wb-leadgen .ff-btn-submit,
.fbiz-sticky .promo-banner-capitolo .wb-leadgen button[type="submit"]{
  height: var(--cta-h) !important;
  min-height: var(--cta-h) !important;
  background: var(--bz-primary) !important;
  color: #fff !important;
  border: none !important;
}

/* Popup: se non c’è media, non riservare spazio */
.fbiz-sticky .promo-banner-capitolo .wb-media:not(:has(img, video)){ display: none !important; }
/* Fallback :has() */
.fbiz-sticky .promo-banner-capitolo .wb-media[style*="display: none"]{ display: none !important; }

/* In popup usa l'accent del popup per il bordo media */
.fbiz-sticky .promo-banner-capitolo .wb-media{ border-color: var(--bz-accent); }

/* Riduci spazio extra sotto al testo nel popup */
.fbiz-sticky .promo-banner-capitolo .promo-text-capitolo p{ margin-bottom: 0 !important; padding-bottom: 0 !important; }
.fbiz-sticky .promo-banner-capitolo .promo-text-capitolo{ gap: var(--bz-space-2) !important; }

/* Opzione: nascondere media nel popup via classe */
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-media,
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-play,
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-playbig,
.fbiz-sticky .promo-banner-capitolo.-hide-media video,
.fbiz-sticky .promo-banner-capitolo.-hide-media figure img{ display: none !important; }

/* POPUP senza media: centratura completa */
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-scroll{
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-screens{
  width: 100% !important;
  max-width: 500px !important;
}
.fbiz-sticky .promo-banner-capitolo.-hide-media .promo-text-capitolo{
  text-align: center !important;
  align-items: center !important;
}
.fbiz-sticky .promo-banner-capitolo.-hide-media .promo-actions{
  justify-content: center !important;
}
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-exit-wrap{
  justify-content: center !important;
}
.fbiz-sticky .promo-banner-capitolo.-hide-media .wb-leadgen{
  max-width: 400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ================================ A11Y & MISC ========================== */
@media (prefers-reduced-motion: reduce){
  .promo-button-capitolo, .fbiz-sticky{ transition: none !important; }
}

/* ===================== PATCH — Tipografia inline = tema ===================== */
.promo-banner-capitolo:not(.in-popup){
  font: inherit !important;
}
.promo-banner-capitolo:not(.in-popup) .promo-text-capitolo strong:not(.wb-lead-title){
  font-family: inherit !important;
  font-size: 1.5em !important;
  line-height: 1.2 !important;
  font-weight: 800;
}
.promo-banner-capitolo:not(.in-popup) .promo-text-capitolo p{
  font-size: 1em !important;
  line-height: inherit !important;
}

/* (wb-lead-title ora dentro wb-leadgen - vedi sezione finale) */

/* =================== Compact spacing inline + rimozione doppio divisore =================== */
.promo-banner-capitolo .promo-actions:empty{
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
@supports selector(:has(*)) {
  .promo-banner-capitolo .promo-actions:not(:has(.promo-button-capitolo)){
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
}
.promo-banner-capitolo .wb-divider{
  margin: var(--bz-space-3) 0 var(--bz-space-2-5) !important;
  border-top-width: 1px !important;
}
@media (min-width: 768px){
  .promo-banner-capitolo .wb-divider{
    margin: var(--bz-space-3-5) 0 var(--bz-space-3) !important;
  }
}
@media (max-width: 767px){
  .promo-banner-capitolo .wb-divider{
    margin: var(--bz-space-2-5) 0 var(--bz-space-2) !important;
  }
}
/* Leadgen: titolo ora interno al wrapper */
.promo-banner-capitolo .promo-text-capitolo > .wb-leadgen:first-child{ margin-top: 0 !important; }

/* === Lead wrapper: niente border-radius sui container === */
.promo-banner-capitolo .wb-leadgen,
.promo-banner-capitolo .wb-leadgen .fluentform,
.promo-banner-capitolo .wb-leadgen .ffs_modern_b_wrap,
.promo-banner-capitolo .wb-leadgen form.ff-el-form-top,
.promo-banner-capitolo .wb-leadgen form.ff-el-form-top fieldset,
.promo-banner-capitolo .wb-leadgen .ff_submit_btn_wrapper {
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* ====== POP‑UP: override mobile per spazi ottimizzati ====== */
@media (max-width: 640px){
  .fbiz-sticky{
    /* extra top per lasciare la X su una riga dedicata, bottom più compatto */
    --pop-top-extra: var(--bz-space-9); /* 36px */
    --pop-bottom-pad: var(--bz-space-3); /* 12px */
    /* Margini laterali per non appiccicarsi ai bordi */
    padding-left: var(--bz-space-3);
    padding-right: var(--bz-space-3);
  }
  .fbiz-sticky .promo-banner-capitolo{
    margin: var(--bz-space-3) auto var(--pop-bottom-pad);
    border-radius: var(--bz-radius-lg); /* Angoli arrotondati visibili con i margini */
  }
  /* Font size popup mobile = inline mobile */
  .fbiz-sticky .promo-text-capitolo strong:not(.wb-lead-title){
    font-size: var(--bz-text-xl) !important;
  }
  .fbiz-sticky .promo-text-capitolo p{
    font-size: var(--bz-text-base) !important;
  }
  .fbiz-sticky .promo-actions{
    margin-bottom: var(--bz-space-1-5); /* ancora più compatto sotto ai CTA */
  }
  .fbiz-sticky .promo-actions .promo-button-capitolo{
    font-size: var(--bz-text-base) !important;
    min-height: var(--bz-btn-height-lg) !important; /* 52px */
  }
  .fbiz-sticky .promo-actions .promo-button-capitolo.primary{
    font-size: var(--bz-text-lg) !important;
    min-height: var(--bz-btn-height-lg) !important;
  }
}

/* Overlay backdrop disabilitato - il popup appare senza oscuramento */

/* ========================= REVIEWS SECTION ========================= */
.promo-banner-capitolo .wb-reviews{
  margin: 0 0 var(--bz-space-5) 0;
}

/* Badge area (WP Review Slider shortcode) */
.promo-banner-capitolo .wb-reviews-badge{
  text-align: left;
}
@media (max-width: 640px){
  .promo-banner-capitolo .wb-reviews-badge{
    text-align: center;
  }
}

/* WP Review Slider badge: usa colore e dimensione testo coerenti con la card */
.promo-banner-capitolo .wb-reviews-badge,
.promo-banner-capitolo .wb-reviews-badge *{
  color: #ffffff !important;
  font-size: var(--bz-text-sm) !important;
  line-height: 1.4 !important;
}
.promo-banner-capitolo .wb-reviews-badge a{
  color: #ffffff !important;
  text-decoration: none;
}
.promo-banner-capitolo .wb-reviews-badge a:hover{
  color: var(--bz-accent) !important;
}
/* WP Review Slider Pro: override colori specifici */
.promo-banner-capitolo .wb-reviews-badge [class*="wppro_badge"],
.promo-banner-capitolo .wb-reviews-badge [id^="wprev-badge"] *{
  color: #ffffff !important;
}
/* Allinea verticalmente stelle e testo */
.promo-banner-capitolo .wb-reviews-badge [id^="wprev-badge"]{
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--bz-space-1-5);
}
.promo-banner-capitolo .wb-reviews-badge .svgicons{
  display: inline-flex !important;
  align-items: center !important;
  vertical-align: middle !important;
  flex-shrink: 0;
}
.promo-banner-capitolo .wb-reviews-badge svg{
  vertical-align: middle !important;
}

/* Slider container */
.promo-banner-capitolo .wb-reviews-slider{
  position: relative;
  overflow: hidden;
  min-height: 100px;
}

/* Slides */
.promo-banner-capitolo .wb-reviews-slide{
  display: none;
  opacity: 0;
  transition: opacity var(--dur-2) var(--ease-std);
}
.promo-banner-capitolo .wb-reviews-slide.active{
  display: block;
  opacity: 1;
}

/* Blockquote */
.promo-banner-capitolo .wb-reviews-text{
  margin: 0;
  padding: 0;
  font-style: italic;
  font-size: var(--bz-text-base);
  line-height: 1.5;
  color: #ffffff;
  text-align: center;
}
.promo-banner-capitolo .wb-reviews-text::before{
  content: '"';
  font-size: 1.4em;
  opacity: .6;
}
.promo-banner-capitolo .wb-reviews-text::after{
  content: '"';
  font-size: 1.4em;
  opacity: .6;
}

/* Author */
.promo-banner-capitolo .wb-reviews-author{
  display: block;
  margin-top: var(--bz-space-3);
  font-style: normal;
  font-weight: 700;
  font-size: var(--bz-text-sm);
  text-align: center;
  color: var(--bz-accent);
}

/* Navigation dots */
.promo-banner-capitolo .wb-reviews-dots{
  display: flex;
  justify-content: center;
  gap: var(--bz-space-2);
  margin-top: var(--bz-space-4);
}
.promo-banner-capitolo .wb-reviews-dot{
  all: unset;
  width: var(--bz-space-2-5);
  height: var(--bz-space-2-5);
  border-radius: var(--bz-radius-full);
  background: var(--bz-light-30);
  cursor: pointer;
  transition: background 0.18s ease, transform 0.18s ease;
}
.promo-banner-capitolo .wb-reviews-dot:hover{
  background: var(--bz-light-50);
  transform: scale(1.15);
}
.promo-banner-capitolo .wb-reviews-dot.active{
  background: var(--bz-accent);
}

/* === POPUP: nascondi recensioni (mostrale solo in inline) === */
.fbiz-sticky .promo-banner-capitolo .wb-reviews{
  display: none !important;
}

/* === MOBILE: reviews layout === */
@media (max-width: 640px){
  .promo-banner-capitolo .wb-reviews{
    margin: var(--bz-space-3) 0;
  }
  .promo-banner-capitolo .wb-reviews-text{
    font-size: var(--fs-small);
  }
}

/* ========================= ANIMAZIONE PULSE CTA ========================= */
/* Animazione sottile e morbida per attirare attenzione sul CTA primario */
@keyframes ctaPulse {
  0%, 100% {
    box-shadow:
      0 6px 24px rgba(212, 168, 83, 0.4),
      0 2px 8px rgba(0,0,0,0.15),
      inset 0 2px 0 rgba(255,255,255,0.3),
      0 0 0 0 rgba(212, 168, 83, 0);
  }
  50% {
    box-shadow:
      0 6px 24px rgba(212, 168, 83, 0.4),
      0 2px 8px rgba(0,0,0,0.15),
      inset 0 2px 0 rgba(255,255,255,0.3),
      0 0 24px 6px rgba(212, 168, 83, 0.4);
  }
}
.promo-button-capitolo.primary{
  animation: ctaPulse 3s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
.promo-button-capitolo.primary:hover{
  animation: none;
}
@media (prefers-reduced-motion: reduce){
  .promo-button-capitolo.primary{
    animation: none !important;
  }
}

/* ========================= WIZARD SEMPRE CENTRATO ========================= */
.promo-banner-capitolo:not(.in-popup){
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ========================= LAYOUT PER CARD ========================= */
/* Card CON immagine (desktop): testo allineato a sinistra */
.promo-banner-capitolo .screen:not(.-no-image) .promo-text-capitolo{
  text-align: left;
  align-items: flex-start;
}
.promo-banner-capitolo .screen:not(.-no-image) .promo-actions{
  justify-content: flex-start;
}

/* Card SENZA immagine: contenuto centrato */
.promo-banner-capitolo .screen.-no-image{
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo .screen.-no-image .promo-text-capitolo{
  text-align: center !important;
  align-items: center !important;
  max-width: 700px !important;
  width: 100% !important;
  margin: 0 auto !important;
}
.promo-banner-capitolo .screen.-no-image .promo-text-capitolo strong:not(.wb-lead-title){
  text-align: center !important;
  width: 100% !important;
}
.promo-banner-capitolo .screen.-no-image .promo-text-capitolo p{
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100% !important;
}
.promo-banner-capitolo .screen.-no-image .promo-actions{
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo .screen.-no-image .wb-exit-wrap{
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo .screen.-no-image .wb-leadgen{
  max-width: 450px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.promo-banner-capitolo .screen.-no-image .wb-leadgen .wb-lead-title{
  text-align: center !important;
}
.promo-banner-capitolo .screen.-no-image .wb-reviews-badge{
  text-align: center !important;
  width: 100% !important;
  justify-content: center !important;
}

/* Mobile: SEMPRE centrato, con o senza immagine */
@media (max-width: 639px){
  .promo-banner-capitolo .screen .promo-text-capitolo{
    text-align: center !important;
    align-items: center !important;
  }
  .promo-banner-capitolo .screen .promo-text-capitolo strong:not(.wb-lead-title),
  .promo-banner-capitolo .screen .promo-text-capitolo p{
    text-align: center !important;
  }
  .promo-banner-capitolo .screen .promo-actions{
    justify-content: center !important;
    align-items: center !important;
  }
  .promo-banner-capitolo .screen .wb-exit-wrap{
    justify-content: center !important;
  }
}

/* ========================= WIZARD SENZA MEDIA (tutte le card senza immagine) ========================= */
/* Nascondi il contenitore media se vuoto */
.promo-banner-capitolo.-no-media .wb-media{
  display: none !important;
}
/* Centra tutto il contenuto quando non c'è media */
.promo-banner-capitolo.-no-media .wb-scroll{
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo.-no-media .wb-screens{
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
}

/* ========================= CARD ATTIVA SENZA IMMAGINE (dinamico) ========================= */
/* Quando la card corrente non ha immagine, centra il contenuto */
.promo-banner-capitolo.-current-no-image .wb-media{
  display: none !important;
}
.promo-banner-capitolo.-current-no-image .wb-scroll{
  justify-content: center !important;
}
.promo-banner-capitolo.-current-no-image .wb-screens{
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .promo-text-capitolo{
  text-align: center !important;
  align-items: center !important;
  max-width: 700px !important;
  width: 100% !important;
  margin: 0 auto !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .promo-text-capitolo strong:not(.wb-lead-title){
  text-align: center !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .promo-text-capitolo p{
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .promo-actions{
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .wb-exit-wrap{
  justify-content: center !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .wb-leadgen{
  max-width: 450px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.promo-banner-capitolo.-current-no-image .screen[aria-hidden="false"] .wb-leadgen .wb-lead-title{
  text-align: center !important;
}
.promo-banner-capitolo.-no-media:not(.in-popup) .promo-text-capitolo strong:not(.wb-lead-title){
  text-align: center !important;
}
.promo-banner-capitolo.-no-media:not(.in-popup) .promo-text-capitolo p{
  max-width: 100% !important;
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ========================= INLINE HIDE MEDIA (checkbox editor) ========================= */
/* Quando il media è nascosto via opzione editor, centra i contenuti nell'inline */
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-media{
  display: none !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-scroll{
  justify-content: center !important;
  width: 100% !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-screens{
  width: 100% !important;
  max-width: 600px !important;
  display: flex !important;
  justify-content: center !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .promo-text-capitolo{
  text-align: center !important;
  align-items: center !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .promo-text-capitolo strong:not(.wb-lead-title){
  text-align: center !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .promo-text-capitolo p{
  max-width: 100% !important;
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .promo-actions{
  justify-content: center !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-exit-wrap{
  justify-content: center !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-leadgen{
  max-width: 450px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.promo-banner-capitolo.-hide-media:not(.in-popup) .wb-leadgen .wb-lead-title{
  text-align: center !important;
}

/* ========================= HEADING PIÙ PROMINENTE ========================= */
/* Override per garantire visibilità heading su tutti i device */
.promo-text-capitolo strong:not(.wb-lead-title){
  text-shadow: 0 2px 4px rgba(0,0,0,0.15);
}

/* Lead form semplificato - titolo raggruppato dentro */
.promo-banner-capitolo .wb-leadgen{
  margin-top: var(--bz-space-5) !important;
  width: 100%;
}
.promo-banner-capitolo .wb-leadgen .wb-lead-title{
  display: block;
  font-family: var(--bz-font-body) !important;
  font-size: var(--bz-text-lg) !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin: 0 0 var(--bz-space-4) !important;
  text-align: center;
  line-height: var(--bz-leading-snug);
}

/* ========================= GLOBAL RESPONSIVE PROTECTION ========================= */
/* Overflow hidden SOLO sul wrapper esterno */
.fbiz-wizard-wrap{
  overflow: hidden !important;
}

/* ========================= CTA GLOW FIX ========================= */
/* Override con alta specificità per permettere il glow sui pulsanti */
.fbiz-wizard-wrap .promo-banner-capitolo{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo .wb-scroll{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo .wb-screens{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo .screen{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo .promo-text-capitolo{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo .promo-actions{
  overflow: visible !important;
}
/* NOTA: NON mettere overflow:visible sul pulsante stesso!
   Il box-shadow (glow) funziona sempre, ma overflow:visible
   renderebbe visibile l'effetto shine (::before) che deve restare nascosto */

/* ========================= CTA GLOW FIX INLINE DESKTOP ========================= */
/* Fix specifico per versione inline: overflow-x hidden tagliava il glow sui lati */
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup){
  overflow: visible !important;
  overflow-x: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup) .wb-scroll{
  overflow: visible !important;
  overflow-x: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup) .wb-screens{
  overflow: visible !important;
  overflow-x: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup) .screen{
  overflow: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup) .promo-text-capitolo{
  overflow: visible !important;
  overflow-x: visible !important;
}
.fbiz-wizard-wrap .promo-banner-capitolo:not(.in-popup) .promo-actions{
  overflow: visible !important;
  padding-bottom: var(--bz-space-2); /* spazio extra per il glow */
}
/* Assicura che il glow non venga tagliato dal wrapper esterno */
.fbiz-wizard-wrap{
  overflow-x: clip !important; /* clip invece di hidden: permette il glow ma previene scrollbar */
}

/* Forza elementi flex a shrinkare */
.promo-banner-capitolo .wb-scroll > *,
.promo-banner-capitolo .wb-screens > *,
.promo-banner-capitolo .promo-text-capitolo > *{
  min-width: 0;
  flex-shrink: 1;
}

/* Nessun elemento può superare il viewport */
@media (max-width: 1024px){
  .fbiz-wizard-wrap *,
  .promo-banner-capitolo *{
    max-width: 100vw !important;
  }
}

/* Safe area per iPhone notch */
@supports (padding: max(0px)){
  .promo-banner-capitolo:not(.in-popup){
    padding-left: max(var(--bz-space-4), env(safe-area-inset-left));
    padding-right: max(var(--bz-space-4), env(safe-area-inset-right));
  }
}

/* ========================= MODALITÀ TRASPARENTE (per hero/leadgen) ========================= */
/* Wizard senza sfondo scuro, si integra con il design della pagina */
.promo-banner-capitolo.-transparent:not(.in-popup){
  /* Reset sfondo e bordi */
  background: transparent !important;
  border: none !important;
  border-top: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;

  /* Padding più contenuto */
  padding: var(--bz-space-6) var(--bz-space-4) !important;

  /* Testo scuro (light mode default) */
  color: var(--bz-text-primary);
}

/* Testi in modalità trasparente */
.promo-banner-capitolo.-transparent .promo-text-capitolo{
  color: var(--bz-text-primary);
}
.promo-banner-capitolo.-transparent .promo-text-capitolo strong:not(.wb-lead-title){
  color: var(--bz-text-primary) !important;
  text-shadow: none !important;
}
.promo-banner-capitolo.-transparent .promo-text-capitolo p{
  color: var(--bz-text-secondary) !important;
}

/* Lead form in modalità trasparente - stile BDS */
.promo-banner-capitolo.-transparent .wb-leadgen{
  margin-top: var(--bz-space-4) !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .wb-lead-title{
  color: var(--bz-text-primary) !important;
  font-size: var(--bz-text-lg) !important;
  margin-bottom: var(--bz-space-3) !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .ff-el-form-control,
.promo-banner-capitolo.-transparent .wb-leadgen input[type="email"],
.promo-banner-capitolo.-transparent .wb-leadgen input[type="text"]{
  background: var(--bz-bg-base) !important;
  border: 2px solid var(--bz-border-default) !important;
  border-radius: var(--bz-radius-lg) !important;
  color: var(--bz-text-primary) !important;
  min-height: var(--bz-btn-height-md) !important;
  padding: var(--bz-space-3) var(--bz-space-4) !important;
  font-size: var(--bz-text-base) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .ff-el-form-control:focus,
.promo-banner-capitolo.-transparent .wb-leadgen input[type="email"]:focus,
.promo-banner-capitolo.-transparent .wb-leadgen input[type="text"]:focus{
  border-color: var(--bz-primary) !important;
  box-shadow: 0 0 0 3px var(--bz-primary-alpha-20) !important;
  outline: none !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .ff-el-form-control::placeholder,
.promo-banner-capitolo.-transparent .wb-leadgen input::placeholder{
  color: var(--bz-text-muted) !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .ff-btn-submit,
.promo-banner-capitolo.-transparent .wb-leadgen button[type="submit"]{
  background: var(--bz-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--bz-radius-lg) !important;
  min-height: var(--bz-btn-height-lg) !important;
  padding: var(--bz-space-3) var(--bz-space-6) !important;
  font-size: var(--bz-text-base) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s ease, transform 0.15s ease !important;
}
.promo-banner-capitolo.-transparent .wb-leadgen .ff-btn-submit:hover,
.promo-banner-capitolo.-transparent .wb-leadgen button[type="submit"]:hover{
  background: var(--bz-primary-dark) !important;
  transform: translateY(-2px) !important;
}

/* Pulsanti CTA in modalità trasparente */
.promo-banner-capitolo.-transparent .promo-button-capitolo.primary{
  background: var(--bz-primary) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: var(--bz-shadow-md) !important;
  animation: none !important;
}
.promo-banner-capitolo.-transparent .promo-button-capitolo.primary:hover{
  background: var(--bz-primary-dark) !important;
  box-shadow: var(--bz-shadow-lg) !important;
}
.promo-banner-capitolo.-transparent .promo-button-capitolo.secondary{
  background: transparent !important;
  border: 2px solid var(--bz-primary) !important;
  color: var(--bz-primary) !important;
  backdrop-filter: none !important;
}
.promo-banner-capitolo.-transparent .promo-button-capitolo.secondary:hover{
  background: var(--bz-primary-alpha-10) !important;
}

/* Exit button in modalità trasparente */
.promo-banner-capitolo.-transparent .wb-exit{
  border-color: var(--bz-border-default) !important;
  color: var(--bz-text-secondary) !important;
  background: transparent !important;
}
.promo-banner-capitolo.-transparent .wb-exit:hover{
  border-color: var(--bz-primary) !important;
  color: var(--bz-primary) !important;
  background: var(--bz-primary-alpha-10) !important;
}

/* Media in modalità trasparente */
.promo-banner-capitolo.-transparent .wb-media{
  border-color: var(--bz-border-default) !important;
  box-shadow: var(--bz-shadow-md) !important;
}

/* Dark mode per modalità trasparente */
html.cf-theme-dark .promo-banner-capitolo.-transparent .promo-text-capitolo strong:not(.wb-lead-title){
  color: var(--bz-text-primary) !important;
}
html.cf-theme-dark .promo-banner-capitolo.-transparent .promo-text-capitolo p{
  color: var(--bz-text-secondary) !important;
}
html.cf-theme-dark .promo-banner-capitolo.-transparent .wb-leadgen .wb-lead-title{
  color: var(--bz-text-primary) !important;
}
html.cf-theme-dark .promo-banner-capitolo.-transparent .wb-leadgen .ff-el-form-control,
html.cf-theme-dark .promo-banner-capitolo.-transparent .wb-leadgen input[type="email"],
html.cf-theme-dark .promo-banner-capitolo.-transparent .wb-leadgen input[type="text"]{
  background: var(--bz-bg-muted) !important;
  border-color: var(--bz-border-default) !important;
  color: var(--bz-text-primary) !important;
}

/* Mobile: modalità trasparente */
@media (max-width: 640px){
  .promo-banner-capitolo.-transparent:not(.in-popup){
    padding: var(--bz-space-4) var(--bz-space-3) !important;
  }
  .promo-banner-capitolo.-transparent .promo-text-capitolo strong:not(.wb-lead-title){
    font-size: var(--bz-text-xl) !important;
  }
  .promo-banner-capitolo.-transparent .promo-text-capitolo p{
    font-size: var(--bz-text-base) !important;
  }
}