/* === Inline style 1 === */
  html, body { margin: 0; padding: 0; }
  body{
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
    color: #0b1220;
    background:#fff;
  }


/* === Inline style 2 === */
    /* ✅ Vars GLOBALI (servono anche FUORI dall'header: burger/drawer/backdrop/spacer) */
    :root{
      --aof-h-desktop: 98px;
      --aof-h-mobile: 88px; /* ✅ più alto per logo più grande */
    }

    .aof-header {
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 222 47% 11%;
      --bd: rgba(2, 6, 23, .08);
      --shadow: 0 10px 26px rgba(2, 6, 23, .10);

      --h-desktop: var(--aof-h-desktop);
      --h-mobile: var(--aof-h-mobile);
      --pad-l: clamp(6px, 1.2vw, 12px);
      --pad-r: clamp(6px, 1.2vw, 12px);
      --maxw: 1240px;

      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 1002;

      background-color: rgba(255, 255, 255, .96);
      border-bottom: 1px solid var(--bd);
      box-shadow: none;

      transform: translateZ(0);
      -webkit-transform: translateZ(0);
      backface-visibility: hidden;
      will-change: background-color, border-color, box-shadow;
      transition: box-shadow .28s ease, border-color .28s ease, background-color .28s ease;
      opacity: 1 !important;
      visibility: visible !important;
      isolation: isolate;
      pointer-events: auto;
    }

    .aof-header::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      background: transparent;
      pointer-events: none;
      opacity: 0;
      transition: opacity .34s ease;
    }

    /* ✅ Lineetta scenografica (desktop + mobile) */
    .aof-header::after {
      content: "";
      position: absolute;
      inset: auto 0 0 0;
      height: 2px;
      z-index: 2;
      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
      opacity: .22; /* ✅ un pelo più visibile */
      transition: opacity .28s ease;
      pointer-events: none;
    }

    .aof-header.is-scrolled {
      background-color: rgba(255, 255, 255, .52);
      border-bottom-color: rgba(2, 6, 23, .12);
      box-shadow: var(--shadow);
    }

    .aof-header.is-scrolled::after { opacity: .34; }

    .aof-header.is-scrolled.aof-filter-armed::before {
      backdrop-filter: blur(16px) saturate(150%) brightness(1.03);
      -webkit-backdrop-filter: blur(16px) saturate(150%) brightness(1.03);
      opacity: 1;
    }

    @supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))) {
      .aof-header.is-scrolled {
        background-color: rgba(255, 255, 255, .78);
        box-shadow: 0 10px 24px rgba(2, 6, 23, .12);
      }
    }

    .aof-header__inner {
      position: relative;
      z-index: 1;
      height: var(--h-desktop);
      width: 100%;
      margin: 0;
      padding: 0 calc(var(--pad-r) + env(safe-area-inset-right, 0px)) 0 calc(var(--pad-l) + env(safe-area-inset-left, 0px));
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: clamp(12px, 3vw, 24px);
    }

    .aof-logo {
      display: block;
      height: 90px;
      width: auto;
      object-fit: contain;
      filter: drop-shadow(0 1px 4px rgba(2, 6, 23, .08));
    }

    .aof-nav {
      position: relative;
      justify-self: center;
      display: flex;
      align-items: center;
      gap: clamp(18px, 3.6vw, 40px);
      padding-bottom: 8px;
    }

	    .aof-nav a {
	      text-decoration: none;
	      color: hsl(var(--ink));
	      font-weight: 800;
	      letter-spacing: .01em;
	      font-size: clamp(15.5px, 1.18vw, 18px);
	      padding: 12px 0;
	      transition: transform .2s ease;
	      white-space: nowrap;
	    }

	    .aof-nav a:hover { transform: translateY(-1px); }
	    .aof-nav a.aof-nav__blog{
	      position: relative;
	      font-weight: 900;
	      color: #0b1324;
	      font-size: 1.07em;
	    }

	    /* ✅ "Dove operiamo": stesso stile di Blog */
	    .aof-nav a.aof-nav__where{
	      position: relative;
	      font-weight: 900;
	      color: #0b1324;
	      font-size: 1.07em;
	      margin-left: 0; /* lo spazio lo gestisce il separatore per mantenerlo centrato */
	    }

	    .aof-nav a.aof-nav__where::after{
	      content:"";
	      position:absolute;
	      left:-2px;
	      right:-2px;
	      bottom: 7px;
	      height: 2px;
	      border-radius: 999px;
	      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
	      opacity: 0;
	      width: 0;
	      margin: 0 auto;
	    }
	    .aof-nav a.aof-nav__where[aria-current="page"]::after{
	      opacity: .95;
	      width: 100%;
	    }

	    /* ✅ Separatore leggero tra le prime 3 voci e (Dove operiamo + Blog) */
	    .aof-nav .aof-nav-sep{
	      width: 2px;
	      height: 22px;
	      border-radius: 999px;
	      background: linear-gradient(180deg, rgba(14,165,233,.55), rgba(37,99,235,.55));
	      margin-left: clamp(18px, 3.4vw, 56px);
	      margin-right: clamp(18px, 3.4vw, 56px);
	      transform: translateY(0);
	      opacity: .55;
	      box-shadow: 0 10px 24px rgba(2,6,23,.08);
	    }
	    .aof-nav a.aof-nav__blog::after{
	      content:"";
	      position:absolute;
	      left:-2px;
	      right:-2px;
	      bottom: 7px;
	      height: 2px;
	      border-radius: 999px;
	      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
	      opacity: 0;
	      width: 0;
	      margin: 0 auto;
	    }
	    .aof-nav a.aof-nav__blog[aria-current="page"]::after{
	      opacity: .95;
	      width: 100%;
	    }

	    .aof-nav-indicator {
	      position: absolute;
	      left: 0;
	      bottom: 0;
      height: 2px;
      width: 0;
      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
      border-radius: 999px;
      transform: translateX(0);
      transition: transform .28s cubic-bezier(.2, .8, .2, 1), width .28s cubic-bezier(.2, .8, .2, 1);
      opacity: .95;
      pointer-events: none;
    }

    /* ✅ CTA desktop: più piccolo + NO underline */
    .aof-cta {
      justify-self: end;
      display: inline-flex;
      align-items: center;
      gap: 10px;
      white-space: nowrap;
      padding: 11px 18px;
      border-radius: 999px;
      font-weight: 900;
      font-size: 15.5px;
      letter-spacing: .01em;
      color: hsl(var(--ink));
      background: rgba(255, 255, 255, .60);
      backdrop-filter: blur(10px) saturate(120%);
      -webkit-backdrop-filter: blur(10px) saturate(120%);
      position: relative;
      border: 1px solid transparent;
      text-decoration: none !important;
      box-sizing: border-box;
    }
    .aof-cta:visited{ color: hsl(var(--ink)); }
    .aof-cta:hover{ text-decoration: none !important; }

    .aof-cta::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 999px;
      padding: 1px;
      background: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask-composite: exclude;
      pointer-events: none;
      opacity: .9;
    }

    .aof-logo-link { margin-left: 50px; }
    .aof-cta { margin-right: 50px; }

    /* PANNELLI (desktop) */
    .aof-panels {
      position: fixed;
      left: 0;
      right: 0;
      top: var(--panel-top, 98px);
      z-index: 1002;
      overflow: hidden;
      height: 0;
      will-change: height;
      transition: height .34s cubic-bezier(.16, .84, .36, 1);
      background: #fff;
      border-top: 0;
      box-shadow: 0 18px 36px rgba(2, 6, 23, .12);
      pointer-events: none;
    }

    .aof-panels.is-open {
      pointer-events: auto;
      border-top: 1px solid rgba(2, 6, 23, .06);
    }

    .aof-panel {
      position: absolute;
      inset: 0;
      opacity: 0;
      pointer-events: none;
      transition: opacity .20s ease;
    }

    .aof-panel.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    .aof-panel__inner {
      max-width: var(--maxw);
      margin: 0 auto;
      padding: 20px var(--pad-r) 20px var(--pad-l);
      display: grid;
      gap: 16px;
      opacity: 0;
      transform: translateY(-6px);
      transition: opacity .28s cubic-bezier(.22, .61, .36, 1), transform .28s cubic-bezier(.22, .61, .36, 1);
    }

    .aof-panel.is-open .aof-panel__inner {
      opacity: 1;
      transform: translateY(0);
    }

    /* FORM */
    .aof-form {
      display: grid;
      grid-template-columns: 1.1fr 1.1fr 1.2fr 1fr;
      grid-template-areas: "nome cognome azienda servizio" "note note note note" "submit submit submit submit";
      gap: 14px;
      align-items: start;
    }

    .aof-field { display: grid; gap: 6px; }

    .aof-label {
      font-size: .86rem;
      font-weight: 700;
      color: rgba(2, 6, 23, .55);
    }

    .aof-label--dark { color: #0b0b0c; }

    .aof-input,
    .aof-textarea {
      font: inherit;
      color: #1f2937;
      background: linear-gradient(180deg, #f8fbff 0%, #ffffff 65%);
      border: 1px solid rgba(37, 99, 235, .22);
      border-radius: 12px;
      padding: 12px;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
      box-sizing: border-box;
      width: 100%;
    }

    .aof-input:focus,
    .aof-textarea:focus {
      outline: none;
      box-shadow: 0 0 0 3px rgba(37, 99, 235, .18);
      border-color: rgba(37, 99, 235, .42);
      background: linear-gradient(180deg, #eef5ff 0%, #ffffff 70%);
    }

    .aof-input::placeholder,
    .aof-textarea::placeholder { color: #94a3b8; }

    .aof-textarea { min-height: 200px; resize: vertical; }

    /* Custom select */
    .aof-cselect { position: relative; user-select: none; }

    .aof-cselect__button {
      width: 100%;
      text-align: left;
      font: inherit;
      color: #1f2937;
      background: linear-gradient(180deg, #f8fbff 0%, #ffffff 65%);
      border: 1px solid rgba(37, 99, 235, .22);
      border-radius: 12px;
      padding: 12px 40px 12px 12px;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8);
      cursor: pointer;
      position: relative;
      box-sizing: border-box;
    }

    .aof-cselect__button:focus {
      outline: none;
      box-shadow: 0 0 0 3px rgba(37, 99, 235, .18);
      border-color: rgba(37, 99, 235, .42);
      background: linear-gradient(180deg, #eef5ff 0%, #ffffff 70%);
    }

    .aof-cselect__button::after {
      content: "";
      position: absolute;
      top: 50%;
      right: 12px;
      width: 14px;
      height: 14px;
      transform: translateY(-50%);
      background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none"><path d="M6 9l6 6 6-6" stroke="%232563eb" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
      background-size: 14px 14px;
      background-repeat: no-repeat;
      opacity: .8;
      pointer-events: none;
    }

    .aof-cselect__list {
      position: absolute;
      left: 0;
      right: 0;
      top: calc(100% + 8px);
      z-index: 10;
      background: #fff;
      border: 1px solid rgba(37, 99, 235, .28);
      border-radius: 14px;
      box-shadow: 0 12px 36px rgba(15, 23, 42, .18);
      padding: 6px;
      display: none;
      max-height: 280px;
      overflow: auto;
      overscroll-behavior: contain;
    }

    .aof-cselect.is-open .aof-cselect__list { display: block; }

    .aof-cselect__opt {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      border-radius: 10px;
      cursor: pointer;
      line-height: 1.15;
      color: #0b1220;
      outline: none;
    }

    .aof-cselect__opt:hover,
    .aof-cselect__opt[aria-selected="true"],
    .aof-cselect__opt:focus {
      background: linear-gradient(180deg, #f3f8ff 0%, #ffffff 80%);
    }

    .aof-cselect__opt .dot {
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      box-shadow: 0 0 0 2px rgba(37, 99, 235, .12);
      flex: 0 0 auto;
    }

    /* CTA SOTTO (unico bottone) */
    .aof-send {
      grid-area: submit;
      justify-self: center;
      width: min(760px, 80%);
      min-height: 56px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 16px 24px;
      border-radius: 16px;
      border: 0 !important;
      background: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan))) !important;
      color: #fff !important;
      font-weight: 900;
      font-size: 17px;
      text-decoration: none;
      cursor: pointer;
      box-shadow: 0 10px 22px rgba(2, 6, 23, .14);
      transition: transform .15s ease, box-shadow .2s ease;
      text-transform: uppercase;
    }

    .aof-send:hover { transform: translateY(-1px); }

    .aof-error {
      color: #b91c1c;
      font-size: .9rem;
      display: none;
    }
    .aof-error.is-visible { display: block; }

    /* MOBILE: logo più grande */
    @media(max-width:1024px) {
      .aof-header {
        background-color: #fff;
        border-bottom: 0;
        box-shadow: none;
      }

      .aof-header__inner { height: var(--h-mobile); }

      .aof-logo { height: 84px; } /* ✅ più grande SOLO mobile */

      .aof-nav,
      .aof-cta { display: none; }

      .aof-logo-link { margin-left: 16px; }

      .aof-header.is-scrolled {
        background-color: #fff;
        box-shadow: var(--shadow);
      }

      .aof-header.is-scrolled.aof-filter-armed::before {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        opacity: 0;
      }
    }

    /* Burger / Drawer */
    .aof-burger {
      position: fixed;
      top: 0; /* ✅ wrapper agganciato al top */
      right: calc(12px + env(safe-area-inset-right, 0px));
      height: var(--aof-h-mobile); /* ✅ stessa altezza header mobile */
      width: 64px; /* ✅ “binario” stabile */
      z-index: 1100;
      display: none;
      place-items: center; /* ✅ centra il bottone nel wrapper */
      background: transparent;
      pointer-events: none;
    }

    @media(max-width:1024px) { .aof-burger { display: grid; } }

    .aof-burger__btn {
      width: 48px;
      height: 48px;
      border: 0;
      cursor: pointer;
      position: relative;
      background: rgba(255, 255, 255, .92);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      border-radius: 12px;
      box-shadow: 0 10px 22px rgba(2, 6, 23, .10);
      pointer-events: auto;
      border: 1px solid rgba(2, 6, 23, .10);
    }

    .aof-burger__btn span {
      position: absolute;
      left: 12px;
      right: 12px;
      height: 2px;
      background: #0b1220 !important;
      transition: transform .25s ease, top .25s ease, opacity .2s ease;
    }

    .aof-burger__btn span:nth-child(1) { top: 15px; }
    .aof-burger__btn span:nth-child(2) { top: 24px; }
    .aof-burger__btn span:nth-child(3) { top: 33px; }

    .aof-burger__btn[aria-expanded="true"] span:nth-child(1) { top: 24px; transform: rotate(45deg); }
    .aof-burger__btn[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
    .aof-burger__btn[aria-expanded="true"] span:nth-child(3) { top: 24px; transform: rotate(-45deg); }

    .aof-backdrop {
      position: fixed;
      inset: var(--bd-top, 0) 0 0 0;
      z-index: 1001;
      background: rgba(12, 18, 28, .55);
      backdrop-filter: blur(16px) saturate(1.2);
      -webkit-backdrop-filter: blur(16px) saturate(1.2);
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      transition: opacity .34s ease, visibility .34s ease;
    }

    .aof-backdrop.is-open {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
    }

    @media (max-width:1024px) {
      html.aof-drawer-open .aof-backdrop {
        inset: 0 !important;
        z-index: 1002;
        background: linear-gradient(180deg, rgba(15, 23, 42, .62), rgba(15, 23, 42, .48));
        backdrop-filter: blur(12px) saturate(1.2);
        -webkit-backdrop-filter: blur(12px) saturate(1.2);
      }

      html.aof-drawer-open .aof-header { z-index: 1001; }

      html.aof-drawer-open .aof-header::before {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        opacity: 0 !important;
      }
    }

    .aof-drawer {
      --w: min(72vw, 420px);
      position: fixed;
      inset: 0 auto 0 0;
      width: var(--w);
      z-index: 1003;
      background: #f1f5f9;
      color: #0b1324;
      border-right: 1px solid rgba(2, 6, 23, .08);
      transform: translateX(-100%);
      transition: transform .28s ease;
      display: block;
      padding-bottom: env(safe-area-inset-bottom, 0px);
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
      box-sizing: border-box;
    }
    .aof-drawer.is-open { transform: translateX(0); }

    .aof-drawer__head {
      background: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      padding: 28px 16px 20px;
      display: grid;
      place-items: center;
      text-align: center;
      border-bottom: 1px solid rgba(255, 255, 255, .28);
    }

    .aof-drawer__head img {
      height: clamp(140px, 26vw, 240px);
      width: auto;
      display: block;
      margin: 0 auto;
      filter: drop-shadow(0 6px 20px rgba(2, 6, 23, .36)) drop-shadow(0 2px 8px rgba(2, 6, 23, .28));
    }

    .aof-drawer__nav {
      display: grid;
      gap: 2px;
      padding: 12px 10px 8px;
    }

    .aof-drawer__nav a {
      display: block;
      text-decoration: none !important;
      color: #0b1324;
      font-weight: 900;
      font-size: 18px;
      letter-spacing: .01em;
      line-height: 1.15;
      padding: 16px 18px;
      border-bottom: 1px solid rgba(2, 6, 23, .08);
      border-radius: 12px;
      box-sizing: border-box;
    }
	    .aof-drawer__nav a:hover { background: rgba(255,255,255,.70); }
	    .aof-drawer__nav a.aof-drawer__blog{
	      background: linear-gradient(135deg, rgba(14,165,233,.14), rgba(37,99,235,.12));
	      border: 1px solid rgba(37,99,235,.16);
	    }
	    .aof-drawer__nav a.aof-drawer__blog:hover{
	      background: linear-gradient(135deg, rgba(14,165,233,.18), rgba(37,99,235,.16));
	    }

    .aof-drawer__ctaWrap { padding: 12px 12px 18px; }

    .aof-drawer__cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      width: 100%;
      max-width: 100%;
      padding: 12px 16px;
      border-radius: 12px;
      text-decoration: none !important;
      font-weight: 900;
      letter-spacing: .01em;
      font-size: 15.5px;
      color: #0b1220;
      background: rgba(255, 255, 255, .92);
      position: relative;
      border: 1px solid transparent;
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      box-shadow: 0 10px 26px rgba(2, 6, 23, .10);
      box-sizing: border-box;
    }

    .aof-drawer__cta::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 12px;
      padding: 1px;
      background: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask-composite: exclude;
      pointer-events: none;
    }

    html.aof-lock,
    body.aof-lock {
      overflow: hidden;
      height: 100%;
      overscroll-behavior: none;
    }

    @media (min-width:1025px) {
      html.aof-panel-open .aof-backdrop { inset: var(--bd-top, 0px) 0 0 0 !important; }

      html.aof-panel-open .aof-header {
        background-color: rgba(255, 255, 255, .96) !important;
        border-bottom-color: var(--bd);
        box-shadow: var(--shadow);
      }

      html.aof-panel-open .aof-header::before {
        backdrop-filter: blur(16px) saturate(140%) brightness(1.00);
        -webkit-backdrop-filter: blur(16px) saturate(140%) brightness(1.00);
        opacity: 1;
      }
    }

    .aof-header.aof-noanim,
    .aof-header.aof-noanim * { transition: none !important; }


/* === Inline style 3 === */
    #aof-hero{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 218 31% 10%;
      --muted: 214 20% 36%;
      --gradient: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --gradient-fallback: linear-gradient(135deg, #2563eb, #0ea5e9);
      --header-h: 88px;
      --t: all .28s cubic-bezier(.2,.8,.2,1);

      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
      color: hsl(var(--ink));
      background:#fff;
      position:relative;
      isolation:isolate;
      overflow:hidden;

      display:flex;
      align-items:center;

      padding-top: calc(var(--header-h) + 56px);
      padding-bottom: 160px;

      /* centratura hardening */
      width:100%;
    }

    @supports (height:100svh){
      @media (min-width:768px){
        #aof-hero{ min-height: calc(92svh - var(--header-h) - 100px); }
      }
    }

    .container{
      max-width:1180px;
      margin:0 auto;
      padding:0 16px;
      width:100%;
      box-sizing:border-box;
    }

    /* ===== SHAPES (fluide, no scatti) ===== */
    .geo-layer{
      position:absolute;
      inset:0;
      z-index:0;
      pointer-events:none;
      overflow:hidden;
    }
    .geo-layer .batch{
      position:absolute;
      inset:0;
      opacity:1;
      contain: layout paint;
    }

    .shape{
      --shape-o:.34;
      position:absolute;
      bottom:0;
      width:44px;
      height:44px;
      opacity: var(--shape-o);
      will-change: transform, opacity;
      backface-visibility:hidden;
      transform: translate3d(0, var(--y0, 12vh), 0);
      pointer-events:none;
    }

    .shape__i{
      width:100%;
      height:100%;
      display:block;
      will-change: transform;
      backface-visibility:hidden;
      filter: drop-shadow(0 6px 16px rgba(59,130,246,.10)) drop-shadow(0 10px 22px rgba(14,165,233,.08));
      background: radial-gradient(110% 110% at 35% 25%,
        rgba(59,130,246,.44) 0%,
        rgba(14,165,233,.38) 48%,
        rgba(59,130,246,.32) 100%);
    }

    .shape--circle .shape__i{ border-radius:50%; }
    .shape--square .shape__i{ border-radius:14px; }
    .shape--triangle .shape__i{ clip-path: polygon(50% 0, 0 100%, 100% 100%); }

    @keyframes aof-floatUp{
      0%   { transform: translate3d(0, var(--y0, 12vh), 0); opacity: var(--shape-o); }
      98%  { opacity: var(--shape-o); }
      100% { transform: translate3d(0, -120vh, 0); opacity: 0; }
    }
    @keyframes aof-swayX{
      0%   { transform: translate3d(calc(var(--amp, 10px) * -1), 0, 0); }
      50%  { transform: translate3d(var(--amp, 10px), 0, 0); }
      100% { transform: translate3d(calc(var(--amp, 10px) * -1), 0, 0); }
    }

    @media (prefers-reduced-motion: reduce){
      .shape{ display:none !important; }
    }

    /* ✅ Performance: quando l'hero non è in viewport, metti in pausa le animazioni (senza ritardi di rendering) */
    #aof-hero:not(.is-inview) .geo-layer .shape,
    #aof-hero:not(.is-inview) .geo-layer .shape__i{
      animation-play-state: paused !important;
    }

    /* ===== Content ===== */
    .content{
      position:relative;
      z-index:2;
      text-align:center !important;
      width:100%;
      margin-inline:auto;
      box-sizing:border-box;
    }

    .badge{
      display:flex;
      align-items:center;
      justify-content:center;
      gap:8px;
      padding:10px 16px;
      border-radius:9999px;
      width:max-content;
      margin:0 auto 18px;
      background:rgba(255,255,255,.9);
      border:1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      color:#2563eb;
      font-weight:700;
      letter-spacing:.02em;
      font-size: clamp(14px, 3.8vw, 16px);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
    }

    .aof-hero-title{
      margin:0 0 16px;
      font-weight: 760 !important;
      line-height: 1.02;
      letter-spacing:-.012em;
      font-size: clamp(40px, 6.2vw, 82px);
      color: hsl(var(--ink));
      overflow: visible;
      -webkit-font-smoothing: antialiased;
      text-rendering: geometricPrecision;
    }

    .gradient-text{
      background: var(--gradient, var(--gradient-fallback));
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      -webkit-text-fill-color:transparent;
      font-weight: 740;
    }

    .title-desktop{ display:block; }
    .title-mobile{ display:none; }

    .lead{
      margin:0 auto 28px;
      color: hsl(var(--muted));
      font-size: clamp(18px, 2.6vw, 20px);
      max-width:860px;
      text-wrap:pretty;
    }
    .lead .lead-second{ display:inline; }

    .cta-row{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      align-items:center;
      justify-content:center;
      margin:0;
      width:100%;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      border-radius:16px;
      font-weight: 720;
      text-decoration:none !important;
      transition: var(--t);
      white-space:nowrap;
      -webkit-font-smoothing: antialiased;
      box-sizing:border-box;
      max-width: 100%;
    }

    .btn-lg{
      padding: 13px 20px;
      font-size: 15.8px;
    }

    .btn-primary{
      background: var(--gradient, var(--gradient-fallback)) !important;
      color:#fff !important;
      border:0;
      box-shadow: 0 10px 26px rgba(59,130,246,.20);
    }
    .btn-primary svg{ color:#fff; }
    .btn-primary:hover{
      transform: translateY(-1px) scale(1.01);
      filter: brightness(1.06);
    }

    .btn-secondary{
      background:#fff;
      color:#0b1220;
      border:1px solid rgba(2,6,23,.08);
      box-shadow: 0 6px 18px rgba(2,6,23,.06);
    }
    .btn-secondary:hover{
      transform: translateY(-1px);
      box-shadow: 0 10px 26px rgba(2,6,23,.08);
    }

    /* Desktop 80/80 */
    @media (min-width:768px){
      #aof-hero{
        padding-top: 80px !important;
        padding-bottom: 80px !important;
        box-sizing:border-box;
      }
    }

    /* ===== MODALE ===== */
    .aof-modal[hidden]{ display:none !important; }

    .aof-modal{
      position:fixed;
      inset:0;
      z-index:2147483646;
      background: rgba(2,6,23,.46);
      display:grid;
      place-items:center;
      opacity:0;
      transition: opacity .26s ease;
      -webkit-backdrop-filter: blur(10px) saturate(1.06);
      backdrop-filter: blur(10px) saturate(1.06);
    }
    .aof-modal.is-open{ opacity:1; }

    .aof-dialog{
      width: min(680px, 92vw);
      border-radius:18px;
      background:#fff;
      box-shadow: 0 30px 60px -24px rgba(2,6,23,.35);
      transform: translateY(8px);
      transition: transform .26s ease;
      max-height: 92svh;
      display:flex;
      flex-direction:column;
    }
    .aof-modal.is-open .aof-dialog{ transform: translateY(0); }

    .aof-dialog__head{
      padding:18px 20px;
      border-bottom:1px solid rgba(2,6,23,.06);
      display:flex;
      align-items:center;
      justify-content:space-between;
    }
    .aof-dialog__title{
      font-size:22px;
      margin:0;
      font-weight:800;
    }

    .hl-blue{
      background: var(--gradient, var(--gradient-fallback));
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      -webkit-text-fill-color:transparent;
    }

    .aof-dialog__close{
      border:0;
      background:transparent;
      font-size:20px;
      cursor:pointer;
      padding:6px 8px;
    }

    .aof-dialog__body{
      padding:16px 18px 18px;
      overflow:auto;
    }

    .aof-form{
      display:grid;
      grid-template-areas:
        "nome cognome"
        "azienda servizio"
        "note note"
        "send send";
      grid-template-columns: minmax(0,1fr) minmax(0,1fr);
      gap:12px;
    }

    .aof-field{ display:flex; flex-direction:column; gap:6px; }

    .aof-label{
      font-weight:700;
      font-size:14px;
      color:#0f172a;
    }

    .aof-input,
    .aof-textarea,
    .aof-cselect__button{
      border:1px solid rgba(2,6,23,.12);
      border-radius:12px;
      padding:10px 12px;
      font:inherit;
      font-size:15px;
      background:#fff;
      color:#0f172a;
      box-sizing:border-box;
      width:100%;
    }

    .aof-textarea{ min-height:120px; resize:vertical; }

    .aof-send{
      grid-area:send;
      margin-top:8px;
      border:0;
      border-radius:14px;
      padding:12px 18px;
      font-weight:800;
      background: var(--gradient, var(--gradient-fallback));
      color:#fff;
      cursor:pointer;
      box-shadow: 0 10px 26px rgba(59,130,246,.20);
    }

    .aof-error{
      display:none;
      margin-top:10px;
      color:#d10000;
      font-weight:700;
    }
    .aof-error.is-visible{ display:block; }

    #aof-modal-consulenza{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --gradient: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --gradient-fallback: linear-gradient(135deg, #2563eb, #0ea5e9);
    }

    .dot{ width:8px; height:8px; border-radius:50%; background:#2563eb; display:inline-block; flex:0 0 auto; }

    .aof-cselect{ position:relative; }
    .aof-cselect__button{ cursor:pointer; }

    .aof-cselect.is-open .aof-cselect__list{ opacity:1; transform: translateY(0); pointer-events:auto; }

    .aof-cselect__list{
      position:absolute;
      z-index:3;
      top: calc(100% + 6px);
      left:0; right:0;
      background:#fff;
      border:1px solid rgba(2,6,23,.12);
      border-radius:12px;
      padding:8px;
      opacity:0;
      transform: translateY(4px);
      transition: .18s ease;
      pointer-events:none;
    }

    .aof-cselect__opt{
      padding:10px 10px;
      border-radius:10px;
      cursor:pointer;
      display:flex;
      align-items:center;
      gap:8px;
      outline:none;
    }
    .aof-cselect__opt:hover{ background:#f4f7fb; }

    html.aof-lock, body.aof-lock{ overflow:hidden !important; }

    /* ==========================
       ✅ OVERRIDE MOBILE (ALLA FINE + BLINDATO)
       ========================== */
    @media (max-width:639.98px){
      #aof-hero{
        align-items:flex-start;
        min-height:auto !important;
        padding-top: calc(var(--header-h) - 24px) !important; /* meno spazio sopra */
        padding-bottom: clamp(130px, 15vh, 190px) !important; /* aria sotto */
      }

      .badge{ margin: 0 auto 6px !important; }
      .lead{ margin: 0 auto 14px !important; }

      .title-desktop{ display:none !important; }
      .title-mobile{ display:block !important; position:relative; }

      /* ✅ un pelo più piccolo rispetto a prima */
      .aof-hero-title.title-mobile{
        font-size: clamp(46px, 11.9vw, 68px) !important;
        line-height: 1.06 !important;
        letter-spacing: -.018em !important;
        font-weight: 640 !important;
        margin-bottom: 10px !important;
      }

      .title-mobile .nowrap{ white-space:nowrap; }

      .title-mobile .t-thick{
        position:absolute;
        inset:0;
        pointer-events:none;
        color:#0b1324;
        -webkit-text-stroke: .46px #0b1324;
        text-shadow: 0 0 .12px rgba(11,19,36,.58);
        paint-order: stroke fill;
        opacity:.86;
      }
      .title-mobile .t-thick .gradient-text{
        -webkit-text-stroke: 0 transparent;
        text-shadow:none;
      }

      .cta-row{
        gap:10px !important;
        margin-bottom: 36px !important;
      }

      .btn-lg{ padding: 12px 14px !important; font-size: 15px !important; }
    }

    @media (max-width:639.98px) and (max-height:700px){
      #aof-hero{
        padding-top: calc(var(--header-h) - 26px) !important;
        padding-bottom: clamp(120px, 14vh, 180px) !important;
      }
      .aof-hero-title.title-mobile{
        font-size: clamp(44px, 11.6vw, 66px) !important;
      }
    }


