.elementor-kit-6{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-6 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ============================================================
   MABE — DESIGN SYSTEM GLOBALE v2
   Versione definitiva con fix menu mobile
   Dove incollare: Elementor → Site Settings → Custom CSS
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ————————————————————————————————
   VARIABILI GLOBALI
———————————————————————————————— */
:root {
  --mabe-bg:          #070A0F;
  --mabe-surface:     #1E2A38;
  --mabe-surface-2:   #293849;
  --mabe-fg:          #FFFFFF;
  --mabe-dim:         #8B9AB0;
  --mabe-primary:     #2E5BFF;
  --mabe-primary-rgb: 46,91,255;
  --mabe-border:      rgba(78,99,128,.5);
  --mabe-deep:        #05070A;
  --mabe-danger:      #E5484D;

  --mabe-glow:        0 0 30px -6px rgba(46,91,255,.8);
  --mabe-glow-strong: 0 0 40px -2px rgba(46,91,255,1);
  --mabe-glow-soft:   0 20px 60px -20px rgba(46,91,255,.3);

  --mabe-radius-sm: 2px;
  --mabe-radius-md: 6px;

  --mabe-font: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mabe-mono: ui-monospace, 'SF Mono', Menlo, monospace;
}

/* ————————————————————————————————
   RESET BASE
———————————————————————————————— */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--mabe-font);
  background-color: var(--mabe-bg) !important;
  color: var(--mabe-fg);
  -webkit-font-smoothing: antialiased;
  margin: 0;
  padding: 0;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image:
    radial-gradient(ellipse 800px 400px at 50% -10%, rgba(46,91,255,.12), transparent),
    radial-gradient(ellipse 600px 300px at 90% 20%, rgba(46,91,255,.06), transparent);
  pointer-events: none;
  z-index: 0;
}

.elementor-section,
.elementor-container,
.e-con,
.e-con-inner {
  position: relative;
  z-index: 1;
}

::selection { background: var(--mabe-primary); color: #fff; }

/* ————————————————————————————————
   CONTAINER
———————————————————————————————— */
.mabe-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) {
  .mabe-container { padding: 0 40px; }
}

/* ————————————————————————————————
   TIPOGRAFIA
———————————————————————————————— */
.mabe-h1 {
  font-size: clamp(48px, 6vw, 80px);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
}
.mabe-h2 {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0;
}
.mabe-h3 {
  font-size: clamp(24px, 2.4vw, 30px);
  font-weight: 500;
  margin: 0;
}
.mabe-h4 {
  font-size: 18px;
  font-weight: 500;
  margin: 0;
}
.mabe-body {
  font-size: 18px;
  line-height: 1.6;
  color: var(--mabe-dim);
  margin: 0;
}
.mabe-small {
  font-size: 14px;
  color: var(--mabe-dim);
  margin: 0;
}
.mabe-eyebrow {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--mabe-primary);
}
.mabe-mono {
  font-family: var(--mabe-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--mabe-dim);
}
.mabe-text-glow    { text-shadow: 0 0 24px rgba(46,91,255,.5); }
.mabe-text-primary { color: var(--mabe-primary); }
.mabe-text-dim     { color: var(--mabe-dim); }

/* ————————————————————————————————
   GLASS
———————————————————————————————— */
.mabe-glass {
  background: rgba(18,26,38,.6);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255,255,255,.08);
}
.mabe-glass-strong {
  background: rgba(7,10,15,.75);
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  border: 1px solid rgba(255,255,255,.08);
}

/* ————————————————————————————————
   PATTERN
———————————————————————————————— */
.mabe-grid-pattern {
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 40px 40px;
}
.mabe-dot-pattern {
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.12) 1px, transparent 0);
  background-size: 24px 24px;
}

/* ————————————————————————————————
   CROSSHAIR
———————————————————————————————— */
.mabe-crosshair { position: relative; }
.mabe-crosshair::before,
.mabe-crosshair::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  border-color: rgba(255,255,255,.4);
}
.mabe-crosshair::before { top: 8px; left: 8px; border-top: 1px solid; border-left: 1px solid; }
.mabe-crosshair::after  { bottom: 8px; right: 8px; border-bottom: 1px solid; border-right: 1px solid; }

