/* ==========================================================================
   Lencustom Theme — Main Stylesheet
   Mobile-first | CSS custom properties | No external libraries
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CUSTOM PROPERTIES (Design Tokens)
   -------------------------------------------------------------------------- */
:root {
  /* Brand */
  --color-primary:            #1E7F6B;
  --color-primary-dark:       #155a4d;
  --color-primary-light:      #d4ede8;
  --color-primary-foreground: #ffffff;

  /* Neutrals */
  --color-white:          #ffffff;
  --color-bg:             #f8f9fa;
  --color-bg-alt:         #f0f4f3;
  --color-surface:        #ffffff;
  --color-surface-muted:  #f4f6f5;
  --color-background:     #ffffff;
  --color-border:         #e2e8e6;
  --color-text:           #1a1a1a;
  --color-text-muted:     #6b7280;
  --color-muted:          #6b7280;
  --color-dark:           #111827;

  /* Feedback */
  --color-sale:           #e53e3e;
  --color-sale-bg:        #fff5f5;

  /* Typography */
  --font-family:          'Inter', system-ui, -apple-system, BlinkMacSystemFont,
                          'Segoe UI', Roboto, sans-serif;
  --font-heading:         'Inter', system-ui, -apple-system, BlinkMacSystemFont,
                          'Segoe UI', Roboto, sans-serif;
  --font-size-xs:         0.75rem;   /* 12px */
  --font-size-sm:         0.875rem;  /* 14px */
  --font-size-base:       1rem;      /* 16px */
  --font-size-lg:         1.125rem;  /* 18px */
  --font-size-xl:         1.25rem;   /* 20px */
  --font-size-2xl:        1.5rem;    /* 24px */
  --font-size-3xl:        1.875rem;  /* 30px */
  --font-size-4xl:        2.25rem;   /* 36px */
  --font-size-5xl:        3rem;      /* 48px */
  --line-height-tight:    1.25;
  --line-height-base:     1.6;
  --font-weight-normal:   400;
  --font-weight-medium:   500;
  --font-weight-semi:     600;
  --font-weight-bold:     700;

  /* Spacing */
  --space-1:    0.25rem;
  --space-2:    0.5rem;
  --space-3:    0.75rem;
  --space-4:    1rem;
  --space-5:    1.25rem;
  --space-6:    1.5rem;
  --space-7:    1.75rem;
  --space-8:    2rem;
  --space-9:    2.25rem;
  --space-10:   2.5rem;
  --space-12:   3rem;
  --space-14:   3.5rem;
  --space-16:   4rem;
  --space-20:   5rem;
  --space-24:   6rem;

  /* Layout */
  --container-max:  1200px;
  --container-px:   1.25rem;   /* 20px */
  --layout-shell-max: 1440px;
  --layout-shell-px: clamp(var(--space-4), 2.5vw, var(--space-10));
  --header-h:       64px;
  --section-py:     5rem;      /* 80px — standard section padding */

  /* Section backgrounds */
  --color-section-alt:  #f5f7f6;  /* alternating light gray sections */
  --color-contact-bg:   #0f172a;  /* dark CTA section */
  --color-footer-bg:    #1a1f2e;  /* footer — dark gray-blue */

  /* Borders */
  --radius-sm:      4px;
  --radius:         8px;
  --radius-lg:      12px;
  --radius-xl:      16px;
  --radius-2xl:     20px;
  --radius-3xl:     24px;
  --radius-full:    9999px;
  --border:         1px solid var(--color-border);

  /* Shadows */
  --shadow-sm:  0 1px 2px rgba(0,0,0,.05);
  --shadow:     0 1px 8px rgba(0,0,0,.08);
  --shadow-md:  0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 8px 32px rgba(0,0,0,.12);

  /* Transitions */
  --transition:      150ms ease;
  --transition-fast: 120ms ease;
  --transition-sm:   100ms ease;
  --transition-md:   250ms ease;
}

/* --------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  margin: 0;
  padding: 0;
}

body {
  margin: 0;
  padding: 0;
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, video, svg { display: block; max-width: 100%; }
img { height: auto; }
a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-dark); }
a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
ul, ol { list-style: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, select, textarea { font-family: inherit; }
address { font-style: normal; }

/* --------------------------------------------------------------------------
   3. TYPOGRAPHY
   -------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-dark);
}
h1 { font-size: var(--font-size-3xl); }
h2 { font-size: var(--font-size-2xl); }
h3 { font-size: var(--font-size-xl); }
h4 { font-size: var(--font-size-lg); }
h5 { font-size: var(--font-size-base); }
h6 { font-size: var(--font-size-sm); }

p { margin-bottom: var(--space-4); }
p:last-child { margin-bottom: 0; }

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* --------------------------------------------------------------------------
   4. LAYOUT UTILITIES
   -------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-px);
}

/* Wider container for shop / category pages */
.container-wide {
  width: 100%;
  max-width: 1600px;
  margin-inline: auto;
  padding-inline: var(--container-px);
}

.section-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-6);
}

.section-subtitle {
  color: var(--color-text-muted);
  margin-top: calc(-1 * var(--space-4));
  margin-bottom: var(--space-8);
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.section-header .section-title { margin-bottom: 0; }

.section-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-primary);
  white-space: nowrap;
}
.section-link:hover { gap: var(--space-3); }
.section-link svg { transition: transform var(--transition); }
.section-link:hover svg { transform: translateX(3px); }

/* --------------------------------------------------------------------------
   5. BUTTONS
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.7em 1.5em;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  line-height: 1;
  border-radius: var(--radius);
  border: 2px solid transparent;
  transition: background var(--transition), color var(--transition),
              border-color var(--transition), box-shadow var(--transition);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}

.btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}
.btn--primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: var(--color-white);
  box-shadow: 0 2px 8px rgba(30,127,107,.3);
}

.btn--outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn--outline:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.btn--white {
  background: var(--color-white);
  color: var(--color-dark);
  border-color: var(--color-white);
}
.btn--white:hover {
  background: var(--color-bg);
  color: var(--color-primary);
}

.btn--sm  { font-size: var(--font-size-sm);  padding: 0.5em 1em; }
.btn--lg  { font-size: var(--font-size-lg);  padding: 0.85em 2em; }

/* --------------------------------------------------------------------------
   6. HEADER — Single-row navbar (queso-delight style)
   -------------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  margin: 0;
  background: color-mix(in srgb, var(--color-white) 94%, transparent);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border-bottom: 1px solid var(--color-border);
  transform: none;
  contain: none;
  overflow: visible;
}

.trust-marquee {
  height: 36px;
  overflow: hidden;
  background: var(--color-primary-dark);
  color: var(--color-white);
  border-bottom: 1px solid rgba(255,255,255,.1);
  contain: strict;
}

.trust-marquee__track {
  display: flex;
  align-items: center;
  height: 36px;
  white-space: nowrap;
}

.trust-marquee__group {
  display: inline-flex;
  align-items: center;
  gap: clamp(1.4rem, 4vw, 4rem);
  padding-inline: clamp(1rem, 3vw, 2rem);
  flex-shrink: 0;
  animation: trust-scroll 18s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
  .trust-marquee__group {
    animation: none;
  }
}

.trust-marquee:hover .trust-marquee__group {
  animation-play-state: paused;
}

@keyframes trust-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}

.trust-marquee__unit {
  display: inline-flex;
  align-items: center;
  gap: clamp(1.4rem, 4vw, 4rem);
  flex: 0 0 auto;
}

.trust-marquee__item {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-size: .82rem;
  line-height: 1;
}

.trust-marquee__item svg {
  width: 16px;
  height: 16px;
  opacity: .92;
}

.trust-marquee__item strong {
  font-size: .76rem;
  letter-spacing: .08em;
  opacity: .78;
}

.trust-marquee__item span {
  font-weight: 800;
}

.trust-marquee__dot {
  opacity: .38;
  font-weight: 700;
}

#main,
.site-main {
  width: 100%;
  max-width: none;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Admin-bar sticky offset */
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

/* ── Container (matching .container in Tailwind: px-4/px-8, margin auto) ── */
.header-inner {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  min-height: var(--header-h);
  width: 100%;
  max-width: var(--layout-shell-max);
  margin-inline: auto;
  padding: 0 var(--layout-shell-px);
}
@media (min-width: 1024px) {
  .header-inner { gap: var(--space-6); }
}

/* ── Logo (.shrink-0 .mr-2) ── */
.site-logo {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  margin-right: var(--space-2);
}
.site-logo img,
.site-logo .logo-img { max-height: 36px; width: auto; display: block; }
.site-logo .custom-logo-link { display: flex; align-items: center; }
.site-logo .custom-logo-link img { max-height: 36px; width: auto; }
.site-logo__text {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
}

/* Footer brand logo (keep unchanged) */
.footer-brand__logo-link { display: inline-flex; align-items: center; text-decoration: none; }
.footer-brand img,
.footer-brand .logo-img { max-height: 40px; width: auto; display: block; }

/* ── Categorie pill trigger (.hidden .md:block) ── */
.cat-mega {
  position: relative;
  flex-shrink: 0;
  display: none; /* hidden on mobile */
}
@media (min-width: 1024px) {
  .cat-mega { display: block; }
}

.cat-trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: calc(var(--space-10) + var(--space-2));
  padding-inline: var(--space-4);
  background: var(--color-bg-alt);
  color: var(--color-dark);
  border: none;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  font-family: var(--font-family);
  white-space: nowrap;
  transition: background var(--transition), color var(--transition);
}
.cat-trigger:hover { background: color-mix(in srgb, var(--color-primary-light) 52%, var(--color-white)); }
.cat-trigger__icon,
.cat-trigger__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cat-trigger svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.cat-trigger__chevron { transition: transform 0.2s ease; }
.cat-trigger[aria-expanded="true"] .cat-trigger__chevron,
.cat-mega.is-open .cat-trigger__chevron {
  transform: rotate(180deg);
}

/* ── Nav links (.hidden .md:flex .gap-1 .lg:gap-2) ── */
.nav-links {
  display: none; /* hidden on mobile */
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 0;
}
@media (min-width: 768px) {
  .nav-links { display: none; }
}
@media (min-width: 1024px) {
  .nav-links {
    display: flex;
    gap: var(--space-4);
  }
}

/* .inline-flex .items-center .gap-1.5 .px-3 .py-2 .rounded-full .text-sm .font-medium .text-muted-foreground .hover:text-foreground .hover:bg-secondary/60 */
.nav-links > li {
  display: flex;
  align-items: center;
}

.nav-pill {
  display: inline-flex;
  align-items: center;
  gap: calc(var(--space-1) + 2px);
  min-height: calc(var(--space-10) + var(--space-2));
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  white-space: nowrap;
  background: transparent;
  transition: color var(--transition), background var(--transition);
}
.nav-pill:hover,
.current-menu-item > .nav-pill,
.current-menu-parent > .nav-pill {
  color: var(--color-dark);
  background: var(--color-bg-alt);
}
.nav-pill svg { width: 16px; height: 16px; flex-shrink: 0; }
.nav-pill__icon,
.nav-pill__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.nav-pill__label { line-height: 1; }

/* Pill con bordo (Movimentazione = filled, Contattaci = outline) */
.nav-pill--bordered {
  border: 1.5px solid var(--color-border);
  color: var(--color-dark);
  font-weight: var(--font-weight-semi);
}
.nav-pill--filled {
  background: var(--color-bg-alt);
  border-color: var(--color-border);
}
.nav-pill--outline {
  background: transparent;
  border-color: var(--color-border);
}
.nav-pill--bordered:hover {
  border-color: var(--color-text-muted);
  background: color-mix(in srgb, var(--color-bg-alt) 80%, var(--color-border));
  color: var(--color-dark);
}

/* Separatore verticale tra gruppo bordered e link semplici */
.nav-links__separator {
  width: 1px;
  height: 20px;
  background: var(--color-border);
  align-self: center;
  margin-inline: var(--space-1);
  list-style: none;
}

/* Offerte red dot indicator */
.nav-pill--offers { position: relative; }
.menu-item-offerte .nav-pill__icon-wrap,
.nav-pill__icon-wrap { position: relative; }
.nav-pill__dot {
  position: absolute;
  top: -2px; right: -2px;
  width: 6px;
  height: 6px;
  background: var(--color-sale);
  border-radius: var(--radius-full);
  box-shadow: 0 0 0 2px var(--color-white);
}

/* ── Right actions (.ml-auto .flex .items-center .gap-1) ── */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-left: auto;
  flex-shrink: 0;
}

/* Search pill (.h-10 .px-3 .lg:px-4 .border .rounded-full) */
.header-search-pill {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-height: calc(var(--space-10) + var(--space-2));
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  white-space: nowrap;
  transition: border-color var(--transition), color var(--transition);
}
@media (min-width: 1024px) {
  .header-search-pill { padding-inline: var(--space-4); }
}
.header-search-pill:hover {
  border-color: var(--color-text-muted);
  color: var(--color-dark);
}
.header-search-pill svg { flex-shrink: 0; width: 16px; height: 16px; }
.header-search-pill__fake-input {
  display: inline-block;
  color: inherit;
}

/* Search icon-only on mobile */
.header-search-mobile {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--space-10) + var(--space-2));
  height: calc(var(--space-10) + var(--space-2));
  color: var(--color-text-muted);
  background: transparent;
  border: none;
}
.header-search-mobile:hover { color: var(--color-dark); }
.header-search-mobile svg { width: 20px; height: 20px; }
@media (min-width: 1024px) {
  .header-search-mobile { display: none; }
}
@media (max-width: 1023px) {
  .header-search-pill { display: none; }
}
@media (min-width: 640px) { /* sm */
  .header-search-mobile {
    display: flex;
  }
}
@media (min-width: 1024px) {
  .header-search-mobile { display: none; }
}

/* Account link (.hidden .sm:inline-flex .h-10 .px-3) */
.header-account-link {
  display: none; /* hidden */
  align-items: center;
  flex-shrink: 0;
  gap: var(--space-2);
  min-height: calc(var(--space-10) + var(--space-2));
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition), background var(--transition);
}
@media (min-width: 640px) { /* sm:inline-flex */
  .header-account-link { display: inline-flex; }
}
.header-account-link:hover {
  color: var(--color-dark);
  background: var(--color-bg-alt);
}
.header-account-link svg { flex-shrink: 0; width: 16px; height: 16px; }
.header-account-link__label { display: none; white-space: nowrap; }
@media (min-width: 1024px) {
  .header-account-link__label { display: inline; } /* lg:inline */
}

/* Cart pill (dark, .bg-foreground .text-background) */
.header-cart-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: calc(var(--space-10) + var(--space-2));
  padding: 0 var(--space-3);
  background: var(--color-dark);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  white-space: nowrap;
  transition: background var(--transition);
  position: relative;
}
.header-cart-pill:hover { background: color-mix(in srgb, var(--color-dark) 90%, var(--color-white)); }
.header-cart-pill svg { flex-shrink: 0; width: 16px; height: 16px; }
.header-cart-pill__label { display: none; }
@media (min-width: 1024px) {
  .header-cart-pill__label { display: inline; } /* lg:inline */
}
.header-cart-pill .cart-count {
  position: static;
  display: none;
  min-width: 20px; /* min-w-5 */
  height: 20px; /* h-5 */
  padding: 0 6px; /* px-1.5 */
  font-size: 10px; /* text-[10px] */
  font-weight: 700; /* font-bold */
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  background: var(--color-primary);
  border-radius: var(--radius-full);
  font-variant-numeric: tabular-nums;
}
.header-cart-pill .cart-count.has-items { display: flex; }
.header-cart-pill .cart-count:empty { display: none !important; }

/* ── Hamburger (mobile only .md:hidden) ── */
.hamburger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--space-10) + var(--space-2));
  height: calc(var(--space-10) + var(--space-2));
  color: var(--color-dark);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  transition: color var(--transition);
}
@media (min-width: 768px) { /* md:hidden */
  .hamburger { display: none; }
}
.hamburger:hover { color: var(--color-text-muted); }
.hamburger__icon {
  width: 20px;
  height: 20px;
}
.hamburger__icon--close { display: none; }
.nav-open .hamburger__icon--menu { display: none; }
.nav-open .hamburger__icon--close { display: block; }

/* --------------------------------------------------------------------------
   7. MOBILE NAV OVERLAY
   -------------------------------------------------------------------------- */
.mobile-nav {
  display: none;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  padding: var(--space-5) var(--layout-shell-px);
}

.mobile-nav__products {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  min-height: calc(var(--space-10) + var(--space-3));
  margin-bottom: var(--space-4);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}

.mobile-nav__products svg,
.mobile-nav__icon svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.mobile-nav__menu {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.mobile-nav__link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-3);
  border-radius: var(--radius);
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
}

.mobile-nav__link:hover,
.mobile-nav__item.current-menu-item > .mobile-nav__link {
  background: var(--color-bg-alt);
}

.mobile-nav__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}

.mobile-nav__label { line-height: 1.3; }

@media (max-width: 767px) {
  .nav-open .mobile-nav { display: block; }
}

.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 180;
  display: none;
  align-items: stretch;
  justify-content: stretch;
}

.admin-bar .search-overlay {
  inset: 32px 0 0;
}

.search-overlay.is-open {
  display: flex;
}

.search-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.search-overlay__panel {
  position: absolute;
  inset: 0;
  background: var(--color-surface);
  border-radius: 0;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.search-overlay__topbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-8) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.search-overlay__search-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  color: var(--color-text-muted);
}

.search-overlay__input {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--color-dark);
  font-family: var(--font-family);
  font-size: clamp(var(--font-size-2xl), 2.3vw, 2.75rem);
  line-height: 1.08;
  outline: none;
}

.search-overlay__input::placeholder {
  color: var(--color-text-muted);
}

.search-overlay__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  background: transparent;
}

.search-overlay__close svg {
  width: 18px;
  height: 18px;
}

.search-overlay__body {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(230px, 0.55fr) minmax(0, 1.8fr);
  gap: clamp(1.5rem, 3vw, 3rem);
  padding: clamp(1.4rem, 2.6vw, 2.5rem) var(--space-8) var(--space-6);
  overflow-y: auto;
  overflow-x: hidden;
}

.search-overlay__sidebar,
.search-overlay__results {
  min-width: 0;
}

.search-overlay__section + .search-overlay__section {
  margin-top: calc(var(--space-8) + var(--space-2));
}

.search-overlay__eyebrow {
  margin: 0 0 var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.search-overlay__eyebrow::before {
  content: "\21B3";
  margin-right: var(--space-2);
  color: currentColor;
}

.search-overlay__popular {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.search-overlay__popular button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  width: fit-content;
  color: var(--color-dark);
  font-size: var(--font-size-base);
  line-height: 1.4;
  background: transparent;
}

.search-overlay__popular-icon {
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.search-overlay__categories {
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}

.search-overlay__categories li {
  border-bottom: 1px solid var(--color-border);
}

.search-overlay__category-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  color: var(--color-dark);
  font-size: var(--font-size-base);
}

.search-overlay__arrow {
  color: var(--color-text-muted);
  font-size: var(--font-size-base);
  flex-shrink: 0;
}

.search-overlay__product-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
  align-content: start;
}

.search-overlay__product-card {
  display: flex;
  align-items: center;
  gap: .9rem;
  min-width: 0;
  min-height: 7rem;
  padding: .85rem;
  border: 1px solid var(--color-border);
  border-radius: .9rem;
  background: rgba(255,255,255,.74);
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast), background-color var(--transition-fast);
}

.search-overlay__product-card:hover,
.search-overlay__product-card.is-active {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border));
  background: var(--color-white);
  box-shadow: 0 12px 28px rgba(15,23,42,.08);
  transform: translateY(-1px);
}

.search-overlay__product-media {
  width: 5.25rem;
  height: 5.25rem;
  border-radius: .7rem;
  overflow: hidden;
  background: var(--color-bg-alt);
  flex-shrink: 0;
}

.search-overlay__product-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: .25rem;
}

.search-overlay__product-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.search-overlay__product-title {
  color: var(--color-dark);
  font-size: .98rem;
  font-weight: 700;
  line-height: 1.28;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.search-overlay__product-title mark {
  color: inherit;
  background: color-mix(in srgb, var(--color-primary) 16%, transparent);
  border-radius: .22rem;
  padding: 0 .08em;
}

.search-overlay__product-sku {
  display: block;
  margin-top: .28rem;
  color: var(--color-text-muted);
  font-size: .72rem;
  line-height: 1.2;
}

.search-overlay__product-meta {
  margin-top: .32rem;
  color: var(--color-text-muted);
  font-size: .88rem;
  font-weight: 650;
}

.search-overlay__product-linkout {
  align-self: flex-start;
  color: var(--color-text-muted);
  font-size: 1rem;
  flex-shrink: 0;
}

@media (min-width: 1440px) {
  .search-overlay__product-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.search-overlay__empty {
  padding: var(--space-16) 0;
  text-align: center;
}

.search-overlay__empty-title {
  margin-bottom: var(--space-2);
  color: var(--color-dark);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semi);
}

.search-overlay__empty-text {
  color: var(--color-text-muted);
}

.search-overlay__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex: 0 0 auto;
  padding: var(--space-4) var(--space-8);
  border-top: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
}

.search-overlay__footer kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 24px;
  padding: 0 var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-dark);
  font-size: var(--font-size-xs);
}

@media (max-width: 782px) {
  .admin-bar .search-overlay {
    inset: 46px 0 0;
  }
}

@media (max-width: 1023px) {
  .search-overlay__panel {
    inset: 0;
  }

  .search-overlay__topbar {
    padding: var(--space-4) var(--space-5);
  }

  .search-overlay__body {
    grid-template-columns: 1fr;
    gap: var(--space-8);
    padding: var(--space-6) var(--space-5) var(--space-5);
  }

  .search-overlay__product-grid {
    grid-template-columns: 1fr;
  }

  .search-overlay__footer {
    padding-inline: var(--space-5);
  }
}

@media (max-width: 639px) {
  .search-overlay__input {
    font-size: var(--font-size-3xl);
  }

  .search-overlay__popular button,
  .search-overlay__category-link {
    font-size: var(--font-size-base);
  }

  .search-overlay__shortcut {
    display: none;
  }
}


/* --------------------------------------------------------------------------
   8. HERO SECTION
   -------------------------------------------------------------------------- */
.hero {
  position: relative;
  background: linear-gradient(135deg, var(--color-dark) 0%, #1a2e28 50%, var(--color-primary-dark) 100%);
  color: var(--color-white);
  padding: var(--space-16) 0 var(--space-20);
  overflow: hidden;
}
/* Subtle decorative background pattern */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 70% 50%, rgba(30,127,107,.15) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M0 0h40v40H0z'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}

.hero__inner {
  position: relative;
}

.hero__content {
  max-width: 100%;
}

/* Right-side banners — hidden on mobile */
.hero__banners { display: none; }

@media (min-width: 1024px) {
  /* Two-column grid: text left 1.2fr, banners right 1fr */
  .hero__inner {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 40px;
    align-items: center;
  }

  .hero__content { max-width: none; }

  .hero__banners {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-self: center;
  }

  .hero-banner-big {
    width: 100%;
    border-radius: 12px;
    background-size: cover;
    background-position: center;
    background-color: #1a5c48;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
    aspect-ratio: 2 / 1;
  }
  /* Banner link styling */
  .hero-banner-big { display: block; text-decoration: none; }

  .hero-banner-smalls {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .hero-banner-small {
    aspect-ratio: 16 / 11;
    width: 100%;
    border-radius: 10px;
    background-size: cover;
    background-position: center;
    background-color: var(--color-primary-dark);
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
  }
  .hero-banner-small { display: block; text-decoration: none; }
  .hero-banner-big:hover,
  .hero-banner-small:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,.12));
  }
}

.hero__title {
  font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-5xl));
  font-weight: var(--font-weight-bold);
  line-height: 1.15;
  color: var(--color-white);
  margin-bottom: var(--space-5);
}

.hero__subtitle {
  font-size: clamp(var(--font-size-base), 2vw, var(--font-size-xl));
  color: rgba(255,255,255,.8);
  margin-bottom: var(--space-8);
  max-width: 540px;
}

.hero__ctas {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* --------------------------------------------------------------------------
   9. CATEGORIES SECTION
   -------------------------------------------------------------------------- */
.categories-section {
  padding: var(--section-py) 0;
  background: var(--color-white);
}

/* DEPRECATED: .categories-grid replaced with .categories-carousel for horizontal scrolling
.categories-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
*/

.category-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: var(--border);
  background: var(--color-white);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-md), transform var(--transition-md);
}
.category-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.category-card__link { display: block; text-decoration: none; color: inherit; }

.category-card__img-wrap {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-bg);
}
.category-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 350ms ease;
}
.category-card:hover .category-card__img-wrap img { transform: scale(1.04); }

.category-card__body {
  padding: var(--space-4);
}
.category-card__title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  margin-bottom: var(--space-1);
  color: var(--color-dark);
}
.category-card__count {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

/* Carousel layout — horizontal scrollable categories */
.categories-carousel-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.categories-carousel {
  display: flex;
  gap: var(--space-4);
  overflow-x: auto;
  scroll-behavior: smooth;
  flex: 1;
  padding: var(--space-2) 0;
  -webkit-overflow-scrolling: touch;
  /* Hide scrollbar but keep functionality */
  scrollbar-width: none;
}
.categories-carousel::-webkit-scrollbar {
  display: none;
}

.categories-carousel .category-card {
  flex: 0 0 auto;
  width: 200px;
  min-width: 200px;
}

/* Navigation buttons */
.categories-carousel-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--transition-md), transform var(--transition-sm);
  padding: 0;
}
.categories-carousel-nav:hover {
  background: var(--color-primary-dark);
  transform: scale(1.05);
}
.categories-carousel-nav:active {
  transform: scale(0.98);
}
.categories-carousel-nav svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.5;
}
.categories-carousel-nav--prev {
  order: -1;
}

/* Tablet and larger: keep carousel visible */
@media (min-width: 768px) {
  .categories-carousel .category-card {
    width: 220px;
    min-width: 220px;
  }
}

/* Desktop: show more items in view */
@media (min-width: 1024px) {
  .categories-carousel .category-card {
    width: 240px;
    min-width: 240px;
  }
}

/* --------------------------------------------------------------------------
   10. (reserved)
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   11. PRODUCTS SECTIONS (WooCommerce overrides)
   -------------------------------------------------------------------------- */
.products-section { padding: var(--section-py) 0; background: var(--color-white); }
/* Offers section gets alternate background for visual rhythm */
.products-section--offers { background: var(--color-section-alt); }

/* Kill WooCommerce's legacy clearfix pseudo-elements inside .woocommerce — ghost block in CSS Grid */
.woocommerce ul.products::before,
.woocommerce ul.products::after {
  content: none !important;
  display: none !important;
}

/* WooCommerce product loop — CSS Grid layout */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: var(--space-4) !important;
  margin: 0 !important;
  float: none !important;
  width: 100% !important;
}

/* Cards — flex column so button always sits at bottom */
.woocommerce ul.products li.product {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  border: var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-white);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-md);
  width: auto !important;
  margin: 0 !important;
}
.woocommerce ul.products li.product:hover {
  box-shadow: var(--shadow-md);
}

.woocommerce ul.products li.product a:first-child {
  flex-shrink: 0;
}

.woocommerce ul.products li.product a img {
  width: 100% !important;
  height: 220px !important;
  object-fit: cover !important;
  background: var(--color-white) !important;
  display: block !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 15px !important;
  line-height: 1.4 !important;
  min-height: 48px !important;
  padding: var(--space-3) var(--space-4) var(--space-1) !important;
  color: var(--color-dark) !important;
}

.woocommerce ul.products li.product .price {
  padding: 0 var(--space-4) var(--space-2) !important;
  font-size: var(--font-size-base) !important;
  color: var(--color-primary) !important;
  font-weight: var(--font-weight-semi) !important;
}
.woocommerce ul.products li.product .price del {
  color: var(--color-text-muted) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-normal) !important;
}

/* Button pushed to card bottom via flex */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
  display: block !important;
  width: calc(100% - var(--space-4)) !important;
  margin: auto var(--space-2) var(--space-2) !important;
  padding: var(--space-3) !important;
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-semi) !important;
  text-align: center !important;
  transition: background var(--transition) !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
  background: var(--color-primary-dark) !important;
}

/* Sale badge */
.woocommerce span.onsale {
  background: var(--color-sale) !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--font-size-xs) !important;
  min-height: auto !important;
  min-width: auto !important;
  padding: var(--space-1) var(--space-2) !important;
  line-height: 1.4 !important;
  top: var(--space-3) !important;
  left: var(--space-3) !important;
}

/* --------------------------------------------------------------------------
   12. QUICK ORDER SECTION
   -------------------------------------------------------------------------- */
.quick-order-section {
  background: var(--color-primary);
  color: var(--color-white);
  padding: var(--space-12) 0;
}

.quick-order-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.quick-order__title {
  font-size: var(--font-size-2xl);
  color: var(--color-white);
  margin-bottom: var(--space-2);
}

.quick-order-section p { color: rgba(255,255,255,.85); }

.quick-order-form__fields {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.quick-order-form__sku {
  flex: 1;
  min-width: 200px;
  padding: var(--space-3) var(--space-4);
  border: 2px solid rgba(255,255,255,.3);
  border-radius: var(--radius);
  background: rgba(255,255,255,.1);
  color: var(--color-white);
  font-size: var(--font-size-base);
  transition: border-color var(--transition);
}
.quick-order-form__sku::placeholder { color: rgba(255,255,255,.6); }
.quick-order-form__sku:focus {
  outline: none;
  border-color: var(--color-white);
  background: rgba(255,255,255,.15);
}

.quick-order-form__qty {
  width: 80px;
  padding: var(--space-3);
  border: 2px solid rgba(255,255,255,.3);
  border-radius: var(--radius);
  background: rgba(255,255,255,.1);
  color: var(--color-white);
  font-size: var(--font-size-base);
  text-align: center;
  transition: border-color var(--transition);
}
.quick-order-form__qty:focus {
  outline: none;
  border-color: var(--color-white);
}

.quick-order-form__submit {
  background: var(--color-white);
  color: var(--color-primary);
  border: 2px solid var(--color-white);
  padding: var(--space-3) var(--space-6);
}
.quick-order-form__submit:hover {
  background: var(--color-bg);
  color: var(--color-primary-dark);
}

.quick-order-form__message {
  width: 100%;
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
  min-height: 1.4em;
}
.quick-order-form__message.success { color: #a7f3d0; }
.quick-order-form__message.error   { color: #fca5a5; }

/* --------------------------------------------------------------------------
   13. MOVIMENTAZIONE SECTION
   -------------------------------------------------------------------------- */
.movimentazione-section { padding: var(--section-py) 0; background: var(--color-section-alt); }

.movimentazione-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.feature-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: var(--border);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-md), transform var(--transition-md);
}
.feature-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.feature-card__img-wrap {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-alt);
}
.feature-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 350ms ease;
}
.feature-card:hover .feature-card__img-wrap img { transform: scale(1.04); }

