/* Auto-generated: concatenazione CSS per sito statico (IT/EN/AR)
   Sorgenti originali: assets/css/{base,utilities,components,site-shell}.css + assets/css/pages/*.css
*/

/* === base.css === */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&display=swap');

:root {
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #fff;
  background-color: #000;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: inherit;
  background: #000;
  color: #fff;
  line-height: 1.5;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

a {
  color: inherit;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

/* Home "Flotta in evidenza": evita drag dell'immagine durante lo swipe */
.pf-fleet-wrap img,
.pf-fleet img,
.pf-card img {
  -webkit-user-drag: none;
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

/* Fleet hint (home): arrows + short instruction (always visible, ultra-light) */
.pf-fleet {
  position: relative;
}

.pf-fleet-navArrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  line-height: 1;
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.55);
  font-size: 22px;
  font-weight: 900;
  opacity: 0.35;
  pointer-events: auto;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  z-index: 9;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}
.pf-fleet-navArrow--left { left: 10px; }
.pf-fleet-navArrow--right { right: 10px; }

.pf-fleet-navArrow svg {
  width: 18px;
  height: 18px;
  display: block;
  transform: translateY(0px);
}

.pf-fleet-navArrow:hover { opacity: 0.55; }
.pf-fleet-navArrow:active { opacity: 0.7; transform: translateY(-50%) scale(0.98); }

.pf-fleet-hint {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.20);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.82);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.2px;
  opacity: 0.55;
  pointer-events: none;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.pf-fleet-hint__mobile { display: none; }
@media (max-width: 760px) {
  .pf-fleet-hint__desktop { display: none; }
  .pf-fleet-hint__mobile { display: inline; }
}

@media (max-width: 600px) {
  /* override inline style that hides arrows on mobile */
  #pf-ig-stories .pf-3d-arrows {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 20;
  }

  #pf-ig-stories .pf-3d-nav {
    pointer-events: auto;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.55);
    font-size: 20px;
    line-height: 1;
    font-weight: 900;
    opacity: 0.35;
    -webkit-tap-highlight-color: transparent;
    cursor: pointer;
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
  }

  #pf-ig-stories .pf-3d-nav-left { margin-left: 10px; }
  #pf-ig-stories .pf-3d-nav-right { margin-right: 10px; }
  #pf-ig-stories .pf-3d-nav:active { opacity: 0.7; transform: scale(0.98); }
}

button,
input,
textarea,
select {
  font: inherit;
}


/* === utilities.css === */
/* Classi utility riutilizzabili (margin helper, layout helper, ecc.) - da popolare se/quando servirà */


/* === components.css === */
/* Stili condivisi per componenti globali (header, footer, ecc.) */

/* Header SupremeCars (copiato dalla home, reso globale) */
:root {
  --pf-sdv-orange: #D40000;
  --pf-sdv-white: #fff;
  --pf-sdv-header-h: 86px;
  --drawer-w: min(74vw, 380px);
  --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');
  --fs-base: clamp(19px, 4vw, 22px);
  --fs-home: clamp(21px, 4.4vw, 24px);
  --fs-vendita: clamp(28px, 7vw, 36px);
  --fs-noleggio: clamp(32px, 8.2vw, 42px);
  --brand-left-nudge: -6px;
}

body {
  padding-top: var(--pf-sdv-header-h);
}

/* Footer: dati societari */
#af-footer .af-bottom .af-company {
  display: none;
}

#af-footer .af-company--mobile {
  display: grid;
}

#af-footer .af-company-lines {
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255, 255, 255, .86);
  font-weight: 650;
}

#af-footer .af-company-name {
  font-weight: 900;
  color: #fff;
  margin-bottom: 6px;
}

/* Footer: link developer (desktop inline, mobile below centered) */
#af-footer .af-legal {
  flex-wrap: wrap;
  align-items: center;
}

#af-footer .af-legal-links {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: nowrap;
}

#af-footer .af-legal-links a {
  white-space: nowrap;
}

#af-footer .af-legal .af-dev {
  color: rgba(255, 255, 255, .75);
  font-weight: 650;
}

#af-footer .af-legal .af-dev:hover {
  text-decoration: underline;
}

@media (max-width: 767.98px) {
  #af-footer .af-legal {
    width: 100%;
    justify-content: center;
    flex-direction: column;
    gap: 10px;
    text-align: center;
  }

  #af-footer .af-bottom .wrap {
    align-items: center;
    text-align: center;
  }

  #af-footer .af-copy {
    text-align: center;
  }

  #af-footer .af-bottom.wrap {
    align-items: center;
    text-align: center;
  }

  #af-footer .af-bottom {
    text-align: center;
  }

  #af-footer .af-company-lines {
    font-size: 12.5px;
  }
}

#pf-sdv-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 60;
  background: #0b0b0b;
  color: var(--pf-sdv-white);
  transition: box-shadow .2s ease, background .2s ease;
  backdrop-filter: saturate(160%) blur(10px);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

#pf-sdv-header.pf-sdv--scrolled {
  box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
}

.pf-sdv-container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 18px;
}

.pf-sdv-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  height: var(--pf-sdv-header-h);
}

.pf-sdv-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
  white-space: nowrap;
  margin-left: var(--brand-left-nudge);
  line-height: 0;
}

.pf-sdv-logo-mask {
  width: 136px;
  height: 50px;
  aspect-ratio: 136/50;
  display: inline-block;
  color: #fff;
  background-color: currentColor;
  -webkit-mask: var(--logo-src) center / contain no-repeat;
  mask: var(--logo-src) center / contain no-repeat;
  image-rendering: -webkit-optimize-contrast;
  transform: translateZ(0);
}

.pf-sdv-menu--desktop {
  display: none;
  align-items: center;
  gap: 26px;
}

.pf-sdv-link,
.pf-sdv-dropdown__btn {
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  letter-spacing: .2px;
  color: var(--pf-sdv-white);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.pf-sdv-link:hover,
.pf-sdv-dropdown__btn:hover {
  opacity: .9;
}

/* iOS/Android: evita highlight blu su tap/focus (logo + voci menu) */
#pf-sdv-header a,
#pf-sdv-header button,
#pf-sdv-svc-dd a,
#pf-sdv-mobile a,
#pf-sdv-mobile button {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.pf-sdv-dropdown__btn {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.pf-sdv-caret {
  transition: transform .15s ease;
}

.pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
  transform: rotate(180deg);
}

.pf-sdv-inline-dropdown {
  position: fixed;
  top: var(--pf-sdv-header-h);
  left: 0;
  display: none;
  background: #0b0b0b;
  color: var(--pf-sdv-white);
  padding: 12px 16px;
  white-space: nowrap;
  z-index: 59;
  border-top: 1px solid rgba(255, 255, 255, .12);
}

.pf-sdv-inline-dropdown__row {
  display: flex;
  align-items: center;
  gap: 28px;
}

.pf-sdv-inline-dropdown a {
  color: var(--pf-sdv-white);
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
}

.pf-sdv-inline-dropdown a:hover {
  text-decoration: underline;
}

.pf-sdv-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pf-lang {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.pf-lang__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0.3px;
  border: 1px solid var(--pf-sdv-white);
  color: var(--pf-sdv-white);
  background: transparent;
  cursor: pointer;
}

.pf-lang__label {
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.2px;
  opacity: 0.92;
  line-height: 1;
}

.pf-lang__btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.75);
  outline-offset: 2px;
}

.pf-lang__menu {
  position: absolute;
  inset-inline-end: 0;
  top: calc(100% + 10px);
  min-width: 132px;
  padding: 6px;
  border-radius: 14px;
  background: rgba(12, 12, 12, 0.96);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.55);
  z-index: 220;
}

.pf-lang__menu a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 10px;
  border-radius: 10px;
  color: var(--pf-sdv-white);
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
}

.pf-lang__menu a:hover {
  background: rgba(255, 255, 255, 0.1);
}

.pf-lang__menu a[aria-current="page"] {
  background: rgba(255, 255, 255, 0.14);
}

.pf-sdv-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid var(--pf-sdv-white);
  color: var(--pf-sdv-white);
  background: transparent;
}

.pf-sdv-btn--primary {
  background: var(--pf-sdv-white);
  color: var(--pf-sdv-orange);
  border-color: var(--pf-sdv-white);
}

.pf-sdv-toggle {
  border: 0;
  background: transparent;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.pf-burger {
  position: relative;
  width: 26px;
  height: 26px;
}

.pf-burger .bar {
  position: absolute;
  left: 2px;
  right: 2px;
  height: 2px;
  background: var(--pf-sdv-white);
  border-radius: 2px;
  transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
}

.pf-burger .bar.top { top: 6px; }
.pf-burger .bar.mid { top: 12px; }
.pf-burger .bar.bot { top: 18px; }

@media (max-width: 640px) {
  :root {
    --pf-sdv-header-h: 72px !important;
    --brand-left-nudge: -2px !important;
  }

  .pf-sdv-container {
    padding: 0 16px;
  }

  .pf-sdv-bar {
    gap: 12px;
  }

  .pf-sdv-logo-mask {
    width: 110px;
    height: 38px;
  }

  .pf-sdv-actions {
    gap: 8px;
  }

  .pf-sdv-btn {
    padding: 8px 14px;
    font-size: 15px;
  }

  .pf-sdv-toggle,
  .pf-burger {
    width: 24px;
    height: 24px;
  }

  .pf-burger .bar {
    left: 1px;
    right: 1px;
  }

  .pf-burger .bar.top { top: 4px; }
  .pf-burger .bar.mid { top: 10px; }
  .pf-burger .bar.bot { top: 16px; }
}

.pf-burger.is-open .bar.top { transform: translateY(6px) rotate(45deg); }
.pf-burger.is-open .bar.bot { transform: translateY(-6px) rotate(-45deg); }
.pf-burger.is-open .bar.mid {
  transform: translateX(10px);
  opacity: 0;
  width: 0;
  left: 50%;
}

@media (max-width:1023px) {
  .pf-sdv-actions .pf-sdv-btn { display: none; }
  .pf-sdv-toggle { display: inline-flex; }
  .pf-sdv-brand { margin-left: calc(var(--brand-left-nudge) - 10px); }
}

@media (min-width:1024px) {
  .pf-sdv-menu--desktop { display: flex; }
  .pf-sdv-toggle { display: none; }
}

/* ===== Mobile (Android): remove blue tap highlight on header elements ===== */
@media (hover: none) and (pointer: coarse) and (max-width: 1023px) {
  /* Android highlights the exact tapped node (often a span/svg inside a link),
     so we disable tap highlight for all descendants of the header + menus. */
  #pf-sdv-header,
  #pf-sdv-header *,
  #pf-sdv-mobile,
  #pf-sdv-mobile *,
  #pf-sdv-svc-dd,
  #pf-sdv-svc-dd * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #pf-sdv-header a:focus,
  #pf-sdv-header button:focus,
  #pf-sdv-mobile a:focus,
  #pf-sdv-mobile button:focus,
  #pf-sdv-svc-dd a:focus {
    outline: none !important;
    box-shadow: none !important;
  }

  #pf-sdv-header *:focus-visible,
  #pf-sdv-mobile *:focus-visible,
  #pf-sdv-svc-dd *:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  /* Alcuni UA applicano un background di "active/focus" (sembra un rettangolo blu) */
  #pf-sdv-header a:active,
  #pf-sdv-header button:active,
  #pf-sdv-mobile a:active,
  #pf-sdv-mobile button:active,
  #pf-sdv-svc-dd a:active {
    background: transparent !important;
  }

  /* Evita l'highlight di "text selection" su tap */
  #pf-sdv-header ::selection,
  #pf-sdv-mobile ::selection,
  #pf-sdv-svc-dd ::selection {
    background: transparent;
  }
}

#pf-sdv-mobile {
  position: fixed;
  inset: auto auto 0 0;
  top: 0;
  width: var(--drawer-w);
  padding: calc(var(--pf-sdv-header-h)) 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: #0b0b0b;
  color: var(--pf-sdv-white);
  border-right: 1px solid rgba(255, 255, 255, .24);
  transform: translateX(-100%);
  transition: transform .28s cubic-bezier(.22, .61, .36, 1);
  z-index: 9998;
  overflow: auto;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

#pf-sdv-mobile.is-open { transform: translateX(0); }

#pf-sdv-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .5);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 9997;
}

#pf-sdv-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

html.pf-mobile-open,
body.pf-mobile-open { overflow: hidden; }

.pf-drawer-head {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  height: 54px;
  margin: 0 0 8px 0;
}

.pf-drawer-logo {
  width: 168px;
  height: 66px;
  aspect-ratio: 168/66;
  display: inline-block;
  color: #fff;
  background-color: currentColor;
  -webkit-mask: var(--logo-src) left top / contain no-repeat;
  mask: var(--logo-src) left top / contain no-repeat;
  margin-top: -6px;
  margin-left: -4px;
  image-rendering: -webkit-optimize-contrast;
  transform: translateZ(0);
}

@media (max-width:1023px) {
  #pf-sdv-mobile .pf-drawer-logo { margin-top: -21px; }
}

#pf-sdv-mobile .pf-sdv-link {
  display: block;
  padding: 12px 0;
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .2px;
  font-size: var(--fs-base);
}

#pf-sdv-mobile .size-home { font-size: var(--fs-home); }
#pf-sdv-mobile .size-vendita { font-size: var(--fs-vendita); }
#pf-sdv-mobile .size-noleggio { font-size: var(--fs-noleggio); }

#pf-sdv-mobile .pf-mobile-svc-toggle {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 12px 0;
  margin: 0;
  color: #fff;
  font-weight: 800;
  letter-spacing: .2px;
  cursor: pointer;
  text-align: left;
  font-size: var(--fs-vendita);
  display: flex;
  align-items: center;
  gap: 10px;
}

#pf-sdv-mobile .pf-mobile-caret { transition: transform .18s ease; }
#pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret { transform: rotate(180deg); }

#pf-sdv-mobile .pf-sdv-submenu {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-left: 6px;
}

#pf-sdv-mobile .pf-sdv-submenu[hidden] { display: none !important; }

#pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
  font-size: var(--fs-home);
  font-weight: 800;
  letter-spacing: .2px;
  color: rgba(255, 255, 255, .88);
  position: relative;
  padding: 12px 0 12px 14px;
}

#pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
  content: "-";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(255, 255, 255, .88);
}

#pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover { color: rgba(255, 255, 255, .96); }

#pf-sdv-mobile .pf-cta-wrap {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, .14);
  padding-bottom: max(16px, env(safe-area-inset-bottom));
}

#pf-sdv-mobile .pf-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  line-height: 1;
  width: 100%;
}

#pf-sdv-mobile .pf-cta--outline {
  border: 1.6px solid #fff;
  color: #fff;
  background: transparent;
}

#pf-sdv-mobile .pf-cta--outline:hover { background: rgba(255, 255, 255, .08); }

#pf-sdv-mobile .pf-cta--white {
  background: #fff;
  color: #D40000;
  border: 1.6px solid #fff;
}

#pf-sdv-mobile .pf-cta--white:hover { filter: brightness(.96); }

@media (min-width:1024px) {
  #pf-sdv-mobile,
  #pf-sdv-backdrop { display: none !important; }
}

#pf-sdv-header .pf-sdv-btn--primary { color: #D40000 !important; }

#pf-sdv-header .pf-sdv-btn--primary svg {
  color: inherit;
  fill: currentColor;
  stroke: currentColor;
}

#pf-sdv-header .pf-sdv-btn--primary:hover { color: #B80000 !important; }

@supports (-webkit-touch-callout: none) {
  .pf-sdv-logo-mask {
    width: 120px;
    height: 44px;
    aspect-ratio: 120/44 !important;
    -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
    mask: var(--logo-src) 50% 50% / contain no-repeat !important;
  }

  #pf-sdv-mobile .pf-drawer-logo {
    width: 150px;
    height: 60px;
    aspect-ratio: 150/60 !important;
    -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
    mask: var(--logo-src) left top / contain no-repeat !important;
  }
}


/* === site-shell.css === */
/* Header/Footer shell styles extracted from catalog pages */
:root {
  --pf-sdv-orange: #D40000;
  --pf-sdv-white: #fff;
  --pf-sdv-header-h: 76px;
  --drawer-w: min(74vw, 380px);
  --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');
  --fs-base: clamp(19px, 4vw, 22px);
  --brand-left-nudge: -6px;
}

body {
  padding-top: var(--pf-sdv-header-h);
}

#pf-sdv-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 60;
  background: #0b0b0b;
  color: var(--pf-sdv-white);
  transition: box-shadow .2s ease, background .2s ease;
  backdrop-filter: saturate(160%) blur(10px);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

#pf-sdv-header.pf-sdv--scrolled {
  box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
}

.pf-sdv-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.pf-sdv-container,
.pf-sdv-menu--desktop {
  overflow: visible;
}

.pf-sdv-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  height: var(--pf-sdv-header-h);
  overflow: visible;
}

.pf-sdv-dropdown { position: relative; overflow: visible; }

.pf-sdv-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
  white-space: nowrap;
  margin-left: var(--brand-left-nudge);
  line-height: 0;
}

.pf-sdv-logo-mask {
  width: 120px;
  height: 44px;
  aspect-ratio: 120/44;
  display: inline-block;
  color: #fff;
  background-color: currentColor;
  -webkit-mask: var(--logo-src) center / contain no-repeat;
  mask: var(--logo-src) center / contain no-repeat;
  image-rendering: -webkit-optimize-contrast;
  will-change: -webkit-mask-position, mask-position;
  transform: translateZ(0);
}

.pf-sdv-menu--desktop {
  display: none;
  align-items: center;
  gap: 26px;
  overflow: visible;
}

.pf-sdv-link,
.pf-sdv-dropdown__btn {
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  letter-spacing: .2px;
  color: var(--pf-sdv-white);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.pf-sdv-link:hover,
.pf-sdv-dropdown__btn:hover {
  opacity: .9;
}

.pf-sdv-navItem--services { position: relative; }

.pf-sdv-dropdown__btn {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.pf-sdv-caret {
  transition: transform .15s ease;
}

.pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
  transform: rotate(180deg);
}

.pf-sdv-inline-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  display: inline-flex;
  width: max-content;
  gap: 18px;
  padding: 12px 16px;
  z-index: 9999;
  background: #0e0e0f;
  color: var(--pf-sdv-white);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  box-shadow: 0 20px 50px rgba(0,0,0,.45);
  white-space: nowrap;
}

.pf-sdv-inline-dropdown[hidden] {
  display: none !important;
}

.pf-sdv-inline-dropdown__row {
  display: flex;
  align-items: center;
  gap: 28px;
}

.pf-sdv-inline-dropdown a {
  color: var(--pf-sdv-white);
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
}

.pf-sdv-inline-dropdown a:hover {
  text-decoration: underline;
}

.pf-sdv-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pf-sdv-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid var(--pf-sdv-white);
  color: var(--pf-sdv-white);
  background: transparent;
}

.pf-sdv-btn--primary {
  background: var(--pf-sdv-white);
  color: var(--pf-sdv-orange);
  border-color: var(--pf-sdv-white);
}

.pf-sdv-toggle {
  border: 0;
  background: transparent;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.pf-burger {
  position: relative;
  width: 26px;
  height: 26px;
}

.pf-burger .bar {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--pf-sdv-white);
  border-radius: 10px;
  transition: transform .2s ease, opacity .2s ease;
}

.pf-burger .top { top: 6px; }
.pf-burger .mid { top: 12px; }
.pf-burger .bot { top: 18px; }

.pf-sdv-toggle[aria-expanded="true"] .top { transform: translateY(6px) rotate(45deg); }
.pf-sdv-toggle[aria-expanded="true"] .mid { opacity: 0; }
.pf-sdv-toggle[aria-expanded="true"] .bot { transform: translateY(-6px) rotate(-45deg); }

#pf-sdv-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .5);
  z-index: 58;
  display: none;
}

#pf-sdv-backdrop.is-open {
  display: block;
}

#services-menu {
  width: auto;
}

#pf-sdv-mobile {
  position: fixed;
  inset: 0 0 auto auto;
  width: var(--drawer-w);
  max-width: 420px;
  background: #0b0b0b;
  color: var(--pf-sdv-white);
  padding: calc(var(--pf-sdv-header-h)) 18px 16px;
  transform: translateX(100%);
  transition: transform .25s ease;
  z-index: 59;
}

#pf-sdv-mobile.is-open {
  transform: translateX(0);
}

#pf-sdv-mobile .pf-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

#pf-sdv-mobile .pf-drawer-logo {
  width: 140px;
  height: 52px;
  aspect-ratio: 120/44;
  background: currentColor;
  -webkit-mask: var(--logo-src) center / contain no-repeat;
  mask: var(--logo-src) center / contain no-repeat;
}

#pf-sdv-mobile .pf-drawer-close {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--pf-sdv-white);
  width: 26px;
  height: 26px;
}

#pf-sdv-mobile .pf-sdv-link {
  display: block;
  color: var(--pf-sdv-white);
  text-decoration: none;
  font-weight: 700;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.14);
}

#pf-sdv-mobile .pf-sdv-submenu {
  padding: 8px 0 0 10px;
}

#pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
  border: 0;
  padding: 8px 0;
  font-weight: 600;
}

#pf-sdv-mobile .pf-cta-wrap {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

#pf-sdv-mobile .pf-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 700;
  text-decoration: none;
}

#pf-sdv-mobile .pf-cta--outline {
  border: 1px solid var(--pf-sdv-white);
  color: var(--pf-sdv-white);
}

#pf-sdv-mobile .pf-cta--white {
  background: var(--pf-sdv-white);
  color: var(--pf-sdv-orange);
  border: 1px solid var(--pf-sdv-white);
}

@media (min-width: 960px) {
  .pf-sdv-menu--desktop { display: flex; }
  .pf-sdv-toggle { display: none; }
  #pf-sdv-mobile,
  #pf-sdv-backdrop { display: none !important; }
}

/* Footer */
#af-footer {
  background: #0b0b0b;
  color: #fff;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

#af-footer .af-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 18px 28px;
}

#af-footer a {
  color: #fff;
  text-decoration: none;
}

#af-footer a:hover {
  text-decoration: underline;
}

#af-footer .af-top {
  margin-bottom: 28px;
}

#af-footer .af-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

@media (max-width: 900px) {
  #af-footer .af-grid {
    grid-template-columns: 1fr;
  }
}

#af-footer .af-section h4 {
  font-size: 18px;
  margin-bottom: 10px;
}

#af-footer .af-logo {
  font-size: 26px;
  font-weight: 800;
  margin-bottom: 8px;
}

#af-footer .af-logo .accent {
  color: var(--pf-sdv-orange);
}

#af-footer .af-desc {
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 12px;
}

#af-footer .af-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

#af-footer .af-row {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: start;
  gap: 10px;
  font-size: 15px;
}

#af-footer .af-icon {
  width: 20px;
  height: 20px;
  color: var(--pf-sdv-orange);
}

#af-footer .social-list {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  list-style: none;
  padding: 0;
  margin-left: 0;
}

#af-footer .social-list a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: auto;
  height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
}

#af-footer .social-list svg {
  width: 18px;
  height: 18px;
}

#af-footer .af-bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 18px;
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

#af-footer .af-legal {
  display: flex;
  gap: 14px;
}

html[dir="rtl"] #af-footer a.af-phone,
html[dir="rtl"] .where-section a[href^="tel:"]:not(.btn):not(.pf-sdv-btn):not(.pf-cta) {
  direction: ltr;
  unicode-bidi: embed;
  display: inline-block;
  position: relative;
  padding-bottom: 10px;
}

html[dir="rtl"] #af-footer a.af-phone::after,
html[dir="rtl"] .where-section a[href^="tel:"]:not(.btn):not(.pf-sdv-btn):not(.pf-cta)::after {
  content: "→";
  position: absolute;
  left: 0;
  bottom: 0;
  font-size: 11px;
  line-height: 1;
  opacity: 0.35;
  color: rgba(255, 255, 255, 0.75);
  pointer-events: none;
}

/* Newsletter bar */
#af-footer .af-newsbar {
  margin: 32px 0 10px;
  padding: 18px 16px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.04);
}
#af-footer .af-newsbar .nb-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
  gap: 18px;
}
@media (max-width: 900px) {
  #af-footer .af-newsbar .nb-grid { grid-template-columns: 1fr; }
}
#af-footer .af-newsbar .nb-title { font-size: 18px; font-weight: 800; margin: 0 0 6px; }
#af-footer .af-newsbar .nb-sub { margin: 0; opacity: .85; }
#af-footer .af-newsbar .nb-form { display: flex; gap: 10px; flex-wrap: wrap; }
#af-footer .af-newsbar .nb-input {
  flex: 1;
  min-width: 220px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.25);
  color: #fff;
}
#af-footer .af-newsbar .nb-input::placeholder { color: rgba(255,255,255,.7); }
#af-footer .af-newsbar .nb-btn {
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid var(--pf-sdv-orange);
  background: var(--pf-sdv-orange);
  color: #0b0b0b;
  font-weight: 700;
  cursor: pointer;
}
#af-footer .af-newsbar .nb-btn:hover { opacity: .9; }
#af-footer .af-newsbar .nb-btn:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
#af-footer .af-note { display: block; margin-top: 6px; font-size: 13px; opacity: .8; }

#af-footer .af-bottom .wrap { display: flex; gap: 14px; flex-wrap: wrap; }


/* === pages/catalogo-noleggio.css === */
﻿/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 86px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1320px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 136px;
      height: 50px;
      aspect-ratio: 136/50;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
:root {
      --accent: var(--pf-buy-blue, #6ecbff);
      /* azzurro del titolo */
      --bg: #0e0e0f;
      --panel: #18181a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .85);
      --line: rgba(255, 255, 255, .14);
      --chip: #26262a;
      /* grigio chip dei filtri */
      --radius: 16px;
      --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);

      /* MenÃ¹ Marca: grigio un pelo piÃ¹ chiaro del chip */
      --menu-bg: #2b2c30;
      /* fallback se color-mix non c'Ã¨ */
    }

    /* Progressive enhancement: schiarisco il chip di ~8% */
    @supports (background: color-mix(in srgb, #000 50%, #fff 50%)) {
      :root {
        --menu-bg: color-mix(in srgb, #fff 8%, var(--chip));
      }
    }

    .scf {
      background: radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%), linear-gradient(180deg, #202020, #111);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 56px 0 54px;
    }

    .scf-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow: visible;
    }

    @media (min-width:1280px) {
      .scf-container {
        max-width: 1320px;
      }
    }

    /* Header */
    .scf-head {
      text-align: center;
      margin-bottom: 18px;
    }

    .scf-head h2 {
      margin: 0 0 6px;
      font-weight: 800;
      letter-spacing: -.02em;
      font-size: clamp(28px, 4vw, 44px);
    }

    .scf-head .accent {
      color: var(--accent);
    }

    .scf-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* ======= MOBILE: stessa tipografia del HERO ======= */
    @media (max-width:639px) {
      .scf-head h2 {
        font-size: clamp(2.5rem, 6vw, 4.5rem);
        line-height: 1.05;
        letter-spacing: -.02em;
      }

      .scf-head p {
        font-size: clamp(.95rem, 3.6vw, 1.2rem);
        line-height: 1.35;
      }
    }

    /* Toolbar */
    .scf-toolbar {
      display: grid;
      gap: 12px;
    }

    .scf-row--search {
      display: flex;
      justify-content: center;
    }

    .scf-row--filters {
      display: grid;
      grid-template-columns: 1fr;
      gap: 10px;
      align-items: center;
    }

    .scf-row--reset {
      display: flex;
      justify-content: center;
    }

    /* Search */
    .scf-search {
      max-width: 520px;
      width: 100%;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 8px;
      align-items: center;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: 999px;
      padding: 8px 8px 8px 12px;
      box-shadow: inset 0 8px 18px -12px rgba(0, 0, 0, .5);
    }

    .scf-search input {
      border: 0;
      outline: 0;
      background: transparent;
      color: #fff;
      font-weight: 700;
      letter-spacing: .2px;
      font-size: 13px;
      line-height: 1.2;
    }

    .scf-search input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    .scf-qclear {
      display: grid;
      place-items: center;
      width: 28px;
      height: 28px;
      background: transparent;
      border: 0;
      color: rgba(255, 255, 255, .6);
      font-size: 16px;
      cursor: pointer;
    }

    .scf-qclear:hover {
      color: rgba(255, 255, 255, .85);
    }

    /* Filtri */
    .scf-bar {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
      row-gap: 8px;
      overflow: visible;
    }

    @media (min-width:1100px) {
      .scf-bar {
        flex-wrap: nowrap;
      }
    }

    .scf-chip {
      position: relative;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 10px;
      border-radius: 999px;
      background: var(--chip);
      border: 1px solid var(--line);
      font-weight: 800;
      font-size: 12px;
      color: #fff;
      white-space: nowrap;
    }

    .scf-chip .lab {
      opacity: .9;
      font-weight: 700;
    }

    .scf-chip .sep {
      opacity: .35;
    }

    .scf-chip input[type="range"] {
      accent-color: var(--accent);
    }

    .scf-chip select,
    .scf-chip input[type="number"],
    .scf-chip input[type="range"] {
      background: transparent;
      color: #fff;
      border: 0;
      outline: 0;
      font: inherit;
      height: 28px;
    }

    .scf-chip select {
      font-size: 12px;
    }

    .scf-chip select option {
      color: #000;
    }

    .scf-chip input[type="number"] {
      width: 110px;
      text-align: center;
      font-size: 12px;
    }

    .scf-chip .rangewrap {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    /* Slider widths */
    .scf-chip input[type="range"] {
      width: 160px;
    }

    @media(min-width:640px) {
      .scf-chip input[type="range"] {
        width: 180px;
      }
    }

    @media(min-width:1100px) {
      .scf-chip input[type="range"] {
        width: 150px;
      }
    }

    @media(min-width:1400px) {
      .scf-chip input[type="range"] {
        width: 170px;
      }
    }

    /* Badge min widths */
    #scf-year-badge {
      display: inline-block;
      min-width: 64px;
      text-align: left;
    }

    #scf-price-badge {
      display: inline-block;
      min-width: 120px;
      text-align: left;
    }

    #scf-km-badge {
      display: inline-block;
      min-width: 90px;
      text-align: left;
    }

    /* Reset */
    #scf-reset {
      height: 34px;
      padding: 0 14px;
      font-size: 12px;
      font-weight: 900;
      background: rgba(255, 255, 255, .88);
      color: #0b0b0b;
      border: 1px solid rgba(255, 255, 255, .88);
      border-radius: 9999px;
      cursor: pointer;
      transition: background .15s ease, border-color .15s ease;
    }

    #scf-reset:hover {
      background: #fff;
      border-color: #fff;
    }

    /* Trigger brand (chip) */
    .scf-select {
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }

    #scf-brand-btn {
      background: transparent;
      color: #fff;
      border: 0;
      font: inherit;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      height: 28px;
      padding: 0 4px;
    }

    #scf-brand-btn .caret {
      width: 14px;
      height: 14px;
      transition: transform .15s ease;
    }

    #scf-brand-btn[aria-expanded="true"] .caret {
      transform: rotate(180deg);
    }

    /* ===== MENU MARCA: grigio piÃ¹ chiaro del chip + azzurro del titolo ===== */
    .scf-menu {
      position: absolute;
      top: calc(100% + 8px);
      left: 0;
      min-width: 200px;
      max-height: 260px;
      overflow: auto;
      background: var(--menu-bg);
      color: var(--accent);
      border-radius: 12px;
      box-shadow: 0 14px 36px rgba(0, 0, 0, .35);
      border: 1px solid var(--accent);
      z-index: 50;
      padding: 6px;
    }

    .scf-option {
      display: block;
      width: 100%;
      text-align: left;
      cursor: pointer;
      background: var(--menu-bg);
      color: var(--accent);
      font: inherit;
      padding: 10px 10px;
      border-radius: 10px;
      border: 2px solid transparent;
    }

    /* hover: appena piÃ¹ chiaro del menu */
    .scf-option:hover {
      background: var(--menu-bg);
    }

    @supports (background: color-mix(in srgb, #000 50%, #fff 50%)) {
      .scf-option:hover {
        background: color-mix(in srgb, #fff 6%, var(--menu-bg));
      }
    }

    /* selezionata: SOLO bordo azzurro, sfondo come il menu */
    .scf-option[aria-selected="true"] {
      background: var(--menu-bg);
      border-color: var(--accent);
    }

    .scf-option:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }

    /* ===== MOBILE TWEAK: accorcia leggermente i filtri senza toccare i font ===== */
    @media (max-width:639px) {
      .scf-bar {
        gap: 6px;
        row-gap: 6px;
      }

      .scf-chip {
        padding: 7px 9px;
      }

      .scf-chip .rangewrap {
        gap: 5px;
        flex: 1 1 auto;
        min-width: 0;
      }

      .scf-chip input[type="range"] {
        width: min(136px, 42vw);
      }

      #scf-year-badge {
        min-width: 56px;
      }

      #scf-price-badge {
        min-width: 104px;
      }

      #scf-km-badge {
        min-width: 80px;
      }
    }