/* ————————————————————————————————
   BOTTONI
———————————————————————————————— */
.mabe-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 48px;
  padding: 0 28px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .01em;
  border-radius: var(--mabe-radius-sm);
  cursor: pointer !important;
  text-decoration: none;
  transition: all .25s ease;
  border: 1px solid transparent;
  font-family: var(--mabe-font);
  pointer-events: all !important;
}
.mabe-btn--primary {
  background: var(--mabe-primary);
  color: #fff;
  box-shadow: var(--mabe-glow);
}
.mabe-btn--primary:hover {
  box-shadow: var(--mabe-glow-strong);
  transform: translateY(-1px);
  color: #fff;
  text-decoration: none;
}
.mabe-btn--ghost {
  background: rgba(18,26,38,.6);
  color: var(--mabe-fg);
  border-color: var(--mabe-border);
  backdrop-filter: blur(20px);
}
.mabe-btn--ghost:hover {
  background: rgba(30,42,56,.6);
  color: var(--mabe-fg);
  text-decoration: none;
}
.mabe-arrow { transition: transform .25s ease; display: inline-block; }
.mabe-btn:hover .mabe-arrow { transform: translateX(4px); }

/* ————————————————————————————————
   ELEMENTI DECORATIVI
———————————————————————————————— */
.mabe-dot-glow {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--mabe-primary);
  animation: mabe-glow-pulse 3s ease-in-out infinite;
}
.mabe-line {
  height: 1px;
  width: 32px;
  background: var(--mabe-primary);
  box-shadow: 0 0 8px var(--mabe-primary);
  display: inline-block;
  flex-shrink: 0;
}
.mabe-divider-grad {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(46,91,255,.6), transparent);
}

/* ————————————————————————————————
   SCAN LINE
———————————————————————————————— */
.mabe-scan-overlay {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}
.mabe-scan-overlay::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(46,91,255,.8);
  box-shadow: 0 0 15px var(--mabe-primary);
  animation: mabe-scan-line 4s linear infinite;
}

/* ————————————————————————————————
   CARD
———————————————————————————————— */
.mabe-card {
  background: rgba(30,42,56,.4);
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-md);
  padding: 32px;
  transition: border-color .4s ease, background .4s ease;
  position: relative;
  overflow: hidden;
}
.mabe-card:hover { border-color: rgba(46,91,255,.4); }

/* ————————————————————————————————
   ICON BOX
———————————————————————————————— */
.mabe-iconbox {
  width: 40px;
  height: 40px;
  border: 1px solid var(--mabe-border);
  background: rgba(30,42,56,.4);
  border-radius: var(--mabe-radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--mabe-primary);
  transition: all .3s ease;
  flex-shrink: 0;
}
.mabe-card:hover .mabe-iconbox,
.mabe-iconbox:hover {
  border-color: rgba(46,91,255,.6);
  box-shadow: 0 0 18px -4px var(--mabe-primary);
}

/* ————————————————————————————————
   SECTION HEADER
———————————————————————————————— */
.mabe-section-header {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 768px;
}
.mabe-section-header__eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;
}
.mabe-section-header.is-center {
  align-items: center;
  text-align: center;
  margin: 0 auto;
}

/* ————————————————————————————————
   LINK ARROW
———————————————————————————————— */
.mabe-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--mabe-fg);
  text-decoration: none;
  transition: color .25s;
  pointer-events: all !important;
  cursor: pointer !important;
}
.mabe-link-arrow:hover { color: var(--mabe-primary); text-decoration: none; }
.mabe-link-arrow:hover .mabe-arrow { transform: translateX(4px); }

/* ————————————————————————————————
   BULLETS
———————————————————————————————— */
.mabe-bullets {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mabe-bullets li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: rgba(255,255,255,.8);
}
.mabe-bullets li::before {
  content: "";
  width: 4px;
  height: 4px;
  background: var(--mabe-primary);
  border-radius: 50%;
  box-shadow: 0 0 6px var(--mabe-primary);
  flex-shrink: 0;
}

/* ————————————————————————————————
   REVEAL ON SCROLL
———————————————————————————————— */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ————————————————————————————————
   HEADER
———————————————————————————————— */
.mabe-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999999 !important;
  background: rgba(7,10,15,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: all .3s ease;
  pointer-events: all !important;
}
.mabe-header.is-scrolled {
  background: rgba(7,10,15,.95);
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  border-bottom-color: rgba(78,99,128,.4);
}
.mabe-header__inner {
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 24px;
  pointer-events: all !important;
}
@media (min-width: 1024px) {
  .mabe-header__inner { padding: 0 40px; }
}