.feature-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.feature-card__title { font-size: var(--font-size-xl); }
.feature-card__text { color: var(--color-text-muted); font-size: var(--font-size-sm); flex: 1; }

/* --------------------------------------------------------------------------
   14. TRUST SECTION (white — clean ecommerce style)
   -------------------------------------------------------------------------- */
.trust-section {
  background: var(--color-white);
  padding: var(--space-16) 0 var(--space-12);
  border-top: var(--border);
  border-bottom: var(--border);
}

/* Section header */
.trust-section__header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.trust-section__title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  margin-bottom: var(--space-2);
}

.trust-section__subtitle {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  margin-bottom: 0;
}

/* 4-block grid — 1 col mobile → 2 col tablet → 4 col desktop */
.trust-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

/* Single block */
.trust-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
}

/* Green circle icon */
.trust-block__icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  flex-shrink: 0;
}

.trust-block__title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  margin-bottom: 0;
}

.trust-block__desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: var(--line-height-base);
  margin-bottom: 0;
}

/* Loghi corrieri — dentro la sezione, senza sfondo */
.trust-carriers {
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: var(--border);
  display: flex;
  justify-content: center;
}

.trust-carriers img {
  max-width: 500px;
  width: 100%;
  height: auto;
  opacity: 0.85;
}

/* --------------------------------------------------------------------------
   15. ABOUT SECTION
   -------------------------------------------------------------------------- */
.about-section { padding: var(--section-py) 0; background: var(--color-section-alt); }

.about-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}

.about-text .section-title { margin-bottom: var(--space-4); }
.about-text p { color: var(--color-text-muted); margin-bottom: var(--space-4); }
.about-text .btn { margin-top: var(--space-2); }

.about-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.stat {
  text-align: center;
  padding: var(--space-5);
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  border: var(--border);
}
.stat__number {
  display: block;
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}
.stat__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   16. CONTACT SECTION
   — Uses a distinct dark bg so it separates from the even-darker footer
   -------------------------------------------------------------------------- */
.contact-section {
  background: var(--color-contact-bg);  /* #0f172a */
  color: var(--color-white);
  padding: var(--section-py) 0;
  text-align: center;
  /* hard top border for clarity against light about section */
  border-top: 4px solid var(--color-primary);
}

.contact-inner { max-width: 600px; margin-inline: auto; }
.contact-section .section-title { color: var(--color-white); }
.contact-desc { color: rgba(255,255,255,.75); margin-bottom: var(--space-8); }

.contact-methods {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.contact-method {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: rgba(255,255,255,.85);
  font-size: var(--font-size-lg);
  text-decoration: none;
  transition: color var(--transition);
}
.contact-method:hover { color: var(--color-primary-light); }
.contact-method svg { flex-shrink: 0; }

/* --------------------------------------------------------------------------
   17. FOOTER
   — Uses --color-footer-bg (#060b14) which is distinctly darker than
     the contact section (#0f172a). The top separator makes the split clear.
   -------------------------------------------------------------------------- */
/* Newsletter section */
.ep-newsletter {
  background: #fff;
  padding-block: 4rem;
  border-top: 1px solid hsla(220, 10%, 15%, 0.1);
}

.ep-newsletter__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: center;
}
@media (min-width: 768px) {
  .ep-newsletter__inner {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}

.ep-newsletter__label {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-primary);
  margin-bottom: 0.75rem;
}

.ep-newsletter__heading {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: hsl(220, 10%, 12%);
  margin-bottom: 1rem;
}

.ep-newsletter__heading em {
  font-style: italic !important;
  font-weight: 600 !important;
  font-size: inherit !important;
  color: var(--color-primary) !important;
  display: inline !important;
}

.ep-newsletter__desc {
  font-size: 0.9375rem;
  color: hsla(220, 10%, 12%, 0.78);
  line-height: 1.7;
  max-width: 28rem;
  list-style: none !important;
  display: block !important;
}
.ep-newsletter__desc::before,
.ep-newsletter__desc::after { display: none !important; content: none !important; }

.ep-newsletter__message {
  margin-top: 0.625rem;
  padding: 0.6rem 1.25rem;
  border-radius: 8px;
  font-size: 0.85rem;
  line-height: 1.5;
}
.ep-newsletter__message.ep-nl-success {
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid #a5d6a7;
}
.ep-newsletter__message.ep-nl-error {
  background: #ffebee;
  color: #c62828;
  border: 1px solid #ef9a9a;
}

.ep-newsletter__input-wrap {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: hsl(220, 10%, 96%);
  border-radius: 9999px;
  padding: 0.5rem 0.5rem 0.5rem 1.25rem;
  border: 1px solid hsla(220, 10%, 15%, 0.12);
}

.ep-newsletter__input-wrap svg {
  flex-shrink: 0;
  color: hsla(220, 10%, 15%, 0.4);
}

.ep-newsletter__input-wrap input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: 0.9375rem;
  color: hsl(220, 10%, 15%);
  min-width: 0;
}

.ep-newsletter__input-wrap input::placeholder {
  color: hsla(220, 10%, 15%, 0.4);
}

.ep-newsletter__input-wrap button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: 9999px;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 200ms;
  flex-shrink: 0;
}
.ep-newsletter__input-wrap button:hover {
  background: var(--color-primary-dark, #1e5e3f);
}

.ep-newsletter__legal {
  font-size: 0.75rem;
  color: hsla(220, 10%, 12%, 0.62);
  margin-top: 0.75rem;
  padding-inline: 1.25rem;
}
.ep-newsletter__legal a {
  color: hsl(220, 10%, 28%);
  text-decoration: underline;
}

.site-footer {
  background: var(--color-footer-bg);
  color: rgba(255,255,255,.65);
  padding-top: var(--space-12);
  border-top: 1px solid rgba(255,255,255,.07);
}

.footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

.footer-brand .site-logo__text,
.footer-brand__name {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  display: block;
  margin-bottom: var(--space-2);
}
/* White logo in footer */
.footer-brand img { max-height: 36px; display: block; }
.footer-brand__usp {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-white);
  margin-top: var(--space-3);
}
.footer-brand__usp svg { flex-shrink: 0; color: var(--color-primary); }
.footer-brand__desc {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,.4);
  margin-top: var(--space-1);
}

.footer-brand__address {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,.5);
  margin-top: var(--space-2);
  line-height: 1.6;
}

.footer-nav { display: none; }

.footer-cols {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6) var(--space-4);
}

/* Primary column (Prodotti) — visually stronger */
.footer-col--primary .footer-col__title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  letter-spacing: .04em;
}

.footer-col__title {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: rgba(255,255,255,.8);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.footer-col ul { display: flex; flex-direction: column; gap: 6px; }
.footer-col a {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,.55);
  transition: color var(--transition);
}
.footer-col a:hover { color: var(--color-white); }

/* Primary column links slightly bolder */
.footer-col--primary a {
  color: rgba(255,255,255,.7);
  font-weight: var(--font-weight-medium);
}
.footer-col--primary a:hover { color: var(--color-white); }

.footer-contact p {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-2);
}
.footer-contact a { color: rgba(255,255,255,.55); }
.footer-contact a:hover { color: var(--color-white); }

.footer-bottom {
  margin-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: var(--space-4) 0;
}
.footer-bottom .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.footer-copy { font-size: var(--font-size-xs); }
.footer-copy a { color: rgba(255,255,255,.8); text-decoration: underline; }
.footer-copy a:hover { color: var(--color-white); }

.footer-langs { display: flex; gap: var(--space-2); }
.footer-langs a { opacity: .6; }
.footer-langs a:hover { opacity: 1; }
.footer-langs img { width: 18px; border-radius: 2px; }

/* Footer Badges (Payments, Shipping & Trustpilot — single row) */
.footer-badges {
  margin-top: var(--space-8);
  padding: var(--space-5) 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer-badges .container {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-6);
}
.footer-badges__group {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.footer-badges__title {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: rgba(255,255,255,.7);
  letter-spacing: .04em;
  white-space: nowrap;
  margin: 0;
}
.footer-badges__img {
  height: 28px;
  width: auto;
  display: block;
}
.footer-badges__group--trustpilot {
  margin-left: auto;
}

/* Trustpilot widget */
.footer-trustpilot {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.footer-trustpilot__stars {
  display: flex;
  align-items: center;
  gap: 2px;
}
.footer-trustpilot__rating {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-white);
  white-space: nowrap;
}
.footer-trustpilot__cta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: #00B67A;
  background: rgba(0,182,122,.1);
  padding: 4px 10px;
  border-radius: 4px;
  transition: background var(--transition), color var(--transition);
  white-space: nowrap;
}
.footer-trustpilot__cta:hover {
  background: rgba(0,182,122,.2);
  color: #00D68F;
}

/* Footer Legal */
.footer-legal {
  font-size: var(--font-size-xs);
  color: rgba(255,255,255,.6);
}

/* --------------------------------------------------------------------------
   18. BLOG / ARCHIVE
   -------------------------------------------------------------------------- */
.page-wrap { padding: var(--space-12) 0; }

.archive-header { margin-bottom: var(--space-8); }
.archive-title {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-2);
}
.archive-description { color: var(--color-text-muted); }

.posts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.post-card {
  display: flex;
  flex-direction: column;
  border: var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-white);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-md);
}
.post-card:hover { box-shadow: var(--shadow-md); }

.post-card__thumb {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg);
}
.post-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 350ms ease;
}
.post-card:hover .post-card__thumb img { transform: scale(1.04); }

.post-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.post-card__meta { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.post-card__title { font-size: var(--font-size-lg); }
.post-card__title a { color: var(--color-dark); }
.post-card__title a:hover { color: var(--color-primary); }
.post-card__excerpt { font-size: var(--font-size-sm); color: var(--color-text-muted); flex: 1; }

/* Pagination */
.nav-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-10);
}
.nav-links a,
.nav-links span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  border: var(--border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.nav-links a:hover { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.nav-links span.current { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }

/* Header navbar must keep Lovable styling, not generic archive pagination pills */
.site-header .nav-links {
  justify-content: flex-start;
  flex-wrap: nowrap;
  margin-top: 0;
  gap: clamp(1.35rem, 2vw, 2.25rem);
  min-width: 0;
}

.site-header .nav-links > li {
  display: flex;
  align-items: center;
}

.site-header .nav-links > li > a.nav-pill,
.site-header .nav-links > li > .nav-pill,
.site-header .nav-links > li > a,
.site-header .nav-links > li > span {
  min-width: 0;
  height: auto;
  padding: var(--space-1) 0;
  gap: 0.42rem;
  border: 0;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-muted);
  justify-content: flex-start;
}

.site-header .nav-links > li > a.nav-pill:hover,
.site-header .nav-links > li.current-menu-item > a.nav-pill,
.site-header .nav-links > li.current-menu-parent > a.nav-pill,
.site-header .nav-links > li > a:hover {
  background: transparent;
  color: var(--color-dark);
  border-color: transparent;
}

.site-header .nav-links .nav-pill__icon,
.site-header .nav-links .nav-pill__icon-wrap {
  color: inherit;
}

.site-header .menu-item-offerte .nav-pill__icon-wrap,
.site-header .menu-item-offerte .nav-pill__icon-wrap svg,
.site-header .menu-item-offerte .nav-pill__icon {
  color: var(--color-text-muted);
  fill: none;
  stroke: currentColor;
}

.site-header .nav-links .nav-pill__icon,
.site-header .nav-links .nav-pill__icon-wrap,
.site-header .nav-links .nav-pill__label {
  min-width: 0;
  height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.site-header .nav-links .nav-pill__dot {
  position: absolute;
  top: -2px;
  right: -2px;
  display: block;
  min-width: 6px;
  width: 6px;
  height: 6px;
  padding: 0;
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-sale);
  color: transparent;
  box-shadow: 0 0 0 2px var(--color-white);
}

.site-header .nav-links .nav-pill__icon,
.site-header .nav-links .nav-pill__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.site-header .nav-links .nav-pill__label {
  display: inline;
  color: inherit;
}

@media (min-width: 1280px) {
  .site-header #site-nav.nav-links {
    gap: 2.25rem;
  }
}

@media (min-width: 1024px) and (max-width: 1199px) {
  .site-header #site-nav.nav-links {
    gap: 1rem;
  }

  .site-header #site-nav.nav-links .nav-pill {
    font-size: 0.8125rem;
    gap: 0.35rem;
  }
}

/* --------------------------------------------------------------------------
   19. SINGLE POST / PAGE
   -------------------------------------------------------------------------- */
.content-area--single,
.content-area--page { max-width: 780px; }

.single-post__header { margin-bottom: var(--space-6); }
.single-post__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.single-post__cats a {
  padding: 2px var(--space-2);
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}
.single-post__title,
.single-page__title { font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl)); }

.single-post__featured-img,
.single-page__featured-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-8);
}
.single-post__featured-img img,
.single-page__featured-img img { width: 100%; }

.single-post__content,
.single-page__content {
  font-size: var(--font-size-lg);
  line-height: 1.7;
  color: var(--color-text);
}
.single-post__content h2,
.single-page__content h2 { margin: var(--space-8) 0 var(--space-4); }
.single-post__content h3,
.single-page__content h3 { margin: var(--space-6) 0 var(--space-3); }
.single-post__content p,
.single-page__content p { margin-bottom: var(--space-5); }
.single-post__content ul,
.single-page__content ul,
.single-post__content ol,
.single-page__content ol {
  margin-bottom: var(--space-5);
  padding-left: var(--space-6);
}
.single-post__content ul { list-style: disc; }
.single-post__content ol { list-style: decimal; }
.single-post__content li,
.single-page__content li { margin-bottom: var(--space-2); }
.single-post__content blockquote,
.single-page__content blockquote {
  border-left: 4px solid var(--color-primary);
  padding: var(--space-4) var(--space-6);
  background: var(--color-bg);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-style: italic;
  color: var(--color-text-muted);
  margin: var(--space-6) 0;
}

.single-post__footer { margin-top: var(--space-10); padding-top: var(--space-6); border-top: var(--border); }
.single-post__tags { margin-bottom: var(--space-6); }
.single-post__tags a {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg);
  border: var(--border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-right: var(--space-2);
  margin-bottom: var(--space-2);
  transition: color var(--transition), border-color var(--transition);
}
.single-post__tags a:hover { color: var(--color-primary); border-color: var(--color-primary); }

.post-navigation {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}
.post-navigation a { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); }

/* --------------------------------------------------------------------------
   20. 404 PAGE
   -------------------------------------------------------------------------- */
.error-404 { padding: var(--space-24) 0; text-align: center; }
.error-404__code {
  display: block;
  font-size: 8rem;
  font-weight: var(--font-weight-bold);
  color: var(--color-border);
  line-height: 1;
  margin-bottom: var(--space-4);
}
.error-404__title { font-size: var(--font-size-3xl); margin-bottom: var(--space-4); }
.error-404__desc { color: var(--color-text-muted); max-width: 480px; margin-inline: auto; margin-bottom: var(--space-8); }
.error-404__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}
.error-404__actions .search-form { display: flex; gap: var(--space-2); }
.error-404__actions .search-field {
  padding: var(--space-3) var(--space-4);
  border: var(--border);
  border-radius: var(--radius);
  font-size: var(--font-size-base);
  min-width: 240px;
}
.error-404__actions .search-submit {
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
}

/* --------------------------------------------------------------------------
   20c. 404 PAGE — QUESO-DELIGHT STYLE (notfound-*)
   -------------------------------------------------------------------------- */
.notfound-bg {
  min-height: 100vh;
  background: var(--color-background, #f8fafb);
  color: var(--color-text-dark, #1a232b);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-16, 4rem) 0;
}
.notfound-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.notfound-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12, 3rem);
  align-items: center;
}
.notfound-left {
  flex: 1 1 340px;
  min-width: 320px;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: var(--space-6, 1.5rem);
}
.notfound-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  border: 1.5px solid var(--color-border, #e0e6eb);
  background: var(--color-muted, #f6f8f9);
  color: var(--color-text-muted, #5b6c7a);
  border-radius: 999px;
  font-size: var(--font-size-xs, 0.8rem);
  font-weight: 500;
  padding: 0.25em 1em;
  margin-bottom: var(--space-4, 1rem);
}
.notfound-title {
  font-family: var(--font-heading, inherit);
  font-size: 4rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1;
  margin: 0 0 var(--space-2, 0.5rem) 0;
}
.notfound-title span {
  color: var(--color-primary, #17806d);
}
.notfound-sub {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: var(--space-2, 0.5rem);
}
.notfound-joke {
  color: var(--color-text-muted, #5b6c7a);
  font-size: var(--font-size-base, 1rem);
  margin-bottom: var(--space-2, 0.5rem);
}
.notfound-actions {
  display: flex;
  gap: var(--space-4, 1rem);
  flex-wrap: wrap;
  margin-bottom: var(--space-4, 1rem);
}
.notfound-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: var(--font-size-base, 1rem);
  font-weight: 600;
  border-radius: var(--radius, 0.5rem);
  padding: 0.75em 1.5em;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.notfound-btn--primary {
  background: var(--color-primary, #17806d);
  color: #fff;
}
.notfound-btn--primary:hover {
  background: #126655;
}
.notfound-btn--ghost {
  background: var(--color-muted, #f6f8f9);
  color: var(--color-primary, #17806d);
  border: 1.5px solid var(--color-border, #e0e6eb);
}
.notfound-btn--ghost:hover {
  background: #e0e6eb;
}
.notfound-quicklinks {
  display: flex;
  gap: var(--space-2, 0.5rem);
  margin-top: var(--space-2, 0.5rem);
}
.notfound-quicklinks a {
  display: inline-block;
  padding: 0.5em 1em;
  border-radius: var(--radius, 0.5rem);
  background: var(--color-card, #fff);
  border: 1px solid var(--color-border, #e0e6eb);
  color: var(--color-text-dark, #1a232b);
  font-size: var(--font-size-sm, 0.95rem);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.notfound-quicklinks a:hover {
  background: var(--color-primary, #17806d);
  color: #fff;
}
.notfound-right {
  flex: 1 1 340px;
  min-width: 320px;
  max-width: 420px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.notfound-game {
  width: 100%;
  background: var(--color-card, #fff);
  border: 1.5px solid var(--color-border, #e0e6eb);
  border-radius: var(--radius-2xl, 1.5rem);
  box-shadow: var(--card-shadow, 0 2px 8px 0 rgba(0,0,0,0.04));
  padding: var(--space-8, 2rem);
  display: flex;
  flex-direction: column;
  gap: var(--space-6, 1.5rem);
}
.notfound-game-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4, 1rem);
}
.notfound-game-label {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-primary, #17806d);
}
.notfound-game-desc {
  color: var(--color-text-muted, #5b6c7a);
  font-size: 0.95rem;
  margin-top: 0.25em;
}
.notfound-scoreboard {
  display: flex;
  gap: var(--space-4, 1rem);
  align-items: center;
}
.notfound-score-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  color: var(--color-text-muted, #5b6c7a);
  letter-spacing: 0.05em;
}
.notfound-score-val {
  font-family: var(--font-heading, inherit);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-text-dark, #1a232b);
  line-height: 1;
}
.notfound-score-val--primary {
  color: var(--color-primary, #17806d);
}
.notfound-board {
  position: relative;
  margin-top: var(--space-4, 1rem);
  height: 320px;
  background: repeating-radial-gradient(circle at 1px 1px, #e0e6eb 1px, transparent 0 22px);
  border-radius: var(--radius-xl, 1rem);
  border: 1.5px solid var(--color-border, #e0e6eb);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.notfound-game-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4, 1rem);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(2px);
  z-index: 2;
}
.notfound-disclaimer {
  color: var(--color-text-muted, #5b6c7a);
  font-size: var(--font-size-xs, 0.8rem);
  margin-top: var(--space-2, 0.5rem);
  text-align: center;
}
@media (max-width: 900px) {
  .notfound-grid {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-8, 2rem);
  }
  .notfound-game, .notfound-left, .notfound-right {
    max-width: 100%;
  }
}

/* --------------------------------------------------------------------------
   21. WOOCOMMERCE — GENERAL AREA
   -------------------------------------------------------------------------- */
.woocommerce-area { width: 100%; }

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.woocommerce .woocommerce-breadcrumb a { color: var(--color-primary); }

/* Product single */
.woocommerce div.product .woocommerce-product-gallery { margin-bottom: var(--space-6); }

.woocommerce div.product div.summary { padding: 0; }

.woocommerce div.product .product_title {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-4);
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: var(--font-size-2xl) !important;
  color: var(--color-primary) !important;
  font-weight: var(--font-weight-bold) !important;
  margin-bottom: var(--space-4);
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}

/* Add to cart button */
.woocommerce div.product form.cart .single_add_to_cart_button {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: var(--space-4) var(--space-8) !important;
  font-size: var(--font-size-base) !important;
  font-weight: var(--font-weight-semi) !important;
  transition: background var(--transition) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: var(--color-primary-dark) !important;
}

/* Cart & checkout */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border-radius: var(--radius) !important;
  font-weight: var(--font-weight-semi) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  border: none !important;
  padding: var(--space-3) var(--space-5) !important;
  transition: background var(--transition) !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background: var(--color-primary) !important;
}

/* ── Notices — redesign completo ─────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
ul.woocommerce-error,
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error {
  border: none !important;
  border-radius: 10px !important;
  padding: 14px 18px 14px 52px !important;
  margin: 0 0 16px !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  position: relative !important;
  list-style: none !important;
}

/* Success / Message */
.woocommerce-message {
  background: #f0fdf4 !important;
  color: #166534 !important;
  box-shadow: 0 0 0 1px #bbf7d0 !important;
}
.woocommerce-message::before {
  content: '' !important;
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  background-color: #16a34a !important;
  border-radius: 50% !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") !important;
  background-size: 12px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  font-size: 0 !important;
  color: transparent !important;
}

/* Info */
.woocommerce-info {
  background: #f0f9ff !important;
  color: #0c4a6e !important;
  box-shadow: 0 0 0 1px #bae6fd !important;
}
.woocommerce-info::before {
  content: '' !important;
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  background-color: #0ea5e9 !important;
  border-radius: 50% !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='12'/%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'/%3E%3C/svg%3E") !important;
  background-size: 13px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  font-size: 0 !important;
  color: transparent !important;
}

/* Error */
.woocommerce-error,
ul.woocommerce-error {
  background: #fef2f2 !important;
  color: #991b1b !important;
  box-shadow: 0 0 0 1px #fecaca !important;
}
.woocommerce-error::before,
ul.woocommerce-error::before {
  content: '' !important;
  position: absolute !important;
  left: 16px !important;
  top: 18px !important;
  width: 20px !important;
  height: 20px !important;
  background-color: #ef4444 !important;
  border-radius: 50% !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") !important;
  background-size: 11px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  font-size: 0 !important;
  color: transparent !important;
}
ul.woocommerce-error li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
ul.woocommerce-error li + li {
  margin-top: 4px !important;
  padding-top: 4px !important;
  border-top: 1px solid #fecaca !important;
}

/* Buttons inside notices */
.woocommerce-message .button,
.woocommerce-info .button {
  float: right !important;
  margin: -2px 0 0 12px !important;
  padding: 6px 16px !important;
  font-size: 13px !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  background: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  cursor: pointer !important;
  text-decoration: none !important;
  line-height: 1.5 !important;
}
.woocommerce-message .button:hover,
.woocommerce-info .button:hover {
  opacity: .88 !important;
}

/* Notices wrapper spacing */
.woocommerce-notices-wrapper {
  margin-bottom: 20px !important;
}
.woocommerce-notices-wrapper:empty {
  display: none !important;
}

/* --------------------------------------------------------------------------
   21b. SHOP / CATEGORY PAGE LAYOUT
   -------------------------------------------------------------------------- */

/* ── Category Banner ─────────────────────────────────────────── */
.category-banner {
  position: relative;
  width: 100%;
  height: 220px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-start;
  padding-top: var(--space-6);
  overflow: hidden;
}
.category-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.6) 0%, rgba(0,0,0,.35) 40%, rgba(0,0,0,.1) 70%, transparent 100%);
  z-index: 1;
}
.category-banner--no-image {
  height: auto;
  min-height: 120px;
  background: var(--color-dark);
}
.category-banner--no-image::before {
  display: none;
}
.category-banner__overlay {
  position: relative;
  z-index: 2;
  width: 100%;
  display: block;
}
.category-banner__title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  margin-bottom: var(--space-2);
  line-height: 1.2;
}
.category-banner__subtitle {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semi);
  color: var(--color-white);
  margin-bottom: var(--space-2);
  line-height: 1.3;
}
.category-banner__desc {
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,.85);
  max-width: 500px;
  line-height: 1.5;
}

/* Breadcrumb */
.category-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  font-size: var(--font-size-xs);
  margin-bottom: var(--space-3);
}
.category-breadcrumb a {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: color var(--transition);
}
.category-breadcrumb a:hover {
  color: var(--color-white);
}
.category-breadcrumb__sep {
  color: rgba(255,255,255,.4);
}
.category-breadcrumb__current {
  color: var(--color-white);
  font-weight: var(--font-weight-medium);
}

/* Back link */
.category-back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
  color: rgba(255,255,255,.85);
  text-decoration: none;
  transition: color var(--transition);
}
.category-back-link:hover {
  color: var(--color-white);
}

/* ── Shop Top Bar ────────────────────────────────────────────── */
.shop-page {
  max-width: 1520px;
  margin-inline: auto;
  padding: var(--space-6) var(--container-px) var(--space-12) var(--space-2);
}

.shop-topbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  margin-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.shop-topbar__left,
.shop-topbar__center,
.shop-topbar__right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.shop-topbar__right {
  margin-left: auto;
}

.shop-topbar__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  white-space: nowrap;
}

.shop-topbar__select,
.shop-topbar .woocommerce-ordering select {
  padding: 6px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  background: var(--color-white);
  color: var(--color-text);
  cursor: pointer;
}

/* Remove WC ordering default margin */
.shop-topbar .woocommerce-ordering {
  margin: 0;
}

/* SKU search */
.shop-sku-search {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--color-white);
}
.shop-sku-search__input {
  border: none;
  padding: 6px 10px;
  font-size: var(--font-size-sm);
  width: 140px;
  outline: none;
  background: transparent;
}
.shop-sku-search__input::placeholder {
  color: var(--color-text-muted);
}
.shop-sku-search__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 8px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  cursor: pointer;
  transition: background var(--transition);
}
.shop-sku-search__btn:hover {
  background: var(--color-primary-dark);
}

/* Stock filter checkbox */
.shop-stock-filter,
.sidebar-checkbox {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  cursor: pointer;
  white-space: nowrap;
}
.shop-stock-filter input,
.sidebar-checkbox input {
  accent-color: var(--color-primary);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* ── Shop 2-column Layout ────────────────────────────────────── */
.shop-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

/* ── Sidebar ─────────────────────────────────────────────────── */
.shop-sidebar {
  display: none; /* hidden on mobile by default, shown via JS overlay */
}

.shop-sidebar.is-open {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  background: var(--color-white);
  overflow-y: auto;
  padding: var(--space-6);
  -webkit-overflow-scrolling: touch;
}

.shop-sidebar__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-white);
  cursor: pointer;
  margin-bottom: var(--space-4);
  margin-left: auto;
}

/* Sidebar widgets */
.sidebar-widget {
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}
.sidebar-widget:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.sidebar-widget__title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--color-dark);
  margin-bottom: var(--space-3);
}

/* Category list */
.sidebar-cat-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sidebar-cat-list li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 8px;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  border-radius: var(--radius-sm);
  transition: background var(--transition), color var(--transition);
}
.sidebar-cat-list li a:hover {
  background: var(--color-section-alt);
  color: var(--color-primary);
}
.sidebar-cat-list li.is-active a {
  background: rgba(var(--color-primary-rgb, 22,101,52), .08);
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
}
.sidebar-cat-count {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

/* Price filter */
.sidebar-price-filter__inputs {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.sidebar-price-filter__input {
  width: 80px;
  padding: 6px 8px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
}
.sidebar-price-filter__input:focus {
  border-color: var(--color-primary);
  outline: none;
}
.sidebar-price-filter__sep {
  color: var(--color-text-muted);
}
.sidebar-price-filter__currency {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-weight: var(--font-weight-medium);
}
.sidebar-price-filter__btn {
  display: inline-block;
  padding: 6px 16px;
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background var(--transition);
}
.sidebar-price-filter__btn:hover {
  background: var(--color-primary-dark);
}

/* ── Shop Content (product grid area) ────────────────────────── */
.shop-content {
  min-width: 0;
  width: 100%;
}

/* Mobile filter toggle button */
.shop-filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  cursor: pointer;
  margin-bottom: var(--space-4);
  transition: border-color var(--transition);
}
.shop-filter-toggle:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* Override product grid on shop pages: 2 cols mobile */
.shop-content ul.products {
  grid-template-columns: repeat(2, 1fr) !important;
}

/* WC pagination */
.woocommerce nav.woocommerce-pagination {
  margin-top: var(--space-8);
  text-align: center;
}
.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  gap: 4px;
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li {
  border: none;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  background: var(--color-white);
  transition: all var(--transition);
}
.woocommerce nav.woocommerce-pagination ul li a:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

/* --------------------------------------------------------------------------
   22. NO-RESULTS / SEARCH
   -------------------------------------------------------------------------- */
.no-results { padding: var(--space-16) 0; text-align: center; }
.no-results h1 { margin-bottom: var(--space-4); }
.no-results p { color: var(--color-text-muted); margin-bottom: var(--space-6); }

/* --------------------------------------------------------------------------
   23. RESPONSIVE — TABLET (768px+)
   -------------------------------------------------------------------------- */
@media (min-width: 768px) {
  :root {
    --container-px: 1.5rem;
    /* --header-h already 72px from base */
  }

  h1 { font-size: var(--font-size-4xl); }
  h2 { font-size: var(--font-size-3xl); }

  /* Categories — DEPRECATED: .categories-grid replaced with .categories-carousel
  .categories-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  */

  /* Trust section: 2 columns at tablet */
  .trust-grid { grid-template-columns: repeat(2, 1fr); }

  /* Products grid: 3 columns at tablet */
  .woocommerce ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: var(--space-4) !important;
  }

  /* Quick order */
  .quick-order-inner { flex-direction: row; align-items: center; gap: var(--space-10); }
  .quick-order__text { flex-shrink: 0; max-width: 280px; }
  .quick-order-form { flex: 1; }

  /* Movimentazione */
  .movimentazione-grid { grid-template-columns: repeat(2, 1fr); }

  /* Trust section: stay 2 cols at 768 breakpoint (desktop handles 4) */

  /* About */
  .about-inner { flex-direction: row; align-items: flex-start; }
  .about-text { flex: 1; }
  .about-stats { flex-shrink: 0; width: 260px; grid-template-columns: repeat(2, 1fr); }

  /* Posts */
  .posts-grid { grid-template-columns: repeat(2, 1fr); }

  /* Shop page: 3 columns on tablet */
  .shop-content ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .category-banner { height: 220px; }

  /* Footer */
  .footer-inner { grid-template-columns: 200px 1fr; align-items: start; gap: var(--space-8); }
  .footer-cols { grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
}

/* --------------------------------------------------------------------------
   24. RESPONSIVE — DESKTOP (1024px+)
   -------------------------------------------------------------------------- */
@media (min-width: 1024px) {
  :root {
    --container-px: 1.5rem;
    /* --header-h already 72px from base */
  }

  /* Desktop header: strict single-row layout — nothing overlaps */

  /* Shop: 2-column layout with sidebar */
  .shop-layout {
    grid-template-columns: 260px 1fr;
    gap: var(--space-6);
  }

  .shop-sidebar {
    display: block;
    position: sticky;
    top: calc(var(--header-h) + var(--space-4));
    max-height: calc(100vh - var(--header-h) - var(--space-8));
    overflow-y: auto;
    scrollbar-width: thin;
  }
  .shop-sidebar__close { display: none; }

  .shop-filter-toggle { display: none; }

  /* 4-column product grid on desktop (shop page and front-page .woocommerce wrapper) */
  .woocommerce ul.products {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: var(--space-4) !important;
  }

  .shop-sku-search__input { width: 160px; }

  .category-banner { height: 220px; }
  .header-inner { flex-wrap: nowrap; }
  .site-logo { margin-right: 0; }
  .cat-mega { display: flex; align-items: center; }
  .nav-links {
    flex: 1 1 auto;
    overflow: visible;
  }

  .header-actions {
    min-width: 0;
    margin-left: auto;
    padding-left: var(--space-4);
  }

  .header-search-pill { width: min(100%, 11rem); }

  /* Nav menu layout */

  /* Categories — DEPRECATED: .categories-grid replaced with .categories-carousel */
  /* .categories-grid { grid-template-columns: repeat(6, 1fr); } */

  /* Trust section: 4 columns on desktop */
  .trust-grid { grid-template-columns: repeat(4, 1fr); }

  /* Movimentazione */
  .movimentazione-grid { grid-template-columns: repeat(3, 1fr); }

  /* Posts */
  .posts-grid { grid-template-columns: repeat(3, 1fr); }
}

/* --------------------------------------------------------------------------
   25. NAV MENU (desktop — visible at 1024px+)
   -------------------------------------------------------------------------- */
@media (min-width: 1024px) {
  .nav-menu {
    display: flex;
    align-items: center;
    gap: 2px;
    list-style: none;
    flex-wrap: nowrap;
  }
  .nav-menu > li { position: relative; }
  .nav-menu > li > a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    font-size: var(--font-size-xs); /* compact so items fit in the nav strip */
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    border-radius: var(--radius-sm);
    text-decoration: none;
    white-space: nowrap;
    transition: color var(--transition), background var(--transition);
  }
  
  .nav-menu > li > a svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
  }
  .nav-menu > li > a:hover,
  .nav-menu > li.current-menu-item > a,
  .nav-menu > li.current-menu-parent > a {
    color: var(--color-primary);
    background: var(--color-primary-light);
  }

  /* Desktop sub-menu dropdown */
  .nav-menu .sub-menu {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 200px;
    background: var(--color-white);
    border: var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    padding: var(--space-2) 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity var(--transition-md), transform var(--transition-md);
    z-index: 200;
    list-style: none;
  }
  .nav-menu li:hover > .sub-menu,
  .nav-menu li:focus-within > .sub-menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  .nav-menu .sub-menu a {
    display: block;
    padding: var(--space-2) var(--space-4);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition), background var(--transition);
  }
  .nav-menu .sub-menu a:hover { color: var(--color-primary); background: var(--color-bg); }

  /* Inline SVG icons in menu items */
  .nav-item-with-icon {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: 100%;
  }
  .nav-item-with-icon svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    display: inline-block;
  }
}