/* === Inline style 4 === */
    #manca-un-pezzo.aofm-piece{
      --aof-blue: 212 100% 50%;
      --aof-cyan: 195 100% 46%;
      --aof-ink: 222 47% 11%;
      --aof-muted: 216 19% 35%;
      --aof-grad: linear-gradient(135deg, hsl(var(--aof-blue)), hsl(var(--aof-cyan)));
      --maxw: 1180px;
      background:#fff;
      color:hsl(var(--aof-ink));
      position:relative;
      isolation:isolate;
      overflow:hidden;
      font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
      padding: clamp(86px, 9vw, 140px) 0 clamp(76px, 9vw, 130px);
    }

    #manca-un-pezzo .aofm-grid{
      position:absolute; inset:0;
      z-index:0; pointer-events:none;
      background:
        repeating-linear-gradient(0deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px),
        repeating-linear-gradient(90deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px);
      -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.74) 42%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
      mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.74) 42%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
    }

    #manca-un-pezzo .aofm-container{
      max-width:var(--maxw);
      margin:0 auto;
      padding:0 16px;
      position:relative;
      z-index:1;
      display:grid;
      grid-template-columns:1.05fr 1fr;
      gap:28px;
      align-items:start;
    }

    #manca-un-pezzo .aofm-left{ display:flex; flex-direction:column; gap:12px; }

    @media (min-width:1025px){
      #manca-un-pezzo .aofm-left{ transform: translateX(-70px); }
    }

    #manca-un-pezzo .aofm-eyebrow{
      display:inline-flex; align-items:center; gap:8px;
      padding:10px 16px;
      border-radius:9999px;
      font-weight:700;
      letter-spacing:.02em;
      font-size:clamp(15px,3.6vw,17px);
      color:#2563eb;
      background:rgba(255,255,255,.9);
      border:1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
      align-self:flex-start;
      width:fit-content;
      max-width:100%;
    }

    #manca-un-pezzo .aofm-title{
      margin:8px 0 6px;
      font-weight:800;
      line-height:1.02;
      letter-spacing:-.018em;
      font-size:clamp(38px,5.25vw,68px);
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    #manca-un-pezzo .aofm-grad{
      background:var(--aof-grad);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      -webkit-text-fill-color:transparent;
      padding-bottom:.04em;
      font-weight:800;
    }

    #manca-un-pezzo .aofm-line-1,
    #manca-un-pezzo .aofm-line-2{ white-space:nowrap; display:inline-block; }

    #manca-un-pezzo .aofm-sub{
      margin:0;
      max-width:880px;
      color:hsl(var(--aof-muted));
      font-size:clamp(18px,2.2vw,21px);
      line-height:1.58;
    }

    #manca-un-pezzo .aofm-sub-break{ display:block; height:14px; }

    #manca-un-pezzo .aofm-progress{
      width:min(520px,94%);
      height:6px;
      border-radius:999px;
      background:rgba(15,23,42,.10);
      margin-top:16px;
      overflow:hidden;
    }
    #manca-un-pezzo .aofm-progress-fill{
      height:100%;
      width:0%;
      background: linear-gradient(90deg, hsl(var(--aof-cyan)), hsl(var(--aof-blue)));
    }

    #manca-un-pezzo .aofm-right{ position:relative; min-height:520px; }

    #manca-un-pezzo .aofm-stack{
      position:absolute;
      top:0; left:50%;
      transform: translate(-50%, 136px);
      transform-origin:center top;
      perspective:900px;
      width:481.25px;
      height:328.125px;
      overflow:visible;
      touch-action: pan-y;
      cursor:grab;
    }
    #manca-un-pezzo .aofm-stack:active{ cursor:grabbing; }

    #manca-un-pezzo .aofm-card{
      position:absolute;
      top:50%; left:50%;
      width:481.25px;
      height:328.125px;
      background:#fff;
      color:hsl(var(--aof-ink));
      border:1px solid rgba(2,6,23,.10);
      border-radius:18px;
      box-shadow:0 10px 26px rgba(2,6,23,.08);
      transform-style:preserve-3d;
      backface-visibility:hidden;
      -webkit-backface-visibility:hidden;
      display:flex;
      flex-direction:column;
      gap:12px;
      padding:18px;
      overflow:hidden;
      visibility:hidden;
      opacity:0;
      transition: border-color .22s ease, box-shadow .22s ease;
      will-change: transform, opacity, filter;
    }

    #manca-un-pezzo .aofm-card-head{ display:flex; align-items:center; gap:10px; }
    #manca-un-pezzo .aofm-card-head h3{
      margin:0;
      font-weight:800;
      letter-spacing:-.012em;
      font-size:21px;
      line-height:1.12;
    }

    #manca-un-pezzo .aofm-ico{
      width:40px; height:40px;
      border-radius:12px;
      display:inline-grid;
      place-items:center;
      background: linear-gradient(135deg, rgba(59,130,246,.12), rgba(14,165,233,.08));
      border:1px solid rgba(59,130,246,.18);
      color:hsl(var(--aof-blue));
      flex:0 0 auto;
    }

    #manca-un-pezzo .aofm-list{
      margin:4px 0 0;
      padding-left:18px;
      color:hsl(var(--aof-muted));
      line-height:1.55;
      font-size:16px;
    }

    #manca-un-pezzo .aofm-ring{
      position:absolute;
      right:-28px; top:-28px;
      width:150px; height:150px;
      border-radius:9999px;
      pointer-events:none;
      --w:9px;
      background: conic-gradient(from 0deg,
        color-mix(in srgb, hsl(var(--aof-blue)) 65%, #fff 35%),
        color-mix(in srgb, hsl(var(--aof-cyan)) 55%, #fff 45%),
        color-mix(in srgb, hsl(var(--aof-blue)) 65%, #fff 35%));
      -webkit-mask: radial-gradient(closest-side, transparent calc(50% - var(--w)), #000 calc(50% - var(--w) + 1px));
      mask: radial-gradient(closest-side, transparent calc(50% - var(--w)), #000 calc(50% - var(--w) + 1px));
      opacity:.30;
      filter: drop-shadow(0 6px 18px rgba(59,130,246,.14));
      animation:aofm-ring-spin 44s linear infinite;
    }
    @keyframes aofm-ring-spin{ to{ transform: rotate(360deg) } }

    @media (max-width:1024px){
      #manca-un-pezzo .aofm-container{ grid-template-columns:1fr; gap:24px; }
      #manca-un-pezzo .aofm-right{ min-height:480px; }
      #manca-un-pezzo .aofm-stack{ transform: translate(-50%, 126px); }
      #manca-un-pezzo .aofm-progress{ width:min(560px,96%); }
      #manca-un-pezzo .aofm-left{ transform:none; }
    }

    @media (max-width:640px){
      #manca-un-pezzo.aofm-piece{
        padding: 20px 0 72px !important;
        margin-bottom: -20px !important;
        overflow-x:hidden;
      }
      #manca-un-pezzo .aofm-sub-break{ height:0 !important; display:block; }
      #manca-un-pezzo .aofm-title{ font-size: clamp(34px, 9.2vw, 46px); line-height:1.02; }

      #manca-un-pezzo{ --cards-downshift:20px; }

      #manca-un-pezzo .aofm-right{
        min-height: calc(328.125px * var(--stack-scale, .9) + 96px);
        margin-bottom:0 !important;
      }

      #manca-un-pezzo .aofm-progress{
        margin-top:-36px;
        margin-bottom:18px;
        position:relative;
        z-index:3;
      }

      #manca-un-pezzo .aofm-sub{ margin-bottom:28px; }

      #manca-un-pezzo .aofm-stack{
        transform: translate(calc(-50% - var(--stack-x-offset, 0px)), var(--stack-y, 116px)) scale(var(--stack-scale, .9));
      }

      /* ✅ TESTI CARD MOBILE: più grandi (FORZATI) */
      #manca-un-pezzo .aofm-card-head h3{ font-size:26px !important; }
      #manca-un-pezzo .aofm-list{ font-size:19px !important; line-height:1.64 !important; }
      #manca-un-pezzo .aofm-list li{ margin-bottom: 6px; }
    }


/* === Inline style 5 === */
    #verifica-3-pilastri.aofm-check.aofm-simple{
      --ink:#0b1220;
      --muted:#5b728a;
      --line:rgba(2,6,23,.12);
      --accent:#2563eb;
      --accent2:#0ea5e9;
      --grad: linear-gradient(135deg, hsl(212 100% 50%), hsl(195 100% 46%));
      --radius:18px;
      --shadow:0 18px 38px -16px rgba(2,6,23,.14);
      font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
      background:#fff;
      color:var(--ink);
      padding: clamp(64px, 7vw, 120px) 0;
      position:relative;
      isolation:isolate;
      overflow:hidden;
    }

    #verifica-3-pilastri .container{
      max-width:920px;
      margin:0 auto;
      padding:0 16px;
      text-align:center;
      position:relative;
      z-index:2;
    }

    /* ===== Forme decorative ===== */
    #verifica-3-pilastri .v3-geo{
      position:absolute; inset:0;
      pointer-events:none;
      z-index:1;
      overflow:hidden;
    }
    #verifica-3-pilastri .v3-geo .shape{
      position:absolute;
      bottom:-70px;
      width:40px; height:40px;
      opacity:.26;
      transform-origin:center;
      will-change:transform,opacity;
      animation:v3-floatUp var(--dur, 14s) linear infinite;
      animation-delay:var(--delay, 0s);
      filter: drop-shadow(0 4px 10px rgba(59,130,246,.12)) drop-shadow(0 10px 20px rgba(14,165,233,.10));
      background: radial-gradient(120% 120% at 30% 20%, rgba(59,130,246,.45) 0%, rgba(14,165,233,.35) 55%, rgba(59,130,246,.18) 100%);
    }
    #verifica-3-pilastri .v3-geo .shape--circle{ border-radius:50% }
    #verifica-3-pilastri .v3-geo .shape--square{ border-radius:12px }
    #verifica-3-pilastri .v3-geo .shape--triangle{ clip-path: polygon(50% 0, 0 100%, 100% 100%) }

    @keyframes v3-floatUp{
      0%{ transform:translateY(0) rotate(var(--rot,0deg)) scale(var(--scale,1)); opacity:0 }
      6%,94%{ opacity:.26 }
      100%{ transform:translateY(-120vh) rotate(calc(var(--rot,0deg) + 360deg)) scale(var(--scale,1)); opacity:0 }
    }
    @media (prefers-reduced-motion:reduce){
      #verifica-3-pilastri .v3-geo .shape{ animation:none; opacity:.16 }
    }

    /* ✅ Performance: pausa le forme quando la sezione non è in viewport */
    #verifica-3-pilastri:not(.is-inview) .v3-geo .shape{
      animation-play-state: paused;
    }

    /* ===== Tipografia (coerente con “Manca un pezzo”) ===== */
    #verifica-3-pilastri .aofm-grad{
      background:var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      -webkit-text-fill-color:transparent;
      padding-bottom:.04em;
      font-weight:800;
    }

    #verifica-3-pilastri .title{
      margin:0 0 10px;
      font-weight:800;
      letter-spacing:-.018em;
      line-height:1.02;
      font-size: clamp(38px, 5.25vw, 68px);
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    #verifica-3-pilastri .subtitle{
      margin:0 0 22px;
      color:var(--muted);
      line-height:1.58;
      font-size: clamp(18px, 2.2vw, 21px);
      max-width: 760px;
      margin-left:auto;
      margin-right:auto;
    }

    @media (max-width:640px){
      #verifica-3-pilastri.aofm-check.aofm-simple{ padding: 56px 0 !important; }
      #verifica-3-pilastri .title{ font-size: clamp(34px, 9.2vw, 46px); }
      #verifica-3-pilastri .subtitle{ margin-bottom: 18px; }
    }

    /* ===== Airbar ===== */
	    .aofm-airbar{
	      margin: 10px auto 0;
	      display:flex;
	      flex-wrap: wrap;
	      align-items:center;
	      gap:10px;
	      background:#fff;
	      border:1px solid var(--line);
	      border-radius:16px;
	      padding:8px;
	      box-shadow:var(--shadow);
	      max-width:720px;
	      width: 100%;
	      box-sizing: border-box;
	      position:relative;
	      z-index:2;
	    }

	    .aofm-input{
	      flex:1 1 auto;
	      border:1px solid rgba(37,99,235,.22);
	      background:#fff;
	      color:var(--ink);
	      border-radius:12px;
	      font-size:16px;
	      padding:12px 14px;
	      outline:none;
	      transition:border-color .2s, box-shadow .2s;
	      min-width: 0;
	      box-sizing: border-box;
	    }
    .aofm-input::placeholder{ color:#9aa7bd }
    .aofm-input:focus{
      border-color:var(--accent);
      box-shadow:0 0 0 4px rgba(37,99,235,.12);
    }

    /* ===== Bottone stile HERO (gradient + freccia bianca) ===== */
	    .aofm-btn{
	      flex:0 0 auto;
	      display:inline-flex;
	      align-items:center;
	      justify-content:center;
      gap:10px;
      padding: 12px 18px;
      border-radius: 14px;
      font-weight: 800;
      font-size: 16px;
      letter-spacing: .01em;
      cursor:pointer;
      background: var(--grad);
      color:#fff;
      border:0;
      box-shadow: 0 10px 26px rgba(59,130,246,.20);
	      transition: transform .18s, filter .18s, box-shadow .18s;
	      white-space: nowrap;
	      max-width: 100%;
	      box-sizing: border-box;
	    }
    .aofm-btn:hover{
      transform: translateY(-1px) scale(1.01);
      filter: brightness(1.06);
      box-shadow: 0 14px 32px rgba(59,130,246,.22);
    }
    .aofm-btn[disabled]{ opacity:.55; cursor:not-allowed; transform:none; filter:none; box-shadow:none }

    .aofm-btn svg{ display:block }
    .aofm-btn .aofm-icoarr{ opacity:.98; }

    @media (max-width:640px){
      .aofm-airbar{
        flex-direction:column;
        align-items:stretch;
        padding:10px;
        gap:10px;
      }
      .aofm-btn{
        width:100%;
        padding: 13px 18px;
        font-size: 16px;
        border-radius: 16px;
      }
      .aofm-input{ width:100% }
    }

    /* ===== Bracci (DESKTOP only) ===== */
    .carry-layer{
      position:absolute;
      inset:0;
      pointer-events:none;
      z-index:3;
      filter: drop-shadow(0 6px 14px rgba(37,99,235,.18));
    }
    .arm{
      position:absolute;
      top:0;
      height:2px;
      transform: translate3d(0,0,0);
      opacity:0;
      will-change: transform, width, top;
      background: linear-gradient(90deg,
        rgba(37,99,235,0),
        rgba(37,99,235,.85) 24%,
        rgba(14,165,233,.9) 62%,
        rgba(14,165,233,0)
      );
    }
    .arm::after{
      content:"";
      position:absolute;
      top:50%;
      width:18px; height:18px;
      border-radius:50%;
      transform: translateY(-50%);
      background: radial-gradient(60% 60% at 40% 35%, #fff 0%, #eaf2ff 42%, #cfe0ff 100%);
      border:2px solid rgba(37,99,235,.7);
      box-shadow: 0 0 0 6px rgba(37,99,235,.12), 0 12px 22px -10px rgba(2,6,23,.25);
    }
    .arm--left{ left:0 }
    .arm--left::after{ left: calc(100% - 9px) }
    .arm--right{ right:0; transform-origin:right center }
    .arm--right::after{ right: calc(100% - 9px) }

    .carry-wrap{ display:inline-block; will-change: transform, opacity; }
    .carry-wrap[data-state="pre"]{ opacity:0; transform: translate3d(var(--dx,0),0,0) scale(.995); }
    .carry-wrap[data-state="landed"]{ opacity:1; transform:none; }

    @media (prefers-reduced-motion:reduce){
      .arm{ display:none }
      .carry-wrap{ transform:none !important; opacity:1 !important }
    }

    /* ✅ MOBILE: togli bracci e disattiva totalmente layer */
    @media (max-width:640px){
      .carry-layer{ display:none !important; }
    }


/* === Inline style 6 === */
    @property --ang { syntax: '<angle>'; inherits: false; initial-value: 0deg; }

    #servizi.aof-services{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 222 47% 11%;
      --muted: 216 19% 35%;
      --grad: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --maxw: 1260px;

      background:#fff;
      color:hsl(var(--ink));
      position:relative;
      isolation:isolate;
      overflow:hidden;
      padding: clamp(82px, 8.5vw, 120px) 0;
      font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
      -webkit-text-size-adjust:100%;
      text-size-adjust:100%;
      text-rendering:optimizeLegibility;
    }

    #servizi .aof-container{
      max-width: var(--maxw);
      margin: 0 auto;
      padding: 0 16px;
      position:relative;
      z-index:1;
    }

    /* BG grid */
    #servizi .aof-grid{
      position:absolute; inset:0;
      z-index:0; pointer-events:none;
      background:
        repeating-linear-gradient(0deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px),
        repeating-linear-gradient(90deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px);
      -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.70) 40%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
      mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.70) 40%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
    }

    /* HEAD */
    #servizi .aof-head{
      display:flex;
      flex-direction:column;
      align-items:center;
      text-align:center;
      gap: 12px;
      margin-bottom: clamp(22px, 4.2vw, 44px);
    }

    #servizi .aof-eyebrow{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding: 10px 16px;
      border-radius: 9999px;
      color:#2563eb;
      font-weight:700;
      letter-spacing:.02em;
      font-size: clamp(15px, 3.6vw, 17px);
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
    }

    #servizi .aof-title{
      margin: 0;
      font-weight:800;
      line-height:1.02;
      letter-spacing:-.018em;
      font-size: clamp(38px, 5.25vw, 68px);
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    #servizi .aof-gradient-text{
      background: var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      -webkit-text-fill-color:transparent;
      padding-bottom:.04em;
      font-weight:800;
    }

    #servizi .aof-title .aof-title-mobile{ display:none; }
    #servizi .aof-title .aof-title-desktop{ display:inline; }

    #servizi .aof-sub{
      margin: 0 auto;
      max-width: 880px;
      color: hsl(var(--muted));
      font-size: clamp(18px, 2.2vw, 21px);
      line-height: 1.58;
    }

    /* GRID (desktop: centrali più larghi) */
    #servizi .aof-grid-cards{
      display:grid;
      grid-template-columns: 1fr;
      gap: 14px;
      align-items: stretch;
      position:relative;
    }

    @media (min-width:768px){
      #servizi .aof-grid-cards{
        grid-template-columns: .92fr 1.18fr 1.18fr .92fr;
        gap: clamp(14px, 1.3vw, 18px);
      }
    }

    /* CARD */
    #servizi .aof-card{
      --base-scale: 1;
      position:relative;
      overflow:hidden;
      border-radius: 20px;
      background:#fff;
      border: 1px solid rgba(2,6,23,.08);
      box-shadow: 0 10px 26px rgba(2,6,23,.06);
      display:flex;
      flex-direction:column;
      isolation:isolate;
      transform-origin:center center;

      opacity: 0;
      transform: translateY(14px) scale(var(--base-scale));
      transition:
        transform .62s cubic-bezier(.2,.8,.2,1),
        opacity .42s ease,
        box-shadow .28s cubic-bezier(.2,.8,.2,1),
        border-color .28s ease;
    }

    #servizi .aof-card.in{
      opacity: 1;
      transform: translateY(0) scale(var(--base-scale));
    }

    #servizi .aof-card:hover{
      transform: translateY(-4px) scale(var(--base-scale));
      box-shadow: 0 16px 38px rgba(2,6,23,.10);
      border-color: color-mix(in srgb, hsl(var(--blue)) 22%, rgba(2,6,23,.12) 78%);
    }

    #servizi .aof-card::after{
      content:"";
      position:absolute; inset:0;
      pointer-events:none;
      opacity:0;
      background: radial-gradient(220px 160px at var(--mx, 50%) var(--my, 50%),
        rgba(59,130,246,.10),
        rgba(14,165,233,.06) 40%,
        transparent 66%);
      transition: opacity .2s ease;
      z-index:0;
    }
    #servizi .aof-card:hover::after{ opacity:1; }

    /* FEATURED */
    #servizi .aof-card--featured{
      --base-scale: 1.03;
      --ring-w: 2px;
      --ang: 0deg;
      border-color: rgba(2,6,23,.10);
      z-index: 2;
    }
    #servizi .aof-card--featured::before{
      content:"";
      position:absolute;
      inset:0;
      padding: var(--ring-w);
      border-radius: inherit;
      background: conic-gradient(from var(--ang),
        rgba(0,0,0,0) 0turn .82turn,
        hsl(195 100% 49% / .88) .90turn,
        hsl(212 100% 50% / .92) 1turn);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      mask-composite: exclude;
      animation: aof-spin 8s linear infinite;
      pointer-events:none;
      z-index:2;
    }
    @keyframes aof-spin{ to{ --ang: 360deg; } }

    /* CONTENUTI */
    #servizi .aof-inner{
      position:relative;
      z-index:1;
      padding: 22px;
      display:flex;
      flex-direction:column;
      gap: 14px;
      flex:1;
    }

    #servizi .aof-icon{
      width:56px; height:56px;
      border-radius:14px;
      display:inline-grid;
      place-items:center;
      background: linear-gradient(135deg, rgba(59,130,246,.10), rgba(14,165,233,.05));
      border: 1px solid rgba(59,130,246,.18);
    }

    /* ✅ Titoli meno cicciotti (font-size uguale, peso più leggero) */
    #servizi .aof-card h3{
      margin:0;
      font-weight:800;          /* prima 900 */
      font-size: 24px;
      letter-spacing:-.01em;
      line-height:1.15;
    }

    #servizi .aof-mark{
      position:relative;
      display:inline-block;
      font-weight:800;          /* prima 900 */
      font-size: 1.14em;
      letter-spacing:-.01em;
    }
    #servizi .aof-mark::before{
      content:"";
      position:absolute;
      left:-6px; right:-6px;
      bottom:.06em;
      height:.62em;
      background: linear-gradient(90deg, hsl(var(--cyan)/.26), hsl(var(--blue)/.26));
      border-radius:10px;
      z-index:-1;
    }

    #servizi .aof-card p{
      margin:0;
      color: hsl(var(--muted));
      line-height:1.55;
      font-size: 16px;
    }

    #servizi .aof-chips{
      display:flex;
      flex-wrap:wrap;
      gap:8px;
      margin-top: 2px;
    }
    #servizi .aof-chip{
      padding: 5px 9px;
      font-weight:600;
      font-size: 12px;
      border-radius: 9999px;
      color:#0b1324;
      background: rgba(59,130,246,.08);
      border: 1px solid rgba(59,130,246,.16);
      white-space:nowrap;
    }

    #servizi .aof-actions{
      margin-top:auto;
      display:flex;
      align-items:center;
      justify-content:flex-start;
    }

    #servizi .aof-cta-quiet{
      display:inline-flex;
      align-items:center;
      gap:8px;
      text-decoration:none;
      font-weight:900;
      letter-spacing:.01em;
      color: hsl(var(--ink));
      padding: 6px 0;
      border-radius: 8px;
      transition: transform .18s ease;
      position:relative;
    }
    #servizi .aof-cta-quiet::after{
      content:"";
      position:absolute;
      left:0; right:0;
      bottom:-2px;
      height:2px;
      width:0;
      margin:0 auto;
      border-radius:9999px;
      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
      transition: width .18s ease;
    }
    #servizi .aof-cta-quiet:hover{ transform: translateY(-1px); }
    #servizi .aof-cta-quiet:hover::after{ width:80%; }
    #servizi .aof-cta-quiet svg{ transition: transform .18s ease; }
    #servizi .aof-cta-quiet:hover svg{ transform: translateX(3px); }

    #servizi .aof-card a:focus-visible,
    #servizi .aof-chip:focus-visible{
      outline: 3px solid color-mix(in srgb, hsl(var(--cyan)) 60%, hsl(var(--blue)) 40%);
      outline-offset: 3px;
      border-radius: 12px;
    }

    /* DESKTOP: animazione “fuoriuscita” esterne */
    @media (min-width:768px){
      #servizi .aof-card.is-stacked{
        transform: translate(var(--dx, 0px), var(--dy, 0px)) scale(var(--base-scale));
        opacity: 1;
        z-index: 1;
        pointer-events:none;
      }
      #servizi .aof-card.is-stacked.in{
        transform: translate(var(--dx, 0px), var(--dy, 0px)) scale(var(--base-scale));
      }
    }

    /* MOBILE: left-align + titolo 3 righe con font identico a “Manca un valore…” */
    @media (max-width:640px){
      #servizi.aof-services{ padding: 68px 0 74px !important; }

      #servizi .aof-head{
        align-items:flex-start;
        text-align:left;
        gap: 10px;
      }

      #servizi .aof-title{
        font-size: clamp(34px, 9.2vw, 46px) !important;
        line-height: 1.02 !important;
      }
      #servizi .aof-title .aof-title-desktop{ display:none !important; }
      #servizi .aof-title .aof-title-mobile{ display:inline !important; }

      #servizi .aof-sub{ margin:0; max-width:640px; }
      #servizi .aof-grid-cards{ gap: 12px; }

      #servizi .aof-card--featured{ --base-scale: 1; }
      #servizi .aof-card h3{ font-size: clamp(24px, 6vw, 28px); }
      #servizi .aof-card p{ font-size: 16px; }
    }

    @media (prefers-reduced-motion: reduce){
      #servizi .aof-card, #servizi .aof-cta-quiet{ transition:none !important; transform:none !important; }
      #servizi .aof-card{ opacity:1 !important; }
      #servizi .aof-card--featured::before{ animation-duration: 16s !important; }
    }