/* ================= SEZIONE 2 ================= */
:root {
      --accent: var(--pf-buy-blue, #6ecbff);
      --bg: #0e0e0f;
      --panel: #18181a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .85);
      --line: rgba(255, 255, 255, .14);
      --chip: #26262a;
      --radius: 18px;
      --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
    }

    .sc-catalog {
      background: radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%), linear-gradient(180deg, #202020, #111111);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 40px 0 64px;
      /* padding top aumentato */
    }

    .sc-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    /* Summary */
    .sc-summary {
      margin: 10px 0 0;
      font-size: 14px;
      color: var(--muted);
    }

    .sc-summary strong {
      color: #fff;
    }

    /* Desktop: nasconde titolo/sottotitolo del catalogo (su mobile resta invariato) */
    @media (min-width: 1024px) {
      #sc-catalog-noleggio .sdv-title,
      #sc-catalog-noleggio .sdv-sub {
        display: none;
      }

      #sc-catalog-noleggio .sc-summary {
        margin-top: 0;
      }

      #sc-catalog-noleggio .sc-grid {
        margin-top: 0;
      }
    }

    /* Grid */
    .sc-grid {
      margin-top: 18px;
      display: grid;
      gap: 20px;
      grid-template-columns: 1fr;
    }

    @media(min-width:640px) {
      .sc-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media(min-width:1024px) {
      .sc-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    .sc-card {
      position: relative;
      background: #1e1e1f;
      border: 1px solid rgba(255, 255, 255, .08);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    .sc-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
      border-color: rgba(255, 255, 255, .16);
    }

    .sc-card .pic {
      display: block;
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      background: #0b0b0b;
    }

    .sc-card .body {
      padding: 14px;
    }

    .sc-tags {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      margin-bottom: 8px;
    }

    .sc-tag {
      padding: 6px 10px;
      border-radius: 999px;
      background: var(--chip);
      font-size: 12px;
      font-weight: 800;
      color: #ededed;
    }

    .sc-title {
      margin: 0 0 6px;
      font-weight: 900;
      font-size: 18px;
    }

    .sc-specs {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      color: var(--muted);
      font-weight: 700;
      font-size: 12px;
    }

    .sc-specs .dot {
      opacity: .35;
    }

    .sc-price {
      margin: 10px 0 12px;
      font-size: 14px;
      color: #e9e9e9;
    }

    .sc-price strong {
      font-size: 22px;
      font-weight: 800;
      color: #fff;
    }

    .sc-price__unit {
      color: var(--muted);
      font-weight: 800;
      font-size: 13px;
      white-space: nowrap;
    }

    /* Make whole card clickable (used by catalogo noleggio simplified cards) */
    .sc-cardLink {
      display: block;
      color: inherit;
      text-decoration: none;
    }

    .sc-cardLink.is-disabled {
      cursor: default;
      opacity: 0.75;
    }

    .sc-actions {
      display: flex;
      gap: 10px;
    }

    /* Bottone base (usato da Dettagli & Richiedi info) */
    .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      height: 40px;
      padding: 0 14px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #222;
      color: #fff;
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      transition: transform .05s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
      line-height: 1;
      box-sizing: border-box;
      text-decoration: none;
    }

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

    /* Variante “Dettagli” (ghost scura) */
    .sc-ghost {
      background: #2a2a2a;
      color: #fff;
      border: 2px solid rgba(255, 255, 255, .25);
    }

    /* Variante “Prenota” (bianco con testo rosso) */
    .sc-cta {
      background: #fff;
      color: #D40000;
      border: 2px solid #D40000;
      box-shadow: 0 10px 18px -12px rgba(0, 0, 0, .8);
      font-weight: 900;
    }

    .sc-cta:hover {
      filter: brightness(.97);
    }

    .sc-cta:active {
      transform: translateY(1px);
    }

    .sc-more-wrap {
      text-align: center;
      margin-top: 20px;
    }

    .sc-empty {
      text-align: center;
      background: var(--panel);
      border: 1px dashed var(--line);
      border-radius: var(--radius);
      padding: 24px;
      color: var(--muted);
      font-weight: 700;
    }

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

    /* Bottom */
    #af-footer .af-bottom {
      border-top: 0;
      padding: 18px 0;
      margin-top: 0;
    }

    #af-footer .af-bottom .wrap {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
    }

    @media (min-width:768px) {
      #af-footer .af-bottom .wrap {
        flex-direction: row;
      }
    }

    #af-footer .af-copy {
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-legal {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    #af-footer .af-legal a {
      font-size: 14px;
    }


/* === pages/catalogo-vendita.css === */
/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 86px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1320px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 136px;
      height: 50px;
      aspect-ratio: 136/50;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
:root {
      --accent: var(--pf-buy-blue, #6ecbff);
      /* azzurro del titolo */
      --bg: #0e0e0f;
      --panel: #18181a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .85);
      --line: rgba(255, 255, 255, .14);
      --chip: #26262a;
      /* grigio chip dei filtri */
      --radius: 16px;
      --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);

      /* Menù Marca: grigio un pelo più chiaro del chip */
      --menu-bg: #2b2c30;
      /* fallback se color-mix non c'è */
    }

    /* Progressive enhancement: schiarisco il chip di ~8% */
    @supports (background: color-mix(in srgb, #000 50%, #fff 50%)) {
      :root {
        --menu-bg: color-mix(in srgb, #fff 8%, var(--chip));
      }
    }

    .scf {
      background: radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%), linear-gradient(180deg, #202020, #111);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 56px 0 54px;
    }

    .scf-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow: visible;
    }

    @media (min-width:1280px) {
      .scf-container {
        max-width: 1320px;
      }
    }

    /* Header */
    .scf-head {
      text-align: center;
      margin-bottom: 18px;
    }

    .scf-head h2 {
      margin: 0 0 6px;
      font-weight: 800;
      letter-spacing: -.02em;
      font-size: clamp(28px, 4vw, 44px);
    }

    .scf-head .accent {
      color: var(--accent);
    }

    .scf-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* ======= MOBILE: stessa tipografia del HERO ======= */
    @media (max-width:639px) {
      .scf-head h2 {
        font-size: clamp(2.5rem, 6vw, 4.5rem);
        line-height: 1.05;
        letter-spacing: -.02em;
      }

      .scf-head p {
        font-size: clamp(.95rem, 3.6vw, 1.2rem);
        line-height: 1.35;
      }
    }

    /* Toolbar */
    .scf-toolbar {
      display: grid;
      gap: 12px;
    }

    .scf-row--search {
      display: flex;
      justify-content: center;
    }

    .scf-row--filters {
      display: grid;
      grid-template-columns: 1fr;
      gap: 10px;
      align-items: center;
    }

    .scf-row--reset {
      display: flex;
      justify-content: center;
    }

    /* Search */
    .scf-search {
      max-width: 520px;
      width: 100%;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 8px;
      align-items: center;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: 999px;
      padding: 8px 8px 8px 12px;
      box-shadow: inset 0 8px 18px -12px rgba(0, 0, 0, .5);
    }

    .scf-search input {
      border: 0;
      outline: 0;
      background: transparent;
      color: #fff;
      font-weight: 700;
      letter-spacing: .2px;
      font-size: 13px;
      line-height: 1.2;
    }

    .scf-search input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    .scf-qclear {
      display: grid;
      place-items: center;
      width: 28px;
      height: 28px;
      background: transparent;
      border: 0;
      color: rgba(255, 255, 255, .6);
      font-size: 16px;
      cursor: pointer;
    }

    .scf-qclear:hover {
      color: rgba(255, 255, 255, .85);
    }

    /* Filtri */
    .scf-bar {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-wrap: wrap;
      row-gap: 8px;
      overflow: visible;
    }

    @media (min-width:1100px) {
      .scf-bar {
        flex-wrap: nowrap;
      }
    }

    .scf-chip {
      position: relative;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 10px;
      border-radius: 999px;
      background: var(--chip);
      border: 1px solid var(--line);
      font-weight: 800;
      font-size: 12px;
      color: #fff;
      white-space: nowrap;
    }

    .scf-chip .lab {
      opacity: .9;
      font-weight: 700;
    }

    .scf-chip .sep {
      opacity: .35;
    }

    .scf-chip input[type="range"] {
      accent-color: var(--accent);
    }

    .scf-chip select,
    .scf-chip input[type="number"],
    .scf-chip input[type="range"] {
      background: transparent;
      color: #fff;
      border: 0;
      outline: 0;
      font: inherit;
      height: 28px;
    }

    .scf-chip select {
      font-size: 12px;
    }

    .scf-chip select option {
      color: #000;
    }

    .scf-chip input[type="number"] {
      width: 110px;
      text-align: center;
      font-size: 12px;
    }

    .scf-chip .rangewrap {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    /* Slider widths */
    .scf-chip input[type="range"] {
      width: 160px;
    }

    @media(min-width:640px) {
      .scf-chip input[type="range"] {
        width: 180px;
      }
    }

    @media(min-width:1100px) {
      .scf-chip input[type="range"] {
        width: 150px;
      }
    }

    @media(min-width:1400px) {
      .scf-chip input[type="range"] {
        width: 170px;
      }
    }

    /* Badge min widths */
    #scf-year-badge {
      display: inline-block;
      min-width: 64px;
      text-align: left;
    }

    #scf-price-badge {
      display: inline-block;
      min-width: 120px;
      text-align: left;
    }

    #scf-km-badge {
      display: inline-block;
      min-width: 90px;
      text-align: left;
    }

    /* Reset */
    #scf-reset {
      height: 34px;
      padding: 0 14px;
      font-size: 12px;
      font-weight: 900;
      background: rgba(255, 255, 255, .88);
      color: #0b0b0b;
      border: 1px solid rgba(255, 255, 255, .88);
      border-radius: 9999px;
      cursor: pointer;
      transition: background .15s ease, border-color .15s ease;
    }

    #scf-reset:hover {
      background: #fff;
      border-color: #fff;
    }

    /* Trigger brand (chip) */
    .scf-select {
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }

    #scf-brand-btn {
      background: transparent;
      color: #fff;
      border: 0;
      font: inherit;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      height: 28px;
      padding: 0 4px;
    }

    #scf-brand-btn .caret {
      width: 14px;
      height: 14px;
      transition: transform .15s ease;
    }

    #scf-brand-btn[aria-expanded="true"] .caret {
      transform: rotate(180deg);
    }

    /* ===== MENU MARCA: grigio più chiaro del chip + azzurro del titolo ===== */
    .scf-menu {
      position: absolute;
      top: calc(100% + 8px);
      left: 0;
      min-width: 200px;
      max-height: 260px;
      overflow: auto;
      background: var(--menu-bg);
      color: var(--accent);
      border-radius: 12px;
      box-shadow: 0 14px 36px rgba(0, 0, 0, .35);
      border: 1px solid var(--accent);
      z-index: 50;
      padding: 6px;
    }

    .scf-option {
      display: block;
      width: 100%;
      text-align: left;
      cursor: pointer;
      background: var(--menu-bg);
      color: var(--accent);
      font: inherit;
      padding: 10px 10px;
      border-radius: 10px;
      border: 2px solid transparent;
    }

    /* hover: appena più chiaro del menu */
    .scf-option:hover {
      background: var(--menu-bg);
    }

    @supports (background: color-mix(in srgb, #000 50%, #fff 50%)) {
      .scf-option:hover {
        background: color-mix(in srgb, #fff 6%, var(--menu-bg));
      }
    }

    /* selezionata: SOLO bordo azzurro, sfondo come il menu */
    .scf-option[aria-selected="true"] {
      background: var(--menu-bg);
      border-color: var(--accent);
    }

    .scf-option:focus-visible {
      outline: 2px solid var(--accent);
      outline-offset: 2px;
    }

    /* ===== MOBILE TWEAK: accorcia leggermente i filtri senza toccare i font ===== */
    @media (max-width:639px) {
      .scf-bar {
        gap: 6px;
        row-gap: 6px;
      }

      .scf-chip {
        padding: 7px 9px;
      }

      .scf-chip .rangewrap {
        gap: 5px;
        flex: 1 1 auto;
        min-width: 0;
      }

      .scf-chip input[type="range"] {
        width: min(136px, 42vw);
      }

      #scf-year-badge {
        min-width: 56px;
      }

      #scf-price-badge {
        min-width: 104px;
      }

      #scf-km-badge {
        min-width: 80px;
      }
    }

/* ================= SEZIONE 2 ================= */
:root {
      --accent: var(--pf-buy-blue, #6ecbff);
      --bg: #0e0e0f;
      --panel: #18181a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .85);
      --line: rgba(255, 255, 255, .14);
      --chip: #26262a;
      --radius: 18px;
      --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
    }

    .sc-catalog {
      background: radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%), linear-gradient(180deg, #202020, #111111);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 40px 0 64px;
      /* padding top aumentato */
    }

    .sc-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    /* Summary */
    .sc-summary {
      margin: 10px 0 0;
      font-size: 14px;
      color: var(--muted);
    }

    .sc-summary strong {
      color: #fff;
    }

    /* Desktop: nasconde titolo/sottotitolo del catalogo (su mobile resta invariato) */
    @media (min-width: 1024px) {
      #sc-catalog-vendita .sdv-title,
      #sc-catalog-vendita .sdv-sub {
        display: none;
      }

      #sc-catalog-vendita .sc-summary {
        margin-top: 0;
      }

      #sc-catalog-vendita .sc-grid {
        margin-top: 0;
      }
    }

    /* Grid */
    .sc-grid {
      margin-top: 18px;
      display: grid;
      gap: 20px;
      grid-template-columns: 1fr;
    }

    @media(min-width:640px) {
      .sc-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media(min-width:1024px) {
      .sc-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    .sc-card {
      position: relative;
      background: #1e1e1f;
      border: 1px solid rgba(255, 255, 255, .08);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    .sc-card:hover {
      transform: translateY(-2px);
      box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
      border-color: rgba(255, 255, 255, .16);
    }

    .sc-card .pic {
      display: block;
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      background: #0b0b0b;
    }

    .sc-card .body {
      padding: 14px;
    }

    .sc-tags {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      margin-bottom: 8px;
    }

    .sc-tag {
      padding: 6px 10px;
      border-radius: 999px;
      background: var(--chip);
      font-size: 12px;
      font-weight: 800;
      color: #ededed;
    }

    .sc-title {
      margin: 0 0 6px;
      font-weight: 900;
      font-size: 18px;
    }

    .sc-specs {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
      color: var(--muted);
      font-weight: 700;
      font-size: 12px;
    }

    .sc-specs .dot {
      opacity: .35;
    }

    .sc-price {
      margin: 10px 0 12px;
      font-size: 14px;
      color: #e9e9e9;
    }

    .sc-price strong {
      font-size: 22px;
      font-weight: 800;
      color: #fff;
    }

    .sc-actions {
      display: flex;
      gap: 10px;
    }

    /* === Bottoni: testo centrato verticalmente/orizzontalmente === */
    .sc-btn {
      display: inline-flex;
      /* ⬅️ centratura verticale */
      align-items: center;
      /* ⬅️ centratura verticale */
      justify-content: center;
      /* ⬅️ centratura orizzontale */
      height: 40px;
      padding: 0 14px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #222;
      color: #fff;
      font-weight: 800;
      font-size: 14px;
      line-height: 1;
      /* evita offset baselines */
      text-decoration: none;
      cursor: pointer;
    }

    .sc-ghost {
      background: #2a2a2a;
      color: #fff;
      border: 2px solid rgba(255, 255, 255, .25);
    }

    .sc-cta {
      background: var(--accent);
      color: #0b0b0b;
      border: 1px solid var(--accent);
      font-weight: 900;
    }

    .sc-cta:active {
      transform: translateY(1px);
    }

    .sc-more-wrap {
      text-align: center;
      margin-top: 20px;
    }

    .sc-empty {
      text-align: center;
      background: var(--panel);
      border: 1px dashed var(--line);
      border-radius: var(--radius);
      padding: 24px;
      color: var(--muted);
      font-weight: 700;
    }

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

    /* Bottom */
    #af-footer .af-bottom {
      border-top: 0;
      padding: 18px 0;
      margin-top: 0;
    }

    #af-footer .af-bottom .wrap {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
    }

    @media (min-width:768px) {
      #af-footer .af-bottom .wrap {
        flex-direction: row;
      }
    }

    #af-footer .af-copy {
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-legal {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    #af-footer .af-legal a {
      font-size: 14px;
    }


/* === pages/deposito.css === */
﻿/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 86px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1320px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 136px;
      height: 50px;
      aspect-ratio: 136/50;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
/* Accent locale alla sezione (non tocca il resto della pagina) */
  .sd-hero {
    --sd-accent: #D40000;
  }

  /* Anchor scroll (header fisso) */
  html { scroll-behavior: smooth; }
  #listino,
  #preventivo { scroll-margin-top: calc(var(--pf-sdv-header-h, 86px) + 12px); }

  /* Ferrari Red */

  /* ===== Base: DESKTOP invariato ===== */
  .sd-hero {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    /* desktop identico all'originale */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

.sd-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

.sd-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  background: #000;
}

  .sd-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, .70), rgba(0, 0, 0, .50), rgba(0, 0, 0, .70));
    pointer-events: none;
  }

  .sd-hero__content {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    padding-inline: 1rem;
    text-align: center;
  }

  .sd-hero__wrap {
    max-width: 64rem;
    margin: 0 auto;
  }

  /* Titoli */
  .sd-hero__title {
    margin: 0 0 .5em;
    color: #fff;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
  }

  .sd-hero__title .sd-primary {
    color: var(--sd-accent);
  }

  .sd-hero__subtitle {
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1.125rem, 2.2vw, 1.5rem);
    margin: 0 0 1.25rem;
    text-align: center;
  }

  .sd-hero__subtitle .sd-line {
    display: block;
    white-space: normal;
  }

  /* Azioni */
  .sd-hero__actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    padding-top: 1rem;
  }

  /* Mobile: niente rettangoli blu su tap dei bottoni hero (Android/iOS) */
  @media (max-width: 1023px) {
    .sd-hero__actions .sd-btn,
    .sd-hero__actions .sd-btn * {
      -webkit-tap-highlight-color: transparent !important;
    }

    .sd-hero__actions .sd-btn {
      -webkit-touch-callout: none;
      -webkit-user-select: none;
      user-select: none;
    }

    .sd-hero__actions .sd-btn:focus,
    .sd-hero__actions .sd-btn:focus-visible,
    .sd-hero__actions .sd-btn:active {
      outline: none !important;
      box-shadow: none !important;
    }
  }

  @media (min-width:640px) {
    .sd-hero__actions {
      flex-direction: row;
    }
  }

  .sd-btn {
    --_h: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 0 2rem;
    height: var(--_h);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 1.125rem;
    text-decoration: none;
    border: 2px solid transparent;
    transition: transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    line-height: 1;
    white-space: nowrap;
  }

  .sd-btn--primary {
    background: #fff;
    color: var(--sd-accent);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .2);
  }

  .sd-btn--primary::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .3), transparent);
    transform: translateX(-100%);
    transition: transform 1s;
  }

  .sd-btn--primary:hover::before {
    transform: translateX(100%);
  }

  .sd-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
  }

  .sd-btn--ghost {
    background: rgba(255, 255, 255, .10);
    color: #fff;
    border-color: rgba(255, 255, 255, .30);
    box-shadow: 0 6px 20px rgba(0, 0, 0, .15);
    backdrop-filter: saturate(1.2) blur(.5px);
  }

  .sd-btn--ghost:hover {
    background: rgba(255, 255, 255, .20);
    transform: translateY(-1px);
  }

  .sd-icon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }

  /* Scroll cue */
  .sd-scroll {
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 10;
  }

  .sd-scroll__mouse {
    width: 24px;
    height: 40px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, .5);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 8px;
  }

  .sd-scroll__dot {
    width: 4px;
    height: 12px;
    background: rgba(255, 255, 255, .7);
    border-radius: 999px;
    animation: sd-bounce 1s infinite alternate;
  }

  @keyframes sd-bounce {
    from {
      transform: translateY(0);
      opacity: 1;
    }

    to {
      transform: translateY(6px);
      opacity: .6;
    }
  }

  @media (prefers-reduced-motion:reduce) {

    .sd-btn,
    .sd-btn::before,
    .sd-scroll__dot {
      transition: none;
      animation: none;
    }

    .sd-hero__video {
      animation: none;
    }
  }

  /* Override anti-arancione */
  .sd-hero .sd-primary {
    color: #D40000 !important;
  }

  .sd-hero .sd-btn--primary {
    color: #D40000 !important;
  }

  .sd-hero .sd-btn--primary .sd-icon {
    stroke: currentColor;
    fill: none;
  }

  /* ===== SOLO MOBILE (â‰¤639px): variante tight ===== */
  @media (max-width:639px) {
      .sd-hero {
      min-height: 85svh;
      }

    /* base mobile */
    .sd-hero--tight {
      min-height: 96svh;
    }

    /* un filo piÃ¹ corta solo su mobile */
    .sd-hero--tight .sd-hero__wrap {
      transform: translateY(-7svh);
    }

    /* alza i contenuti solo su mobile */
    .sd-hero--tight .sd-hero__title {
      margin-bottom: .4em;
    }

    .sd-hero--tight .sd-hero__subtitle {
      margin-bottom: .9rem;
    }

    .sd-hero__subtitle {
      font-size: clamp(.95rem, 3.6vw, 1.2rem);
      line-height: 1.35;
      margin-bottom: .75rem;
    }

    .sd-hero__subtitle .sd-line {
      white-space: normal;
    }

    .sd-hero__actions {
      flex-direction: row;
      gap: .75rem;
      padding-top: .5rem;
    }

    .sd-hero__actions .sd-btn {
      flex: 1 1 0;
      min-width: 0;
      height: 3rem;
      font-size: 1.05rem;
      padding: 0 1.25rem;
    }

    .sd-scroll {
      bottom: 1rem;
    }
  }

/* ================= SEZIONE 2 ================= */
#sc-dep-pillars {
      --accent: #D40000;
      /* Ferrari Red */
      --bg1: #0c0c0d;
      --bg2: #141415;
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, var(--bg1), var(--bg2));
      isolation: isolate;
      padding: clamp(24px, 3.6vw, 48px) 0 clamp(28px, 3.8vw, 56px);
    }

/* Mobile: stesso respiro (top/bottom) di Lavaggio/Trasporto */
@media (max-width: 639px) {
  #sc-dep-pillars {
    padding: 60px 0;
  }
}

    #sc-dep-pillars .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
    }

    /* --- Head (titolo) --- */
    #sc-dep-pillars .pillars-head {
      text-align: center;
      margin: 0 0 18px;
    }

    #sc-dep-pillars .pillars-title {
      margin: 0;
      font-weight: 800;
      letter-spacing: -.02em;
      line-height: 1.05;
      font-size: clamp(1.75rem, 4.4vw, 2.5rem);
      color: #fff;
    }

    #sc-dep-pillars .pillars-title .accent {
      color: var(--accent);
    }

    /* --- Grid --- */
    #sc-dep-pillars .pillars {
      display: grid;
      gap: 14px;
      grid-template-columns: 1fr;
    }

    @media (min-width:720px) {
      #sc-dep-pillars .pillars {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    /* --- Card --- */
    #sc-dep-pillars .pillar {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: clamp(16px, 1.8vw, 22px);
      min-height: 156px;
      box-shadow: var(--shadow);
      text-decoration: none;
      color: inherit;
      transform: translateZ(0);
      transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    }

    /* alone ROSSO (fallback) */
    #sc-dep-pillars .pillar::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 2px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .70) 0%,
          rgba(212, 0, 0, .18) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.98);
      filter: blur(14px);
      opacity: .35;
      transition: opacity .2s ease, transform .2s ease, filter .2s ease;
      pointer-events: none;
    }

    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #sc-dep-pillars .pillar::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 70%, transparent) 0%,
            color-mix(in srgb, var(--accent) 18%, transparent) 45%,
            transparent 70%);
      }
    }

    /* hover/focus: espansione dellâ€™alone */
    #sc-dep-pillars .pillar:hover,
    #sc-dep-pillars .pillar:focus-visible {
      transform: translateY(-2px) scale(1.02);
      box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
      border-color: rgba(255, 255, 255, .16);
      outline: none;
    }

    #sc-dep-pillars .pillar:hover::before,
    #sc-dep-pillars .pillar:focus-visible::before {
      opacity: .7;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* Icona/heading/desc */
    #sc-dep-pillars .pill-ico {
      width: 44px;
      height: 44px;
      border-radius: 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #ffffff;
      /* â¬…ï¸ sfondo BIANCO */
      border: 1px solid #ffffff;
      /* â¬…ï¸ bordo bianco pulito */
      box-shadow: 0 4px 14px rgba(0, 0, 0, .22);
      /* leggera emersione sul pannello scuro */
      margin-bottom: 10px;
    }

    #sc-dep-pillars .pill-ico svg {
      width: 24px;
      height: 24px;
      color: var(--accent);
      /* â¬…ï¸ icone ROSSE */
      stroke: currentColor;
      fill: none;
    }

    #sc-dep-pillars h3 {
      margin: .1rem 0 .25rem;
      font-size: 1.15rem;
      font-weight: 900;
    }

    #sc-dep-pillars p {
      margin: 0;
      color: var(--muted);
    }

    @media (prefers-reduced-motion:reduce) {

      #sc-dep-pillars .pillar,
      #sc-dep-pillars .pillar::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 3 ================= */
#sc-dep-services {
      --accent: #D40000;
      /* Ferrari Red (solo colore, nessun cambio animazioni) */
      --bg1: #0c0c0d;
      --bg2: #141415;
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --chip: #25262a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, var(--bg1), var(--bg2));
      isolation: isolate;
      padding: 60px 0 60px;
    }

    #sc-dep-services .container {
      max-width: 1400px;
      margin: 0 auto;
      padding: 0 24px;
    }

    #sc-dep-services .sec-head {
      text-align: center;
      margin-bottom: 14px;
    }

    #sc-dep-services h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(2rem, 3.8vw, 2.6rem);
    }

    /* parola in ROSSO */
    #sc-dep-services .accent {
      color: var(--accent);
    }

    #sc-dep-services .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 700;
      font-size: 1rem;
    }

    #sc-dep-services .svc-grid {
      margin-top: 20px;
      display: grid;
      gap: 18px;
      grid-template-columns: repeat(auto-fit, minmax(clamp(0px, 100%, 360px), 1fr));
    }

    #sc-dep-services .svc-card {
      position: relative;
      /* per alone ::before */
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: 18px;
      overflow: hidden;
      box-shadow: var(--shadow);
      display: flex;
      flex-direction: column;
      max-width: 100%;
      box-sizing: border-box;
      transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, opacity .15s ease;
    }

    /* Alone ROSSO morbido (stesse animazioni, solo colore) */
    #sc-dep-services .svc-card::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 4px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .65) 0%,
          rgba(212, 0, 0, .16) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.985);
      filter: blur(14px);
      opacity: .28;
      transition: opacity .18s ease, transform .18s ease, filter .18s ease;
      pointer-events: none;
    }

    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #sc-dep-services .svc-card::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 65%, transparent) 0%,
            color-mix(in srgb, var(--accent) 16%, transparent) 45%,
            transparent 70%);
      }
    }

    #sc-dep-services .svc-card:hover,
    #sc-dep-services .svc-card:focus-within {
      transform: translateY(-1px) scale(1.01);
      border-color: rgba(255, 255, 255, .16);
      box-shadow: 0 18px 34px rgba(0, 0, 0, .36);
      outline: none;
    }

    #sc-dep-services .svc-card:hover::before,
    #sc-dep-services .svc-card:focus-within::before {
      opacity: .55;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

#sc-dep-services .svc-photo {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  height: auto;
}

/* Mobile: evita overflow orizzontale e allinea bene la griglia */
@media (max-width: 420px) {
  #sc-dep-services .container {
    padding: 0 16px;
  }
  #sc-dep-services .svc-grid {
    gap: 14px;
  }
}

    #sc-dep-services .svc-body {
      padding: 14px 16px 16px;
    }

    #sc-dep-services .svc-body h3 {
      margin: 0 0 .3rem;
      font-size: 1.2rem;
      font-weight: 900;
      letter-spacing: -.01em;
    }

    #sc-dep-services .svc-body p {
      margin: 0;
      color: rgba(255, 255, 255, .9);
      font-weight: 600;
      font-size: 1rem;
      line-height: 1.45;
    }

    #sc-dep-services .chip {
      display: inline-block;
      padding: 6px 12px;
      border-radius: 999px;
      background: #2c2d30;
      font-size: 12px;
      font-weight: 800;
      color: #ededed;
      margin-right: 8px;
      box-shadow: 0 6px 16px -10px rgba(0,0,0,.5);
      border: 1px solid rgba(255,255,255,.08);
    }

    /* Riduzione motion */
    @media (prefers-reduced-motion: reduce) {

      #sc-dep-services .svc-card,
      #sc-dep-services .svc-card::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 4 ================= */
#scd-process {
      --accent: #D40000;
      /* Ferrari Red */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #202124;
      --line: rgba(255, 255, 255, .14);
      --radius: 16px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      padding: 60px 0;
      isolation: isolate;
    }

    #scd-process .wrap {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip
    }

    /* Head */
    #scd-process .head {
      text-align: center;
      margin-bottom: 14px
    }

    #scd-process .head h2 {
      margin: 0 0 8px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.9rem, 3.8vw, 2.5rem);
      line-height: 1.08;
      color: #fff
    }

    /* parola â€œfunziona?â€ in ROSSO */
    #scd-process .head .accent {
      color: var(--accent);
    }

    #scd-process .head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600
    }

    /* Grid */
    #scd-process .timeline {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr
    }

    @media(min-width:900px) {
      #scd-process .timeline {
        grid-template-columns: repeat(4, 1fr)
      }
    }

    /* Card */
    #scd-process .step {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      transform: translateZ(0);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    /* alone ROSSO (solo colore, stesse animazioni) */
    #scd-process .step::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 4px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .65) 0%,
          rgba(212, 0, 0, .16) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.985);
      filter: blur(14px);
      opacity: .28;
      transition: opacity .18s ease, transform .18s ease, filter .18s ease;
      pointer-events: none;
    }

    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #scd-process .step::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 65%, transparent) 0%,
            color-mix(in srgb, var(--accent) 16%, transparent) 45%,
            transparent 70%);
      }
    }

    /* Hover/Focus */
    #scd-process .step:hover,
    #scd-process .step:focus-visible {
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 14px 30px rgba(0, 0, 0, .34);
      border-color: rgba(255, 255, 255, .16);
      outline: none;
    }

    #scd-process .step:hover::before,
    #scd-process .step:focus-visible::before {
      opacity: .55;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* Badge numeri: SFONDO BIANCO + NUMERO ROSSO */
    #scd-process .num {
      width: 32px;
      height: 32px;
      border-radius: 10px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #fff;
      /* sfondo bianco */
      color: var(--accent);
      /* numero rosso */
      font-weight: 900;
      margin-bottom: 10px;
    }

    #scd-process h3 {
      margin: .1rem 0 .35rem;
      font-weight: 900
    }

    #scd-process p {
      margin: 0;
      color: var(--muted)
    }

    /* Riduzione motion */
    @media (prefers-reduced-motion:reduce) {

      #scd-process .step,
      #scd-process .step::before {
        transition: none;
        transform: none;
        filter: none
      }
    }

/* ================= SEZIONE 5 ================= */
#listino.sc-dep-pricing {
      /* ACCENTO: Rosso Ferrari */
      --accent: #D40000;
      --bg1: #0c0c0d;
      --bg2: #141415;
      --panel: #1a1b1d;
      --panel2: #202124;
      --line: rgba(255, 255, 255, .14);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, var(--bg1), var(--bg2));
      isolation: isolate;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    #listino .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    /* Titolo */
    #listino .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    #listino h2 {
      margin: 0 0 8px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.9rem, 3.8vw, 2.5rem);
      line-height: 1.08;
    }

    #listino .sec-head .accent {
      color: var(--accent);
    }

    #listino .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* Grid */
    #listino .price-grid {
      display: grid;
      gap: 16px;
      grid-template-columns: 1fr;
      align-items: stretch;
    }

    @media (min-width:900px) {
      #listino .price-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    /* Card base */
    #listino .plan {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      text-align: center;
    }

    /* Bordo evidenziato ROSSO */
    #listino .plan--best {
      outline: 2px solid var(--accent);
      outline-offset: 0;
    }

    /* Badge: bianco con testo rosso */
    #listino .badge {
      align-self: center;
      margin: 10px 0 0 0;
      padding: 6px 10px;
      border-radius: 999px;
      background: #ffffff;
      border: 1px solid var(--accent);
      color: var(--accent);
      font-weight: 800;
      font-size: 12px;
    }

    #listino .plan header {
      padding: 16px;
      border-bottom: 1px solid var(--line);
    }

    #listino .plan h3 {
      margin: 0 0 4px;
      font-weight: 900;
    }

    #listino .subtitle {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* Corpo */
    #listino .body {
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: center;
    }

    #listino .price {
      font-size: 28px;
      font-weight: 900;
      white-space: nowrap;
    }

    #listino .price small {
      font-size: 14px;
      color: var(--muted);
      font-weight: 700;
    }

    /* Elenco con icone centrato */
    #listino .ul {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 8px;
      justify-items: center;
      width: 100%;
    }

    #listino .ul li {
      display: inline-flex;
      gap: 8px;
      align-items: center;
      justify-content: center;
      text-align: center;
    }

    /* Spunte ROSSE */
    #listino .ul svg {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px;
    }

    /* CTA container */
    #listino .cta {
      padding: 14px 16px 18px;
      display: flex;
      justify-content: center;
    }

    /* Bottone "Richiedi preventivo": bianco, testo ROSSO, SENZA bordo rosso */
    #listino .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 44px;
      padding: 0 16px;
      border-radius: 14px;
      border: 1px solid transparent;
      /* â† bordo rimosso */
      background: #ffffff;
      color: var(--accent);
      font-weight: 900;
      text-decoration: none;
      white-space: nowrap;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
    }

    /* Bottone ghost (resta scuro) */
    #listino .sc-btn--ghost {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 44px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid var(--line);
      background: #242424;
      color: #fff;
      font-weight: 900;
      text-decoration: none;
      white-space: nowrap;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
    }

    /* Card â€œServizi aggiuntiviâ€ invariata nel layout dei tag */
    #listino .addons-card {
      background: var(--panel);
    }

    #listino .tags {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      justify-content: center;
    }

    #listino .tag {
      padding: 8px 12px;
      border: 1px solid var(--line);
      background: #232429;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 800;
    }