/* --------------------------------------------------------------------------
   26. CATEGORIE MEGA MENU (sidebar 2 colonne: categorie sx / sottocategorie dx)
   -------------------------------------------------------------------------- */

/* ── Trigger button "Tutti i prodotti" ── */
.cat-trigger {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 14px;
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  white-space: nowrap;
  user-select: none;
  transition: background var(--transition), box-shadow var(--transition);
}
.cat-trigger:hover,
.cat-trigger.is-active {
  background: var(--color-primary-dark);
  box-shadow: 0 2px 8px rgba(30,127,107,.25);
}
.cat-trigger__chevron {
  flex-shrink: 0;
  transition: transform var(--transition-md);
}
.cat-trigger.is-active .cat-trigger__chevron {
  transform: rotate(180deg);
}

/* ── Pannello principale (slide da sinistra) ── */
.cat-panel {
  position: fixed;
  top: 0;
  left: 0;
  width: 680px;           /* 280px col.sx + 400px col.dx */
  max-width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  box-shadow: 6px 0 24px rgba(0, 0, 0, 0.18);
  transform: translateX(-100%);
  transition: transform 320ms cubic-bezier(.4,0,.2,1);
  z-index: 9999;
  pointer-events: none;
}
.cat-mega.is-open .cat-panel {
  transform: translateX(0);
  pointer-events: auto;
}

/* ── Inner: flex row → 2 colonne ── */
.cat-panel__inner {
  display: flex;
  flex: 1;
  overflow: hidden;
}

/* ── Colonna sinistra: categorie ── */
.cat-panel__left {
  width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--color-border);
  background: var(--color-white);
}

/* Topbar con logo + × */
.cat-panel__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}
.cat-panel__logo {
  height: 28px;
  width: auto;
  display: block;
}
.cat-panel__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--color-text-muted);
  border-radius: 50%;
  transition: color var(--transition), background var(--transition);
  flex-shrink: 0;
}
.cat-panel__close:hover {
  color: var(--color-primary);
  background: var(--color-bg);
}

/* Lista categorie */
.cat-list {
  list-style: none;
  padding: 8px 0;
  margin: 0;
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}
.cat-list::-webkit-scrollbar { width: 4px; }
.cat-list::-webkit-scrollbar-track { background: transparent; }
.cat-list::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

.cat-item-parent { list-style: none; }

.cat-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 16px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  cursor: pointer;
}
.cat-item:hover,
.cat-item-parent.is-active > .cat-item {
  background: var(--color-primary-light, #f0faf5);
  color: var(--color-primary);
  border-left-color: var(--color-primary);
}
.cat-item__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  display: block;
}
.cat-item__icon--placeholder {
  display: inline-block;
  background: var(--color-bg);
}
.cat-item__label {
  flex: 1;
  line-height: 1.3;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.cat-item__arrow {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: color var(--transition), transform var(--transition);
}
.cat-item:hover .cat-item__arrow,
.cat-item-parent.is-active > .cat-item .cat-item__arrow {
  color: var(--color-primary);
  transform: translateX(2px);
}

/* ── Colonna destra: sottocategorie ── */
.cat-panel__right {
  flex: 1;
  background: #f8f9fb;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--color-border) transparent;
}
.cat-panel__right::-webkit-scrollbar { width: 4px; }
.cat-panel__right::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

/* Sub-panel: uno per categoria, nascosto/visibile via JS */
.cat-subpanel { padding: 20px; }
.cat-subpanel[hidden] { display: none; }

.cat-subpanel__title {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border);
}

/* Lista sottocategorie */
.cat-sublist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cat-sublist li { list-style: none; }

.cat-subitem {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  font-size: var(--font-size-sm);
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
  cursor: pointer;
}
.cat-subitem:hover {
  background: var(--color-white);
  color: var(--color-primary);
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.cat-subitem__icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  display: block;
}
.cat-subitem__icon--placeholder {
  display: inline-block;
  background: var(--color-bg);
}
.cat-subitem__label {
  flex: 1;
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
}
.cat-subitem__arrow {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: color var(--transition), transform var(--transition);
}
.cat-subitem:hover .cat-subitem__arrow {
  color: var(--color-primary);
  transform: translateX(2px);
}

/* ── Backdrop ── */
.cat-panel__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  transition: opacity 320ms ease;
  z-index: 9998;
  pointer-events: none;
}
.cat-mega.is-open .cat-panel__backdrop {
  opacity: 1;
  pointer-events: auto;
}

/* ── Mobile (≤768px): pannello full-width, colonna dx nascosta ── */
@media (max-width: 768px) {
  .cat-panel { width: 100%; }
  .cat-panel__right { display: none; }
  .cat-panel__right.is-visible { display: block; }
  .cat-panel__left { width: 100%; border-right: none; }
}

@media (max-width: 1023px) {
  .header-inner {
    gap: var(--space-3);
    min-height: var(--header-h);
  }

  .site-logo img,
  .site-logo .logo-img,
  .site-logo .custom-logo-link img {
    max-height: 32px;
  }

  .cat-mega,
  .nav-links {
    display: none !important;
  }

  .header-actions {
    margin-left: auto;
    gap: var(--space-2);
  }

  .header-account-link {
    display: none;
  }

  .hamburger {
    display: flex;
  }
}

/* Lovable navbar dropdown override */
.cat-panel {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 0;
  width: min(35rem, calc(100vw - (var(--layout-shell-px) * 2)));
  height: auto;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: calc(var(--radius-lg) + var(--space-1));
  background: var(--color-surface);
  box-shadow: var(--shadow-lg);
  transform: translateY(calc(var(--space-2) * -1));
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  z-index: 120;
}

.cat-mega.is-open .cat-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.cat-panel__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-1);
}

.cat-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  color: var(--color-dark);
  transition: background var(--transition), color var(--transition);
}

.cat-card:hover {
  background: var(--color-bg-alt);
  color: var(--color-dark);
}

.cat-card__media {
  width: calc(var(--space-12) + var(--space-2));
  height: calc(var(--space-12) + var(--space-2));
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--color-bg-alt);
  flex-shrink: 0;
}

.cat-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cat-card__media--placeholder::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color-bg);
}

.cat-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.cat-card__title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  line-height: 1.2;
}

.cat-card__meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.cat-panel__catalog-link {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  background: var(--color-dark);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}

.cat-panel__catalog-link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.cat-panel {
  width: min(46rem, calc(100vw - (var(--layout-shell-px) * 2)));
  padding: 0;
  overflow: hidden;
}

.cat-panel__inner {
  display: grid;
  grid-template-columns: 14.75rem minmax(0, 1fr);
  align-items: start;
}

.cat-panel__left {
  width: auto;
  border-right: 1px solid var(--color-border);
  background: #f8f9fb;
}

.cat-list {
  padding: .55rem 0;
}

.cat-item {
  gap: .75rem;
  padding: .78rem 1rem;
  border-left: none;
  background: transparent;
}

.cat-item:hover,
.cat-item-parent.is-active > .cat-item {
  background: #fff;
  color: var(--color-dark);
  border-left-color: transparent;
}

.cat-item__icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: .55rem;
  border: 1px solid #eceff3;
  background: #fff;
  overflow: hidden;
}

.cat-item__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cat-item__label {
  font-size: .98rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}

.cat-item__arrow svg,
.cat-subitem__arrow svg {
  width: .95rem;
  height: .95rem;
  display: block;
}

.cat-panel__right {
  background: #fff;
  padding: 1.1rem 1.2rem 1.2rem;
}

.cat-subpanel {
  padding: 0;
}

.cat-subpanel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.cat-subpanel__title {
  margin: 0;
  padding: 0;
  border: none;
  color: var(--color-primary);
  font-size: .9rem;
  letter-spacing: .22em;
}

.cat-subpanel__view-all {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--color-text-muted);
  font-size: .9rem;
  text-decoration: none;
}

.cat-subpanel__view-all:hover {
  color: var(--color-dark);
}

.cat-subpanel__view-all svg {
  width: .9rem;
  height: .9rem;
}

.cat-sublist {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .45rem .7rem;
  align-content: start;
}

.cat-subitem {
  gap: .8rem;
  min-width: 0;
  padding: .65rem .7rem;
  border-radius: .8rem;
}

.cat-subitem__icon {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: .7rem;
  overflow: hidden;
}

.cat-subitem__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cat-subitem__content {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .18rem;
}

.cat-subitem__label {
  font-size: .95rem;
  line-height: 1.2;
}

.cat-subitem__meta {
  color: var(--color-text-muted);
  font-size: .8rem;
  line-height: 1.2;
}

.cat-subpanel__empty {
  padding: .5rem 0 1rem;
  color: var(--color-text-muted);
  font-size: .9rem;
}

.cat-panel__catalog-link {
  margin-top: 1rem;
  padding: .95rem 1.15rem;
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: var(--color-white);
  box-shadow: 0 10px 24px rgba(30, 127, 107, 0.22);
}

.cat-panel__catalog-link::before {
  content: "";
  width: 1rem;
  height: 1rem;
  display: inline-block;
  flex: 0 0 1rem;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='black' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M20 7 12 3 4 7m16 0-8 4m8-4v10l-8 4m0-10L4 7m8 4v10M4 7v10l8 4'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='black' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M20 7 12 3 4 7m16 0-8 4m8-4v10l-8 4m0-10L4 7m8 4v10M4 7v10l8 4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.cat-panel__catalog-link:hover {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, #114b40 100%);
  color: var(--color-white);
  transform: translateY(-1px);
}

.cat-panel__catalog-link span {
  flex: 1;
}

@media (max-width: 767px) {
  .cat-mega { display: none; }
  .cat-panel { display: none; }
}

/* --------------------------------------------------------------------------
   27. EMPTY PRODUCT CARDS — hide products with no image
   -------------------------------------------------------------------------- */
/* :has() is supported in all modern browsers (Chrome 105+, Firefox 121+, Safari 15.4+) */
.woocommerce ul.products li.product:has(img[src=""]),
.woocommerce ul.products li.product:has(img[src*="woocommerce-placeholder"]):not(:has(.attachment-woocommerce_thumbnail)) {
  display: none;
}

/* --------------------------------------------------------------------------
   28. PRINT
   -------------------------------------------------------------------------- */
@media print {
  .site-header, .site-footer, .hero__ctas, .quick-order-section, .contact-section { display: none; }
  body { font-size: 12pt; color: #000; }
  a { color: #000; }
}

/* --------------------------------------------------------------------------
   29. SINGLE PRODUCT PAGE
   -------------------------------------------------------------------------- */

/* Page wrapper */
.lc-single-product-page {
  padding: var(--space-8) var(--container-px) var(--space-16);
}

/* ── 2-column grid ─────────────────────────────────────────────────── */
.lc-product-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: start;
  margin-bottom: var(--space-12);
}

@media (min-width: 768px) {
  .lc-product-cols {
    grid-template-columns: 45fr 55fr;
    gap: var(--space-10);
  }
}

/* Gallery column — sticky on desktop so it stays visible while scrolling */
@media (min-width: 768px) {
  .lc-gallery-col {
    position: sticky;
    top: calc(var(--header-h) + var(--space-4));
  }
}

/* Info column spacing */
.lc-info-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ── Product summary (WC output) ───────────────────────────────────── */
.lc-info-col .summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.lc-product-custom-cats {
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--color-primary, #1E7F6B);
  letter-spacing: .05em;
  margin-bottom: -10px; /* pull title closer */
}
.lc-product-custom-cats a {
  color: var(--color-primary, #1E7F6B);
  text-decoration: none;
  transition: color var(--transition, .15s ease);
}
.lc-product-custom-cats a:hover {
  color: var(--color-primary-dark, #155a4d);
}

.lc-product-custom-title {
  font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-4xl));
  font-weight: 800;
  line-height: 1.15;
  color: var(--color-dark, #111827);
  margin-bottom: 0;
}

.lc-product-custom-meta-row {
  display: flex;
  align-items: center;
  gap: var(--space-3, 12px);
  margin-bottom: var(--space-2);
}
.lc-product-custom-meta-row .woocommerce-product-rating {
  margin-bottom: 0;
  display: flex;
  align-items: center;
}
.lc-product-custom-meta-row .woocommerce-review-link {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-text-muted, #6b7280);
  margin-left: 6px;
  text-decoration: none;
}

.lc-product-custom-sku {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-primary, #1E7F6B);
}
.lc-product-custom-sku .sku {
  font-weight: 400;
}
/* Separator between rating and sku */
.lc-product-custom-meta-row .woocommerce-product-rating::after {
  content: '·';
  color: var(--color-border, #e2e8e6);
  margin-left: var(--space-3, 12px);
  font-weight: bold;
}

.lc-product-custom-price-box {
  background: var(--color-bg, #f9fafb);
  border: 1px solid var(--color-border, #e2e8e6);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-4, 16px) var(--space-5, 20px);
  margin: var(--space-2, 8px) 0;
}
.lc-product-custom-price-box .price {
  margin: 0;
  font-size: var(--font-size-3xl, 1.875rem) !important;
  color: var(--color-dark, #111827) !important;
  font-weight: 800 !important;
  line-height: 1.2;
}
.lc-product-custom-price-box .price del {
  font-size: var(--font-size-base, 1rem) !important;
  color: var(--color-text-muted, #6b7280) !important;
  font-weight: 400 !important;
  margin-right: 8px;
}
.lc-product-custom-price-box .price ins {
  text-decoration: none;
}
/* Small VAT suffix native to WooCommerce, styled like the photo */
.lc-product-custom-price-box .price .woocommerce-price-suffix {
  font-size: var(--font-size-sm, 0.875rem) !important;
  color: var(--color-text-muted, #6b7280) !important;
  font-weight: 400 !important;
  margin-left: 8px;
}

/* Hide the meta that might sneak in if other plugins hook it, though we unhooked it */
.lc-info-col .summary .product_meta {
  display: none;
}

/* Add to cart area */
.lc-info-col .summary .cart {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  flex-wrap: wrap;
}

.lc-info-col .summary .qty {
  width: 80px;
  height: 46px;
  padding: 0 var(--space-3);
  border: var(--border);
  border-radius: var(--radius);
  font-size: var(--font-size-base);
  text-align: center;
}

.lc-info-col .summary .single_add_to_cart_button {
  flex: 1;
  min-width: 160px;
  height: 46px;
  padding: 0 var(--space-6) !important;
  font-size: var(--font-size-base) !important;
  font-weight: var(--font-weight-semi) !important;
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  cursor: pointer !important;
  transition: background var(--transition) !important;
}
.lc-info-col .summary .single_add_to_cart_button:hover {
  background: var(--color-primary-dark) !important;
}

/* Variations form */
.lc-info-col .variations td,
.lc-info-col .variations th {
  padding: var(--space-2) 0;
  vertical-align: middle;
}
.lc-info-col .variations label {
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
  color: var(--color-dark);
  white-space: nowrap;
  padding-right: var(--space-4);
}
.lc-info-col .variations select {
  padding: var(--space-2) var(--space-3);
  border: var(--border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  min-width: 180px;
  background: var(--color-white);
}

/* ── Trust bar ─────────────────────────────────────────────────────── */
.product-trust-bar {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  border: var(--border);
}

@media (min-width: 480px) {
  .product-trust-bar { flex-direction: row; flex-wrap: wrap; gap: var(--space-4); }
}

.product-trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
  flex: 1 1 auto;
}
.product-trust-item svg { color: var(--color-primary); flex-shrink: 0; }

/* ── Shared side-block title ───────────────────────────────────────── */
.product-side-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: var(--border);
}
.product-side-title svg { color: var(--color-primary); flex-shrink: 0; }

/* ── Shipping block ────────────────────────────────────────────────── */
.product-shipping-block {
  padding: var(--space-4);
  border: var(--border);
  border-radius: var(--radius-lg);
}
.product-shipping-block__img {
  max-width: 100%;
  height: auto;
  display: block;
  margin-bottom: var(--space-3);
}
.product-shipping-block__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.product-shipping-block__list li {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  padding-left: var(--space-4);
  position: relative;
}
.product-shipping-block__list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
}

/* ── Payment block ─────────────────────────────────────────────────── */
.product-payment-block {
  padding: var(--space-4);
  border: var(--border);
  border-radius: var(--radius-lg);
}
.product-payment-block__img {
  max-width: 100%;
  height: auto;
  display: block;
}
.payment-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.payment-badge {
  display: inline-block;
  padding: 2px var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  border: var(--border);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  background: var(--color-white);
}

/* ── Contact block ─────────────────────────────────────────────────── */
.product-contact-block {
  padding: var(--space-4);
  border: var(--border);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
}
.product-contact-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.product-contact-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  text-decoration: none;
  transition: color var(--transition);
}
.product-contact-link:hover { color: var(--color-primary); }
.product-contact-link--wa {
  color: #25D366;
  font-weight: var(--font-weight-semi);
}
.product-contact-link--wa:hover { color: #128C7E; }

/* ── Variant table section ─────────────────────────────────────────── */
.variant-table-section {
  margin-bottom: var(--space-12);
  width: 100%;
}
.variant-table-section__title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary);
  display: inline-block;
}
.variant-table-wrap {
  overflow-x: auto;
  border: var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

/* Table base */
.variant-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
  min-width: 640px;
}
.variant-table thead {
  background: var(--color-bg);
  border-bottom: 2px solid var(--color-border);
}
.variant-table th {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  text-align: left;
  white-space: nowrap;
}
.variant-table tbody tr { height: 56px; }
.variant-table td {
  padding: 0 var(--space-4);
  border-bottom: var(--border);
  vertical-align: middle;
}
.variant-row:last-child td { border-bottom: none; }
.variant-row:hover td { background: var(--color-bg); }
.variant-row--oos td { opacity: .55; }

/* Cell specifics */
.vt-sku code {
  font-family: monospace;
  font-size: var(--font-size-xs);
  background: var(--color-bg);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--color-text-muted);
}
.vt-format { max-width: 240px; }
.vt-price, .vt-total { white-space: nowrap; font-weight: var(--font-weight-semi); }
.line-total { color: var(--color-primary); }
.vt-na { color: var(--color-text-muted); }

/* Availability cell — flex on inner wrapper, not on td */
.vt-stock { white-space: nowrap; }
.vt-stock-inner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.stock-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.stock-dot--in  { background: #22c55e; }
.stock-dot--out { background: #ef4444; }

/* Qty +/- control inside table */
.qty-ctrl {
  display: flex;
  align-items: center;
  gap: 0;
  border: var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  width: fit-content;
}
.qty-btn {
  width: 28px;
  height: 32px;
  border: none;
  background: var(--color-bg);
  cursor: pointer;
  font-size: var(--font-size-base);
  color: var(--color-text);
  transition: background var(--transition);
  flex-shrink: 0;
  line-height: 1;
}
.qty-btn:hover { background: var(--color-primary-light); color: var(--color-primary); }
.qty-input {
  width: 44px;
  height: 32px;
  border: none;
  border-left: var(--border);
  border-right: var(--border);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-dark);
  background: var(--color-white);
  appearance: textfield;
  -moz-appearance: textfield;
}
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button { -webkit-appearance: none; appearance: none; }

/* Table ATC button */
.vt-atc-btn {
  white-space: nowrap;
  padding: var(--space-2) var(--space-4) !important;
  font-size: var(--font-size-xs) !important;
}
.vt-atc-btn.is-loading { opacity: .6; pointer-events: none; }
.vt-atc-btn.is-added {
  background: #22c55e !important;
}

/* Out-of-stock badge */
.badge-oos {
  display: inline-block;
  padding: 2px var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: #ef4444;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

/* WC gallery overrides on single product */
.lc-gallery-col .woocommerce-product-gallery {
  margin: 0 !important;
}
.lc-gallery-col .woocommerce-product-gallery__image img {
  border-radius: var(--radius-lg);
}

/* WC tabs on single product */
.lc-product-wrap .woocommerce-tabs {
  margin-top: var(--space-8);
  width: 100%;
}

/* Related / upsell grids */
.lc-product-wrap .related,
.lc-product-wrap .upsells {
  padding: var(--space-10) 0 0;
  width: 100%;
}
.lc-product-wrap .related h2,
.lc-product-wrap .upsells h2 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semi);
  margin-bottom: var(--space-5);
}

/* --------------------------------------------------------------------------
   30. PRODUCT PAGE — new components (hero banner, delivery, var cards, IVA)
   -------------------------------------------------------------------------- */

/* ── Hero banner ────────────────────────────────────────────────────── */
.product-hero-banner {
  position: relative;
  width: 100%;
  height: 180px;
  background-size: cover;
  background-position: center;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-8);
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .product-hero-banner { height: 240px; }
}
.product-hero-banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.68) 0%, rgba(0,0,0,.35) 55%, transparent 100%);
}
.product-hero-banner__content {
  position: relative;
  z-index: 1;
  padding: var(--space-6) var(--space-8);
  color: var(--color-white);
  max-width: 65%;
}
.product-hero-banner__category {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: var(--font-weight-semi);
  opacity: .75;
  margin-bottom: var(--space-1);
}
.product-hero-banner__title {
  font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-3xl));
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  margin-bottom: var(--space-2);
  text-shadow: 0 1px 4px rgba(0,0,0,.35);
}
.product-hero-banner__subtitle {
  font-size: var(--font-size-sm);
  opacity: .85;
  line-height: 1.5;
  margin-bottom: var(--space-3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.product-hero-banner__badge {
  display: inline-block;
  padding: 3px var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.product-hero-banner__cta {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-5);
  border: 2px solid rgba(255,255,255,.65);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-white);
  text-decoration: none;
  background: transparent;
  transition: background var(--transition), border-color var(--transition);
}
.product-hero-banner__cta:hover {
  background: rgba(255,255,255,.18);
  border-color: var(--color-white);
  color: var(--color-white);
}

/* ── Delivery estimate ──────────────────────────────────────────────── */
.product-delivery-estimate {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  color: #166534;
  line-height: 1.4;
}
.product-delivery-estimate svg { flex-shrink: 0; }
.product-delivery-estimate strong { font-weight: var(--font-weight-semi); }

/* ── Price IVA suffix ───────────────────────────────────────────────── */
.price-iva-suffix {
  font-size: .72em;
  font-weight: var(--font-weight-normal);
  color: var(--color-text-muted);
  margin-left: .2em;
  white-space: nowrap;
}

/* ── Variation custom dropdown ──────────────────────────────────────── */
.lc-var-dropdown {
  position: relative;
  display: block;
}

/* Trigger (looks like a styled select) */
.lc-var-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  width: 100%;
  max-width: 340px;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-white);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
  text-align: left;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.lc-var-trigger:hover { border-color: var(--color-primary); }
.lc-var-trigger.is-open {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(30,127,107,.12);
}
.lc-var-trigger__text { flex: 1; }
.lc-var-trigger__arrow {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--transition);
}
.lc-var-trigger.is-open .lc-var-trigger__arrow { transform: rotate(180deg); }

/* Dropdown panel */
.lc-var-panel {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 100%;
  width: max-content;
  max-width: 400px;
  background: var(--color-white);
  border: 1.5px solid var(--color-primary);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 200;
  padding: var(--space-2);
  max-height: 320px;
  overflow-y: auto;
}
.lc-var-panel.is-open { display: block; }

/* Each option row */
.lc-var-option {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: none;
  background: transparent;
  border-radius: var(--radius);
  cursor: pointer;
  text-align: left;
  transition: background var(--transition);
}
.lc-var-option:hover:not(:disabled) { background: var(--color-bg); }
.lc-var-option.is-selected {
  background: var(--color-primary-light);
}
.lc-var-option.is-disabled,
.lc-var-option:disabled { opacity: .4; cursor: not-allowed; }

.lc-var-option__code {
  font-family: monospace;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: var(--color-text-muted);
  min-width: 90px;
  flex-shrink: 0;
}
.lc-var-option.is-selected .lc-var-option__code { color: var(--color-primary-dark); }
.lc-var-option__dim {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
}
.lc-var-option.is-selected .lc-var-option__dim {
  color: var(--color-primary);
  font-weight: var(--font-weight-semi);
}

/* ==========================================================================
   31. CONTACT PAGE (page-contatti.php)
   ========================================================================== */

/* ── Hero ───────────────────────────────────────────────────────────── */
.ct-hero {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: var(--color-white);
  padding: var(--space-16) var(--container-px) var(--space-12);
  text-align: center;
}
.ct-hero__inner { max-width: 640px; margin: 0 auto; }
.ct-hero__label {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-transform: uppercase;
  letter-spacing: .12em;
  background: rgba(255,255,255,.15);
  border-radius: var(--radius-full);
  padding: 4px var(--space-4);
  margin-bottom: var(--space-4);
}
.ct-hero__title {
  font-size: clamp(var(--font-size-3xl), 5vw, var(--font-size-5xl));
  font-weight: var(--font-weight-bold);
  line-height: 1.15;
  margin-bottom: var(--space-4);
}
.ct-hero__sub {
  font-size: var(--font-size-lg);
  opacity: .85;
  margin-bottom: var(--space-6);
  line-height: 1.6;
}
.ct-hero__pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
}
.ct-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: var(--radius-full);
  padding: 6px var(--space-4);
  backdrop-filter: blur(4px);
}