/* === Inline style 7 === */
    #lavori.oflw-works{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 222 47% 11%;
      --muted: 216 19% 35%;
      --grad: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --maxw: 1200px;

      position: relative;
      isolation: isolate;
      background: #fff !important;
      color: hsl(var(--ink));
      padding: 80px 0 80px;
      overflow: hidden;
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
      -webkit-font-smoothing: auto;
      -moz-osx-font-smoothing: auto;
      text-rendering: optimizeLegibility;
      -webkit-text-size-adjust: 100%;
      text-size-adjust: 100%;
    }

    #lavori .oflw-container{
      max-width: var(--maxw);
      margin: 0 auto;
      padding: 0 16px;
      position: relative;
      z-index: 3;
    }

    /* ===== Forme geometriche animate (BG) ===== */
    #lavori .oflw-geo{
      position:absolute; inset:0;
      pointer-events:none;
      z-index:1;
      overflow:hidden;
    }
    #lavori .oflw-geo .shape{
      position:absolute;
      bottom:-70px;
      width:40px; height:40px;
      opacity:.26;
      transform-origin:center;
      will-change:transform,opacity;
      animation: oflw-floatUp var(--dur, 14s) linear infinite;
      animation-delay: var(--delay, 0s);
      filter: drop-shadow(0 4px 10px rgba(59,130,246,.12)) drop-shadow(0 10px 20px rgba(14,165,233,.10));
      background: radial-gradient(120% 120% at 30% 20%,
        rgba(59,130,246,.45) 0%,
        rgba(14,165,233,.35) 55%,
        rgba(59,130,246,.18) 100%);
    }
    #lavori .oflw-geo .shape--circle{ border-radius:50% }
    #lavori .oflw-geo .shape--square{ border-radius:12px }
    #lavori .oflw-geo .shape--triangle{ clip-path: polygon(50% 0, 0 100%, 100% 100%) }

    @keyframes oflw-floatUp{
      0%{ transform:translateY(0) rotate(var(--rot,0deg)) scale(var(--scale,1)); opacity:0 }
      6%,94%{ opacity:.26 }
      100%{ transform:translateY(-120vh) rotate(calc(var(--rot,0deg) + 360deg)) scale(var(--scale,1)); opacity:0 }
    }
    @media (prefers-reduced-motion:reduce){
      #lavori .oflw-geo .shape{ animation:none; opacity:.16 }
    }

    /* ✅ Performance: pausa le forme quando la sezione non è in viewport */
    #lavori:not(.is-inview) .oflw-geo .shape{
      animation-play-state: paused;
    }

    /* ===== Head ===== */
    #lavori .oflw-head{
      display:flex;
      flex-direction:column;
      align-items:center;
      gap: clamp(8px, 1vw, 10px);
      text-align:center;
      margin-bottom: clamp(28px, 5vw, 48px);
    }

    #lavori .oflw-eyebrow{
      display:inline-flex;
      align-items:center;
      gap: 8px;
      margin: 0 auto;
      padding: 10px 16px;
      border-radius: 9999px;
      color: #2563eb;
      font-weight: 700;
      letter-spacing: .02em;
      font-size: clamp(15px, 3.6vw, 17px);
      background: rgba(255,255,255,.9);
      border: 1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
    }

    #lavori .oflw-title{
      margin: 16px 0 10px;
      font-weight: 800;
      letter-spacing: -0.018em;
      line-height: 1.02;
      font-size: clamp(38px, 5.25vw, 68px);
      position: relative;
      display: inline-block;
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    #lavori .g{
      background: var(--grad);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
      -webkit-text-fill-color: transparent;
      padding-bottom: .04em;
      font-weight: 800;
    }

    #lavori .capo-mini{
      display: inline-block;
      font-weight: 700;
      font-size: .62em;
      color: hsl(var(--ink));
      letter-spacing: 0;
      transform: translateY(-0.06em);
      margin-right: -0.02em;
      white-space: nowrap;
    }

    #lavori br.mobbr{ display:none; }
    @media (max-width:767.98px){ #lavori br.mobbr{ display:block; } }

    #lavori .oflw-sub{
      margin: 0 auto;
      max-width: 880px;
      color: hsl(var(--muted));
      font-size: clamp(18px, 2.2vw, 21px);
      line-height: 1.58;
    }

    /* mobile: sinistra->destra come le altre sezioni + titolo su 2 righe */
    #lavori .oflw-title-desktop{ display:inline; }
    #lavori .oflw-title-mobile{ display:none; }

    @media (max-width:640px){
      #lavori.oflw-works{ padding: 20px 0 72px !important; overflow-x:hidden; }
      #lavori .oflw-head{ align-items:flex-start; text-align:left; margin-bottom: 22px; }
      #lavori .oflw-eyebrow{ margin: 0; }
      #lavori .oflw-title{ font-size: clamp(34px, 9.2vw, 46px); }
      #lavori .oflw-sub{ margin: 0; }

      #lavori .oflw-title-desktop{ display:none; }
      #lavori .oflw-title-mobile{ display:inline; }
    }

    /* ===== Slider rail ===== */
    #lavori .oflw-slider{ position:relative; z-index:2; }

    #lavori .oflw-rail{
      display:flex;
      gap: 18px;
      overflow:auto;
      scroll-snap-type: x mandatory;
      scroll-behavior:smooth;
      padding: 2px 2px 10px;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    #lavori .oflw-rail::-webkit-scrollbar{ display:none; }

    #lavori .oflw-item{ flex: 0 0 100%; scroll-snap-align:start; display:grid; gap:10px; min-width:0; }

    @media (min-width:980px){
      #lavori .oflw-item{ flex-basis: calc((100% - 18px*2)/3); }
    }
    @media (min-width:680px) and (max-width:979.98px){
      #lavori .oflw-item{ flex-basis: calc((100% - 18px)/2); }
    }

    /* mobile: NO slideshow (uno sotto l'altro) */
    @media (max-width:679.98px){
      #lavori .oflw-rail{
        display:grid;
        grid-template-columns: 1fr;
        gap: 18px;
        overflow: visible;
        scroll-snap-type: none;
        padding: 0;
      }
      #lavori .oflw-item{ flex:none; }
      #lavori .oflw-nav{ display:none !important; }
    }

    /* ===== Card view ===== */
    #lavori .oflw-view{
      position: relative;
      border-radius: 20px;
      overflow: hidden;
      border: 1px solid rgba(2,6,23,.08);
      background: linear-gradient(180deg, rgba(2,6,23,.03), rgba(2,6,23,.01));
      box-shadow: 0 10px 26px rgba(2,6,23,.06);
      aspect-ratio: 16/9;
      cursor: pointer;
      backface-visibility: hidden;
    }

    #lavori .oflw-view:focus-visible{
      outline: 2px solid hsl(var(--cyan));
      outline-offset: 3px;
    }

    #lavori .oflw-frame{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      border:0;
      display:block;
      pointer-events:none;
      background: transparent;
    }

    /* cover (FQS / Vintresell) */
    #lavori .oflw-cover{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      object-fit:cover;
      z-index:3;
      pointer-events:none;
      transform: scale(1.01);
    }
    #lavori .oflw-coverShade{
      position:absolute;
      inset:0;
      z-index:4;
      pointer-events:none;
      background:
        radial-gradient(70% 70% at 50% 50%, rgba(59,130,246,.10), transparent 64%),
        linear-gradient(180deg, rgba(2,6,23,.06), rgba(2,6,23,.02));
      opacity:.92;
    }

    /* CTA card */
    #lavori .oflw-view--ring::before{
      content:"";
      position:absolute;
      inset:0;
      border-radius:inherit;
      padding: 2px;
      background: var(--grad);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      mask-composite: exclude;
      opacity: .9;
      pointer-events:none;
      z-index:3;
    }

    #lavori .oflw-cta{
      position:absolute;
      inset:0;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      text-align:center;
      padding: clamp(18px, 3vw, 28px);
      background: radial-gradient(circle at top, rgba(59,130,246,.24), transparent 55%), #0b0f19;
      color:#fff;
      z-index:2;
      cursor: default;
    }

    #lavori .oflw-cta-title{
      margin:0 0 8px;
      font-weight:900;
      letter-spacing:-.01em;
      line-height:1.12;
      font-size: clamp(20px, 3.4vw, 30px);
    }

    #lavori .oflw-cta-title .g{
      background: var(--grad);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
      -webkit-text-fill-color: transparent;
    }

    #lavori .oflw-cta-sub{
      margin:0;
      font-size: clamp(14px, 2.1vw, 18px);
      color: #cbd5f5;
      max-width: 28rem;
      line-height: 1.55;
    }

    /* Link sotto */
    #lavori .oflw-link{
      display:inline-flex;
      align-items:center;
      gap: 6px;
      width: max-content;
      color: #2563eb;
      font-weight: 800;
      text-decoration: none;
      line-height: 1.25;
    }
    #lavori .oflw-link:hover{ text-decoration: underline; }
    #lavori .oflw-link svg{ flex:0 0 auto; }

    /* ===== Nav (desktop only) ===== */
    #lavori .oflw-nav{
      display:none;
      justify-content: space-between;
      align-items:center;
      margin-top: 14px;
      gap: 10px;
    }
    @media (min-width: 980px){ #lavori .oflw-nav{ display:flex; } }

    #lavori .oflw-btn{
      flex:0 0 auto;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      width:44px;
      height:44px;
      border-radius:999px;
      border:1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.92);
      color:#0b1324;
      box-shadow: 0 10px 26px rgba(2,6,23,.08);
      cursor:pointer;
      transition: transform .18s ease, filter .18s ease, opacity .18s ease;
    }
    #lavori .oflw-btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
    #lavori .oflw-btn[disabled]{ opacity:.45; cursor:not-allowed; transform:none; filter:none; }

    #lavori .oflw-dots{
      flex: 1 1 auto;
      display:flex;
      justify-content:center;
      gap: 8px;
    }
    #lavori .oflw-dot{
      width: 8px; height: 8px;
      border-radius: 999px;
      border: 1px solid rgba(2,6,23,.18);
      background: rgba(2,6,23,.08);
      transition: width .18s ease, background .18s ease;
    }
    #lavori .oflw-dot.is-active{
      width: 18px;
      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
      border-color: rgba(59,130,246,.35);
    }

    /* ===== MODALE (fuori flow, niente testi che scappano) ===== */
	    .oflw-modal{
	      position: fixed;
	      inset: 0;
	      z-index: 2147483647;
	      display: none;
	      align-items: center;
	      justify-content: center;
	      background: rgba(3,6,23,.50);
	      -webkit-backdrop-filter: blur(6px);
	      backdrop-filter: blur(6px);
	      overflow: hidden;
	      overscroll-behavior: contain;
	      padding: 14px;
	      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
	      -webkit-text-size-adjust: 100%;
	      text-size-adjust: 100%;
	    }
    .oflw-modal.is-open{ display:flex; }

    .oflw-canvas{
      position: relative;
      width: min(94vw, 1600px);
      height: min(86vh, 900px);
      overflow: hidden;
      border-radius: 18px;
    }

    .oflw-modal__iframe{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      border:0;
      background: transparent;
      z-index: 1;
    }

    /* Preview iframes should never steal taps/scroll */
    .oflw-frame{ pointer-events:none; }

    .oflw-close{
      position:absolute;
      top: 10px;
      right: 10px;
      z-index: 5;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      width:44px;
      height:44px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.24);
      background:#fff;
      color:#0b0f19;
      font-weight:900;
      box-shadow: 0 12px 36px rgba(0,0,0,.30);
      cursor:pointer;
    }

    .oflw-close:focus-visible{
      outline: 2px solid hsl(var(--cyan));
      outline-offset: 3px;
    }

    .oflw-hint{
      position:absolute;
      left:50%;
      bottom: 10px;
      transform: translateX(-50%);
      z-index: 4;
      display:flex;
      gap: 8px;
      padding: 10px 12px;
      border-radius: 9999px;
      background: rgba(0,0,0,.55);
      border: 1px solid rgba(255,255,255,.18);
      color:#fff;
      font-weight: 800;
      font-size: 12px;
      opacity: 0;
      pointer-events: none;
      transition: opacity .28s ease;
      -webkit-backdrop-filter: blur(6px);
      backdrop-filter: blur(6px);
      max-width: 92vw;
      text-align: center;
    }
    .oflw-hint.show{ opacity:1; pointer-events:auto; }
    @media (min-width:861px){ .oflw-hint{ display:none; } }

    /* Vintresell modal (immagine + testo) */
    .oflw-vimg{
      position:absolute;
      inset:0;
      z-index:2;
      background:#0b0f19;
      display:none;
      color:#fff;
    }
    .oflw-vimg.is-on{ display:block; }
    .oflw-vimg img{
      width:100%;
      height:100%;
      object-fit:contain;
      display:block;
      opacity:.96;
    }
	    .oflw-vnote{
	      position:absolute;
	      left:12px;
	      right:12px;
	      bottom:12px;
      z-index:3;
      background: rgba(0,0,0,.56);
      border: 1px solid rgba(255,255,255,.18);
      border-radius: 14px;
      padding: 12px 12px;
      font-weight: 700;
      font-size: 13px;
	      line-height: 1.35;
	      -webkit-backdrop-filter: blur(8px);
	      backdrop-filter: blur(8px);
	    }
	    .oflw-vnote p{ margin:0; }
	    .oflw-vnote a{
	      display:inline-flex;
	      align-items:center;
	      gap:8px;
      margin-top:10px;
      padding:10px 12px;
      border-radius: 12px;
      background:#fff;
      color:#0b0f19;
      text-decoration:none;
      font-weight: 900;
      width: fit-content;
    }