/* ================= SEZIONE 6 ================= */
#sc-dep-faq {
      --accent: #D40000;
      /* Ferrari Red (solo cambio colore) */
      --bg1: #0c0c0d;
      --bg2: #141415;
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --radius: 14px;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, var(--bg1), var(--bg2));
      isolation: isolate;
      padding: 60px 0;
    }

    #sc-dep-faq .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    #sc-dep-faq .sec-head {
      text-align: center;
      margin-bottom: 18px;
    }

    #sc-dep-faq h2 {
      margin: 0;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.2rem);
      color: var(--text);
    }

    /* parola "Domande" in ROSSO */
    #sc-dep-faq .sec-head .accent {
      color: var(--accent);
    }

    /* --- FIX: mantieni i titoli bianchi anche su hover/focus (override globali) --- */
    #sc-dep-faq h2:hover,
    #sc-dep-faq h2:focus {
      color: var(--text) !important;
    }

    #sc-dep-faq h2:hover .accent,
    #sc-dep-faq h2:focus .accent {
      color: var(--accent) !important;
    }

    /* FAQ grid */
    #sc-dep-faq .faq {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media(min-width:900px) {
      #sc-dep-faq .faq {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    #sc-dep-faq .q {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
    }

    #sc-dep-faq summary {
      list-style: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 14px 16px;
      font-weight: 900;
      color: var(--text);
    }

    #sc-dep-faq summary::-webkit-details-marker {
      display: none;
    }

    /* FIX: resta bianco anche al passaggio mouse / focus */
    #sc-dep-faq summary:hover,
    #sc-dep-faq summary:focus,
    #sc-dep-faq summary:focus-visible {
      color: var(--text) !important;
    }

    #sc-dep-faq .a {
      padding: 0 16px 14px;
      color: var(--muted);
    }

    #sc-dep-faq .q[open] summary {
      border-bottom: 1px solid var(--line);
    }

    #sc-dep-faq .caret {
      width: 18px;
      height: 18px;
      transform: rotate(0deg);
      transition: transform .15s ease;
    }

    #sc-dep-faq .q[open] .caret {
      transform: rotate(180deg);
    }

/* Android: rimuove rettangoli blu (tap highlight/focus) sui summary FAQ */
@media (hover: none) and (pointer: coarse) {
  #sc-dep-faq summary,
  #sc-dep-faq summary * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }
  #sc-dep-faq summary:focus,
  #sc-dep-faq summary:focus-visible {
    outline: none;
    box-shadow: none;
  }
  #sc-dep-faq summary:active {
    background: transparent;
  }
}

/* Mobile: fallback extra per FAQ (alcuni Android non matchano pointer/hover correttamente) */
@media (max-width: 1023px) {
  #sc-dep-faq summary,
  #sc-dep-faq summary * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #sc-dep-faq summary {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #sc-dep-faq summary:focus,
  #sc-dep-faq summary:focus-visible,
  #sc-dep-faq summary:active {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
  }
}

/* Mobile (Android/iOS): rimuove rettangoli blu su tap dei pulsanti principali */
@media (hover: none) and (pointer: coarse) {
  .sd-btn,
  .sd-btn *,
  #listino .sc-btn,
  #listino .sc-btn--ghost,
  #scd-cta .btn,
  #scd-cta .btn--ghost,
  #preventivo .btn,
  #preventivo .btn--ghost,
  #preventivo .btn * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }

  .sd-btn:focus,
  .sd-btn:focus-visible,
  #listino .sc-btn:focus,
  #listino .sc-btn:focus-visible,
  #listino .sc-btn--ghost:focus,
  #listino .sc-btn--ghost:focus-visible,
  #scd-cta .btn:focus,
  #scd-cta .btn:focus-visible,
  #preventivo .btn:focus,
  #preventivo .btn:focus-visible {
    outline: none;
    box-shadow: none;
  }
}

/* Deposito: su mobile elimina rettangoli blu su qualunque elemento cliccabile (esclusi input/textarea) */
@media (hover: none) and (pointer: coarse) {
  html,
  body {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  body * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a,
  button,
  summary,
  [role="button"],
  [role="menuitem"],
  [tabindex]:not([tabindex="-1"]) {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  a *,
  button *,
  summary *,
  [role="button"] *,
  [role="menuitem"] * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a:focus,
  a:focus-visible,
  button:focus,
  button:focus-visible,
  summary:focus,
  summary:focus-visible,
  [role="button"]:focus,
  [role="button"]:focus-visible,
  [role="menuitem"]:focus,
  [role="menuitem"]:focus-visible,
  [tabindex]:not([tabindex="-1"]):focus,
  [tabindex]:not([tabindex="-1"]):focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  a:active,
  button:active,
  summary:active,
  [role="button"]:active,
  [role="menuitem"]:active,
  [tabindex]:not([tabindex="-1"]):active {
    background-color: transparent !important;
  }

  body :not(input):not(textarea)::selection {
    background: transparent;
  }
}

/* ================= SEZIONE 7 ================= */
#scd-cta {
      --accent: #D40000;
      /* Ferrari Red */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      padding: 60px 0;
      text-align: center;
      isolation: isolate;
    }

    #scd-cta .wrap {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
    }

    #scd-cta .box {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
    }

    #scd-cta h3 {
      margin: 0 0 .35em;
      font-weight: 900;
      font-size: clamp(1.4rem, 3vw, 1.9rem);
      line-height: 1.12;
    }

    #scd-cta p {
      margin: 0 0 .8rem;
      color: var(--muted);
      font-weight: 600;
    }

    #scd-cta .row {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: center;
    }

    /* PRIMARIO: sfondo bianco + testo rosso */
    #scd-cta .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      height: 46px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid #fff;
      /* bordo bianco */
      background: #fff;
      /* sfondo bianco */
      color: #D40000;
      /* testo rosso */
      font-weight: 900;
      text-decoration: none;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
    }

    /* SECONDARIO invariato */
    #scd-cta .btn--ghost {
      background: #242424;
      border: 1px solid var(--line);
      color: #fff;
    }

/* Mobile: niente rettangoli blu su tap dei bottoni CTA (Android/iOS) */
@media (max-width: 1023px) {
  #scd-cta .btn,
  #scd-cta .btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #scd-cta .btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #scd-cta .btn:focus,
  #scd-cta .btn:focus-visible,
  #scd-cta .btn:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* Mobile: niente rettangoli blu su tap dei bottoni Listino (Android/iOS) */
@media (max-width: 1023px) {
  #listino .sc-btn,
  #listino .sc-btn *,
  #listino .sc-btn--ghost,
  #listino .sc-btn--ghost * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #listino .sc-btn,
  #listino .sc-btn--ghost {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #listino .sc-btn:focus,
  #listino .sc-btn:focus-visible,
  #listino .sc-btn:active,
  #listino .sc-btn--ghost:focus,
  #listino .sc-btn--ghost:focus-visible,
  #listino .sc-btn--ghost:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* ================= SEZIONE 8 ================= */
.scd-form {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #202124;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      padding: 60px 0;
      /* 60px sopra e sotto */
      color-scheme: dark;
    }

    .scd-form .wrap {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px
    }

    .scd-form .head {
      text-align: center;
      margin-bottom: 10px
    }

    .scd-form .head h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem)
    }

    .scd-form .accent {
      color: var(--accent);
    }

    /* "preventivo" in rosso */
    .scd-form .head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600
    }

    .scd-form .form {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow)
    }

    .scd-form .grid2 {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr
    }

    @media(min-width:760px) {
      .scd-form .grid2 {
        grid-template-columns: repeat(2, 1fr)
      }
    }

    .scd-form .field {
      display: flex;
      flex-direction: column;
      gap: 6px;
      position: relative
    }

    .scd-form .label {
      font-weight: 800;
      font-size: 13px;
      color: var(--text)
    }

    .scd-form .input,
    .scd-form .textarea,
    .scd-form .select {
      width: 100%;
      min-height: 44px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #111;
      color: #fff;
      caret-color: #fff;
      outline: none;
      box-shadow: inset 0 8px 18px -12px rgba(0, 0, 0, .5)
    }

    .scd-form .input::placeholder,
    .scd-form .textarea::placeholder {
      color: rgba(255, 255, 255, .72);
      opacity: 1
    }

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

    /* ===== DATE PICKER: POPOVER BIANCO + TESTI ROSSI ===== */
	    .scd-form .date-display {
	      display: flex;
	      align-items: center;
	      justify-content: space-between;
	      gap: 10px;
      width: 100%;
      min-height: 44px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--line);
	      background: #111;
	      color: #fff;
	      font-weight: 800;
	      cursor: pointer
	    }

/* Mobile: niente rettangoli blu su tap del date picker (Dal/Al) */
@media (max-width: 1023px) {
  .scd-form .date-display,
  .scd-form .date-display *,
  .scd-form .cal-toggle,
  .scd-form .cal-navbtn,
  .scd-form .day,
  .scd-form .mon {
    -webkit-tap-highlight-color: transparent !important;
  }

  .scd-form .date-display,
  .scd-form .cal-toggle,
  .scd-form .cal-navbtn,
  .scd-form .day,
  .scd-form .mon {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .scd-form .date-display:focus,
  .scd-form .date-display:focus-visible,
  .scd-form .cal-toggle:focus,
  .scd-form .cal-toggle:focus-visible,
  .scd-form .cal-navbtn:focus,
  .scd-form .cal-navbtn:focus-visible,
  .scd-form .day:focus,
  .scd-form .day:focus-visible,
  .scd-form .mon:focus,
  .scd-form .mon:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }
}

	    .scd-form .date-display .placeholder {
	      color: rgba(255, 255, 255, .72);
	      font-weight: 600
	    }

    .scd-form .date-caret {
      width: 18px;
      height: 18px;
      flex: 0 0 18px
    }

    .scd-form .date-pop {
      position: absolute;
      left: 0;
      top: calc(100% + 6px);
      width: 100%;
      background: #ffffff;
      color: var(--accent);
      color-scheme: light;
      border-radius: 14px;
      box-shadow: var(--shadow);
      border: 1px solid var(--accent);
      z-index: 50;
      overflow: hidden;
      display: none
    }

    .scd-form .date-pop.is-open {
      display: block
    }

    /* Header calendario bianco con testi rossi */
    .scd-form .cal-head {
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      background: #fff;
      color: var(--accent);
      font-weight: 900;
      letter-spacing: .2px;
      border-bottom: 1px solid rgba(212, 0, 0, .15)
    }

    .scd-form .cal-center {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      text-align: center
    }

    .scd-form .cal-label {
      min-width: 180px;
      color: var(--accent)
    }

    .scd-form .cal-toggle,
    .scd-form .cal-navbtn {
      appearance: none;
      border: 1px solid var(--accent);
      border-radius: 10px;
      padding: 6px 10px;
      background: transparent;
      color: var(--accent);
      cursor: pointer;
      font-weight: 900
    }

    .scd-form .cal-toggle:hover,
    .scd-form .cal-navbtn:hover {
      background: rgba(212, 0, 0, .06)
    }

    .scd-form .cal-right {
      min-width: 52px
    }

    /* Giorni/mesi con testi rossi su bianco */
    .scd-form .cal-grid {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 6px;
      padding: 10px 12px 14px
    }

    .scd-form .dow {
      opacity: .9;
      font-weight: 800;
      text-align: center;
      color: var(--accent)
    }

    .scd-form .day {
      appearance: none;
      border: 1px solid transparent;
      border-radius: 10px;
      padding: 8px 0;
      background: transparent;
      color: var(--accent);
      font-weight: 800;
      cursor: pointer
    }

    .scd-form .day:hover {
      background: rgba(212, 0, 0, .08)
    }

    .scd-form .day.is-today {
      outline: 2px solid rgba(212, 0, 0, .45);
      outline-offset: 1px
    }

    .scd-form .day.is-selected {
      background: rgba(212, 0, 0, .10);
      outline: 2px solid var(--accent)
    }

    .scd-form .month-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 8px;
      padding: 10px 12px 14px
    }

    @media(min-width:480px) {
      .scd-form .month-grid {
        grid-template-columns: repeat(6, 1fr)
      }
    }

    .scd-form .mon {
      appearance: none;
      border: 1px solid var(--accent);
      border-radius: 12px;
      padding: 10px 0;
      background: #fff;
      color: var(--accent);
      font-weight: 900;
      cursor: pointer;
      text-transform: capitalize
    }

    .scd-form .mon:hover {
      background: rgba(212, 0, 0, .06)
    }

    .scd-form .mon.is-current {
      outline: 2px solid rgba(212, 0, 0, .45)
    }

    .scd-form .mon.is-view {
      background: rgba(212, 0, 0, .10)
    }

    /* Focus accessibile in rosso */
    .scd-form .cal-toggle:focus-visible,
    .scd-form .cal-navbtn:focus-visible,
    .scd-form .day:focus-visible,
    .scd-form .mon:focus-visible {
      outline: 3px solid rgba(212, 0, 0, .5);
      outline-offset: 2px
    }

    /* Row CTA */
    .scd-form .row {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      align-items: center;
      margin-top: 10px
    }

    /* "Invia richiesta": bianco con testo rosso (senza bordo rosso) */
    .scd-form .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      height: 44px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid transparent;
      /* niente bordo rosso */
      background: #ffffff;
      color: var(--accent);
      font-weight: 900;
      text-decoration: none
    }

    /* Ghost invariato */
    .scd-form .btn--ghost {
      background: #242424;
      border-color: var(--line);
      color: #fff
    }

/* Mobile: niente rettangoli blu su tap dei bottoni form (Invia richiesta / Chiama ora) */
@media (max-width: 1023px) {
  .scd-form .btn,
  .scd-form .btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  .scd-form .btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .scd-form .btn:focus,
  .scd-form .btn:focus-visible,
  .scd-form .btn:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

    .scd-form .note {
      font-size: 12px;
      color: rgba(255, 255, 255, .75);
      margin-top: 8px
    }

    .scd-form .note--err {
      color: #ffd1c0
    }

    /* Autofill fix */
    .scd-form input:-webkit-autofill,
    .scd-form input:-webkit-autofill:hover,
    .scd-form input:-webkit-autofill:focus {
      -webkit-text-fill-color: #fff;
      transition: background-color 5000s ease-in-out 0s;
      box-shadow: 0 0 0 1000px #111 inset;
    }

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

    /* Bottom */
    #af-footer .af-bottom {
      border-top: 0;
      padding: 18px 0;
      margin-top: 0;
    }

    #af-footer .af-bottom .wrap {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
    }

    @media (min-width:768px) {
      #af-footer .af-bottom .wrap {
        flex-direction: row;
      }
    }

    #af-footer .af-copy {
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-legal {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    #af-footer .af-legal a {
      font-size: 14px;
    }


/* === pages/home.css === */
/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 76px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1800px;
      margin: 0 auto;
      padding: 0 24px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 170px;
      height: 60px;
      aspect-ratio: 170/60;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
/* Accent locale alla sezione (non tocca il resto della pagina) */
  .sd-hero {
    --sd-accent: #D40000;
  }

  /* Ferrari Red */

  .sd-hero {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    /* desktop invariato */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

.sd-hero {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  overflow: hidden;
}

.sd-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

.sd-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  background: #000;
}

  .sd-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, .70), rgba(0, 0, 0, .50), rgba(0, 0, 0, .70));
    pointer-events: none;
  }

  .sd-hero__content {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    padding-inline: 1rem;
    text-align: center;
  }

  .sd-hero__wrap {
    max-width: 64rem;
    margin: 0 auto;
  }

  /* ====== TITOLO (dimensioni ORIGINALI) ====== */
  .sd-hero__title {
    margin: 0 0 .5em;
    color: #fff;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(3.1rem, 7.4vw, 5.4rem);
  }

  .sd-hero__title .sd-primary {
    color: var(--sd-accent);
  }

  .sd-hero__subtitle {
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1.3rem, 2.6vw, 1.85rem);
    margin: 0 0 1.35rem;
  }

  .sd-hero__subtitle .sd-line {
    display: block;
    white-space: nowrap;
  }

  .sd-hero__actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    padding-top: 1rem;
    width: 100%;
  }

  @media (min-width:640px) {
    .sd-hero__actions {
      flex-direction: row;
      align-items: center;
      justify-content: center;
      gap: 1rem;
      width: auto;
      max-width: none;
    }

    .sd-hero__actions .sd-btn {
      flex: 0 1 auto;
      min-width: 0;
      width: auto;
    }
  }

  .sd-btn {
    --_h: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 0 2rem;
    height: var(--_h);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 1.125rem;
    text-decoration: none;
    border: 2px solid transparent;
    transition: transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    line-height: 1;
    white-space: nowrap;
  }

  .sd-btn--primary {
    background: #fff;
    color: var(--sd-accent);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .2);
  }

  .sd-btn--primary::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .3), transparent);
    transform: translateX(-100%);
    transition: transform 1s;
  }

  .sd-btn--primary:hover::before {
    transform: translateX(100%);
  }

  .sd-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
  }

  .sd-btn--ghost {
    background: rgba(255, 255, 255, .10);
    color: #fff;
    border-color: rgba(255, 255, 255, .30);
    box-shadow: 0 6px 20px rgba(0, 0, 0, .15);
    backdrop-filter: saturate(1.2) blur(.5px);
  }

  .sd-btn--ghost:hover {
    background: rgba(255, 255, 255, .20);
    transform: translateY(-1px);
  }

  .sd-icon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }

  .sd-scroll {
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 10;
  }

  .sd-scroll__mouse {
    width: 24px;
    height: 40px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, .5);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 8px;
  }

  .sd-scroll__dot {
    width: 4px;
    height: 12px;
    background: rgba(255, 255, 255, .7);
    border-radius: 999px;
    animation: sd-bounce 1s infinite alternate;
  }

  @keyframes sd-bounce {
    from {
      transform: translateY(0);
      opacity: 1;
    }

    to {
      transform: translateY(6px);
      opacity: .6;
    }
  }

  @media (prefers-reduced-motion:reduce) {

    .sd-btn,
    .sd-btn::before,
    .sd-scroll__dot {
      transition: none;
      animation: none;
    }

    .sd-hero__video {
      animation: none;
    }
  }

  /* ====== OVERRIDE DI SICUREZZA (anti-arancione) ====== */
  .sd-hero .sd-primary {
    color: #D40000 !important;
  }

  /* "quando vuoi." */
  .sd-hero .sd-btn--primary {
    color: #D40000 !important;
  }

  /* testo bottone primario */
  .sd-hero .sd-btn--primary .sd-icon {
    stroke: currentColor;
    fill: none;
  }

  /* ===================== SOLO MOBILE (â‰¤ 639px) ===================== */
  @media (max-width: 639px) {

    /* usa unitÃ  "svh" per includere la UI del browser su iOS/Android */
  .sd-hero {
        min-height: 96svh;
      }

    /* Sottotitolo piÃ¹ compatto per far rientrare tutto in viewport */
    .sd-hero__subtitle {
      font-size: clamp(.95rem, 3.6vw, 1.2rem);
      /* ~15pxâ€“19px */
      line-height: 1.35;
      margin-bottom: .75rem;
    }

    .sd-hero__subtitle .sd-line {
      white-space: normal;
    }

    /* consenti a capo */

    /* Bottoni affiancati, compatti su mobile */
    .sd-hero__actions {
      flex-direction: row;
      gap: .75rem;
      padding-top: .5rem;
    }

    .sd-hero__actions .sd-btn {
      flex: 1 1 0;
      min-width: 0;
      height: 3rem;
      font-size: 1.05rem;
      padding: 0 1.25rem;
    }

    /* Scroll cue piÃ¹ vicino al bordo per non rubare spazio */
    .sd-scroll {
      bottom: 1rem;
    }
  }

/* ================= SEZIONE 2 ================= */
.sd-services {
    --sd-accent: #D40000;
    /* Ferrari Red */
    position: relative;
    isolation: isolate;
    background: var(--sd-bg-radial), var(--sd-bg-linear);
    color: #fff;
    padding: 72px 0;
    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

  .sd-services__container {
    max-width: 1350px;
    margin: 0 auto;
    padding: 0 24px;
  }

  .sd-services__title {
    margin: 0 0 .25em;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2rem, 5vw, 3rem);
    text-align: center;
    color: #fff;
  }

  #servizi .sd-services__title .sd-accent {
    color: var(--sd-accent) !important;
  }

  .sd-services__subtitle {
    margin: 0 0 1.75rem;
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1rem, 2vw, 1.125rem);
    text-align: center;
  }

  /* ===== Desktop/Tablet (grid classico) ===== */
  .sd-services__grid {
    display: grid;
    gap: 20px;
  }

  @media (min-width:640px) {
    .sd-services__grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (min-width:1024px) {
    .sd-services__grid {
      grid-template-columns: repeat(4, 1fr);
    }
  }

  /* ===== Mobile Masonry (gestito da JS) ===== */
  @media (max-width:639px) {
    /* Android: evita focus highlight sull'intera card (anchor) */
    #servizi a.sd-card:focus,
    #servizi a.sd-card:focus-visible,
    #servizi a.sd-card:active {
      outline: none !important;
      box-shadow: none !important;
    }

    /* quando JS attiva il masonry aggiunge .is-masonry al container */
    #servizi .sd-services__grid.is-masonry {
      display: flex !important;
      /* due colonne affiancate */
      gap: 20px;
      /* spazio tra colonne */
      align-items: flex-start;
    }

    #servizi .sd-services__grid.is-masonry .mcol {
      display: flex;
      flex-direction: column;
      gap: 20px;
      /* spazio tra card della stessa colonna */
      width: calc(50% - 10px);
      /* 2 colonne con gap=20 â†’ -10 per lato */
      min-width: 0;
    }
  }

  /* ===== Card base ===== */
  .sd-card {
    position: relative;
    display: block;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 18px;
    padding: 22px;
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }

  .sd-card:hover,
  .sd-card:focus-visible {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
    border-color: rgba(255, 255, 255, .16);
    outline: none;
  }

  /* Glow ROSSO sotto la card */
  .sd-card::before {
    content: "";
    position: absolute;
    inset: -3px;
    border-radius: 20px;
    background: radial-gradient(120% 120% at 50% 100%,
        rgba(212, 0, 0, .70) 0%, rgba(212, 0, 0, .18) 45%, transparent 70%);
    z-index: -1;
    transform: translateY(6px) scale(.98);
    filter: blur(14px);
    opacity: .35;
    transition: opacity .2s ease, transform .2s ease, filter .2s ease;
    pointer-events: none;
  }

  @supports (background:color-mix(in srgb, red 50%, transparent)) {
    .sd-card::before {
      background: radial-gradient(120% 120% at 50% 100%,
          color-mix(in srgb, var(--sd-accent) 70%, transparent) 0%,
          color-mix(in srgb, var(--sd-accent) 18%, transparent) 45%, transparent 70%);
    }
  }

  .sd-card:hover::before,
  .sd-card:focus-visible::before {
    opacity: .7;
    transform: translateY(2px) scale(1);
    filter: blur(10px);
  }

  /* Icone: sfondo bianco + icone rosse */
  .sd-card__icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #fff;
    box-shadow: 0 4px 14px rgba(0, 0, 0, .22);
    margin-bottom: 12px;
  }

  #servizi .sd-card__icon svg {
    width: 24px;
    height: 24px;
    stroke: var(--sd-accent) !important;
    fill: none;
  }

  .sd-card__title {
    margin: 0 0 .35rem;
    font-weight: 800;
    font-size: 1.25rem;
    letter-spacing: .2px;
  }

  .sd-card__desc {
    margin: 0;
    color: rgba(255, 255, 255, .9);
    line-height: 1.5;
    font-weight: 500;
  }

  /* ===== SOLO MOBILE: 4 righe ellissi + pulsante +/âˆ’ in basso a destra ===== */
  @media (max-width:639px) {
    #servizi .sd-card {
      padding-bottom: 46px;
    }

    #servizi .sd-card__icon {
      display: none !important;
    }

    #servizi .sd-card__title {
      margin-top: 14px !important;
      line-height: 1.15;
    }

    #servizi .sd-card__desc {
      margin-top: .35rem !important;
      line-height: 1.4;
    }

    /* Clamp 4 righe quando chiusa */
    #servizi .sd-card:not(.is-open) .sd-card__desc {
      --clamp-lines: 4;
      display: -webkit-box;
      -webkit-line-clamp: var(--clamp-lines);
      -webkit-box-orient: vertical;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    /* Pulsante +/âˆ’ */
    #servizi .sd-card__plus {
      position: absolute;
      right: 10px;
      bottom: 10px;
      width: 26px;
      height: 26px;
      border-radius: 999px;
      background: #fff;
      color: var(--sd-accent);
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 900;
      font-size: 16px;
      line-height: 1;
      border: 1px solid rgba(255, 255, 255, .35);
      box-shadow: 0 6px 16px rgba(0, 0, 0, .24);
      cursor: pointer;
      user-select: none;
      outline: none;
      -webkit-appearance: none;
      -webkit-tap-highlight-color: transparent;
      touch-action: manipulation;
    }

    /* Android/iOS: evita rettangoli blu / selezioni su tap */
    #servizi .sd-card,
    #servizi .sd-card * {
      -webkit-tap-highlight-color: transparent;
    }

    #servizi .sd-card__plus:focus-visible {
      outline: none;
      box-shadow: 0 0 0 2px rgba(212, 0, 0, .4);
    }

    /* Stato aperto (solo la card cliccata si allunga) */
    #servizi .sd-card.is-open .sd-card__desc {
      display: block;
      -webkit-line-clamp: initial;
      -webkit-box-orient: initial;
      overflow: visible;
    }
  }

  /* Nascondo il bottone sopra mobile */
  @media (min-width:640px) {
    #servizi .sd-card__plus {
      display: none !important;
    }
  }

  @media (prefers-reduced-motion:reduce) {

    .sd-card,
    .sd-card::before {
      transition: none;
      transform: none;
    }
  }