/* ── Contact cards ──────────────────────────────────────────────────── */
.ct-cards-section {
  padding: var(--space-12) var(--container-px);
  background: var(--color-bg);
}
.ct-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 640px)  { .ct-cards { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .ct-cards { grid-template-columns: repeat(3, 1fr); } }

.ct-card {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), transform var(--transition);
}
.ct-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.ct-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ct-card__icon--location { background: #e8f5f2; color: var(--color-primary); }
.ct-card__icon--phone    { background: #e8f0ff; color: #3b68e8; }
.ct-card__icon--hours    { background: #fff8e6; color: #d97706; }

.ct-card__title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  margin: 0;
}
.ct-card__body {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.7;
  font-style: normal;
}
.ct-card__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
  text-decoration: none;
  margin-top: auto;
}
.ct-card__link:hover { text-decoration: underline; }

.ct-contact-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text);
  text-decoration: none;
  font-size: var(--font-size-sm);
  padding: 3px 0;
  transition: color var(--transition);
}
.ct-contact-row:hover { color: var(--color-primary); }
.ct-contact-row--wa { color: #25D366; font-weight: var(--font-weight-medium); }
.ct-contact-row--wa:hover { color: #128C7E; }

.ct-hours-table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
.ct-hours-table td { padding: 3px 0; }
.ct-hours-table td:last-child { text-align: right; }
.ct-hours-closed td { color: var(--color-text-muted); }

.ct-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  padding: 3px var(--space-3);
  border-radius: var(--radius-full);
}
.ct-status-badge--open  { background: #dcfce7; color: #166534; }
.ct-status-badge--closed { background: #fee2e2; color: #991b1b; }

/* ── Main section: form + sidebar ───────────────────────────────────── */
.ct-main-section {
  padding: var(--space-16) var(--container-px);
}
.ct-main-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: start;
}
@media (min-width: 768px) {
  .ct-main-grid { grid-template-columns: 1.4fr 1fr; }
}

/* Section headings */
.ct-section-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  margin-bottom: var(--space-2);
}
.ct-section-sub {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.ct-form-header { margin-bottom: var(--space-6); }

/* ── Contact form ───────────────────────────────────────────────────── */
.ct-form { display: flex; flex-direction: column; gap: var(--space-4); }
.ct-form__row { display: flex; flex-direction: column; gap: var(--space-4); }
@media (min-width: 480px) {
  .ct-form__row--2col { flex-direction: row; }
  .ct-form__row--2col .ct-form__field { flex: 1; }
}
.ct-form__row--privacy { flex-direction: row; gap: var(--space-2); align-items: flex-start; }
.ct-form__field { display: flex; flex-direction: column; gap: var(--space-1); }
.ct-form__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
}
.ct-form__input,
.ct-form__select,
.ct-form__textarea {
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  color: var(--color-dark);
  background: var(--color-white);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
}
.ct-form__input:focus,
.ct-form__select:focus,
.ct-form__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(30,127,107,.12);
}
.ct-form__textarea { resize: vertical; min-height: 120px; }
.ct-form__checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  cursor: pointer;
  line-height: 1.5;
}
.ct-form__checkbox-label a { color: var(--color-primary); }
.ct-form__checkbox { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; accent-color: var(--color-primary); }
.ct-form__submit {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-8) !important;
  font-size: var(--font-size-base) !important;
  align-self: flex-start;
}
.ct-form__feedback {
  font-size: var(--font-size-sm);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius);
  display: none;
}
.ct-form__feedback.is-success { display: block; background: #dcfce7; color: #166534; }
.ct-form__feedback.is-error   { display: block; background: #fee2e2; color: #991b1b; }

/* ── Sidebar blocks ─────────────────────────────────────────────────── */
.ct-sidebar { display: flex; flex-direction: column; gap: var(--space-5); }

.ct-block-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: var(--border);
}
.ct-block-title svg { color: var(--color-primary); }

/* Map block */
.ct-map-block {
  border: var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.ct-map-block iframe {
  display: block;
  width: 100%;
}
.ct-map-placeholder {
  background: var(--color-bg);
  height: 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  color: var(--color-text-muted);
  text-align: center;
  padding: var(--space-6);
}
.ct-map-placeholder svg { color: var(--color-primary); opacity: .6; }
.ct-map-placeholder p { font-size: var(--font-size-sm); margin: 0; }
.ct-map-link {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
  text-decoration: none;
}
.ct-map-link:hover { text-decoration: underline; }
/* When actual iframe is used: */
.ct-map-block iframe { display: block; }

/* Hours list in sidebar */
.ct-hours-block {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
}
.ct-hours-list { list-style: none; display: flex; flex-direction: column; }
.ct-hours-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) 0;
  border-bottom: var(--border);
  font-size: var(--font-size-sm);
  color: var(--color-text);
}
.ct-hours-item:last-child { border-bottom: none; }
.ct-hours-item.is-today .ct-hours-item__day { font-weight: var(--font-weight-semi); color: var(--color-primary); }
.ct-hours-item.is-today .ct-hours-item__time { font-weight: var(--font-weight-semi); color: var(--color-primary); }
.ct-hours-item.is-closed { color: var(--color-text-muted); }
.ct-hours-item__day { display: flex; align-items: center; gap: var(--space-2); }
.ct-today-badge {
  font-size: 10px;
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  padding: 1px 6px;
  letter-spacing: .04em;
}

/* ── FAQ ────────────────────────────────────────────────────────────── */
.ct-faq-section {
  padding: var(--space-16) var(--container-px);
  background: var(--color-bg);
}
.ct-faq-header { text-align: center; margin-bottom: var(--space-10); }
.ct-faq-grid {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.ct-faq-item {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--transition);
}
.ct-faq-item[open] { box-shadow: var(--shadow); }
.ct-faq-item[open] > .ct-faq-q { border-bottom: var(--border); }
.ct-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background var(--transition), color var(--transition);
}
.ct-faq-q::-webkit-details-marker { display: none; }
.ct-faq-q:hover { background: var(--color-bg); color: var(--color-primary); }
.ct-faq-item[open] .ct-faq-q { color: var(--color-primary); background: var(--color-bg); }
.ct-faq-icon {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--transition);
}
.ct-faq-item[open] .ct-faq-icon { transform: rotate(180deg); color: var(--color-primary); }
.ct-faq-a {
  padding: var(--space-4) var(--space-5);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.7;
}
.ct-faq-a p { margin: 0; }

/* ── Map facade (click-to-load) ─────────────────────────────────────── */
.ct-map-facade {
  position: relative;
  height: 280px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  cursor: pointer;
}
.ct-map-facade__bg {
  position: absolute;
  inset: 0;
  background:
    /* subtle grid lines to suggest a map */
    repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(30,127,107,.08) 39px, rgba(30,127,107,.08) 40px),
    repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(30,127,107,.08) 39px, rgba(30,127,107,.08) 40px),
    linear-gradient(160deg, #e8f4f0 0%, #d4ede8 50%, #c8e8e0 100%);
}
.ct-map-facade__content {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-6);
  text-align: center;
}
.ct-map-facade__content svg { color: var(--color-primary); opacity: .7; }
.ct-map-facade__address {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  line-height: 1.6;
  margin: 0;
}
.ct-map-load-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: background var(--transition), transform var(--transition);
  box-shadow: 0 2px 8px rgba(30,127,107,.3);
}
.ct-map-load-btn:hover { background: var(--color-primary-dark); transform: translateY(-1px); }
.ct-map-ext-link {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-decoration: none;
}
.ct-map-ext-link:hover { color: var(--color-primary); text-decoration: underline; }

/* --------------------------------------------------------------------------
   MOVIMENTAZIONE PAGE (mv- prefix)
   -------------------------------------------------------------------------- */

/* ── Hero ──────────────────────────────────────────────────────────── */
.mv-hero {
  background: linear-gradient(135deg, #1a3c34 0%, #1F6F55 60%, #28866a 100%);
  color: var(--color-white);
  padding: var(--space-16) 0 var(--space-20);
}
.mv-hero__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 768px) {
  .mv-hero__inner { grid-template-columns: 1.2fr 0.8fr; }
}
.mv-hero__label {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-transform: uppercase;
  letter-spacing: .12em;
  opacity: .75;
  margin-bottom: var(--space-3);
}
.mv-hero__title {
  font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-5xl));
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  margin-bottom: var(--space-4);
}
.mv-hero__sub {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-base);
  opacity: .85;
  max-width: 520px;
  margin-bottom: var(--space-6);
}
.mv-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.mv-hero__visual {
  display: flex;
  justify-content: center;
  align-items: center;
}
.mv-hero__icon {
  width: 180px;
  height: 180px;
  color: rgba(255,255,255,.2);
}
@media (max-width: 767px) {
  .mv-hero__visual { display: none; }
}

/* ── Buttons ───────────────────────────────────────────────────────── */
.mv-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-6);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  letter-spacing: .04em;
  border-radius: var(--radius);
  text-decoration: none;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
  border: 2px solid transparent;
  line-height: 1.4;
}
.mv-btn--primary {
  background: #1F6F55;
  color: var(--color-white);
  border-color: #1F6F55;
}
.mv-btn--primary:hover {
  background: #185a45;
  border-color: #185a45;
  color: var(--color-white);
  transform: translateY(-1px);
}
.mv-btn--outline {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255,255,255,.5);
}
.mv-btn--outline:hover {
  background: rgba(255,255,255,.12);
  border-color: var(--color-white);
  color: var(--color-white);
}
.mv-btn--sm { padding: var(--space-2) var(--space-4); font-size: var(--font-size-xs); }
.mv-btn--lg { padding: var(--space-4) var(--space-8); font-size: var(--font-size-base); }

/* ── Sections ──────────────────────────────────────────────────────── */
.mv-section { padding: var(--section-py) 0; }
.mv-section--alt { background: var(--color-section-alt); }
.mv-section--dark {
  background: #0f2922;
  color: var(--color-white);
}
.mv-section__title {
  font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-3xl));
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-3);
  color: var(--color-dark);
}
.mv-section__title--light { color: var(--color-white); }
.mv-section__sub {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  margin-bottom: var(--space-8);
  max-width: 560px;
}

/* ── Product cards grid ────────────────────────────────────────────── */
.mv-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-6);
}
.mv-card {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: box-shadow var(--transition), transform var(--transition);
}
.mv-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.mv-card__icon {
  width: 64px;
  height: 64px;
  color: #1F6F55;
}
.mv-card__icon svg { width: 100%; height: 100%; }
.mv-card__name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
}
.mv-card__specs {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
  color: var(--color-text);
}
.mv-card__specs strong { font-weight: var(--font-weight-medium); }
.mv-card__badge {
  display: inline-block;
  width: fit-content;
  padding: 2px var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: #166534;
  background: #dcfce7;
  border-radius: var(--radius-sm);
}
.mv-card .mv-btn { margin-top: auto; }

/* ── Form layout ───────────────────────────────────────────────────── */
.mv-form-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}
@media (min-width: 768px) {
  .mv-form-layout { grid-template-columns: 1fr 1.4fr; align-items: start; }
}
.mv-form-intro p {
  font-size: var(--font-size-base);
  color: var(--color-text);
  margin-bottom: var(--space-4);
  line-height: var(--line-height-base);
}
.mv-form-intro__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.mv-form-intro__list li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
}
.mv-form-intro__list svg { color: #1F6F55; flex-shrink: 0; }

/* Form fields */
.mv-form {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.mv-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 480px) {
  .mv-form__row { grid-template-columns: 1fr 1fr; }
}
.mv-form__field { display: flex; flex-direction: column; gap: var(--space-1); }
.mv-form__field--full { grid-column: 1 / -1; }
.mv-form label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
}
.mv-form input,
.mv-form select,
.mv-form textarea {
  padding: var(--space-2) var(--space-3);
  border: var(--border);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-family: inherit;
  color: var(--color-text);
  background: var(--color-white);
  transition: border-color var(--transition);
}
.mv-form input:focus,
.mv-form select:focus,
.mv-form textarea:focus {
  outline: none;
  border-color: #1F6F55;
}
.mv-form textarea { resize: vertical; }
.mv-form .mv-btn { align-self: flex-start; }
.mv-form__msg {
  font-size: var(--font-size-sm);
  min-height: 1.4em;
}
.mv-form__msg--ok { color: #166534; }
.mv-form__msg--err { color: #dc2626; }

/* ── Specs grid ────────────────────────────────────────────────────── */
.mv-specs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-6);
}
.mv-spec-block {
  background: var(--color-white);
  border: var(--border);
  border-radius: var(--radius-lg, 12px);
  padding: var(--space-5);
}
.mv-spec-block__title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 2px solid #1F6F55;
}
.mv-spec-block__title svg { color: #1F6F55; flex-shrink: 0; }
.mv-spec-block ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.mv-spec-block li {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  padding-left: var(--space-4);
  position: relative;
}
.mv-spec-block li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: #1F6F55;
  font-weight: var(--font-weight-bold);
}

/* ── Brands ────────────────────────────────────────────────────────── */
.mv-brands { text-align: center; }
.mv-brands .mv-section__sub { margin-inline: auto; }
.mv-brands-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-2);
}
.mv-brand-item {
  padding: var(--space-3) var(--space-6);
  border: var(--border);
  border-radius: var(--radius);
  background: var(--color-white);
  transition: box-shadow var(--transition);
}
.mv-brand-item:hover { box-shadow: var(--shadow); }
.mv-brand-item__name {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
}
.mv-brand-item--other {
  border-style: dashed;
  background: transparent;
}

/* ── Advantages ────────────────────────────────────────────────────── */
.mv-advantages-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-6);
  margin-top: var(--space-4);
}
.mv-advantage {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}
.mv-advantage__icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85);
}
.mv-advantage__text {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  opacity: .9;
}

/* --------------------------------------------------------------------------
   30. COMING SOON / MANUTENZIONE — page template "Coming Soon / Manutenzione"
   -------------------------------------------------------------------------- */

/* ── Wrapper ─────────────────────────────────────────────────────────────── */
.cs-page {
  display: flex;
  flex-direction: column;
}

/* ── Hero section ────────────────────────────────────────────────────────── */
.cs-hero {
  flex: 1;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;
  padding: var(--space-20) 0;
  background: var(--color-white);
  position: relative;
  overflow: hidden;
}

/* Decorative blobs — brand primary-light circles */
.cs-hero::before,
.cs-hero::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  background: var(--color-primary-light);
}
.cs-hero::before {
  width: 520px;
  height: 520px;
  top: -200px;
  right: -140px;
  opacity: 0.5;
}
.cs-hero::after {
  width: 360px;
  height: 360px;
  bottom: -140px;
  left: -100px;
  opacity: 0.35;
}

/* Inner — centrato orizzontalmente */
.cs-hero__inner {
  position: relative;        /* sopra i blob */
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ── Badge "Presto disponibile" ──────────────────────────────────────────── */
.cs-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.4em 1em;
  border-radius: var(--radius-full);
  border: 1px solid rgba(30,127,107,.2);
  margin-bottom: var(--space-6);
}

/* Pulsing dot prima del testo */
.cs-badge::before {
  content: '';
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-primary);
  animation: cs-pulse 2s ease-in-out infinite;
}

@keyframes cs-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.35; transform: scale(0.75); }
}

/* ── Titolo ──────────────────────────────────────────────────────────────── */
.cs-title {
  font-size: clamp(2.25rem, 6vw, 3.75rem);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-dark);
  letter-spacing: -0.025em;
  margin-bottom: var(--space-5);
}

/* Parola accentata in verde */
.cs-title em {
  font-style: normal;
  color: var(--color-primary);
}

/* ── Sottotitolo ─────────────────────────────────────────────────────────── */
.cs-subtitle {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  line-height: var(--line-height-base);
  margin-bottom: var(--space-10);
  max-width: 480px;
}

/* ── Area CTA ────────────────────────────────────────────────────────────── */
.cs-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  margin-bottom: var(--space-10);
  width: 100%;
}

.cs-cta__btn {
  min-width: 220px;
  box-shadow: 0 4px 20px rgba(30,127,107,.25);
  transition: transform var(--transition), box-shadow var(--transition),
              background var(--transition), border-color var(--transition);
}
.cs-cta__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(30,127,107,.35);
}

/* Separatore testuale */
.cs-cta__divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  width: 100%;
  max-width: 320px;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  margin: 0;
}
.cs-cta__divider::before,
.cs-cta__divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

/* ── Contatti ────────────────────────────────────────────────────────────── */
.cs-contacts {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3) var(--space-8);
  font-style: normal;
}

.cs-contact-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--transition);
}
.cs-contact-item:hover {
  color: var(--color-primary);
}
.cs-contact-item svg {
  flex-shrink: 0;
  color: var(--color-primary);
}

/* ── Trust section ───────────────────────────────────────────────────────── */
.cs-trust-section {
  background: var(--color-bg);
  border-top: var(--border);
  padding: var(--space-8) 0;
}

.cs-trust-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-5) var(--space-12);
}

.cs-trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.cs-trust-item__icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  flex-shrink: 0;
}

.cs-trust-item__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-text);
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 599px) {
  .cs-hero { padding: var(--space-12) 0; min-height: unset; }
  .cs-contacts { flex-direction: column; align-items: center; }
  .cs-trust-grid { flex-direction: column; gap: var(--space-4); }
  .cs-cta__divider { max-width: 260px; }
}


/* Allargare la pagina del prodotto singolo per usare piu spazio */
@media (min-width: 1024px) {
  .single-product #content .container,
  .single-product .site-main .container,
  .single-product .container {
    padding-inline: 2rem;
  }
}

.woocommerce div.product .woocommerce-product-details__short-description {
  margin-bottom: var(--space-4) !important;
}


/* Espandere la pagina del prodotto */
@media (min-width: 1024px) {
  body.single-product .container {
    max-width: 1520px !important;
  }
}


.woocommerce div.product .woocommerce-product-details__short-description > :last-child {
  margin-bottom: 0 !important;
}
.lc-quick-variants {
  margin-top: -0.5rem;
}

.woocommerce div.product .woocommerce-product-details__short-description {
  margin-bottom: 0 !important;
}
.lc-info-col .summary {
  gap: var(--space-4) /* o un valore minore come var(--space-2) */;
}

/* Miglioramento Badget In Offerta */
.woocommerce span.onsale {
  background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%) !important;
  color: #fff !important;
  font-size: 0.85rem !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 6px 14px !important;
  box-shadow: 0 4px 14px rgba(220, 38, 38, 0.35) !important;
  transform: translateY(-2px);
  border: 1.5px solid #fff;
}

@keyframes pulseSale {
  0% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4); }
  70% { box-shadow: 0 0 0 10px rgba(239, 68, 68, 0); }
  100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0); }
}
.woocommerce span.onsale {
  animation: pulseSale 2.5s infinite !important;
  z-index: 10 !important;
}

.vt2-price-tiers { margin-top: 8px; font-size: 13px; color: var(--color-text-dark); background: #f8f9fa; padding: 6px 10px; border-radius: 4px; border-left: 3px solid var(--color-primary); }
.vt2-price-tiers-title { font-weight: 600; margin-bottom: 4px; font-size: 12px; }
.vt2-price-tiers-list { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.vt2-price-tiers-list li { display: flex; justify-content: space-between; padding: 2px 0; border-bottom: 1px solid rgba(0,0,0,0.05); }
.vt2-price-tiers-list li:last-child { border-bottom: none; }
.tier-range { color: var(--color-text-muted); }
.tier-price strong { color: var(--color-primary); }
.vt2-delivery-dates { display: inline-flex; align-items: center; gap: 6px; font-weight: 500; font-size: 13px; }
.vt2-delivery-dates svg { color: var(--color-primary); flex-shrink: 0; }

/* --------------------------------------------------------------------------
   35. CONTACT PAGE EDITORIAL (page-contatti.php)
   -------------------------------------------------------------------------- */
.lc-contact-hero {
  padding: var(--space-16) 0 var(--space-10);
  background: var(--color-surface);
}

.lc-contact-kicker {
  margin-bottom: var(--space-6);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.lc-contact-hero__grid,
.lc-contact-form-section__grid,
.lc-contact-faq__grid {
  display: grid;
  gap: var(--space-8);
}

.lc-contact-hero__title,
.lc-contact-section-title {
  margin: 0;
  font-family: var(--font-family);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--color-dark);
}

.lc-contact-section-title {
  font-size: clamp(1.875rem, 4vw, 3rem);
}

.lc-contact-hero__title em,
.lc-contact-section-title em {
  font-style: italic;
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
}

.lc-contact-hero__text,
.lc-contact-section-text {
  max-width: 36rem;
  margin-top: var(--space-6);
  font-size: var(--font-size-lg);
  line-height: 1.65;
  color: var(--color-text-muted);
}

.lc-contact-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  align-self: end;
}

.lc-contact-stat {
  padding-left: var(--space-4);
  border-left: 1px solid var(--color-border);
}

.lc-contact-stat__number {
  font-size: clamp(1.5rem, 2.5vw, 1.875rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.lc-contact-stat__label {
  margin-top: 0.375rem;
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  line-height: 1.4;
}

.lc-contact-channels {
  padding-bottom: var(--space-12);
}

.lc-contact-channels__grid,
.lc-contact-offices__grid {
  display: grid;
  gap: var(--space-5);
}

.lc-contact-card,
.lc-contact-office-card,
.lc-contact-form-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.lc-contact-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-6);
  color: inherit;
  text-decoration: none;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.lc-contact-card:hover,
.lc-contact-office-card:hover {
  transform: translateY(calc(var(--space-1) * -1));
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
}

.lc-contact-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.lc-contact-card__icon {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
}

.lc-contact-card__icon svg,
.lc-contact-benefits__icon svg,
.lc-contact-office-card__icon svg {
  width: 20px;
  height: 20px;
}

.lc-contact-card__icon--phone,
.lc-contact-card__icon--mail,
.lc-contact-card__icon--wa,
.lc-contact-benefits__icon {
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
}

.lc-contact-card__arrow {
  color: var(--color-text-muted);
}

.lc-contact-card__eyebrow {
  font-size: 0.625rem;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.25rem;
}

.lc-contact-office-card__label {
  font-size: 0.625rem;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.lc-contact-card__value {
  font-size: clamp(1.125rem, 1.5vw, 1.25rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
  color: var(--color-dark);
}

.lc-contact-card__detail {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-top: 0.375rem;
}

.lc-contact-form-section,
.lc-contact-faq {
  padding: var(--space-16) 0;
  background: color-mix(in srgb, var(--color-bg-alt) 55%, var(--color-surface));
}

.lc-contact-form-copy {
  align-self: start;
}

.lc-contact-benefits {
  margin-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.lc-contact-benefits__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-dark);
}

.lc-contact-benefits__icon {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.lc-contact-form-card {
  padding: var(--space-6);
}

@media (min-width: 768px) {
  .lc-contact-form-card {
    padding: var(--space-10);
  }
}

.lc-contact-feedback {
  margin-bottom: var(--space-5);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
}

.lc-contact-feedback--success {
  background: color-mix(in srgb, var(--color-primary) 12%, var(--color-surface));
  color: var(--color-dark);
}

.lc-contact-feedback--error {
  background: color-mix(in srgb, #c0392b 10%, var(--color-surface));
  color: var(--color-dark);
}

.lc-contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.lc-contact-form__row {
  display: grid;
  gap: var(--space-4);
}

.lc-contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.lc-contact-form__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
}

.lc-contact-form__input,
.lc-contact-form__textarea {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-surface);
  padding: var(--space-4);
  font: inherit;
  color: var(--color-dark);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.lc-contact-form__input {
  min-height: 2.75rem;
}

.lc-contact-form__textarea {
  min-height: 10rem;
  resize: vertical;
}

.lc-contact-form__input:focus,
.lc-contact-form__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 14%, transparent);
}

.lc-contact-form__privacy {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  line-height: 1.6;
  color: var(--color-text-muted);
}

.lc-contact-form__privacy input {
  margin-top: 0.2rem;
  accent-color: var(--color-primary);
}

.lc-contact-form__submit {
  min-height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: background var(--transition), transform var(--transition);
}

.lc-contact-form__submit:hover {
  background: var(--color-primary-dark);
  transform: translateY(calc(var(--space-1) * -0.5));
}

.lc-contact-form__submit svg {
  width: 18px;
  height: 18px;
}

.lc-contact-form__note {
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.lc-contact-offices {
  padding: var(--space-16) 0;
  background: var(--color-surface);
}

.lc-contact-offices__header {
  margin-bottom: var(--space-8);
}

.lc-contact-section-title--wide {
  max-width: 52rem;
}

.lc-contact-office-card {
  padding: var(--space-6);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.lc-contact-office-card__row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin-top: var(--space-4);
  color: var(--color-dark);
}

.lc-contact-office-card__row p {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  line-height: 1.6;
}

.lc-contact-office-card__row--muted {
  color: var(--color-text-muted);
}

.lc-contact-office-card__row--muted p {
  font-size: var(--font-size-sm);
}

.lc-contact-office-card__icon {
  color: var(--color-dark);
  flex-shrink: 0;
}

.lc-contact-faq__intro {
  align-self: start;
}

.lc-contact-faq__list {
  border-top: 1px solid var(--color-border);
}

.lc-contact-faq__item {
  border-bottom: 1px solid var(--color-border);
}

.lc-contact-faq__summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  cursor: pointer;
  color: var(--color-dark);
  font-size: clamp(1rem, 1.4vw, 1.125rem);
  font-weight: var(--font-weight-semi);
}

.lc-contact-faq__summary::-webkit-details-marker {
  display: none;
}

.lc-contact-faq__toggle {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 1;
  color: var(--color-dark);
  flex-shrink: 0;
  transition: background var(--transition), color var(--transition), transform var(--transition), border-color var(--transition);
}

.lc-contact-faq__item[open] .lc-contact-faq__toggle {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
  transform: rotate(45deg);
}

.lc-contact-faq__answer {
  padding: 0 var(--space-12) var(--space-5) 0;
  max-width: 52rem;
  font-size: var(--font-size-base);
  line-height: 1.65;
  color: var(--color-text-muted);
}

.lc-contact-faq__answer p {
  margin: 0;
}

.lc-contact-extra {
  padding: var(--space-10) 0 var(--space-16);
  background: var(--color-surface);
}

@media (min-width: 768px) {
  .lc-contact-form__row--2,
  .lc-contact-channels__grid,
  .lc-contact-offices__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .lc-contact-hero__grid {
    grid-template-columns: minmax(0, 1.7fr) minmax(320px, 0.8fr);
    align-items: end;
  }

  .lc-contact-channels__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lc-contact-form-section__grid {
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: var(--space-16);
    align-items: start;
  }

  .lc-contact-form-copy {
    position: sticky;
    top: calc(var(--space-8) + 4rem);
  }

  .lc-contact-faq__grid {
    grid-template-columns: minmax(0, 4fr) minmax(0, 8fr);
    gap: var(--space-16);
  }
}

@media (max-width: 767px) {
  .lc-contact-hero,
  .lc-contact-form-section,
  .lc-contact-offices,
  .lc-contact-faq {
    padding-block: var(--space-12);
  }

  .lc-contact-hero__stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lc-contact-section-text,
  .lc-contact-hero__text {
    font-size: var(--font-size-base);
  }

  .lc-contact-form-card {
    padding: var(--space-5);
  }
}

/* --------------------------------------------------------------------------
   36. QUICK ORDER PAGE (page-ordine-veloce.php)
   -------------------------------------------------------------------------- */
.lq-hero {
  padding: var(--space-12) 0 var(--space-8);
  background: var(--color-surface);
}

.lq-hero__topline {
  padding-bottom: var(--space-6);
  margin-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.lq-hero__grid,
.lq-order-bottom,
.lq-check-card {
  display: grid;
  gap: var(--space-6);
}

.lq-hero__title {
  margin: 0;
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--color-dark);
}

.lq-hero__title span,
.lq-check-card__title span {
  white-space: nowrap;
  font-style: italic;
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
}

.lq-hero__text,
.lq-check-card__text {
  max-width: 42rem;
  margin-top: var(--space-5);
  font-size: var(--font-size-lg);
  line-height: 1.7;
  color: var(--color-text-muted);
}

.lq-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.lq-pill-btn {
  min-height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-dark);
  background: transparent;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
}

.lq-pill-btn--outline {
  border-color: var(--color-border);
}

.lq-pill-btn--primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

.lq-pill-btn:disabled,
.lq-pill-btn[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}

.lq-pill-btn svg {
  width: 16px;
  height: 16px;
}

.lq-mode-switch {
  padding-bottom: var(--space-6);
}

.lq-mode-switch__inner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-bg-alt) 50%, var(--color-surface));
}

.lq-mode-switch__btn {
  min-height: 2.5rem;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-5);
  border: 0;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: color var(--transition), background var(--transition);
}

.lq-mode-switch__btn svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.lq-mode-switch__btn.is-active {
  background: var(--color-dark);
  color: var(--color-white);
}

.lq-order-panel,
.lq-check-panel {
  display: none;
  padding-bottom: var(--space-16);
}

.lq-order-panel.is-active,
.lq-check-panel.is-active {
  display: block;
}

.lq-order-card,
.lq-info-card,
.lq-summary-card,
.lq-check-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}

.lq-order-head {
  display: none;
  padding: var(--space-4) var(--space-6);
  background: color-mix(in srgb, var(--color-bg-alt) 60%, var(--color-surface));
  border-bottom: 1px solid var(--color-border);
}

.lq-order-head__grid {
  display: grid;
  grid-template-columns: 2.2fr 1.6fr 0.8fr 0.8fr;
  gap: var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.lq-row {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.lq-row:last-child {
  border-bottom: 0;
}

.lq-row__sku {
  position: relative;
}

.lq-row__sku-input,
.lq-check-search__input {
  width: 100%;
  min-height: 3rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-surface);
  color: var(--color-dark);
  font: inherit;
  padding: 0 var(--space-4);
}

.lq-row__sku-input {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  text-transform: uppercase;
}

.lq-row__sku-input:focus,
.lq-check-search__input:focus,
.lq-qty__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 14%, transparent);
}

.lq-row__suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.lq-suggestion {
  padding: 0.25rem 0.6rem;
  border: 0;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-bg-alt) 70%, var(--color-surface));
  color: var(--color-dark);
  font-size: var(--font-size-xs);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  cursor: pointer;
}

.lq-row__product {
  min-width: 0;
}