/* LOGO */
.mabe-header__logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  pointer-events: all !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  position: relative;
}
.mabe-header__logo img {
  height: 40px;
  width: auto;
  transition: filter .3s ease;
}
.mabe-header__logo:hover img {
  filter: drop-shadow(0 0 12px rgba(46,91,255,.6));
}
.mabe-header__sub {
  font-family: var(--mabe-mono);
  font-size: 9px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--mabe-dim);
}
@media (max-width: 640px) { .mabe-header__sub { display: none; } }

/* NAV DESKTOP */
.mabe-nav {
  display: none;
  gap: 28px;
  pointer-events: all !important;
}
@media (min-width: 1024px) {
  .mabe-nav { display: flex; align-items: center; }
}

/* NAV LINK */
.mabe-nav__link {
  position: relative;
  font-size: 14px;
  font-weight: 500;
  color: #ffffff !important;
  text-decoration: none !important;
  padding: 24px 8px !important;
  transition: color .25s ease;
  pointer-events: all !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  display: inline-flex !important;
  align-items: center !important;
  line-height: 1 !important;
}
.mabe-nav__link:hover { color: rgba(255,255,255,.7) !important; }
.mabe-nav__link.is-active { color: #ffffff !important; }
.mabe-nav__link.is-active::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 16px;
  height: 1px;
  background: var(--mabe-primary);
  box-shadow: 0 0 8px var(--mabe-primary);
}

/* HEADER ACTIONS */
.mabe-header__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  pointer-events: all !important;
  position: relative;
  z-index: 999999 !important;
}
.mabe-header__cta {
  height: 40px;
  padding: 0 20px;
  font-size: 13px;
  pointer-events: all !important;
  cursor: pointer !important;
}
@media (max-width: 640px) { .mabe-header__cta { display: none; } }

/* BURGER */
.mabe-burger {
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-sm);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer !important;
  pointer-events: all !important;
  position: relative;
  z-index: 999999 !important;
}
.mabe-burger span {
  width: 18px;
  height: 1.5px;
  background: #fff;
  transition: .25s;
  display: block;
}
@media (min-width: 1024px) { .mabe-burger { display: none; } }

/* ————————————————————————————————
   MENU MOBILE — FIX DEFINITIVO
   position: fixed, nero pieno, sopra tutto
———————————————————————————————— */
.mabe-mobile-menu {
  display: none;
  flex-direction: column;
  gap: 0;
  background: #070A0F !important;
  border-top: 1px solid rgba(78,99,128,.4);
  position: fixed !important;
  top: 80px;
  left: 0;
  right: 0;
  z-index: 999998 !important;
  pointer-events: all !important;
  box-shadow: 0 20px 40px rgba(0,0,0,.9);
}
.mabe-mobile-menu.is-open {
  display: flex !important;
}
.mabe-mobile-menu a {
  padding: 16px 24px !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #ffffff !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(78,99,128,.2);
  transition: all .2s;
  pointer-events: all !important;
  cursor: pointer !important;
  display: block !important;
  position: relative;
  z-index: 999999 !important;
}
.mabe-mobile-menu a:hover {
  color: #ffffff !important;
  background: rgba(46,91,255,.15) !important;
  padding-left: 32px !important;
}
.mabe-mobile-menu .mabe-btn {
  margin: 16px 24px !important;
  justify-content: center !important;
  border-bottom: none !important;
}

/* Offset pagina per header fixed */
.elementor-page { padding-top: 80px !important; }

/* ————————————————————————————————
   FOOTER
———————————————————————————————— */
.mabe-footer {
  background: var(--mabe-bg);
  border-top: 1px solid rgba(78,99,128,.5);
  position: relative;
}
.mabe-footer__grid {
  display: grid;
  gap: 48px;
  padding: 64px 24px;
  grid-template-columns: 1fr;
  max-width: 1440px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .mabe-footer__grid { grid-template-columns: 2fr 1fr 1fr; padding: 64px 40px; }
}
.mabe-footer__title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: var(--mabe-dim);
  margin: 0 0 16px;
}
.mabe-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 14px;
}
.mabe-footer__list a {
  color: rgba(255,255,255,.9);
  text-decoration: none;
  transition: color .25s;
  pointer-events: all !important;
}
.mabe-footer__list a:hover { color: var(--mabe-primary); }
.mabe-footer__bottom {
  border-top: 1px solid rgba(78,99,128,.4);
  padding: 24px 40px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: var(--mabe-dim);
  max-width: 1440px;
  margin: 0 auto;
}