/* === Inline style 8 === */
    #perche-sceglierci.aofc-choose{
      --aofc-blue: 212 100% 50%;
      --aofc-cyan: 195 100% 46%;
      --aofc-ink: 222 47% 11%;
      --aofc-muted: 216 19% 35%;
      --aofc-grad: linear-gradient(135deg, hsl(var(--aofc-blue)), hsl(var(--aofc-cyan)));
      --aofc-maxw: 1180px;

      background:#fff;
      color:hsl(var(--aofc-ink));
      position:relative;
      isolation:isolate;
      overflow:hidden;
      padding:80px 0;
      font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji",sans-serif;
    }

    #perche-sceglierci .aofc-container{
      max-width: var(--aofc-maxw);
      margin:0 auto;
      padding:0 16px;
      position:relative;
      z-index:1;
    }

    #perche-sceglierci .aofc-grid{
      position:absolute; inset:0; z-index:0; pointer-events:none;
      background:
        repeating-linear-gradient(0deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px),
        repeating-linear-gradient(90deg, rgba(59,130,246,.10) 0 1px, transparent 1px 24px);
      -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.74) 42%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
      mask-image: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.74) 42%, rgba(0,0,0,.82) 60%, rgba(0,0,0,.22) 88%, rgba(0,0,0,0) 100%);
    }

    /* ===== HEAD ===== */
    #perche-sceglierci .aofc-head{
      text-align:center;
      margin-bottom: clamp(28px, 5vw, 54px);
    }

    #perche-sceglierci .aofc-eyebrow{
      display:flex;
      width:max-content;
      margin:0 auto;
      align-items:center;
      gap:8px;
      padding:10px 16px;
      border-radius:9999px;
      color:#2563eb;
      font-weight:700;
      letter-spacing:.02em;
      font-size:clamp(15px,3.6vw,17px);
      background:rgba(255,255,255,.9);
      border:1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow:0 8px 22px rgba(2,6,23,.06);
    }

    #perche-sceglierci .aofc-title{
      position:relative;
      display:inline-block;
      margin:16px 0 12px;
      font-weight:800;
      line-height:1.08;
      letter-spacing:-.018em;
      font-size:clamp(38px,5.25vw,68px);
      overflow:visible;
      padding-bottom:.10em;
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    /* ✅ “Perché” sempre nero */
    #perche-sceglierci .aofc-plain{
      color: hsl(var(--aofc-ink));
      font-weight: inherit;
    }

    .aofc-word{
      position:relative;
      display:inline-block;
      padding-bottom:.08em;
    }

    .aofc-word .aofc-word-plain{
      position:relative;
      z-index:1;
      color:hsl(var(--aofc-ink));
      transition: opacity .6s ease;
    }

    .aofc-word .aofc-word-grad{
      position:absolute;
      inset:0;
      z-index:2;
      background: var(--aofc-grad);
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
      opacity:0;
      transition: opacity .6s ease;
      text-shadow: 0 6px 18px rgba(59,130,246,.10);
    }

    .aofc-word.on .aofc-word-plain{ opacity:0; }
    .aofc-word.on .aofc-word-grad{ opacity:1; }

    #perche-sceglierci .aofc-sub{
      margin:0 auto;
      max-width:880px;
      color:hsl(var(--aofc-muted));
      font-size:clamp(18px,2.2vw,21px);
      font-weight:400;
      line-height:1.58;
    }

    /* ===== GRID CARDS ===== */
    #perche-sceglierci .aofc-grid-cards{
      display:grid;
      grid-template-columns:1fr;
      gap:18px;
      align-items:stretch;
    }
    @media (min-width:768px){
      #perche-sceglierci .aofc-grid-cards{ grid-template-columns:repeat(2,1fr); gap:22px; }
    }
    @media (min-width:1100px){
      #perche-sceglierci .aofc-grid-cards{ grid-template-columns:repeat(4,1fr); }
    }

    #perche-sceglierci .aofc-card{
      position:relative;
      overflow:hidden;
      border-radius:20px;
      background:#fff;
      border:1px solid rgba(2,6,23,.08);
      box-shadow:0 10px 26px rgba(2,6,23,.06);
      transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .28s cubic-bezier(.2,.8,.2,1), border-color .28s ease;
      transform: translateY(0);
      opacity:1;
      isolation:isolate;
      user-select:none;
      cursor: default;
    }

    @media (hover:hover){
      #perche-sceglierci .aofc-card:hover{
        transform: translateY(-4px);
        box-shadow:0 16px 38px rgba(2,6,23,.10);
        border-color: color-mix(in srgb, hsl(var(--aofc-blue)) 22%, rgba(2,6,23,.12) 78%);
      }
    }

    #perche-sceglierci .aofc-card::before{
      content:"";
      position:absolute;
      inset:0;
      border-radius:20px;
      padding:1.5px;
      pointer-events:none;
      opacity:0;
      background: conic-gradient(from 45deg,
        hsl(var(--aofc-blue)) 0deg,
        hsl(var(--aofc-cyan)) 120deg,
        hsl(var(--aofc-blue)) 240deg,
        hsl(var(--aofc-cyan)) 360deg);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask-composite: exclude;
      transition: opacity .2s linear;
    }

    @keyframes aofc-ignite{ 0%{opacity:0} 45%{opacity:.95} 100%{opacity:.52} }
    #perche-sceglierci .aofc-card.aofc-ignite::before{ animation: aofc-ignite 900ms ease-out forwards; }
    #perche-sceglierci .aofc-card.aofc-ignite{
      border-color: color-mix(in srgb, hsl(var(--aofc-blue)) 38%, rgba(2,6,23,.12) 62%);
    }

    #perche-sceglierci .aofc-card.aofc-lit::before{ opacity:.52; }
    #perche-sceglierci .aofc-card.aofc-lit{
      border-color: color-mix(in srgb, hsl(var(--aofc-blue)) 34%, rgba(2,6,23,.12) 66%);
    }

    @keyframes aofc-flash{ 0%{opacity:.52} 40%{opacity:1} 100%{opacity:.55} }
    #perche-sceglierci .aofc-card.aofc-flash::before{ animation: aofc-flash 320ms ease-out forwards; }

    #perche-sceglierci .aofc-icon{
      width:56px; height:56px;
      border-radius:14px;
      display:inline-grid;
      place-items:center;
      background: linear-gradient(135deg, rgba(59,130,246,.10), rgba(14,165,233,.05));
      border:1px solid rgba(59,130,246,.18);
    }

    #perche-sceglierci .aofc-face{
      position:relative;
      z-index:1;
      padding:22px;
      min-height:230px;
      display:flex;
      flex-direction:column;
      gap:14px;
    }

    #perche-sceglierci .aofc-face h3{
      margin:0;
      font-weight:800;
      font-size:24px;
      letter-spacing:-.01em;
      line-height:1.15;
    }

    #perche-sceglierci .aofc-mark{
      position:relative;
      display:inline-block;
      font-weight:800;
      font-size:1.14em;
      letter-spacing:-.01em;
    }

    #perche-sceglierci .aofc-mark::before{
      content:"";
      position:absolute;
      left:-6px; right:-6px;
      bottom:.06em;
      height:.62em;
      background: linear-gradient(90deg, hsl(var(--aofc-cyan)/.24), hsl(var(--aofc-blue)/.24));
      border-radius:10px;
      z-index:-1;
    }

    #perche-sceglierci .aofc-face p{
      margin:0;
      color:hsl(var(--aofc-muted));
      line-height:1.55;
      font-size:16px;
    }

    /* CTA Contattaci (desktop visibile su tutte) */
    #perche-sceglierci .aofc-actions{
      margin-top:auto;
      display:flex;
      align-items:center;
      justify-content:flex-start;
      padding-top:4px;
    }

    #perche-sceglierci .aofc-cta-quiet{
      display:inline-flex;
      align-items:center;
      gap:8px;
      text-decoration:none;
      font-weight:900;
      letter-spacing:.01em;
      color:hsl(var(--aofc-ink));
      padding:6px 0;
      border-radius:8px;
      position:relative;
    }

    #perche-sceglierci .aofc-cta-quiet::after{
      content:"";
      position:absolute;
      left:0; right:0;
      bottom:-2px;
      height:2px;
      width:0;
      margin:0 auto;
      border-radius:999px;
      background: linear-gradient(90deg, hsl(var(--aofc-cyan)), hsl(var(--aofc-blue)));
      transition: width .18s ease;
    }

    @media (hover:hover){
      #perche-sceglierci .aofc-cta-quiet:hover::after{ width:80%; }
      #perche-sceglierci .aofc-cta-quiet:hover{ transform: translateY(-1px); transition: transform .18s ease; }
    }

    /* ===== MOBILE: title 1 riga stabile + CTA SOLO ultima con delay+pop ===== */
    @media (max-width:640px){
      #perche-sceglierci.aofc-choose{ padding:20px 0 72px !important; overflow-x:hidden; }
      #perche-sceglierci .aofc-head{ text-align:left; margin-bottom:22px; }
      #perche-sceglierci .aofc-eyebrow{ margin:0; }

      #perche-sceglierci .aofc-title{
        display:block;
        width:100%;
        text-align:left;
        font-size: clamp(34px, 9.2vw, 46px);
        line-height:1.06;
        padding-bottom:.12em;
        white-space: nowrap;
      }

      /* su mobile: “sceglierci?” sempre gradiente, “Perché” resta nero */
      #perche-sceglierci .aofc-word{ display:inline; position:static; }
      #perche-sceglierci .aofc-word .aofc-word-plain{ display:none !important; }
      #perche-sceglierci .aofc-word .aofc-word-grad{
        position:static !important;
        inset:auto !important;
        display:inline !important;
        opacity:1 !important;
        text-shadow:none !important;
      }

      /* CTA: nascosta su tutte, appare SOLO ultima con delay + POP */
      #perche-sceglierci .aofc-actions{
        opacity:0;
        transform: translateY(14px) scale(.985);
        pointer-events:none;
        transition: opacity .24s ease, transform .24s ease;
      }

      @keyframes aofc-cta-pop{
        0%{ opacity:0; transform: translateY(14px) scale(.985); }
        62%{ opacity:1; transform: translateY(0) scale(1.06); }
        100%{ opacity:1; transform: translateY(0) scale(1); }
      }

      #perche-sceglierci .aofc-card.aofc-show-cta .aofc-actions{
        opacity:1;
        transform:none;
        pointer-events:auto;
        animation: aofc-cta-pop .60s ease-out both;
      }
    }

    @media (prefers-reduced-motion:reduce){
      #perche-sceglierci .aofc-card::before,
      #perche-sceglierci .aofc-card,
      .aofc-word-plain,
      .aofc-word-grad{
        animation:none !important;
        transition:none !important;
      }
      @media (max-width:640px){
        #perche-sceglierci .aofc-card.aofc-show-cta .aofc-actions{ animation:none !important; }
      }
    }