.lq-row__product-empty,
.lq-row__product-status {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.lq-row__product-name {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
  line-height: 1.35;
}

.lq-row__product-status {
  margin-top: var(--space-1);
}

.lq-row__product-status.is-ok {
  color: var(--color-primary);
}

.lq-row__product-status.is-out,
.lq-row__product-status.is-missing {
  color: #c0392b;
}

.lq-row__qty,
.lq-row__total {
  display: flex;
  align-items: center;
}

.lq-qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}

.lq-qty__btn {
  width: 2.5rem;
  height: 2.5rem;
  border: 0;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
}

.lq-qty__input {
  width: 3rem;
  height: 2.5rem;
  border: 0;
  border-left: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
  background: transparent;
  text-align: center;
  font: inherit;
  font-weight: var(--font-weight-semi);
}

.lq-row__total {
  justify-content: space-between;
  gap: var(--space-3);
}

.lq-row__total-value {
  color: var(--color-dark);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
}

.lq-row__remove {
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-muted);
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

.lq-order-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg-alt) 40%, var(--color-surface));
}

.lq-text-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 0;
  background: transparent;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
}

.lq-order-footer__meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.lq-summary-card__note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.lq-info-card,
.lq-summary-card,
.lq-check-card {
  padding: var(--space-6);
}

.lq-info-card__title,
.lq-check-card__title {
  margin: 0 0 var(--space-2);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--color-dark);
}

.lq-info-card__list {
  padding: 0;
  margin: 0;
  list-style: none;
  counter-reset: lq-step;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  line-height: 1.6;
}

.lq-info-card__list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  counter-increment: lq-step;
}

.lq-info-card__list li::before {
  content: counter(lq-step);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  width: 1.625rem;
  height: 1.625rem;
  border-radius: 50%;
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.7rem;
  font-weight: var(--font-weight-bold);
  margin-top: 0.05rem;
}

.lq-summary-card__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
}

.lq-summary-card__row span {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.lq-summary-card__row strong {
  font-size: clamp(1.5rem, 2vw, 1.75rem);
  line-height: 1;
  color: var(--color-dark);
  font-variant-numeric: tabular-nums;
}

.lq-submit-btn {
  width: 100%;
  min-height: 3rem;
  margin-top: var(--space-4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
}

.lq-submit-btn svg {
  width: 16px;
  height: 16px;
}

.lq-feedback {
  min-height: 1.25rem;
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
}

.lq-feedback.is-success {
  color: var(--color-primary);
}

.lq-feedback.is-error {
  color: #c0392b;
}

.lq-check-search {
  max-width: 42rem;
}

.lq-check-results {
  display: grid;
  gap: var(--space-3);
}

.lq-check-empty {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-8);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-xl);
  text-align: center;
  color: var(--color-text-muted);
}

.lq-check-empty strong {
  color: var(--color-dark);
}

.lq-check-empty.is-error strong {
  color: #c0392b;
}

.lq-check-item {
  display: grid;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
}

.lq-check-item__image {
  width: 4rem;
  height: 4rem;
  object-fit: cover;
  border-radius: var(--radius);
  background: var(--color-bg-alt);
}

.lq-check-item__name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semi);
  color: var(--color-dark);
}

.lq-check-item__sku {
  margin-top: var(--space-1);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.lq-check-item__meta {
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
}

.lq-check-item__meta.is-ok {
  color: var(--color-primary);
}

.lq-check-item__meta.is-out {
  color: #c0392b;
}

.lq-check-item__add {
  min-height: 2.5rem;
  padding: 0 var(--space-5);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-dark);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
}

.lq-extra-content {
  padding: 0 0 var(--space-16);
}

/* --- Modal Excel import --- */
.lq-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.lq-modal[hidden] {
  display: none;
}

.lq-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(3px);
}

.lq-modal__box {
  position: relative;
  width: 100%;
  max-width: 28rem;
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: 0 20px 60px rgba(0,0,0,0.18);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.lq-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
}

.lq-modal__title {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  line-height: 1.3;
}

.lq-modal__close {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-bg-alt) 70%, var(--color-surface));
  color: var(--color-text-muted);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background var(--transition);
}

.lq-modal__close:hover {
  background: var(--color-bg-alt);
}

.lq-modal__close svg {
  width: 14px;
  height: 14px;
}

.lq-modal__desc {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

.lq-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.lq-modal__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

@media (min-width: 1024px) {
  .lq-hero__grid {
    grid-template-columns: minmax(0, 1.3fr) auto;
    align-items: end;
  }

  .lq-order-head {
    display: block;
  }

  .lq-row {
    grid-template-columns: 2.2fr 1.6fr 0.8fr 0.8fr;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-6);
  }

  .lq-row__total {
    justify-content: flex-end;
  }

  .lq-order-bottom {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    margin-top: var(--space-8);
  }

  .lq-check-item {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
}

@media (max-width: 767px) {
  .lq-hero__actions,
  .lq-mode-switch__inner,
  .lq-order-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .lq-pill-btn,
  .lq-mode-switch__btn {
    width: 100%;
  }
}

/* --------------------------------------------------------------------------
   37. MOVIMENTAZIONE PAGE (page-movimentazione.php)
   -------------------------------------------------------------------------- */

.lmv-page {
  overflow: hidden;
  background: var(--color-bg);
}

.lmv-page .container {
  max-width: var(--container-max);
}

.lmv-kicker {
  margin-bottom: var(--space-3);
  color: var(--color-primary);
  font-family: var(--font-family);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  line-height: 1.4;
  text-transform: uppercase;
}

.lmv-kicker::before {
  content: "↳ ";
}

.lmv-kicker--light {
  color: color-mix(in srgb, var(--color-white) 62%, transparent);
}

.lmv-section-title,
.lmv-hero__title,
.lmv-final-cta__title {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-family);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.055em;
}

.lmv-section-title {
  max-width: 42rem;
  font-size: clamp(1.875rem, 3vw, 3rem);
  line-height: 1.02;
}

.lmv-section-title--sm {
  max-width: 28rem;
  font-size: clamp(1.5rem, 2.5vw, 1.875rem);
  line-height: 1.08;
}

.lmv-section-title span,
.lmv-hero__title span,
.lmv-final-cta__title span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: var(--font-weight-medium);
}

.lmv-btn,
.lmv-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  text-decoration: none;
  transition: transform var(--transition), background-color var(--transition), border-color var(--transition), color var(--transition);
}

.lmv-btn {
  min-height: 3rem;
  padding: 0 var(--space-6);
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
}

.lmv-btn:hover,
.lmv-card-link:hover {
  transform: translateY(-1px);
}

.lmv-btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
}

.lmv-btn--outline {
  border-color: color-mix(in srgb, var(--color-dark) 20%, transparent);
  background: transparent;
  color: var(--color-dark);
}

.lmv-btn--outline:hover {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-white);
}

.lmv-btn--white {
  background: var(--color-white);
  color: var(--color-dark);
}

.lmv-btn--ghost {
  border-color: color-mix(in srgb, var(--color-white) 28%, transparent);
  color: var(--color-white);
}

.lmv-btn--ghost:hover {
  background: var(--color-white);
  color: var(--color-dark);
}

/* ── HERO MOVIMENTAZIONE — full-bleed bg image + overlay ── */
.lmv-hero {
  position: relative;
  min-height: auto;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: var(--color-white);
}

.lmv-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.lmv-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

.lmv-hero__overlay {
  position: absolute;
  inset: 0;
}

.lmv-hero__overlay--flat { background: rgba(10,14,20,0.55); }
.lmv-hero__overlay--h    { background: linear-gradient(to right, rgba(10,14,20,0.72) 0%, rgba(10,14,20,0.30) 60%, transparent 100%); }
.lmv-hero__overlay--v    { background: linear-gradient(to top, rgba(10,14,20,0.65) 0%, transparent 55%); }

.lmv-hero__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  padding-top: var(--space-8);
  padding-bottom: var(--space-10);
  gap: var(--space-5);
}

.lmv-hero__top .lmv-kicker--light {
  color: var(--color-primary);
  letter-spacing: 0.28em;
}

.lmv-hero__mid {
  display: grid;
  gap: var(--space-8);
  align-items: start;
}

.lmv-hero__copy {
  display: flex;
  flex-direction: column;
}

.lmv-hero__title {
  max-width: 56rem;
  margin: 0 0 var(--space-4);
  font-size: clamp(3rem, 7vw, 6.5rem);
  font-weight: 800;
  line-height: 0.93;
  letter-spacing: -0.04em;
  color: var(--color-white);
  filter: drop-shadow(0 2px 24px rgba(0,0,0,0.5));
}

.lmv-hero__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--color-primary);
}

.lmv-hero__text {
  max-width: 38rem;
  margin: 0 0 var(--space-8);
  color: rgba(255,255,255,0.88);
  font-size: clamp(1rem, 1.6vw, 1.15rem);
  line-height: 1.7;
}

.lmv-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.lmv-btn--hero-outline {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: calc(var(--space-10) + var(--space-2));
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  font-family: var(--font-family);
  white-space: nowrap;
  text-decoration: none;
  cursor: pointer;
  border: 1.5px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.10);
  color: var(--color-white);
  backdrop-filter: blur(8px);
  transition: background var(--transition), border-color var(--transition);
}
.lmv-btn--hero-outline:hover {
  background: rgba(255,255,255,0.18);
  border-color: rgba(255,255,255,0.6);
}

/* Pannello brand */
/* Pannello brand — lista testo 2 colonne */
.lmv-hero__panel {
  background: rgba(10,14,20,0.60);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 1.25rem;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.lmv-hero__panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-3);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

.lmv-hero__panel-label {
  color: rgba(255,255,255,0.50);
  font-size: var(--font-size-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.lmv-hero__panel-count {
  color: rgba(255,255,255,0.35);
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.lmv-hero__panel-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.lmv-hero__panel-item {
  padding: var(--space-3) 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  color: var(--color-white);
  font-size: clamp(0.95rem, 1.1vw, 1.05rem);
  font-weight: var(--font-weight-medium);
}

.lmv-hero__panel-item:nth-child(odd) {
  padding-right: var(--space-4);
  border-right: 1px solid rgba(255,255,255,0.08);
}

.lmv-hero__panel-item:nth-child(even) {
  padding-left: var(--space-4);
}

.lmv-hero__panel-item:nth-last-child(-n+2) {
  border-bottom: none;
}

.lmv-hero__panel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-3);
  border-top: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.50);
  font-size: var(--font-size-xs);
  text-decoration: none;
  transition: color var(--transition);
}

.lmv-hero__panel-footer:hover { color: var(--color-primary); }
.lmv-hero__panel-footer svg { flex-shrink: 0; color: var(--color-primary); }

/* Bottom: feature cards + stats */
.lmv-hero__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,0.15);
}

.lmv-hero__feature-cards {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.lmv-hero__fcard {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.06);
}

.lmv-hero__fcard-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  color: var(--color-primary);
}

.lmv-hero__fcard-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.lmv-hero__fcard-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  color: var(--color-white);
  line-height: 1.2;
}

.lmv-hero__fcard-sub {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.50);
  line-height: 1.2;
  margin-top: 2px;
}

/* Kicker editoriale con trattino */
.lmv-kicker--editorial {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.lmv-kicker__line {
  display: block;
  width: 2rem;
  height: 1.5px;
  background: var(--color-primary);
  flex-shrink: 0;
}

.lmv-hero__features {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
}

.lmv-feature {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.lmv-feature--light { color: rgba(255,255,255,0.75); }
.lmv-feature--light .lmv-feature__icon { color: var(--color-primary); }

.lmv-feature__icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-primary);
}

.lmv-feature__icon svg,
.lmv-order-card__icon svg,
.lmv-quote__perk-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.lmv-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
  margin-top: var(--space-12);
  padding-top: var(--space-10);
  border-top: 1px solid var(--color-border);
}

.lmv-stats--light {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
  gap: var(--space-8);
}

.lmv-stats--light .lmv-stat__number { color: var(--color-white); }
.lmv-stats--light .lmv-stat__label  { color: rgba(255,255,255,0.55); }

.lmv-stat__number {
  color: var(--color-dark);
  font-family: var(--font-family);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  letter-spacing: -0.04em;
}

.lmv-stat__label {
  margin-top: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}

.lmv-vehicles,
.lmv-sold {
  padding: var(--space-16) 0;
  background: color-mix(in srgb, var(--color-bg-alt) 55%, var(--color-bg));
}

.lmv-section-head,
.lmv-brands__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}

.lmv-scroll-hint {
  display: none;
  color: var(--color-text-muted);
  font-size: var(--font-size-xl);
  letter-spacing: 0.3em;
}

.lmv-vehicle-scroller {
  margin-inline: calc(var(--space-6) * -1);
  padding-inline: var(--space-6);
  overflow-x: auto;
  scrollbar-width: none;
}

.lmv-vehicle-scroller::-webkit-scrollbar {
  display: none;
}

.lmv-vehicle-grid {
  display: flex;
  min-width: max-content;
  gap: var(--space-5);
  margin: 0;
  padding: 0 0 var(--space-2);
  list-style: none;
  scroll-snap-type: x mandatory;
}

.lmv-vehicle-grid li {
  width: min(21.25rem, 78vw);
  scroll-snap-align: start;
}

.lmv-vehicle-card,
.lmv-order-card,
.lmv-quote-form,
.lmv-sold-card {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lmv-vehicle-card__media,
.lmv-order-card__media,
.lmv-sold-card__media {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-alt);
}

.lmv-vehicle-card__media {
  aspect-ratio: 4 / 3;
}

.lmv-order-card__media {
  aspect-ratio: 16 / 10;
}

.lmv-sold-card__media {
  aspect-ratio: 5 / 4;
}

.lmv-vehicle-card img,
.lmv-order-card img,
.lmv-sold-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.lmv-vehicle-card:hover img,
.lmv-order-card:hover img,
.lmv-sold-card:hover img {
  transform: scale(1.05);
}

.lmv-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.625rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lmv-vehicle-card__body,
.lmv-order-card__body {
  padding: var(--space-5);
}

.lmv-vehicle-card h3,
.lmv-order-card h3 {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-family);
  font-size: clamp(1.25rem, 2vw, 1.875rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.22;
}

.lmv-vehicle-card p,
.lmv-order-card p,
.lmv-brands__head p,
.lmv-quote__text,
.lmv-final-cta__side p {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.7;
}

.lmv-vehicle-card p {
  margin-top: var(--space-1);
  font-size: var(--font-size-sm);
}

.lmv-card-link {
  width: 100%;
  min-height: 2.55rem;
  margin-top: var(--space-4);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}

.lmv-brands {
  padding: var(--space-16) 0;
  border-block: 1px solid var(--color-border);
  background: var(--color-bg);
}

.lmv-brands__head p {
  max-width: 24rem;
  font-size: var(--font-size-sm);
}

.lmv-brand-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-border);
}

.lmv-brand-grid--logos {
  gap: clamp(0.875rem, 1.5vw, 1.25rem);
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.lmv-brand-tile {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 3 / 2;
  background: var(--color-surface);
  transition: background-color var(--transition);
}

.lmv-brand-grid--logos .lmv-brand-tile {
  aspect-ratio: auto;
  min-height: clamp(7.5rem, 9vw, 9.25rem);
  padding: clamp(1.25rem, 2vw, 1.75rem);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}

.lmv-order-card {
  display: flex;
  flex-direction: column;
}

.lmv-brand-tile:hover {
  background: color-mix(in srgb, var(--color-bg-alt) 65%, var(--color-surface));
}

.lmv-brand-tile span {
  color: var(--color-text-muted);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  transition: color var(--transition);
}

@media (min-width: 1024px) {
  .lmv-brand-tile span {
    font-size: var(--font-size-lg);
  }
}

.lmv-brand-tile:hover span {
  color: var(--color-dark);
}

.lmv-brand-logo {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 88%;
  max-height: 62%;
  object-fit: contain;
  transition: transform var(--transition);
}

.lmv-brand-logo--linde {
  max-width: 90%;
  max-height: 70%;
}

.lmv-brand-logo--jungheinrich {
  max-width: 94%;
  max-height: 54%;
}

.lmv-brand-logo--still {
  max-width: 90%;
  max-height: 66%;
}

.lmv-brand-logo--toyota {
  max-width: 88%;
  max-height: 68%;
}

.lmv-brand-logo--hyster {
  max-width: 90%;
  max-height: 64%;
}

.lmv-brand-tile:hover .lmv-brand-logo {
  transform: translateY(-1px);
}

.lmv-ordering,
.lmv-quote {
  padding: var(--space-16) 0;
  background: var(--color-bg);
}

.lmv-ordering__head {
  margin-bottom: var(--space-10);
}

.lmv-ordering__grid,
.lmv-sold__grid {
  display: grid;
  gap: var(--space-6);
}

.lmv-order-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--space-4);
}

.lmv-order-card .lmv-card-link {
  margin-top: auto;
}

.lmv-order-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-muted);
  font-family: var(--font-family);
  font-size: var(--font-size-xs);
  font-variant-numeric: tabular-nums;
}

.lmv-order-card__line {
  height: 1px;
  flex: 1;
  background: var(--color-border);
}

.lmv-order-card__icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-primary);
}

.lmv-quote__grid {
  display: grid;
  gap: var(--space-10);
  align-items: start;
}

.lmv-quote__copy {
  display: grid;
  gap: var(--space-6);
}

.lmv-quote__perks {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.lmv-quote__perks li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-dark);
  font-size: var(--font-size-sm);
}

.lmv-quote__perk-icon {
  display: grid;
  width: 2rem;
  height: 2rem;
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
}

.lmv-quote__perk-icon svg {
  width: 1rem;
  height: 1rem;
}

.lmv-quote-form {
  display: grid;
  gap: var(--space-5);
  padding: var(--space-6);
}

.lmv-quote-form__row {
  display: grid;
  gap: var(--space-4);
}

.lmv-quote-form label {
  display: grid;
  gap: var(--space-2);
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.lmv-quote-form input,
.lmv-quote-form select,
.lmv-quote-form textarea {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-surface);
  color: var(--color-dark);
  font: inherit;
  font-weight: var(--font-weight-normal);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.lmv-quote-form input,
.lmv-quote-form select {
  min-height: 2.75rem;
  padding: 0 var(--space-4);
}

.lmv-quote-form textarea {
  min-height: 8.5rem;
  padding: var(--space-3) var(--space-4);
  resize: vertical;
}

.lmv-quote-form input:focus,
.lmv-quote-form select:focus,
.lmv-quote-form textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 14%, transparent);
}

.lmv-submit-btn {
  display: inline-flex;
  min-height: 3rem;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: transform var(--transition), opacity var(--transition);
}

.lmv-submit-btn:hover {
  transform: translateY(-1px);
}

.lmv-submit-btn:disabled {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.lmv-form-msg,
.mv-form__msg {
  min-height: 1.25rem;
  margin: 0;
  text-align: center;
  font-size: var(--font-size-sm);
}

.mv-form__msg--ok {
  color: var(--color-primary);
}

.mv-form__msg--err {
  color: #c0392b;
}

.lmv-sold .lmv-section-title {
  margin-bottom: var(--space-10);
}

.lmv-sold-card {
  margin: 0;
}

.lmv-sold-card__caption {
  padding: var(--space-4);
}

.lmv-sold-card__caption div {
  color: var(--color-dark);
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}

.lmv-sold-card__caption span {
  display: block;
  margin-top: var(--space-1);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
}

.lmv-final-cta {
  padding: var(--space-16) 0;
  background: var(--color-dark);
  color: var(--color-white);
}

.lmv-final-cta__grid {
  display: grid;
  gap: var(--space-8);
  align-items: center;
}

.lmv-final-cta__title {
  color: var(--color-white);
  font-size: clamp(2rem, 4vw, 3.75rem);
  line-height: 0.95;
}

.lmv-final-cta__title span {
  color: color-mix(in srgb, var(--color-white) 88%, var(--color-primary));
}

.lmv-final-cta__side {
  display: grid;
  gap: var(--space-4);
}

.lmv-final-cta__side p {
  color: color-mix(in srgb, var(--color-white) 70%, transparent);
}

.lmv-final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.lmv-extra {
  padding: var(--space-12) 0 var(--space-16);
}

/* ── FAQ movimentazione ── */
.lmv-faq {
  padding: var(--space-14) 0 var(--space-16);
}

.lmv-faq__list {
  margin-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.lmv-faq__item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  overflow: hidden;
}

.lmv-faq__item[open] {
  box-shadow: var(--shadow-sm);
}

.lmv-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: clamp(0.95rem, 1.2vw, 1.05rem);
  color: var(--color-text);
  user-select: none;
}

.lmv-faq__question::-webkit-details-marker { display: none; }

.lmv-faq__question span:first-child {
  flex: 1;
}

.lmv-faq__icon {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  transition: transform 0.25s ease;
  color: var(--color-text-secondary);
}

.lmv-faq__icon svg {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
}

.lmv-faq__item[open] .lmv-faq__icon {
  transform: rotate(180deg);
}

.lmv-faq__answer {
  padding: 0 var(--space-6) var(--space-5);
  border-top: 1px solid var(--color-border);
}

.lmv-faq__answer p {
  margin: var(--space-4) 0 0;
  color: var(--color-text-secondary);
  line-height: 1.75;
  font-size: 0.95rem;
}

.lmv-seo-area {
  padding: var(--space-12) 0 var(--space-16);
  background: var(--color-surface-secondary, #f7f7f7);
  border-top: 1px solid var(--color-border);
}

.lmv-seo-grid {
  display: grid;
  gap: var(--space-8);
}

.lmv-seo-block h2 {
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 700;
  margin: 0 0 var(--space-4);
  color: var(--color-text);
}

.lmv-seo-block h3 {
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  font-weight: 600;
  margin: 0 0 var(--space-3);
  color: var(--color-text);
}

.lmv-seo-block p {
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin: 0 0 var(--space-4);
}

.lmv-seo-block ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.lmv-seo-block ul li {
  color: var(--color-text-secondary);
  line-height: 1.6;
  padding-left: var(--space-4);
  position: relative;
}

.lmv-seo-block ul li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--color-accent, #e63329);
}

@media (min-width: 768px) {
  .lmv-seo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .lmv-seo-block:first-child {
    grid-column: 1 / -1;
  }
}

@media (min-width: 640px) {
  .lmv-brand-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .lmv-brand-grid--logos {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .lmv-quote-form__row,
  .lmv-sold__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .lmv-hero__mid {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: var(--space-12);
  }

  .lmv-hero__panel-brands {
    grid-template-columns: repeat(3, minmax(0,1fr));
  }

  .lmv-scroll-hint {
    display: block;
  }

  .lmv-brand-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .lmv-brand-grid--logos {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }

  .lmv-ordering__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-8);
  }

  .lmv-quote__grid {
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: var(--space-16);
  }

  .lmv-quote__copy {
    position: sticky;
    top: 6rem;
  }

  .lmv-quote-form {
    padding: var(--space-10);
  }

  .lmv-sold__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .lmv-final-cta__grid {
    grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
  }

  .lmv-final-cta__side {
    justify-items: end;
    text-align: right;
  }

  .lmv-final-cta__side p {
    max-width: 26rem;
  }

  .lmv-final-cta__actions {
    justify-content: end;
  }
}

@media (max-width: 767px) {
  .lmv-stats {
    gap: var(--space-4);
  }

  .lmv-stat__label {
    font-size: 0.65rem;
  }

  .lmv-hero__actions,
  .lmv-final-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .lmv-btn {
    width: 100%;
  }
}

/* --------------------------------------------------------------------------
   38. OFFERTE PAGE (page-offerte.php)
   -------------------------------------------------------------------------- */

.lof-page {
  overflow: hidden;
  background: var(--color-bg);
}

.lof-page .container {
  max-width: var(--container-max);
}

.lof-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  line-height: 1.4;
  text-transform: uppercase;
}

.lof-kicker::before {
  content: "↳ ";
}

.lof-kicker--icon::before {
  content: none;
}

.lof-kicker svg {
  width: 0.875rem;
  height: 0.875rem;
  flex: 0 0 auto;
}

.lof-kicker--light {
  color: color-mix(in srgb, var(--color-white) 62%, transparent);
}

.lof-hero {
  padding: var(--space-10) 0 var(--space-12);
  background: var(--color-bg);
}

.lof-hero__grid {
  display: grid;
  gap: var(--space-8);
  align-items: end;
}

.lof-hero__copy {
  display: grid;
  gap: var(--space-6);
}

.lof-hero__title,
.lof-section-title,
.lof-cta h2 {
  margin: 0;
  color: var(--color-dark);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.055em;
}

.lof-hero__title {
  max-width: 48rem;
  font-size: clamp(2.5rem, 7vw, 5.75rem);
  line-height: 0.95;
}

.lof-hero__title span,
.lof-section-title span,
.lof-cta h2 span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: var(--font-weight-medium);
}

.lof-hero__text {
  max-width: 40rem;
  margin: 0;
  color: var(--color-text-muted);
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
  line-height: 1.7;
}

.lof-hero__badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.lof-soft-badge {
  display: inline-flex;
  min-height: 2.25rem;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-bg-alt) 72%, var(--color-surface));
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}

.lof-soft-badge--danger {
  background: color-mix(in srgb, var(--color-sale) 10%, var(--color-surface));
  color: var(--color-sale);
}

.lof-soft-badge svg {
  width: 0.9rem;
  height: 0.9rem;
}

.lof-featured-card,
.lof-offer-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lof-discount-badge {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  z-index: 2;
  display: inline-flex;
  min-height: 2rem;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-sale);
  color: var(--color-white);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lof-discount-badge svg {
  width: 0.875rem;
  height: 0.875rem;
}

.lof-featured-card__media,
.lof-offer-card__media {
  display: block;
  overflow: hidden;
  background: var(--color-bg-alt);
}

.lof-featured-card__media {
  aspect-ratio: 4 / 3;
}

.lof-offer-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
}

.lof-featured-card img,
.lof-offer-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.lof-offer-card:hover img {
  transform: scale(1.05);
}

.lof-featured-card__body {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5);
}

.lof-card-kicker {
  color: var(--color-primary);
  font-size: 0.625rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.lof-featured-card h2,
.lof-offer-card h3 {
  margin: 0;
  color: var(--color-dark);
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
}

.lof-featured-card h2 {
  font-size: var(--font-size-lg);
}

.lof-featured-card a,
.lof-offer-card a {
  color: inherit;
  text-decoration: none;
}

.lof-price-row,
.lof-card-bottom {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-3);
}

.lof-old-price {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  line-height: 1.4;
  text-decoration: line-through;
  font-variant-numeric: tabular-nums;
}

.lof-price-from {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  line-height: 1.4;
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.lof-price {
  color: var(--color-dark);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.lof-price--sm {
  font-size: var(--font-size-xl);
}

.lof-cart-btn {
  display: inline-flex;
  min-height: 2.5rem;
  align-items: center;
  justify-content: center;
  padding: 0 var(--space-4);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: transform var(--transition), opacity var(--transition);
}

.lof-cart-btn:hover {
  color: var(--color-white);
  transform: translateY(-1px);
}

.lof-cart-btn:disabled {
  cursor: wait;
  opacity: 0.75;
  transform: none;
}

.lof-cart-btn--sm {
  min-height: 2.25rem;
  padding-inline: var(--space-3);
  font-size: var(--font-size-xs);
}

.lof-grid-section {
  padding: var(--space-12) 0 var(--space-16);
  border-block: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg-alt) 55%, var(--color-bg));
}

.lof-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.lof-section-title {
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.05;
}

.lof-offer-grid {
  display: grid;
  gap: var(--space-4);
}

.lof-offer-card {
  display: flex;
  min-width: 0;
  flex-direction: column;
}

.lof-offer-card__discount,
.lof-offer-card__badge {
  position: absolute;
  z-index: 2;
  top: var(--space-3);
  display: inline-flex;
  min-height: 1.65rem;
  align-items: center;
  border-radius: var(--radius-full);
  font-weight: var(--font-weight-bold);
}

.lof-offer-card__discount {
  left: var(--space-3);
  padding: 0 var(--space-3);
  background: var(--color-sale);
  color: var(--color-white);
  font-size: var(--font-size-xs);
}

.lof-offer-card__badge {
  right: var(--space-3);
  padding: 0 var(--space-2);
  background: var(--color-dark);
  color: var(--color-white);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lof-offer-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
}

.lof-offer-card h3 {
  flex: 1;
  font-size: var(--font-size-base);
}

.lof-empty {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-8);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  color: var(--color-text-muted);
  text-align: center;
}

.lof-empty strong {
  color: var(--color-dark);
}

.lof-cta {
  padding: var(--space-16) 0 var(--space-20);
  background: var(--color-bg);
}

.lof-cta__box {
  display: grid;
  gap: var(--space-6);
  align-items: center;
  padding: var(--space-8);
  border-radius: 1.5rem;
  background: var(--color-dark);
  color: var(--color-white);
}

.lof-cta h2 {
  color: var(--color-white);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
}

.lof-cta h2 span {
  color: color-mix(in srgb, var(--color-white) 88%, var(--color-primary));
}

.lof-cta p {
  max-width: 28rem;
  margin: var(--space-3) 0 0;
  color: color-mix(in srgb, var(--color-white) 70%, transparent);
  line-height: 1.65;
}

.lof-cta__btn {
  display: inline-flex;
  min-height: 3rem;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  justify-self: start;
  padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  background: var(--color-white);
  color: var(--color-dark);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
  transition: transform var(--transition);
}

.lof-cta__btn:hover {
  color: var(--color-dark);
  transform: translateY(-1px);
}

.lof-extra {
  padding: 0 0 var(--space-16);
}

@media (min-width: 640px) {
  .lof-offer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .lof-hero {
    padding: var(--space-14) 0 var(--space-16);
  }

  .lof-hero__grid {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: var(--space-12);
  }

  .lof-offer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lof-cta__box {
    grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
    padding: var(--space-14);
  }

  .lof-cta__btn {
    justify-self: end;
  }
}

@media (max-width: 767px) {
  .lof-price-row,
  .lof-card-bottom {
    align-items: stretch;
    flex-direction: column;
  }

  .lof-cart-btn,
  .lof-cta__btn {
    width: 100%;
  }
}

/* --------------------------------------------------------------------------
   39. AREA CLIENTI PAGE (page-area-clienti.php)
   -------------------------------------------------------------------------- */

/* Fix: neutralize WP error-page styles if injected at runtime */
body#error-page {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.lac-page {
  /* overflow: clip non crea uno scroll-container → position:sticky nella sidebar funziona,
     e l'overflow-x: auto del nav mobile rimane scrollabile su iOS. */
  overflow: clip;
  background: var(--color-bg);
}