/* ————————————————————————————————
   HERO
———————————————————————————————— */
.mabe-hero {
  position: relative;
  overflow: hidden;
}
.mabe-hero__halo {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1000px;
  height: 500px;
  border-radius: 50%;
  background: rgba(46,91,255,.15);
  filter: blur(140px);
  pointer-events: none;
  z-index: 0;
}
.mabe-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: center;
  padding-top: 64px;
  padding-bottom: 96px;
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .mabe-hero__grid {
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    padding-top: 96px;
  }
}
.mabe-hero__metrics {
  display: flex;
  gap: 40px;
  padding-top: 40px;
  margin-top: 40px;
  border-top: 1px solid rgba(78,99,128,.5);
  flex-wrap: wrap;
}
.mabe-hero__metrics > div { display: flex; flex-direction: column; gap: 4px; }
.mabe-hero__metric-val {
  font-size: 24px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.mabe-hero__visual {
  position: relative;
  aspect-ratio: 4/5;
}
@media (min-width: 1024px) { .mabe-hero__visual { aspect-ratio: 1/1; } }
.mabe-hero__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid var(--mabe-border);
  transform: scale(.88);
  opacity: .5;
}
.mabe-hero__ring--inner {
  border: .5px solid rgba(46,91,255,.3);
  transform: scale(.96);
  opacity: 1;
  box-shadow: inset 0 0 60px rgba(46,91,255,.15);
}
.mabe-hero__frame {
  position: absolute;
  inset: 16px;
  border-radius: var(--mabe-radius-sm);
  overflow: hidden;
  background: var(--mabe-surface);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.1);
}
.mabe-hero__frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .9;
}
.mabe-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top right, rgba(7,10,15,.7), transparent, rgba(46,91,255,.2));
  mix-blend-mode: hard-light;
  pointer-events: none;
}
.mabe-hero__readout {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  color: rgba(255,255,255,.7);
  font-family: var(--mabe-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .15em;
}

/* ————————————————————————————————
   DIVISIONI
———————————————————————————————— */
.mabe-divisions {
  display: grid;
  gap: 24px;
  margin-top: 64px;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .mabe-divisions { grid-template-columns: 1fr 1fr; } }
.mabe-division {
  position: relative;
  min-height: 520px;
  padding: 40px;
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-md);
  overflow: hidden;
  transition: border-color .5s ease;
  display: flex;
  flex-direction: column;
}
.mabe-division--b2c { background: rgba(30,42,56,.4); }
.mabe-division--b2b { background: var(--mabe-deep); }
.mabe-division:hover { border-color: rgba(46,91,255,.4); }
.mabe-division--b2b:hover { border-color: rgba(46,91,255,.6); }
.mabe-division__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .3;
  filter: grayscale(100%);
  transition: all .7s ease;
  z-index: 0;
}
.mabe-division:hover .mabe-division__bg { opacity: .5; filter: grayscale(0); }
.mabe-division--b2b .mabe-division__bg { opacity: .2; filter: none; }
.mabe-division--b2b:hover .mabe-division__bg { opacity: .3; }
.mabe-division::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: linear-gradient(to top, var(--mabe-bg), rgba(7,10,15,.8) 30%, rgba(7,10,15,.3));
}
.mabe-division--b2b::after {
  background: linear-gradient(to top, var(--mabe-deep), rgba(5,7,10,.9) 30%, rgba(5,7,10,.6));
}
.mabe-division__sidebar {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--mabe-primary);
  box-shadow: 0 0 20px var(--mabe-primary);
  opacity: .6;
  z-index: 2;
}
.mabe-division__shimmer {
  position: absolute;
  top: 0; right: 0;
  height: 100%;
  width: 50%;
  background: linear-gradient(to left, rgba(255,255,255,.05), transparent);
  transform: translateX(100%) skewX(-12deg);
  transition: transform 1s ease-out;
  pointer-events: none;
  z-index: 3;
}
.mabe-division:hover .mabe-division__shimmer { transform: translateX(0) skewX(-12deg); }
.mabe-division__content {
  position: relative;
  z-index: 4;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.mabe-division__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
}