/* ================= SEZIONE 3 ================= */
:root {
      --bg-start: #202020;
      --bg-end: #111111;
      --card-bg: #1e1e1f;
      --text: #ffffff;
      --muted: #cfcfcf;
      --chip-bg: #2b2b2d;
      --chip-text: #ededed;
      --outline: #6b6b6b;
      --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
      --radius: 22px;
      /* ModalitÃ  */
      --rent-color: #D40000;
      --rent-pressed: #B80000;
      --buy-color: #6ecbff;
      --filter-bg: #141414;
      --filter-border: #2e2e2e;
      --filter-text: #e9e9e9;
      --filter-placeholder: #afafaf;
    }

    html,
    body {
      margin: 0;
      padding: 0;
      overflow-x: hidden
    }

    body {
      font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Roboto, Arial, sans-serif;
      color: var(--text)
    }

    .pf-fleet-wrap {
      background:
        radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%),
        linear-gradient(180deg, var(--bg-start), var(--bg-end));
      padding: 56px 0 36px;
      width: 100%;
    }

    .pf-fleet-outer {
      position: relative;
      left: 50%;
      right: 50%;
      margin-left: -50vw;
      margin-right: -50vw;
      width: 100vw;
      max-width: 100vw;
      padding-inline: 0
    }

    .pf-fleet-head {
      text-align: center;
      margin: 0 auto 8px;
      max-width: min(1280px, 100%);
      padding: 0 16px;
    }

    .pf-fleet-head h2 {
      color: #fff;
      font-weight: 800;
      font-size: clamp(28px, 4vw, 48px);
      margin: 0 0 6px;
      letter-spacing: .2px;
    }

    .pf-fleet-head p {
      margin: 0 16px 14px;
      color: var(--muted);
      font-size: clamp(14px, 2vw, 18px);
    }

    .pf-fleet-head .pf-accent {
      color: var(--rent-color)
    }

    .pf-fleet-wrap.is-buy .pf-fleet-head .pf-accent {
      color: var(--buy-color)
    }

    /* SWITCH */
    .pf-switch.nav {
      display: block;
      width: min(460px, 92vw);
      margin: 12px auto 0;
      background: #1a1a1a;
      padding: 6px clamp(18px, 4vw, 40px);
      border-radius: 999px;
      border: 1px solid #2e2e2e;
      position: relative;
      overflow: hidden;
      box-shadow: 0 8px 22px -12px rgba(0, 0, 0, .5) inset
    }

    .nav__links {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      width: 100%;
      list-style: none;
      margin: 0;
      padding: 0
    }

    .nav__link {
      display: flex;
      align-items: center
    }

    .nav__link button {
      appearance: none;
      border: 0;
      background: transparent;
      cursor: pointer;
      color: #e9e9e9;
      opacity: .9;
      font-weight: 800;
      padding-block: 16px;
      padding-inline: 0;
      font-size: 15px;
      line-height: 1;
      border-radius: 999px;
      position: relative;
      z-index: 2;
      transition: opacity .2s, transform .02s, text-shadow .2s, color .2s;
      text-align: center
    }

    .nav__link .label {
      display: inline-block;
      padding: 0 2px
    }

    .nav__link button:active {
      transform: translateY(1px)
    }

    .nav__link[data-mode="rent"].active button {
      color: var(--rent-color);
      text-shadow: 0 0 10px color-mix(in srgb, var(--rent-color) 70%, transparent), 0 0 24px color-mix(in srgb, var(--rent-color) 45%, transparent)
    }

    .nav__link[data-mode="buy"].active button {
      color: var(--buy-color);
      text-shadow: 0 0 10px color-mix(in srgb, var(--buy-color) 70%, transparent), 0 0 24px color-mix(in srgb, var(--buy-color) 45%, transparent)
    }

    .nav__toggle {
      flex: 0 0 auto;
      display: flex;
      align-items: center;
      justify-content: center;
      min-width: 72px
    }

    .toggle-container {
      --knob-size: 1.6em;
      display: flex;
      justify-content: center;
      position: relative;
      transform: translateY(2px)
    }

    .toggle-input {
      position: absolute;
      z-index: 2;
      bottom: 132.5%;
      border-radius: 50%;
      transform: rotate(-25deg);
      transform-origin: 50% 4.75em;
      width: var(--knob-size);
      height: var(--knob-size);
      opacity: 0;
      font: inherit;
      transition: transform .24s cubic-bezier(.65, 1.35, .5, 1);
      cursor: pointer
    }

    .toggle-input:checked {
      transform: rotate(25deg)
    }

    .toggle-handle-wrapper {
      position: absolute;
      z-index: 1;
      bottom: -135%;
      -webkit-mask-image: linear-gradient(to bottom, #000 62.125%, transparent 50%);
      mask-image: linear-gradient(to bottom, #000 62.125%, transparent 50%);
      width: 200%;
      overflow: hidden
    }

    .toggle-handle {
      display: flex;
      flex-direction: column;
      align-items: center;
      transform: rotate(-25deg);
      transform-origin: bottom center;
      transition: transform .24s cubic-bezier(.65, 1.35, .5, 1)
    }

    .toggle-input:checked+.toggle-handle-wrapper>.toggle-handle {
      transform: rotate(25deg)
    }

    .toggle-handle-knob {
      position: relative;
      z-index: 1;
      border-radius: 50%;
      width: var(--knob-size);
      height: var(--knob-size);
      background: radial-gradient(60% 60% at 30% 30%, color-mix(in srgb, var(--rent-color) 92%, #000 8%) 0%, var(--rent-color) 55%, color-mix(in srgb, var(--rent-color) 60%, #000 40%) 100%);
      transition: transform .24s cubic-bezier(.65, 1.35, .5, 1), background .2s ease
    }

    .pf-fleet-wrap.is-buy .toggle-handle-knob {
      background: radial-gradient(60% 60% at 30% 30%, color-mix(in srgb, var(--buy-color) 92%, #000 8%) 0%, var(--buy-color) 55%, color-mix(in srgb, var(--buy-color) 60%, #000 40%) 100%)
    }

    .toggle-handle-bar-wrapper {
      position: relative;
      width: .5em;
      height: 3em
    }

    .toggle-handle-bar {
      position: absolute;
      top: calc(var(--knob-size)/2 * -1);
      left: 0;
      width: 100%;
      height: calc(100% + var(--knob-size)/2);
      background-image: linear-gradient(to right, #777475, #a4a4a4, #bbb 45% 55%, #a4a4a4, #777475);
      background-position-x: .06125em;
      transition: background-position-x .24s cubic-bezier(.65, 1.35, .5, 1);
      box-shadow: inset 0 1em .25em rgb(0 0 0 / .35)
    }

    .toggle-input:checked+.toggle-handle-wrapper .toggle-handle-bar {
      background-position-x: -.06125em
    }

    .toggle-base {
      position: relative;
      border-radius: 3.125em;
      padding: .25em;
      width: 3.5em;
      height: 1.125em;
      background-color: #dcdcdc;
      background-image: linear-gradient(to bottom, #ffffff, #cfcfcf);
      box-shadow: 0 -.25em .5em #fff, 0 .25em .5em #bfbfbf
    }

    .toggle-base-inside {
      position: relative;
      border-radius: inherit;
      width: 100%;
      height: 100%;
      background-image: linear-gradient(to bottom, #a6a6a6, #7d7d7d);
      box-shadow: inset 0 .0625em rgb(255 255 255 / .2), inset 0 -.03125em rgb(255 255 255 / 1), inset 0 -.0625em .25em rgb(0 0 0 / .1)
    }

    /* ===== GLOW CARDS ===== */
    /* FIX iOS: niente paint containment/clipping e overflow ben visibile per le slide laterali */
    .pf-fleet {
      position: relative;
      z-index: 1;
      width: 100%;
      padding-top: 12px;
      padding-bottom: 56px;
      overflow: visible !important;
      contain: layout;
    }

    @supports (-webkit-touch-callout: none) {
      .pf-fleet {
        contain: none;
      }

      /* iOS Safari: rimuovi completamente il paint containment */
    }

    .pf-stage,
    .swiper.pf-fleet,
    .pf-fleet .swiper-wrapper,
    .pf-fleet .swiper-slide {
      overflow: visible !important;
    }

    .pf-fleet .swiper-wrapper {
      padding: 5.75rem 0;
      will-change: transform;
      transform: translateZ(0);
    }

    /* forza compositing su iOS */

    .pf-fleet .swiper-slide {
      position: relative;
      border-radius: var(--radius)
    }

    .pf-stage.mode-rent .pf-fleet .swiper-slide::before {
      content: "";
      position: absolute;
      z-index: 0;
      pointer-events: none;
      inset: -10% -6% -16% -6%;
      border-radius: calc(var(--radius) + 22px);
      filter: blur(30px);
      opacity: .34;
      transition: .35s;
      transform: translateZ(0);
      background: radial-gradient(65% 75% at 50% 38%, color-mix(in srgb, var(--rent-color) 50%, transparent) 0%, color-mix(in srgb, var(--rent-color) 18%, transparent) 46%, transparent 72%)
    }

    .pf-stage.mode-rent .pf-fleet .swiper-slide::after {
      content: "";
      position: absolute;
      z-index: 0;
      pointer-events: none;
      left: 50%;
      transform: translateX(-50%) translateZ(0);
      bottom: -10%;
      width: 120%;
      height: 38%;
      filter: blur(28px);
      opacity: .30;
      border-radius: 50%;
      background: radial-gradient(60% 100% at 50% 0%, color-mix(in srgb, var(--rent-color) 42%, transparent) 0%, color-mix(in srgb, var(--rent-color) 14%, transparent) 55%, transparent 80%)
    }

    .pf-stage.mode-buy .pf-fleet .swiper-slide::before {
      content: "";
      position: absolute;
      z-index: 0;
      pointer-events: none;
      inset: -10% -6% -16% -6%;
      border-radius: calc(var(--radius) + 22px);
      filter: blur(30px);
      opacity: .34;
      transition: .35s;
      transform: translateZ(0);
      background: radial-gradient(65% 75% at 50% 38%, color-mix(in srgb, var(--buy-color) 48%, transparent) 0%, color-mix(in srgb, var(--buy-color) 18%, transparent) 46%, transparent 72%)
    }

    .pf-stage.mode-buy .pf-fleet .swiper-slide::after {
      content: "";
      position: absolute;
      z-index: 0;
      pointer-events: none;
      left: 50%;
      transform: translateX(-50%) translateZ(0);
      bottom: -10%;
      width: 120%;
      height: 38%;
      filter: blur(28px);
      opacity: .30;
      border-radius: 50%;
      background: radial-gradient(60% 100% at 50% 0%, color-mix(in srgb, var(--buy-color) 38%, transparent) 0%, color-mix(in srgb, var(--buy-color) 12%, transparent) 55%, transparent 80%)
    }

    /* Card */
    .pf-fleet .swiper-slide .pf-card {
      position: relative;
      z-index: 1;
      background: var(--card-bg);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow);
      backface-visibility: hidden;
      -webkit-backface-visibility: hidden;
      transform: translateZ(0);
      will-change: transform;
    }

    .pf-card img {
      display: block;
      width: 100%;
      aspect-ratio: 4/3;
      object-fit: cover;
      backface-visibility: hidden;
      transform: translateZ(0)
    }

    /* ===== INFO: layout con bottone fisso in basso a destra; NESSUN CHIP ===== */
    .pf-card .info {
      position: absolute;
      left: 0;
      right: 0;
      bottom: -100%;
      opacity: 0;
      padding: 12px 140px 12px 12px;
      display: block;
      background: linear-gradient(0deg, rgba(10, 10, 10, .78) 0%, rgba(10, 10, 10, .28) 34%, rgba(10, 10, 10, 0) 56%);
      color: #f1f1f1;
      transition: bottom .35s ease, opacity .35s ease;
      border-radius: 0 0 var(--radius) var(--radius);
      pointer-events: none
    }

    .swiper-slide.swiper-slide-active .pf-card .info {
      bottom: 0;
      opacity: 1;
      backdrop-filter: blur(2px);
      pointer-events: auto
    }

    .pf-card .info .chips {
      display: none !important
    }

    .pf-card .info h3 {
      margin: 0 0 2px;
      font-size: 20px;
      font-weight: 700
    }

    .pf-card .info .price {
      margin: 0;
      color: #e9e9e9;
      font-size: 16px
    }

    .pf-card .info .price strong {
      font-size: 22px;
      font-weight: 800
    }

    /* Bottone fisso in basso a destra della card */
    .pf-card .info .actions {
      position: absolute;
      right: 12px;
      bottom: 12px;
      display: flex;
      align-items: center;
      gap: 10px;
      white-space: nowrap;
    }

    .pf-card .info .actions .btn {
      padding: 10px 16px;
      font-size: 15px;
      border-radius: 12px;
      line-height: 1
    }

    @media (max-width:360px) {
      .pf-card .info {
        padding-right: 128px
      }

      .pf-card .info .actions .btn {
        padding: 10px 14px;
        font-size: 14px
      }
    }

    .actions {
      display: flex;
      gap: 10px;
      align-items: center
    }

    /* Bottoni */
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 10px 16px;
      border-radius: 12px;
      text-decoration: none;
      font-weight: 800;
      font-size: 15px;
      line-height: 1;
      transition: transform .05s, box-shadow .15s, background .15s, color .15s;
      box-shadow: 0 10px 18px -12px rgba(0, 0, 0, .8)
    }

    .btn-primary {
      color: #fff
    }

    .btn--rent.btn-primary {
      background: var(--rent-color)
    }

    .btn--rent.btn-primary:active {
      background: var(--rent-pressed);
      transform: translateY(1px)
    }

    .btn--buy.btn-primary {
      background: var(--buy-color);
      color: #fff
    }

    .btn--buy.btn-primary:active {
      background: color-mix(in srgb, var(--buy-color) 85%, #000 15%);
      transform: translateY(1px)
    }

    .btn-secondary {
      background: #2a2a2a;
      color: #fff;
      border: 2px solid var(--outline)
    }

    .btn-secondary:active {
      transform: translateY(1px)
    }

    .pf-filter {
      position: relative;
      width: min(460px, 92vw);
      margin: 12px auto 0
    }

    .pf-filter__input {
      width: 100%;
      appearance: none;
      border: 1px solid var(--filter-border);
      background: var(--filter-bg) !important;
      color: var(--filter-text) !important;
      border-radius: 12px;
      padding: 12px 44px 12px 14px;
      font-weight: 700;
      font-size: 14px;
      letter-spacing: .2px;
      outline: none;
      box-shadow: 0 8px 18px -12px rgba(0, 0, 0, .5) inset;
      caret-color: var(--filter-text)
    }

    .pf-filter__input:hover,
    .pf-filter__input:focus,
    .pf-filter__input:focus-visible,
    .pf-filter__input:active {
      background: var(--filter-bg) !important;
      color: var(--filter-text) !important;
      border-color: var(--filter-border);
      outline: none
    }

    .pf-filter__input::placeholder {
      color: var(--filter-placeholder);
      font-weight: 600
    }

    .pf-filter__clear {
      position: absolute;
      right: 8px;
      top: 50%;
      transform: translateY(-50%);
      width: 28px;
      height: 28px;
      border-radius: 999px;
      border: 1px solid var(--filter-border);
      background: #222;
      color: #ddd;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 14px;
      line-height: 1;
      transition: opacity .15s, transform .02s
    }

    /* ====== SOLO MOBILE: card piÃ¹ in alto e 80px di spazio a fine sezione ====== */
    @media (max-width:639px) {
      .pf-fleet .swiper-wrapper {
        padding-top: calc(5.75rem - 40px);
        padding-bottom: 0;
      }

      .pf-fleet-wrap {
        padding-bottom: 0 !important;
      }

      .pf-fleet {
        padding-bottom: 80px !important;
      }
    }

    /* ====== SOLO DESKTOP/TABLET: padding inferiore ora 6px ====== */
    @media (min-width:640px) {
      .pf-fleet {
        padding-bottom: 6px;
      }
    }

/* ================= SEZIONE 4 ================= */
:host {
        /* Palette & tokens (colori tuoi, NO arancione) */
        --sd-accent: #D40000;           /* Ferrari Red */
        --text: #fff;
        --muted: rgba(255,255,255,.88);
        --panel: #1a1b1d;
        --line: rgba(255,255,255,.14);
        --radius: 18px;
        --shadow: 0 24px 32px -18px rgba(0,0,0,.65);

        /* Logo animazione */
        --pfbv-logo-left: 140px;
        --pfbv-logo-top:  120px;
        --pfbv-logo-w:    260px;

        /* Mobile: scala auto */
        --car-scale: 0.36;
      }

      /* Sezione principale */
      #animation_holder {
        width: 100%;
        position: relative;
        background: linear-gradient(180deg, #0c0c0d, #141415);
        color: var(--text);
        overflow: hidden;
      }

      /* Contenitore + titolo */
      .sd-container {
        position: relative;
        z-index: 2;
        max-width: 1200px;
        margin: 0 auto;
        padding: 72px 16px 24px;
        font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      }
      .sd-header { text-align: center; margin: 0 0 18px; }
      .sd-title {
        margin: 0;
        font-weight: 800;
        letter-spacing: -.02em;
        line-height: 1.05;
        font-size: clamp(1.75rem, 4.4vw, 2.5rem);
        color: #fff;
      }
      .sd-title .sd-accent { color: var(--sd-accent); }
      .sd-subtitle {
        margin: 8px 0 0;
        color: var(--muted);
        font-weight: 600;
        font-size: clamp(1rem, 2vw, 1.125rem);
        text-align: center;
      }

      /* ===== CARDS stile "pillars" ===== */
      .sd-cards {
        display: grid;
        gap: 14px;
        grid-template-columns: 1fr;
      }
      @media (min-width:720px) {
        .sd-cards { grid-template-columns: repeat(3, 1fr); }
      }

      .sd-card {
        position: relative;
        background: var(--panel);
        border: 1px solid var(--line);
        border-radius: var(--radius);
        padding: 16px;
        box-shadow: var(--shadow);
        transform: translateZ(0);
        transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
      }

      /* Glow (rosso) */
      .sd-card::before {
        content: "";
        position: absolute;
        inset: -3px;
        border-radius: calc(var(--radius) + 2px);
        background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .70) 0%,
          rgba(212, 0, 0, .18) 45%,
          transparent 70%);
        z-index: -1;
        transform: translateY(6px) scale(.98);
        filter: blur(14px);
        opacity: .35;
        transition: opacity .2s ease, transform .2s ease, filter .2s ease;
        pointer-events: none;
      }
      @supports (background: color-mix(in srgb, red 50%, transparent)) {
        .sd-card::before {
          background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--sd-accent) 70%, transparent) 0%,
            color-mix(in srgb, var(--sd-accent) 18%, transparent) 45%,
            transparent 70%);
        }
      }

      .sd-card:hover,
      .sd-card:focus-visible {
        transform: translateY(-2px) scale(1.02);
        box-shadow: 0 16px 36px rgba(0,0,0,.35);
        border-color: rgba(255,255,255,.16);
        outline: none;
      }
      .sd-card:hover::before,
      .sd-card:focus-visible::before {
        opacity: .7;
        transform: translateY(2px) scale(1);
        filter: blur(10px);
      }

      /* Icona + testi (come pillars) â€” SFONDO BIANCO + ICONA ROSSA */
      .sd-ico {
        width: 44px; height: 44px;
        border-radius: 12px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: #ffffff;                 /* sfondo bianco */
        border: 1px solid #ffffff;           /* bordo bianco pulito */
        box-shadow: 0 6px 16px -10px rgba(0,0,0,.6);
        margin-bottom: 10px;
      }
      .sd-ico svg { width: 24px; height: 24px; color: var(--sd-accent); stroke: currentColor; }

      .sd-card h3 {
        margin: .1rem 0 .25rem;
        font-size: 1.15rem;
        font-weight: 900;
        color: #fff;
      }
      .sd-card p {
        margin: 0;
        color: var(--muted);
      }

      @media (prefers-reduced-motion:reduce){
        .sd-card, .sd-card::before { transition: none; transform: none; filter: none; }
      }

      /* ===== AUTO (animazione) â€” DESKTOP invariata ===== */
      #bugatti_veyron { position: relative; float: left; width: 100%; z-index: 2; }
      #bugatti_v { display:block; width:100%; position:relative; max-width:980px; margin:0 auto; }
      #carhold_1 { border:1px solid transparent; height:352px; margin:0 auto 50px; position:relative; width:980px; float:none; }

      #veyron_rear_break, #veyron_front_break { position:absolute; bottom:35px; }
      #stage_2 { position:absolute; left:45px; width:816px; top:52px; }

      img#bugatti_v_tire, img#bugatti_v_tire_2 { position:relative; z-index:3; }
      img#bugatti_v_tire { top:-133px; left:101px; }
      img#bugatti_v_tire_2 { left:476px; top:-133px; }

      #veyron_bumper, #veyron_frame, #veyron_siding, #veyron_fender,
      #veyron_tire, #veyron_tire_2, #veyron_window, #bugatti_v_tire, #bugatti_v_tire_2 { position:relative; }

      #veyron_ruler_holer_box { width:900px; height:340px; margin:0 auto; z-index:1; position:absolute; top:0; left:0; }
      #ruler_1_wrap { height:370px; position:relative; width:1000px; z-index:9999; }
      #veyron_scroll_1, #veyron_scroll_1 img { position:absolute; bottom:-125px; }
      #ruler_horizontal_1, #ruler_horizontal_2 { position:relative; }
      #veyron_hold_box { width:978px; height:229px; position:absolute; top:60px; left:-50px; }
      #veyron_hold_box img { opacity:0; }

      /* Tinta rossa carrozzeria */
      #stage_2 img { opacity:0; }
      #veyron_front_break, #veyron_rear_break { filter:url(#pfbv-accentTint); z-index:2; }
      #veyron_bumper, #veyron_frame, #veyron_siding, #veyron_fender, #bugatti_veyron { filter:url(#pfbv-accentTint); z-index:2; }
      #veyron_tire, #veyron_tire_2, #bugatti_v_tire, #bugatti_v_tire_2 { filter:grayscale(1) brightness(0.15) contrast(1.35); }

      /* Logo dietro all'auto */
      #pfbv-logo{
        position:absolute;
        left: calc(var(--pfbv-logo-left) - 80px);
        top:  calc(var(--pfbv-logo-top)  - 180px);
        width: var(--pfbv-logo-w);
        height:auto;
        opacity:0;
        pointer-events:none;
        z-index:1;
        transform:scale(.9);
        filter: drop-shadow(0 10px 28px rgba(0,0,0,.35));
        mix-blend-mode: screen;
      }

      /* ===== SOLO MOBILE: padding extra 40px sopra/sotto + auto centrata/scalata ===== */
      @media (max-width:860px){
        .sd-container{
          padding: 40px 16px 40px; /* richiesto */
        }
        #bugatti_v{
          position: relative;
          width: 100%;
          height: calc(352px * var(--car-scale) + 6px);
          overflow: hidden;
          margin: 0 auto 8px;
        }
        #carhold_1{
          position: relative;
          left: 50%;
          transform: translateX(-50%) scale(var(--car-scale));
          transform-origin: top center;
          width: 980px; height: 352px;
          margin: 0;
        }
      }

/* ================= SEZIONE 5 ================= */
/* === FIX globali per eliminare eventuale righina/bianco sopra la sezione === */
  html,
  body {
    margin: 0;
    padding: 0;
  }

  /* Evita margini esterni involontari sulla sezione */
  #perche-noi.sd-choose {
    margin-top: -1px;
    border-top: 1px solid transparent;
  }

  /* Default globale (resta invariato), ma la sezione forza il rosso */
  :root {
    --sd-accent: var(--pf-sdv-orange, #FF7A00);
  }

  /* Fallback locale (se togli l'inline) */
  #perche-noi.sd-choose {
    --sd-accent: #D40000;
  }

.sd-choose {
    background:
      var(--sd-bg-radial),
      var(--sd-bg-linear);
    color: #fff;
    padding: 72px 0;
  }

  .sd-choose .sd-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
  }

  .sd-choose .sd-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .sd-choose .sd-title {
    margin: 0 0 .35em;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2rem, 5vw, 3rem);
  }

  /* Parola evidenziata in ROSSO */
  #perche-noi .sd-accent {
    color: var(--sd-accent) !important;
  }

  .sd-choose .sd-subtitle {
    margin: 0;
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1rem, 2vw, 1.125rem);
  }

  .sd-choose .sd-grid {
    display: grid;
    gap: 20px;
  }

  @media (min-width:1024px) {
    .sd-choose .sd-grid {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  .sd-choose .sd-card {
    position: relative;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 18px;
    padding: 22px;
    color: inherit;
    text-decoration: none;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  }

  /* Alone ROSSO sotto la card (fallback senza color-mix) */
  .sd-choose .sd-card::before {
    content: "";
    position: absolute;
    inset: -3px;
    border-radius: 20px;
    z-index: -1;
    pointer-events: none;
    background: radial-gradient(120% 120% at 50% 100%,
        rgba(212, 0, 0, .70) 0%,
        rgba(212, 0, 0, .18) 45%,
        transparent 70%);
    transform: translateY(6px) scale(.98);
    filter: blur(14px);
    opacity: .35;
    transition: opacity .2s, transform .2s, filter .2s;
  }

  /* Se supportato, usa esattamente var(--sd-accent) col color-mix */
  @supports (background: color-mix(in srgb, red 50%, transparent)) {
    .sd-choose .sd-card::before {
      background: radial-gradient(120% 120% at 50% 100%,
          color-mix(in srgb, var(--sd-accent) 70%, transparent) 0%,
          color-mix(in srgb, var(--sd-accent) 18%, transparent) 45%,
          transparent 70%);
    }
  }

  .sd-choose .sd-card:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
    border-color: rgba(255, 255, 255, .16);
  }

  /* === Icone: sfondo BIANCO + icona ROSSA (dimensioni originali) === */
  .sd-ico {
    width: 48px;
    /* come prima */
    height: 48px;
    /* come prima */
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    background: #ffffff;
    /* sfondo bianco */
    border: 1px solid #ffffff;
    /* bordo bianco pulito */
    box-shadow: 0 6px 16px -10px rgba(0, 0, 0, .6);
    color: var(--sd-accent);
    /* currentColor â†’ rosso */
  }

  /* Icone: ROSSE e dimensione originale */
  #perche-noi .sd-ico svg,
  #perche-noi .sd-ico svg * {
    width: 26px;
    /* come prima */
    height: 26px;
    /* come prima */
    stroke: var(--sd-accent) !important;
  }

  .sd-photo {
    width: 100%;
    height: 160px;
    object-fit: cover;
    border-radius: 12px;
    margin-bottom: 14px;
    display: block;
    border: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .25);
  }

  @media (min-width:640px) {
    .sd-photo {
      height: 180px;
    }
  }

  /* Sezione "Perché scegliere" – immagini quadrate */
  .sd-choose .sd-photo {
    height: auto;
    aspect-ratio: 1 / 1;
  }

  .sd-choose .sd-card h3 {
    margin: 0 0 .25rem;
    font-weight: 900;
    font-size: 1.15rem;
  }

  .sd-choose .sd-card p {
    margin: 0;
    color: rgba(255, 255, 255, .9);
  }

  @media (prefers-reduced-motion: reduce) {

    .sd-choose .sd-card,
    .sd-choose .sd-card::before {
      transition: none;
      transform: none;
    }
  }

/* ================= SEZIONE 6 ================= */
.pf-fleet-wrap {
  --bg-start: #202020;
  --bg-end: #111111;
  --card-bg: #1e1e1f;
  --text: #ffffff;
  --muted: #cfcfcf;
  --chip-bg: #2b2b2d;
  --chip-text: #ededed;
  --outline: #6b6b6b;
  --shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
  --radius: 22px;
  --rent-color: #D40000;
  --rent-pressed: #B80000;
  --buy-color: #6ecbff;
  --filter-bg: #141414;
  --filter-border: #2e2e2e;
  --filter-text: #e9e9e9;
  --filter-placeholder: #afafaf;
  background:
    radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-start), var(--bg-end));
  padding: 56px 0 36px;
  width: 100%;
  color: var(--text);
}

.pf-fleet-outer {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
  max-width: 100vw;
  padding-inline: 0;
}

.pf-stage {
  position: relative;
  max-width: min(1400px, 100%);
  margin: 0 auto;
  padding: 0 16px;
}

.pf-backdrop {
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 80% at 50% 10%, rgba(255,255,255,.06), transparent 65%);
  pointer-events: none;
  filter: blur(24px);
}

.pf-fleet-head {
  text-align: center;
  margin: 0 auto 8px;
  max-width: min(1280px, 100%);
  padding: 0 16px;
}

.pf-fleet-head h2 {
  color: #fff;
  font-weight: 800;
  font-size: clamp(28px, 4vw, 48px);
  margin: 0 0 6px;
  letter-spacing: .2px;
}

.pf-fleet-head p {
  margin: 0 16px 14px;
  color: var(--muted);
  font-size: clamp(14px, 2vw, 18px);
}

.pf-fleet-head .pf-accent { color: var(--rent-color); }
.pf-fleet-wrap.is-buy .pf-fleet-head .pf-accent { color: var(--buy-color); }

/* SWITCH */
.pf-switch.nav {
  display: block;
  width: min(460px, 92vw);
  margin: 12px auto 0;
  background: #1a1a1a;
  padding: 6px clamp(18px, 4vw, 40px);
  border-radius: 999px;
  border: 1px solid #2e2e2e;
  position: relative;
  overflow: visible;
  box-shadow: 0 8px 22px -12px rgba(0, 0, 0, .5) inset;
}

.nav__links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 1;
}

.nav__link { display: flex; align-items: center; }

.nav__link button {
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: #e9e9e9;
  opacity: .9;
  font-weight: 800;
  padding-block: 16px;
  padding-inline: 0;
  font-size: 15px;
  line-height: 1;
  border-radius: 999px;
  position: relative;
  z-index: 2;
  transition: opacity .2s, transform .02s, text-shadow .2s, color .2s;
  text-align: center;
}

.nav__link .label { display: inline-block; padding: 0 2px; }
.nav__link button:active { transform: translateY(1px); }

.nav__link[data-mode="rent"].active button {
  color: var(--rent-color);
  text-shadow: 0 0 10px color-mix(in srgb, var(--rent-color) 70%, transparent), 0 0 24px color-mix(in srgb, var(--rent-color) 45%, transparent);
}

.nav__link[data-mode="buy"].active button {
  color: var(--buy-color);
  text-shadow: 0 0 10px color-mix(in srgb, var(--buy-color) 70%, transparent), 0 0 24px color-mix(in srgb, var(--buy-color) 45%, transparent);
}

.nav__toggle {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  position: relative;
  z-index: 2;
}

.toggle-container {
  --knob-size: 1.6em;
  display: flex;
  justify-content: center;
  position: relative;
  transform: translateY(2px);
  z-index: 3;
}

.toggle-input {
  position: absolute;
  z-index: 2;
  bottom: 132.5%;
  border-radius: 50%;
  transform: rotate(-25deg);
  transform-origin: 50% 4.75em;
  width: var(--knob-size);
  height: var(--knob-size);
  opacity: 0;
  font: inherit;
  transition: transform .24s cubic-bezier(.65, 1.35, .5, 1);
  cursor: pointer;
}

.toggle-input:checked { transform: rotate(25deg); }

.toggle-handle-wrapper {
  position: absolute;
  z-index: 1;
  bottom: -135%;
  -webkit-mask-image: linear-gradient(to bottom, #000 62.125%, transparent 50%);
  mask-image: linear-gradient(to bottom, #000 62.125%, transparent 50%);
  width: 200%;
  overflow: hidden;
}

.toggle-handle {
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: rotate(-25deg);
  transform-origin: bottom center;
  transition: transform .24s cubic-bezier(.65, 1.35, .5, 1);
}

.toggle-input:checked + .toggle-handle-wrapper > .toggle-handle { transform: rotate(25deg); }

.toggle-handle-knob {
  position: relative;
  z-index: 1;
  border-radius: 50%;
  width: var(--knob-size);
  height: var(--knob-size);
  background: radial-gradient(60% 60% at 30% 30%, color-mix(in srgb, var(--rent-color) 92%, #000 8%) 0%, var(--rent-color) 55%, color-mix(in srgb, var(--rent-color) 60%, #000 40%) 100%);
  transition: transform .24s cubic-bezier(.65, 1.35, .5, 1), background .2s ease;
}

.pf-fleet-wrap.is-buy .toggle-handle-knob {
  background: radial-gradient(60% 60% at 30% 30%, color-mix(in srgb, var(--buy-color) 92%, #000 8%) 0%, var(--buy-color) 55%, color-mix(in srgb, var(--buy-color) 60%, #000 40%) 100%);
}

.toggle-handle-bar-wrapper { position: relative; width: .5em; height: 3em; }

.toggle-handle-bar {
  position: absolute;
  top: calc(var(--knob-size)/2 * -1);
  left: 0;
  width: 100%;
  height: calc(100% + var(--knob-size)/2);
  background-image: linear-gradient(to right, #777475, #a4a4a4, #bbb 45% 55%, #a4a4a4, #777475);
  background-position-x: .06125em;
  transition: background-position-x .24s cubic-bezier(.65, 1.35, .5, 1);
  box-shadow: inset 0 1em .25em rgb(0 0 0 / .35);
}

.toggle-input:checked + .toggle-handle-wrapper .toggle-handle-bar { background-position-x: -.06125em; }

.toggle-base {
  position: relative;
  border-radius: 3.125em;
  padding: .25em;
  width: 3.5em;
  height: 1.125em;
  background-color: #dcdcdc;
  background-image: linear-gradient(to bottom, #ffffff, #cfcfcf);
  box-shadow: 0 -.25em .5em #fff, 0 .25em .5em #bfbfbf;
}

.toggle-base-inside {
  position: relative;
  border-radius: inherit;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to bottom, #a6a6a6, #7d7d7d);
  box-shadow: inset 0 .0625em rgb(255 255 255 / .2), inset 0 -.03125em rgb(255 255 255 / 1), inset 0 -.0625em .25em rgb(0 0 0 / .1);
}

/* STAGE / CARDS */
.pf-fleet {
  position: relative;
  z-index: 1;
  width: 100%;
  padding-top: 12px;
  padding-bottom: 56px;
  overflow: visible !important;
  contain: layout;
}

@supports (-webkit-touch-callout: none) {
  .pf-fleet { contain: none; }
}

.pf-stage,
.swiper.pf-fleet,
.pf-fleet .swiper-wrapper,
.pf-fleet .swiper-slide { overflow: visible !important; }

.pf-fleet .swiper-wrapper {
  padding: 5.75rem 0;
  will-change: transform;
  transform: translateZ(0);
}

.pf-fleet .swiper-slide {
  position: relative;
  border-radius: var(--radius);
}

.pf-stage.mode-rent .pf-fleet .swiper-slide::before {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  inset: -10% -6% -16% -6%;
  border-radius: calc(var(--radius) + 22px);
  filter: blur(30px);
  opacity: .34;
  transition: .35s;
  transform: translateZ(0);
  background: radial-gradient(65% 75% at 50% 38%, color-mix(in srgb, var(--rent-color) 50%, transparent) 0%, color-mix(in srgb, var(--rent-color) 18%, transparent) 46%, transparent 72%);
}

.pf-stage.mode-rent .pf-fleet .swiper-slide::after {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  left: 50%;
  transform: translateX(-50%) translateZ(0);
  bottom: -10%;
  width: 120%;
  height: 38%;
  filter: blur(28px);
  opacity: .30;
  border-radius: 50%;
  background: radial-gradient(60% 100% at 50% 0%, color-mix(in srgb, var(--rent-color) 42%, transparent) 0%, color-mix(in srgb, var(--rent-color) 14%, transparent) 55%, transparent 80%);
}

.pf-stage.mode-buy .pf-fleet .swiper-slide::before {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  inset: -10% -6% -16% -6%;
  border-radius: calc(var(--radius) + 22px);
  filter: blur(30px);
  opacity: .34;
  transition: .35s;
  transform: translateZ(0);
  background: radial-gradient(65% 75% at 50% 38%, color-mix(in srgb, var(--buy-color) 48%, transparent) 0%, color-mix(in srgb, var(--buy-color) 18%, transparent) 46%, transparent 72%);
}

.pf-stage.mode-buy .pf-fleet .swiper-slide::after {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  left: 50%;
  transform: translateX(-50%) translateZ(0);
  bottom: -10%;
  width: 120%;
  height: 38%;
  filter: blur(28px);
  opacity: .30;
  border-radius: 50%;
  background: radial-gradient(60% 100% at 50% 0%, color-mix(in srgb, var(--buy-color) 38%, transparent) 0%, color-mix(in srgb, var(--buy-color) 12%, transparent) 55%, transparent 80%);
}

.pf-fleet .swiper-slide .pf-card {
  position: relative;
  z-index: 1;
  background: var(--card-bg);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
  will-change: transform;
}

.pf-card img {
  display: block;
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  backface-visibility: hidden;
  transform: translateZ(0);
}

.pf-card .info {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -100%;
  opacity: 0;
  padding: 12px 140px 12px 12px;
  display: block;
  background: linear-gradient(0deg, rgba(10, 10, 10, .78) 0%, rgba(10, 10, 10, .28) 34%, rgba(10, 10, 10, 0) 56%);
  color: #f1f1f1;
  transition: bottom .35s ease, opacity .35s ease;
  border-radius: 0 0 var(--radius) var(--radius);
  pointer-events: none;
}

.swiper-slide.swiper-slide-active .pf-card .info {
  bottom: 0;
  opacity: 1;
  backdrop-filter: blur(2px);
  pointer-events: auto;
}

.pf-card .info .chips { display: none !important; }

.pf-card .info h3 {
  margin: 0 0 2px;
  font-size: 20px;
  font-weight: 700;
}

.pf-card .info .price {
  margin: 0;
  color: #e9e9e9;
  font-size: 16px;
}

.pf-card .info .price strong { font-size: 22px; font-weight: 800; }

.pf-card .info .actions {
  position: absolute;
  right: 12px;
  bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}

.pf-card .info .actions .btn {
  padding: 10px 16px;
  font-size: 15px;
  border-radius: 12px;
  line-height: 1;
}

@media (max-width:360px) {
  .pf-card .info { padding-right: 128px; }
  .pf-card .info .actions .btn { padding: 10px 14px; font-size: 14px; }
}

.actions { display: flex; gap: 10px; align-items: center; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 800;
  font-size: 15px;
  line-height: 1;
  transition: transform .05s, box-shadow .15s, background .15s, color .15s;
  box-shadow: 0 10px 18px -12px rgba(0, 0, 0, .8);
}

.btn-primary { color: #fff; }
.btn--rent.btn-primary { background: var(--rent-color); }
.btn--rent.btn-primary:active { background: var(--rent-pressed); transform: translateY(1px); }
.btn--buy.btn-primary { background: var(--buy-color); color: #fff; }
.btn--buy.btn-primary:active { background: color-mix(in srgb, var(--buy-color) 85%, #000 15%); transform: translateY(1px); }

.btn-secondary { background: #2a2a2a; color: #fff; border: 2px solid var(--outline); }
.btn-secondary:active { transform: translateY(1px); }

.pf-filter {
  position: relative;
  width: min(460px, 92vw);
  margin: 12px auto 0;
}

.pf-filter__input {
  width: 100%;
  appearance: none;
  border: 1px solid var(--filter-border);
  background: var(--filter-bg) !important;
  color: var(--filter-text) !important;
  border-radius: 12px;
  padding: 12px 44px 12px 14px;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .2px;
  outline: none;
  box-shadow: 0 8px 18px -12px rgba(0, 0, 0, .5) inset;
  caret-color: var(--filter-text);
}

.pf-filter__input:hover,
.pf-filter__input:focus,
.pf-filter__input:focus-visible,
.pf-filter__input:active {
  background: var(--filter-bg) !important;
  color: var(--filter-text) !important;
  border-color: var(--filter-border);
  outline: none;
}

.pf-filter__input::placeholder { color: var(--filter-placeholder); font-weight: 600; }

.pf-filter__clear {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--filter-border);
  background: #222;
  color: #ddd;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
  transition: opacity .15s, transform .02s;
}

@media (max-width:639px) {
  .pf-fleet .swiper-wrapper { padding-top: calc(5.75rem - 40px); padding-bottom: 0; }
  .pf-fleet-wrap { padding-bottom: 0 !important; }
  .pf-fleet { padding-bottom: 80px !important; }
}

@media (min-width:640px) {
  .pf-fleet { padding-bottom: 6px; }
}/* ================= SEZIONE 7 ================= */
:root {
    --sd-accent: var(--pf-sdv-orange, #FF7A00);
    --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
    --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
  }

.sd-faq {
    background:
      var(--sd-bg-radial),
      var(--sd-bg-linear);
    color: #fff;
    padding: 72px 0;
  }

  .sd-faq .sd-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 18px;
  }

  .sd-faq .sd-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .sd-faq .sd-title {
    margin: 0 0 .35em;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2rem, 5vw, 3rem);
  }

  /* parola in arancione (default) */
  .sd-accent {
    color: var(--sd-accent);
  }

  /* OVERRIDE MIRATO: solo "frequenti" nel titolo in Rosso Ferrari */
  #faq .sd-title .sd-accent {
    color: #D40000 !important;
  }

  .sd-faq .sd-subtitle {
    margin: 0;
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1rem, 2vw, 1.125rem);
  }

  /* Layout a due colonne */
  .sd-faq__cols {
    display: grid;
    gap: 18px 22px;
    grid-template-columns: 1fr;
    /* mobile: una colonna */
  }

  @media (min-width: 960px) {
    .sd-faq__cols {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    /* desktop: due colonne */
  }

  .sd-faq__col details {
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 16px;
    padding: 18px 22px;
    box-shadow: 0 24px 36px -28px rgba(0,0,0,.6);
  }

  .sd-faq__col details+details {
    margin-top: 14px;
  }

  /* spaziatura verticale dentro la colonna */
  .sd-faq summary {
    cursor: pointer;
    list-style: none;
    font-weight: 850;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: clamp(1.05rem, 2.2vw, 1.25rem);
    color: #fff;
    /* base */
    -webkit-tap-highlight-color: rgba(255, 255, 255, .15);
  }

  .sd-faq summary::-webkit-details-marker {
    display: none;
  }

  /* Mantieni il testo del summary sempre bianco, in tutti gli stati */
  .sd-faq details>summary,
  .sd-faq details>summary *,
  .sd-faq details>summary:hover,
  .sd-faq details>summary:active,
  .sd-faq details>summary:focus,
  .sd-faq details[open]>summary {
    color: #fff !important;
  }

  .sd-faq details>summary:focus-visible {
    outline: 2px solid var(--sd-accent);
    outline-offset: 4px;
    border-radius: 8px;
  }

  .sd-caret {
    transition: transform .2s ease;
  }

  details[open] .sd-caret {
    transform: rotate(180deg);
  }

  .sd-faq p {
    margin: 10px 0 0;
    color: rgba(255, 255, 255, .9);
  }

  @media (prefers-reduced-motion: reduce) {
    .sd-caret {
      transition: none;
    }
  }

/* ================= SEZIONE 8 ================= */
:root {
    --sd-accent: var(--pf-sdv-orange, #FF7A00);
  }

  /* Unica modifica: forzo lâ€™accento a Rosso Ferrari SOLO in questa sezione */
  .sd-coverage {
    --sd-accent: #D40000;
  }

  .sd-coverage {
    background: var(--sd-bg-radial), var(--sd-bg-linear);
    color: #fff;
    padding: 72px 0;
  }

  .sd-coverage .sd-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
  }

  .sd-coverage .sd-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .sd-coverage .sd-title {
    margin: 0 0 .35em;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2rem, 5vw, 3rem);
  }

  /* parola accentata: ora prenderÃ  il Rosso Ferrari */
  .sd-accent {
    color: var(--sd-accent);
  }

  .sd-coverage .sd-subtitle {
    margin: 0;
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1rem, 2vw, 1.125rem);
  }

  /* WRAP: mappa full width sopra, card in riga sotto */
  .sd-coverage__wrap {
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
    /* una sola colonna: la mappa occupa tutta la larghezza */
    align-items: start;
  }

  /* MAPPA */
  .sd-gmap-wrap {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .08);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
  }

  .sd-gmap {
    display: block;
    width: 100%;
    height: 420px;
    border: 0;
    filter: saturate(105%) contrast(105%);
  }

  /* Schede info (in riga sotto la mappa su desktop) */
  .sd-list {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
    /* mobile: in colonna */
  }

  @media (min-width:1024px) {
    .sd-list {
      grid-template-columns: repeat(3, 1fr);
      /* desktop: una riga con 3 card */
    }
  }

  .sd-card {
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 18px;
    padding: 18px;
  }

  .sd-card h3 {
    margin: 0 0 .25rem;
    font-weight: 900;
    font-size: 1.15rem;
  }

  .sd-card p {
    margin: 0;
    color: rgba(255, 255, 255, .9);
  }

  /* Link e pulsanti */
  .sd-link {
    color: #fff;
    text-decoration: none;
    border-bottom: 1px dashed rgba(255, 255, 255, .5);
  }

  .sd-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
  }

  .sd-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 10px 14px;
    border-radius: 12px;
    font-weight: 700;
    text-decoration: none;
    border: 2px solid transparent;
  }

  .sd-btn--accent {
    background: var(--sd-accent);
    color: #fff;
  }

  .sd-btn--ghost {
    background: rgba(255, 255, 255, .1);
    color: #fff;
    border-color: rgba(255, 255, 255, .3);
  }

  .sd-btn--ghost:hover {
    background: rgba(255, 255, 255, .2);
  }

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

/* ================= SEZIONE 4: COME LAVORIAMO ================= */
#come-lavoriamo {
  --accent: #D40000;
  --text: #fff;
  --muted: rgba(255, 255, 255, .82);
  --panel: #131313;
  --line: rgba(255, 255, 255, .12);
  --radius: 18px;
  --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
  background: linear-gradient(180deg, #0c0c0d, #141415);
  color: var(--text);
  padding: 60px 0;
}

#come-lavoriamo .sd-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

#come-lavoriamo .sd-header {
  text-align: center;
  margin-bottom: 12px;
}

#come-lavoriamo .sd-title {
  margin: 0 0 8px;
  font-weight: 900;
  letter-spacing: -.02em;
  font-size: clamp(1.8rem, 3.6vw, 2.4rem);
}

#come-lavoriamo .sd-subtitle {
  margin: 0;
  color: var(--muted);
  font-weight: 600;
}

#come-lavoriamo .sd-accent { color: var(--accent); }

#come-lavoriamo .sd-process__grid {
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
  margin-top: 16px;
}

@media(min-width:900px) {
  #come-lavoriamo .sd-process__grid { grid-template-columns: repeat(4, 1fr); }
}

#come-lavoriamo .sd-step {
  position: relative;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 12px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow: hidden;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

#come-lavoriamo .sd-step::before {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: calc(var(--radius) + 4px);
  background: radial-gradient(120% 120% at 50% 100%,
      rgba(212, 0, 0, .55) 0%,
      rgba(212, 0, 0, .12) 45%,
      transparent 70%);
  z-index: -1;
  transform: translateY(6px) scale(.985);
  filter: blur(14px);
  opacity: 0;
  transition: opacity .18s ease, transform .18s ease, filter .18s ease;
  pointer-events: none;
}