/* Fallback per browser che non supportano overflow:clip (Safari < 15.4). */
@supports not (overflow: clip) {
  .lac-page {
    overflow: hidden;
  }
}

.lac-page .container {
  max-width: 100%;
}

.lac-hero {
  padding: var(--space-6) 0 var(--space-5);
  background: var(--color-bg);
}

.lac-hero__top {
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.lac-eyebrow {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lac-hero__row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.lac-title {
  margin: 0;
  color: var(--color-dark);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  letter-spacing: -0.05em;
}

.lac-title span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: var(--font-weight-medium);
}

.lac-logout,
.lac-outline-link,
.lac-primary-link,
.lac-small-btn,
.lac-ghost-link,
.lac-cta-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 2.5rem;
  padding: 0 var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  line-height: 1;
  text-decoration: none;
  transition: transform var(--transition), background-color var(--transition), color var(--transition), border-color var(--transition);
}

.lac-logout,
.lac-outline-link {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-dark);
}

.lac-logout:hover,
.lac-outline-link:hover {
  border-color: var(--color-dark);
  background: var(--color-dark);
  color: var(--color-white);
}

.lac-logout svg {
  width: 1rem;
  height: 1rem;
}

.lac-primary-link,
.lac-small-btn {
  border: 0;
  background: var(--color-primary);
  color: var(--color-white);
}

.lac-primary-link:hover,
.lac-small-btn:hover {
  color: var(--color-white);
  transform: translateY(-1px);
}

.lac-small-btn {
  min-height: 2.25rem;
  white-space: nowrap;
  cursor: pointer;
}

.lac-small-btn:disabled {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.lac-ghost-link,
.lac-detail-link,
.lac-text-link {
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
}

.lac-text-link {
  border: 0;
  background: transparent;
  cursor: pointer;
}

.lac-shell--login {
  padding: 0 0 var(--space-16);
}

.lac-login-grid {
  display: grid;
  gap: var(--space-8);
  align-items: start;
}

.lac-login-copy {
  display: grid;
  gap: var(--space-4);
}

.lac-kicker {
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lac-kicker::before {
  content: "↳ ";
}

.lac-login-copy h2 {
  max-width: 34rem;
  margin: 0;
  color: var(--color-dark);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.lac-login-copy p {
  max-width: 34rem;
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-lg);
  line-height: 1.7;
}

.lac-login-card,
.lac-card,
.lac-stat-card,
.lac-nav,
.lac-quick-card,
.lac-address-card,
.lac-reorder-list {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lac-login-card {
  padding: var(--space-6);
}

.lac-login-card .woocommerce,
.lac-login-card .woocommerce-form {
  margin: 0;
}

.lac-layout {
  display: grid;
  gap: var(--space-8);
  padding-bottom: var(--space-16);
}

.lac-nav {
  display: grid;
  gap: 0;
  padding: var(--space-3) var(--space-2);
}

.lac-nav__group {
  display: block;
  padding: var(--space-4) var(--space-3) var(--space-1);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  user-select: none;
}
.lac-nav__group:first-child { padding-top: var(--space-1); }

.lac-nav__divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-2) var(--space-3);
}

.lac-nav__item {
  display: flex;
  width: 100%;
  min-height: 3rem;
  align-items: center;
  gap: var(--space-3);
  padding: 0 var(--space-4);
  border: 0;
  border-radius: var(--radius-lg);
  background: transparent;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-align: left;
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition);
}

.lac-nav__item:hover {
  background: color-mix(in srgb, var(--color-bg-alt) 65%, var(--color-surface));
}

.lac-nav__item.is-active,
.lac-nav__item.lac-nav__item--active {
  background: var(--color-primary);
  color: var(--color-white);
}

.lac-nav__icon {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
}

.lac-nav__icon svg {
  width: 100%;
  height: 100%;
}

.lac-chevron {
  margin-left: auto;
  opacity: 0.35;
  font-size: var(--font-size-xl);
  line-height: 1;
}

.lac-nav__item.is-active .lac-chevron {
  opacity: 1;
}

.lac-content {
  min-width: 0;
}

.lac-panel {
  display: grid;
  gap: var(--space-6);
}

.lac-panel[hidden] {
  display: none;
}

.lac-stat-grid {
  display: grid;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.lac-stat-card {
  padding: var(--space-5);
}

.lac-stat-card p,
.lac-card > p,
.lac-quick-card p {
  margin: 0;
  color: var(--color-text-muted);
}

/* ── Riga superiore: label sinistra, icona destra ─────────────────── */
.lac-stat-card__top {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

/* ── Label in alto ────────────────────────────────────────────────── */
.lac-stat-card__label {
  margin: 0 !important;
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  line-height: 1.4;
}

/* ── Icona piccola, top-right ─────────────────────────────────────── */
.lac-stat-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(46, 125, 91, .12);
  color: #2e7d5b;
}
.lac-stat-card__icon svg {
  display: block;
  width: 1rem;
  height: 1rem;
  max-width: none;
  flex-shrink: 0;
  color: inherit;
}
.lac-stat-card__icon--blue {
  background: rgba(37, 99, 235, .1);
  color: #2563eb;
}
.lac-stat-card__icon--gold {
  background: rgba(201, 162, 39, .12);
  color: #b8860b;
}

/* ── Numero grande in basso ───────────────────────────────────────── */
.lac-stat-card__num {
  display: block;
  font-size: clamp(1.625rem, 3vw, 2.25rem);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  letter-spacing: -0.04em;
  line-height: 1;
}

/* Legacy (non-BEM) — mantieni per retrocompatibilità */
.lac-stat-card strong {
  display: block;
  margin-top: var(--space-1);
  color: var(--color-dark);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  letter-spacing: -0.04em;
}

.lac-card {
  overflow: hidden;
  padding: var(--space-6);
}

.lac-card--table {
  padding: 0;
}

.lac-card__head,
.lac-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.lac-card__head {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.lac-card h2,
.lac-card__head h2,
.lac-panel-head h2,
.lac-quick-card h3 {
  margin: 0;
  color: var(--color-dark);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: 1.25;
}

.lac-quick-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: color-mix(in srgb, var(--color-bg-alt) 55%, var(--color-surface));
}

.lac-quick-card p {
  margin-top: var(--space-1);
  font-size: var(--font-size-sm);
}

.lac-table-wrap {
  width: 100%;
  overflow-x: auto;
}

.lac-table {
  width: 100%;
  border-collapse: collapse;
}

.lac-table th {
  padding: var(--space-3) var(--space-6);
  background: color-mix(in srgb, var(--color-bg-alt) 65%, var(--color-surface));
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
}

.lac-table td {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  vertical-align: middle;
  white-space: nowrap;
}

.lac-table tbody tr:hover {
  background: color-mix(in srgb, var(--color-bg-alt) 35%, transparent);
}

.lac-table code {
  color: var(--color-dark);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: var(--font-size-sm);
}

.lac-table .is-right {
  text-align: right;
}

.lac-status {
  display: inline-flex;
  min-height: 1.5rem;
  align-items: center;
  padding: 0 var(--space-2);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
}

.lac-status--processing,
.lac-status--on-hold,
.lac-status--pending {
  background: color-mix(in srgb, #f59e0b 12%, var(--color-surface));
  color: #a15c00;
}

.lac-status--cancelled,
.lac-status--failed,
.lac-status--refunded {
  background: color-mix(in srgb, var(--color-sale) 10%, var(--color-surface));
  color: var(--color-sale);
}

.lac-reorder-list {
  overflow: hidden;
}

.lac-reorder-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.lac-reorder-item:first-child {
  border-top: 0;
}

.lac-reorder-item img {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius);
  background: var(--color-bg-alt);
  object-fit: cover;
}

.lac-reorder-item__body {
  min-width: 0;
}

.lac-reorder-item__body strong {
  display: block;
  overflow: hidden;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lac-reorder-item__body span {
  display: block;
  margin-top: var(--space-1);
  color: var(--color-text-muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: var(--font-size-xs);
}

.lac-reorder-item__price {
  display: none;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  white-space: nowrap;
}

.lac-panel-head {
  margin-bottom: var(--space-4);
}

.lac-address-grid {
  display: grid;
  gap: var(--space-4);
}

.lac-address-card {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-5);
}

.lac-address-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.lac-address-card__top span {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lac-address-card__top em {
  padding: 0.15rem var(--space-2);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
  font-size: 0.625rem;
  font-style: normal;
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}

.lac-address-card strong {
  color: var(--color-dark);
  font-size: var(--font-size-base);
}

.lac-address-card p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.lac-address-card a {
  margin-top: var(--space-2);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
}

.lac-account-grid {
  display: grid;
  gap: var(--space-6);
}

.lac-account-card {
  min-width: 0;
}

.lac-field-grid {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.lac-field {
  display: grid;
  gap: var(--space-2);
}

.lac-field span {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lac-field input {
  width: 100%;
  min-height: 2.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-surface);
  color: var(--color-dark);
  padding: 0 var(--space-4);
  font: inherit;
}

.lac-account-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-6);
}

.lac-field input:not([readonly]) {
  border-color: var(--color-primary);
  background: var(--color-surface);
  outline: none;
}

.lac-field input:not([readonly]):focus {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}

.lac-field--checkbox {
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
}

.lac-field--checkbox input[type="checkbox"] {
  width: 1.125rem;
  height: 1.125rem;
  min-height: unset;
  flex-shrink: 0;
  accent-color: var(--color-primary);
  cursor: pointer;
}

.lac-field--checkbox span {
  text-transform: none;
  letter-spacing: 0;
  font-size: var(--font-size-sm);
  cursor: pointer;
}

.lac-save-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0 var(--space-5);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
}

.lac-save-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.lac-save-btn.is-saved {
  background: #16a34a;
}

.lac-save-notice {
  font-size: var(--font-size-xs);
  color: #16a34a;
  margin-left: var(--space-2);
}

@media (min-width: 640px) {
  .lac-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lac-address-grid,
  .lac-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lac-account-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lac-account-grid > .lac-account-card:last-child {
    grid-column: 1 / -1;
  }

  /* Con --split le card rimangono affiancate (nessuna va full-width) */
  .lac-account-grid--split > .lac-account-card:last-child {
    grid-column: auto;
  }

  .lac-reorder-item {
    grid-template-columns: auto minmax(0, 1fr) auto auto;
  }

  .lac-reorder-item__price {
    display: inline;
  }
}

/* ── Extra: fieldset in form-edit-account + muted btn ─────────────── */
.lac-fieldset {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-5);
}

.lac-fieldset legend {
  padding: 0 var(--space-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: var(--color-text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lac-small-btn--muted {
  background: var(--color-surface);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  pointer-events: none;
  opacity: .65;
}

.lac-reorder-item__sku,
.lac-reorder-item__times {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.lac-address-edit-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  margin-top: var(--space-2);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
}
.lac-address-edit-link:hover {
  text-decoration: underline;
}

@media (min-width: 1024px) {
  .lac-hero {
    padding-top: var(--space-10);
    padding-bottom: var(--space-6);
  }

  .lac-layout {
    grid-template-columns: minmax(0, 3fr) minmax(0, 9fr);
  }

  .lac-sidebar {
    position: sticky;
    top: 6rem;
    align-self: start;
  }

  .lac-login-grid {
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: var(--space-12);
  }
}

/* ── Accordion nav styles (all breakpoints) ── */
.lac-nav__section {
  border-bottom: 1px solid var(--color-border);
}
.lac-nav__section:last-child { border-bottom: none; }

.lac-nav__group--toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  padding: var(--space-3) var(--space-3) var(--space-1);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  user-select: none;
}
.lac-nav__group--toggle::-webkit-details-marker { display: none; }

.lac-nav__group-chevron {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s;
  margin-top: -4px;
  flex-shrink: 0;
}
details[open] .lac-nav__group-chevron {
  transform: rotate(-135deg);
  margin-top: 4px;
}

.lac-nav__items {
  padding: var(--space-1) var(--space-2) var(--space-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Desktop/tablet: accordion disabilitato — tutto sempre visibile */
@media (min-width: 768px) {
  .lac-nav__section {
    border-bottom: none;
    display: contents;
  }
  .lac-nav__group--toggle {
    cursor: default;
    pointer-events: none;
    display: block;
    justify-content: unset;
  }
  .lac-nav__group-chevron { display: none; }
  .lac-nav__items {
    display: contents;
  }
}

/* Mobile: accordion — nasconde items delle sezioni non aperte via JS che rimuove [open] */
@media (max-width: 767px) {
  .lac-nav__section:not([open]) > .lac-nav__items {
    display: none;
  }
  .lac-nav__section:not([open]) .lac-nav__group-chevron {
    transform: rotate(45deg);
    margin-top: -4px;
  }
  .lac-nav__section[open] .lac-nav__group-chevron {
    transform: rotate(-135deg);
    margin-top: 4px;
  }
}

@media (max-width: 767px) {
  .lac-nav {
    display: grid;
    gap: 0;
    padding: 0;
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .lac-nav__group--toggle {
    padding: 14px 16px;
    font-size: .65rem;
  }

  .lac-nav__items {
    padding: 0 8px 8px;
  }

  .lac-nav__item {
    min-height: 2.75rem;
    padding: 0 12px;
    border-radius: var(--radius-lg);
    font-size: .875rem;
  }

  .lac-nav__icon {
    width: 1rem;
    height: 1rem;
  }

  /* Layout: distanza tra la nav e il contenuto su mobile */
  .lac-layout {
    padding-top: var(--space-4);
    gap: var(--space-6);
  }

  /* Stat cards: 2 colonne su schermi > 440px, 1 colonna su < 440px */
  .lac-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* Stat card più compatte su mobile */
  .lac-stat-card {
    padding: var(--space-4);
  }

  .lac-stat-card__num {
    font-size: 1.75rem;
  }

  /* Hero più compatto su mobile */
  .lac-hero {
    padding-top: var(--space-5);
    padding-bottom: var(--space-4);
  }

  .lac-chevron,
  .lac-table .hide-sm,
  .lac-table .hide-md {
    display: none;
  }

  .lac-card__head,
  .lac-panel-head,
  .lac-quick-card {
    align-items: stretch;
    flex-direction: column;
  }

  .lac-primary-link,
  .lac-outline-link {
    width: 100%;
  }
}

/* Stat cards su schermi molto piccoli (< 440px): torna 1 colonna */
@media (max-width: 440px) {
  .lac-stat-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* --------------------------------------------------------------------------
   40. STORY USE-CASE PAGES (/trasloco /ecommerce /magazzino)
   -------------------------------------------------------------------------- */

.lst-page {
  overflow: hidden;
  background: var(--color-bg);
}

.lst-page .container {
  max-width: var(--container-max);
}

.lst-hero {
  padding: var(--space-10) 0 0;
  background: var(--color-bg);
}

.lst-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lst-breadcrumb a {
  color: var(--color-text-muted);
}

.lst-breadcrumb a:hover,
.lst-breadcrumb span:last-child {
  color: var(--color-dark);
}

.lst-hero__grid {
  display: grid;
  gap: var(--space-8);
  align-items: end;
}

.lst-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lst-kicker::before {
  content: "↳ ";
}

.lst-kicker--icon::before {
  content: none;
}

.lst-kicker svg {
  width: 0.875rem;
  height: 0.875rem;
}

.lst-kicker--light {
  color: color-mix(in srgb, var(--color-white) 60%, transparent);
}

.lst-hero__title,
.lst-section-title,
.lst-other__title {
  margin: 0;
  color: var(--color-dark);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.055em;
}

.lst-hero__title {
  font-size: clamp(2.5rem, 5.5vw, 4.5rem);
  line-height: 1.02;
}

.lst-hero__title span,
.lst-section-title span {
  color: var(--color-text-muted);
  font-style: italic;
  font-weight: var(--font-weight-medium);
}

.lst-hero__intro {
  max-width: 36rem;
  margin: var(--space-7) 0 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-lg);
  line-height: 1.65;
}

.lst-bullets {
  display: grid;
  gap: var(--space-3);
  margin: var(--space-7) 0 0;
  padding: 0;
  list-style: none;
}

.lst-bullets li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  color: var(--color-dark);
}

.lst-bullets span {
  display: grid;
  width: 1.25rem;
  height: 1.25rem;
  flex: 0 0 auto;
  margin-top: 0.15rem;
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 15%, var(--color-surface));
  color: var(--color-primary);
}

.lst-bullets svg {
  width: 0.75rem;
  height: 0.75rem;
}

.lst-hero__media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: var(--color-bg-alt);
}

.lst-hero__media img,
.lst-other-card img,
.lst-product-card__media img,
.lst-kit-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lst-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, color-mix(in srgb, var(--color-dark) 62%, transparent), transparent 58%);
}

.lst-hero__number {
  position: absolute;
  top: var(--space-5);
  left: var(--space-5);
  color: color-mix(in srgb, var(--color-white) 90%, transparent);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lst-shop {
  padding: var(--space-16) 0 var(--space-20);
}

.lst-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}

.lst-section-title {
  font-size: clamp(1.875rem, 3.5vw, 3rem);
  line-height: 1.05;
}

.lst-section-head p {
  max-width: 25rem;
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.7;
}

.lst-section-head strong {
  color: var(--color-dark);
}

.lst-mode-switch {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-10);
  gap: var(--space-1);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  padding: 0.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  box-shadow: 0 10px 26px color-mix(in srgb, var(--color-dark) 8%, transparent);
}

.lst-mode-switch__btn {
  display: inline-flex;
  min-height: 2.75rem;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  border: 0;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
  cursor: pointer;
}

.lst-mode-switch__btn.is-active {
  background: var(--color-dark);
  color: var(--color-white);
}

.lst-mode-switch__icon {
  display: inline-flex;
  color: currentColor;
}

.lst-mode-switch__btn em {
  padding: 0.15rem var(--space-2);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 88%, var(--color-white));
  color: var(--color-white);
  font-size: 0.625rem;
  font-style: normal;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-mode-panel[hidden] {
  display: none !important;
}

.lst-kit-grid {
  display: grid;
  gap: var(--space-6);
  align-items: start;
}

.lst-kit-card {
  overflow: hidden;
  border-radius: 1.5rem;
  background: var(--color-dark);
  color: var(--color-white);
  padding: var(--space-7);
  box-shadow: var(--shadow-lg);
}

.lst-kit-card h3 {
  margin: 0;
  font-size: clamp(1.875rem, 3vw, 2.25rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.lst-kit-card p {
  margin: var(--space-4) 0 0;
  color: color-mix(in srgb, var(--color-white) 75%, transparent);
  line-height: 1.7;
}

.lst-kit-qty {
  margin-top: var(--space-7);
}

.lst-kit-qty label {
  display: block;
  margin-bottom: var(--space-3);
  color: color-mix(in srgb, var(--color-white) 58%, transparent);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.lst-kit-qty__row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.lst-kit-qty__controls {
  display: inline-flex;
  min-height: 2.4rem;
  align-items: center;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-white) 18%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-white) 7%, transparent);
}

.lst-kit-qty__btn,
.lst-kit-qty__input,
.lst-kit-qty__quick button {
  border: 0;
  color: var(--color-white);
  font: inherit;
}

.lst-kit-qty__btn {
  width: 2.35rem;
  height: 2.35rem;
  background: transparent;
  color: color-mix(in srgb, var(--color-white) 55%, transparent);
  cursor: pointer;
}

.lst-kit-qty__input {
  width: 3.2rem;
  height: 2.35rem;
  padding: 0;
  background: transparent;
  font-weight: var(--font-weight-bold);
  text-align: center;
  appearance: textfield;
}

.lst-kit-qty__input::-webkit-outer-spin-button,
.lst-kit-qty__input::-webkit-inner-spin-button {
  margin: 0;
  appearance: none;
}

.lst-kit-qty__quick {
  display: inline-flex;
  gap: var(--space-2);
}

.lst-kit-qty__quick button {
  min-width: 2.4rem;
  height: 2.4rem;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-white) 10%, transparent);
  color: color-mix(in srgb, var(--color-white) 72%, transparent);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
}

.lst-kit-qty__quick button.is-active {
  background: var(--color-white);
  color: var(--color-dark);
}

.lst-kit-price {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-7);
}

.lst-kit-price strong {
  font-size: clamp(2rem, 3.5vw, 2.25rem);
  font-weight: var(--font-weight-bold);
  line-height: 1;
}

.lst-kit-price .amount,
.lst-kit-item__price .amount,
.lst-product-card__bottom .amount {
  display: inline;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  text-transform: none;
  white-space: nowrap;
}

.lst-kit-price .woocommerce-Price-currencySymbol,
.lst-kit-item__price .woocommerce-Price-currencySymbol,
.lst-product-card__bottom .woocommerce-Price-currencySymbol {
  display: inline;
  margin-left: 0.15em;
}

.lst-kit-price del {
  color: color-mix(in srgb, var(--color-white) 50%, transparent);
  font-size: var(--font-size-lg);
}

.lst-kit-price__saving {
  display: inline-flex;
  min-height: 1.6rem;
  align-items: center;
  margin-left: auto;
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: 0.6875rem;
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-kit-btn,
.lst-primary-btn,
.lst-outline-btn,
.lst-add-btn {
  display: inline-flex;
  min-height: 3rem;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
  transition: transform var(--transition), background-color var(--transition), color var(--transition), border-color var(--transition);
}

.lst-kit-btn {
  width: 100%;
  margin-top: var(--space-7);
  border: 0;
  background: var(--color-white);
  color: var(--color-dark);
  cursor: pointer;
}

.lst-kit-btn:hover,
.lst-primary-btn:hover,
.lst-add-btn:hover {
  transform: translateY(-1px);
}

.lst-kit-btn:disabled,
.lst-add-btn:disabled {
  cursor: wait;
  opacity: 0.75;
  transform: none;
}

.lst-kit-link {
  display: block;
  width: 100%;
  border: 0;
  background: transparent;
  margin-top: var(--space-3);
  color: color-mix(in srgb, var(--color-white) 60%, transparent);
  font-size: var(--font-size-sm);
  text-align: center;
  text-decoration: underline;
  text-underline-offset: 4px;
  cursor: pointer;
}

.lst-delivery-note {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0 var(--space-3);
  align-items: center;
  margin-top: var(--space-5);
  padding: var(--space-3) var(--space-4);
  border: 1px solid color-mix(in srgb, var(--color-white) 16%, transparent);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-white) 8%, transparent);
}

.lst-delivery-note > span {
  display: grid;
  width: 2rem;
  height: 2rem;
  grid-row: 1 / span 2;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
}

.lst-delivery-note strong {
  color: var(--color-white);
  font-size: var(--font-size-base);
  line-height: 1.15;
}

.lst-delivery-note small {
  color: color-mix(in srgb, var(--color-white) 62%, transparent);
  font-size: var(--font-size-xs);
  line-height: 1.2;
  order: -1;
}

.lst-delivery-note--single {
  grid-column: 1 / -1;
  justify-self: center;
  margin: 0 0 var(--space-4);
  padding: 0.72rem 1rem;
  border-radius: var(--radius-full);
  border-color: var(--color-border);
  background: var(--color-surface);
}

.lst-delivery-note--single > span {
  background: color-mix(in srgb, var(--color-primary) 13%, var(--color-surface));
  color: var(--color-primary);
}

.lst-delivery-note--single strong {
  color: var(--color-dark);
}

.lst-delivery-note--single small {
  color: var(--color-text-muted);
}

.lst-page--trasloco .lst-delivery-note--single {
  display: flex;
  gap: var(--space-2);
}

.lst-page--trasloco .lst-delivery-note--single > span {
  width: 1.75rem;
  height: 1.75rem;
}

.lst-empty-kit {
  max-width: 46rem;
  margin: var(--space-8) auto 0;
  padding: var(--space-8);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lst-empty-kit h3 {
  margin: 0;
  color: var(--color-dark);
  font-size: var(--font-size-2xl);
}

.lst-empty-kit p {
  margin: var(--space-3) 0 0;
  color: var(--color-text-muted);
  line-height: 1.7;
}

.lst-kit-list__title {
  margin-bottom: var(--space-5);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lst-kit-list ul {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.lst-kit-list li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  transition: border-color var(--transition);
}

.lst-kit-list li:hover {
  border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
}

.lst-kit-item__image {
  position: relative;
  display: block;
  width: 5rem;
  height: 5rem;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--color-bg-alt);
}

.lst-kit-item__image span {
  position: absolute;
  right: -0.15rem;
  bottom: -0.15rem;
  display: grid;
  min-width: 2rem;
  height: 2rem;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--color-dark);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
}

.lst-kit-item__body {
  min-width: 0;
}

.lst-kit-item__body div {
  color: var(--color-text-muted);
  font-size: 0.625rem;
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-kit-item__body h4 {
  margin: var(--space-1) 0 0;
  color: var(--color-dark);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  line-height: 1.25;
}

.lst-kit-item__body h4 a,
.lst-product-card h3 a {
  color: inherit;
  text-decoration: none;
}

.lst-kit-item__body p {
  overflow: hidden;
  margin: var(--space-1) 0 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lst-kit-item__body small {
  display: inline-flex;
  align-items: center;
  margin-top: var(--space-2);
  padding: 0.2rem var(--space-3);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));
  color: var(--color-primary);
  font-size: 0.6875rem;
  font-weight: var(--font-weight-semi);
}

.lst-kit-item__price {
  display: none;
  min-width: 7.25rem;
  text-align: right;
}

.lst-kit-item__price strong {
  display: block;
  color: var(--color-dark);
  font-weight: var(--font-weight-bold);
}

.lst-kit-item__price span {
  display: block;
  margin-top: var(--space-1);
  color: var(--color-text-muted);
  font-size: 0.625rem;
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-product-grid {
  display: grid;
  gap: var(--space-5);
  margin-top: 0;
}

.lst-product-card {
  display: flex;
  overflow: hidden;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.lst-product-card:hover {
  border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
  box-shadow: var(--shadow-lg);
}

.lst-product-card__media {
  position: relative;
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--color-bg-alt);
}

.lst-page--trasloco .lst-product-card__media,
.lst-page--trasloco .lst-kit-item__image {
  background: color-mix(in srgb, var(--color-white) 96%, var(--color-bg-alt));
}

.lst-page--trasloco .lst-product-card__media img,
.lst-page--trasloco .lst-kit-item__image img {
  object-fit: contain;
  padding: var(--space-3);
}

.lst-page--trasloco .lst-shop > .container {
  max-width: 80rem;
}

.lst-page--trasloco .lst-kit-grid {
  max-width: 75rem;
  margin: 0 auto;
}

.lst-page--trasloco .lst-kit-card {
  border-radius: 1.25rem;
  padding: 2.25rem;
  overflow: visible;
}

.lst-page--trasloco .lst-kit-card h3 {
  font-size: clamp(2rem, 3vw, 2.45rem);
}

.lst-page--trasloco .lst-kit-price strong {
  font-size: clamp(2.45rem, 4vw, 3rem);
}

.lst-page--trasloco .lst-kit-list li {
  min-height: 8.1rem;
  padding: 1rem 1.35rem 1rem 1rem;
  grid-template-columns: 6rem minmax(0, 1fr) auto;
}

.lst-page--trasloco .lst-kit-item__image {
  width: 5.9rem;
  height: 5.9rem;
}

.lst-page--trasloco .lst-kit-item__body h4 {
  max-width: 30rem;
  font-size: 1.125rem;
}

.lst-page--trasloco .lst-kit-item__price strong {
  font-size: 1.35rem;
}

.lst-page--trasloco .lst-product-grid {
  max-width: 76rem;
  margin-left: auto;
  margin-right: auto;
}

.lst-page--trasloco .lst-product-card {
  border-radius: 1rem;
}

.lst-page--trasloco .lst-product-card__media {
  aspect-ratio: 1 / 1.02;
  background: #fff;
}

.lst-page--trasloco .lst-product-card__media img {
  padding: 1.4rem;
}

.lst-page--trasloco .lst-product-card__body {
  padding: 1.25rem;
}

.lst-page--trasloco .lst-product-card h3 {
  font-size: 1.125rem;
  line-height: 1.22;
}

.lst-page--trasloco .lst-shop-actions {
  grid-column: 1 / -1;
}

.lst-product-card__media img {
  transition: transform 500ms ease;
}

.lst-product-card:hover .lst-product-card__media img {
  transform: scale(1.05);
}

.lst-product-card__media span,
.lst-product-card__media em {
  position: absolute;
  top: var(--space-3);
  display: inline-flex;
  min-height: 1.55rem;
  align-items: center;
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  font-size: 0.625rem;
  font-style: normal;
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-product-card__media span {
  left: var(--space-3);
  background: color-mix(in srgb, var(--color-white) 95%, transparent);
  color: var(--color-dark);
  backdrop-filter: blur(8px);
}

.lst-product-card__media em {
  right: var(--space-3);
  background: var(--color-primary);
  color: var(--color-white);
}

.lst-product-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: var(--space-4);
}

.lst-product-card h3 {
  margin: 0;
  color: var(--color-dark);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semi);
  line-height: 1.3;
}

.lst-product-card__body > p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: var(--space-2) 0 0;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  line-height: 1.55;
}

.lst-product-card__bottom {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: auto;
  padding-top: var(--space-4);
}

.lst-product-card__bottom span {
  display: block;
  color: var(--color-text-muted);
  font-size: 0.625rem;
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lst-product-card__bottom strong {
  display: block;
  color: var(--color-dark);
  font-size: var(--font-size-xl);
  line-height: 1.1;
}

.lst-add-btn {
  min-height: 2.35rem;
  padding: 0 var(--space-4);
  border: 0;
  background: var(--color-primary);
  color: var(--color-white);
  cursor: pointer;
  white-space: nowrap;
}

.lst-add-btn:hover {
  color: var(--color-white);
}

.lst-shop-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-top: var(--space-10);
}

.lst-primary-btn {
  padding: 0 var(--space-6);
  border: 1px solid var(--color-primary);
  background: var(--color-primary);
  color: var(--color-white);
}

.lst-primary-btn:hover {
  color: var(--color-white);
}

.lst-outline-btn {
  padding: 0 var(--space-6);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-dark);
}

.lst-outline-btn:hover {
  border-color: var(--color-dark);
  background: var(--color-dark);
  color: var(--color-white);
}