/* ————————————————————————————————
   REASONS
———————————————————————————————— */
.mabe-reasons {
  display: grid;
  gap: 1px;
  margin-top: 64px;
  background: rgba(78,99,128,.4);
  border-radius: var(--mabe-radius-md);
  overflow: hidden;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px) { .mabe-reasons { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .mabe-reasons { grid-template-columns: repeat(5, 1fr); } }
.mabe-reason {
  background: var(--mabe-bg);
  padding: 32px;
  min-height: 200px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background .5s ease;
}
.mabe-reason:hover { background: rgba(30,42,56,.4); }

/* ————————————————————————————————
   PORTFOLIO
———————————————————————————————— */
.mabe-works-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .mabe-works-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mabe-works-grid { grid-template-columns: repeat(4, 1fr); } }
.mabe-work-card {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: var(--mabe-radius-sm);
  background: var(--mabe-surface);
  box-shadow: inset 0 0 0 1px var(--mabe-border);
  text-decoration: none;
  color: #fff;
  display: block;
  pointer-events: all !important;
  cursor: pointer !important;
}
.mabe-work-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s ease;
  display: block;
}
.mabe-work-card:hover img { transform: scale(1.05); }
.mabe-work-card:hover { box-shadow: inset 0 0 0 1px rgba(46,91,255,.4); }
.mabe-work-card__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(to top, var(--mabe-bg), rgba(7,10,15,.4) 50%, transparent);
}
.mabe-work-card__tag {
  position: absolute;
  top: 12px;
  left: 12px;
  font-family: var(--mabe-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .15em;
  padding: 4px 8px;
  border-radius: var(--mabe-radius-sm);
  border: 1px solid;
  backdrop-filter: blur(12px);
}
.mabe-work-card__tag--white {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
  color: #fff;
}
.mabe-work-card__tag--blue {
  background: rgba(46,91,255,.2);
  border-color: rgba(46,91,255,.4);
  color: var(--mabe-primary);
}
.mabe-work-card__caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 20px;
}
.mabe-work-card__caption h4 {
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  margin: 0 0 4px;
}

/* ————————————————————————————————
   INFO CARDS
———————————————————————————————— */
.mabe-info-cards {
  display: grid;
  gap: 16px;
  margin-top: 40px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .mabe-info-cards { grid-template-columns: 1fr 1fr; } }
.mabe-info-card {
  padding: 20px;
  border-radius: var(--mabe-radius-sm);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mabe-info-card strong { font-size: 14px; font-weight: 500; }
.mabe-info-card span  { font-size: 12px; color: var(--mabe-dim); }

/* ————————————————————————————————
   CTA BANNER
———————————————————————————————— */
.mabe-cta-banner {
  position: relative;
  overflow: hidden;
  border-radius: var(--mabe-radius-md);
  background: rgba(7,10,15,.75);
  backdrop-filter: blur(28px) saturate(160%);
  border: 1px solid rgba(78,99,128,.6);
  padding: 64px 32px;
}
@media (min-width: 1024px) { .mabe-cta-banner { padding: 80px; } }
.mabe-cta-banner__halo {
  position: absolute;
  top: -80px;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 300px;
  border-radius: 50%;
  background: rgba(46,91,255,.3);
  filter: blur(120px);
  pointer-events: none;
}
.mabe-cta-banner__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
  justify-content: space-between;
}
@media (min-width: 1024px) {
  .mabe-cta-banner__inner { flex-direction: row; align-items: center; }
}