/* === Inline style 9 === */
    /* TOKENS */
    #come-lavoriamo{
      --acc1: hsl(212 100% 55%);
      --acc2: hsl(195 100% 52%);
      --ink: #0b1220;
      --muted: #475569;

      --line: color-mix(in srgb, var(--acc1) 35%, transparent);
      --card-bg: #fff;
      --card-fg: var(--ink);
      --card-bd: rgba(2, 6, 23, .10);
      --shadow: 0 6px 18px rgba(2, 6, 23, .05);
      --shadow-md: 0 10px 24px rgba(2, 6, 23, .10);
      --radius: 14px;

      --gap-safe: 32px;
    }

    /* SECTION BG */
    #come-lavoriamo.pf-timeline{
      position: relative;
      isolation: isolate;
      padding: clamp(72px, 8vw, 108px) 16px clamp(96px, 10vw, 140px);
      color: var(--card-fg);
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
      background:
        radial-gradient(60% 60% at 100% 0%, rgba(59, 130, 246, .10), rgba(59, 130, 246, 0) 60%),
        radial-gradient(60% 60% at 0% 100%, rgba(14, 165, 233, .10), rgba(14, 165, 233, 0) 60%),
        linear-gradient(180deg, #f7fbff 0%, #eef5ff 100%);
      overflow-x: clip;
    }

    /* MOBILE-ONLY: 60px sopra / 20px sotto */
    @media (max-width: 767.98px){
      #come-lavoriamo.pf-timeline{
        padding-top: 60px;
        padding-bottom: 20px;
      }
    }

    /* blobs */
    #come-lavoriamo .pf-bg-blobs{ position:absolute; inset:0; pointer-events:none; z-index:0; }
    #come-lavoriamo .pf-blob{ position:absolute; border-radius:9999px; filter: blur(52px); }
    #come-lavoriamo .pf-blob.bl{
      bottom:-240px; left:-240px; width:520px; height:520px;
      background: radial-gradient(closest-side, rgba(59, 130, 246, .20), rgba(59, 130, 246, .06) 62%, transparent 72%);
    }
    #come-lavoriamo .pf-blob.tr{
      top:-240px; right:-240px; width:540px; height:540px;
      background: radial-gradient(closest-side, rgba(14, 165, 233, .18), rgba(14, 165, 233, .06) 62%, transparent 72%);
    }

    /* forme leggere */
    #come-lavoriamo .pf-geo-shapes{
      position:absolute; inset:0; pointer-events:none; z-index:0;
      overflow:hidden; contain: paint;
    }
    #come-lavoriamo .pf-shape{
      position:absolute;
      bottom:-140px;
      opacity:.20;
      width: var(--size, 40px);
      height: var(--size, 40px);
      transform: translate3d(0,0,0) rotate(var(--rot,0deg)) scale(var(--scale,1));
      will-change: transform, opacity;
      backface-visibility:hidden;
      contain: layout paint;
      animation: pf-floatUp var(--dur, 16s) linear infinite both;
      animation-delay: var(--delay, 0s);
      filter: drop-shadow(0 6px 12px rgba(59, 130, 246, .08));
      background: radial-gradient(120% 120% at 30% 20%, rgba(59, 130, 246, .36) 0%, rgba(14, 165, 233, .26) 55%, rgba(59, 130, 246, .16) 100%);
    }
    #come-lavoriamo .pf-shape.circle{ border-radius:50%; }
    #come-lavoriamo .pf-shape.square{ border-radius:12px; }
    #come-lavoriamo .pf-shape.triangle{ clip-path: polygon(50% 0, 0 100%, 100% 100%); }
    #come-lavoriamo:not(.is-inview) .pf-shape{ animation-play-state: paused; }

    @keyframes pf-floatUp{
      0%{ transform: translate3d(0,0,0) rotate(var(--rot)) scale(var(--scale)); opacity:0 }
      6%,94%{ opacity:.20 }
      100%{ transform: translate3d(0,-160vh,0) rotate(calc(var(--rot) + var(--spin, 360deg))) scale(var(--scale)); opacity:0 }
    }
    @media (prefers-reduced-motion:reduce){
      #come-lavoriamo .pf-shape{ animation:none; opacity:.12 }
    }

    /* HEADER (stesso schema della sezione 3 pilastri / servizi) */
    #come-lavoriamo .pf-timeline__header{
      position: relative;
      z-index: 1;
      max-width: 960px;
      margin: 0 auto clamp(22px, 4.2vw, 44px);

      display: flex;               /* ✅ evita “in linea” */
      flex-direction: column;      /* ✅ eyebrow sopra, titolo sotto */
      align-items: center;
      text-align: center;
      gap: 12px;
    }

    #come-lavoriamo .pf-eyebrow{
      display: inline-flex;
      width: max-content;          /* ✅ una riga, sempre sopra */
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 9999px;
      color: #2563eb;
      font-weight: 700;
      letter-spacing: .02em;
      font-size: clamp(15px, 3.6vw, 17px);
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
      margin: 0 auto;              /* ✅ centrato desktop */
    }

    #come-lavoriamo .pf-title{
      margin: 0;
      font-weight: 800;
      letter-spacing: -.018em;
      line-height: 1.02;
      font-size: clamp(38px, 5.25vw, 68px);
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;

      opacity: 0;
      transform: translateY(8px);
      transition: opacity .34s ease, transform .34s cubic-bezier(.2, .8, .2, 1);
    }

    #come-lavoriamo .pf-sub{
      margin: 0;
      max-width: 880px;
      color: var(--muted);
      font-size: clamp(18px, 2.2vw, 21px);
      line-height: 1.58;
      font-weight: 400;

      opacity: 0;
      transform: translateY(8px);
      transition: opacity .34s ease .06s, transform .34s cubic-bezier(.2, .8, .2, 1) .06s;
    }

    #come-lavoriamo .pf-grad{
      background-image: linear-gradient(135deg, var(--acc1), var(--acc2));
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
      -webkit-text-fill-color: transparent;
      display: inline-block;
      padding-bottom: .04em;
      font-weight: 800;
    }

    #come-lavoriamo .pf-ink{
      color: var(--ink);
      -webkit-text-fill-color: var(--ink);
      font-weight: 800;
    }

    /* MOBILE: header sx->dx, stesso font-size della sezione 3 pilastri */
    @media (max-width:640px){
      #come-lavoriamo .pf-timeline__header{
        align-items: flex-start;
        text-align: left;
        gap: 10px;
        margin-bottom: 22px;
        max-width: 740px;
      }
      #come-lavoriamo .pf-eyebrow{ margin: 0; }
      #come-lavoriamo .pf-title{
        font-size: clamp(34px, 9.2vw, 46px);
      }
      #come-lavoriamo .pf-sub{
        max-width: 640px;
      }
    }

    #come-lavoriamo .pf-title.is-in,
    #come-lavoriamo .pf-sub.is-in{
      opacity: 1;
      transform: none;
    }

    /* WRAP / SVG */
    #come-lavoriamo .pf-timeline__wrap{
      max-width: 1120px;
      margin: 0 auto;
      position: relative;
      padding-inline: clamp(12px, 4vw, 16px);
    }
    @media (min-width:1024px){
      #come-lavoriamo .pf-timeline__wrap{ padding-inline: 0 }
    }

    #come-lavoriamo .pf-timeline__svg{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      pointer-events:none;
      z-index:1;
    }

    #come-lavoriamo .pf-tl-path-base{
      fill:none;
      stroke: var(--line);
      stroke-width: 2;
      stroke-linecap: round;
      shape-rendering: geometricPrecision;
    }

	    #come-lavoriamo .pf-tl-path-active{
	      fill:none;
	      stroke: url(#pf-tl-grad);
	      stroke-width: 2;
	      stroke-linecap: round;
	      shape-rendering: geometricPrecision;
	    }
	    #come-lavoriamo .pf-tl-comet{ display:none; }

	    #come-lavoriamo .pf-tl-comet .pf-tl-comet-core{ fill: var(--acc1); }

	    /* Sticky head (all viewports): avoids scroll-driven JS updates.
	       Note: `pf-timeline__wrap` has padding on mobile; SVG is absolute (padding-box),
	       so we anchor the sticky element inside an absolute overlay to match coordinates. */
	    #come-lavoriamo .pf-tl-head{
	      position:absolute;
	      inset:0;
	      z-index:2;
	      pointer-events:none;
	    }
	    #come-lavoriamo .pf-tl-head__stick{
	      display:block;
	      position: sticky;
	      top: 50vh;
	      height: 1px;
	    }
	    #come-lavoriamo .pf-tl-head__stick::before{
	      content:"";
	      position:absolute;
	      left: var(--pf-centerx, 22px);
	      top: 0;
	      width: 4px;
	      height: 44px;
	      border-radius: 999px;
	      transform: translate(-50%, -50%);
	      background: linear-gradient(180deg, rgba(14,165,233,0), rgba(14,165,233,.95) 42%, rgba(37,99,235,.90) 100%);
	    }
	    @media (max-width: 767.98px){
	      #come-lavoriamo .pf-tl-head__stick::before{ width: 3px; height: 36px; }
	    }

    /* DOTS */
    #come-lavoriamo .pf-tl-dots{
      position:absolute;
      inset:0;
      pointer-events:none;
      z-index:2;
    }

    #come-lavoriamo .pf-tl-dot{
      position:absolute;
      transform: translate(-50%, -50%);
      width: 22px;
      height: 22px;
      border-radius: 9999px;
      border: 4px solid var(--line);
      background: var(--card-bg);
      transition: box-shadow .18s ease, border-color .18s ease, transform .18s ease;
      pointer-events: auto;
      cursor: pointer;
    }

    #come-lavoriamo .pf-tl-dot:hover{
      transform: translate(-50%, -50%) scale(1.06);
      border-color: var(--acc2);
      box-shadow: 0 0 0 6px color-mix(in srgb, var(--acc2) 18%, transparent);
    }

    #come-lavoriamo .pf-tl-dot.is-active{ border-color: var(--acc2) }
    #come-lavoriamo .pf-tl-dot.is-visited{ box-shadow: 0 0 0 8px color-mix(in srgb, var(--acc2) 16%, transparent) }

    @media (max-width: 767.98px){
      #come-lavoriamo .pf-tl-dot{
        width: 20px;
        height: 20px;
        border-width: 3px;
      }
    }

    /* ITEMS */
    #come-lavoriamo .pf-timeline__items{
      position: relative;
      z-index: 3;
    }

    /* ✅ MOBILE: linea/pallini a sinistra + cards da sx->dx */
    @media (max-width: 767.98px){
      #come-lavoriamo .pf-timeline__items{
        padding-left: 32px;
      }
    }

    #come-lavoriamo .pf-tl-item{
      position: relative;
      display: block;
      margin-bottom: 44px;
      padding-top: 12px;
    }

    /* CARD */
    #come-lavoriamo .pf-tl-card{
      --raise: 0px;
      --nudge: 0px;
      --conn-w: 12px;
      --tilt: 0deg;
      --shift: 0px;

      width: min(100%, 560px);
      background: var(--card-bg);
      color: var(--card-fg);
      border: 1px solid var(--card-bd);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      transform: translateX(calc(var(--nudge)+var(--shift))) translateY(var(--raise)) rotate(var(--tilt));
      transition: transform .24s ease, box-shadow .24s ease, margin .22s ease, opacity .28s ease, border-color .18s ease;
      position: relative;
      opacity: 1;
      will-change: transform, opacity;
      background-image: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, 0));
    }

    #come-lavoriamo .pf-tl-card:hover{
      --raise: -2px;
      box-shadow: var(--shadow-md);
    }

    #come-lavoriamo .pf-tl-card.is-glow{
      border-color: color-mix(in srgb, var(--acc1) 50%, transparent);
      box-shadow: 0 0 0 2px color-mix(in srgb, var(--acc1) 45%, transparent) inset, 0 10px 26px rgba(2, 6, 23, .12);
    }

    #come-lavoriamo .pf-tl-card::after{ display:none !important; }

    /* Connector orizzontale (desktop) */
    #come-lavoriamo .pf-tl-card::before{
      content:"";
      position:absolute;
      top:50%;
      transform: translateY(-50%);
      height:2px;
      width: var(--conn-w);
      background: linear-gradient(90deg, color-mix(in srgb, var(--acc1) 60%, transparent), color-mix(in srgb, var(--acc2) 60%, transparent));
    }
    #come-lavoriamo .pf-tl-card.left::before{ right:-2px; transform-origin: right center; }
    #come-lavoriamo .pf-tl-card.right::before{ left:-2px; transform-origin: left center; }

    #come-lavoriamo .pf-tl-card__inner{ padding: 26px 22px 24px; position: relative; }

    #come-lavoriamo .pf-step{
      position:absolute;
      top:10px;
      right:10px;
      width:28px;
      height:28px;
      border-radius:999px;
      display:flex;
      align-items:center;
      justify-content:center;
      background: linear-gradient(135deg, var(--acc1), var(--acc2));
      color:#fff;
      font-weight: 900;
      font-size: 12px;
      letter-spacing: .02em;
      box-shadow: 0 6px 16px rgba(0, 0, 0, .14);
    }

    /* testo card */
    #come-lavoriamo .pf-tl-title{
      margin: 0 0 6px;
      font-weight: 800;
      font-size: 1.18rem;
      letter-spacing: -.004em;
      color: var(--ink);
    }

    #come-lavoriamo .pf-tl-sub{
      margin: 0 0 8px;
      color: var(--muted);
      font-weight: 600;
      font-size: 1.00rem;
    }

    #come-lavoriamo .pf-tl-desc{
      margin: 0;
      color: var(--muted);
      line-height: 1.62;
      font-weight: 400;
      font-size: 0.98rem;
    }

    /* DESKTOP: gap fisso dalla linea centrale */
    @media (min-width:1024px){
      #come-lavoriamo .pf-tl-card{
        width: clamp(420px, calc(50% - var(--gap-safe)), 560px);
      }
      #come-lavoriamo .pf-tl-card.left{ --nudge: 0px; }
      #come-lavoriamo .pf-tl-card.right{ --nudge: 0px; }
    }

    /* TABLET/MOBILE: card full width, connector off */
    @media (max-width:1023px){
      #come-lavoriamo .pf-tl-card{ margin-left: 0 !important; --nudge: 0px; }
      #come-lavoriamo .pf-tl-card::before{ width: 0 !important }
    }

    /* tilt micro su mobile */
    @media (max-width:640px){
      #come-lavoriamo .pf-tl-card.tilt-l{ --tilt: -1.6deg; --shift: -6px }
      #come-lavoriamo .pf-tl-card.tilt-r{ --tilt:  1.6deg; --shift:  6px }
      #come-lavoriamo .pf-tl-card.tilt-l-2{ --tilt: -2.2deg; --shift: -10px }
      #come-lavoriamo .pf-tl-card.tilt-r-2{ --tilt:  2.2deg; --shift:  10px }
    }