.lst-other {
  padding: var(--space-16) 0 var(--space-20);
  border-top: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg-alt) 45%, var(--color-bg));
}

.lst-other__title {
  font-size: clamp(1.875rem, 3.5vw, 3rem);
  line-height: 1.1;
}

.lst-other-grid {
  display: grid;
  gap: var(--space-5);
}

.lst-other-card {
  position: relative;
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: var(--color-bg-alt);
  color: var(--color-white);
}

.lst-other-card img {
  transition: transform 700ms ease;
}

.lst-other-card:hover img {
  transform: scale(1.05);
}

.lst-other-card__shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, color-mix(in srgb, var(--color-dark) 85%, transparent), color-mix(in srgb, var(--color-dark) 30%, transparent), transparent);
}

.lst-other-card__num {
  position: absolute;
  top: var(--space-5);
  left: var(--space-5);
  color: color-mix(in srgb, var(--color-white) 80%, transparent);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lst-other-card > span {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  display: grid;
  width: 2.5rem;
  height: 2.5rem;
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-white) 95%, transparent);
  color: var(--color-dark);
  transition: transform 300ms ease;
}

.lst-other-card:hover > span {
  transform: rotate(45deg);
}

.lst-other-card__copy {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: var(--space-6);
}

.lst-other-card__copy h3 {
  margin: 0;
  color: var(--color-white);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.1;
}

.lst-other-card__copy p {
  overflow: hidden;
  margin: var(--space-1) 0 0;
  color: color-mix(in srgb, var(--color-white) 80%, transparent);
  font-size: var(--font-size-sm);
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (min-width: 640px) {
  .lst-kit-list li {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .lst-kit-item__price {
    display: block;
  }

  .lst-product-grid,
  .lst-other-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .lst-hero {
    padding-top: var(--space-14);
  }

  .lst-hero__grid {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: var(--space-12);
  }

  .lst-kit-grid {
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: var(--space-8);
  }

  .lst-page--trasloco .lst-kit-grid {
    grid-template-columns: minmax(25rem, 30.5rem) minmax(0, 44rem);
  }

  .lst-kit-card {
    position: sticky;
    top: 6rem;
    padding: var(--space-9);
  }

  .lst-product-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-6);
  }
}

@media (max-width: 767px) {
  .lst-page--trasloco .lst-kit-list li {
    min-height: 0;
    grid-template-columns: auto minmax(0, 1fr);
  }

  .lst-page--trasloco .lst-kit-item__price {
    display: none;
  }

  .lst-page--trasloco .lst-kit-card {
    padding: var(--space-6);
  }

  .lst-page--trasloco .lst-delivery-note--single {
    justify-content: center;
    flex-wrap: wrap;
  }

  .lst-section-head,
  .lst-product-card__bottom,
  .lst-shop-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .lst-mode-switch {
    justify-content: stretch;
    width: 100%;
  }

  .lst-mode-switch__btn,
  .lst-primary-btn,
  .lst-outline-btn,
  .lst-add-btn {
    width: 100%;
  }
}

/* --------------------------------------------------------------------------
   41. NEGOZIO PAGE (/negozio, Lovable /prodotti)
   -------------------------------------------------------------------------- */

.lnp-page {
  overflow: hidden;
  background: var(--color-bg);
}

.lnp-page .container {
  max-width: var(--container-max);
}

.lnp-hero {
  padding: var(--space-10) 0;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
}

.lnp-kicker {
  margin-bottom: var(--space-5);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.lnp-kicker::before {
  content: "↳ ";
}

.lnp-hero__grid {
  display: grid;
  gap: var(--space-6);
  align-items: end;
}

.lnp-hero__title {
  margin: 0;
  color: var(--color-dark);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: var(--font-weight-bold);
  line-height: 0.95;
  letter-spacing: -0.055em;
}

.lnp-hero__title span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: var(--font-weight-medium);
}

.lnp-search {
  position: relative;
}

.lnp-search svg {
  position: absolute;
  left: var(--space-4);
  top: 50%;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
  transform: translateY(-50%);
}

.lnp-search input {
  width: 100%;
  min-height: 3rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--color-dark);
  font: inherit;
  padding: 0 var(--space-4) 0 2.75rem;
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.lnp-search input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.lnp-filters {
  position: sticky;
  top: var(--header-h);
  z-index: 30;
  border-bottom: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg) 90%, transparent);
  backdrop-filter: blur(12px);
}

/* Fade mask sui lati per indicare scroll */
.lnp-filters::before,
.lnp-filters::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 3rem;
  pointer-events: none;
  z-index: 2;
}
.lnp-filters::before {
  left: 0;
  background: linear-gradient(90deg, var(--color-bg) 0%, transparent 100%);
}
.lnp-filters::after {
  right: 0;
  background: linear-gradient(270deg, var(--color-bg) 0%, transparent 100%);
}

.lnp-filters__inner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  overflow-x: auto;
  padding-block: var(--space-3);
  padding-inline: var(--space-4);
  scrollbar-width: none;
  /* Ensure pills are not clipped */
  min-width: 0;
}

.lnp-filters__inner::-webkit-scrollbar {
  display: none;
}

.lnp-filter-pill {
  flex: 0 0 auto;
  min-height: 2.25rem;
  padding: 0 var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  cursor: pointer;
  transition: border-color var(--transition), background-color var(--transition), color var(--transition);
}

.lnp-filter-pill:hover {
  border-color: color-mix(in srgb, var(--color-dark) 40%, var(--color-border));
}

.lnp-filter-pill.is-active {
  border-color: var(--color-dark);
  background: var(--color-dark);
  color: var(--color-white);
}

.lnp-sort {
  display: none;
  align-items: center;
  gap: var(--space-2);
  margin-left: auto;
  flex: 0 0 auto;
}

.lnp-sort svg {
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
}

.lnp-sort select {
  min-height: 2.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--color-dark);
  font: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  padding: 0 var(--space-3);
  outline: none;
}

.lnp-grid-section {
  padding: var(--space-10) 0 var(--space-14);
  background: var(--color-bg);
}

.lnp-count {
  margin-bottom: var(--space-6);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.lnp-count span {
  color: var(--color-dark);
  font-weight: var(--font-weight-semi);
}

.lnp-empty {
  padding: var(--space-20) var(--space-4);
  color: var(--color-text-muted);
  text-align: center;
}

.lnp-product-grid {
  display: grid;
  gap: var(--space-4);
}

.lnp-product-card {
  display: flex;
  overflow: hidden;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lnp-product-card__media {
  position: relative;
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--color-bg-alt);
}

.lnp-product-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.lnp-product-card:hover .lnp-product-card__media img {
  transform: scale(1.05);
}

.lnp-badge {
  position: absolute;
  top: var(--space-3);
  display: inline-flex;
  min-height: 1.6rem;
  align-items: center;
  padding: 0 var(--space-3);
  border-radius: var(--radius-full);
  font-size: 0.625rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lnp-badge--primary {
  left: var(--space-3);
  background: var(--color-primary);
  color: var(--color-white);
}

.lnp-badge--dark {
  right: var(--space-3);
  background: var(--color-dark);
  color: var(--color-white);
}

.lnp-badge--sale {
  left: var(--space-3);
  background: var(--color-sale);
  color: var(--color-white);
  font-size: 0.7rem;
}

.lnp-product-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
}

.lnp-product-card__main {
  flex: 1;
}

.lnp-product-card__title {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: var(--color-dark);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
  line-height: 1.35;
  text-decoration: none;
}

/* Quando c'è una query attiva, mostra il titolo completo
   così l'utente vede perché la card è stata trovata. */
.lnp-page--searching .lnp-product-card__title {
  display: block;
  overflow: visible;
  -webkit-line-clamp: unset;
}

.lnp-product-card__title:hover {
  color: var(--color-primary);
}

.lnp-rating {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-variant-numeric: tabular-nums;
}

.lnp-rating svg {
  width: 0.75rem;
  height: 0.75rem;
  color: var(--color-primary);
}

.lnp-product-card__bottom {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-2);
}

.lnp-price-label {
  color: var(--color-text-muted);
  font-size: 0.625rem;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lnp-price {
  color: var(--color-dark);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  line-height: 1;
}

.lnp-price-block {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.lnp-price--sale {
  color: var(--color-sale);
}

.lnp-price-regular {
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-decoration: line-through;
  line-height: 1;
}

.lnp-product-card__body--sale {
  border-top: 2px solid color-mix(in srgb, var(--color-sale) 20%, transparent);
}

.lnp-buy-btn {
  display: inline-flex;
  min-height: 2.25rem;
  align-items: center;
  justify-content: center;
  padding: 0 var(--space-3);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: transform var(--transition), opacity var(--transition);
}

.lnp-buy-btn:hover {
  color: var(--color-white);
  transform: translateY(-1px);
}

.lnp-buy-btn:disabled {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.lnp-cta {
  padding: var(--space-16) 0;
  border-top: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-bg-alt) 45%, var(--color-bg));
}

.lnp-cta__inner {
  max-width: 42rem;
  text-align: center;
}

.lnp-cta h2 {
  margin: 0 0 var(--space-4);
  color: var(--color-dark);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-weight-bold);
  line-height: 1.1;
  letter-spacing: -0.04em;
}

.lnp-cta p {
  margin: 0 0 var(--space-6);
  color: var(--color-text-muted);
  line-height: 1.7;
}

.lnp-cta__btn {
  display: inline-flex;
  min-height: 3rem;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: var(--font-weight-semi);
  text-decoration: none;
}

.lnp-cta__btn:hover {
  color: var(--color-white);
}

.lnp-extra {
  padding: 0 0 var(--space-16);
}

@media (min-width: 640px) {
  .lnp-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-6);
  }
}

@media (min-width: 768px) {
  .lnp-sort {
    display: flex;
  }
}

@media (min-width: 1024px) {
  .lnp-hero {
    padding: var(--space-14) 0;
  }

  .lnp-hero__grid {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  }

  .lnp-product-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  .lnp-product-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* --------------------------------------------------------------------------
   Toast notification (usato da quick-order-page.js e altri)
   -------------------------------------------------------------------------- */

.vt2-toast-container {
  position: fixed;
  top: 1.25rem;
  right: 1.25rem;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
}

.vt2-toast {
  background: var(--color-dark);
  color: #fff;
  padding: 0.85rem 1.1rem;
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  max-width: 22rem;
  pointer-events: auto;
  animation: lq-toast-in 0.25s ease forwards;
}

.vt2-toast a {
  color: inherit;
  text-decoration: underline;
  white-space: nowrap;
}

.vt2-toast--success { border-left: 3px solid #22c55e; }
.vt2-toast--error   { border-left: 3px solid #ef4444; }

.vt2-toast.is-leaving {
  animation: lq-toast-out 0.25s ease forwards;
}

@keyframes lq-toast-in {
  from { opacity: 0; transform: translateX(1.25rem); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes lq-toast-out {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(1.25rem); }
}

@media (max-width: 480px) {
  .vt2-toast-container {
    top: auto;
    bottom: 1rem;
    right: 1rem;
    left: 1rem;
  }
  .vt2-toast { max-width: 100%; }
}
/* --------------------------------------------------------------------------
   42. PRIVACY PAGE (/privacy, Lovable)
   -------------------------------------------------------------------------- */

.lpr-page {
  background: var(--color-background);
  color: var(--color-dark);
}

.lpr-hero {
  padding: var(--space-10) 0 var(--space-12);
}

.lpr-kicker {
  margin-bottom: var(--space-6);
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lpr-hero__grid {
  display: grid;
  gap: var(--space-8);
  align-items: end;
}

.lpr-hero__copy {
  max-width: 46rem;
}

.lpr-hero__title {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2.75rem, 8vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 0.92;
}

.lpr-hero__title span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: 500;
}

.lpr-hero__copy p {
  max-width: 38rem;
  margin: var(--space-6) 0 0;
  color: var(--color-muted);
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
  line-height: 1.75;
}

.lpr-update {
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface-muted);
  color: var(--color-muted);
  font-size: var(--font-size-sm);
}

.lpr-update p {
  margin: 0 0 var(--space-1);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-weight: 700;
}

.lpr-update strong {
  font-weight: 500;
}

.lpr-principles {
  padding: 0 0 var(--space-14);
}

.lpr-principles__grid {
  display: grid;
  gap: var(--space-4);
}

.lpr-principle-card,
.lpr-detail-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}

.lpr-principle-card {
  padding: var(--space-7);
}

.lpr-icon {
  display: grid;
  width: 3rem;
  height: 3rem;
  margin-bottom: var(--space-5);
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  color: var(--color-primary);
}

.lpr-icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

.lpr-principle-card h2 {
  margin: 0 0 var(--space-2);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.lpr-principle-card p,
.lpr-detail-card p {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.7;
}

.lpr-details {
  padding: var(--space-14) 0;
  background: var(--color-surface-muted);
}

.lpr-details__inner {
  max-width: 64rem;
}

.lpr-section-head {
  margin-bottom: var(--space-10);
}

.lpr-section-head h2 {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.95;
}

.lpr-section-head h2 span {
  color: var(--color-primary);
  font-style: italic;
  font-weight: 500;
}

.lpr-detail-list {
  display: grid;
  gap: var(--space-3);
}

.lpr-detail-card {
  padding: var(--space-6);
}

.lpr-detail-card h3 {
  display: flex;
  gap: var(--space-3);
  align-items: baseline;
  margin: 0 0 var(--space-3);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.lpr-detail-card h3 span {
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}

.lpr-contact {
  padding: var(--space-14) 0;
}

.lpr-contact__box {
  display: grid;
  gap: var(--space-8);
  align-items: center;
  padding: var(--space-8);
  border-radius: var(--radius-3xl);
  background: var(--color-dark);
  color: var(--color-background);
}

.lpr-contact__box h2 {
  margin: 0;
  color: inherit;
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.95;
}

.lpr-contact__box p {
  max-width: 38rem;
  margin: var(--space-4) 0 0;
  color: color-mix(in srgb, var(--color-background) 70%, transparent);
  line-height: 1.7;
}

.lpr-mail {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 3rem;
  padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-primary-foreground);
  font-family: var(--font-heading);
  font-weight: 700;
  text-decoration: none;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.lpr-mail:hover,
.lpr-mail:focus-visible {
  background: var(--color-primary-dark);
  color: var(--color-primary-foreground);
  transform: translateY(-1px);
}

.lpr-mail svg {
  width: 1rem;
  height: 1rem;
}

@media (min-width: 640px) {
  .lpr-principles__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .lpr-hero {
    padding: var(--space-14) 0 var(--space-16);
  }

  .lpr-hero__grid {
    grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
  }

  .lpr-details,
  .lpr-contact {
    padding: var(--space-16) 0;
  }

  .lpr-contact__box {
    grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
    padding: var(--space-10);
  }

  .lpr-mail {
    justify-self: end;
  }
}

/* ==========================================================================
   PAGE-TERMINI — ltr- prefix (mirrors lpr- pattern)
   ========================================================================== */

.ltr-page { background: var(--color-background); color: var(--color-dark); }

.ltr-hero { padding: var(--space-10) 0 var(--space-12); }

.ltr-kicker {
  margin-bottom: var(--space-6);
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.ltr-hero__grid { display: grid; gap: var(--space-8); align-items: end; }
.ltr-hero__copy { max-width: 46rem; }

.ltr-hero__title {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2.75rem, 8vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 0.92;
}
.ltr-hero__title span { color: var(--color-primary); font-style: italic; font-weight: 500; }
.ltr-hero__copy p {
  max-width: 38rem; margin: var(--space-6) 0 0;
  color: var(--color-muted);
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
  line-height: 1.75;
}

.ltr-version {
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface-muted);
  color: var(--color-muted);
  font-size: var(--font-size-sm);
}
.ltr-version p { margin: 0 0 var(--space-1); color: var(--color-dark); font-family: var(--font-heading); font-weight: 700; }
.ltr-version strong { font-weight: 500; }

.ltr-highlights { padding: 0 0 var(--space-14); }
.ltr-highlights__grid { display: grid; gap: var(--space-4); }

.ltr-highlight-card {
  padding: var(--space-7);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}
.ltr-icon {
  display: grid;
  width: 3rem; height: 3rem;
  margin-bottom: var(--space-5);
  place-items: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  color: var(--color-primary);
}
.ltr-icon svg { width: 1.25rem; height: 1.25rem; }
.ltr-highlight-card h2 {
  margin: 0 0 var(--space-2);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.ltr-highlight-card p { margin: 0; color: var(--color-muted); line-height: 1.7; }

.ltr-conditions { padding: var(--space-14) 0; background: var(--color-surface-muted); }
.ltr-conditions__grid { display: grid; gap: var(--space-8); }

.ltr-index__sticky { position: sticky; top: calc(var(--header-h) + 1.5rem); }
.ltr-index .ltr-kicker { margin-bottom: var(--space-4); }
.ltr-index ol { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-2); }
.ltr-index ol li a {
  display: inline-flex; align-items: baseline; gap: var(--space-2);
  color: var(--color-muted); font-size: var(--font-size-sm);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.ltr-index ol li a:hover { color: var(--color-dark); }
.ltr-index ol li a span {
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  min-width: 1.4rem;
}

.ltr-section-list { display: grid; gap: var(--space-3); }
.ltr-section-card {
  padding: var(--space-6) var(--space-8);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
  scroll-margin-top: calc(var(--header-h) + 1.5rem);
}
.ltr-section-card h2 {
  display: flex; gap: var(--space-3); align-items: baseline;
  margin: 0 0 var(--space-3);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
}
.ltr-section-card h2 span { color: var(--color-primary); font-variant-numeric: tabular-nums; }
.ltr-section-card p { margin: 0; color: var(--color-muted); line-height: 1.7; }

.ltr-contact { padding: var(--space-14) 0; }
.ltr-contact__box {
  display: grid; gap: var(--space-8); align-items: center;
  padding: var(--space-8);
  border-radius: var(--radius-3xl);
  background: var(--color-dark);
  color: var(--color-background);
}
.ltr-contact__box h2 {
  margin: 0; color: inherit;
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.95;
}
.ltr-contact__box p {
  max-width: 38rem; margin: var(--space-4) 0 0;
  color: color-mix(in srgb, var(--color-background) 70%, transparent);
  line-height: 1.7;
}
.ltr-contact__btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2);
  min-height: 3rem; padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-primary-foreground);
  font-family: var(--font-heading); font-weight: 700;
  text-decoration: none;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
}
.ltr-contact__btn:hover, .ltr-contact__btn:focus-visible {
  background: var(--color-primary-dark);
  color: var(--color-primary-foreground);
  transform: translateY(-1px);
}
.ltr-contact__btn svg { width: 1rem; height: 1rem; }

@media (min-width: 640px) {
  .ltr-highlights__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .ltr-hero { padding: var(--space-14) 0 var(--space-16); }
  .ltr-hero__grid { grid-template-columns: minmax(0, 8fr) minmax(0, 4fr); }
  .ltr-conditions { padding: var(--space-16) 0; }
  .ltr-conditions__grid { grid-template-columns: minmax(0, 3fr) minmax(0, 9fr); }
  .ltr-contact { padding: var(--space-16) 0; }
  .ltr-contact__box { grid-template-columns: minmax(0, 8fr) minmax(0, 4fr); padding: var(--space-10); }
  .ltr-contact__btn { justify-self: end; }
}

/* ==========================================================================
   PAGE-RESI — lresi- prefix
   ========================================================================== */

.lresi-page { background: var(--color-background); color: var(--color-dark); }

.lresi-hero { padding: var(--space-10) 0 var(--space-12); }
.lresi-kicker {
  margin-bottom: var(--space-6);
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.lresi-hero__grid { display: grid; gap: var(--space-8); align-items: end; }
.lresi-hero__copy { max-width: 46rem; }
.lresi-hero__title {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2.75rem, 8vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 0.92;
}
.lresi-hero__title span { color: var(--color-primary); font-style: italic; font-weight: 500; }
.lresi-hero__copy > p {
  max-width: 38rem; margin: var(--space-6) 0 0;
  color: var(--color-muted);
  font-size: clamp(1.0625rem, 2vw, 1.25rem);
  line-height: 1.75;
}
.lresi-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-8); }
.lresi-hero__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.lresi-stat { padding-left: var(--space-4); border-left: 2px solid var(--color-border); }
.lresi-stat strong {
  display: block;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.lresi-stat span { display: block; margin-top: var(--space-1); color: var(--color-muted); font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: 0.1em; line-height: 1.3; }

.lresi .lresi-stat .lresi-stat__icon {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  margin-top: 0;
  padding: 0;
  border-radius: 50%;
  line-height: 0;
}

.lresi .lresi-stat .lresi-stat__icon svg {
  display: block;
  width: 18px;
  height: 18px;
  max-width: 18px;
  max-height: 18px;
  margin: 0;
}

/* Due casi */
.lresi-cases { padding: 0 0 var(--space-14); }
.lresi-cases__grid { display: grid; gap: var(--space-4); }
.lresi-case {
  padding: var(--space-8);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}
.lresi-case--dark {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-background);
}
.lresi-case-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  margin-bottom: var(--space-6);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  color: var(--color-primary);
  font-family: var(--font-heading); font-size: var(--font-size-xs); font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.lresi-case-badge svg { width: .875rem; height: .875rem; }
.lresi-case h3 {
  margin: 0 0 var(--space-4);
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.15;
}
.lresi-case--dark h3 { color: var(--color-background); }
.lresi-case p { margin: 0 0 var(--space-5); color: var(--color-muted); line-height: 1.7; }
.lresi-case--dark p { color: color-mix(in srgb, var(--color-background) 70%, transparent); }
.lresi-checklist { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-2); }
.lresi-checklist li {
  display: flex; align-items: flex-start; gap: var(--space-2);
  font-size: var(--font-size-sm); color: var(--color-dark);
}
.lresi-case--dark .lresi-checklist li { color: var(--color-background); }
.lresi-checklist li svg { width: 1rem; height: 1rem; color: var(--color-primary); flex-shrink: 0; margin-top: .15rem; }

/* Steps */
.lresi-steps { padding: var(--space-14) 0; background: var(--color-surface-muted); }
.lresi-steps__head { max-width: 38rem; margin-bottom: var(--space-10); }
.lresi-steps__head h2 {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.95;
}
.lresi-steps__head h2 span { color: var(--color-primary); font-style: italic; font-weight: 500; }
.lresi-steps__grid { display: grid; gap: var(--space-4); }
.lresi-step {
  padding: var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
}
.lresi-step__n {
  font-family: var(--font-heading); font-size: 3rem; font-weight: 800;
  line-height: 1; color: color-mix(in srgb, var(--color-primary) 30%, transparent);
  margin-bottom: var(--space-5);
  font-variant-numeric: tabular-nums;
}
.lresi-step__icon {
  display: grid; width: 2.5rem; height: 2.5rem;
  place-items: center; border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  color: var(--color-primary); margin-bottom: var(--space-4);
}
.lresi-step__icon svg { width: 1.25rem; height: 1.25rem; }
.lresi-step h3 {
  margin: 0 0 var(--space-2);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2vw, 1.15rem);
  font-weight: 700;
}
.lresi-step p { margin: 0; color: var(--color-muted); font-size: var(--font-size-sm); line-height: 1.7; }

/* Help box */
.lresi-help {
  margin-top: var(--space-8);
  display: flex; align-items: center; gap: var(--space-5);
  padding: var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
}
.lresi-help__icon {
  display: grid; width: 2.75rem; height: 2.75rem; flex-shrink: 0;
  place-items: center; border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 10%, transparent);
  color: var(--color-primary);
}
.lresi-help__icon svg { width: 1.25rem; height: 1.25rem; }
.lresi-help__body { flex: 1; }
.lresi-help__body strong { display: block; color: var(--color-dark); font-family: var(--font-heading); font-weight: 700; }
.lresi-help__body p { margin: var(--space-1) 0 0; color: var(--color-muted); font-size: var(--font-size-sm); line-height: 1.6; }
.lresi-help__body a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 2px; }
.lresi-help__link {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: var(--space-2);
  min-height: 2.5rem; padding: 0 var(--space-4);
  border: 1px solid var(--color-border); border-radius: var(--radius-full);
  color: var(--color-dark);
  font-family: var(--font-heading); font-size: var(--font-size-sm); font-weight: 600;
  text-decoration: none;
  transition: border-color var(--transition-fast);
}
.lresi-help__link:hover { border-color: var(--color-dark); }
.lresi-help__link svg { width: .875rem; height: .875rem; }

/* Eccezioni */
.lresi-exceptions { padding: var(--space-14) 0; }
.lresi-exceptions__grid { display: grid; gap: var(--space-8); }
.lresi-exceptions__copy h2 {
  margin: 0;
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.95;
}
.lresi-exceptions__copy h2 span { color: var(--color-primary); font-style: italic; font-weight: 500; }
.lresi-exceptions__copy p { margin: var(--space-5) 0 0; color: var(--color-muted); line-height: 1.7; }
.lresi-exception-list { display: grid; gap: var(--space-3); }
.lresi-exception {
  display: flex; align-items: flex-start; gap: var(--space-4);
  padding: var(--space-5);
  border: 1px solid var(--color-border); border-radius: var(--radius-xl);
  background: var(--color-surface);
}
.lresi-exception__icon {
  display: grid; width: 2.25rem; height: 2.25rem; flex-shrink: 0;
  place-items: center; border-radius: var(--radius-full);
  background: color-mix(in srgb, #f59e0b 10%, transparent);
  color: #d97706;
}
.lresi-exception__icon svg { width: 1rem; height: 1rem; }
.lresi-exception strong { display: block; color: var(--color-dark); font-family: var(--font-heading); font-weight: 700; }
.lresi-exception p { margin: var(--space-1) 0 0; color: var(--color-muted); font-size: var(--font-size-sm); line-height: 1.6; }

/* Bottoni resi */
.lresi-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  min-height: 3rem; padding: 0 var(--space-6);
  border-radius: var(--radius-full);
  font-family: var(--font-heading); font-weight: 700; font-size: var(--font-size-sm);
  text-decoration: none;
  transition: background-color var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);
}
.lresi-btn svg { width: 1rem; height: 1rem; }
.lresi-btn--primary {
  background: var(--color-primary); color: var(--color-primary-foreground);
}
.lresi-btn--primary:hover { background: var(--color-primary-dark); color: var(--color-primary-foreground); transform: translateY(-1px); }
.lresi-btn--ghost {
  color: var(--color-dark); background: transparent;
}
.lresi-btn--ghost:hover { background: var(--color-surface-muted); color: var(--color-dark); }
.lresi-btn--outline {
  border: 1px solid var(--color-border); color: var(--color-dark); background: transparent;
}
.lresi-btn--outline:hover { border-color: var(--color-dark); }

@media (min-width: 640px) {
  .lresi-cases__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lresi-steps__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .lresi-hero { padding: var(--space-14) 0 var(--space-16); }
  .lresi-hero__grid { grid-template-columns: minmax(0, 8fr) minmax(0, 4fr); align-items: center; }
  .lresi-steps { padding: var(--space-16) 0; }
  .lresi-steps__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .lresi-help { flex-wrap: nowrap; }
  .lresi-exceptions { padding: var(--space-16) 0; }
  .lresi-exceptions__grid { grid-template-columns: minmax(0, 5fr) minmax(0, 7fr); align-items: start; }
  .lresi-exceptions__copy { position: sticky; top: calc(var(--header-h) + 2rem); }
}

/* ==========================================================================
   NAVBAR REDESIGN — 2-row layout
   ========================================================================== */

/* ── Top row (logo + catalogo + search + actions) ── */
.header-inner {
  min-height: 56px;
}

/* ── Bottom row (secondary nav) ── */
.header-bottom {
  border-top: 1px solid var(--color-border);
  background: inherit;
  display: none;
}
@media (min-width: 1024px) {
  .header-bottom { display: block; }
}
.header-bottom__inner {
  display: flex;
  align-items: center;
  max-width: var(--layout-shell-max);
  margin-inline: auto;
  padding: 0 var(--layout-shell-px);
  min-height: 40px;
}
.header-bottom__inner .nav-links {
  display: flex !important;
  gap: var(--space-1);
}
.header-bottom__inner .nav-pill {
  min-height: 36px;
  padding: var(--space-1) var(--space-3);
  font-size: var(--font-size-sm);
}

/* ── Catalogo button → outlined style ── */
.cat-trigger {
  background: transparent;
  color: var(--color-dark);
  border: 1.5px solid var(--color-border);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semi);
}
.cat-trigger:hover {
  background: var(--color-bg-alt);
  border-color: var(--color-text-muted);
  color: var(--color-dark);
}
.cat-mega.is-open .cat-trigger,
.cat-trigger[aria-expanded="true"] {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-white);
}
.cat-mega.is-open .cat-trigger:hover,
.cat-trigger[aria-expanded="true"]:hover {
  background: var(--color-dark);
}

/* ── Search pill → grows wide ── */
.header-search-pill {
  flex: 1;
  max-width: 480px;
  justify-content: space-between;
}
.header-search-pill__fake-input {
  flex: 1;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.header-search-pill__kbd {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 6px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font-size: 0.7rem;
  font-family: inherit;
  color: hsl(220, 10%, 25%);
  line-height: 1.4;
}

/* ── Mega-menu: 3 columns ── */
.cat-panel {
  width: min(48rem, calc(100vw - (var(--layout-shell-px) * 2)));
}
.cat-panel__inner {
  grid-template-columns: 14rem minmax(0, 1fr) 200px;
  align-items: stretch; /* override align-items: start so columns fill height */
}

/* Featured card column */
.cat-panel__feat {
  border-left: 1px solid var(--color-border);
  background: #f8f9fb;
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
}
.cat-feat-card {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.cat-feat-card[hidden] { display: none; }
.cat-feat-card__inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  background: var(--color-dark);
  min-height: 200px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition);
}
.cat-feat-card__inner:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.cat-feat-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .7;
}
.cat-feat-card__overlay {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  flex: 1;
  padding: 0.85rem;
  background: linear-gradient(to top, rgba(0,0,0,.72) 0%, transparent 55%);
}
.cat-feat-card__badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: 0.35rem;
}
.cat-feat-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 0.45rem;
  line-height: 1.2;
}
.cat-feat-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.8rem;
  color: rgba(255,255,255,.85);
  font-weight: 500;
}
.cat-feat-card__inner--empty {
  background: var(--color-bg-alt);
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}
.cat-feat-card__inner--empty .cat-feat-card__title {
  color: var(--color-dark);
  font-size: 0.9rem;
}
.cat-feat-card__inner--empty .cat-feat-card__cta {
  color: var(--color-primary);
}

