/* templates/finion/css/qba-menu.css
   QBA mega-menu v2 — escluso da JCH combine (vedi nj4_extensions.params.excludeCss).
   Tutti i selettori ancorati a .qba-menu-v2 / .qba-mm-card.
   Pattern reduced-motion v2: in no-preference dichiariamo display:block + animation;
   in reduce nessun override — fallback a display:none / :hover display:block nativo di Helix.
*/

/* ---------- 1. TOKENS locali ---------- */
.sp-megamenu-parent .qba-menu-v2,
.qba-mm-card {
  --qba-ink: #0f172a; --qba-ink-2: #334155; --qba-muted: #64748b; --qba-faint: #94a3b8;
  --qba-line: #e2e8f0; --qba-line-soft: #eef2f6; --qba-bg: #f8fafc; --qba-card: #fbfcfd;
  --qba-accent: #fa6b27; --qba-accent-ink: #c2410c;
  --qba-shadow: 0 18px 50px -12px rgba(15,23,42,.18);
}

/* ---------- 2. Top-link ---------- */
.sp-megamenu-parent > li.qba-menu-v2 > a,
.sp-megamenu-parent > li.qba-menu-v2 > span {
  padding: 23px 16px;
  font-weight: 600;
  font-size: 15px;
  color: var(--qba-ink);
  position: relative;
  text-transform: none;
  letter-spacing: 0;
  line-height: 1.2;
}
.sp-megamenu-parent > li.qba-menu-v2 > a::after {
  content: '';
  position: absolute;
  left: 16px; right: 16px; bottom: 0;
  height: 3px;
  background: var(--qba-accent);
  transform: scaleX(0);
}
.sp-megamenu-parent > li.qba-menu-v2:hover > a,
.sp-megamenu-parent > li.qba-menu-v2:focus-within > a {
  color: var(--qba-accent-ink);
}
.sp-megamenu-parent > li.qba-menu-v2:hover > a::after,
.sp-megamenu-parent > li.qba-menu-v2:focus-within > a::after {
  transform: scaleX(1);
}

/* Nascondi il caret font-awesome di Helix sui top-link mega-menu (pulizia visiva) */
body.ltr .sp-megamenu-parent > li.qba-menu-v2.sp-has-child > a:after,
body.ltr .sp-megamenu-parent > li.qba-menu-v2.sp-has-child > span:after {
  display: none;
  content: none;
}

/* ---------- 3. Dropdown container ---------- */
.sp-megamenu-parent > li.qba-menu-v2 > .sp-dropdown {
  border: 1px solid var(--qba-line);
  border-top: 3px solid var(--qba-accent);
  border-radius: 0 0 14px 14px;
  box-shadow: var(--qba-shadow);
  background: #fff;
  margin-top: 0;
  /* default Helix: display:none — manteniamo per fallback reduced-motion */
}
.sp-megamenu-parent > li.qba-menu-v2 > .sp-dropdown > .sp-dropdown-inner {
  padding: 0;
  box-shadow: none;
}

/* ---------- 4. Mega 4-col layout (Conti/Carte/Risparmio/Investimenti) ---------- */
.sp-megamenu-parent > li.qba-menu-v2.custom-full-menu > .sp-dropdown {
  width: 1100px;
  max-width: calc(100vw - 32px);
}
.sp-megamenu-parent > li.qba-menu-v2.custom-full-menu .sp-dropdown-inner > .row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 300px;
  gap: 28px;
  padding: 26px 32px 30px;
  margin: 0;
}
.sp-megamenu-parent > li.qba-menu-v2.custom-full-menu .sp-dropdown-inner > .row > [class*="col-"] {
  flex: unset;
  max-width: unset;
  padding: 0;
  width: auto;
}

/* Row tagline (Risparmio/Investimenti): full-width sopra le colonne, niente grid */
.sp-megamenu-parent > li.qba-menu-v2.custom-full-menu .sp-dropdown-inner > .row:first-child:not(:only-child) {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 16px 32px 0;
}