#come-lavoriamo .sd-step:hover {
  transform: translateY(-1px) scale(1.01);
  border-color: rgba(255, 255, 255, .16);
  box-shadow: 0 14px 30px rgba(0, 0, 0, .34);
}

#come-lavoriamo .sd-step:hover::before {
  opacity: .55;
  transform: translateY(2px) scale(1);
  filter: blur(10px);
}

#come-lavoriamo .sd-step__num {
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: #fff;
  color: var(--accent);
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
}

#come-lavoriamo .sd-step__icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border-radius: 12px;
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .08);
}

#come-lavoriamo .sd-step h3 {
  margin: .15rem 0 .25rem;
  font-weight: 800;
  font-size: 1.1rem;
}

#come-lavoriamo .sd-step p {
  margin: 0;
  color: var(--muted);
}

@media (prefers-reduced-motion: reduce) {
  #come-lavoriamo .sd-step,
  #come-lavoriamo .sd-step::before { transition: none; transform: none; filter: none; }
}

/* ================= SEZIONE 6: CONSEGNE MEMORABILI ================= */
#consegne {
  --accent: #D40000;
  --text: #fff;
  --muted: rgba(255, 255, 255, .86);
  --panel: #131313;
  --line: rgba(255, 255, 255, .12);
  --radius: 18px;
  --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
  background: linear-gradient(180deg, #0e0e10, #161618);
  color: var(--text);
  padding: 56px 0;
}

#consegne .sd-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

#consegne .sd-header { text-align: center; margin-bottom: 12px; }
#consegne .sd-title { margin: 0 0 8px; font-weight: 900; letter-spacing: -.02em; font-size: clamp(1.8rem, 3.6vw, 2.4rem); }
#consegne .sd-subtitle { margin: 0; color: var(--muted); font-weight: 600; }
#consegne .sd-accent { color: var(--accent); }

#consegne .sd-ig__grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr;
  margin-top: 16px;
}

@media(min-width:900px) {
  #consegne .sd-ig__grid { grid-template-columns: repeat(3, 1fr); }
}

#consegne .sd-ig__card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
}

#consegne .sd-ig__media { position: relative; background: #000; }
#consegne .sd-ig__video { display: block; width: 100%; height: auto; aspect-ratio: 16/9; object-fit: cover; background: #000; }
#consegne .sd-ig__meta { padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
#consegne .sd-ig__meta span { font-weight: 800; }
#consegne .sd-ig__meta a { color: #fff; font-weight: 700; text-decoration: none; }
#consegne .sd-ig__meta a:hover { color: var(--accent); }

/* ================= SEZIONE 9: MAPPA ================= */
#dove-trovarci {
  --accent: #D40000;
  --text: #fff;
  --muted: rgba(255, 255, 255, .82);
  background: linear-gradient(180deg, #0b0b0c, #101013);
  color: var(--text);
  padding: 56px 0;
}

#dove-trovarci .sd-map__grid {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
}

@media(min-width:900px) {
  #dove-trovarci .sd-map__grid { grid-template-columns: 1fr 1.1fr; align-items: stretch; }
}

#dove-trovarci .sd-map__info {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 20px 32px -18px rgba(0,0,0,.55);
}

#dove-trovarci .sd-title { margin: 0 0 8px; font-weight: 900; letter-spacing: -.02em; font-size: clamp(1.8rem, 3.6vw, 2.4rem); }
#dove-trovarci .sd-subtitle { margin: 0 0 10px; color: var(--muted); font-weight: 600; }
#dove-trovarci .sd-accent { color: var(--accent); }

#dove-trovarci .sd-map__contacts {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 6px;
}

#dove-trovarci .sd-map__contacts a { color: #fff; text-decoration: none; font-weight: 700; }
#dove-trovarci .sd-map__contacts a:hover { color: var(--accent); }

#dove-trovarci .sd-map__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, .2);
  background: #1a1a1a;
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  transition: transform .1s, box-shadow .15s;
}

#dove-trovarci .sd-map__cta:hover { transform: translateY(-1px); box-shadow: 0 14px 30px rgba(0,0,0,.34); }

#dove-trovarci .sd-map__frame {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 20px 32px -18px rgba(0,0,0,.55);
  border: 1px solid rgba(255, 255, 255, .08);
}

#dove-trovarci iframe { width: 100%; min-height: 320px; height: 100%; border: 0; display: block; }

/* Bottom */
#af-footer .af-bottom {
  border-top: 0;
  padding: 18px 0;
  margin-top: 0;
}

#af-footer .af-bottom .wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

/* Some pages use a single node with both classes: <div class="af-bottom wrap"> */
#af-footer .af-bottom.wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

@media (min-width:768px) {
  #af-footer .af-bottom .wrap {
    flex-direction: row;
  }

  #af-footer .af-bottom.wrap {
    flex-direction: row;
  }
}

#af-footer .af-copy {
  font-size: 14px;
  color: var(--muted);
}

#af-footer .af-legal {
  display: flex;
  gap: 16px;
  align-items: center;
}

#af-footer .af-legal a {
  font-size: 14px;
}

/* ===== Mobile: rimuove highlight blu (tap/focus) nella Flotta in evidenza ===== */
@media (max-width: 760px) {
  .pf-fleet-wrap a,
  .pf-fleet-wrap button,
  .pf-fleet-wrap input,
  .pf-fleet-wrap label,
  .pf-fleet-wrap .toggle-container,
  .pf-fleet-wrap .toggle-container *,
  .pf-fleet-wrap .pf-card,
  .pf-fleet-wrap .pf-card * {
    -webkit-tap-highlight-color: transparent;
  }

  .pf-fleet-wrap a:focus,
  .pf-fleet-wrap a:focus-visible,
  .pf-fleet-wrap button:focus,
  .pf-fleet-wrap button:focus-visible,
  .pf-fleet-wrap input:focus,
  .pf-fleet-wrap input:focus-visible,
  .pf-fleet-wrap label:focus,
  .pf-fleet-wrap label:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  /* Android: rimuove il riquadro blu del toggle (input invisibile) */
  .pf-fleet-wrap .toggle-input {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* ===== Mobile: rimuove highlight grigio (tap/focus) nelle FAQ ===== */
@media (max-width: 760px) {
  #faq summary,
  #faq summary * {
    -webkit-tap-highlight-color: transparent;
  }

  #faq summary:focus,
  #faq summary:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }
}


/* === pages/lavaggio.css === */
﻿/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 86px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1320px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 136px;
      height: 50px;
      aspect-ratio: 136/50;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
/* Accent locale alla sezione (non tocca il resto della pagina) */
  .sd-hero {
    --sd-accent: #D40000;
  }

  /* Ferrari Red */

  /* Anchor scroll (header fisso) */
  html { scroll-behavior: smooth; }
  #wash-pricing,
  #wash-form { scroll-margin-top: calc(var(--pf-sdv-header-h, 86px) + 12px); }

  /* ===== Base: DESKTOP invariato ===== */
  .sd-hero {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    /* desktop identico all'originale */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

.sd-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.sd-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  background: #000;
}

/* Safety: forza il video a coprire sempre il container */
.sd-hero__video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

  .sd-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, .70), rgba(0, 0, 0, .50), rgba(0, 0, 0, .70));
    pointer-events: none;
  }

  .sd-hero__content {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    padding-inline: 1rem;
    text-align: center;
  }

  .sd-hero__wrap {
    max-width: 64rem;
    margin: 0 auto;
  }

  /* Titoli */
  .sd-hero__title {
    margin: 0 0 .5em;
    color: #fff;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
  }

  .sd-hero__title .sd-primary {
    color: var(--sd-accent);
  }

  .sd-hero__subtitle {
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1.125rem, 2.2vw, 1.5rem);
    margin: 0 0 1.25rem;
  }

  .sd-hero__subtitle .sd-line {
    display: block;
    white-space: nowrap;
  }

  /* Azioni */
  .sd-hero__actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    padding-top: 1rem;
  }

  /* Mobile: niente rettangoli blu su tap dei bottoni hero (Android/iOS) */
  @media (max-width: 1023px) {
    .sd-hero__actions .sd-btn,
    .sd-hero__actions .sd-btn * {
      -webkit-tap-highlight-color: transparent !important;
    }

    .sd-hero__actions .sd-btn {
      -webkit-touch-callout: none;
      -webkit-user-select: none;
      user-select: none;
    }

    .sd-hero__actions .sd-btn:focus,
    .sd-hero__actions .sd-btn:focus-visible,
    .sd-hero__actions .sd-btn:active {
      outline: none !important;
      box-shadow: none !important;
    }
  }

  @media (min-width:640px) {
    .sd-hero__actions {
      flex-direction: row;
    }
  }

  .sd-btn {
    --_h: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 0 2rem;
    height: var(--_h);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 1.125rem;
    text-decoration: none;
    border: 2px solid transparent;
    transition: transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    line-height: 1;
    white-space: nowrap;
  }

  .sd-btn--primary {
    background: #fff;
    color: var(--sd-accent);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .2);
  }

  .sd-btn--primary::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(0, 0, 0, 0), rgba(255, 255, 255, .3), rgba(0, 0, 0, 0), transparent);
    transform: translateX(-100%);
    transition: transform 1s;
  }

  .sd-btn--primary:hover::before {
    transform: translateX(100%);
  }

  .sd-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
  }

  .sd-btn--ghost {
    background: rgba(255, 255, 255, .10);
    color: #fff;
    border-color: rgba(255, 255, 255, .30);
    box-shadow: 0 6px 20px rgba(0, 0, 0, .15);
    backdrop-filter: saturate(1.2) blur(.5px);
  }

  .sd-btn--ghost:hover {
    background: rgba(255, 255, 255, .20);
    transform: translateY(-1px);
  }

  .sd-icon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }

  /* Scroll cue */
  .sd-scroll {
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 10;
  }

  .sd-scroll__mouse {
    width: 24px;
    height: 40px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, .5);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 8px;
  }

  .sd-scroll__dot {
    width: 4px;
    height: 12px;
    background: rgba(255, 255, 255, .7);
    border-radius: 999px;
    animation: sd-bounce 1s infinite alternate;
  }

  @keyframes sd-bounce {
    from {
      transform: translateY(0);
      opacity: 1;
    }

    to {
      transform: translateY(6px);
      opacity: .6;
    }
  }

  @media (prefers-reduced-motion:reduce) {

    .sd-btn,
    .sd-btn::before,
    .sd-scroll__dot {
      transition: none;
      animation: none;
    }

    .sd-hero__video {
      animation: none;
    }
  }

  /* Override anti-arancione */
  .sd-hero .sd-primary {
    color: #D40000 !important;
  }

  .sd-hero .sd-btn--primary {
    color: #D40000 !important;
  }

  .sd-hero .sd-btn--primary .sd-icon {
    stroke: currentColor;
    fill: none;
  }

  /* ===== SOLO MOBILE (â‰¤639px): variante tight ===== */
  @media (max-width:639px) {
      .sd-hero {
      min-height: 85svh;
      }

    .sd-hero--tight {
      min-height: 96svh;
    }

    .sd-hero--tight .sd-hero__wrap {
      transform: translateY(-7svh);
    }

    .sd-hero--tight .sd-hero__title {
      margin-bottom: .4em;
    }

    .sd-hero--tight .sd-hero__subtitle {
      margin-bottom: .9rem;
    }

    .sd-hero__subtitle {
      font-size: clamp(.95rem, 3.6vw, 1.2rem);
      line-height: 1.35;
      margin-bottom: .75rem;
    }

    .sd-hero__subtitle .sd-line {
      white-space: normal;
    }

    .sd-hero__actions {
      flex-direction: row;
      gap: .75rem;
      padding-top: .5rem;
    }

    .sd-hero__actions .sd-btn {
      flex: 1 1 0;
      min-width: 0;
      height: 3rem;
      font-size: 1.05rem;
      padding: 0 1.25rem;
    }

    .sd-scroll {
      bottom: 1rem;
    }
  }

/* ================= SEZIONE 2 ================= */
#wash-pillars {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    #wash-pillars .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
      /* evita scroll orizzontale se il glow sborda */
    }

    /* Titolo sezione */
    #wash-pillars .pillars-head {
      text-align: center;
      margin: 0 0 18px;
    }

    #wash-pillars .pillars-title {
      margin: 0;
      font-weight: 800;
      letter-spacing: -.02em;
      line-height: 1.05;
      font-size: clamp(1.75rem, 4.4vw, 2.5rem);
      color: #fff;
    }

    /* "Dettagli" in ROSSO */
    #wash-pillars .pillars-title .accent {
      color: var(--accent);
    }

    #wash-pillars .pillars {
      display: grid;
      gap: 14px;
      grid-template-columns: 1fr;
    }

    @media(min-width:720px) {
      #wash-pillars .pillars {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    /* Card + glow (ora ROSSO) */
    #wash-pillars .pillar {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      transform: translateZ(0);
      transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    }

    /* alone ROSSO (fallback senza color-mix) */
    #wash-pillars .pillar::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 2px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .70) 0%,
          rgba(212, 0, 0, .18) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.98);
      filter: blur(14px);
      opacity: .35;
      transition: opacity .2s ease, transform .2s ease, filter .2s ease;
      pointer-events: none;
    }

    /* se supportato, usa var(--accent) precisa */
    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #wash-pillars .pillar::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 70%, transparent) 0%,
            color-mix(in srgb, var(--accent) 18%, transparent) 45%,
            transparent 70%);
      }
    }

    /* Hover/Focus: espansione glow */
    #wash-pillars .pillar:hover,
    #wash-pillars .pillar:focus-visible {
      transform: translateY(-2px) scale(1.02);
      box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
      border-color: rgba(255, 255, 255, .16);
      outline: none;
    }

    #wash-pillars .pillar:hover::before,
    #wash-pillars .pillar:focus-visible::before {
      opacity: .7;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* Icona / testi */
    #wash-pillars .pill-ico {
      width: 44px;
      height: 44px;
      border-radius: 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #ffffff;
      /* sfondo BIANCO */
      border: 1px solid #ffffff;
      /* bordo bianco pulito */
      margin-bottom: 10px;
    }

    /* icona ROSSA su sfondo bianco */
    #wash-pillars .pill-ico svg {
      width: 24px;
      height: 24px;
      color: var(--accent);
    }

    #wash-pillars h3 {
      margin: .1rem 0 .25rem;
      font-size: 1.15rem;
      font-weight: 900;
    }

    #wash-pillars p {
      margin: 0;
      color: var(--muted);
    }

    @media (prefers-reduced-motion:reduce) {

      #wash-pillars .pillar,
      #wash-pillars .pillar::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 3 ================= */
#wash-services {
      --accent: #D40000;
      /* Rosso Ferrari */
      --bg1: #0c0c0d;
      --bg2: #141415;
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --chip: #25262a;
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color: var(--text);
      background: linear-gradient(180deg, var(--bg1), var(--bg2));
      isolation: isolate;
      padding: 60px 0 60px;
    }

    #wash-services .container {
      max-width: 1400px;
      margin: 0 auto;
      padding: 0 24px;
    }

    #wash-services .sec-head {
      text-align: center;
      margin-bottom: 14px;
    }

    #wash-services h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(2rem, 3.8vw, 2.6rem);
    }

    /* parole in ROSSO (Pacchetti) */
    #wash-services .accent {
      color: var(--accent);
    }

    #wash-services p {
      margin: 0;
      color: var(--muted);
      font-weight: 700;
      font-size: 1rem;
    }

    #wash-services .svc-grid {
      margin-top: 20px;
      display: grid;
      gap: 18px;
      grid-template-columns: repeat(auto-fit, minmax(clamp(0px, 100%, 360px), 1fr));
    }

    /* Card stile Deposito */
#wash-services .svc-card {
  position: relative;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  /* altezza auto per lasciare spazio ai testi */
  max-width: 100%;
  box-sizing: border-box;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, opacity .15s ease;
  transform: translateZ(0);
}

/* Mobile: evita overflow orizzontale e allinea bene la griglia */
@media (max-width: 420px) {
  #wash-services .container {
    padding: 0 16px;
  }
  #wash-services .svc-grid {
    gap: 14px;
  }
}

    #wash-services .svc-card::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 4px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .65) 0%,
          rgba(212, 0, 0, .16) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.985);
      filter: blur(14px);
      opacity: .28;
      transition: opacity .18s ease, transform .18s ease, filter .18s ease;
      pointer-events: none;
    }

    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #wash-services .svc-card::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 65%, transparent) 0%,
            color-mix(in srgb, var(--accent) 16%, transparent) 45%,
            transparent 70%);
      }
    }

    #wash-services .svc-card:hover {
      transform: translateY(-1px) scale(1.01);
      border-color: rgba(255, 255, 255, .16);
      box-shadow: 0 18px 34px rgba(0, 0, 0, .36);
    }

    #wash-services .svc-card:hover::before {
      opacity: .55;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

#wash-services .svc-photo {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  max-height: 340px;
  object-fit: cover;
  display: block;
  background: #0b0b0b;
  transition: transform .3s ease;
}

    #wash-services .svc-body {
      padding: 14px 16px 16px;
      color: #fff;
      display: flex;
      flex-direction: column;
      gap: 8px;
      flex: 1 1 auto;
    }

    #wash-services .svc-body h3 {
      margin: 0;
      font-size: 1.2rem;
      font-weight: 900;
      letter-spacing: -.01em;
    }

    #wash-services .svc-body p {
      margin: 0;
      color: rgba(255, 255, 255, .9);
      font-weight: 600;
      line-height: 1.45;
      font-size: 1rem;
    }

    #wash-services .chip {
      display: inline-block;
      padding: 6px 12px;
      border-radius: 999px;
      background: #2c2d30;
      border: 1px solid rgba(255, 255, 255, .08);
      font-size: 12px;
      font-weight: 800;
      color: #ededed;
      margin-right: 8px;
      box-shadow: 0 6px 16px -10px rgba(0, 0, 0, .5);
    }

    @media (prefers-reduced-motion:reduce) {

      #wash-services .svc-card,
      #wash-services .svc-card::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 4 ================= */
#wash-form {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --panel2: #202124;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
    }

    #wash-form .accent {
      color: var(--accent)
    }

    #wash-form .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px
    }

    #wash-form .sec-head {
      text-align: center;
      margin-bottom: 10px
    }

    #wash-form h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem)
    }

    #wash-form p {
      margin: 0;
      color: var(--muted);
      font-weight: 600
    }

    /* Box + fix width 100% anche in anteprima tema/PageFly */
    #wash-form .formbox {
      background: var(--panel2);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      width: 100%
    }

    #wash-form .formbox>form {
      max-width: none !important;
      width: 100% !important;
      margin: 0 !important;
      display: block
    }

    /* Griglia 2 colonne piene */
    #wash-form .grid {
      display: grid;
      gap: 16px;
      grid-template-columns: 1fr
    }

    @media(min-width:980px) {
      #wash-form .grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr)
      }
    }

    /* Campi */
    #wash-form .field {
      display: flex;
      flex-direction: column;
      gap: 6px
    }

    #wash-form .label {
      font-weight: 800;
      font-size: 13px
    }

    #wash-form .input,
    #wash-form .textarea,
    #wash-form .select {
      width: 100%;
      min-height: 44px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #111;
      color: #fff;
      outline: none;
      box-shadow: inset 0 8px 18px -12px rgba(0, 0, 0, .5)
    }

    /* Placeholder bianchi */
    #wash-form .input::placeholder,
    #wash-form .textarea::placeholder {
      color: rgba(255, 255, 255, .92)
    }

    /* NOTE: a tutta riga sotto le due colonne */
    #wash-form .note-row {
      grid-column: 1/-1
    }

    #wash-form .textarea {
      min-height: 140px;
      resize: vertical
    }

    /* Toggle inline */
    #wash-form .toggle {
      display: flex;
      gap: 8px;
      flex-wrap: wrap
    }

    @media(min-width:980px) {
      #wash-form .toggle {
        flex-wrap: nowrap
      }
    }

    #wash-form .seg {
      flex: 1 1 0;
      min-width: 0;
      white-space: nowrap;
      text-align: center;
      padding: 10px 12px;
      border-radius: 10px;
      border: 1px solid var(--line);
      background: #111;
      cursor: pointer;
      font-weight: 800;
      color: #fff;
      transition: border-color .15s, background .15s, color .15s, transform .15s
    }

    /* Mobile: "Dimensione veicolo" su 2 righe (SUV/Grande a capo) per evitare testo che esce dai bottoni */
    @media (max-width: 560px) {
      #wash-form .toggle[aria-label="Dimensione veicolo"] .seg {
        flex: 1 1 calc(50% - 8px);
        min-width: 140px;
        padding: 10px 10px;
        font-size: 14px;
      }

      #wash-form .toggle[aria-label="Dimensione veicolo"] .seg:nth-child(3) {
        flex-basis: 100%;
      }

      #wash-form .toggle[aria-label="Vehicle size"] .seg {
        flex: 1 1 calc(50% - 8px);
        min-width: 140px;
        padding: 10px 10px;
        font-size: 14px;
      }

      #wash-form .toggle[aria-label="Vehicle size"] .seg:nth-child(3) {
        flex-basis: 100%;
      }
    }

    /* Stato selezionato: bottone BIANCO, testo ROSSO */
    #wash-form .seg[aria-pressed="true"] {
      background: #fff;
      border-color: var(--accent);
      color: var(--accent);
      box-shadow: 0 6px 18px -10px rgba(0, 0, 0, .5);
    }

    /* Checklist: spunta ROSSA + contenitore BIANCO quando checked */
    #wash-form .checks {
      display: grid;
      gap: 8px;
      grid-template-columns: 1fr
    }

    @media(min-width:560px) {
      #wash-form .checks {
        grid-template-columns: repeat(2, 1fr)
      }
    }

    #wash-form .check {
      display: flex;
      gap: 10px;
      align-items: center;
      background: #111;
      border: 1px solid var(--line);
      border-radius: 10px;
      padding: 10px 12px;
      transition: background .15s, border-color .15s, color .15s;
      width: 100%;
      color: #fff;
    }

    #wash-form .check input {
      width: 18px;
      height: 18px;
      accent-color: var(--accent);
      /* spunta ROSSA */
    }

    #wash-form .check:has(input:checked) {
      border-color: var(--accent);
      background: #fff;
      /* contenitore BIANCO */
      color: #0b0b0b;
      /* testo scuro su bianco */
    }

    /* Bottoni */
    #wash-form .actions-row {
      grid-column: 1/-1;
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      margin-top: 10px
    }

    /* Primario invertito: BIANCO con testo ROSSO */
    #wash-form .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 46px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid var(--accent);
      background: #ffffff;
      color: var(--accent);
      font-weight: 900;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
      text-decoration: none;
      cursor: pointer;
      transition: transform .15s ease, box-shadow .15s ease, background .15s ease
    }

    #wash-form .sc-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 12px 22px -12px rgba(0, 0, 0, .75)
    }

    /* Ghost invariato */
    #wash-form .sc-btn--ghost {
      background: #242424;
      border: 1px solid var(--line);
      color: #fff
    }

/* Mobile: niente rettangoli blu su tap dei bottoni form (Invia richiesta / Chiama ora) */
@media (max-width: 1023px) {
  #wash-form .sc-btn,
  #wash-form .sc-btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #wash-form .sc-btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #wash-form .sc-btn:focus,
  #wash-form .sc-btn:focus-visible,
  #wash-form .sc-btn:active {
    outline: none !important;
    box-shadow: none !important;
  }

  /* Anche i toggle "seg" (Dimensione/Pacchetto) */
  #wash-form .seg,
  #wash-form .seg * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #wash-form .seg {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #wash-form .seg:focus,
  #wash-form .seg:focus-visible,
  #wash-form .seg:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

    @media (prefers-reduced-motion: reduce) {

      #wash-form .seg,
      #wash-form .check,
      #wash-form .sc-btn {
        transition: none
      }
    }

/* ================= SEZIONE 5 ================= */
#wash-compare {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --line: rgba(255, 255, 255, .14);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    #wash-compare .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px
    }

    #wash-compare .sec-head {
      text-align: center;
      margin-bottom: 10px
    }

    #wash-compare h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem)
    }

    #wash-compare p {
      margin: 0;
      color: var(--muted);
      font-weight: 600
    }

    #wash-compare .accent {
      color: var(--accent)
    }

    /* griglia 3 elementi */
    #wash-compare .ba-grid {
      display: grid;
      gap: 16px;
      grid-template-columns: 1fr
    }

    @media (min-width:900px) {
      #wash-compare .ba-grid {
        grid-template-columns: repeat(3, 1fr)
      }
    }

    /* CARD: meno schiacciata (mobile/tablet 4:3, desktop 3:2) */
    #wash-compare .compare {
      position: relative;
      border: 1px solid var(--line);
      border-radius: 16px;
      overflow: hidden;
      background: #0b0b0b;
      aspect-ratio: 4 / 3;
      /* piÃ¹ alta su mobile/tablet */
    }

    @media (min-width:900px) {
      #wash-compare .compare {
        aspect-ratio: 3 / 2;
      }

      /* desktop ancora piÃ¹ alta rispetto al 16:9 */
    }

    /* immagini: riempiono la card */
    #wash-compare .compare img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover
    }

    /* Card 1: sposta leggermente l'immagine "Dopo" (crop più in alto e a sinistra) */
    #wash-compare .ba-grid > .compare:first-child .after img {
      object-position: 30% 15%;
    }

    #wash-compare .after {
      position: absolute;
      inset: 0;
      clip-path: inset(0 0 0 50%)
    }

    #wash-compare .slider {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 10px;
      margin: auto;
      width: min(460px, 92%);
      appearance: none;
      height: 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .2);
      outline: none
    }

    /* Thumb ROSSO (WebKit) */
    #wash-compare .slider::-webkit-slider-thumb {
      appearance: none;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--accent);
      border: 2px solid #111;
      box-shadow: 0 4px 16px rgba(0, 0, 0, .5);
      cursor: ew-resize
    }

    /* Thumb ROSSO (Firefox) */
    #wash-compare .slider::-moz-range-thumb {
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--accent);
      border: 2px solid #111;
      box-shadow: 0 4px 16px rgba(0, 0, 0, .5);
      cursor: ew-resize
    }

    #wash-compare .slider::-moz-range-track {
      height: 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .2);
    }

#wash-compare .cap {
  position: absolute;
  top: 12px;
  display: flex;
  gap: 8px;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
}

#wash-compare .cap--before {
  left: 12px;
}