/* === Inline style 10 === */
    /* ===== TOKENS / BASE ===== */
    #aof-ba-slideshow{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 222 47% 11%;
      --muted: 216 19% 35%;
      --grad: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --maxw: 1200px;
      --radius: 16px;
      --gap: 14px;

      background: #fff;
      color: hsl(var(--ink));
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 64px 0 72px;
      position: relative;
      isolation: isolate;
      overflow: hidden;

      contain: layout style paint;
      content-visibility: auto;
      contain-intrinsic-size: 900px;

      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      text-rendering: optimizeLegibility;
      -webkit-text-size-adjust: 100%;
      text-size-adjust: 100%;
    }

    @media (min-width:768px){
      #aof-ba-slideshow{ padding-bottom: 112px; }
    }

    #aof-ba-slideshow .aof-ba__wrap{
      max-width: var(--maxw);
      margin: 0 auto;
      padding: 0 16px;
      position: relative;
      z-index: 2;
    }

    /* ===== HEADER (match pattern “Come lavoriamo”) ===== */
    #aof-ba-slideshow .aof-ba__head{
      position: relative;
      z-index: 2;
      max-width: 960px;
      margin: 0 auto clamp(22px, 4.2vw, 44px);

      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 12px;
    }

    #aof-ba-slideshow .aof-ba__eyebrow{
      display: inline-flex;
      width: max-content;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 9999px;
      color: #2563eb;
      font-weight: 700;
      letter-spacing: .02em;
      font-size: clamp(15px, 3.6vw, 17px);
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(59,130,246,.28);
      -webkit-backdrop-filter: blur(10px) saturate(1.05);
      backdrop-filter: blur(10px) saturate(1.05);
      box-shadow: 0 8px 22px rgba(2,6,23,.06);
      margin: 0 auto;
    }

    #aof-ba-slideshow .aof-ba__title{
      margin: 0;
      font-weight: 800;
      letter-spacing: -.018em;
      line-height: 1.02;
      font-size: clamp(38px, 5.25vw, 68px);
      text-rendering: geometricPrecision;
      -webkit-font-smoothing: antialiased;
    }

    #aof-ba-slideshow .aof-ba__title .g{
      background: var(--grad);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
      -webkit-text-fill-color: transparent;
      display: inline-block;
      padding-bottom: .04em;
      font-weight: 800;
    }

    #aof-ba-slideshow .aof-ba__sub{
      margin: 0;
      max-width: 880px;
      color: hsl(var(--muted));
      font-size: clamp(18px, 2.2vw, 21px);
      line-height: 1.58;
      font-weight: 400;
    }

    /* ✅ MOBILE: left aligned + title size MATCH “Come lavoriamo” */
    @media (max-width:640px){
      #aof-ba-slideshow .aof-ba__head{
        align-items: flex-start;
        text-align: left;
        gap: 10px;
        margin-bottom: 22px;
        max-width: 740px;
      }
      #aof-ba-slideshow .aof-ba__eyebrow{ margin: 0; }
      #aof-ba-slideshow .aof-ba__title{
        font-size: clamp(34px, 9.2vw, 46px);
      }
      #aof-ba-slideshow .aof-ba__sub{
        max-width: 640px;
      }
    }

    /* ===== BG floating shapes ===== */
    #aof-ba-slideshow .aof-ba__geo{
      position: absolute;
      inset: 0;
      pointer-events: none;
      z-index: 1;
      overflow: hidden;
    }

    #aof-ba-slideshow .aof-ba__geo .shape{
      position: absolute;
      bottom: -70px;
      width: 40px;
      height: 40px;
      opacity: .26;
      transform-origin: center;
      will-change: transform, opacity;
      animation: ba-floatUp var(--dur, 14s) linear infinite;
      animation-delay: var(--delay, 0s);
      background: radial-gradient(120% 120% at 30% 20%, rgba(59,130,246,.45) 0%, rgba(14,165,233,.35) 55%, rgba(59,130,246,.18) 100%);
      filter: drop-shadow(0 4px 10px rgba(59,130,246,.12)) drop-shadow(0 10px 20px rgba(14,165,233,.10));
    }
    #aof-ba-slideshow .aof-ba__geo.lite .shape{ filter:none; }

    #aof-ba-slideshow .shape--circle{ border-radius:50%; }
    #aof-ba-slideshow .shape--square{ border-radius:12px; }
    #aof-ba-slideshow .shape--triangle{ clip-path: polygon(50% 0, 0 100%, 100% 100%); }

    @keyframes ba-floatUp{
      0%{ transform: translateY(0) rotate(var(--rot, 0deg)) scale(var(--scale, 1)); opacity:0; }
      6%,94%{ opacity:.26; }
      100%{ transform: translateY(-120vh) rotate(calc(var(--rot, 0deg) + 360deg)) scale(var(--scale, 1)); opacity:0; }
    }
    @media (prefers-reduced-motion:reduce){
      #aof-ba-slideshow .aof-ba__geo .shape{ animation:none; opacity:.16; }
    }

    /* ✅ Performance: pausa le forme quando la sezione non è in viewport */
    #aof-ba-slideshow:not(.is-inview) .aof-ba__geo .shape{
      animation-play-state: paused;
    }

    /* ===== Cards ===== */
    #aof-ba-slideshow .ba-card{
      position: relative;
      border: 1px solid rgba(2, 6, 23, .08);
      border-radius: var(--radius);
      box-shadow: 0 10px 26px rgba(2, 6, 23, .06);
      background: transparent;
      overflow: visible;
      isolation: isolate;
    }

    #aof-ba-slideshow .ba-card::after{
      content:"";
      position:absolute;
      inset:0;
      border-radius: var(--radius);
      padding: 2px;
      background: var(--grad);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor;
      mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      mask-composite: exclude;
      opacity: 0;
      transition: opacity .22s ease;
      pointer-events:none;
      z-index:1;
    }

    @media(hover:hover){
      #aof-ba-slideshow .ba-card:hover{
        border-color: transparent;
        box-shadow: 0 16px 38px rgba(2, 6, 23, .10);
      }
      #aof-ba-slideshow .ba-card:hover::after{ opacity:1; }
    }

    #aof-ba-slideshow .ba-media{
      position: relative;
      width: 100%;
      aspect-ratio: var(--ratio, 16/9);
      background: #0b0f19;
      border-radius: var(--radius);
      overflow: hidden;
      display:flex;
      align-items:center;
      justify-content:center;
    }

    #aof-ba-slideshow .ba-media video{
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      display:block;
      background: #0b0f19;
      transform: translateZ(0);
    }

    #aof-ba-slideshow .ba-badge{
      position:absolute;
      z-index:2;
      padding: 8px 10px;
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .02em;
      color:#fff;
      border-radius: 999px;
      background: rgba(15, 23, 42, .74);
      border: 1px solid rgba(255,255,255,.2);
      -webkit-backdrop-filter: blur(6px);
      backdrop-filter: blur(6px);
      bottom: 10px;
      left: 10px;
    }

    #aof-ba-slideshow .ba-badge--after{
      right: 10px;
      left: auto;
      background: linear-gradient(135deg, rgba(37,99,235,.95), rgba(14,165,233,.95));
      border: none;
    }

    /* ===== Layout slide content ===== */
    #aof-ba-slideshow .slide-grid{
      display:grid;
      grid-template-columns: repeat(2, minmax(0, 1fr)); /* desktop: PRIMA | DOPO */
      gap: var(--gap);
      margin-top: 20px;
    }

    /* ✅ MOBILE: PRIMA sopra + DOPO sotto */
    @media(max-width:767.98px){
      #aof-ba-slideshow .slide-grid{
        grid-template-columns: 1fr;
        gap: 14px;
        margin-top: 16px;
      }
    }

    /* ===== Slider ===== */
    #aof-ba-slideshow .slider{ position: relative; }

    #aof-ba-slideshow .slider__frame{
      position: relative;
      overflow: hidden;
      padding: 0;
    }

    #aof-ba-slideshow .slides{
      display:flex;
      transition: transform .45s cubic-bezier(.2, .8, .2, 1);
      will-change: transform;
    }

    #aof-ba-slideshow .slide{
      flex: 0 0 100%;
      min-width: 100%;
      opacity: 0;
      pointer-events:none;
    }
    #aof-ba-slideshow .slide[aria-hidden="false"]{
      opacity: 1;
      pointer-events:auto;
    }

    /* ===== NAV: frecce stile portfolio (circolari) + dots ===== */
    #aof-ba-slideshow .ba-nav{
      display:flex;
      justify-content:center;
      align-items:center;
      gap: 12px;
      margin-top: 12px; /* sotto al contenuto */
    }

    #aof-ba-slideshow .ba-btn{
      flex:0 0 auto;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      width:44px;
      height:44px;
      border-radius:999px;
      border:1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.92);
      color:#0b1324;
      box-shadow: 0 10px 26px rgba(2,6,23,.08);
      cursor:pointer;
      transition: transform .18s ease, filter .18s ease, opacity .18s ease;
    }
    #aof-ba-slideshow .ba-btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
    #aof-ba-slideshow .ba-btn[disabled]{ opacity:.45; cursor:not-allowed; transform:none; filter:none; }

    #aof-ba-slideshow .ba-dots{
      display:flex;
      align-items:center;
      justify-content:center;
      gap: 8px;
      padding: 0 6px;
    }

    #aof-ba-slideshow .dot{
      width: 8px;
      height: 8px;
      border-radius: 999px;
      border: 1px solid rgba(2,6,23,.18);
      background: rgba(2,6,23,.08);
      transition: width .18s ease, background .18s ease, border-color .18s ease;
      cursor: pointer;
    }

    #aof-ba-slideshow .dot[aria-current="true"]{
      width: 18px;
      background: linear-gradient(90deg, hsl(var(--cyan)), hsl(var(--blue)));
      border-color: rgba(59,130,246,.35);
    }

    /* ===== CTA inside media ===== */
    #aof-ba-slideshow .cta-wrap{
      position: relative;
      z-index: 1;
      padding: clamp(18px, 3vw, 28px);
      text-align: center;
      color:#fff;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      gap: 10px;
    }

    #aof-ba-slideshow .cta-title{
      font-weight: 900;
      letter-spacing: -.01em;
      line-height: 1.1;
      font-size: clamp(22px, 3.6vw, 34px);
      margin: 0;
      display:-webkit-box;
      -webkit-line-clamp: 3;
      -webkit-box-orient: vertical;
      overflow:hidden;
    }

    #aof-ba-slideshow .cta-title .g{
      background: var(--grad);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
      -webkit-text-fill-color: transparent;
    }

    #aof-ba-slideshow .cta-sub{
      color: #c9d3e6;
      font-size: clamp(14px, 2.2vw, 18px);
      margin: 0;
      line-height: 1.55;
    }

    #aof-ba-slideshow .cta-actions{
      margin-top: 8px;
      display:flex;
      justify-content:center;
    }

    #aof-ba-slideshow .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap: 8px;
      padding: 12px 18px;
      font-weight: 900;
      letter-spacing: .02em;
      border-radius: 12px;
      cursor:pointer;
      background: linear-gradient(180deg, #fff, #eef4ff);
      color: hsl(var(--ink));
      border: 1px solid rgba(37,99,235,.35);
      box-shadow: 0 10px 18px -10px rgba(37,99,235,.28);
      text-decoration:none;
    }