/* ── Hide old nav-links from header-inner (moved to header-bottom) ── */
.header-inner > .nav-links { display: none !important; }

/* ── Category left column: "CATEGORIE" label, no icons ── */
.cat-panel__section-label {
  margin: 0;
  padding: 0.85rem 1rem 0.5rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
/* Hide icons from left category list — text-only style */
.cat-item__icon { display: none !important; }

/* Active category: bold + highlight */
.cat-item-parent.is-active > .cat-item {
  font-weight: 700;
  background: var(--color-white);
  color: var(--color-dark);
}
.cat-item__label {
  font-size: 0.95rem;
}

/* ── Mega-menu sub-panel typography fixes ── */

/* Title: meno letter-spacing, non va più a capo */
.cat-subpanel__title {
  letter-spacing: .06em;
  font-size: .78rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* "Vedi tutto" sempre su una riga */
.cat-subpanel__view-all {
  flex-shrink: 0;
  white-space: nowrap;
  font-size: .82rem;
}

/* Sub-items: icona più piccola, testo non tronca */
.cat-subitem__icon {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: .5rem;
}
.cat-subitem__label {
  font-size: .875rem;
  line-height: 1.25;
  overflow-wrap: break-word;
  word-break: break-word;
}
.cat-subitem__meta {
  font-size: .75rem;
}
.cat-subitem__arrow {
  display: none; /* rimuove freccia galleggiante nei sub-item */
}

/* Sub-item padding ridotto per guadagnare spazio */
.cat-subitem {
  gap: .6rem;
  padding: .55rem .6rem;
}

/* Panel width leggermente più largo per evitare wrapping */
.cat-panel {
  width: min(52rem, calc(100vw - (var(--layout-shell-px) * 2)));
}

/* ── Mega menu full-width: reference layout ── */
@media (min-width: 1024px) {
  .cat-mega {
    position: static;
  }

  .cat-panel {
    position: fixed;
    top: 56px;
    left: 0;
    right: 0;
    width: 100vw;
    max-width: none;
    min-height: clamp(20rem, 31vw, 35.5rem);
    height: auto;
    padding: 0;
    border: 0;
    border-top: 1px solid var(--color-border);
    border-radius: 0;
    background: var(--color-white);
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.12);
    overflow: hidden;
    transform: translateY(-0.75rem);
  }

  .admin-bar .cat-panel {
    top: 88px;
  }

  .cat-panel__inner {
    width: 100%;
    max-width: none;
    min-height: clamp(20rem, 31vw, 35.5rem);
    display: grid;
    grid-template-columns: minmax(16rem, 25vw) minmax(30rem, 41vw) minmax(22rem, 34vw);
    align-items: stretch;
    gap: 0;
    margin: 0;
    padding: 0;
  }

  .cat-panel__left {
    width: auto;
    padding: 2.15rem clamp(1.4rem, 2.8vw, 2.9rem);
    border-right: 0;
    background: var(--color-white);
  }

  .cat-panel__section-label {
    margin: 0 0 1.45rem;
    padding: 0;
    color: var(--color-text-muted);
    font-size: clamp(0.72rem, 0.95vw, 0.95rem);
    font-weight: 600;
    letter-spacing: 0.22em;
  }

  .cat-list {
    display: flex;
    flex-direction: column;
    gap: clamp(0.55rem, 1vw, 1rem);
    padding: 0;
    overflow: visible;
  }

  .cat-item {
    min-height: clamp(3.2rem, 4.2vw, 5.4rem);
    gap: clamp(0.8rem, 1.4vw, 1.45rem);
    padding: 0 clamp(0.9rem, 1.75vw, 1.6rem);
    border: 0;
    border-radius: 0.7rem;
    color: var(--color-text-muted);
    background: transparent;
  }

  .cat-item:hover,
  .cat-item-parent.is-active > .cat-item {
    background: #f0f3f2;
    color: var(--color-dark);
  }

  .cat-item__icon {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: clamp(1.25rem, 1.7vw, 1.75rem);
    height: clamp(1.25rem, 1.7vw, 1.75rem);
    flex: 0 0 clamp(1.25rem, 1.7vw, 1.75rem);
    border: 0;
    border-radius: 0;
    background: transparent;
    color: currentColor;
    overflow: visible;
  }

  .cat-item__icon svg {
    width: 100%;
    height: 100%;
    display: block;
  }

  .cat-item-parent.is-active > .cat-item .cat-item__icon,
  .cat-item:hover .cat-item__icon {
    color: var(--color-primary);
  }

  .cat-item__label {
    font-size: clamp(1rem, 1.35vw, 1.55rem);
    font-weight: 650;
    line-height: 1.16;
    letter-spacing: 0;
  }

  .cat-item__arrow svg {
    width: clamp(1rem, 1.45vw, 1.45rem);
    height: clamp(1rem, 1.45vw, 1.45rem);
  }

  .cat-panel__right {
    padding: 2.15rem clamp(1.45rem, 2.8vw, 3rem);
    background: var(--color-white);
    overflow: hidden;
  }

  .cat-subpanel {
    min-height: 100%;
    padding: 0;
    display: flex;
    flex-direction: column;
  }

  .cat-subpanel[hidden] {
    display: none;
  }

  .cat-subpanel__head {
    margin-bottom: clamp(1.3rem, 2vw, 2rem);
  }

  .cat-subpanel__title {
    color: var(--color-primary);
    font-size: clamp(0.78rem, 1vw, 1rem);
    font-weight: 650;
    letter-spacing: 0.24em;
  }

  .cat-subpanel__view-all {
    color: var(--color-text-muted);
    font-size: clamp(0.95rem, 1.25vw, 1.35rem);
    font-weight: 500;
  }

  .cat-subpanel__view-all svg {
    width: clamp(1rem, 1.35vw, 1.4rem);
    height: clamp(1rem, 1.35vw, 1.4rem);
  }

  .cat-sublist {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.45rem, 2.4vw, 3rem) clamp(1.7rem, 3.5vw, 4.6rem);
  }

  .cat-subitem {
    min-width: 0;
    gap: clamp(0.8rem, 1.25vw, 1.35rem);
    padding: 0;
    border-radius: 0;
    background: transparent;
  }

  .cat-subitem:hover {
    background: transparent;
    box-shadow: none;
  }

  .cat-subitem__icon {
    width: clamp(3rem, 3.4vw, 4.4rem);
    height: clamp(3rem, 3.4vw, 4.4rem);
    flex: 0 0 clamp(3rem, 3.4vw, 4.4rem);
    border: 0;
    border-radius: 0.7rem;
    background: #f2f4f4;
  }

  .cat-subitem__label {
    max-width: 100%;
    color: var(--color-dark);
    font-size: clamp(1.02rem, 1.45vw, 1.7rem);
    font-weight: 650;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .cat-subitem__meta {
    color: var(--color-text-muted);
    font-size: clamp(0.86rem, 1.08vw, 1.2rem);
    line-height: 1.2;
  }

  .cat-panel__catalog-link {
    display: none;
  }

  .cat-panel__feat {
    display: flex;
    align-items: stretch;
    justify-content: center;
    padding: clamp(1.8rem, 3.3vw, 4.2rem) clamp(1.7rem, 2.7vw, 3.4rem) clamp(1.9rem, 3.1vw, 3.8rem);
    border-left: 0;
    background: var(--color-white);
  }

  .cat-feat-card__inner {
    min-height: clamp(16rem, 24.8vw, 31.5rem);
    border-radius: 1rem;
  }

  .cat-feat-card__overlay {
    padding: clamp(1.35rem, 2.25vw, 2.55rem);
    background: linear-gradient(to top, rgba(18, 24, 32, 0.78) 0%, rgba(18, 24, 32, 0.24) 48%, rgba(18, 24, 32, 0.03) 100%);
  }

  .cat-feat-card__badge {
    font-size: clamp(0.72rem, 1vw, 1.05rem);
    font-weight: 500;
    letter-spacing: 0.25em;
  }

  .cat-feat-card__title {
    font-size: clamp(1.55rem, 2.1vw, 2.45rem);
    line-height: 1.08;
  }

  .cat-feat-card__cta {
    gap: 0.55rem;
    font-size: clamp(1rem, 1.35vw, 1.55rem);
    font-weight: 650;
  }
}

/* ==========================================================================
   CRO — Checkout trust strip e microcopy sicurezza (v1.8.0)
   ========================================================================== */

.qco-trust-strip {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  margin-top: var(--space-4);
}

.qco-trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: 1.4;
}

.qco-trust-item svg {
  flex-shrink: 0;
  color: var(--color-primary);
}

.qco-secure-note {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-3);
  justify-content: center;
}

.qco-secure-note svg {
  flex-shrink: 0;
}

/* ── Marketing Psychology: Hero proof bar + cutoff notice ── */
.ep-hero__proof {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem .25rem;
  margin-top: 1.25rem;
  font-size: .8rem;
  font-weight: 500;
  letter-spacing: .03em;
  color: rgba(255,255,255,.65);
}
.ep-hero__proof-sep {
  color: rgba(255,255,255,.3);
}
.ep-hero__cutoff {
  margin-top: .6rem;
  font-size: .75rem;
  color: rgba(255,255,255,.5);
  letter-spacing: .02em;
}

/* Override per hero con sfondo chiaro (immagine 3D con wash bianco) */
.ep-hero__inner .ep-hero__proof {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
  margin-top: 1.75rem;
}
.ep-hero__proof-stat {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  padding: .75rem 1rem;
  border-radius: 12px;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(15,23,42,0.08);
  box-shadow: 0 2px 8px rgba(15,23,42,0.06);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.ep-hero__proof-stat svg {
  flex-shrink: 0;
  width: 1.15rem;
  height: 1.15rem;
  margin-top: .15rem;
  color: var(--color-primary, #1a8c64);
}
.ep-hero__proof-stat-body {
  display: flex;
  flex-direction: column;
  gap: .1rem;
}
.ep-hero__proof-stat strong {
  font-size: .95rem;
  font-weight: 700;
  color: hsl(220,10%,15%);
  line-height: 1.1;
}
.ep-hero__proof-stat span {
  font-size: .7rem;
  font-weight: 500;
  color: hsl(220,5%,45%);
  letter-spacing: .02em;
}
.ep-hero__inner .ep-hero__proof-sep { display: none; }
.ep-hero__inner .ep-hero__cutoff {
  color: hsl(220,5%,40%);
  margin-top: .5rem;
}
@media (max-width: 540px) {
  .ep-hero__inner .ep-hero__proof {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 380px) {
  .ep-hero__inner .ep-hero__proof {
    grid-template-columns: 1fr;
  }
}

/* ── Category page: loss-aversion note ── */
.lca-loss-note {
  margin-top: .9rem;
  font-size: .8rem;
  color: var(--color-text-muted);
  line-height: 1.55;
  max-width: 44ch;
}

/* Catalogo dropdown: final visibility guard.
   Several historical mega-menu blocks still exist in this stylesheet; keep the
   actual header dropdown anchored below the full desktop header and outside
   any sticky-header clipping context. */
@media (min-width: 1024px) {
  .site-header,
  .site-header .header-inner,
  .site-header .header-bottom,
  .site-header .cat-mega {
    overflow: visible;
    contain: none;
  }

  .site-header .cat-panel {
    position: fixed;
    top: 96px;
    left: 0;
    right: 0;
    display: block;
    width: 100vw;
    max-width: none;
    min-height: clamp(20rem, 31vw, 35.5rem);
    padding: 0;
    border: 0;
    border-top: 1px solid var(--color-border);
    border-radius: 0;
    background: var(--color-white);
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.12);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-0.75rem);
    z-index: 10000;
  }

  .admin-bar .site-header .cat-panel {
    top: 128px;
  }

  .site-header .cat-mega.is-open > .cat-panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .site-header .cat-panel__left,
  .site-header .cat-panel__right {
    padding-top: 1.35rem;
  }

  .site-header .cat-panel__feat {
    padding-top: 1.35rem;
  }
}

/* Mobile catalog menu: compact accordion with category thumbnails. */
@media (max-width: 767px) {
  .nav-open .mobile-nav {
    display: block;
  }

  .mobile-nav {
    max-height: calc(100dvh - var(--header-h));
    overflow-y: auto;
    padding: 1.25rem var(--layout-shell-px) 1.75rem;
    border-top: 1px solid var(--color-border);
    background: var(--color-white);
  }

  .mobile-nav__products {
    display: none;
  }

  .mobile-products-title {
    margin: 0 0 .65rem;
    color: var(--color-text-muted);
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .22em;
    line-height: 1;
    text-transform: uppercase;
  }

  .mobile-products-cats {
    display: grid;
    gap: .5rem;
  }

  .mobile-products-cat {
    display: block;
    margin: 0;
    border: 1px solid var(--color-border);
    border-radius: .75rem;
    background: var(--color-white);
    overflow: hidden;
  }

  .mobile-products-cat__parent {
    display: grid;
    grid-template-columns: 2.4rem minmax(0, 1fr) 1rem;
    align-items: center;
    gap: .75rem;
    width: 100%;
    min-height: 3.15rem;
    padding: .45rem .7rem;
    color: var(--color-dark);
    text-decoration: none;
    cursor: pointer;
    list-style: none;
  }

  .mobile-products-cat__parent::-webkit-details-marker {
    display: none;
  }

  a.mobile-products-cat__parent {
    grid-template-columns: 2.4rem minmax(0, 1fr);
  }

  .mobile-products-cat__icon {
    display: grid;
    width: 2.4rem;
    height: 2.4rem;
    place-items: center;
    border-radius: .55rem;
    background: var(--color-bg-alt);
    color: var(--color-primary);
    overflow: hidden;
  }

  .mobile-products-cat__icon img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .mobile-products-cat__icon svg {
    width: 1.2rem;
    height: 1.2rem;
  }

  .mobile-products-cat__name {
    min-width: 0;
    color: var(--color-dark);
    font-size: .98rem;
    font-weight: 600;
    line-height: 1.18;
  }

  .mobile-products-cat__chevron {
    display: grid;
    width: 1rem;
    height: 1rem;
    place-items: center;
    color: var(--color-text-muted);
    transition: transform var(--transition);
  }

  .mobile-products-cat__chevron svg {
    width: 1rem;
    height: 1rem;
  }

  .mobile-products-cat[open] .mobile-products-cat__chevron {
    transform: rotate(180deg);
  }

  .mobile-products-cat__children {
    display: grid;
    gap: .35rem;
    padding: 0 .7rem .75rem 3.85rem;
  }

  .mobile-products-cat__all,
  .mobile-products-cat__child {
    display: flex;
    align-items: center;
    gap: .75rem;
    min-height: 2.8rem;
    padding: .35rem .25rem;
    color: var(--color-text-muted);
    font-size: .98rem;
    font-weight: 500;
    line-height: 1.2;
    text-decoration: none;
  }

  .mobile-products-cat__all {
    color: var(--color-primary);
    font-weight: 700;
  }

  .mobile-products-cat__child img {
    width: 2.15rem;
    height: 2.15rem;
    flex: 0 0 2.15rem;
    border-radius: .55rem;
    object-fit: cover;
    background: var(--color-bg-alt);
  }

  .mobile-products-cat__child span {
    color: var(--color-dark);
    font-weight: 600;
  }

  .mobile-products-all {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    min-height: 3rem;
    margin-top: 1.25rem;
    padding: 0 1rem;
    border-radius: var(--radius-full);
    background: var(--color-dark);
    color: var(--color-white);
    font-size: .98rem;
    font-weight: 800;
    text-decoration: none;
  }

  .mobile-products-all:hover {
    color: var(--color-white);
  }

  .mobile-products-all svg {
    width: 1rem;
    height: 1rem;
  }
}

/* Secondary navbar: PackPro-style icon circles + animated underline. */
@media (min-width: 1024px) {
  .site-header .header-bottom {
    border-top: 0;
    border-bottom: 1px solid var(--color-border);
    background: linear-gradient(180deg, rgba(248, 250, 250, .76) 0%, rgba(255, 255, 255, .96) 100%);
  }

  .site-header .header-bottom__inner {
    min-height: 42px;
  }

  .site-header .header-bottom__inner .nav-links {
    gap: 0;
  }

  .site-header .header-bottom__inner .nav-links > li {
    position: relative;
    display: flex;
    align-items: center;
  }

  .site-header .header-bottom__inner .nav-links > li:not(:last-child)::after {
    content: "";
    width: 1px;
    height: 16px;
    margin-inline: 12px;
    background: var(--color-border);
    opacity: .85;
  }

  .site-header .header-bottom__inner .nav-pill {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    min-height: 40px;
    padding: .35rem 0;
    border: 0;
    background: transparent;
    color: var(--color-text-muted);
    font-size: .875rem;
    font-weight: 600;
    line-height: 1;
  }

  .site-header .header-bottom__inner .nav-pill::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    border-radius: 999px;
    background: var(--color-dark);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 180ms ease;
  }

  .site-header .header-bottom__inner .nav-pill:hover,
  .site-header .header-bottom__inner .current-menu-item > .nav-pill,
  .site-header .header-bottom__inner .current-menu-parent > .nav-pill {
    color: var(--color-dark);
    background: transparent;
  }

  .site-header .header-bottom__inner .nav-pill:hover::after,
  .site-header .header-bottom__inner .current-menu-item > .nav-pill::after,
  .site-header .header-bottom__inner .current-menu-parent > .nav-pill::after {
    transform: scaleX(1);
  }

  .site-header .header-bottom__inner .nav-pill__icon,
  .site-header .header-bottom__inner .nav-pill__icon-wrap {
    position: relative;
    display: inline-grid;
    width: 24px;
    height: 24px;
    min-width: 24px;
    place-items: center;
    border: 1px solid color-mix(in srgb, var(--color-text-muted) 38%, transparent);
    border-radius: 999px;
    color: var(--color-text-muted);
    background: var(--color-white);
    transition: border-color 180ms ease, color 180ms ease, background-color 180ms ease;
  }

  .site-header .header-bottom__inner .nav-pill svg {
    width: 14px;
    height: 14px;
  }

  .site-header .header-bottom__inner .nav-pill:hover .nav-pill__icon,
  .site-header .header-bottom__inner .nav-pill:hover .nav-pill__icon-wrap,
  .site-header .header-bottom__inner .current-menu-item > .nav-pill .nav-pill__icon,
  .site-header .header-bottom__inner .current-menu-item > .nav-pill .nav-pill__icon-wrap {
    border-color: var(--color-dark);
    color: var(--color-dark);
    background: var(--color-white);
  }

  .site-header .header-bottom__inner .nav-pill__label {
    line-height: 1;
  }

  .site-header .header-bottom__inner .nav-pill__dot {
    top: -3px;
    right: -1px;
    width: 7px;
    height: 7px;
    min-width: 7px;
    background: #ef6b76;
    box-shadow: 0 0 0 2px var(--color-white);
  }
}

/* Secondary navbar: compact reference match. */
@media (min-width: 1024px) {
  .site-header .header-bottom {
    border-top: 1px solid hsl(210, 18%, 92%);
    border-bottom: 1px solid hsl(210, 16%, 88%);
    background: #fff;
  }

  .site-header .header-bottom__inner {
    min-height: 58px;
    gap: 1.05rem;
  }

  .site-header .header-bottom__inner .nav-links {
    align-items: center;
    flex: 1 1 auto;
    gap: .35rem;
    min-width: 0;
  }

  .site-header .header-bottom__inner .nav-links > li::after {
    display: none !important;
  }

  .site-header .header-bottom__inner .nav-pill {
    gap: .42rem;
    min-height: 32px;
    padding: 0 .45rem;
    border-radius: 999px;
    color: hsl(220, 9%, 39%);
    font-size: .84rem;
    font-weight: 600;
    white-space: nowrap;
  }

  .site-header .header-bottom__inner .nav-pill::after {
    display: none;
  }

  .site-header .header-bottom__inner .nav-pill--bordered,
  .site-header .header-bottom__inner .nav-links > li:first-child > .nav-pill,
  .site-header .header-bottom__inner .nav-links > li:nth-child(2) > .nav-pill {
    padding-inline: .8rem;
    border: 1px solid hsl(204, 12%, 75%);
    color: hsl(210, 9%, 18%);
    background: #fff;
  }

  .site-header .header-bottom__inner .nav-pill:hover,
  .site-header .header-bottom__inner .current-menu-item > .nav-pill,
  .site-header .header-bottom__inner .current-menu-parent > .nav-pill {
    color: hsl(210, 9%, 18%);
    background: hsl(150, 18%, 96%);
  }

  .site-header .header-bottom__inner .nav-pill__icon,
  .site-header .header-bottom__inner .nav-pill__icon-wrap {
    width: 15px;
    height: 15px;
    min-width: 15px;
    border: 0;
    border-radius: 0;
    color: hsl(217, 8%, 58%);
    background: transparent;
  }

  .site-header .header-bottom__inner .nav-pill--bordered .nav-pill__icon,
  .site-header .header-bottom__inner .nav-links > li:first-child > .nav-pill .nav-pill__icon,
  .site-header .header-bottom__inner .nav-links > li:first-child > .nav-pill .nav-pill__icon-wrap,
  .site-header .header-bottom__inner .nav-links > li:nth-child(2) > .nav-pill .nav-pill__icon,
  .site-header .header-bottom__inner .nav-links > li:nth-child(2) > .nav-pill .nav-pill__icon-wrap,
  .site-header .header-bottom__inner .nav-pill:hover .nav-pill__icon,
  .site-header .header-bottom__inner .nav-pill:hover .nav-pill__icon-wrap {
    color: var(--color-primary);
    background: transparent;
  }

  .site-header .header-bottom__inner .nav-pill svg {
    width: 14px;
    height: 14px;
  }

  .site-header .header-bottom__inner .nav-pill__dot {
    top: -6px;
    right: -5px;
    width: 6px;
    height: 6px;
    min-width: 6px;
    box-shadow: 0 0 0 2px #fff;
  }

  .header-bottom__shipping {
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    gap: .32rem;
    margin-left: auto;
    color: hsl(220, 7%, 43%);
    font-size: .8rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
  }

  .header-bottom__shipping strong {
    color: hsl(210, 9%, 18%);
    font-weight: 700;
  }

  .header-bottom__shipping-icon {
    display: inline-flex;
    color: var(--color-primary);
  }

  .header-bottom__shipping-icon svg {
    width: 16px;
    height: 16px;
  }

  .header-bottom__shipping-sep {
    color: hsl(220, 8%, 66%);
  }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .site-header .header-bottom__inner {
    gap: .6rem;
  }

  .site-header .header-bottom__inner .nav-pill {
    gap: .28rem;
    padding-inline: .3rem;
    font-size: .76rem;
  }

  .site-header .header-bottom__inner .nav-pill--bordered,
  .site-header .header-bottom__inner .nav-links > li:first-child > .nav-pill,
  .site-header .header-bottom__inner .nav-links > li:nth-child(2) > .nav-pill {
    padding-inline: .55rem;
  }

  .header-bottom__shipping {
    gap: .22rem;
    font-size: .74rem;
  }
}

/* Movimentazione hero: align with editorial reference. */
@media (min-width: 1024px) {
  .lmv-page .container {
    max-width: 1232px;
  }

  .lmv-hero {
    min-height: calc(100svh - var(--header-h, 0px));
  }

  .lmv-hero__bg img {
    object-position: center center;
  }

  .lmv-hero__overlay--flat {
    background: rgba(16, 19, 24, 0.68);
  }

  .lmv-hero__overlay--h {
    background: linear-gradient(90deg, rgba(15, 18, 22, 0.72) 0%, rgba(21, 23, 28, 0.58) 48%, rgba(21, 23, 28, 0.34) 100%);
  }

  .lmv-hero__overlay--v {
    background: linear-gradient(0deg, rgba(16, 19, 24, 0.72) 0%, rgba(16, 19, 24, 0.10) 44%, rgba(16, 19, 24, 0.32) 100%);
  }

  .lmv-hero__inner {
    min-height: calc(100svh - var(--header-h, 0px));
    padding-top: clamp(3.2rem, 5.3vw, 6rem);
    padding-bottom: clamp(2.4rem, 4vw, 3.6rem);
    gap: 0;
  }

  .lmv-hero__top {
    margin-bottom: clamp(3rem, 5.1vw, 4.8rem);
  }

  .lmv-kicker--editorial {
    margin-bottom: 0;
    gap: .75rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .25em;
  }

  .lmv-kicker__line {
    width: 2rem;
    height: 1px;
  }

  .lmv-hero__mid {
    grid-template-columns: minmax(0, 1.35fr) minmax(25rem, .95fr);
    align-items: center;
    gap: clamp(4rem, 8vw, 7rem);
  }

  .lmv-hero__copy {
    min-width: 0;
  }

  .lmv-hero__title {
    max-width: 48rem;
    margin-bottom: 1.55rem;
    font-size: clamp(4.2rem, 5.1vw, 5.6rem);
    line-height: .98;
    letter-spacing: -0.045em;
  }

  .lmv-hero__title em {
    display: inline-block;
    font-weight: 500;
  }

  .lmv-hero__text {
    max-width: 43rem;
    margin-bottom: 2.35rem;
    color: rgba(255,255,255,.84);
    font-size: clamp(1.02rem, 1.05vw, 1.16rem);
    font-weight: 500;
    line-height: 1.6;
  }

  .lmv-hero__actions {
    gap: .75rem;
  }

  .lmv-hero__actions .lmv-btn,
  .lmv-btn--hero-outline {
    min-height: 3rem;
    padding: 0 1.45rem;
    font-size: .92rem;
  }

  .lmv-hero__panel {
    width: min(100%, 30.5rem);
    justify-self: end;
    margin-top: clamp(3rem, 5.8vw, 5.8rem);
    padding: 1.7rem;
    gap: 1.05rem;
    border-color: rgba(255,255,255,.18);
    border-radius: .95rem;
    background: rgba(28, 30, 35, .78);
    box-shadow: 0 22px 70px rgba(0,0,0,.26);
  }

  .lmv-hero__panel-head {
    padding-bottom: 1rem;
  }

  .lmv-hero__panel-label,
  .lmv-hero__panel-count {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .2em;
  }

  .lmv-hero__panel-label {
    color: var(--color-primary);
  }

  .lmv-hero__panel-count {
    color: rgba(255,255,255,.52);
  }

  .lmv-hero__panel-item {
    padding: .86rem 0;
    font-size: 1rem;
    font-weight: 750;
    line-height: 1.1;
  }

  .lmv-hero__panel-item:nth-child(odd) {
    padding-right: 1rem;
  }

  .lmv-hero__panel-item:nth-child(even) {
    padding-left: 1rem;
  }

  .lmv-hero__panel-footer {
    padding-top: 1rem;
    color: rgba(255,255,255,.64);
    font-size: .75rem;
    font-weight: 650;
  }

  .lmv-hero__bottom {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(28rem, 1fr);
    align-items: end;
    gap: clamp(2.5rem, 5.2vw, 5rem);
    margin-top: clamp(3.4rem, 6vw, 5.4rem);
    padding-top: 2rem;
  }

  .lmv-hero__feature-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }

  .lmv-hero__fcard {
    min-height: 4.55rem;
    padding: .85rem 1rem;
    border-color: rgba(255,255,255,.16);
    border-radius: .65rem;
    background: rgba(255,255,255,.055);
  }

  .lmv-hero__fcard-icon {
    width: 2rem;
    height: 2rem;
    padding: .52rem;
    border-radius: 999px;
    background: rgba(24, 137, 103, .24);
  }

  .lmv-hero__fcard-title {
    font-size: .9rem;
    font-weight: 750;
  }

  .lmv-hero__fcard-sub {
    font-size: .68rem;
    color: rgba(255,255,255,.62);
  }

  .lmv-hero__bottom .lmv-stats--light {
    gap: clamp(2.4rem, 4.4vw, 4.5rem);
    margin: 0;
    padding: 0 0 0 2.3rem;
    border-top: 0;
    border-left: 1px solid rgba(255,255,255,.18);
  }

  .lmv-hero__bottom .lmv-stat__number {
    font-size: clamp(2.25rem, 3vw, 3.1rem);
    line-height: .9;
  }

  .lmv-hero__bottom .lmv-stat__label {
    margin-top: .75rem;
    font-size: .68rem;
    letter-spacing: .16em;
    line-height: 1.25;
  }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .lmv-hero__mid {
    grid-template-columns: minmax(0, 1.2fr) minmax(21rem, .9fr);
    gap: 2.4rem;
  }

  .lmv-hero__title {
    font-size: clamp(3.65rem, 5.4vw, 4.5rem);
  }

  .lmv-hero__panel {
    margin-top: 2.5rem;
  }

  .lmv-hero__bottom {
    grid-template-columns: 1fr;
    gap: 1.7rem;
  }

  .lmv-hero__bottom .lmv-stats--light {
    padding-left: 0;
    border-left: 0;
  }
}

/* Movimentazione hero: title-only top and brand table above stats. */
@media (min-width: 1024px) {
  .lmv-hero__mid {
    display: block;
    max-width: 49rem;
  }

  .lmv-hero__title {
    max-width: 58rem;
  }

  .lmv-hero__title em {
    display: block;
  }

  .lmv-hero__bottom {
    grid-template-columns: minmax(0, 1.35fr) minmax(28rem, 1fr);
    grid-template-rows: auto auto;
    align-items: end;
    column-gap: clamp(3rem, 6vw, 6rem);
    row-gap: 1.45rem;
    margin-top: clamp(2.8rem, 4.8vw, 4.4rem);
  }

  .lmv-hero__feature-cards {
    grid-column: 1;
    grid-row: 2;
  }

  .lmv-hero__panel {
    grid-column: 2;
    grid-row: 1;
    width: min(100%, 31rem);
    margin: 0;
    align-self: end;
  }

  .lmv-hero__bottom .lmv-stats--light {
    grid-column: 2;
    grid-row: 2;
  }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .lmv-hero__mid {
    max-width: 45rem;
  }

  .lmv-hero__bottom {
    grid-template-columns: 1fr;
  }

  .lmv-hero__feature-cards,
  .lmv-hero__panel,
  .lmv-hero__bottom .lmv-stats--light {
    grid-column: 1;
    grid-row: auto;
  }
}