#wash-compare .cap--after {
  right: 12px;
  left: auto;
}

#wash-compare .badge {
  padding: 6px 10px;
  border-radius: 999px;
      background: rgba(0, 0, 0, .5);
      backdrop-filter: blur(4px);
      border: 1px solid rgba(255, 255, 255, .18);
      font-size: 12px;
      font-weight: 800
    }

/* ================= SEZIONE 6 ================= */
#wash-process {
      /* ACCENTO ROSSO FERRARI */
      --accent: #D40000;

      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 16px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      isolation: isolate;
    }

    #wash-process .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
    }

    #wash-process .sec-head {
      text-align: center;
      margin-bottom: 14px;
    }

    #wash-process h2 {
      margin: 0 0 8px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
      color: #fff;
    }

    /* â€œfunziona?â€ in rosso */
    #wash-process .accent {
      color: var(--accent);
    }

    #wash-process p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    #wash-process .timeline {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media (min-width:900px) {
      #wash-process .timeline {
        grid-template-columns: repeat(4, 1fr);
      }
    }

    /* Card con glow ROSSO */
    #wash-process .step {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      transform: translateZ(0);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
      outline: none;
    }

    /* Fallback senza color-mix: rosso diretto */
    #wash-process .step::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 4px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .65) 0%,
          rgba(212, 0, 0, .16) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.985);
      filter: blur(14px);
      opacity: .28;
      /* tenue a riposo */
      transition: opacity .18s ease, transform .18s ease, filter .18s ease;
      pointer-events: none;
    }

    /* Se supportato: usa var(--accent) per il glow rosso */
    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      #wash-process .step::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 65%, transparent) 0%,
            color-mix(in srgb, var(--accent) 16%, transparent) 45%,
            transparent 70%);
      }
    }

    #wash-process .step:hover,
    #wash-process .step:focus-visible {
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 14px 30px rgba(0, 0, 0, .34);
      border-color: rgba(255, 255, 255, .16);
    }

    #wash-process .step:hover::before,
    #wash-process .step:focus-visible::before {
      opacity: .55;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* Badge numerati: SFONDO BIANCO, NUMERI ROSSI + bordo rosso */
    #wash-process .num {
      width: 32px;
      height: 32px;
      border-radius: 10px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #ffffff;
      color: var(--accent);
      border: 1px solid var(--accent);
      font-weight: 900;
      margin-bottom: 10px;
    }

    #wash-process h3 {
      margin: .1rem 0 .35rem;
      font-weight: 900;
    }

    #wash-process .step p {
      margin: 0;
      color: var(--muted);
    }

    @media (prefers-reduced-motion: reduce) {

      #wash-process .step,
      #wash-process .step::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 7 ================= */
#wash-pricing {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 28px 0;
    }

    #wash-pricing .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    #wash-pricing .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    #wash-pricing h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
    }

    /* parola "Listino" in ROSSO */
    #wash-pricing .accent {
      color: var(--accent);
    }

    #wash-pricing p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    #wash-pricing .price-grid {
      display: grid;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media(min-width:900px) {
      #wash-pricing .price-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    #wash-pricing .plan {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    #wash-pricing .plan header {
      padding: 16px;
      border-bottom: 1px solid var(--line);
    }

    #wash-pricing .plan h3 {
      margin: 0 0 4px;
      font-weight: 900;
    }

    #wash-pricing .subtitle {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    #wash-pricing .body {
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    #wash-pricing .price {
      font-weight: 900;
    }

    #wash-pricing .ul {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 8px;
    }

    #wash-pricing .ul li {
      display: flex;
      gap: 8px;
      align-items: flex-start;
    }

    /* Spunte ROSSE */
    #wash-pricing .ul li svg {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px;
    }

/* ================= SEZIONE 8 ================= */
#wash-gallery {
      --accent: var(--pf-sdv-orange, #FF7A00);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --line: rgba(255, 255, 255, .14);
      --radius: 16px;
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60 sopra / 60 sotto */
    }

    #wash-gallery .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
      /* sicurezza anti-artefatti */
    }

    #wash-gallery .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    #wash-gallery h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
    }

    /* SOLO la parola "lavorazione" in rosso Ferrari */
    #wash-gallery .accent {
      color: #D40000;
    }

    #wash-gallery p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* GRIGLIA: niente carosello nÃ© scroll orizzontale */
    #wash-gallery .snap {
      display: grid;
      grid-template-columns: 1fr;
      gap: 12px;
    }

    @media (min-width: 900px) {
      #wash-gallery .snap {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    #wash-gallery figure {
      margin: 0;
      position: relative;
      border-radius: var(--radius);
      overflow: hidden;
      border: 1px solid var(--line);
      background: #0b0b0b;
    }

    #wash-gallery img {
      width: 100%;
      height: 260px;
      object-fit: cover;
      display: block;
    }

    #wash-gallery figcaption {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      padding: 10px 12px;
      background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .72));
      font-weight: 800;
    }

/* ================= SEZIONE 9 ================= */
#wash-faq {
      --accent: #D40000;
      /* Rosso Ferrari per la parola "Domande" */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 14px;
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    #wash-faq .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    #wash-faq .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    #wash-faq h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
    }

    /* parola in ROSSO */
    #wash-faq .accent {
      color: var(--accent);
    }

    #wash-faq .faq {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #wash-faq .faq {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    #wash-faq .q {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
    }

    #wash-faq .q summary {
      list-style: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 14px 16px;
      font-weight: 900;
      color: var(--text);
    }

    #wash-faq .q summary::-webkit-details-marker {
      display: none;
    }

    #wash-faq .q .a {
      padding: 0 16px 14px;
      color: var(--muted);
    }

    #wash-faq .q[open] summary {
      border-bottom: 1px solid var(--line);
    }

    #wash-faq .caret {
      width: 18px;
      height: 18px;
      transform: rotate(0deg);
      transition: transform .15s ease;
    }

    #wash-faq .q[open] .caret {
      transform: rotate(180deg);
    }

/* Android: rimuove rettangoli blu (tap highlight/focus) sui summary FAQ */
@media (hover: none) and (pointer: coarse) {
  #wash-faq .q summary,
  #wash-faq .q summary * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }
  #wash-faq .q summary:focus,
  #wash-faq .q summary:focus-visible {
    outline: none;
    box-shadow: none;
  }
  #wash-faq .q summary:active {
    background: transparent;
  }
}

/* Mobile: fallback extra (alcuni Android non matchano pointer/hover correttamente) */
@media (max-width: 1023px) {
  #wash-faq summary,
  #wash-faq summary * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #wash-faq summary {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #wash-faq summary:focus,
  #wash-faq summary:focus-visible,
  #wash-faq summary:active {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
  }
}

/* Lavaggio: su mobile elimina rettangoli blu su qualunque elemento cliccabile (esclusi input/textarea) */
@media (hover: none) and (pointer: coarse) {
  html,
  body {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  body * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a,
  button,
  summary,
  [role="button"],
  [role="menuitem"],
  [tabindex]:not([tabindex="-1"]) {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  a *,
  button *,
  summary *,
  [role="button"] *,
  [role="menuitem"] * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a:focus,
  a:focus-visible,
  button:focus,
  button:focus-visible,
  summary:focus,
  summary:focus-visible,
  [role="button"]:focus,
  [role="button"]:focus-visible,
  [role="menuitem"]:focus,
  [role="menuitem"]:focus-visible,
  [tabindex]:not([tabindex="-1"]):focus,
  [tabindex]:not([tabindex="-1"]):focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  a:active,
  button:active,
  summary:active,
  [role="button"]:active,
  [role="menuitem"]:active,
  [tabindex]:not([tabindex="-1"]):active {
    background-color: transparent !important;
  }

  body :not(input):not(textarea)::selection {
    background: transparent;
  }
}

/* ================= SEZIONE 10 ================= */
#wash-cta {
      --accent: var(--pf-sdv-orange, #FF7A00);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      text-align: center;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    #wash-cta .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
    }

    #wash-cta .box {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
    }

    #wash-cta h3 {
      margin: 0 0 .35em;
      font-weight: 900;
      font-size: clamp(1.4rem, 3vw, 1.9rem);
    }

    #wash-cta p {
      margin: 0 0 .8rem;
      color: var(--muted);
      font-weight: 600;
    }

    #wash-cta .row {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: center;
    }

    #wash-cta .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 46px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid var(--accent);
      background: var(--accent);
      color: #0b0b0b;
      font-weight: 900;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
      text-decoration: none;
    }

    #wash-cta .sc-btn--ghost {
      background: #242424;
      border: 1px solid var(--line);
      color: #fff;
    }

    /* Variante richiesta: sfondo bianco, testo rosso Ferrari */
    #wash-cta .sc-btn--white {
      background: #ffffff;
      color: #D40000;
      border-color: #ffffff;
      /* niente bordo arancio */
    }

/* Mobile: niente rettangoli blu su tap dei bottoni CTA (Richiedi preventivo / Scrivici su WhatsApp) */
@media (max-width: 1023px) {
  #wash-cta .sc-btn,
  #wash-cta .sc-btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  #wash-cta .sc-btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  #wash-cta .sc-btn:focus,
  #wash-cta .sc-btn:focus-visible,
  #wash-cta .sc-btn:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

    /* Bottom */
    #af-footer .af-bottom {
      border-top: 0;
      padding: 18px 0;
      margin-top: 0;
    }

    #af-footer .af-bottom .wrap {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
    }

    @media (min-width:768px) {
      #af-footer .af-bottom .wrap {
        flex-direction: row;
      }
    }

    #af-footer .af-copy {
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-legal {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    #af-footer .af-legal a {
      font-size: 14px;
    }


/* === pages/legal.css === */
/* ================= LEGAL PAGES (Privacy/Cookie) ================= */
:root {
  --legal-accent: #D40000;
  --legal-bg1: #0c0c0d;
  --legal-bg2: #141415;
  --legal-panel: rgba(255, 255, 255, .04);
  --legal-line: rgba(255, 255, 255, .14);
  --legal-text: #fff;
  --legal-muted: rgba(255, 255, 255, .86);
  --legal-radius: 18px;
  --legal-shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
}

body {
  background: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%),
    linear-gradient(180deg, #202020, #111111);
  color: var(--legal-text);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.legal-hero {
  background: linear-gradient(180deg, var(--legal-bg1), var(--legal-bg2));
  padding-top: calc(clamp(28px, 5vw, 56px) + 100px);
  padding-bottom: clamp(28px, 5vw, 56px);
}

.legal-container {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 16px;
}

.legal-hero h1 {
  margin: 0 0 10px;
  font-weight: 900;
  letter-spacing: -.02em;
  font-size: clamp(2rem, 4.2vw, 3rem);
  line-height: 1.08;
}

.legal-hero .accent {
  color: var(--legal-accent);
}

.legal-hero p {
  margin: 0;
  color: var(--legal-muted);
  font-weight: 650;
  font-size: 1.05rem;
}

.legal-meta {
  margin-top: 14px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.legal-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .92);
  font-size: 12px;
  font-weight: 800;
}

.legal-content {
  padding: 22px 0 60px;
}

.legal-card {
  background: var(--legal-panel);
  border: 1px solid var(--legal-line);
  border-radius: var(--legal-radius);
  box-shadow: var(--legal-shadow);
  padding: clamp(16px, 2.4vw, 22px);
}

.legal-card h2 {
  margin: 0 0 8px;
  font-weight: 900;
  letter-spacing: -.01em;
  font-size: 1.35rem;
}

.legal-card h3 {
  margin: 18px 0 8px;
  font-weight: 900;
  letter-spacing: -.01em;
  font-size: 1.15rem;
}

.legal-card p {
  margin: 0 0 10px;
  color: rgba(255, 255, 255, .9);
  font-weight: 600;
  line-height: 1.6;
}

.legal-card ul {
  margin: 0 0 10px 18px;
  padding: 0;
  color: rgba(255, 255, 255, .9);
  font-weight: 650;
  line-height: 1.6;
}

.legal-card li {
  margin: 6px 0;
}

.legal-card a {
  color: #fff;
  text-decoration: underline;
  text-decoration-color: rgba(255, 255, 255, .35);
  text-underline-offset: 3px;
}

.legal-card a:hover {
  text-decoration-color: rgba(255, 255, 255, .8);
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 14px;
  overflow: hidden;
  margin: 10px 0 0;
}

.legal-table th,
.legal-table td {
  padding: 12px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, .10);
  vertical-align: top;
}

.legal-table th {
  text-align: left;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .9);
  background: rgba(0, 0, 0, .22);
}

.legal-table td {
  color: rgba(255, 255, 255, .88);
  font-weight: 600;
  line-height: 1.55;
}

@media (max-width: 560px) {
  .legal-table,
  .legal-table thead,
  .legal-table tbody,
  .legal-table th,
  .legal-table td,
  .legal-table tr {
    display: block;
  }

  .legal-table thead {
    display: none;
  }

  .legal-table tr {
    border-bottom: 1px solid rgba(255, 255, 255, .12);
  }

  .legal-table td {
    border-bottom: 0;
    padding: 10px 12px;
  }

  .legal-table td[data-label]::before {
    content: attr(data-label);
    display: block;
    font-size: 12px;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .75);
    margin-bottom: 6px;
    font-weight: 800;
  }
}


/* === pages/pagina-veicolo.css === */
/* styles.css — estratto da pagina veichle.txt */
/* Sezione 1: Scheda veicolo (PDP) */

:root {
      --brand-red: #D40000;
      --sc-bg: #0e0e0f;
      --sc-panel: #18181a;
      --sc-panel-2: #1f1f22;
      --sc-text: #ffffff;
      --sc-muted: rgba(255, 255, 255, .82);
      --sc-line: rgba(255, 255, 255, .18);
      --sc-shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      overflow: hidden;
      clip: rect(0 0 0 0);
      white-space: nowrap;
    }

    .pfpdp,
    .pfpdp * {
      box-sizing: border-box;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

.pfpdp {
  background:
    radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%),
    linear-gradient(180deg, #202020, #111111);
  color: var(--sc-text);
  padding-top: 20px;
}

.pfpdp__inner {
  max-width: 1700px;
  margin: 0 auto;
      padding: clamp(18px, 3vw, 28px) clamp(16px, 3.6vw, 28px) 40px;
    }

@media (max-width: 640px) {
  .pfpdp { padding-top: 6px; }
  .pfpdp__inner { padding-top: 12px; }
}

    /* ===== GRID ===== */
    .pfpdp__grid {
      --colL: 1.20fr;
      --colR: 0.80fr;
      display: grid;
      grid-template-columns: var(--colL) var(--colR);
      gap: clamp(20px, 3.2vw, 32px);
      align-items: start;
    }

    .pfpdp-left {
      display: flex;
      flex-direction: column;
      gap: 28px;
    }

    .pfpdp-right {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    /* ===== MOBILE HEADER ===== */
    .pfpdp-headMobile {
      display: none;
      margin-bottom: 6px;
    }

    .pfpdp-title--mobile {
      margin: 0 0 24px;
      font-size: clamp(30px, 9vw, 42px);
      line-height: 1.08;
      font-weight: 1000;
      letter-spacing: -.01em;
    }

    .pfpdp-price--mobile {
      display: inline-block;
      margin-top: 30px;
      border-radius: 14px;
      border: 1px solid rgba(212, 0, 0, .5);
      background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, .88));
      box-shadow: 0 12px 28px rgba(0, 0, 0, .45), inset 0 1px 0 rgba(255, 255, 255, .5);
      padding: 10px 14px;
    }

.pfpdp-price--mobile .pfpdp-price__val {
  color: var(--brand-red);
  font-weight: 1000;
  font-size: clamp(20px, 5.6vw, 28px);
  letter-spacing: .01em;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .7);
}

/* IVA note under price (if present) */
.pfpdp-price__vat {
  margin-top: 4px;
  font-size: 12px;
  color: #9ca3af;
}

/* Mobile: make "vendita" PDP title/price match rental styling */
@media (max-width: 640px) {
  .pfpdp-title--mobile {
    font-size: 46px;
    line-height: 1.08;
  }

  .pfpdp-price--mobile {
    padding: 10px 12px;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    width: fit-content;
    max-width: 300px;
  }

  .pfpdp-price--mobile .pfpdp-price__val {
    font-size: 22px;
    line-height: 1.1;
  }

  .pfpdp-price__vat {
    margin-top: 2px;
  }
}

@media (min-width: 480px) and (max-width: 640px) {
  .pfpdp-title--mobile { font-size: 52px; }
}

/* ===== GALLERY ===== */
.pfpdp-media-wrap {
  --nav-gutter: 44px;
  position: relative;
      margin: 0 var(--nav-gutter);
    }

    .pfpdp-media {
      position: relative;
      border-radius: 16px;
      overflow: hidden;
      border: 1px solid var(--sc-line);
      background: var(--sc-panel-2);
      box-shadow: var(--sc-shadow);
    }

    .pfpdp-media img {
      display: block;
      width: 100%;
      height: auto;
      aspect-ratio: 4/3;
      object-fit: cover;
      background: #050506;
      transition: transform .35s ease;
    }

    .pfpdp-media img:hover {
      transform: scale(1.01);
      cursor: zoom-in;
    }

    .pfpdp-media__nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 44px;
      height: 44px;
      border-radius: 999px;
      background: rgba(0, 0, 0, .72);
      color: #fff;
      border: 1px solid rgba(255, 255, 255, .22);
      box-shadow: 0 8px 18px rgba(0, 0, 0, .45);
      z-index: 3;
    }

    .pfpdp-media__nav--prev {
      left: calc(var(--nav-gutter) * -1 + 6px);
    }

    .pfpdp-media__nav--next {
      right: calc(var(--nav-gutter) * -1 + 6px);
    }

    .pfpdp-thumbs {
      margin: 10px 0 0;
      padding: 0;
      list-style: none;
      display: grid;
      gap: 10px;
      grid-template-columns: repeat(5, 1fr);
    }

    .pfpdp-thumb {
      position: relative;
      border-radius: 12px;
      overflow: hidden;
      border: 1px solid rgba(255, 255, 255, .18);
      background: var(--sc-panel-2);
      cursor: pointer;
    }

    .pfpdp-thumb img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
        aspect-ratio: 4/3;
        transition: opacity .2s ease;
    }

    .pfpdp-thumb.is-active {
      outline: 2px solid var(--brand-red);
      outline-offset: 2px;
    }

    .pfpdp-thumb--more::after {
      content: attr(data-more);
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      background: rgba(0, 0, 0, .5);
      color: #fff;
      font-weight: 1000;
      font-size: clamp(16px, 1.8vw, 20px);
    }

    /* ===== INFO DESTRA ===== */
    .pfpdp-info {
      border: 1px solid var(--sc-line);
      border-radius: 16px;
      padding: clamp(16px, 2vw, 22px);
      background:
        radial-gradient(900px 520px at 0% -120px, rgba(212, 0, 0, .16) 0%, transparent 60%),
        linear-gradient(180deg, #18181a, #111113);
      box-shadow: var(--sc-shadow);
      margin: 0;
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .pfpdp-head {
      margin-bottom: 4px;
    }

    .pfpdp-titleprice {
      display: flex;
      flex-direction: column;
      gap: 10px;
      align-items: flex-start;
    }

    .pfpdp-title {
      margin: 0;
      font-size: clamp(22px, 2.4vw, 30px);
      line-height: 1.22;
      font-weight: 1000;
      letter-spacing: -.01em;
    }

    .pfpdp-price {
      align-self: stretch;
      border-radius: 14px;
      border: 1px solid rgba(212, 0, 0, .6);
      background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, .9));
      box-shadow: 0 14px 32px rgba(0, 0, 0, .6), inset 0 1px 0 rgba(255, 255, 255, .65);
      padding: 12px 16px;
    }

    .pfpdp-price__val {
      color: var(--brand-red);
      font-weight: 1000;
      font-size: clamp(22px, 2.4vw, 30px);
      letter-spacing: .01em;
      text-shadow: 0 1px 0 rgba(255, 255, 255, .7);
    }

    .pfpdp-block__title {
      margin: 4px 0 10px;
      font-size: 13px;
      font-weight: 800;
      letter-spacing: .24em;
      text-transform: uppercase;
      color: var(--sc-muted);
    }

    .pfpdp-keyspecs {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 8px 12px;
      margin: 4px 0 4px;
      padding: 0;
      list-style: none;
    }

    .pfpdp-keyspecs li {
      padding: 10px 12px;
      border-radius: 12px;
      background: var(--sc-panel-2);
      border: 1px solid rgba(255, 255, 255, .1);
      font-size: 13px;
      color: var(--sc-text);
      display: flex;
      flex-direction: column;
      gap: 2px;
    }

    .pfpdp-k__label {
      color: var(--sc-muted);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .06em;
      font-size: 11px;
    }

    .pfpdp-k__val {
      font-weight: 800;
    }

    /* ===== DESCRIZIONE ===== */
    .pfpdp-desc__text {
      position: relative;
      overflow: hidden;
    }

    .pfpdp-desc__text p {
      font-size: clamp(15px, 1.05vw, 17px);
      line-height: 1.68;
      color: var(--sc-muted);
      margin: .2em 0;
    }

    #pfpdp-descText{
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 6;
      overflow: hidden;
    }
    @media (max-width: 760px){
      #pfpdp-descText{ -webkit-line-clamp: 5; }
    }

    #pfpdp-descText.is-open{
      display: block;
      -webkit-line-clamp: unset;
    }

    .pfpdp-desc__text .desc-label {
      font-weight: 1000;
      color: #ffffff;
      margin-right: 6px;
      font-size: 1.05em;
    }

    .pfpdp-desc__text.is-collapsed {
      max-height: 7.2em;
    }

    .pfpdp-desc__text.is-collapsed::after {
      content: "";
      position: absolute;
      inset: auto 0 0 0;
      height: 3.2em;
      background: linear-gradient(180deg, rgba(14, 14, 15, 0), rgba(14, 14, 15, .96));
    }

    .pfpdp-desc__more {
      margin-top: 10px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 12px;
      border-radius: 12px;
      cursor: pointer;
      border: 1px solid var(--sc-line);
      background: var(--sc-panel);
      color: var(--sc-text);
      font-weight: 900;
      font-size: 13px;
    }

    .pfpdp-desc__more[aria-expanded="true"] svg {
      transform: rotate(180deg);
      transition: transform .2s ease;
    }

    /* ===== CARATTERISTICHE (toggle + blocchi) ===== */
    .pfpdp-specs__toggle {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 12px;
      border-radius: 14px;
      border: 1px solid var(--brand-red);
      background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, .92));
      font-weight: 1000;
      cursor: pointer;
      font-size: 13px;
      color: var(--brand-red);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .55), inset 0 1px 0 rgba(255, 255, 255, .7);
      transition: background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease, transform .12s ease;
    }

    .pfpdp-specs__toggle svg path {
      stroke: currentColor;
    }

    .pfpdp-specs__toggle:hover {
      transform: translateY(-1px);
      box-shadow: 0 16px 32px rgba(0, 0, 0, .65), inset 0 1px 0 rgba(255, 255, 255, .8);
    }

    .pfpdp-specs__toggle[aria-expanded="true"] {
      background: linear-gradient(180deg, #ffffff, rgba(255, 255, 255, .9));
      border-color: rgba(212, 0, 0, .9);
      color: var(--brand-red);
    }

    .pfpdp-specs__more {
      margin-top: 10px;
      overflow: hidden;
    }

    #pfpdp-specs-more,
    #pfpdp-services{
      transition: none !important;
      opacity: 1;
      transform: none;
    }

    #pfpdp-specs-more.is-anim,
    #pfpdp-services.is-anim{
      transition: opacity .18s ease, transform .18s ease;
    }

    .pfpdp-specsGrid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px 14px;
    }

    .pfpdp-specCard {
      background: #111113;
      border-radius: 16px;
      border: 1px solid rgba(255, 255, 255, .12);
      box-shadow: 0 18px 40px rgba(0, 0, 0, .7);
      padding: 14px 14px 12px;
    }

    .pfpdp-specCard--full {
      grid-column: 1 / -1;
    }

    .pfpdp-specCard h3 {
      margin: 0 0 8px;
      font-size: 17px;
      font-weight: 900;
      letter-spacing: -.01em;
    }

    .pfpdp-specCard dl {
      margin: 0;
    }

    .pfpdp-specRow {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 18px;
      padding: 4px 0;
      font-size: 13px;
    }

    .pfpdp-specRow dt {
      flex: 1 1 60%;
      color: var(--sc-muted);
      font-weight: 500;
    }

    .pfpdp-specRow dd {
      flex: 0 0 auto;
      margin: 0;
      font-weight: 800;
      color: #ffffff;
      text-align: right;
      white-space: nowrap;
    }

    .pfpdp-specRow--multiline {
      flex-direction: column;
      align-items: flex-start;
      gap: 4px;
    }

    .pfpdp-specRow--multiline dd {
      text-align: left;
      white-space: normal;
      font-weight: 600;
      line-height: 1.55;
    }

    .pfpdp-specs__empty {
      margin: 4px 0 0;
      font-size: 14px;
      color: var(--sc-muted);
    }

    .pfpdp-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 4px;
    }

    .pfpdp-tags span {
      display: inline-flex;
      align-items: center;
      padding: 6px 10px;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, .22);
      background: #111113;
      font-size: 13px;
      font-weight: 600;
      color: #ffffff;
    }

    /* ===== CTA ROW ===== */
    .pfpdp-ctaRow {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      margin: 0;
    }

    .pfpdp-ctaRow .btn {
      position: relative;
      overflow: hidden;
      min-width: 0;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 66px;
      padding: 0 20px;
      border-radius: 14px;
      font-weight: 1000;
      font-size: clamp(16px, 1.15vw, 18px);
      letter-spacing: .01em;
      text-decoration: none;
      border: 1px solid var(--sc-line);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .5);
      transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
      color: inherit;
      line-height: 1;
      background: var(--sc-panel-2);
    }

    .pfpdp-ctaRow .btn::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(75deg, transparent 0%, rgba(255, 255, 255, .25) 45%, transparent 60%);
      transform: translateX(-120%);
      opacity: 0;
      transition: transform .55s ease, opacity .35s ease;
      pointer-events: none;
    }

    .pfpdp-ctaRow .btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 16px 32px rgba(0, 0, 0, .65);
    }

    .pfpdp-ctaRow .btn:hover::after {
      transform: translateX(120%);
      opacity: .9;
    }

    .pfpdp-ctaRow .btn:focus-visible {
      outline: none;
      box-shadow: 0 0 0 3px rgba(212, 0, 0, .5), 0 14px 30px rgba(0, 0, 0, .7);
    }
    .pfpdp .pfpdp-ctaRow .btn--call{
      background:#fff !important;
      color: var(--brand-red) !important;
      border-color: var(--brand-red) !important;
    }
    .pfpdp .pfpdp-ctaRow .btn--call:hover{
      transform: translateY(-1px);
    }

    .pfpdp-ctaRow .btn svg path {
      stroke: currentColor;
    }

    .btn--primary {
      background: #ffffff;
      color: var(--brand-red) !important;
      border-color: var(--brand-red);
      box-shadow: 0 14px 30px rgba(0, 0, 0, .7), inset 0 1px 0 rgba(255, 255, 255, .7);
    }

    .btn--primary:hover {
      box-shadow: 0 18px 38px rgba(0, 0, 0, .85), inset 0 1px 0 rgba(255, 255, 255, .8);
    }

    .btn--ghost {
      background: #26262a;
      color: #ffffff !important;
      border-color: var(--sc-line);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .55);
    }

    .btn--ghost:hover {
      background: #2f2f34;
      box-shadow: 0 16px 34px rgba(0, 0, 0, .75);
    }

    /* ===== SERVIZI (3 card con IMMAGINE quadrata più grande) ===== */
    .pfpdp-services {
      display: flex;
      flex-direction: column;
      gap: 14px;
      margin: 4px 0 0;
    }

    .pfpdp-serviceCard {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      gap: 16px;
      padding: 16px 18px;
      border-radius: 14px;
      border: 1px solid var(--sc-line);
      background: #18181b;
      box-shadow: 0 16px 32px rgba(0, 0, 0, .7);
      align-items: flex-start;
    }

    .pfpdp-serviceCard__media {
      width: 190px;
      height: 190px;
      border-radius: 12px;
      overflow: hidden;
      background: #050506;
      border: 1px solid rgba(255, 255, 255, .22);
      flex-shrink: 0;
    }

    .pfpdp-serviceCard__media img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .pfpdp-serviceCard__body {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .pfpdp-serviceCard__title {
      margin: 0;
      font-size: 15px;
      font-weight: 900;
      letter-spacing: .01em;
    }

    .pfpdp-serviceCard__text {
      margin: 0;
      font-size: 13px;
      line-height: 1.6;
      color: var(--sc-muted);
    }

    .pfpdp-serviceCard__cta {
      margin-top: 8px;
      align-self: flex-start;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 8px 12px;
      border-radius: 12px;
      background: #ffffff;
      color: var(--brand-red);
      border: 1px solid var(--brand-red);
      font-weight: 900;
      font-size: 13px;
      text-decoration: none;
      box-shadow: 0 10px 24px rgba(0, 0, 0, .7), inset 0 1px 0 rgba(255, 255, 255, .8);
      transition: transform .12s, box-shadow .2s, border-color .2s;
    }

    .pfpdp-serviceCard__cta:hover {
      transform: translateY(-1px);
      box-shadow: 0 14px 30px rgba(0, 0, 0, .85);
      border-color: rgba(212, 0, 0, .85);
    }

    /* ===== LIGHTBOX ===== */
    .pfpdp-lightbox {
      position: fixed;
      inset: 0;
      z-index: 2000000;
    }

    .pfpdp-lightbox[hidden] {
      display: none;
    }

    .pfpdp-lightbox__backdrop {
      position: absolute;
      inset: 0;
      background: rgba(10, 12, 18, .78);
      backdrop-filter: blur(8px) saturate(1.2);
      -webkit-backdrop-filter: blur(8px) saturate(1.2);
    }

    .pfpdp-lightbox__stage {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      padding: clamp(12px, 3vw, 24px);
    }

    .pfpdp-lightbox__figure {
      position: relative;
      width: min(94vw, 1280px);
      max-height: 88vh;
      margin: 0 auto;
    }

    .pfpdp-lightbox__figure img {
      display: block;
      width: 100%;
      height: auto;
      max-height: 88vh;
      object-fit: contain;
      background: transparent;
      border-radius: 10px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, .45);
    }

    .pfpdp-lightbox__count {
      position: absolute;
      right: 14px;
      bottom: 10px;
      color: #fff;
      background: rgba(0, 0, 0, .45);
      padding: 6px 10px;
      border-radius: 999px;
      font-weight: 900;
      font-size: 14px;
    }

    .pfpdp-lightbox__close {
      position: absolute;
      top: clamp(10px, 3vw, 20px);
      right: clamp(10px, 3vw, 20px);
      display: inline-flex;
      align-items: center;
      gap: 8px;
      justify-content: center;
      height: 42px;
      padding: 0 12px;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, .28);
      background: rgba(255, 255, 255, .12);
      color: #fff;
      cursor: pointer;
    }

    .pfpdp-lightbox__nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 54px;
      height: 54px;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, .22);
      background: rgba(255, 255, 255, .14);
      color: #fff;
      cursor: pointer;
    }

    .pfpdp-lightbox__nav--prev {
      left: 12px;
    }

    .pfpdp-lightbox__nav--next {
      right: 12px;
    }

    @media(max-width:1024px) {
      .pfpdp__grid {
        grid-template-columns: 1fr;
      }

      .pfpdp-headMobile {
        display: flex;
        flex-direction: column;
        gap: 22px;
      }

      .pfpdp-headMobile .pfpdp-title--mobile {
        margin: 0 !important;
      }

      .pfpdp-headMobile .pfpdp-price--mobile {
        margin-top: 0 !important;
      }

      .pfpdp-head {
        display: none;
      }

      .pfpdp-media-wrap {
        margin: 0;
      }

      .pfpdp-media__nav {
        width: 42px;
        height: 42px;
        background: rgba(0, 0, 0, .65);
        border-color: rgba(0, 0, 0, .6);
        box-shadow: 0 6px 14px rgba(0, 0, 0, .6);
      }

      .pfpdp-media__nav--prev {
        left: 8px;
      }

      .pfpdp-media__nav--next {
        right: 8px;
      }

      .pfpdp-specsGrid {
        grid-template-columns: 1fr;
      }

      .pfpdp-keyspecs {
        grid-template-columns: 1fr;
      }

      .pfpdp-ctaRow {
        grid-template-columns: 1fr;
      }

      .pfpdp-services {
        margin-top: 8px;
      }

      .pfpdp-lightbox__stage {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 8px;
      }

      .pfpdp-lightbox__figure {
        width: calc(100vw - 16px);
        max-height: 86vh;
        margin: 0 auto;
      }

      .pfpdp-lightbox__figure img {
        max-width: 100%;
        max-height: 86vh;
        margin: 0 auto;
        object-fit: contain;
      }

      .pfpdp-lightbox__nav {
        width: 48px;
        height: 48px;
        background: rgba(255, 255, 255, .13);
        border-color: rgba(255, 255, 255, .22);
      }
    }

    html.pdp-modal-open,
    body.pdp-modal-open {
      overflow: hidden;
      height: 100%;
    }

    @media (prefers-reduced-motion: reduce) {

      .pfpdp *,
      .pfpdp *::before,
      .pfpdp *::after {
        transition: none !important;
        animation: none !important;
      }
    }