/* === Inline style 11 === */
    /* ========== TOKENS (isolati al solo footer) ========== */
    #aof-footer{
      --blue: 212 100% 50%;
      --cyan: 195 100% 46%;
      --ink: 218 31% 10%;
      --muted: 214 16% 78%;
      --ink-strong: 222 47% 11%;

      --navy: #1e3a8a;
      --navy-deep: #17275d;
      --bg-cta: linear-gradient(135deg, var(--navy), #2563eb);
      --bg-bottom: linear-gradient(180deg, #152447 0%, #1b2e59 100%);

      --grad: linear-gradient(135deg, hsl(var(--blue)), hsl(var(--cyan)));
      --maxw: 1180px;
      --radius: 16px;
      --cta-pad-y: clamp(34px, 6.5vw, 56px);
      --bottom-pad-y: clamp(32px, 6vw, 52px);

      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
      color:#fff;
      background: transparent;
      position: relative;
      isolation: isolate;
      border-top: 0 !important;
    }

    /* ========== CTA STRIP (PRE-FOOTER) ========== */
    #aof-footer .aofft-cta{
      position: relative;
      background: var(--bg-cta);
      padding: var(--cta-pad-y) 16px;
      -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.98), rgba(0,0,0,.98));
      mask-image: linear-gradient(to bottom, rgba(0,0,0,.98), rgba(0,0,0,.98));
      overflow:hidden;
    }

    #aof-footer .aofft-cta::before{
      content:"AOF";
      position:absolute;
      inset:auto 0 -10%;
      top:-6%;
      margin:0 auto;
      width:100%;
      text-align:center;
      font-weight:900;
      letter-spacing:.12em;
      font-size: clamp(160px, 20vw, 320px);
      line-height:1;
      color: rgba(255,255,255,.06);
      pointer-events:none;
      user-select:none;
      transform:none;
      will-change: transform;
    }
    @media (min-width:801px){
      #aof-footer .aofft-cta::before{ transform: translateY(-5px); }
    }
    @media (max-width:800px){
      #aof-footer .aofft-cta::before{ transform: translateY(75px); }
    }

    #aof-footer .aofft-cta .aofft-wrap{
      max-width: var(--maxw);
      margin: 0 auto;
      position: relative;
      z-index:1;
      display:grid;
      gap: 14px;
      grid-template-columns: 1fr auto;
      align-items:center;
    }
    @media (max-width:800px){
      #aof-footer .aofft-cta .aofft-wrap{
        grid-template-columns: 1fr;
      }
    }

    #aof-footer .aofft-eyebrow{
      display:inline-flex;
      align-items:center;
      gap:8px;
      font-weight:800;
      letter-spacing:.02em;
      color:#cbe0ff;
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.18);
      border-radius: 9999px;
      padding: 8px 14px;
      width: max-content;
      box-shadow: 0 8px 22px rgba(2,6,23,.18) inset, 0 8px 22px rgba(2,6,23,.16);
    }

    /* ✅ TITOLO PRE-FOOTER: forzato su 2 righe (desktop) */
    #aof-footer .aofft-title{
      margin: 6px 0 0;
      font-weight: 900;
      line-height: 1.12;
      letter-spacing: -.015em;
      font-size: clamp(28px, 4.6vw, 42px);
      text-wrap: balance;
      max-width: 32ch; /* <-- chiave: con questo tende a stare in 2 righe su desktop */
    }

    #aof-footer .aofft-title .grad{
      background: var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color: transparent;
      -webkit-text-fill-color: transparent;
    }

    #aof-footer .aofft-sub{
      margin: 6px 0 0;
      color:#e6efff;
      opacity:.92;
      font-weight:700;
      letter-spacing:.01em;
    }

    @media (max-width:800px){
      #aof-footer .aofft-title{
        max-width: none;
        font-size: clamp(22px, 6.2vw, 30px);
        line-height: 1.16;
        word-break: break-word;
        overflow-wrap: anywhere;
        hyphens: auto;
      }
      #aof-footer .aofft-sub{
        font-size: clamp(13px, 3.8vw, 15px);
        line-height: 1.45;
        word-break: break-word;
        overflow-wrap: anywhere;
        max-width: none;
        width:100%;
      }
    }

    #aof-footer .aofft-cta .aofft-actions{
      display:inline-flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-self: end;
    }
    @media (max-width:800px){
      #aof-footer .aofft-cta .aofft-actions{ justify-self: start; }
    }

    /* Bottoni (2 soli: WhatsApp + Contattaci) */
    #aof-footer .aofft-btn{
      --pad-x: 18px;
      --pad-y: 12px;
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding: var(--pad-y) var(--pad-x);
      font-weight:900;
      letter-spacing:.02em;
      border-radius: 14px;
      border: 1px solid transparent;
      text-decoration:none;
      white-space: nowrap;
      cursor:pointer;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background-position .9s ease;
      will-change: transform;
    }

    #aof-footer .aofft-btn--primary{
      color:#0b1220;
      background:
        linear-gradient(90deg, rgba(255,255,255,0) 0, rgba(255,255,255,.26) 16%, rgba(255,255,255,0) 33%) 0/220% 100%,
        linear-gradient(180deg, #fff, #eef5ff);
      border-color: rgba(203,213,225,.42);
      box-shadow: 0 10px 26px rgba(2,6,23,.18);
    }
    #aof-footer .aofft-btn--primary:hover{
      transform: translateY(-1px);
      background-position: 120% 0;
      filter: brightness(1.02);
    }

    #aof-footer .aofft-btn--ghost{
      color:#fff;
      background: rgba(255,255,255,.06);
      border-color: rgba(255,255,255,.26);
      box-shadow: 0 10px 26px rgba(2,6,23,.12) inset;
    }
    #aof-footer .aofft-btn--ghost:hover{ transform: translateY(-1px); }

    /* ========== BOTTOM ========== */
    #aof-footer .aofft-bottom{
      position: relative;
      background: var(--bg-bottom);
      padding: var(--bottom-pad-y) 16px calc(var(--bottom-pad-y) - 6px);
      overflow:hidden;
    }

    #aof-footer .aofft-bottom::before{
      content:"";
      position:absolute;
      inset:0;
      background:
        repeating-linear-gradient(0deg, rgba(59,130,246,.06) 0 1px, transparent 1px 22px),
        repeating-linear-gradient(90deg, rgba(59,130,246,.06) 0 1px, transparent 1px 22px);
      -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.16), rgba(0,0,0,.82), rgba(0,0,0,.16));
      mask-image: linear-gradient(to bottom, rgba(0,0,0,.16), rgba(0,0,0,.82), rgba(0,0,0,.16));
      pointer-events:none;
    }

    /* ✅ Desktop/tablet: 3 colonne reali (brand | nav+contatti | info federico+alex) */
    #aof-footer .aofft-wrap-bottom{
      max-width: var(--maxw);
      margin: 0 auto;
      position: relative;
      z-index: 1;
      display:grid;
      gap: 34px; /* più aria tra blocchi */
      grid-template-columns: 1.15fr 0.95fr 1.15fr;
      align-items:start;
    }
    @media (max-width:1100px){
      #aof-footer .aofft-wrap-bottom{
        grid-template-columns: 1fr;
        gap: 22px;
      }
    }

    /* Brand */
    #aof-footer .brand{
      display:grid;
      gap:10px;
    }
    #aof-footer .brand .logo{
      display:inline-flex;
      align-items:baseline;
      gap:0;
      font-weight:900;
      letter-spacing:-.01em;
      font-size: clamp(22px, 3.6vw, 28px);
      color:#fff;
    }
    #aof-footer .brand .logo .accent{
      background: var(--grad);
      -webkit-background-clip:text;
      background-clip:text;
      color: transparent;
      -webkit-text-fill-color: transparent;
    }
    #aof-footer .brand p{
      margin:0;
      color:#c7d2fe;
      opacity:.9;
      line-height: 1.6;
      max-width: 52ch;
    }
    @media (max-width:640px){
      #aof-footer .brand p{
        max-width:none;
        width:100%;
        word-break: break-word;
        overflow-wrap: anywhere;
        hyphens:auto;
        font-size: clamp(13px, 3.9vw, 15px);
        line-height:1.5;
      }
      #aof-footer .brand .logo{
        font-size: clamp(24px, 7vw, 28px);
      }
    }

    /* Social */
    #aof-footer .social{
      display:flex;
      gap:10px;
      flex-wrap: wrap;
    }
    #aof-footer .social a{
      width:38px;
      height:38px;
      display:grid;
      place-items:center;
      border-radius: 12px;
      color:#e7efff;
      text-decoration:none;
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.16);
      transition: transform .18s ease, background .18s ease, border-color .18s ease;
    }
    #aof-footer .social a:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.10);
      border-color: rgba(255,255,255,.22);
    }

    /* Colonne: titoli */
    #aof-footer .col h3,
    #aof-footer .h3like{
      margin: 0 0 10px;
      font-size: 14px;
      text-transform: uppercase;
      letter-spacing: .16em;
      color: #cbd5e1;
      opacity: .86;
      font-weight: 800;
    }

    /* Liste base */
    #aof-footer .list{
      display:grid;
      gap:8px;
      margin:0;
      padding:0;
      list-style:none;
    }

    #aof-footer .link{
      display:inline-flex;
      align-items:center;
      gap:8px;
      color:#e5edff;
      text-decoration:none;
      font-weight:700;
      letter-spacing:.01em;
      position:relative;
      word-break: break-word;
    }
    #aof-footer .link::after{
      content:"";
      position:absolute;
      left:0;
      bottom:-2px;
      width:0;
      height:2px;
      border-radius:999px;
      background: var(--grad);
      transition: width .18s ease;
    }
	    #aof-footer .link:hover::after{ width:82%; }
	    #aof-footer .link svg{ transform: translateY(.5px); opacity:.9; }
	    #aof-footer .link.link--blog{
	      font-weight: 900;
	      color:#ffffff;
	    }
	    #aof-footer .link.link--blog::after{
	      width: 0;
	      opacity: .95;
	    }
	    #aof-footer .link.link--blog[aria-current="page"]::after{
	      width: 100%;
	    }

	    /* ✅ NAV + CONTATTI uno sotto l'altro (stesso blocco) */
	    #aof-footer .navcont{
      display:grid;
      gap: 18px;
    }
    /* navigazione e contatti più in risalto */
    #aof-footer .navcont .h3like{
      color: #e7efff;
      opacity: .98;
    }

    /* ✅ INFO legali */
    #aof-footer .infowrap{
      display:grid;
      gap: 16px;
    }

    /* Desktop: 1 colonna (solo Alex) */
    @media (min-width: 1101px){
      #aof-footer .infowrap{
        grid-template-columns: minmax(0, 1fr);
        gap: 18px;
        align-items: start;
      }
    }

    /* ✅ SOLO le righe delle info (denominazione, CF, P.IVA, ecc.) MOLTO più piccole */
    #aof-footer .list.meta li{
      font-size: 0.78rem;
      line-height: 1.35;
      color: rgba(229, 237, 255, .90);
      font-weight: 650;
    }
    @media (max-width:640px){
      #aof-footer .list.meta li{
        font-size: clamp(11px, 3.2vw, 13px);
        line-height: 1.32;
      }
    }

    /* Legal */
    #aof-footer .legal{
      margin-top: clamp(18px, 3.6vw, 26px);
      padding-top: 14px;
      border-top: 1px solid rgba(148,163,184,.22);
      display:block;
      grid-column: 1 / -1;
    }
    #aof-footer .legal .copy{
      color:#a9b6d8;
      font-weight:700;
      white-space: nowrap;
      overflow:hidden;
      text-overflow: clip;
    }
    #aof-footer .legal a{
      color:#dbe6ff;
      text-decoration:none;
      position:relative;
    }
    #aof-footer .legal a::after{
      content:"";
      position:absolute;
      left:0;
      bottom:-2px;
      width:0;
      height:2px;
      border-radius:999px;
      background: var(--grad);
      transition: width .18s ease;
    }
    #aof-footer .legal a:hover::after{ width:100%; }

	    @media (max-width:640px){
	      #aof-footer .legal .copy{
	        white-space: nowrap;
        font-size: clamp(10px, 2.7vw, 12px);
        line-height: 1.4;
        letter-spacing: 0;
        text-align:center;
      }
    }

    /* Accessibilità */
    #aof-footer .link:focus-visible,
    #aof-footer .social a:focus-visible,
    #aof-footer .aofft-btn:focus-visible,
    #aof-footer .legal a:focus-visible{
      outline: 3px solid color-mix(in srgb, hsl(var(--blue)) 60%, hsl(var(--cyan)) 40%);
      outline-offset: 3px;
      border-radius: 12px;
    }

    @media (prefers-reduced-motion:reduce){
      #aof-footer .aofft-btn,
      #aof-footer .link::after,
      #aof-footer .legal a::after{ transition:none !important; }
    }