/* Tagline content (menu_class_sfx="qba-tagline") */
.sp-megamenu-parent > li.qba-menu-v2 .qba-tagline .item-header > a,
.sp-megamenu-parent > li.qba-menu-v2 .qba-tagline .item-header > span,
.sp-megamenu-parent > li.qba-menu-v2 .qba-tagline > .nav-header > span,
.sp-megamenu-parent > li.qba-menu-v2 .qba-tagline > a,
.sp-megamenu-parent > li.qba-menu-v2 .qba-tagline > span {
  font-size: 13px !important;
  color: var(--qba-ink-2) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  display: block;
}

/* Row CTA footer (Conti/Carte): last row con menu_item url (CTA quiz item 384/394) */
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row:last-child:not(:first-child),
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row:last-child:not(:first-child),
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row:last-child:not(:first-child) {
  grid-template-columns: 1fr;
  background: #f1f5f9;
  padding: 14px 32px;
  border-top: 1px solid var(--qba-line-soft);
  border-radius: 0 0 12px 12px;
  margin: 0;
  gap: 12px;
  align-items: center;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row:last-child:not(:first-child) > [class*="col-"],
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row:last-child:not(:first-child) > [class*="col-"],
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row:last-child:not(:first-child) > [class*="col-"] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row:last-child:not(:first-child) > [class*="col-"] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row:last-child:not(:first-child) a,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row:last-child:not(:first-child) a,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row:last-child:not(:first-child) a {
  background: var(--qba-accent);
  color: #fff !important;
  padding: 9px 20px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 12.5px;
  text-decoration: none;
  white-space: nowrap;
  display: inline-block;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row:last-child:not(:first-child) a::after,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row:last-child:not(:first-child) a::after,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row:last-child:not(:first-child) a::after {
  content: ' →';
}

/* ---------- 5. Heading di colonna (Classifiche/Recensioni/Guide/Per iniziare/Broker partner/Promo & guide/Conti deposito/...) ---------- */
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section:not(.qba-tagline) .item-header > a,
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section:not(.qba-tagline) .item-header > span,
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section:not(.qba-tagline) > .nav-header > span,
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section:not(.qba-tagline) > .nav-header > a {
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  color: var(--qba-ink) !important;
  padding-bottom: 9px !important;
  margin-bottom: 13px !important;
  border-bottom: 2px solid var(--qba-accent) !important;
  display: inline-block;
  line-height: 1.2 !important;
}

/* ---------- 6. Link delle colonne ---------- */
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li > a {
  font-size: 13.5px;
  line-height: 1.35;
  color: var(--qba-ink-2) !important;
  padding: 5px 8px 5px 0;
  display: block;
  border-radius: 6px;
  text-transform: none !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li > a:hover {
  color: var(--qba-accent-ink) !important;
}

/* Voce "Tutte le ..." (menu_class_sfx="qba-link-all") */
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li.qba-link-all > a {
  margin-top: 10px;
  padding-top: 11px;
  border-top: 1px solid var(--qba-line-soft);
  font-weight: 700 !important;
  font-size: 12.5px;
  color: var(--qba-accent-ink) !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li.qba-link-all > a::after {
  content: ' →';
}

/* ---------- 7. Vetrina card (HTML in mod_custom) ---------- */
.qba-mm-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
  background: var(--qba-card);
  border: 1px solid var(--qba-line);
  border-radius: 11px;
  overflow: hidden;
}
.qba-mm-card:hover {
  border-color: var(--qba-accent);
}
.qba-mm-card__media {
  height: 128px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.qba-mm-card__icon {
  width: 32px;
  height: 32px;
  color: #fff;
  flex-shrink: 0;
}

.qba-mm-card--conti .qba-mm-card__media { background: #fff; border-bottom: 1px solid var(--qba-line); }
.qba-mm-card--carte        .qba-mm-card__media { background: #fff; border-bottom: 1px solid var(--qba-line); }
.qba-mm-card--risparmio    .qba-mm-card__media { background: linear-gradient(135deg, #0f766e, #14b8a6); }
.qba-mm-card--investimenti .qba-mm-card__media { background: #fff; border-bottom: 1px solid var(--qba-line); }

.qba-mm-card__body {
  padding: 13px 15px 15px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.qba-mm-card__label {
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--qba-accent-ink);
  font-weight: 800;
  margin-bottom: 5px;
}
.qba-mm-card__title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 5px;
  color: var(--qba-ink);
}
.qba-mm-card__desc {
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--qba-muted);
  margin: 0;
  flex: 1;
}
.qba-mm-card__cta {
  font-size: 12px;
  color: var(--qba-accent-ink);
  font-weight: 700;
  margin-top: 9px;
}
.qba-mm-card__cta::after {
  content: ' →';
}

/* ---------- 8. Dropdown semplici (Strumenti/Esplora) ---------- */
.sp-megamenu-parent > li.qba-menu-v2.qba-dropdown-simple > .sp-dropdown {
  min-width: 260px;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-strumenti > .sp-dropdown {
  min-width: 300px;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-dropdown-simple > .sp-dropdown > .sp-dropdown-inner {
  padding: 16px 22px;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-dropdown-simple .sp-dropdown-items > li > a {
  display: block;
  padding: 8px 0;
  font-size: 14px;
  color: var(--qba-ink-2) !important;
  border-bottom: 1px solid var(--qba-line-soft);
  text-transform: none !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 1.35;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-dropdown-simple .sp-dropdown-items > li:last-child > a {
  border-bottom: none;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-dropdown-simple .sp-dropdown-items > li > a:hover {
  color: var(--qba-accent-ink) !important;
}

/* ---------- 9. Animazioni — gated ESCLUSIVAMENTE in no-preference ---------- */
/* FIX v2: NESSUN override @media (prefers-reduced-motion: reduce). In reduce
   il dropdown segue il display:none / :hover display:block nativo di Helix
   (vedi templates/finion/scss/menu.scss) — niente animazione, ma stato OK. */
@media (prefers-reduced-motion: no-preference) {
  .sp-megamenu-parent > li.qba-menu-v2 > a,
  .sp-megamenu-parent > li.qba-menu-v2 > a::after {
    transition: color .12s ease, transform .18s ease;
  }

  .sp-megamenu-parent > li.qba-menu-v2 > .sp-dropdown {
    display: block;                /* sostituisce display:none di Helix */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity .16s ease, transform .16s ease, visibility .16s;
  }
  .sp-megamenu-parent > li.qba-menu-v2:hover > .sp-dropdown,
  .sp-megamenu-parent > li.qba-menu-v2:focus-within > .sp-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  .sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li > a {
    transition: color .12s ease, padding-left .12s ease;
  }
  .sp-megamenu-parent > li.qba-menu-v2 .sp-mega-section ul > li > a:hover {
    padding-left: 6px;
  }

  .qba-mm-card {
    transition: border-color .15s ease, box-shadow .15s ease;
  }
  .qba-mm-card:hover {
    box-shadow: 0 8px 22px -8px rgba(15,23,42,.16);
  }
}

/* ---------- 10. Responsive ---------- */
@media (max-width: 1199.98px) {
  .sp-megamenu-parent > li.qba-menu-v2.custom-full-menu > .sp-dropdown {
    width: calc(100vw - 32px);
  }
  .sp-megamenu-parent > li.qba-menu-v2.custom-full-menu .sp-dropdown-inner > .row:not(:first-child) {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    padding: 20px 24px;
  }
}
/* < 992px: offcanvas mobile attivo, sp-megamenu-parent non viene reso. Mobile usa offcanvas.scss esistente. */

/* ---------- 11. SPPB row → flex (override Bootstrap row di SPPB nel dropdown) ---------- */
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-row {
  display: flex;
  gap: 24px;
  flex-wrap: nowrap;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-row > [class*="sppb-col"] {
  flex: 1 1 0;
  width: auto !important;
  max-width: none;
}

/* ============ MEGA MENU — MOCKUP STYLE (tutti e 4) ============ */
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner > .row,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-row {
  display: flex !important;
  gap: 40px;
  flex-wrap: nowrap;
  padding: 28px 32px !important;
  margin: 0 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner [class*="sppb-col"] {
  flex: 1 1 0 !important;
  width: auto !important;
  max-width: none !important;
  border: none !important;
  padding: 0 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-column-addons { padding: 0 !important; }
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-addon-header { text-align: left !important; }
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-addon-text-block,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .links-1 {
  text-align: left !important;
  text-transform: none !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .links-1 p { margin: 0 !important; }
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .links-1 a,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-addon-text-block a {
  display: block !important;
  color: var(--qba-ink-2, #334155) !important;
  text-decoration: none !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  padding: 5px 0 !important;
  transition: color .12s, padding-left .12s;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .links-1 a span { font-family: inherit !important; }
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .links-1 a:hover,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-addon-text-block a:hover {
  color: var(--qba-accent-ink, #c2410c) !important;
  padding-left: 6px !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .bottom-link a,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner a.bottom-link {
  color: var(--qba-accent-ink, #c2410c) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  text-transform: none !important;
  background: none !important;
  padding: 6px 0 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner #dropdown-container-bottom {
  background: #f8fafc !important;
  border-top: 1px solid var(--qba-line-soft, #eef2f6) !important;
  padding: 16px 32px !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .orange-btn a,
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner a.orange-btn {
  background: var(--qba-accent, #fa6b27) !important;
  color: #fff !important;
  border-radius: 8px !important;
  padding: 10px 20px !important;
  font-weight: 700 !important;
}

.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner #dropdown-container-bottom .sppb-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: 0 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner #dropdown-container-bottom .sppb-addon-text-block {
  color: #334155 !important;
  font-size: 15px !important;
  font-weight: 600 !important;
}
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner #dropdown-container-bottom [class*="sppb-col"] {
  flex: 0 0 auto !important;
}

/* ---------- 12. Consolidamento heading colonna ----------
   SOSTITUISCE le due regole eliminate allo STEP 2.
   Risultato: 12px, sentence-case (identico a quello che già vince oggi). */
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown .sp-dropdown-inner .sppb-addon-header .sppb-addon-title {
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 1.2px !important;
  text-transform: none !important;
  color: var(--qba-ink, #0f172a) !important;
  text-align: left !important;
  margin: 0 0 13px 0 !important;
  padding-bottom: 9px !important;
  border-bottom: 2px solid var(--qba-accent, #fa6b27) !important;
  display: inline-block !important;
}

/* ---------- 13. Colonna vetrina: larghezza fissa ----------
   RICHIEDE campo "Class" della 4ª sppb-col = qba-col-vetrina (lo metto a mano nell'editor). */
.sp-megamenu-parent > li.qba-menu-v2 .sp-dropdown-inner .sppb-row > .qba-col-vetrina {
  flex: 0 0 260px !important;
  width: 260px !important;
  max-width: 260px !important;
}

/* ---------- 14. Card "In evidenza" ---------- */
.qba-mm-card {
  display: block;
  text-decoration: none;
  border: 1px solid var(--qba-line, #e2e8f0);
  border-radius: 12px;
  overflow: hidden;
  background: var(--qba-white, #fff);
  transition: box-shadow .2s ease, transform .2s ease;
}
.qba-mm-card:hover {
  box-shadow: 0 12px 28px -12px rgba(15,23,42,.28);
  transform: translateY(-2px);
}
.qba-mm-card .qba-mm-img {
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 34px;
  font-weight: 800;
  color: #fff;
  background: var(--qba-accent, #fa6b27);
}
.qba-mm-card .qba-mm-body { padding: 14px 16px 16px; }
.qba-mm-card .qba-mm-lab {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--qba-accent-ink, #c2410c);
  margin-bottom: 5px;
}
.qba-mm-card .qba-mm-tt {
  font-size: 16px;
  font-weight: 800;
  color: var(--qba-ink, #0f172a);
  margin-bottom: 6px;
  letter-spacing: -.2px;
}
.qba-mm-card .qba-mm-ds {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--qba-muted, #64748b);
  margin-bottom: 12px;
}
.qba-mm-card .qba-mm-go {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--qba-accent-ink, #c2410c);
}
.qba-mm-card .qba-mm-go::after { content: ' →'; }

@media (prefers-reduced-motion: reduce) {
  .qba-mm-card { transition: none; }
  .qba-mm-card:hover { transform: none; }
}
/* ============================================================
   SEZIONE 15 — MEGA CONTI via mod_custom (HTML puro, no SPPB)
   Tutto ancorato a .qba-mm-conti. Tokens --qba-* da sez.1.
   Il guscio (.sp-dropdown, border-top, hover, posizionamento)
   resta gestito dalle sez. 3-4 sul <li class="qba-menu-v2">.
   ============================================================ */

/* Layout 3 colonne + vetrina (sostituisce .body-v1 del mockup) */
.qba-mm-conti .qba-mm-grid,
.qba-mm-investimenti .qba-mm-grid,
.qba-mm-carte .qba-mm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 300px;
  gap: 28px;
  padding: 26px 32px 30px;
}

.qba-mm-conti .qba-mm-vetrina,
.qba-mm-investimenti .qba-mm-vetrina,
.qba-mm-carte .qba-mm-vetrina {
  align-items: start;
  border-left: 1px solid var(--qba-line-soft);
  padding-left: 24px;
}

/* Heading di colonna */
.qba-mm-conti .qba-mm-title,
.qba-mm-investimenti .qba-mm-title,
.qba-mm-carte .qba-mm-title {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--qba-ink);
  padding-bottom: 9px;
  margin-bottom: 9px;
  border-bottom: 2px solid var(--qba-accent);
  display: inline-block;
  line-height: 1.2;
}

/* Tagline sotto top-link (Investimenti et al.) */
.qba-mm-conti .qba-mm-tagline,
.qba-mm-carte .qba-mm-tagline,
.qba-mm-investimenti .qba-mm-tagline {
  font-size: 13px;
  font-style: italic;
  color: var(--qba-ink-2);
  padding: 14px 32px 4px;
  margin: 0;
}

/* Liste link */
.qba-mm-conti .qba-mm-links,
.qba-mm-investimenti .qba-mm-links,
.qba-mm-carte .qba-mm-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.qba-mm-conti .qba-mm-links a,
.qba-mm-investimenti .qba-mm-links a,
.qba-mm-carte .qba-mm-links a {
  color: var(--qba-ink-2);
  text-decoration: none;
  font-size: 13.5px;
  line-height: 1.35;
  font-weight: 400;
  padding: 5px 8px 5px 0;
  display: block;
  border-radius: 6px;
}
.qba-mm-conti .qba-mm-links a:hover,
.qba-mm-investimenti .qba-mm-links a:hover,
.qba-mm-carte .qba-mm-links a:hover {
  color: var(--qba-accent-ink);
}

/* Voce "Tutte le ..." */
.qba-mm-conti .qba-mm-links a.qba-mm-all,
.qba-mm-investimenti .qba-mm-links a.qba-mm-all,
.qba-mm-carte .qba-mm-links a.qba-mm-all {
  margin-top: 10px;
  padding-top: 11px;
  border-top: 1px solid var(--qba-line-soft);
  font-weight: 700;
  font-size: 12.5px;
  color: var(--qba-accent-ink);
}
.qba-mm-conti .qba-mm-links a.qba-mm-all::after,
.qba-mm-investimenti .qba-mm-links a.qba-mm-all::after,
.qba-mm-carte .qba-mm-links a.qba-mm-all::after { content: ' \2192'; }

/* Card vetrina (riusa look di .qba-mm-card sez.14, ma autocontenuta) */
.qba-mm-conti .qba-mm-card,
.qba-mm-investimenti .qba-mm-card,
.qba-mm-carte .qba-mm-card {
  display: flex;
  flex-direction: column;
  background: var(--qba-card);
  border: 1px solid var(--qba-line);
  border-radius: 11px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  height: auto;
  align-self: start;
}
.qba-mm-conti .qba-mm-card:hover,
.qba-mm-investimenti .qba-mm-card:hover,
.qba-mm-carte .qba-mm-card:hover {
  border-color: var(--qba-accent);
  box-shadow: 0 8px 22px -8px rgba(15,23,42,.16);
}
.qba-mm-conti .qba-mm-card__media,
.qba-mm-investimenti .qba-mm-card__media,
.qba-mm-carte .qba-mm-card__media {
  height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-bottom: 1px solid var(--qba-line);
}
.qba-mm-conti .qba-mm-card__media img,
.qba-mm-investimenti .qba-mm-card__media img,
.qba-mm-carte .qba-mm-card__media img {
  max-width: 140px;
  max-height: 48px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.qba-mm-conti .qba-mm-card__body,
.qba-mm-investimenti .qba-mm-card__body,
.qba-mm-carte .qba-mm-card__body {
  padding: 13px 15px 15px;
  display: flex;
  flex-direction: column;
  
}
.qba-mm-conti .qba-mm-card__label,
.qba-mm-investimenti .qba-mm-card__label,
.qba-mm-carte .qba-mm-card__label {
  font-size: 10px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--qba-accent-ink);
  font-weight: 800;
  margin-bottom: 5px;
}
.qba-mm-conti .qba-mm-card__label::before,
.qba-mm-investimenti .qba-mm-card__label::before,
.qba-mm-carte .qba-mm-card__label::before { content: '\2605 '; }
.qba-mm-conti .qba-mm-card__title,
.qba-mm-investimenti .qba-mm-card__title,
.qba-mm-carte .qba-mm-card__title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 5px;
  color: var(--qba-ink);
}
.qba-mm-conti .qba-mm-card__desc,
.qba-mm-investimenti .qba-mm-card__desc,
.qba-mm-carte .qba-mm-card__desc {
  font-size: 12.5px;
  color: var(--qba-muted);
  line-height: 1.45;
  
}
.qba-mm-conti .qba-mm-card__cta,
.qba-mm-investimenti .qba-mm-card__cta,
.qba-mm-carte .qba-mm-card__cta {
  font-size: 12px;
  color: var(--qba-accent-ink);
  font-weight: 700;
  margin-top: 9px;
}
.qba-mm-conti .qba-mm-card__cta::after,
.qba-mm-investimenti .qba-mm-card__cta::after,
.qba-mm-carte .qba-mm-card__cta::after { content: ' \2192'; }

/* CTA footer */
}

/* Transizioni solo se l'utente non ha ridotto il movimento */
@media (prefers-reduced-motion: no-preference) {
  .qba-mm-conti .qba-mm-links a,
  .qba-mm-investimenti .qba-mm-links a,
  .qba-mm-carte .qba-mm-links a { transition: color .12s, padding-left .12s; }
  .qba-mm-conti .qba-mm-links a:hover,
  .qba-mm-investimenti .qba-mm-links a:hover,
  .qba-mm-carte .qba-mm-links a:hover { padding-left: 6px; }
  .qba-mm-conti .qba-mm-card,
  .qba-mm-investimenti .qba-mm-card,
  .qba-mm-carte .qba-mm-card { transition: border-color .15s, box-shadow .15s; }
}

/* Responsive: sotto i 1200px il guscio si adatta gia (sez.4);
   qui collassiamo la griglia per evitare overflow orizzontale */
@media (max-width: 1199.98px) {
  .qba-mm-conti .qba-mm-grid,
  .qba-mm-investimenti .qba-mm-grid,
  .qba-mm-carte .qba-mm-grid {
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }
  .qba-mm-conti .qba-mm-vetrina,
  .qba-mm-investimenti .qba-mm-vetrina,
  .qba-mm-carte .qba-mm-vetrina {
    border-left: none;
    padding-left: 0;
    grid-column: 1 / -1;
  }
}

/* ---------- FIX Conti mod_custom: neutralizza grid .row SPPB (riga 73) ---------- */
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row {
  display: block; grid-template-columns: none; gap: 0; padding: 0; margin: 0;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row > .col-sm-12,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row > .col-sm-12,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row > .col-sm-12,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner > .row > [class*="col-"],
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner > .row > [class*="col-"],
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner > .row > [class*="col-"] {
  display: block; width: 100%; max-width: 100%; flex: none; padding: 0; margin: 0;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner .sp-mega-group,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner .sp-mega-group,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner .sp-mega-group,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti .sp-dropdown-inner .sp-mega-group > li.module,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti .sp-dropdown-inner .sp-mega-group > li.module,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte .sp-dropdown-inner .sp-mega-group > li.module {
  list-style: none; margin: 0; padding: 0; display: block;
}

/* ---------- FIX Conti: larghezza 1200 piatta (no @media, JCH-safe) ---------- */
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti.custom-full-menu > .sp-dropdown,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti.custom-full-menu > .sp-dropdown,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte.custom-full-menu > .sp-dropdown {
  width: 1100px !important;
  max-width: calc(100vw - 32px) !important;
}

/* ---------- FIX Conti: elimina padding/bordo del .container Bootstrap nel dropdown ---------- */
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti > .sp-dropdown.container,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti > .sp-dropdown.container,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte > .sp-dropdown.container {
  padding-left: 0;
  padding-right: 0;
  border-width: 1px;
}
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti > .sp-dropdown > .sp-dropdown-inner,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti > .sp-dropdown > .sp-dropdown-inner,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte > .sp-dropdown > .sp-dropdown-inner {
  border: none;
  background: transparent;
}

/* ---------- FIX Conti: azzera padding .container Bootstrap (doppio bordo) ---------- */
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-conti > .sp-dropdown.container,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-investimenti > .sp-dropdown.container,
.sp-megamenu-parent > li.qba-menu-v2.qba-menu-carte > .sp-dropdown.container,
li.qba-menu-conti > .sp-dropdown.sp-menu-full.container,
li.qba-menu-investimenti > .sp-dropdown.sp-menu-full.container,
li.qba-menu-carte > .sp-dropdown.sp-menu-full.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* ---------- FIX Conti: allinea i link "Tutte le..." in fondo a ogni colonna ---------- */
.qba-mm-conti .qba-mm-col,
.qba-mm-investimenti .qba-mm-col,
.qba-mm-carte .qba-mm-col {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.qba-mm-conti .qba-mm-links,
.qba-mm-investimenti .qba-mm-links,
.qba-mm-carte .qba-mm-links { flex: 1 0 auto; }
.qba-mm-conti .qba-mm-links a.qba-mm-all,
.qba-mm-investimenti .qba-mm-links a.qba-mm-all,
.qba-mm-carte .qba-mm-links a.qba-mm-all {
  margin-top: auto;
}

/* ---------- FIX Conti: il link "Tutte le.." e' in un <li>, ancoro QUELLO in fondo ---------- */
.qba-mm-conti .qba-mm-links li:has(> a.qba-mm-all),
.qba-mm-investimenti .qba-mm-links li:has(> a.qba-mm-all),
.qba-mm-carte .qba-mm-links li:has(> a.qba-mm-all) {
  margin-top: auto;
  padding-top: 8px;
}

/* ---------- FASCIA CTA QUIZ — variante Navy (riusabile su tutte le voci) ---------- */
.qba-mm-cta {
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 0 24px 24px;
  padding: 22px 28px;
  border-radius: 12px;
  background: linear-gradient(135deg, #0f172a, #1e293b);
  border-left: 4px solid var(--qba-accent);
}
.qba-mm-cta__icon {
  width: 46px;
  height: 46px;
  border-radius: 11px;
  background: rgba(250,107,39,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
  line-height: 1;
  position: relative;
}
.qba-mm-cta__body { flex: 1; min-width: 0; }
.qba-mm-cta__title {
  font-size: 17px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 3px;
  line-height: 1.25;
}
.qba-mm-cta__sub {
  font-size: 13.5px;
  color: #94a3b8;
  line-height: 1.4;
}
.qba-mm-cta__btn {
  flex-shrink: 0;
  background: var(--qba-accent);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  padding: 12px 26px;
  border-radius: 50px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(250,107,39,.3);
  white-space: nowrap;
}
@media (prefers-reduced-motion: no-preference) {
  .qba-mm-cta__btn { transition: background .15s, box-shadow .15s, transform .15s; }
  .qba-mm-cta__btn:hover {
    background: #e85d1a;
    box-shadow: 0 6px 18px rgba(250,107,39,.4);
    transform: translateY(-1px);
  }
}

/* Icona target in CSS puro (no SVG, mod_custom-safe) */
.qba-mm-cta__icon::before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--qba-accent);
}
.qba-mm-cta__icon::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--qba-accent);
}