/* Sezione 2: Dove trovarci */

.where-section.supreme-cars {
    --brand-red: #D40000;
    --sc-bg: #0e0e0f;
    --sc-panel: #18181a;
    --sc-panel-2: #1f1f22;
    --sc-text: #ffffff;
    --sc-muted: rgba(255, 255, 255, .82);
    --sc-line: rgba(255, 255, 255, .18);
    --sc-shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);

    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    color: var(--sc-text);
    background:
      radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%),
      linear-gradient(180deg, #202020, #111111);
  }

  .where-container {
    max-width: 1120px;
    margin: 0 auto;
    padding: 56px 16px;
  }

  .where-header {
    text-align: center;
    margin-bottom: 24px;
  }

  /* TITOLI */
  .where-section.supreme-cars .where-header .where-title,
  .where-section.supreme-cars .where-header .pf-da-find__title {
    margin: 0;
    font-weight: 1000;
    line-height: 1.12;
    letter-spacing: -.01em;
    color: var(--sc-text);
    font-size: clamp(42px, 4.4vw, 68px) !important;
  }

  .where-title .brand-red,
  .where-title .hl-red {
    color: var(--brand-red) !important;
  }

  .where-subtitle {
    margin: 12px 0 0;
    color: var(--sc-muted);
    font-size: clamp(15px, 1.6vw, 18px);
  }

  .where-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: stretch;
  }

  @media(min-width:1024px) {
    .where-grid {
      grid-template-columns: 360px minmax(0, 1fr);
    }
  }

  .map-box {
    border: 1px solid var(--sc-line);
    border-radius: 14px;
    box-shadow: var(--sc-shadow);
    background: var(--sc-panel);
    overflow: hidden;
    min-height: 340px;
    height: 100%;
  }

  .map-iframe {
    width: 100%;
    height: 100%;
    border: 0;
  }

  .info-card {
    border: 1px solid var(--sc-line);
    border-radius: 14px;
    box-shadow: var(--sc-shadow);
    background: var(--sc-panel);
    height: 100%;
  }

  .info-card__content {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 20px;
  }

  .info-title {
    font-size: 22px;
    line-height: 1.2;
    font-weight: 900;
    margin: 0 0 14px;
    letter-spacing: -.01em;
    color: var(--sc-text);
  }

  .info-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .info-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
  }

  .info-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: #ffffff;
    border: 1px solid rgba(212, 0, 0, .6);
    color: var(--brand-red);
    flex: 0 0 32px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, .4), inset 0 1px 0 rgba(255, 255, 255, .9);
  }

  .info-icon svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.75;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .info-icon svg * {
    fill: none !important;
  }

  .info-label {
    font-size: 12.4px;
    color: rgba(255, 255, 255, .72);
    margin-bottom: 2px;
    font-weight: 600;
  }

  .info-value {
    font-size: 14px;
    color: var(--sc-text);
    line-height: 1.55;
  }

  .info-value a {
    color: #ffffff !important;
    text-decoration: none;
    font-weight: 600;
  }

  .info-value a:hover {
    text-decoration: underline;
  }

  .info-spacer {
    flex: 1 1 auto;
  }

  .btn-map {
    margin-top: 18px;
    width: 100%;
    height: 44px;
    padding: 0 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 12px;
    cursor: pointer;
    font-weight: 900;
    letter-spacing: .2px;
    color: var(--brand-red);
    background: #ffffff;
    border: 1px solid var(--brand-red);
    box-shadow: 0 14px 30px rgba(0, 0, 0, .7), inset 0 1px 0 rgba(255, 255, 255, .8);
    position: relative;
    overflow: hidden;
    transition: transform .12s ease, box-shadow .18s ease, filter .18s ease;
  }

  .btn-map:hover {
    filter: brightness(.99);
    transform: translateY(-1px);
    box-shadow: 0 18px 36px rgba(0, 0, 0, .85), inset 0 1px 0 rgba(255, 255, 255, .9);
  }

  .btn-map::after {
    content: "";
    position: absolute;
    inset: -40% -120%;
    background: linear-gradient(120deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .4) 45%, rgba(255, 255, 255, 0) 60%);
    transform: translateX(-120%) rotate(16deg);
    opacity: 0;
    pointer-events: none;
  }

  .btn-map:hover::after,
  .btn-map:focus-visible::after {
    animation: btnShimmer 1.2s ease-out 1 forwards;
  }

  @keyframes btnShimmer {
    0% {
      transform: translateX(-120%) rotate(16deg);
      opacity: 0;
    }

    30% {
      opacity: .18;
    }

    55% {
      opacity: .28;
    }

    100% {
      transform: translateX(120%) rotate(16deg);
      opacity: 0;
    }
  }

  .btn-map svg {
    width: 18px;
    height: 18px;
    stroke: var(--brand-red);
    fill: none;
    stroke-width: 1.75;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .btn-map svg * {
    fill: none !important;
  }

  /* MOBILE (≤980px) */
  @media (max-width:980px) {
    .where-header {
      text-align: left;
    }

    .where-section.supreme-cars .where-header .pf-da-find__title {
      font-size: clamp(36px, 9vw, 54px) !important;
      line-height: 1.1;
      letter-spacing: -.3px;
    }

    /* ordine: mappa prima, poi contatti */
    .map-box {
      order: 1;
    }

    .info-card {
      order: 2;
    }

    .info-card__content {
      padding: 16px;
    }

    .info-title {
      font-size: 18px;
      margin-bottom: 10px;
    }

    .info-list {
      gap: 10px;
    }

    .info-item {
      gap: 10px;
    }

    .info-icon {
      width: 28px;
      height: 28px;
      border-radius: 8px;
    }

    .info-icon svg {
      width: 16px;
      height: 16px;
      stroke-width: 1.6;
    }

    .info-label {
      font-size: 11.5px;
    }

    .info-value {
      font-size: 13.4px;
      line-height: 1.48;
    }
  }

/* Sezione 3: Scopri anche */

.sr-only {
      position: absolute !important;
      width: 1px !important;
      height: 1px !important;
      overflow: hidden !important;
      clip: rect(0, 0, 0, 0) !important;
      white-space: nowrap !important;
    }

    /* ===== Header stile Supreme Cars ===== */
    #pf-also42 {
      --brand-red: #D40000;
      --sc-bg: #0e0e0f;
      --sc-panel: #18181a;
      --sc-panel-2: #1f1f22;
      --sc-text: #ffffff;
      --sc-muted: rgba(255, 255, 255, .82);
      --sc-line: rgba(255, 255, 255, .18);
      --sc-shadow: 0 24px 28px -18px rgba(0, 0, 0, .6);
    }

    #pf-also42 .also-header {
      margin: 0 0 6px 0;
      text-align: center;
    }

    #pf-also42 .also-title {
      margin: 0;
      font-weight: 1000;
      line-height: 1.12;
      letter-spacing: -.01em;
      color: var(--sc-text);
      font-size: clamp(42px, 4.4vw, 68px) !important;
    }

    #pf-also42 .also-title .brand-red,
    #pf-also42 .also-title .hl-red {
      color: var(--brand-red) !important;
    }

    /* ====== Slider (stessa struttura/metriche della v42.1) ====== */
    #pf-also42 {
      --wm-px: clamp(700px, 24vw, 1000px);
      --wm-ratio: 0.3805;
      --wm-right: 120px;
      --wm-bottom: -44px;
      --wm-opacity: .0;
      /* non usata perché la nascondiamo */
      --card-alpha: .66;
      --nav-offset: 8px;
      --nav-size: 48px;
    }

    .pfc42,
    .pfc42 * {
      box-sizing: border-box;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    .pfc42 {
      position: relative;
      isolation: isolate;
      background:
        radial-gradient(1400px 640px at 50% -140px, #222 0%, transparent 60%),
        linear-gradient(180deg, #202020, #111111) !important;
      color: var(--sc-text);
    }

    #pf-also42 {
      overflow: visible;
    }

    #pf-also42 .pfc42__inner {
      max-width: 1520px;
      margin: 12px auto;
      padding: 8px clamp(16px, 4vw, 24px) clamp(70px, 4.5vw, 100px);
      position: relative;
    }

    /* contatore visivo rimosso */
    #pf-also42 .pfc42-head {
      display: none;
    }

    #pf-also42 .pfc42-slider {
      position: relative;
      display: block;
      overflow: visible;
      background: transparent;
      z-index: 0;
    }

    /* Watermark DemasiAuto nascosto */
    #pf-also42 .pfc42-wm {
      display: none;
    }

    #pf-also42 .pfc42-stage {
      position: relative;
      z-index: 1;
    }

    #pf-also42 .pfc42-viewport {
      --gap: 22px;
      --cards-desktop: 4;
      --vp-padX: 14px;
      position: relative;
      overflow-x: hidden;
      overflow-y: visible;
      background: transparent;
      scroll-behavior: smooth;
      padding-inline: var(--vp-padX);
      scroll-padding-inline: var(--vp-padX);
      z-index: 1;
    }

    #pf-also42 .pfc42-track {
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      gap: var(--gap);
      padding-bottom: clamp(30px, 2.8vw, 50px);
      position: relative;
      background: transparent;
      padding-right: calc(var(--vp-padX) + 2px);
      justify-content: flex-start;
    }

    #pf-also42 .pfc42-nav {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: var(--nav-size);
      height: var(--nav-size);
      border-radius: 999px;
      background: #ffffff;
      color: var(--brand-red);
      border: 1px solid rgba(212, 0, 0, .45);
      transition: transform .15s, border-color .2s, box-shadow .2s, background .2s;
      z-index: 5;
      box-shadow: 0 12px 26px rgba(0, 0, 0, .6);
    }

    #pf-also42 .pfc42-nav--prev {
      left: var(--nav-offset);
    }

    #pf-also42 .pfc42-nav--next {
      right: var(--nav-offset);
    }

    #pf-also42 .pfc42-nav:hover {
      transform: translateY(-50%) translateY(-1px);
      border-color: rgba(212, 0, 0, .75);
      box-shadow: 0 16px 32px rgba(0, 0, 0, .75);
    }

    #pf-also42 .pfc42-nav:disabled {
      opacity: .45;
      pointer-events: none;
      box-shadow: none;
    }

    /* CARDS */
    #pf-also42 .pfc42-card {
      flex: 0 0 var(--card-wpx, 25%);
      min-width: var(--card-wpx, 25%);
      display: flex;
      flex-direction: column;
      height: 100%;
      background: var(--sc-panel-2);
      border: 1px solid var(--sc-line);
      border-radius: 22px;
      overflow: hidden;
      transition: border-color .2s, box-shadow .2s, transform .15s;
      box-shadow: var(--sc-shadow);
      color: var(--sc-text);
    }

    #pf-also42 .pfc42-card:hover {
      border-color: rgba(212, 0, 0, .55);
      box-shadow: 0 18px 36px rgba(0, 0, 0, .85);
      transform: translateY(-2px);
    }

    #pf-also42 .pfc42-media {
      position: relative;
      aspect-ratio: 4/3;
      overflow: hidden;
      background: #050506;
    }

    #pf-also42 .pfc42-media img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform .35s ease;
    }

    #pf-also42 .pfc42-card:hover .pfc42-media img {
      transform: scale(1.045);
    }

    #pf-also42 .pfc42-body {
      display: flex;
      flex-direction: column;
      gap: 12px;
      padding: 22px 22px 22px;
      background: transparent;
      min-height: 172px;
    }

    #pf-also42 .pfc42-title {
      font-size: 24px;
      font-weight: 1000;
      margin: 0;
      color: var(--sc-text);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    #pf-also42 .pfc42-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
    }

    #pf-also42 .pfc42-row--a {
      margin-top: 2px;
    }

    #pf-also42 .pfc42-row--b {
      margin-top: auto;
    }

    /* Pill prezzo – sfondo bianco, bordo rosso, testo rosso */
    #pf-also42 .pfc42-price {
      padding: 10px 14px;
      border-radius: 999px;
      background: #ffffff;
      color: var(--brand-red);
      font-weight: 1000;
      font-size: 18px;
      border: 1px solid rgba(212, 0, 0, .6);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .6), inset 0 1px 0 rgba(255, 255, 255, .85);
    }

    #pf-also42 .pfc42-meta {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-weight: 900;
      color: var(--sc-muted);
    }

    #pf-also42 .pfc42-meta svg {
      color: var(--sc-muted);
    }

    /* Bottone "Scopri" – bianco con testo rosso */
    #pf-also42 .pfc42-more {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 10px 14px;
      border-radius: 12px;
      text-decoration: none;
      font-weight: 1000;
      color: var(--brand-red);
      background: #ffffff;
      border: 1px solid var(--brand-red);
      box-shadow: 0 12px 26px rgba(0, 0, 0, .6), inset 0 1px 0 rgba(255, 255, 255, .8);
      transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
    }

    #pf-also42 .pfc42-more:hover {
      transform: translateY(-1px);
      border-color: rgba(212, 0, 0, .8);
      box-shadow: 0 16px 34px rgba(0, 0, 0, .85), inset 0 1px 0 rgba(255, 255, 255, .9);
      background: #ffffff;
    }

    /* ===== Card CTA (6ª) — centra il contenuto sull’intera card ===== */
    #pf-also42 .pfc42-card--cta {
      position: relative;
    }

    /* Spacer mantiene la stessa altezza delle altre card ma non mostra nulla */
    #pf-also42 .pfc42-card--cta .pfc42-media--spacer {
      visibility: hidden;
    }

    /* Overlay centrale: testo + bottone, centrati in verticale/orizzontale */
    #pf-also42 .pfc42-card--cta .pfc42-body--cta {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 16px;
      text-align: center;
      padding: 22px;
      background: transparent;
    }

    #pf-also42 .pfc42-ctaHeading {
      margin: 0;
      font-weight: 1000;
      letter-spacing: .2px;
      color: var(--sc-text);
      font-size: 24px;
      line-height: 1.2;
    }

    /* CTA card button – stesso stile: bianco, testo rosso, bordo rosso */
    #pf-also42 .pfc42-ctaLink {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 12px 16px;
      border-radius: 12px;
      background: #ffffff;
      color: var(--brand-red) !important;
      font-weight: 1000;
      border: 1px solid var(--brand-red);
      text-decoration: none;
      box-shadow: 0 14px 30px rgba(0, 0, 0, .75), inset 0 1px 0 rgba(255, 255, 255, .85);
      transition: transform .12s, box-shadow .2s, border-color .2s;
    }

    #pf-also42 .pfc42-ctaLink:hover {
      transform: translateY(-1px);
      box-shadow: 0 18px 38px rgba(0, 0, 0, .9), inset 0 1px 0 rgba(255, 255, 255, .9);
      border-color: rgba(212, 0, 0, .85);
    }

    /* ===== Responsive ===== */
    @media(max-width:980px) {
      #pf-also42 .also-header {
        text-align: left;
      }

      #pf-also42 .pf-da-find__title {
        font-size: clamp(36px, 9vw, 54px) !important;
        line-height: 1.1;
        letter-spacing: -.3px;
      }

      #pf-also42 .pfc42-ctaHeading {
        font-size: 22px;
      }
    }

@media (max-width:1024px) {
  #pf-also42 .pfc42-viewport {
    --cards-desktop: 2;
    --vp-padX: 14px;
  }
  #pf-pdp,
  .pfpdp {
    padding-top: 76px;
  }

  #pf-also42 .pfc42-title {
    font-size: 23px;
  }

      #pf-also42 .pfc42-media {
        aspect-ratio: 3/2;
      }
    }

    @media (max-width:720px) {
      #pf-also42 .pfc42__inner {
        padding-top: 8px;
      }

      #pf-also42 .pfc42-viewport {
        --cards-desktop: 1;
        --vp-padX: 16px;
      }

      #pf-also42 {
        --wm-opacity: .0;
        --wm-px: clamp(520px, 72vw, 680px);
        --wm-bottom: -36px;
        --nav-offset: 10px;
        --nav-size: 46px;
      }

      #pf-also42 .pfc42-media {
        aspect-ratio: 4/3;
      }

      #pf-also42 .pfc42-title {
        font-size: 22px;
      }

      #pf-also42 .pfc42-body {
        padding: 18px 18px 20px;
      }
    }
/* ================================
   OVERRIDE "SCOPRI ANCHE" (pf-also42)
   - Titolo su 2 righe
   - Prezzo sotto al titolo a tutta card
   - Meta/specifiche sotto il prezzo
   ================================= */

/* Titolo: niente nowrap, massimo 2 righe con ellissi */
#pf-also42 .pfc42-title {
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-height: 1.25;
}

.pfpdp [hidden] {
  display: none !important;
}

/* Riga prezzo + meta: impilata in colonna */
#pf-also42 .pfc42-row--a {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  margin-top: 6px;
}

/* Prezzo: pillola full-width, centrata */
#pf-also42 .pfc42-price {
  width: 100%;
  border-radius: 14px;
  text-align: center;
  justify-content: center;
  display: inline-flex;
}

/* Meta / specifiche: sotto al prezzo, può andare su 2 righe */
#pf-also42 .pfc42-meta {
  flex-wrap: wrap;
  row-gap: 4px;
  column-gap: 10px;
  font-size: 13px;
}


/* === pages/trasporto.css === */
/* ===== Imports (font, etc.) ===== */


/* ================= HEADER ================= */
:root {
      --pf-sdv-orange: #D40000;
      /* Rosso Ferrari */
      --pf-sdv-white: #fff;
      --pf-sdv-header-h: 86px;
      --drawer-w: min(74vw, 380px);
      /* usa direttamente lâ€™URL del logo (trasparente) */
      --logo-src: url('https://cdn.shopify.com/s/files/1/0932/6247/9684/files/325247930_155681167232339_343017528390532657_n.webp?v=1761916031');

      /* Tipografie mobile */
      --fs-base: clamp(19px, 4vw, 22px);
      --fs-home: clamp(21px, 4.4vw, 24px);
      --fs-vendita: clamp(28px, 7vw, 36px);
      --fs-noleggio: clamp(32px, 8.2vw, 42px);

      /* nudge base desktop/mobile header */
      --brand-left-nudge: -6px;
      --sd-bg-radial: radial-gradient(1400px 640px at 50% -140px, #2a2a2a 0%, transparent 60%);
      --sd-bg-linear: linear-gradient(180deg, #202020, #111111);
    }

    body {
      background: var(--sd-bg-radial), var(--sd-bg-linear);
      padding-top: var(--pf-sdv-header-h);
    }

    /* ================= Header base ================= */
    #pf-sdv-header {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 60;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      transition: box-shadow .2s ease, background .2s ease;
      backdrop-filter: saturate(160%) blur(10px);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-header.pf-sdv--scrolled {
      box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    }

    .pf-sdv-container {
      max-width: 1320px;
      margin: 0 auto;
      padding: 0 18px;
    }

    .pf-sdv-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      height: var(--pf-sdv-header-h);
    }

    /* ================= LOGO =================
       Safari/iOS FIX: usa la shorthand -webkit-mask/mask con size esplicito
       e blocca le dimensioni via width/height + aspect-ratio
    */
    .pf-sdv-brand {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      color: inherit;
      white-space: nowrap;
      margin-left: var(--brand-left-nudge);
      line-height: 0;
      /* evita baseline su iOS */
    }

    .pf-sdv-logo-mask {
      width: 136px;
      height: 50px;
      aspect-ratio: 136/50;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      /* tinta bianca */
      /* SHORTHAND: immagine maschera centrata, contain, no-repeat */
      -webkit-mask: var(--logo-src) center / contain no-repeat;
      mask: var(--logo-src) center / contain no-repeat;
      /* Stabilizza su WebKit */
      image-rendering: -webkit-optimize-contrast;
      will-change: -webkit-mask-position, mask-position;
      transform: translateZ(0);
    }

    /* Menu desktop */
    .pf-sdv-menu--desktop {
      display: none;
      align-items: center;
      gap: 26px;
    }

    .pf-sdv-link,
    .pf-sdv-dropdown__btn {
      font-weight: 700;
      font-size: 16px;
      line-height: 1;
      letter-spacing: .2px;
      color: var(--pf-sdv-white);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .pf-sdv-link:hover,
    .pf-sdv-dropdown__btn:hover {
      opacity: .9;
    }

    .pf-sdv-dropdown__btn {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 0;
      margin: 0;
      cursor: pointer;
    }

    .pf-sdv-caret {
      transition: transform .15s ease;
    }

    .pf-sdv-dropdown__btn[aria-expanded="true"] .pf-sdv-caret {
      transform: rotate(180deg);
    }

    .pf-sdv-inline-dropdown {
      position: fixed;
      top: var(--pf-sdv-header-h);
      left: 0;
      display: none;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      padding: 12px 16px;
      white-space: nowrap;
      z-index: 59;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .pf-sdv-inline-dropdown__row {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .pf-sdv-inline-dropdown a {
      color: var(--pf-sdv-white);
      text-decoration: none;
      font-weight: 700;
      font-size: 16px;
    }

    .pf-sdv-inline-dropdown a:hover {
      text-decoration: underline;
    }

    /* CTA desktop */
    .pf-sdv-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .pf-sdv-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 999px;
      font-weight: 700;
      text-decoration: none;
      border: 1px solid var(--pf-sdv-white);
      color: var(--pf-sdv-white);
      background: transparent;
    }

    .pf-sdv-btn--primary {
      background: var(--pf-sdv-white);
      color: var(--pf-sdv-orange);
      border-color: var(--pf-sdv-white);
    }

    /* Burger */
    .pf-sdv-toggle {
      border: 0;
      background: transparent;
      width: 26px;
      height: 26px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }

    .pf-burger {
      position: relative;
      width: 26px;
      height: 26px;
    }

    .pf-burger .bar {
      position: absolute;
      left: 2px;
      right: 2px;
      height: 2px;
      background: var(--pf-sdv-white);
      border-radius: 2px;
      transition: transform .22s cubic-bezier(.22, .61, .36, 1), opacity .18s ease, width .18s ease, left .18s ease;
    }

    .pf-burger .bar.top {
      top: 6px;
    }

    .pf-burger .bar.mid {
      top: 12px;
    }

    .pf-burger .bar.bot {
      top: 18px;
    }

    .pf-burger.is-open .bar.top {
      transform: translateY(6px) rotate(45deg);
    }

    .pf-burger.is-open .bar.bot {
      transform: translateY(-6px) rotate(-45deg);
    }

    .pf-burger.is-open .bar.mid {
      transform: translateX(10px);
      opacity: 0;
      width: 0;
      left: 50%;
    }

    /* ======= MOBILE ONLY ======= */
    @media (max-width:1023px) {
      .pf-sdv-actions .pf-sdv-btn {
        display: none;
      }

      .pf-sdv-toggle {
        display: inline-flex;
      }

      /* Sposta il logo 10px piÃ¹ a sinistra rispetto al nudge base */
      .pf-sdv-brand {
        margin-left: calc(var(--brand-left-nudge) - 10px);
      }
    }

    /* ======= DESKTOP ======= */
    @media (min-width:1024px) {
      .pf-sdv-menu--desktop {
        display: flex;
      }

      .pf-sdv-toggle {
        display: none;
      }
    }

    /* ================= Drawer & Backdrop ================= */
    #pf-sdv-mobile {
      position: fixed;
      inset: auto auto 0 0;
      top: 0;
      width: var(--drawer-w);
      padding: calc(var(--pf-sdv-header-h)) 18px 16px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      background: #0b0b0b;
      color: var(--pf-sdv-white);
      border-right: 1px solid rgba(255, 255, 255, .24);
      transform: translateX(-100%);
      transition: transform .28s cubic-bezier(.22, .61, .36, 1);
      z-index: 9998;
      overflow: auto;
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #pf-sdv-mobile.is-open {
      transform: translateX(0);
    }

    #pf-sdv-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .5);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease;
      z-index: 9997;
    }

    #pf-sdv-backdrop.is-open {
      opacity: 1;
      pointer-events: auto;
    }

    html.pf-mobile-open,
    body.pf-mobile-open {
      overflow: hidden;
    }

    /* Logo nel drawer (stessa fix) */
    .pf-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      height: 54px;
      margin: 0 0 8px 0;
    }

    .pf-drawer-logo {
      width: 200px;
      height: 80px;
      aspect-ratio: 200/80;
      display: inline-block;
      color: #fff;
      background-color: currentColor;
      -webkit-mask: var(--logo-src) left top / contain no-repeat;
      mask: var(--logo-src) left top / contain no-repeat;
      margin-top: -6px;
      margin-left: -4px;
      image-rendering: -webkit-optimize-contrast;
      transform: translateZ(0);
    }

    /* SOLO MOBILE: alza leggermente */
    @media (max-width:1023px) {
      #pf-sdv-mobile .pf-drawer-logo {
        margin-top: -21px;
      }
    }

    /* Voci menu */
    #pf-sdv-mobile .pf-sdv-link {
      display: block;
      padding: 12px 0;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: var(--fs-base);
    }

    #pf-sdv-mobile .size-home {
      font-size: var(--fs-home);
    }

    #pf-sdv-mobile .size-vendita {
      font-size: var(--fs-vendita);
    }

    #pf-sdv-mobile .size-noleggio {
      font-size: var(--fs-noleggio);
    }

    /* Toggle Servizi */
    #pf-sdv-mobile .pf-mobile-svc-toggle {
      appearance: none;
      background: transparent;
      border: 0;
      padding: 12px 0;
      margin: 0;
      color: #fff;
      font-weight: 800;
      letter-spacing: .2px;
      cursor: pointer;
      text-align: left;
      font-size: var(--fs-vendita);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    #pf-sdv-mobile .pf-mobile-caret {
      transition: transform .18s ease;
    }

    #pf-sdv-mobile .pf-mobile-svc-toggle[aria-expanded="true"] .pf-mobile-caret {
      transform: rotate(180deg);
    }

    /* Submenu Servizi */
    #pf-sdv-mobile .pf-sdv-submenu {
      display: flex;
      flex-direction: column;
      gap: 2px;
      padding-left: 6px;
    }

    #pf-sdv-mobile .pf-sdv-submenu[hidden] {
      display: none !important;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link {
      font-size: var(--fs-home);
      font-weight: 800;
      letter-spacing: .2px;
      color: rgba(255, 255, 255, .88);
      position: relative;
      padding: 12px 0 12px 14px;
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link::before {
      content: "-";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      color: rgba(255, 255, 255, .88);
    }

    #pf-sdv-mobile .pf-sdv-submenu .pf-sdv-link:hover {
      color: rgba(255, 255, 255, .96);
    }

    /* CTA in fondo */
    #pf-sdv-mobile .pf-cta-wrap {
      margin-top: auto;
      display: flex;
      flex-direction: column;
      gap: 10px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, .14);
      padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    #pf-sdv-mobile .pf-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: 800;
      text-decoration: none;
      line-height: 1;
      width: 100%;
    }

    #pf-sdv-mobile .pf-cta--outline {
      border: 1.6px solid #fff;
      color: #fff;
      background: transparent;
    }

    #pf-sdv-mobile .pf-cta--outline:hover {
      background: rgba(255, 255, 255, .08);
    }

    #pf-sdv-mobile .pf-cta--white {
      background: #fff;
      color: #D40000;
      border: 1.6px solid #fff;
    }

    #pf-sdv-mobile .pf-cta--white:hover {
      filter: brightness(.96);
    }

    /* Nascondi drawer/backdrop su desktop */
    @media (min-width:1024px) {

      #pf-sdv-mobile,
      #pf-sdv-backdrop {
        display: none !important;
      }
    }

    /* WhatsApp desktop */
    #pf-sdv-header .pf-sdv-btn--primary {
      color: #D40000 !important;
    }

    #pf-sdv-header .pf-sdv-btn--primary svg {
      color: inherit;
      fill: currentColor;
      stroke: currentColor;
    }

    #pf-sdv-header .pf-sdv-btn--primary:hover {
      color: #B80000 !important;
    }

    /* ===== iOS Safari hard-fix =====
       Applica di nuovo la shorthand (alcune versioni ignorano proprietÃ  separate)
       e blocca l'aspect-ratio esplicitamente.
    */
    @supports (-webkit-touch-callout: none) {
      .pf-sdv-logo-mask {
        width: 120px;
        height: 44px;
        aspect-ratio: 120/44 !important;
        -webkit-mask: var(--logo-src) 50% 50% / contain no-repeat !important;
        mask: var(--logo-src) 50% 50% / contain no-repeat !important;
      }

      #pf-sdv-mobile .pf-drawer-logo {
        width: 150px;
        height: 60px;
        aspect-ratio: 150/60 !important;
        -webkit-mask: var(--logo-src) left top / contain no-repeat !important;
        mask: var(--logo-src) left top / contain no-repeat !important;
      }
    }

/* ================= SEZIONE 1 ================= */
/* Accent locale alla sezione (non tocca il resto della pagina) */
  .sd-hero {
    --sd-accent: #D40000;
  }

  /* Ferrari Red */

  .sd-hero {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    /* DESKTOP: invariato */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

.sd-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

.sd-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  background: #000;
}

  .sd-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, .70), rgba(0, 0, 0, .50), rgba(0, 0, 0, .70));
    pointer-events: none;
  }

  .sd-hero__content {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    padding-inline: 1rem;
    text-align: center;
  }

  .sd-hero__wrap {
    max-width: 64rem;
    margin: 0 auto;
  }

  /* ====== TITOLO (dimensioni ORIGINALI) ====== */
  .sd-hero__title {
    margin: 0 0 .5em;
    color: #fff;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
  }

  .sd-hero__title .sd-primary {
    color: var(--sd-accent);
  }

  .sd-hero__subtitle {
    color: rgba(255, 255, 255, .9);
    font-weight: 600;
    font-size: clamp(1.125rem, 2.2vw, 1.5rem);
    margin: 0 0 1.25rem;
  }

  .sd-hero__subtitle .sd-line {
    display: block;
    white-space: nowrap;
  }

  .sd-hero__actions {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: center;
    padding-top: 1rem;
  }

  /* Mobile: niente rettangoli blu su tap dei bottoni hero (Android/iOS) */
  @media (max-width: 1023px) {
    .sd-hero__actions .sd-btn,
    .sd-hero__actions .sd-btn * {
      -webkit-tap-highlight-color: transparent !important;
    }

    .sd-hero__actions .sd-btn {
      -webkit-touch-callout: none;
      -webkit-user-select: none;
      user-select: none;
    }

    .sd-hero__actions .sd-btn:focus,
    .sd-hero__actions .sd-btn:focus-visible,
    .sd-hero__actions .sd-btn:active {
      outline: none !important;
      box-shadow: none !important;
    }
  }

  @media (min-width:640px) {
    .sd-hero__actions {
      flex-direction: row;
    }
  }

  .sd-btn {
    --_h: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 0 2rem;
    height: var(--_h);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 1.125rem;
    text-decoration: none;
    border: 2px solid transparent;
    transition: transform .2s, box-shadow .2s, background .2s, color .2s, border-color .2s;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    line-height: 1;
    white-space: nowrap;
  }

  .sd-btn--primary {
    background: #fff;
    color: var(--sd-accent);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .2);
  }

  .sd-btn--primary::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .3), transparent);
    transform: translateX(-100%);
    transition: transform 1s;
  }

  .sd-btn--primary:hover::before {
    transform: translateX(100%);
  }

  .sd-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25);
  }

  .sd-btn--ghost {
    background: rgba(255, 255, 255, .10);
    color: #fff;
    border-color: rgba(255, 255, 255, .30);
    box-shadow: 0 6px 20px rgba(0, 0, 0, .15);
    backdrop-filter: saturate(1.2) blur(.5px);
  }

  .sd-btn--ghost:hover {
    background: rgba(255, 255, 255, .20);
    transform: translateY(-1px);
  }

  .sd-icon {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }

  .sd-scroll {
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 10;
  }

  .sd-scroll__mouse {
    width: 24px;
    height: 40px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, .5);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 8px;
  }

  .sd-scroll__dot {
    width: 4px;
    height: 12px;
    background: rgba(255, 255, 255, .7);
    border-radius: 999px;
    animation: sd-bounce 1s infinite alternate;
  }

  @keyframes sd-bounce {
    from {
      transform: translateY(0);
      opacity: 1;
    }

    to {
      transform: translateY(6px);
      opacity: .6;
    }
  }

  @media (prefers-reduced-motion:reduce) {

    .sd-btn,
    .sd-btn::before,
    .sd-scroll__dot {
      transition: none;
      animation: none;
    }

    .sd-hero__video {
      animation: none;
    }
  }

  /* ====== OVERRIDE DI SICUREZZA (anti-arancione) ====== */
  .sd-hero .sd-primary {
    color: #D40000 !important;
  }

  .sd-hero .sd-btn--primary {
    color: #D40000 !important;
  }

  /* testo bottone primario */
  .sd-hero .sd-btn--primary .sd-icon {
    stroke: currentColor;
    fill: none;
  }

  /* ===================== SOLO MOBILE (≤ 639px) ===================== */
  @media (max-width: 639px) {
      .sd-hero {
      min-height: 85svh;
      }

    /* base mobile */
    /* Variante tight SOLO MOBILE */
    .sd-hero--tight {
      min-height: 96svh;
    }

    .sd-hero--tight .sd-hero__wrap {
      transform: translateY(-7svh);
    }

    .sd-hero__subtitle {
      font-size: clamp(.95rem, 3.6vw, 1.2rem);
      /* ~15px–19px */
      line-height: 1.35;
      margin-bottom: .75rem;
    }

    .sd-hero__subtitle .sd-line {
      white-space: normal;
    }

    .sd-hero__actions {
      flex-direction: row;
      gap: .75rem;
      padding-top: .5rem;
    }

    .sd-hero__actions .sd-btn {
      flex: 1 1 0;
      min-width: 0;
      height: 3rem;
      font-size: 1.05rem;
      padding: 0 1.25rem;
    }

    .sd-scroll {
      bottom: 1rem;
    }
  }