/* === BLOG (catalogo + articolo) === */
    .aof-blog-main{
      background:
        radial-gradient(900px 600px at 15% -10%, rgba(14,165,233,.12), transparent 55%),
        radial-gradient(900px 600px at 90% 0%, rgba(37,99,235,.10), transparent 55%),
        #f7fbff;
      --gradient: linear-gradient(135deg, hsl(212 100% 50%), hsl(195 100% 46%));
      color:#0b1220;
      padding: 34px 0 80px;
    }
    .aof-blog-container{
      max-width: 1040px;
      margin: 0 auto;
      padding: 0 16px;
    }
    .aof-blog-breadcrumb{
      display:flex;
      gap:10px;
      align-items:center;
      color: rgba(11,18,32,.65);
      font-weight: 800;
      font-size: 14px;
      margin: 0 0 18px;
    }
    .aof-blog-breadcrumb a{
      text-decoration:none;
      color: rgba(11,18,32,.72);
      padding: 0;
      border-radius: 0;
      border: 0;
      background: transparent;
    }
    .aof-blog-breadcrumb a:hover{ text-decoration: underline; }

	    .aof-blog-hero{
	      background: rgba(255,255,255,.70);
	      border: 1px solid rgba(2,6,23,.10);
	      border-radius: 22px;
	      padding: clamp(18px, 3.6vw, 26px);
	      box-shadow: 0 14px 34px rgba(2,6,23,.10);
	    }

	    /* === DOVE OPERIAMO === */
	    .aof-where-grid{
	      display:grid;
	      grid-template-columns: repeat(2, minmax(0, 1fr));
	      gap: 14px;
	      margin-top: 18px;
	    }
	    @media (max-width: 820px){
	      .aof-where-grid{ grid-template-columns: 1fr; }
	    }
	    .aof-where-card{
	      background: rgba(255,255,255,.72);
	      border: 1px solid rgba(2,6,23,.10);
	      border-radius: 22px;
	      padding: clamp(16px, 3.2vw, 22px);
	      box-shadow: 0 14px 34px rgba(2,6,23,.10);
	      position: relative;
	      overflow: hidden;
	    }
	    .aof-where-card::before{
	      content:"";
	      position:absolute;
	      inset:-1px;
	      background:
	        radial-gradient(520px 240px at 10% 0%, rgba(14,165,233,.14), transparent 58%),
	        radial-gradient(520px 240px at 100% 15%, rgba(37,99,235,.12), transparent 60%);
	      pointer-events:none;
	    }
	    .aof-where-card > *{ position: relative; z-index: 1; }
	    .aof-where-badge{
	      display:inline-flex;
	      align-items:center;
	      width:max-content;
	      padding: 9px 14px;
	      border-radius: 999px;
	      border: 1px solid rgba(37,99,235,.22);
	      background: rgba(14,165,233,.08);
	      font-weight: 900;
	      letter-spacing: .02em;
	      color:#2563eb;
	      font-size: 13px;
	    }
	    .aof-where-title{
	      margin: 12px 0 6px;
	      font-weight: 900;
	      letter-spacing: -0.02em;
	      line-height: 1.08;
	      font-size: clamp(22px, 2.6vw, 30px);
	      color: #0b1220;
	    }
	    .aof-where-text{
	      margin: 0;
	      color: rgba(11,18,32,.78);
	      line-height: 1.55;
	      font-size: 16px;
	      font-weight: 650;
	      max-width: 60ch;
	    }
    .aof-blog-eyebrow{
      display:inline-flex;
      align-items:center;
      padding: 9px 14px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.22);
      background: rgba(14,165,233,.08);
      font-weight: 900;
      letter-spacing: .02em;
      color:#2563eb;
      font-size: 13px;
    }
    .aof-blog-title{
      margin: 12px 0 8px;
      font-weight: 900;
      letter-spacing: -0.02em;
      line-height: 1.06;
      font-size: clamp(34px, 5.2vw, 56px);
    }
    .aof-blog-sub{
      margin: 0;
      color: rgba(11,18,32,.72);
      font-weight: 700;
      line-height: 1.55;
      font-size: clamp(16px, 2.2vw, 19px);
      max-width: 70ch;
    }

    .aof-blog-tools{
      margin-top: 18px;
      display:flex;
      align-items:flex-end;
      justify-content:space-between;
      gap:16px;
    }
    .aof-blog-search{flex:1;min-width:240px;max-width:560px;}
    .aof-blog-tools__meta{
      font-weight: 800;
      color: rgba(11,18,32,.68);
      font-size: 13px;
    }
    .aof-blog-pager{
      margin-top: 18px;
      display:flex;
      align-items:center;
      justify-content:center;
      gap:10px;
    }
    .aof-blog-pages{
      display:flex;
      align-items:center;
      justify-content:center;
      gap:8px;
      flex-wrap:wrap;
    }
    .aof-blog-pagebtn{
      appearance:none;
      border: 1px solid rgba(2,6,23,.12);
      background: rgba(255,255,255,.86);
      color: rgba(11,18,32,.86);
      border-radius: 12px;
      padding: 10px 12px;
      font-weight: 900;
      min-width: 44px;
      line-height: 1;
      cursor:pointer;
      box-shadow: 0 10px 24px rgba(2,6,23,.10);
      transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
    }
    .aof-blog-pagebtn:hover{
      transform: translateY(-1px);
      background: rgba(255,255,255,.94);
      border-color: rgba(6,182,212,.35);
      box-shadow: 0 14px 32px rgba(2,6,23,.12);
    }
    .aof-blog-pagebtn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow: 0 10px 24px rgba(2,6,23,.08);}
    .aof-blog-pagebtn.is-active{
      background: linear-gradient(135deg, rgba(37,99,235,.14), rgba(6,182,212,.16));
      border-color: rgba(6,182,212,.45);
      color: rgba(11,18,32,.96);
    }
    .aof-blog-dots{opacity:.55;font-weight:900;}

    @media (max-width: 900px){
      .aof-blog-tools{flex-direction:column;align-items:stretch;}
      .aof-blog-tools__meta{order:2}
    }

    .aof-blog-grid{
      margin-top: 18px;
      display:grid;
      grid-template-columns: 1fr;
      gap: 14px;
    }
    .aof-post-card{
      background: rgba(255,255,255,.86);
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 22px;
      overflow:hidden;
      box-shadow: 0 14px 34px rgba(2,6,23,.10);
    }
    .aof-post-card__link{
      display:block;
      padding: 18px 18px 16px;
      text-decoration:none;
      color: inherit;
    }
    .aof-post-card__thumb{
      margin: -18px -18px 14px;
      border-bottom: 1px solid rgba(2,6,23,.08);
      background: rgba(14,165,233,.08);
      overflow:hidden;
    }
    .aof-post-card__thumb img{
      width:100%;
      display:block;
      height:auto;
      object-fit: cover;
      aspect-ratio: 16/9;
      filter: saturate(1.05) contrast(1.02);
    }
    .aof-post-card__meta{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding: 8px 12px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.20);
      background: rgba(37,99,235,.06);
      color: rgba(11,18,32,.74);
      font-weight: 800;
      font-size: 13px;
    }
    .aof-post-card__title{
      margin: 12px 0 8px;
      font-weight: 900;
      letter-spacing: -0.02em;
      line-height: 1.1;
      font-size: clamp(22px, 3.2vw, 30px);
    }
    .aof-post-card__excerpt{
      margin: 0 0 12px;
      color: rgba(11,18,32,.72);
      font-weight: 700;
      line-height: 1.6;
      font-size: 16px;
      max-width: 85ch;
    }
    .aof-post-card__cta{
      display:inline-flex;
      align-items:center;
      gap: 8px;
      font-weight: 900;
      color:#2563eb;
    }
    .aof-post-card__link:hover .aof-post-card__cta{ text-decoration: underline; }

    /* articolo */
    .aof-article{
      background: rgba(255,255,255,.86);
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 22px;
      overflow:hidden;
      box-shadow: 0 14px 34px rgba(2,6,23,.10);
    }
    .aof-article-hero{
      padding: clamp(18px, 3.6vw, 26px);
      border-bottom: 1px solid rgba(2,6,23,.10);
      background: linear-gradient(180deg, rgba(14,165,233,.08), rgba(255,255,255,.0));
    }
    .aof-article-kicker{
      display:inline-flex;
      padding: 9px 14px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.20);
      background: rgba(14,165,233,.08);
      color: rgba(11,18,32,.74);
      font-weight: 900;
      font-size: 13px;
      margin: 0;
    }
    .aof-article-title{
      margin: 12px 0 8px;
      font-weight: 900;
      letter-spacing: -0.02em;
      line-height: 1.06;
      font-size: clamp(30px, 4.8vw, 50px);
    }
    .aof-article-sub{
      margin: 0 0 14px;
      color: rgba(11,18,32,.72);
      font-weight: 700;
      line-height: 1.6;
      font-size: 17px;
      max-width: 78ch;
    }
    .aof-article-meta{
      display:flex;
      flex-wrap: wrap;
      gap: 10px;
      color: rgba(11,18,32,.68);
      font-weight: 800;
      font-size: 13px;
      margin-top: 10px;
    }
    .aof-article-meta span{
      display:inline-flex;
      align-items:center;
      padding: 8px 12px;
      border-radius: 999px;
      border: 1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.65);
    }
    .aof-article-cover{
      margin: 16px 0 0;
      border-radius: 18px;
      overflow:hidden;
      border: 1px solid rgba(2,6,23,.10);
      background:#eaf2ff;
    }
    .aof-article-cover img{
      width:100%;
      height:auto;
      display:block;
      aspect-ratio: 16 / 8;
      object-fit: cover;
    }

    .aof-article-toc{
      margin: 16px clamp(18px, 3.6vw, 26px) 0;
      padding: 14px 14px;
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(14,165,233,.10), rgba(37,99,235,.06));
    }
    .aof-article-toc strong{ display:block; margin-bottom: 10px; }
    .aof-article-toc a{
      display:block;
      padding: 9px 10px;
      border-radius: 12px;
      text-decoration:none;
      color: rgba(11,18,32,.84);
      font-weight: 800;
    }
    .aof-article-toc a:hover{
      background: rgba(255,255,255,.65);
      border: 1px solid rgba(37,99,235,.18);
    }

    .aof-article-body{
      padding: 0 clamp(18px, 3.6vw, 26px) 22px;
      color: rgba(11,18,32,.92);
      font-size: 17px;
      line-height: 1.72;
    }
    .aof-article-body h2{
      margin: 26px 0 10px;
      font-weight: 900;
      letter-spacing: -0.01em;
      line-height: 1.15;
      font-size: clamp(22px, 2.4vw, 30px);
    }
    .aof-article-body p{ margin: 12px 0; }
    .aof-article-body ul{ margin: 12px 0 12px 20px; }
    .aof-article-body li{ margin: 6px 0; }

    .aof-article-callout{
      margin: 16px 0;
      padding: 14px 14px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.20);
      background: rgba(37,99,235,.06);
    }
    .aof-article-callout strong{ display:block; margin-bottom: 6px; }

    .aof-article-figure{
      margin: 18px 0;
      border-radius: 18px;
      overflow:hidden;
      border: 1px solid rgba(2,6,23,.10);
      background:#eaf2ff;
      box-shadow: 0 12px 28px rgba(2,6,23,.10);
    }
    .aof-article-figure img{
      width:100%;
      display:block;
      height:auto;
      aspect-ratio: 16 / 9;
      object-fit: cover;
    }
    .aof-article-figure figcaption{
      padding: 12px 14px;
      border-top: 1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.70);
      color: rgba(11,18,32,.72);
      font-weight: 800;
      font-size: 13px;
      line-height: 1.4;
    }
    @media (max-width:720px){
      .aof-article-figure img{ aspect-ratio: 16/10; }
    }

    .aof-article-gallery{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin: 16px 0 6px;
    }
    .aof-article-gallery__item{
      margin: 0;
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 18px;
      overflow: hidden;
      background: rgba(255,255,255,.70);
      box-shadow: 0 12px 28px rgba(2,6,23,.08);
    }
    .aof-article-gallery__item img{
      width:100%;
      display:block;
      height:auto;
      object-fit: cover;
      aspect-ratio: 16/10;
    }
    .aof-article-gallery__item figcaption{
      padding: 10px 12px 12px;
      border-top: 1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.70);
      color: rgba(11,18,32,.72);
      font-weight: 800;
      font-size: 13px;
      line-height: 1.4;
    }
    @media (max-width: 860px){
      .aof-article-gallery{ grid-template-columns: 1fr; }
    }

    .aof-article-split{
      margin: 18px 0;
      display:grid;
      grid-template-columns: 1.25fr .95fr;
      gap: 14px;
      align-items: stretch;
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 18px;
      background: rgba(255,255,255,.70);
      overflow:hidden;
      box-shadow: 0 12px 28px rgba(2,6,23,.08);
    }
    .aof-article-split__text{ padding: 14px 14px; }
    .aof-article-miniTitle{
      margin: 0 0 10px;
      font-weight: 950;
      letter-spacing: -0.01em;
      font-size: 18px;
      color:#0b1220;
    }
    .aof-article-check{
      margin: 0 0 10px 18px;
      color: rgba(11,18,32,.88);
      font-weight: 750;
    }
    .aof-article-muted{ margin: 0; color: rgba(11,18,32,.68); font-weight: 750; font-size: 14px; line-height: 1.55; }
    .aof-article-split__media{
      margin: 0;
      border-left: 1px solid rgba(2,6,23,.10);
      background:#eaf2ff;
      display:flex;
    }
    .aof-article-split__media img{
      width:100%;
      height:100%;
      object-fit: cover;
      display:block;
    }
    @media (max-width: 860px){
      .aof-article-split{ grid-template-columns: 1fr; }
      .aof-article-split__media{ border-left: 0; border-top: 1px solid rgba(2,6,23,.10); min-height: 200px; }
    }

    .aof-article-ranges{
      display:grid;
      gap: 12px;
      margin: 14px 0 10px;
    }
    .aof-article-range{
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 18px;
      background: rgba(255,255,255,.70);
      padding: 14px 14px;
    }
    .aof-article-range__head{
      display:flex;
      justify-content: space-between;
      gap: 10px;
      flex-wrap: wrap;
      align-items: baseline;
      margin-bottom: 6px;
    }
    .aof-article-range__title{ font-weight: 900; }
    .aof-article-range__price{
      font-weight: 900;
      color:#2563eb;
      white-space: nowrap;
    }

	    .aof-article-cta{
	      margin: 18px 0;
	      border-radius: 22px;
	      border: 1px solid rgba(14,165,233,.24);
	      background: linear-gradient(135deg, rgba(14,165,233,.18), rgba(37,99,235,.12));
      padding: 18px 18px;
      display:flex;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      position: relative;
      overflow: hidden;
	      box-shadow: 0 18px 40px rgba(2,6,23,.12);
	    }
	    .aof-article-cta::before{
      content:"";
      position:absolute;
      inset:-2px;
      background: linear-gradient(135deg, rgba(37,99,235,.55), rgba(14,165,233,.55));
      opacity:.22;
      filter: blur(14px);
      pointer-events:none;
	    }

	    /* Variante più “accesa” (usata su Dove operiamo) */
	    .aof-article-cta.aof-article-cta--bright{
	      border-color: rgba(14,165,233,.22);
	      background: linear-gradient(135deg, rgba(14,165,233,.14), rgba(37,99,235,.08));
	      box-shadow: 0 18px 40px rgba(2,6,23,.08);
	    }
	    .aof-article-cta.aof-article-cta--bright::before{
	      opacity: .16;
	      filter: blur(18px);
	    }
    .aof-article-cta > *{ position: relative; z-index: 1; }
    .aof-article-cta h2{ margin: 0 0 4px; font-size: 18px; }
    .aof-article-cta p{ margin: 0; color: rgba(11,18,32,.72); font-weight: 700; font-size: 14px; line-height: 1.55; }
    .aof-article-cta__actions{ display:flex; gap: 10px; flex-wrap: wrap; }
    .aof-article-btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap: 10px;
      text-decoration:none;
      font-weight: 900;
      letter-spacing: .01em;
      padding: 12px 14px;
      border-radius: 999px;
      border: 1px solid rgba(2,6,23,.10);
      background: rgba(255,255,255,.80);
      color:#0b1220;
      white-space: nowrap;
    }
    .aof-article-btn--primary{
      border: 0;
      background: linear-gradient(135deg, hsl(195 100% 46%), hsl(212 100% 50%));
      color: #fff;
      box-shadow: 0 16px 34px rgba(37,99,235,.26);
    }
    .aof-article-btn:hover{ transform: translateY(-1px); }

    /* Mobile: CTA button full-width, no awkward wrapping */
    @media (max-width: 640px){
      .aof-article-cta{ padding: 16px 14px; }
      .aof-article-cta__actions{ width:100%; }
      .aof-article-btn{
        width:100%;
        border-radius: 16px;
        padding: 12px 14px;
      }
    }

    .aof-article-faq{
      border: 1px solid rgba(2,6,23,.10);
      border-radius: 16px;
      padding: 12px 12px;
      background: rgba(255,255,255,.70);
      margin: 12px 0;
    }
    .aof-article-faq summary{
      cursor:pointer;
      font-weight: 900;
      color:#0b1220;
    }
    .aof-article-faq p{ margin: 10px 0 0; color: rgba(11,18,32,.82); }

    .aof-article-foot{
      padding: 14px clamp(18px, 3.6vw, 26px) 18px;
      border-top: 1px solid rgba(2,6,23,.10);
      color: rgba(11,18,32,.62);
      font-weight: 800;
      font-size: 13px;
      background: rgba(255,255,255,.65);
    }
    .aof-article-foot p{ margin:0; }

    @media (max-width:720px){
      .aof-article-cover img{ aspect-ratio: 16/10; }
    }

/* =======================
   LARGE DESKTOP TUNING
   (applies only on big viewports)
   ======================= */
@media (min-width:1440px){
  /* 1440–1919: small bump (keeps 13–15" looking right) */
  .container{ max-width: 1240px; }
  .aof-header{ --maxw: 1240px; }
  #aof-footer{ --maxw: 1240px; }

  #manca-un-pezzo.aofm-piece{ --maxw: 1240px; }
  #servizi.aof-services{ --maxw: 1280px; }
  #lavori.oflw-works{ --maxw: 1280px; }
  #aof-ba-slideshow{ --maxw: 1280px; }
  #perche-sceglierci.aofc-choose{ --aofc-maxw: 1280px; }

  #verifica-3-pilastri .container{ max-width: 980px; }
  #verifica-3-pilastri .subtitle{ max-width: 820px; }
  .aofm-airbar{ max-width: 760px; }

  #come-lavoriamo .pf-timeline__header{ max-width: 1040px; }
  #come-lavoriamo .pf-sub{ max-width: 900px; }
  #come-lavoriamo .pf-timeline__wrap{ max-width: 1240px; }
  #come-lavoriamo .pf-tl-card{ width: clamp(460px, calc(50% - var(--gap-safe)), 620px); }

  /* Avoid left-shift that creates extra empty space on wide displays */
  #manca-un-pezzo .aofm-left{ transform: none !important; }
}

@media (min-width:1920px){
  /* 1920+: true large monitors (21\"/27\") */
  .container{ max-width: 1520px; }
  .aof-header{ --maxw: 1520px; }
  #aof-footer{ --maxw: 1520px; }

  /* Key “too small” sections */
  #manca-un-pezzo.aofm-piece{ --maxw: 1640px; }
  #servizi.aof-services{ --maxw: 1660px; }
  #lavori.oflw-works{ --maxw: 1660px; }
  #aof-ba-slideshow{ --maxw: 1660px; }
  #perche-sceglierci.aofc-choose{ --aofc-maxw: 1560px; }

  #verifica-3-pilastri .container{ max-width: 1280px; }
  #verifica-3-pilastri .subtitle{ max-width: 1040px; }
  .aofm-airbar{ max-width: 980px; }

  /* Timeline: make cards/typography feel proportional */
  #come-lavoriamo .pf-timeline__header{ max-width: 1280px; }
  #come-lavoriamo .pf-sub{ max-width: 1120px; }
  #come-lavoriamo .pf-timeline__wrap{ max-width: 1500px; }
  #come-lavoriamo .pf-tl-card{ width: clamp(600px, calc(50% - var(--gap-safe)), 820px); }
  #come-lavoriamo .pf-tl-card__inner{ padding: 30px 26px 28px; }
  #come-lavoriamo .pf-tl-title{ font-size: 1.28rem; }
  #come-lavoriamo .pf-tl-sub{ font-size: 1.08rem; }
  #come-lavoriamo .pf-tl-desc{ font-size: 1.05rem; }
}

/* ===============================
   AOF — Cookie Consent (GA)
   =============================== */
.aof-consent-overlay{
  position: fixed;
  inset: 0;
  z-index: 2500;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 18px;
  background: rgba(2, 6, 23, .46);
  -webkit-backdrop-filter: blur(10px) saturate(140%);
  backdrop-filter: blur(10px) saturate(140%);
}

.aof-consent-card{
  width: min(980px, calc(100vw - 36px));
  border-radius: 26px;
  background: rgba(255, 255, 255, .94);
  border: 1px solid rgba(255, 255, 255, .22);
  box-shadow: 0 28px 80px rgba(2, 6, 23, .42);
  padding: 22px 22px 18px;
  position: relative;
  overflow: hidden;
}

.aof-consent-card::before{
  content:"";
  position:absolute;
  inset: -2px;
  border-radius: 28px;
  background: linear-gradient(90deg, rgba(0,184,255,.22), rgba(0,119,255,.22));
  pointer-events:none;
  z-index: 0;
}

.aof-consent-card > *{ position: relative; z-index: 1; }

.aof-consent-head{
  display: flex;
  align-items: center;
  gap: 14px;
}

.aof-consent-logo{
  height: 54px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 2px 10px rgba(2, 6, 23, .12));
}

.aof-consent-kicker{
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(11, 19, 36, .62);
}

.aof-consent-title{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 900;
  letter-spacing: .01em;
  color: #0b1324;
  font-size: 20px;
}

.aof-consent-sub{
  margin-top: 10px;
  color: rgba(11, 19, 36, .82);
  font-size: 15.5px;
  line-height: 1.45;
}

.aof-consent-links{
  display: inline-flex;
  gap: 8px;
  margin-left: 10px;
  white-space: nowrap;
}

.aof-consent-link{
  color: #0b1324;
  font-weight: 800;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.aof-consent-actions{
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.aof-consent-btn{
  appearance: none;
  border: 0;
  border-radius: 999px;
  padding: 13px 16px;
  font-weight: 900;
  font-size: 15.5px;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.aof-consent-btn:active{ transform: translateY(1px); }

.aof-consent-btn--ghost{
  background: rgba(2, 6, 23, .06);
  color: #0b1324;
  border: 1px solid rgba(2, 6, 23, .10);
}

.aof-consent-btn--primary{
  color: #fff;
  background: linear-gradient(90deg, hsl(195 100% 46%), hsl(212 100% 50%));
  box-shadow: 0 12px 28px rgba(0, 119, 255, .28);
}

.aof-consent-btn--primary:hover{ box-shadow: 0 16px 34px rgba(0, 119, 255, .34); }

@media (min-width: 900px){
  .aof-consent-overlay{ align-items: flex-end; padding: 24px; }
  .aof-consent-card{ padding: 26px 26px 20px; }
  .aof-consent-title{ font-size: 22px; }
  .aof-consent-sub{ font-size: 16px; }
  .aof-consent-logo{ height: 58px; }
}