/* ————————————————————————————————
   PROCESSO
———————————————————————————————— */
.mabe-process {
  position: relative;
  display: grid;
  gap: 24px;
  margin-top: 64px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .mabe-process { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mabe-process { grid-template-columns: repeat(4, 1fr); } }
.mabe-process__line { display: none; }
@media (min-width: 1024px) {
  .mabe-process__line {
    display: block;
    position: absolute;
    top: 48px;
    left: 12%;
    right: 12%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(46,91,255,.4), transparent);
    z-index: 0;
  }
}
.mabe-process__step {
  border-radius: var(--mabe-radius-md);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.mabe-process__num {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(46,91,255,.4);
  background: var(--mabe-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mabe-mono);
  font-size: 14px;
  color: var(--mabe-primary);
  box-shadow: 0 0 20px -4px var(--mabe-primary);
}

/* ————————————————————————————————
   MATERIALI
———————————————————————————————— */
.mabe-materials {
  display: grid;
  gap: 24px;
  margin-top: 64px;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .mabe-materials { grid-template-columns: repeat(3, 1fr); } }
.mabe-material {
  position: relative;
  padding: 32px;
  background: rgba(30,42,56,.4);
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-md);
  transition: all .35s;
  overflow: hidden;
}
.mabe-material:hover { border-color: rgba(46,91,255,.4); }
.mabe-material__halo {
  position: absolute;
  top: -48px; right: -48px;
  width: 160px; height: 160px;
  background: rgba(46,91,255,.1);
  filter: blur(48px);
  border-radius: 50%;
  opacity: 0;
  transition: opacity .7s;
}
.mabe-material:hover .mabe-material__halo { opacity: 1; }
.mabe-spec-list {
  list-style: none;
  padding: 24px 0 0;
  margin: 0;
  border-top: 1px solid rgba(78,99,128,.4);
}
.mabe-spec-list li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  font-size: 14px;
  border-bottom: 1px solid rgba(78,99,128,.2);
}
.mabe-spec-list li:last-child { border-bottom: none; }
.mabe-spec-list li > span:first-child {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--mabe-dim);
}