/* ================= SEZIONE 2 ================= */
.sc-tr-pillars {
      --accent: #D40000;
      /* Ferrari Red */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 30px 0 60px;
      /* TOP dimezzato */
      isolation: isolate;
    }

/* Mobile: stesso respiro (top/bottom) di Lavaggio/Deposito */
@media (max-width: 639px) {
  .sc-tr-pillars {
    padding: 60px 0;
  }
}

    .sc-tr-pillars .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 18px 16px 8px;
      /* TOP dimezzato (36→18) */
      overflow-x: clip;
      /* evita scroll orizzontale col glow */
    }

    /* --- Head (titolo) --- */
    .sc-tr-pillars .pillars-head {
      text-align: center;
      margin: 0 0 18px;
    }

    .sc-tr-pillars .pillars-title {
      margin: 0;
      font-weight: 800;
      letter-spacing: -.02em;
      line-height: 1.05;
      font-size: clamp(1.75rem, 4.4vw, 2.5rem);
      color: #fff;
    }

    .sc-tr-pillars .pillars-title .accent {
      color: var(--accent);
    }

    .sc-tr-pillars .pillars {
      display: grid;
      gap: 14px;
      grid-template-columns: 1fr;
    }

    @media(min-width:720px) {
      .sc-tr-pillars .pillars {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    /* --- Card con glow ROSSO --- */
    .sc-tr-pillars .pillar {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      transform: translateZ(0);
      transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    }

    /* alone ROSSO (fallback) */
    .sc-tr-pillars .pillar::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 2px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .70) 0%,
          rgba(212, 0, 0, .18) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.98);
      filter: blur(14px);
      opacity: .35;
      transition: opacity .2s ease, transform .2s ease, filter .2s ease;
      pointer-events: none;
    }

    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      .sc-tr-pillars .pillar::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 70%, transparent) 0%,
            color-mix(in srgb, var(--accent) 18%, transparent) 45%,
            transparent 70%);
      }
    }

    .sc-tr-pillars .pillar:hover,
    .sc-tr-pillars .pillar:focus-visible {
      transform: translateY(-2px) scale(1.02);
      box-shadow: 0 16px 36px rgba(0, 0, 0, .35);
      border-color: rgba(255, 255, 255, .16);
      outline: none;
    }

    .sc-tr-pillars .pillar:hover::before,
    .sc-tr-pillars .pillar:focus-visible::before {
      opacity: .7;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* === Icone: SFONDO BIANCO + ICONA ROSSA === */
    .sc-tr-pillars .pill-ico {
      width: 44px;
      height: 44px;
      border-radius: 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #ffffff;
      /* sfondo BIANCO */
      border: 1px solid #ffffff;
      /* bordo bianco pulito */
      box-shadow: 0 6px 16px -10px rgba(0, 0, 0, .6);
      margin-bottom: 10px;
    }

    .sc-tr-pillars .pill-ico svg {
      width: 24px;
      height: 24px;
      color: var(--accent);
      /* icona ROSSA */
    }

    .sc-tr-pillars h3 {
      margin: .1rem 0 .25rem;
      font-size: 1.15rem;
      font-weight: 900;
    }

    .sc-tr-pillars p {
      margin: 0;
      color: var(--muted);
    }

    @media (prefers-reduced-motion: reduce) {

      .sc-tr-pillars .pillar,
      .sc-tr-pillars .pillar::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 3 ================= */
.sc-tr-form {
      --accent: #D40000;
      /* Rosso Ferrari */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #202124;
      --panel2: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 16px;
      /* top/bottom 60px */
      color-scheme: dark;
    }

    .sc-tr-form .container {
      max-width: 1200px;
      margin: 0 auto;
    }

    .sc-tr-form .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    .sc-tr-form .sec-head h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
    }

    /* “preventivo” in rosso */
    .sc-tr-form .sec-head .accent {
      color: var(--accent);
    }

    .sc-tr-form .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    .sc-tr-form .formbox {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
    }

    /* Grid a DUE colonne (mobile → 1 colonna) */
    .sc-tr-form .grid2 {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media (min-width:760px) {
      .sc-tr-form .grid2 {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .sc-tr-form .field {
      display: flex;
      flex-direction: column;
      gap: 6px;
      position: relative;
    }

    .sc-tr-form .label {
      font-weight: 800;
      font-size: 13px;
      color: #fff;
    }

    .sc-tr-form .input,
    .sc-tr-form .textarea,
    .sc-tr-form .select {
      width: 100%;
      min-height: 44px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #111;
      color: #fff;
      outline: none;
      box-shadow: inset 0 8px 18px -12px rgba(0, 0, 0, .5);
      caret-color: #fff;
    }

    .sc-tr-form .textarea {
      min-height: 120px;
      resize: vertical;
    }

    /* Placeholder BIANCHI */
    .sc-tr-form .input::placeholder,
    .sc-tr-form .textarea::placeholder {
      color: #fff;
      opacity: .92;
    }

    .sc-tr-form .note {
      font-size: 12px;
      color: #fff;
      margin-top: 8px;
    }

    /* ====== DATE PICKER ====== */
    .sc-tr-form .date-display {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      width: 100%;
      min-height: 44px;
      padding: 10px 12px;
      border-radius: 12px;
      border: 1px solid var(--line);
      background: #111;
      color: #fff;
      font-weight: 800;
      cursor: pointer;
    }

    .sc-tr-form .date-display .placeholder {
      color: #fff;
      font-weight: 600;
    }

/* Mobile: niente rettangoli blu su tap del date picker (Seleziona data) */
@media (max-width: 1023px) {
  .sc-tr-form .date-display,
  .sc-tr-form .date-display *,
  .sc-tr-form .cal-toggle,
  .sc-tr-form .cal-navbtn,
  .sc-tr-form .day,
  .sc-tr-form .mon {
    -webkit-tap-highlight-color: transparent !important;
  }

  .sc-tr-form .date-display,
  .sc-tr-form .cal-toggle,
  .sc-tr-form .cal-navbtn,
  .sc-tr-form .day,
  .sc-tr-form .mon {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .sc-tr-form .date-display:focus,
  .sc-tr-form .date-display:focus-visible,
  .sc-tr-form .cal-toggle:focus,
  .sc-tr-form .cal-toggle:focus-visible,
  .sc-tr-form .cal-navbtn:focus,
  .sc-tr-form .cal-navbtn:focus-visible,
  .sc-tr-form .day:focus,
  .sc-tr-form .day:focus-visible,
  .sc-tr-form .mon:focus,
  .sc-tr-form .mon:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }
}

    .sc-tr-form .date-caret {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
    }

    .sc-tr-form .date-pop {
      position: absolute;
      left: 0;
      top: calc(100% + 6px);
      width: 100%;
      z-index: 50;
      overflow: hidden;
      display: none;
      border-radius: 14px;
      box-shadow: var(--shadow);
      /* POPUP bianco con testi rossi */
      background: #ffffff;
      color: var(--accent);
      color-scheme: light;
      border: 1px solid var(--accent);
    }

    .sc-tr-form .date-pop.is-open {
      display: block;
    }

    /* Header calendario bianco con testi/contorni rossi */
    .sc-tr-form .cal-head {
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      background: #fff;
      color: var(--accent);
      font-weight: 900;
      letter-spacing: .2px;
      border-bottom: 1px solid rgba(212, 0, 0, .15);
    }

    .sc-tr-form .cal-center {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      text-align: center;
    }

    .sc-tr-form .cal-label {
      min-width: 180px;
      color: var(--accent);
    }

    .sc-tr-form .cal-right {
      min-width: 52px;
    }

    .sc-tr-form .cal-toggle,
    .sc-tr-form .cal-navbtn {
      appearance: none;
      border: 1px solid var(--accent);
      border-radius: 10px;
      padding: 6px 10px;
      background: transparent;
      color: var(--accent);
      cursor: pointer;
      font-weight: 900;
    }

    .sc-tr-form .cal-toggle:hover,
    .sc-tr-form .cal-navbtn:hover {
      background: rgba(212, 0, 0, .06);
    }

    /* Giorni/mesi rossi su bianco */
    .sc-tr-form .cal-grid {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 6px;
      padding: 10px 12px 14px;
    }

    .sc-tr-form .dow {
      opacity: .9;
      font-weight: 800;
      text-align: center;
      color: var(--accent);
    }

    .sc-tr-form .day {
      appearance: none;
      border: 1px solid transparent;
      border-radius: 10px;
      padding: 8px 0;
      background: transparent;
      color: var(--accent);
      font-weight: 800;
      cursor: pointer;
    }

    .sc-tr-form .day:hover {
      background: rgba(212, 0, 0, .08);
    }

    .sc-tr-form .day.is-today {
      outline: 2px solid rgba(212, 0, 0, .45);
      outline-offset: 1px;
    }

    .sc-tr-form .day.is-selected {
      background: rgba(212, 0, 0, .10);
      outline: 2px solid var(--accent);
    }

    .sc-tr-form .month-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 8px;
      padding: 10px 12px 14px;
    }

    @media(min-width:480px) {
      .sc-tr-form .month-grid {
        grid-template-columns: repeat(6, 1fr);
      }
    }

    .sc-tr-form .mon {
      appearance: none;
      border: 1px solid var(--accent);
      border-radius: 12px;
      padding: 10px 0;
      background: #fff;
      color: var(--accent);
      font-weight: 900;
      cursor: pointer;
      text-transform: capitalize;
    }

    .sc-tr-form .mon:hover {
      background: rgba(212, 0, 0, .06);
    }

    .sc-tr-form .mon.is-current {
      outline: 2px solid rgba(212, 0, 0, .45);
    }

    .sc-tr-form .mon.is-view {
      background: rgba(212, 0, 0, .10);
    }

    /* Focus accessibile in rosso */
    .sc-tr-form .cal-toggle:focus-visible,
    .sc-tr-form .cal-navbtn:focus-visible,
    .sc-tr-form .day:focus-visible,
    .sc-tr-form .mon:focus-visible {
      outline: 3px solid rgba(212, 0, 0, .5);
      outline-offset: 2px;
    }

    /* ===== CTA ===== */
    .sc-tr-form .actions {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      margin-top: 10px;
    }

    /* Primario: INVIDIA RICHIESTA = bianco + rosso */
    .sc-tr-form .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 46px;
      padding: 0 18px;
      border-radius: 14px;
      background: #ffffff;
      color: var(--accent);
      border: 1px solid #ffffff;
      font-weight: 900;
      text-decoration: none;
      cursor: pointer;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
    }

    .sc-tr-form .sc-btn:hover {
      filter: brightness(.96);
    }

    /* Ghost invariato */
    .sc-tr-form .sc-btn--ghost {
      background: #242424;
      border: 1px solid var(--line);
      color: #fff;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
    }

/* Mobile: niente rettangoli blu su tap dei bottoni form (Invia richiesta / Chiama ora) */
@media (max-width: 1023px) {
  .sc-tr-form .sc-btn,
  .sc-tr-form .sc-btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  .sc-tr-form .sc-btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .sc-tr-form .sc-btn:focus,
  .sc-tr-form .sc-btn:focus-visible,
  .sc-tr-form .sc-btn:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

    /* Autofill bianco */
    .sc-tr-form input:-webkit-autofill,
    .sc-tr-form input:-webkit-autofill:hover,
    .sc-tr-form input:-webkit-autofill:focus {
      -webkit-text-fill-color: #fff;
      transition: background-color 5000s ease-in-out 0s;
      box-shadow: 0 0 0 1000px #111 inset;
    }

/* ================= SEZIONE 4 ================= */
.sc-tr-process {
      /* ACCENTO ROSSO FERRARI */
      --accent: #D40000;

      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 16px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      isolation: isolate;
    }

    .sc-tr-process .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
    }

    .sc-tr-process .sec-head {
      text-align: center;
      margin-bottom: 14px;
    }

    .sc-tr-process .sec-head h2 {
      margin: 0 0 8px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
      color: #fff;
    }

    /* “funziona?” in rosso */
    .sc-tr-process .sec-head .accent {
      color: var(--accent);
    }

    .sc-tr-process .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    .sc-tr-process .timeline {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media (min-width:900px) {
      .sc-tr-process .timeline {
        grid-template-columns: repeat(4, 1fr);
      }
    }

    .sc-tr-process .step {
      position: relative;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 16px;
      box-shadow: var(--shadow);
      transform: translateZ(0);
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    /* Glow ROSSO morbido (fallback senza color-mix) */
    .sc-tr-process .step::before {
      content: "";
      position: absolute;
      inset: -3px;
      border-radius: calc(var(--radius) + 4px);
      background: radial-gradient(120% 120% at 50% 100%,
          rgba(212, 0, 0, .65) 0%,
          rgba(212, 0, 0, .16) 45%,
          transparent 70%);
      z-index: -1;
      transform: translateY(6px) scale(.985);
      filter: blur(14px);
      opacity: .28;
      transition: opacity .18s ease, transform .18s ease, filter .18s ease;
      pointer-events: none;
    }

    /* Se supportato: usa var(--accent) per il glow */
    @supports (background: color-mix(in srgb, red 50%, transparent)) {
      .sc-tr-process .step::before {
        background: radial-gradient(120% 120% at 50% 100%,
            color-mix(in srgb, var(--accent) 65%, transparent) 0%,
            color-mix(in srgb, var(--accent) 16%, transparent) 45%,
            transparent 70%);
      }
    }

    .sc-tr-process .step:hover,
    .sc-tr-process .step:focus-visible {
      transform: translateY(-1px) scale(1.01);
      box-shadow: 0 14px 30px rgba(0, 0, 0, .34);
      border-color: rgba(255, 255, 255, .16);
      outline: none;
    }

    .sc-tr-process .step:hover::before,
    .sc-tr-process .step:focus-visible::before {
      opacity: .55;
      transform: translateY(2px) scale(1);
      filter: blur(10px);
    }

    /* Badge numerati: SFONDO BIANCO, TESTO ROSSO + bordo rosso */
    .sc-tr-process .num {
      width: 32px;
      height: 32px;
      border-radius: 10px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #ffffff;
      color: var(--accent);
      border: 1px solid var(--accent);
      font-weight: 900;
      margin-bottom: 10px;
    }

    .sc-tr-process h3 {
      margin: .1rem 0 .35rem;
      font-weight: 900;
    }

    .sc-tr-process p {
      margin: 0;
      color: var(--muted);
    }

    @media (prefers-reduced-motion: reduce) {

      .sc-tr-process .step,
      .sc-tr-process .step::before {
        transition: none;
        transform: none;
        filter: none;
      }
    }

/* ================= SEZIONE 5 ================= */
.sc-tr-pricing {
      /* ACCENTO ROSSO FERRARI */
      --accent: #D40000;

      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e 60px sotto */
      isolation: isolate;
    }

    .sc-tr-pricing .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      /* verticale già gestito dalla sezione */
      overflow-x: clip;
    }

    .sc-tr-pricing .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    .sc-tr-pricing .sec-head h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
    }

    .sc-tr-pricing .sec-head .accent {
      color: var(--accent);
      /* parola “Tariffe” in rosso */
    }

    .sc-tr-pricing .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    .sc-tr-pricing .price-grid {
      display: grid;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media(min-width:900px) {
      .sc-tr-pricing .price-grid {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    .sc-tr-pricing .plan {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    .sc-tr-pricing .plan header {
      padding: 16px;
      border-bottom: 1px solid var(--line);
    }

    .sc-tr-pricing .plan h3 {
      margin: 0 0 4px;
      font-weight: 900;
    }

    .sc-tr-pricing .subtitle {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    .sc-tr-pricing .body {
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .sc-tr-pricing .ul {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 8px;
    }

    .sc-tr-pricing .ul li {
      display: flex;
      gap: 8px;
      align-items: flex-start;
    }

    .sc-tr-pricing .ul li svg {
      width: 18px;
      height: 18px;
      color: var(--accent);
      /* spunte rosse */
      flex: 0 0 18px;
    }

/* ================= SEZIONE 6 ================= */
.sc-tr-gallery {
      --accent: var(--pf-sdv-orange, #FF7A00);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --line: rgba(255, 255, 255, .14);
      --radius: 16px;
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e 60px sotto */
    }

    .sc-tr-gallery .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      /* verticale gestito dalla sezione */
      overflow-x: clip;
      /* sicurezza anti-artefatti laterali */
    }

    .sc-tr-gallery .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    .sc-tr-gallery .sec-head h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
    }

    /* SOLO la parola "road" in rosso Ferrari */
    .sc-tr-gallery .sec-head .accent {
      color: #D40000;
    }

    .sc-tr-gallery .sec-head p {
      margin: 0;
      color: var(--muted);
      font-weight: 600;
    }

    /* GRID a 3 colonne su desktop, 1 su mobile — NIENTE SCROLL ORIZZONTALE */
    .sc-tr-gallery .snap {
      display: grid;
      grid-template-columns: 1fr;
      gap: 12px;
      /* rimosse proprietà del carosello orizzontale */
    }

    @media (min-width:900px) {
      .sc-tr-gallery .snap {
        grid-template-columns: repeat(3, 1fr);
      }
    }

    /* Hover zoom sulle card On the road */
    .sc-tr-gallery .snap figure {
      position: relative;
      overflow: hidden;
      border-radius: 14px;
    }

    .sc-tr-gallery .snap figure img {
      transition: transform .3s ease;
    }

    .sc-tr-gallery .snap figure:hover img {
      transform: scale(1.04);
    }

    .sc-tr-gallery figure {
      margin: 0;
      position: relative;
      border-radius: 16px;
      overflow: hidden;
      border: 1px solid var(--line);
      background: #0b0b0b;
    }

    .sc-tr-gallery img {
      width: 100%;
      height: 260px;
      object-fit: cover;
      display: block;
    }

    /* On the road: abbassa molto la 2ª immagine (Copertura totale) dentro la card */
    .sc-tr-gallery .snap figure:nth-child(2) img {
      object-position: 50% 24%;
    }

    .sc-tr-gallery figcaption {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      padding: 10px 12px;
      background: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, .72));
      font-weight: 800;
    }

/* ================= SEZIONE 7 ================= */
.sc-tr-faq {
      --accent: #D40000;
      /* Rosso Ferrari per "Domande" */
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 14px;
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 60px 0;
      /* 60px sopra e sotto */
    }

    .sc-tr-faq .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      /* verticale già gestito dalla sezione */
    }

    .sc-tr-faq .sec-head {
      text-align: center;
      margin-bottom: 10px;
    }

    .sc-tr-faq .sec-head h2 {
      margin: 0 0 6px;
      font-weight: 900;
      letter-spacing: -.02em;
      font-size: clamp(1.8rem, 3.6vw, 2.4rem);
      line-height: 1.08;
    }

    .sc-tr-faq .sec-head .accent {
      color: var(--accent);
      /* parola “Domande” ROSSA */
    }

    .sc-tr-faq .faq {
      display: grid;
      gap: 12px;
      grid-template-columns: 1fr;
    }

    @media(min-width:900px) {
      .sc-tr-faq .faq {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .sc-tr-faq .q {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
    }

    /* Testo del summary: SEMPRE bianco (anche su hover/focus/open) */
    .sc-tr-faq .q summary {
      list-style: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 14px 16px;
      font-weight: 900;
      color: var(--text);
      transition: color .15s ease;
      user-select: none;
    }

    .sc-tr-faq .q summary * {
      color: inherit;
    }

    .sc-tr-faq .q summary:hover,
    .sc-tr-faq .q summary:hover *,
    .sc-tr-faq .q summary:focus-visible,
    .sc-tr-faq .q[open] summary {
      color: var(--text);
    }

    .sc-tr-faq .q summary::-webkit-details-marker {
      display: none;
    }

    .sc-tr-faq .q .a {
      padding: 0 16px 14px;
      color: var(--muted);
    }

    .sc-tr-faq .q[open] summary {
      border-bottom: 1px solid var(--line);
    }

    .sc-tr-faq .caret {
      width: 18px;
      height: 18px;
      transform: rotate(0deg);
      transition: transform .15s ease;
    }

    .sc-tr-faq .q[open] .caret {
      transform: rotate(180deg);
    }

/* Android: rimuove rettangoli blu (tap highlight/focus) sui summary FAQ */
@media (hover: none) and (pointer: coarse) {
  .sc-tr-faq .q summary,
  .sc-tr-faq .q summary * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }
  .sc-tr-faq .q summary:focus,
  .sc-tr-faq .q summary:focus-visible {
    outline: none;
    box-shadow: none;
  }
  .sc-tr-faq .q summary:active {
    background: transparent;
  }
}

/* Mobile: fallback extra per FAQ (alcuni Android non matchano pointer/hover correttamente) */
@media (max-width: 1023px) {
  .sc-tr-faq summary,
  .sc-tr-faq summary * {
    -webkit-tap-highlight-color: transparent !important;
  }

  .sc-tr-faq summary {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .sc-tr-faq summary:focus,
  .sc-tr-faq summary:focus-visible,
  .sc-tr-faq summary:active {
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
  }
}

/* Trasporto: su mobile elimina rettangoli blu su qualunque elemento cliccabile (esclusi input/textarea) */
@media (hover: none) and (pointer: coarse) {
  html,
  body {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  body * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a,
  button,
  summary,
  [role="button"],
  [role="menuitem"],
  [tabindex]:not([tabindex="-1"]) {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  a *,
  button *,
  summary *,
  [role="button"] *,
  [role="menuitem"] * {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  a:focus,
  a:focus-visible,
  button:focus,
  button:focus-visible,
  summary:focus,
  summary:focus-visible,
  [role="button"]:focus,
  [role="button"]:focus-visible,
  [role="menuitem"]:focus,
  [role="menuitem"]:focus-visible,
  [tabindex]:not([tabindex="-1"]):focus,
  [tabindex]:not([tabindex="-1"]):focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  a:active,
  button:active,
  summary:active,
  [role="button"]:active,
  [role="menuitem"]:active,
  [tabindex]:not([tabindex="-1"]):active {
    background-color: transparent !important;
  }

  body :not(input):not(textarea)::selection {
    background: transparent;
  }
}

/* ================= SEZIONE 8 ================= */
.sc-tr-cta {
      --accent: var(--pf-sdv-orange, #FF7A00);
      --text: #fff;
      --muted: rgba(255, 255, 255, .88);
      --panel: #1a1b1d;
      --line: rgba(255, 255, 255, .14);
      --radius: 18px;
      --shadow: 0 24px 32px -18px rgba(0, 0, 0, .65);
      background: linear-gradient(180deg, #0c0c0d, #141415);
      color: var(--text);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      text-align: center;
      padding: 60px 0;
      isolation: isolate;
    }

    .sc-tr-cta .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 16px;
      overflow-x: clip;
    }

    .sc-tr-cta .box {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
    }

    .sc-tr-cta h3 {
      margin: 0 0 .35em;
      font-weight: 900;
      font-size: clamp(1.4rem, 3vw, 1.9rem);
    }

    .sc-tr-cta p {
      margin: 0 0 .8rem;
      color: var(--muted);
      font-weight: 600;
    }

    .sc-tr-cta .row {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: center;
    }

    .sc-tr-cta .sc-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      height: 46px;
      padding: 0 18px;
      border-radius: 14px;
      border: 1px solid var(--accent);
      background: var(--accent);
      color: #0b0b0b;
      font-weight: 900;
      box-shadow: 0 10px 20px -12px rgba(0, 0, 0, .7);
      text-decoration: none;
    }

    .sc-tr-cta .sc-btn--ghost {
      background: #242424;
      border: 1px solid rgba(255, 255, 255, .14);
      color: #fff;
    }

    /* Variante bianca: SFONDO #fff, TESTO rosso Ferrari, NIENTE bordo rosso */
    .sc-tr-cta .sc-btn--white {
      background: #ffffff;
      color: #D40000;
      border-color: #ffffff;
    }

/* Mobile: niente rettangoli blu su tap dei bottoni CTA (Richiedi preventivo / Scrivici su WhatsApp) */
@media (max-width: 1023px) {
  .sc-tr-cta .sc-btn,
  .sc-tr-cta .sc-btn * {
    -webkit-tap-highlight-color: transparent !important;
  }

  .sc-tr-cta .sc-btn {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .sc-tr-cta .sc-btn:focus,
  .sc-tr-cta .sc-btn:focus-visible,
  .sc-tr-cta .sc-btn:active {
    outline: none !important;
    box-shadow: none !important;
  }
}

/* ================= FOOTER ================= */
:root {
      --pf-sdv-orange: #FF7A00;
      --sidepad: 16px;
      /* padding simmetrico lato schermo */
    }

    @media (min-width: 1200px) {
      :root {
        --sidepad: 24px;
      }
    }

    #af-footer {
      --accent: #D40000;
      /* Ferrari Red */
      --bg: #0b0b0b;
      --fg: #ffffff;
      --muted: rgba(255, 255, 255, .85);
      --border: rgba(255, 255, 255, .16);
      --card: rgba(255, 255, 255, .04);
      --radius: 18px;
      --ease: cubic-bezier(.4, 0, .2, 1);
      background: var(--bg);
      color: var(--fg);
      border-top: 1px solid var(--border);
      font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    #af-footer .af-container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 var(--sidepad);
    }

    #af-footer a {
      color: var(--muted);
      text-decoration: none;
      transition: color .2s var(--ease), opacity .2s var(--ease);
    }

    #af-footer a:hover {
      color: var(--fg);
    }

    /* Top blocco */
    #af-footer .af-top {
      padding: 64px 0 0;
    }

    #af-footer .af-grid {
      display: grid;
      gap: 32px;
    }

    /* ===== DESKTOP (INVARIATO) ===== */
    @media (min-width: 768px) {
      #af-footer .af-grid {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
      }

      #af-footer .col-center {
        justify-self: center;
        text-align: center;
      }

      /* Social allineato a destra con stesso padding del brand a sinistra */
      #af-footer .col-right {
        justify-self: end;
        padding-right: var(--sidepad);
      }
    }

    /* ===== MOBILE ONLY: Social affianco a Servizi + piccoli fix layout ===== */
    @media (max-width: 767.98px) {
      #af-footer .af-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "left left"
          "center right";
        align-items: start;
      }

      #af-footer .af-section {
        margin: 0;
      }

      #af-footer .af-grid>.af-section:nth-child(1) {
        grid-area: left;
      }

      #af-footer .col-center {
        grid-area: center;
        justify-self: start;
        text-align: left;
      }

      #af-footer .col-right {
        grid-area: right;
        justify-self: end;
        padding-right: 0;
        transform: translateX(-30px);
        /* sposta Social 30px a sinistra SOLO mobile */
      }

      #af-footer .social-list {
        justify-items: start;
      }
    }

    /* Titoli & testo */
    #af-footer .af-section h4 {
      margin: 0 0 14px 0;
      font-weight: 800;
      letter-spacing: .2px;
      font-size: 16px;
    }

    #af-footer .af-logo {
      font-weight: 800;
      font-size: 26px;
      letter-spacing: -.02em;
      margin: 0 0 6px 0;
    }

    #af-footer .af-logo .accent {
      color: var(--accent);
    }

    /* "Cars" in rosso */
    #af-footer .af-desc {
      margin: 0 0 18px 0;
      color: var(--muted);
      font-weight: 600;
      line-height: 1.45;
    }

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

    #af-footer .af-row {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
    }

    #af-footer .af-icon {
      width: 18px;
      height: 18px;
      color: var(--accent);
      flex: 0 0 18px
    }

    /* Social */
    #af-footer .social-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    #af-footer .social-list a {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-weight: 800;
      color: var(--fg);
    }

    #af-footer .social-list a:hover {
      opacity: .92
    }

    #af-footer .social-list svg {
      width: 18px;
      height: 18px;
      flex: 0 0 18px;
      color: var(--accent);
    }

    /* Utility label nascosta */
    #af-footer .sr-only {
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* === NEWSLETTER (una riga: email + bottone a destra) === */
    #af-footer .af-newsbar {
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
      padding: 18px 0;
      margin: 16px 0 0;
    }

    #af-footer .af-newsbar .nb-grid {
      display: grid;
      align-items: center;
      gap: 16px;
      grid-template-columns: 1fr;
    }

    @media (min-width: 900px) {
      #af-footer .af-newsbar .nb-grid {
        grid-template-columns: 1fr auto;
      }
    }

    #af-footer .af-newsbar .nb-title {
      margin: 0 0 6px 0;
      font-size: 16px;
      font-weight: 800;
      color: #fff;
    }

    #af-footer .af-newsbar .nb-sub {
      margin: 0;
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-newsbar .nb-form {
      display: flex;
      align-items: center;
      gap: 12px;
      white-space: nowrap;
    }

    #af-footer .af-newsbar .nb-input {
      width: clamp(280px, 40vw, 560px);
      height: 44px;
      border-radius: 9999px;
      background: transparent;
      border: 1px solid var(--border);
      color: #fff;
      padding: 0 14px;
      font-size: 14px;
      outline: none;
      transition: box-shadow .15s var(--ease), border-color .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-input::placeholder {
      color: rgba(255, 255, 255, .55);
    }

    #af-footer .af-newsbar .nb-input:focus {
      border-color: rgba(255, 255, 255, .28);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18);
    }

    /* Bottone: testo rosso + sfondo bianco + BORDO BIANCO */
    #af-footer .af-newsbar .nb-btn {
      height: 44px;
      padding: 0 16px;
      border-radius: 9999px;
      flex: 0 0 auto;
      border: 1px solid #ffffff;
      background: #ffffff;
      color: var(--accent);
      font-weight: 800;
      font-size: 14px;
      cursor: pointer;
      box-shadow: 0 6px 18px rgba(0, 0, 0, .25);
      transition: transform .15s var(--ease), box-shadow .15s var(--ease), filter .15s var(--ease), background .15s var(--ease);
    }

    #af-footer .af-newsbar .nb-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, .30);
      filter: brightness(0.98);
    }

    #af-footer .af-newsbar .nb-btn:focus-visible {
      outline: 2px solid #ffffff;
      outline-offset: 2px;
    }

    /* ===== MOBILE: evita overflow del form, centra e rendi fluido ===== */
    @media (max-width: 520px) {
      #af-footer .af-newsbar .nb-form {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
      }

      #af-footer .af-newsbar .nb-input {
        width: 100%;
      }

      #af-footer .af-newsbar .nb-btn {
        width: 100%;
        text-align: center;
      }
    }

    /* ===== MOBILE: Servizi in griglia 2x2 con riordinamento (Deposito sotto Noleggio a sinistra) ===== */
    @media (max-width: 767.98px) {
      #af-footer .col-center .af-list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 12px;
        justify-items: start;
      }

      /* riga 1 */
      #af-footer .col-center .af-list .svc-vendita {
        grid-column: 1;
        grid-row: 1;
      }

      #af-footer .col-center .af-list .svc-trasporto {
        grid-column: 2;
        grid-row: 1;
      }

      /* riga 2 */
      #af-footer .col-center .af-list .svc-noleggio {
        grid-column: 1;
        grid-row: 2;
      }

      #af-footer .col-center .af-list .svc-lavaggio {
        grid-column: 2;
        grid-row: 2;
      }

      /* riga 3: Deposito sotto Noleggio, allineato a sinistra */
      #af-footer .col-center .af-list .svc-deposito {
        grid-column: 1;
        grid-row: 3;
        justify-self: start;
      }
    }

    /* Bottom */
    #af-footer .af-bottom {
      border-top: 0;
      padding: 18px 0;
      margin-top: 0;
    }

    #af-footer .af-bottom .wrap {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: center;
      justify-content: space-between;
    }

    @media (min-width:768px) {
      #af-footer .af-bottom .wrap {
        flex-direction: row;
      }
    }

    #af-footer .af-copy {
      font-size: 14px;
      color: var(--muted);
    }

    #af-footer .af-legal {
      display: flex;
      gap: 16px;
      align-items: center;
    }

    #af-footer .af-legal a {
      font-size: 14px;
    }
html[dir="rtl"] .sc-title,
html[dir="rtl"] .pfpdp-title--mobile,
html[dir="rtl"] .pfpdp-title {
  direction: ltr;
  unicode-bidi: plaintext;
  text-align: right;
}

@media (max-width: 767.98px) {
  html[dir="rtl"] #af-footer .col-right {
    text-align: right;
    align-items: flex-end;
  }

  html[dir="rtl"] #af-footer .col-right .social-list {
    flex-direction: column;
    align-items: flex-end;
    padding-right: 18px;
    margin-right: 6px;
  }

  html[dir="rtl"] #af-footer .col-right .social-list a {
    width: 100%;
    justify-content: flex-end;
  }

  html[dir="rtl"] #af-footer .af-grid {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  html[dir="rtl"] #af-footer .col-center {
    order: 2;
  }

  html[dir="rtl"] #af-footer .col-right {
    order: 3;
  }
}

@media (max-width: 767.98px) {
  #af-footer .af-bottom .wrap {
    align-items: center !important;
    text-align: center !important;
  }

  #af-footer .af-bottom.wrap {
    align-items: center !important;
    text-align: center !important;
  }

  #af-footer .af-copy {
    text-align: center !important;
  }

  #af-footer .af-legal {
    justify-content: center !important;
    text-align: center !important;
  }
}