/* ————————————————————————————————
   TECH SPECS
———————————————————————————————— */
.mabe-tech-specs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 48px;
  background: rgba(78,99,128,.4);
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-sm);
  overflow: hidden;
}
.mabe-tech-specs > div { background: var(--mabe-bg); padding: 16px; }
.mabe-tech-specs strong {
  display: block;
  margin-top: 4px;
  font-size: 18px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.mabe-tech-specs strong span { color: var(--mabe-dim); font-size: 14px; }

/* ————————————————————————————————
   SERVICES DARK
———————————————————————————————— */
.mabe-services-dark {
  display: grid;
  gap: 24px;
  margin-top: 64px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) { .mabe-services-dark { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mabe-services-dark { grid-template-columns: repeat(3, 1fr); } }
.mabe-service-dark {
  position: relative;
  padding: 32px;
  background: var(--mabe-deep);
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-md);
  transition: border-color .35s;
  overflow: hidden;
}
.mabe-service-dark:hover { border-color: rgba(46,91,255,.5); }
.mabe-service-dark__edge {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 1px;
  background: var(--mabe-primary);
  opacity: 0;
  transition: all .35s;
}
.mabe-service-dark:hover .mabe-service-dark__edge {
  opacity: 1;
  box-shadow: 0 0 15px var(--mabe-primary);
}

/* ————————————————————————————————
   STATS
———————————————————————————————— */
.mabe-stats {
  display: grid;
  gap: 1px;
  background: rgba(78,99,128,.4);
  border-radius: var(--mabe-radius-md);
  overflow: hidden;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 1024px) { .mabe-stats { grid-template-columns: repeat(4, 1fr); } }
.mabe-stats__item {
  background: var(--mabe-bg);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mabe-stats__val {
  font-size: clamp(36px, 4vw, 48px);
  font-weight: 300;
  font-variant-numeric: tabular-nums;
}

/* ————————————————————————————————
   FILTRI LAVORI
———————————————————————————————— */
.mabe-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 40px;
}
.mabe-filter-btn {
  padding: 0 20px;
  height: 40px;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--mabe-radius-sm);
  cursor: pointer !important;
  background: rgba(18,26,38,.6);
  backdrop-filter: blur(20px);
  border: 1px solid var(--mabe-border);
  color: var(--mabe-dim);
  transition: all .25s;
  font-family: var(--mabe-font);
  pointer-events: all !important;
}
.mabe-filter-btn:hover { color: #fff; border-color: rgba(255,255,255,.3); }
.mabe-filter-btn.is-active {
  background: var(--mabe-primary);
  border-color: var(--mabe-primary);
  color: #fff;
  box-shadow: 0 0 20px -4px var(--mabe-primary);
}
.mabe-works-list {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .mabe-works-list { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mabe-works-list { grid-template-columns: repeat(3, 1fr); } }
.mabe-work-item {
  background: rgba(30,42,56,.4);
  border: 1px solid var(--mabe-border);
  border-radius: var(--mabe-radius-md);
  overflow: hidden;
  transition: border-color .35s;
}
.mabe-work-item:hover { border-color: rgba(46,91,255,.4); }
.mabe-work-item__media {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.mabe-work-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s;
  display: block;
}
.mabe-work-item:hover .mabe-work-item__media img { transform: scale(1.05); }
.mabe-work-item__body { padding: 24px; }

/* ————————————————————————————————
   CONTATTI
———————————————————————————————— */
.mabe-contact-row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px;
  border-radius: var(--mabe-radius-sm);
  text-decoration: none;
  color: #fff;
  transition: border-color .25s;
  margin-bottom: 8px;
  pointer-events: all !important;
  cursor: pointer !important;
}
.mabe-contact-row:hover {
  border-color: rgba(46,91,255,.4) !important;
  color: #fff;
  text-decoration: none;
}

/* ————————————————————————————————
   FORM ELEMENTOR PRO OVERRIDE
———————————————————————————————— */
.elementor-form-fields-wrapper {
  gap: 16px !important;
  display: flex !important;
  flex-direction: column !important;
}
.elementor-field-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  color: #8B9AB0 !important;
  margin-bottom: 6px !important;
  font-family: 'Inter', sans-serif !important;
}
.elementor-field-textual,
.elementor-form input[type="text"],
.elementor-form input[type="email"],
.elementor-form input[type="tel"],
.elementor-form input[type="number"],
.elementor-form select,
.elementor-form textarea {
  background: rgba(30,42,56,0.6) !important;
  border: 1px solid rgba(78,99,128,0.5) !important;
  border-radius: 2px !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-family: 'Inter', sans-serif !important;
  padding: 12px 16px !important;
  height: auto !important;
  min-height: 48px !important;
  width: 100% !important;
  transition: all 0.25s ease !important;
  box-shadow: none !important;
}
.elementor-form textarea {
  min-height: 120px !important;
  resize: vertical !important;
}
.elementor-field-textual:focus,
.elementor-form input:focus,
.elementor-form select:focus,
.elementor-form textarea:focus {
  outline: none !important;
  border-color: #2E5BFF !important;
  box-shadow: 0 0 0 3px rgba(46,91,255,0.15) !important;
  background: rgba(30,42,56,0.9) !important;
}
.elementor-form input::placeholder,
.elementor-form textarea::placeholder {
  color: rgba(139,154,176,0.6) !important;
}
.elementor-form select option {
  background: #1E2A38 !important;
  color: #ffffff !important;
}
.elementor-button[type="submit"],
.elementor-form .e-form__buttons .elementor-button {
  background: #2E5BFF !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 2px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  font-family: 'Inter', sans-serif !important;
  height: 48px !important;
  padding: 0 28px !important;
  box-shadow: 0 0 30px -6px rgba(46,91,255,0.8) !important;
  transition: all 0.25s ease !important;
  cursor: pointer !important;
  width: 100% !important;
}
.elementor-button[type="submit"]:hover,
.elementor-form .e-form__buttons .elementor-button:hover {
  box-shadow: 0 0 40px -2px rgba(46,91,255,1) !important;
  transform: translateY(-1px) !important;
}
.elementor-message.elementor-message-success {
  background: rgba(46,91,255,0.1) !important;
  border: 1px solid rgba(46,91,255,0.3) !important;
  border-radius: 2px !important;
  color: #ffffff !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
}
.elementor-message.elementor-message-danger {
  background: rgba(229,72,77,0.1) !important;
  border: 1px solid rgba(229,72,77,0.3) !important;
  border-radius: 2px !important;
  color: #E5484D !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
}

/* ————————————————————————————————
   KEYFRAMES
———————————————————————————————— */
@keyframes mabe-glow-pulse {
  0%,100% { box-shadow: 0 0 20px -4px rgba(46,91,255,.4); opacity: .85; }
  50%     { box-shadow: 0 0 50px -2px rgba(46,91,255,.8); opacity: 1; }
}
@keyframes mabe-scan-line {
  0%   { transform: translateY(-100%); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(8000%); opacity: 0; }
}

/* ————————————————————————————————
   UTILITY
———————————————————————————————— */
.mabe-section-border-top { border-top: 1px solid rgba(78,99,128,.5); }
.mabe-py { padding-top: 96px; padding-bottom: 96px; }
.mabe-pt { padding-top: 96px; }
.mabe-pb { padding-bottom: 96px; }/* End custom CSS */