/* ============================================================
   NVI — NATURAE VICTUS INTERNATIONAL
   Homepage prototype / design system  (reference-aligned pass)
   ============================================================ */

/* -----  FONTS  ------------------------------------------------ */
@font-face{
  font-family:"Girisuba";
  src:url("../fonts/Girisuba.woff") format("woff"),
      url("../fonts/Girisuba.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Thin/Gotham%20Thin.otf") format("opentype");font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Extra%20Light/Gotham%20Extra%20Light.otf") format("opentype");font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Light/Gotham%20Light.otf") format("opentype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Book/Gotham%20Book.otf") format("opentype");font-weight:350;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Regular/Gotham%20Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Italic/Gotham%20Italic.otf") format("opentype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Medium/Gotham%20Medium.otf") format("opentype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Bold/Gotham%20Bold.otf") format("opentype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Bold%20Italic/Gotham%20Bold%20Italic.ttf") format("truetype");font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:"Gotham";src:url("../fonts/Gotham/Gotham%20Black/Gotham%20Black.otf") format("opentype");font-weight:900;font-style:normal;font-display:swap}

/* -----  DESIGN TOKENS  --------------------------------------- */
:root{
  --color-cream:          #FFFDFA;
  --color-cream-warm:     #F6F1E7;
  --color-cream-soft:     #FAF5EB;
  --color-paper:          #F0EADF;  /* beige editorial — usato da Section Settings preset "paper" */
  --color-sage:           #9BCB9C;
  --color-sage-300:       #C3DFC4;
  --color-sage-700:       #7FAA80;
  --color-forest:         #41594C;
  --color-forest-900:     #2B3D35;
  --color-forest-700:     #38493F;
  --color-forest-500:     #6B8378;
  --color-ink:            #1C1C1C;
  --color-ink-soft:       #2B2B2B;
  --color-line:           rgba(28,28,28,.10);
  --color-line-on-forest: rgba(255,253,250,.16);

  --font-display: "Girisuba", "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --font-sans:    "Gotham", "Inter", system-ui, -apple-system, Segoe UI, sans-serif;

  /* Title typography tokens — default Gotham Medium con <em> Gotham Bold Italic.
     Per usare Girisuba (display serif italic) su una sezione specifica,
     aggiungere la classe `.title-display` al contenitore della sezione. */
  --title-font: var(--font-sans);
  --title-weight: 500;
  --title-em-weight: 700;
  --title-em-style: italic;

  /* Type scale (fluid, reference-calibrated) */
  --fs-display: clamp(48px, 6.5vw, 108px);
  --fs-h1:      clamp(40px, 5vw, 84px);
  --fs-h2:      clamp(30px, 3.6vw, 58px);
  --fs-h3:      clamp(22px, 2.1vw, 32px);
  --fs-body:    16px;
  --fs-body-l:  clamp(16px, 1.15vw, 19px);
  --fs-small:   13.5px;
  --fs-tiny:    11.5px;

  --sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;
  --sp-6: 32px;--sp-7: 48px;--sp-8: 64px;--sp-9: 96px;--sp-10:128px;--sp-11:160px;

  --radius-card: 28px;
  --radius-card-lg: 40px;
  --radius-pill: 999px;

  --shadow-soft: 0 2px 8px rgba(28,28,28,.04), 0 12px 36px rgba(28,28,28,.06);
  --shadow-card: 0 8px 24px rgba(28,28,28,.08), 0 24px 60px rgba(28,28,28,.08);

  --easing: cubic-bezier(.22,.61,.36,1);
  --easing-out: cubic-bezier(.16,1,.3,1);

  --container: 1320px;
  --container-tight: 1120px;

  /* -----  SISTEMA DI LARGHEZZE UNIFICATO  ------------------------
     Misure di testo in `ch` (scalano con la dimensione del font fluido
     `clamp()` -> niente inversione desktop/tablet). Rail strutturali in
     px solo per blocchi con cornice/sfondo. Vedi audit spaziature giu 2026. */
  --measure-display: 22ch;        /* titoli display standard */
  --measure-display-wide: 28ch;   /* hero / titoli sezione principali (più imponenti) */
  --measure-lede: 62ch;           /* lede / sottotitoli — valore unico */
  --measure-body: 68ch;           /* paragrafi lunghi */
  --rail: 920px;                  /* header di sezione con cornice/sfondo */
  --rail-wide: 1180px;            /* inner larghi (brand, manifesto) */

  /* -----  SCALA TIPOGRAFICA DEL TESTO  ---------------------------
     Ruoli unificati per testo corrente e lede (vedi audit testi giu 2026).
     L'allineamento NON è gestito qui (resta per-sezione). */
  --lede-size:   clamp(17px, 1.25vw, 21px);  --lede-lh: 1.7;   --lede-weight: 300;  /* sottotitolo sotto un titolo */
  --body-size:   clamp(16px, 1.15vw, 19px);  --body-lh: 1.75;  --body-weight: 300;  /* testo corrente */
  --body-sm-size: 15px;                      --body-sm-lh: 1.7; --body-sm-weight: 300; /* card, modali, FAQ */
  --meta-size:   13px;                       --meta-lh: 1.5;   --meta-weight: 350;  /* date, autore, micro */
  --prose-ink: var(--color-ink-soft);        /* testo su fondo chiaro */
  --prose-on-dark: rgba(255,253,250,.85);    /* testo su fondo scuro (ogni brand può sovrascrivere) */
  --nav-h: 96px;
}

/* -----  RESET & BASE  ---------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);font-weight:350;font-size:var(--fs-body);
  line-height:1.65;color:var(--color-ink-soft);background:var(--color-cream);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color .3s var(--easing-out)}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit}
ul,ol{list-style:none}
::selection{background:var(--color-sage);color:var(--color-forest-900)}

/* -----  TYPOGRAPHY  ------------------------------------------ */
.display{font-family:var(--font-display);font-weight:400;letter-spacing:-.01em;line-height:1.02}
.display em,.display i{font-style:italic}
em.emph,i.emph{font-style:italic;font-weight:400}
.eyebrow{font-family:var(--font-sans);font-size:var(--fs-tiny);font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--color-forest)}

/* Override globale: usa Girisuba (display serif italic) sui titoli.
   Aggiungere la classe `.title-display` a una <section> o contenitore per
   forzare l'uso del font display su tutti i titoli al suo interno.
   I titoli leggono `var(--title-font / --title-weight / --title-em-weight)`. */
.title-display{
  --title-font: var(--font-display);
  --title-weight: 400;
  --title-em-weight: 400;
  --title-em-style: italic;
}

/* -----  UTILITY  --------------------------------------------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.container--tight{max-width:var(--container-tight)}
.section{padding:clamp(80px,10vw,140px) 0;position:relative}
.only-desktop{display:none}
@media (min-width:1024px){.only-desktop{display:initial}.only-mobile{display:none}}

/* -----  BUTTONS (reference-style pill)  ---------------------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 32px;border-radius:var(--radius-pill);
  font-family:var(--font-sans);font-weight:500;font-size:14.5px;letter-spacing:.01em;
  background:var(--color-sage);color:var(--color-forest-900);
  border:1px solid transparent;
  transition:transform .4s var(--easing-out),background .3s,color .3s,border-color .3s;
  will-change:transform;
}
.btn:hover{transform:translateY(-2px);background:var(--color-sage-700);color:var(--color-forest-900)}
.btn--forest{background:var(--color-forest);color:var(--color-cream)}
.btn--forest:hover{background:var(--color-forest-900);color:var(--color-cream)}
.btn--ghost{background:transparent;color:var(--color-forest);border-color:var(--color-forest)}
.btn--ghost:hover{background:var(--color-forest);color:var(--color-cream)}
.btn--ghost-light{background:transparent;color:var(--color-cream);border-color:rgba(255,253,250,.5)}
.btn--ghost-light:hover{background:var(--color-cream);color:var(--color-forest-900);border-color:var(--color-cream)}
.btn--dark{background:var(--color-ink);color:var(--color-cream)}
.btn--dark:hover{background:var(--color-forest-900);color:var(--color-cream)}
.btn__arrow{
  width:8px;height:8px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;
  transform:rotate(45deg);transition:transform .3s var(--easing-out);
}
.btn:hover .btn__arrow{transform:rotate(45deg) translate(3px,-3px)}

/* -----  HEADER / NAV (single Forest banner)  ---------------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  padding:16px clamp(16px,2.5vw,28px) 0;
  pointer-events:none;
}
.nav__bar{
  pointer-events:auto;position:relative;
  display:flex;align-items:center;gap:clamp(10px,2vw,24px);
  background:rgba(43,61,53,.32);
  color:var(--color-cream);
  padding:14px clamp(18px,2vw,28px);
  border-radius:28px;
  border:1px solid rgba(255,253,250,.14);
  box-shadow:
    inset 0 1px 0 rgba(255,253,250,.06),
    0 8px 32px rgba(0,0,0,.10);
  backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);
  transition:background .35s var(--easing-out),border-color .35s,box-shadow .35s;
}
/* Scrolled — slightly more opaque for readability over page content */
.nav.is-scrolled .nav__bar{
  background:rgba(43,61,53,.58);
  border-color:rgba(255,253,250,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,253,250,.08),
    0 12px 40px rgba(0,0,0,.16);
}
/* Light-hero pages need a stronger forest tint so cream text stays readable.
   Glass effect preserved (still translucent + backdrop-filter), but tint is
   pushed forward so the menu reads as a solid forest band, not a sage wash. */
body.qly .nav__bar,
body.ricette .nav__bar,
body.ricetta .nav__bar,
body.news .nav__bar,
body.post .nav__bar,
body.contatti .nav__bar,
body.search .nav__bar{
  background:rgba(43,61,53,.68);
  border-color:rgba(255,253,250,.20);
  box-shadow:
    inset 0 1px 0 rgba(255,253,250,.08),
    0 10px 36px rgba(28,40,32,.18);
}
body.qly .nav.is-scrolled .nav__bar,
body.ricette .nav.is-scrolled .nav__bar,
body.ricetta .nav.is-scrolled .nav__bar,
body.news .nav.is-scrolled .nav__bar,
body.post .nav.is-scrolled .nav__bar,
body.contatti .nav.is-scrolled .nav__bar,
body.search .nav.is-scrolled .nav__bar{
  background:rgba(43,61,53,.86);
  border-color:rgba(255,253,250,.24);
  box-shadow:
    inset 0 1px 0 rgba(255,253,250,.10),
    0 14px 44px rgba(28,40,32,.22);
}
.nav__logo{
  display:flex;align-items:center;flex:none;
  transition:opacity .3s var(--easing-out);
}
.nav__logo:hover{opacity:.85}
.nav__logo-img{height:48px;width:auto;display:block}

.nav__menu{
  display:none;flex:1;justify-content:center;
  align-items:center;gap:clamp(4px,1vw,14px);
}
@media (min-width:1024px){.nav__menu{display:flex}}
.nav__link{
  padding:10px 14px;border-radius:var(--radius-pill);
  font-size:14.5px;font-weight:300;letter-spacing:.005em;
  color:var(--color-cream);
  transition:background .3s,color .3s,opacity .3s;
  display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.nav__link:hover{background:rgba(255,253,250,.12);color:var(--color-cream)}
.nav__link--active{background:rgba(255,253,250,.14);color:var(--color-cream)}

/* -----  NAV DROPDOWNS  --------------------------------------- */
.nav__drop{position:relative;display:inline-flex;align-items:center}
.nav__caret{
  display:inline-block;width:7px;height:7px;
  border-right:1.4px solid currentColor;border-bottom:1.4px solid currentColor;
  transform:translateY(-2px) rotate(45deg);
  opacity:.7;transition:transform .3s var(--easing-out),opacity .3s;
}
.nav__drop:hover .nav__caret,
.nav__drop.is-open .nav__caret{transform:translateY(1px) rotate(225deg);opacity:1}

.nav__dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translate(-50%,-6px);
  min-width:220px;padding:16px 0;
  background:rgba(43,61,53,.78);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid rgba(255,253,250,.14);
  border-radius:22px;
  box-shadow:0 18px 48px rgba(28,28,28,.28),0 2px 8px rgba(28,28,28,.14);
  opacity:0;pointer-events:none;visibility:hidden;
  transition:opacity .28s var(--easing-out),transform .32s var(--easing-out),visibility 0s linear .32s;
  z-index:80;
}
.nav__dropdown::before{
  content:"";position:absolute;inset:-10px 0 auto 0;height:18px;
  /* hover-gap bridge so mouse can cross without closing */
}
.nav__drop:hover > .nav__dropdown,
.nav__drop.is-open > .nav__dropdown,
.nav__drop:focus-within > .nav__dropdown{
  opacity:1;pointer-events:auto;visibility:visible;
  transform:translate(-50%,0);
  transition-delay:0s;
}
.nav__dropdown-list{display:flex;flex-direction:column}
.nav__dropdown-list > li > a,
.nav__brand-head,
.nav__brand--single > a{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 26px;
  font-family:var(--font-sans);font-weight:400;font-size:15px;letter-spacing:.005em;
  color:var(--color-cream);
  transition:background .25s,color .25s,padding-left .3s var(--easing-out);
  white-space:nowrap;
}
.nav__dropdown-list > li > a:hover,
.nav__brand-head:hover,
.nav__brand--single > a:hover{
  background:rgba(155,203,156,.1);color:var(--color-sage);
  padding-left:32px;
}

/* Mega (Linee Prodotti) — solo gli 8 brand. I tre senior aprono un flyout laterale. */
.nav__dropdown--mega{min-width:260px;padding:10px 0}
.nav__brand{position:relative;display:flex;flex-direction:column}
.nav__brand-head,
.nav__brand--single > a{
  font-weight:400;color:var(--color-cream);
}
.nav__brand--has-sub > .nav__brand-head{
  font-weight:500;
}
.nav__brand + .nav__brand{border-top:1px solid rgba(255,253,250,.06)}

/* Frecciotta a destra sui brand con sub */
.nav__brand-arrow{
  display:inline-block;width:7px;height:7px;
  border-right:1.4px solid currentColor;border-top:1.4px solid currentColor;
  transform:rotate(45deg);opacity:.6;flex:none;
  transition:transform .3s var(--easing-out),opacity .3s;
}
.nav__brand--has-sub:hover > .nav__brand-head .nav__brand-arrow,
.nav__brand--has-sub.is-flyout-open > .nav__brand-head .nav__brand-arrow{
  opacity:1;
}

/* Flyout laterale (desktop) */
.nav__flyout{
  position:absolute;top:-10px;left:calc(100% + 8px);
  min-width:220px;padding:10px 0;
  background:rgba(43,61,53,.78);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid rgba(255,253,250,.14);
  border-radius:18px;
  box-shadow:0 18px 48px rgba(28,28,28,.32),0 2px 8px rgba(28,28,28,.18);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateX(-6px);
  transition:opacity .26s var(--easing-out),transform .3s var(--easing-out),visibility 0s linear .3s;
  z-index:90;
}
.nav__flyout::before{
  content:"";position:absolute;top:0;bottom:0;left:-10px;width:10px;
  /* hover-gap bridge: il mouse non perde il flyout passando sopra il gap */
}
.nav__brand--has-sub:hover > .nav__flyout,
.nav__brand--has-sub:focus-within > .nav__flyout,
.nav__brand--has-sub.is-flyout-open > .nav__flyout{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(0);transition-delay:0s;
}
.nav__flyout ul{display:flex;flex-direction:column}
.nav__flyout li > a{
  display:block;padding:9px 22px;
  font-family:var(--font-sans);font-weight:400;font-size:14px;
  color:rgba(255,253,250,.86);letter-spacing:.005em;
  transition:color .25s,background .25s,padding-left .3s var(--easing-out);
  white-space:nowrap;
}
.nav__flyout li > a:hover{
  background:rgba(155,203,156,.1);color:var(--color-sage);
  padding-left:28px;
}
.nav__flyout-head{
  font-style:italic;font-size:12.5px !important;
  color:rgba(155,203,156,.85) !important;
  border-bottom:1px solid rgba(255,253,250,.08);
  margin-bottom:4px;padding-bottom:8px !important;
}

/* Se il flyout uscirebbe a destra, lo capovolgi sulla sinistra del brand */
.nav__brand--has-sub.is-flip > .nav__flyout{
  left:auto;right:calc(100% + 8px);transform:translateX(6px);
}
.nav__brand--has-sub.is-flip:hover > .nav__flyout,
.nav__brand--has-sub.is-flip.is-flyout-open > .nav__flyout{transform:translateX(0)}

@media (max-width:1023px){
  /* Mobile drawer — matches desktop glass style, with stronger tint for readability */
  .nav__menu.is-open{
    display:flex !important;flex-direction:column;align-items:stretch;gap:2px;
    position:absolute;top:calc(100% + 10px);left:0;right:0;
    padding:14px;
    max-height:calc(100vh - 110px);overflow-y:auto;overscroll-behavior:contain;
    background:rgba(28,40,34,.82);
    backdrop-filter:blur(28px) saturate(160%);
    -webkit-backdrop-filter:blur(28px) saturate(160%);
    border:1px solid rgba(255,253,250,.18);
    border-radius:22px;
    box-shadow:
      inset 0 1px 0 rgba(255,253,250,.08),
      0 16px 44px rgba(0,0,0,.32);
    z-index:5;
  }
  .nav__menu.is-open .nav__link{
    justify-content:space-between;padding:14px 18px;
    border-radius:16px;font-size:15px;font-weight:400;
  }
  /* Bigger tap target for the caret on mobile via ::before hit-area */
  .nav__menu.is-open .nav__caret{position:relative}
  .nav__menu.is-open .nav__caret::before{
    content:"";position:absolute;inset:-18px -22px -18px -22px;
  }
  .nav__menu.is-open .nav__drop{
    display:flex;flex-direction:column;align-items:stretch;
  }
  .nav__menu.is-open .nav__link--drop{width:100%}
  /* Accordion dropdowns on mobile — inset pane inside the glass drawer */
  .nav__menu.is-open .nav__dropdown{
    display:block;
    position:static;transform:none;
    min-width:0;width:100%;
    margin:4px 0 6px;padding:6px 0;
    background:rgba(18,26,22,.70);
    border:1px solid rgba(255,253,250,.10);
    border-radius:14px;
    opacity:0;visibility:hidden;pointer-events:none;
    max-height:0;overflow:hidden;
    transition:opacity .25s var(--easing-out),max-height .35s var(--easing-out),visibility 0s linear .35s;
    box-shadow:inset 0 1px 0 rgba(255,253,250,.04);
    backdrop-filter:none;-webkit-backdrop-filter:none;
  }
  .nav__menu.is-open .nav__drop.is-open > .nav__dropdown{
    opacity:1;visibility:visible;pointer-events:auto;
    max-height:2000px;
    transition-delay:0s;
  }
  .nav__menu.is-open .nav__dropdown-list > li > a,
  .nav__menu.is-open .nav__brand-head,
  .nav__menu.is-open .nav__brand--single > a{
    padding:10px 18px;font-size:14px;
  }
  /* Brand single = una sola voce cliccabile, niente arrow */
  .nav__menu.is-open .nav__brand--single > a{padding:10px 18px;font-size:14px}

  /* Brand con flyout: la freccia diventa caret accordion */
  .nav__menu.is-open .nav__brand--has-sub > .nav__brand-head{
    justify-content:space-between;
  }
  .nav__menu.is-open .nav__brand-arrow{
    width:8px;height:8px;
    transform:rotate(135deg);transition:transform .3s var(--easing-out);
  }
  .nav__menu.is-open .nav__brand--has-sub.is-flyout-open .nav__brand-arrow{
    transform:rotate(-45deg);
  }

  /* Flyout su mobile = accordion verticale annidato (NON laterale) */
  .nav__menu.is-open .nav__flyout{
    position:static;transform:none;
    min-width:0;width:100%;padding:0;margin:0;
    background:rgba(18,26,22,.55);
    border:0;border-radius:10px;box-shadow:none;
    opacity:0;visibility:hidden;pointer-events:none;
    max-height:0;overflow:hidden;
    transition:opacity .25s var(--easing-out),max-height .35s var(--easing-out),visibility 0s linear .35s,padding .3s var(--easing-out),margin .3s var(--easing-out);
  }
  .nav__menu.is-open .nav__brand--has-sub.is-flyout-open > .nav__flyout{
    opacity:1;visibility:visible;pointer-events:auto;
    max-height:600px;padding:6px 0;margin:4px 0 6px;
    transition-delay:0s;
  }
  .nav__menu.is-open .nav__flyout li > a{
    padding:8px 18px 8px 36px;font-size:13px;
  }
  .nav__menu.is-open .nav__flyout-head{
    padding:6px 18px 8px 36px !important;font-size:11.5px !important;
  }
  .nav__menu.is-open .nav__dropdown-list > li > a:hover,
  .nav__menu.is-open .nav__brand-head:hover,
  .nav__menu.is-open .nav__brand--single > a:hover{
    padding-left:18px;
  }
  .nav__menu.is-open .nav__flyout li > a:hover{padding-left:42px}
}

.nav__search{
  display:flex;align-items:center;gap:10px;flex:none;
  background:var(--color-cream);color:var(--color-forest-900);
  padding:10px 18px;border-radius:var(--radius-pill);
  min-width:clamp(160px,22vw,280px);
  box-shadow:inset 0 0 0 1px rgba(28,28,28,.04);
}
.nav__search-icon{color:var(--color-forest);flex:none;opacity:.85}
.nav__search input{
  flex:1;min-width:0;background:transparent;border:0;outline:0;
  font-family:var(--font-sans);font-weight:400;font-size:14.5px;
  color:var(--color-ink-soft);
}
.nav__search input::placeholder{color:var(--color-forest-500);opacity:.85}

.nav__toggle{
  display:flex;flex-direction:column;gap:5px;padding:10px;
  color:var(--color-cream);background:rgba(255,253,250,.08);
  border-radius:14px;width:42px;height:42px;
  align-items:center;justify-content:center;flex:none;
}
.nav__toggle span{width:18px;height:1.5px;background:currentColor;display:block}
@media (min-width:1024px){.nav__toggle{display:none}}
@media (max-width:1023px){
  .nav__bar{gap:8px;padding:10px 14px}
  .nav__logo{margin-right:auto}
  .nav__logo-img{height:38px}
  .nav__search{min-width:0;flex:none;padding:8px 14px;max-width:230px}
  .nav__search input{font-size:14px;width:150px}
}
@media (max-width:640px){
  .nav__search input{display:none}
  .nav__search{min-width:0;flex:none;padding:10px;justify-content:center;max-width:none}
}

/* ============================================================
   GLASS NAV — universal
   All pages share a forest-tinted translucent bar so the cream
   menu text stays legible across dark and light hero backgrounds.
   Qualy (light hero) bumps the tint in .nav__bar above.
   ============================================================ */
/* Dropdowns — match glass aesthetic */
.nav__dropdown{
  background:rgba(28,40,34,.82);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border:1px solid rgba(255,253,250,.10);
  box-shadow:0 18px 48px rgba(0,0,0,.35),0 2px 8px rgba(0,0,0,.18);
}

/* Search — glass-compatible pill */
.nav__search{
  background:rgba(255,253,250,.14);
  box-shadow:inset 0 0 0 1px rgba(255,253,250,.18);
  color:var(--color-cream);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.nav__search-icon{color:var(--color-cream);opacity:.85}
.nav__search input{color:var(--color-cream)}
.nav__search input::placeholder{color:rgba(255,253,250,.62)}

/* Mobile toggle — keep cream icon over glass */
.nav__toggle{color:var(--color-cream)}

/* Fallback — browsers without backdrop-filter */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){
  .nav__bar{background:rgba(43,61,53,.88)}
  body.qly .nav__bar{background:rgba(43,61,53,.92)}
  .nav__dropdown{background:var(--color-forest-900)}
  .nav__search{background:rgba(255,253,250,.16)}
}

/* -----  HERO  ------------------------------------------------- */
.hero{
  position:relative;min-height:100vh;min-height:100svh;
  padding:calc(var(--nav-h) + 40px) 0 80px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;color:var(--color-cream);
  background:#4a3a20; /* warm honey fallback */
  text-align:center;
}
.hero__media{position:absolute;inset:0;overflow:hidden;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.03);will-change:transform}
.hero__overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(28,28,28,.35) 0%, rgba(28,28,28,.15) 40%, rgba(28,28,28,.65) 100%);
}
.hero__content{position:relative;z-index:3;width:100%;display:flex;flex-direction:column;align-items:center}
.hero__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:var(--fs-display);line-height:1.05;letter-spacing:-.01em;
  max-width:var(--measure-display-wide);
  color:var(--color-cream);
  text-align:center;
}
.hero__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
  color:inherit;
}
.hero__actions{margin-top:var(--sp-7);display:flex;gap:16px;flex-wrap:wrap;align-items:center;justify-content:center}

/* -----  SECTION: RIVOLUZIONE (text + spoon + brands)  ------- */
.rivoluzione{background:var(--color-cream)}
.rivoluzione__inner{
  display:grid;gap:var(--sp-8);
  grid-template-columns:1fr;align-items:center;
}
@media (min-width:900px){
  .rivoluzione__inner{grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px)}
  /* min-width:0 indispensabile per evitare che il carousel max-content forzi expanding del column */
  .rivoluzione__inner > *{min-width:0}
}
.rivoluzione__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:var(--fs-h2);line-height:1.1;letter-spacing:-.005em;
  color:var(--color-forest);
}
.rivoluzione__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
  color:var(--color-forest);
}
.rivoluzione__text{font-family:var(--font-sans);font-weight:var(--body-weight);font-size:var(--body-size);line-height:var(--body-lh);color:var(--color-ink-soft);margin-top:var(--sp-5);max-width:var(--measure-lede)}
.rivoluzione__text + .rivoluzione__text{margin-top:var(--sp-4)}
.rivoluzione__text em.emph{font-weight:400}
.rivoluzione__cta{margin-top:var(--sp-7);display:flex;align-items:center}
.rivoluzione__visual{
  position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:var(--sp-6);
  width:100%;min-width:0;  /* min-width:0 = lascia il grid column shrinkare correttamente */
}
.rivoluzione__spoon{
  position:relative;width:100%;aspect-ratio:5/3;max-width:480px;
  display:flex;align-items:center;justify-content:center;
}
.rivoluzione__spoon-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;object-position:center;
}
/* Carrossel infinito dei 8 logo brand — 3 visibili alla volta in loop seamless */
.rivoluzione__carousel{
  position:relative;width:100%;
  overflow:hidden;
  /* Mask graduale ai lati per effetto fade */
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);
}
.rivoluzione__carousel-track{
  display:flex;align-items:center;
  width:max-content;
  animation:rivCarousel 36s linear infinite;
  gap:0;
}
.rivoluzione__carousel:hover .rivoluzione__carousel-track{animation-play-state:paused}
.rivoluzione__carousel-item{
  flex:0 0 auto;
  width:clamp(170px,19vw,240px);
  height:clamp(130px,14vw,180px);
  display:flex;align-items:center;justify-content:center;
  padding:0;
  transition:transform .3s var(--easing-out),opacity .3s;
}
.rivoluzione__carousel-item img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  border-radius:var(--radius-card); /* cantos arredondati per seguire il visual degli altri card */
  opacity:.85;
  transition:opacity .3s var(--easing-out),transform .3s var(--easing-out);
}
.rivoluzione__carousel-item:hover img{opacity:1;transform:scale(1.06)}

/* Animation: percorre metà del track (l'altra metà è la copia per loop seamless) */
@keyframes rivCarousel{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

@media (prefers-reduced-motion:reduce){
  .rivoluzione__carousel-track{animation:none}
}
.rivoluzione__brands img:hover{opacity:1;transform:translateY(-2px)}

/* -----  SECTION: STATS (4 cards: photo · text · photo · text) */
.stats{background:var(--color-cream);padding-top:0}
.stats__grid{
  display:grid;gap:var(--sp-5);
  grid-template-columns:1fr;
  align-items:stretch; /* tutti i card stretch alla stessa altezza nel row */
}
@media (min-width:700px){.stats__grid{grid-template-columns:1fr 1fr}}
@media (min-width:1100px){.stats__grid{grid-template-columns:repeat(4,1fr)}}
.stat-card{
  position:relative;aspect-ratio:4/5;
  border-radius:var(--radius-card-lg);overflow:hidden;
  display:flex;
  isolation:isolate;
}
/* Tutti i card (photo + text) usano lo stesso aspect-ratio 4/5
   per garantire allineamento perfetto top/bottom dei 4 card. */
.stat-card--photo{
  background:var(--color-cream-warm);
  padding:0;
}
.stat-card--photo img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform 1.2s var(--easing-out);
}
.stat-card--photo:hover img{transform:scale(1.04)}

.stat-card--text{
  padding:clamp(24px,2.6vw,32px);
  flex-direction:column;justify-content:flex-start;
  gap:0; /* uso margini espliciti per controllo preciso del spacing */
}
.stat-card--forest{
  background:var(--color-forest);
  color:var(--color-cream);
}
.stat-card--cream{
  background:var(--color-cream-warm);
  color:var(--color-forest-900);
}

.stat-card__num{
  font-family:var(--font-sans);font-weight:700;
  font-size:clamp(52px,5.5vw,96px);line-height:.98;letter-spacing:-.02em;
  color:inherit;
  display:flex;align-items:baseline;gap:6px;
}
.stat-card--cream .stat-card__num{color:var(--color-forest)}
.stat-card__unit{
  font-family:var(--font-sans);font-weight:700;font-style:normal;
  font-size:clamp(34px,3.4vw,64px);letter-spacing:-.02em;
}
.stat-card__label{
  font-family:var(--font-sans);font-size:13px;line-height:1.3;
  letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  margin-top:2px;max-width:18ch; /* gap stretto col numero per coesione visiva */
  color:inherit;
}
.stat-card__desc{
  font-family:var(--font-sans);font-size:13.5px;line-height:1.5;
  max-width:34ch;margin-top:22px;opacity:.9;font-weight:350; /* breathing room più ampio dopo il label */
  color:inherit;
}

/* -----  SECTION: ALLEATO (Sage banner, image + text)  ------- */
.alleato{padding:clamp(32px,5vw,72px) 0}
.alleato__band{
  background:var(--color-sage-300);
  border-radius:var(--radius-card-lg);
  padding:clamp(28px,3.5vw,48px);
  color:var(--color-forest-900);
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:1fr;gap:clamp(24px,3vw,48px);
  align-items:stretch; /* riempi tutta l'altezza della row, niente fascia sage sotto l'immagine */
}
@media (min-width:900px){.alleato__band{grid-template-columns:1fr 1.15fr;padding:clamp(36px,4vw,56px)}}
.alleato__media{
  position:relative;
  border-radius:calc(var(--radius-card-lg) - 12px);
  overflow:hidden;
  background:var(--color-sage);
  min-height:480px; /* fallback: evita collasso se row è vuota */
}
@media (max-width:899px){
  /* Mobile only: aspect-ratio 4/5 portrait per dare altezza visibile */
  .alleato__media{
    aspect-ratio:4/5;
    min-height:0;
  }
}
/* Desktop (≥900px): NIENTE aspect-ratio. Il grid con align-items:stretch
   fa il lavoro — la cella si estende all'altezza della row (= alto come il testo). */
.alleato__media img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.alleato__content{
  padding:clamp(8px,2vw,28px) clamp(8px,2vw,20px);
  text-align:left;
}
@media (min-width:900px){.alleato__content{text-align:right}}
.alleato__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:var(--fs-h2);line-height:1.1;letter-spacing:-.005em;
  color:var(--color-forest);
  max-width:var(--measure-display);
}
@media (min-width:900px){.alleato__title{margin-left:auto}}
.alleato__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
}
.alleato__text{
  font-family:var(--font-sans);font-weight:var(--body-weight);
  font-size:var(--body-size);line-height:var(--body-lh);
  color:var(--color-ink-soft);opacity:.95;
  margin-top:var(--sp-5);max-width:var(--measure-lede);
}
@media (min-width:900px){.alleato__text{margin-left:auto}}
.alleato__cta{margin-top:var(--sp-6)}

/* -----  SECTION: DOLCEZZA (product slider)  ------------------ */
.dolcezza{background:var(--color-cream)}
.dolcezza__head{text-align:center !important;max-width:var(--rail-wide);margin:0 auto var(--sp-7)}
.dolcezza__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:var(--fs-h2);line-height:1.1;letter-spacing:-.005em;
  color:var(--color-forest);
  text-wrap:balance;
}
.dolcezza__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
}
.dolcezza__sub{
  font-family:var(--font-sans);font-weight:var(--lede-weight);
  font-size:var(--lede-size);line-height:var(--lede-lh);color:var(--color-ink-soft);
  margin:var(--sp-7) auto 0;max-width:var(--measure-lede);text-align:center !important;
}
.dolcezza__sub em.emph{font-weight:400}
/* --- Dolcezza: slider (3 visible, arrow navigation) --- */
.slider{position:relative;margin-top:var(--sp-7)}
.slider__track-wrap{overflow:hidden;margin:0 clamp(0px,6vw,80px)}
/* Quando le frecce sono nascoste, il track usa l'intera larghezza
   → i prodotti visibili diventano automaticamente più grandi */
.slider--no-arrows .slider__track-wrap{margin:0}
.slider__track{
  display:flex;gap:clamp(16px,2vw,32px);
  transition:transform .65s var(--easing-out);
  will-change:transform;
}
.product{
  flex:0 0 calc((100% - (clamp(16px,2vw,32px) * 2)) / 3);
  position:relative;display:flex;flex-direction:column;align-items:center;gap:18px;
  padding:20px 10px;cursor:pointer;
  transition:transform .5s var(--easing-out);
}
@media (max-width:900px){.product{flex:0 0 calc((100% - clamp(16px,2vw,32px)) / 2)}}
@media (max-width:600px){.product{flex:0 0 100%}}
/* Default: layout-box dei slide invariato (slider track resta corretto).
   Lo scale viene applicato SOLO al photo-wrap, così i calcoli del JS
   restano accurati e mostrano sempre 3 slide per pagina. */
.product{
  opacity:.6;
  transition:opacity .55s var(--easing-out);
}
.product:hover{opacity:.85}
.product__photo-wrap{
  width:100%;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  background:transparent;position:relative;
  transform:scale(.78);
  transition:transform .55s var(--easing-out);
}
.product:hover .product__photo-wrap{transform:scale(.82)}
.product__photo{
  max-width:92%;max-height:92%;width:auto;height:auto;
  object-fit:contain;
  filter:drop-shadow(0 8px 22px rgba(28,28,28,.14));
  transition:filter .55s var(--easing-out);
}
.product__name{
  transition:font-size .4s var(--easing-out),font-weight .4s var(--easing-out),color .4s var(--easing-out);
}

/* Magnify effect: slide centrale dominante (stile dock macOS).
   Scale ~50% maggiore rispetto ai slide laterali → contrasto chiaro. */
.product.is-center{opacity:1;z-index:2;position:relative}
.product.is-center .product__photo-wrap{
  transform:scale(1.18);
}
.product.is-center:hover .product__photo-wrap{transform:scale(1.22)}
.product.is-center .product__photo{
  filter:drop-shadow(0 22px 50px rgba(28,28,28,.32));
}
.product.is-center .product__name{
  font-size:17px;font-weight:600;color:var(--color-forest-900);
}
.product__name{
  font-family:var(--font-sans);font-weight:400;font-size:14px;
  letter-spacing:.02em;color:var(--color-forest);
}

/* Slider nav arrows (filled sage circles, cream chevron) */
.slider__btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:var(--color-sage);color:var(--color-cream);
  display:flex;align-items:center;justify-content:center;
  border:0;cursor:pointer;z-index:3;
  box-shadow:0 2px 8px rgba(28,28,28,.1);
  transition:background .3s var(--easing-out),color .3s,transform .3s var(--easing-out),opacity .3s;
}
.slider__btn:hover{background:var(--color-sage-700);color:var(--color-cream);transform:translateY(-50%) scale(1.08)}
.slider__btn[disabled]{opacity:.45;cursor:not-allowed}
.slider__btn[disabled]:hover{transform:translateY(-50%);background:var(--color-sage);color:var(--color-cream)}
.slider__btn--prev{left:0}
.slider__btn--next{right:0}
@media (max-width:900px){
  .slider__btn{width:40px;height:40px}
  .slider__track-wrap{margin:0 52px}
  .slider--no-arrows .slider__track-wrap{margin:0}
}

/* Slider dots */
.slider__dots{
  display:flex;gap:8px;justify-content:center;
  margin-top:var(--sp-6);
}
.slider__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--color-line);border:0;padding:0;cursor:pointer;
  transition:background .3s,width .3s;
}
.slider__dot.is-active{background:var(--color-sage);width:24px;border-radius:4px}

.dolcezza__foot{text-align:center !important;margin-top:var(--sp-6)}

/* -----  SECTION: SOLUZIONI (text + 2x2 market grid)  --------- */
.soluzioni{background:var(--color-cream)}
.soluzioni__inner{
  display:grid;gap:clamp(28px,4vw,72px);
  grid-template-columns:1fr;align-items:center;
}
@media (min-width:900px){.soluzioni__inner{grid-template-columns:1fr 1.1fr}}
.soluzioni__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:var(--fs-h2);line-height:1.1;letter-spacing:-.005em;
  color:var(--color-forest);
}
.soluzioni__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
}
.soluzioni__text{
  font-family:var(--font-sans);font-weight:var(--body-weight);
  font-size:var(--body-size);line-height:var(--body-lh);color:var(--color-ink-soft);
  margin-top:var(--sp-6);max-width:var(--measure-lede);
}

/* 2x2 markets grid */
.mercati__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(14px,1.5vw,22px);
}
.mercato{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  border-radius:var(--radius-card);
  display:block;isolation:isolate;
  transition:transform .4s var(--easing-out);
}
.mercato:hover{transform:translateY(-4px)}
.mercato img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform 1.2s var(--easing-out);
}
.mercato:hover img{transform:scale(1.06)}
.mercato::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(65,89,76,0) 40%,rgba(65,89,76,.55) 70%,rgba(43,61,53,.85) 100%);
  z-index:1;pointer-events:none;
}
.mercato__label{
  position:absolute;left:0;right:0;bottom:clamp(18px,2vw,28px);
  z-index:2;color:var(--color-cream);
  font-family:var(--font-sans);font-weight:700;
  font-size:clamp(16px,1.3vw,20px);letter-spacing:.005em;
  text-align:center;
  text-shadow:0 1px 2px rgba(0,0,0,.25);
}

/* -----  FOOTER  ---------------------------------------------- */
.footer{background:var(--color-forest-900);color:var(--color-cream);padding:80px 0 32px;position:relative;overflow:hidden}
.footer__top{
  display:grid;gap:var(--sp-7);grid-template-columns:1fr;
  padding-bottom:var(--sp-7);border-bottom:1px solid var(--color-line-on-forest);
}
@media (min-width:900px){.footer__top{grid-template-columns:1.6fr repeat(3,1fr)}}
.footer__brand{max-width:360px}
.footer__brand-mark{width:160px;height:auto;margin-bottom:24px;display:block}
.footer__brand-text{font-family:var(--font-display);font-size:20px;line-height:1.35;color:var(--color-cream);font-style:italic}
.footer__brand-sub{margin-top:14px;font-size:13.5px;line-height:1.6;opacity:.7;max-width:34ch}
.footer__social{margin-top:24px;display:flex;gap:10px}
.footer__social a{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--color-line-on-forest);
  display:flex;align-items:center;justify-content:center;transition:background .3s,color .3s,border-color .3s;
}
.footer__social a:hover{background:var(--color-sage);color:var(--color-forest-900);border-color:transparent}
.footer__col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-sage);margin-bottom:22px;font-weight:500}
.footer__col h5 a{color:inherit;transition:opacity .3s}
.footer__col h5 a:hover{opacity:.7}
.footer__col ul{display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:14px;opacity:.75;transition:opacity .3s,color .3s}
.footer__col a:hover{opacity:1;color:var(--color-sage)}
.footer__contact li{font-size:13.5px;line-height:1.6;opacity:.75;margin-bottom:10px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:var(--sp-6);flex-wrap:wrap;font-size:12px;opacity:.55}
.footer__bottom a{text-decoration:underline;text-underline-offset:3px}

/* -----  SCROLL REVEAL  --------------------------------------- */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 1s var(--easing-out),transform 1s var(--easing-out)}
[data-reveal].is-in{opacity:1;transform:translateY(0)}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}
[data-reveal-delay="5"]{transition-delay:.4s}

/* -----  REDUCED MOTION  -------------------------------------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1;transform:none}
}

/* -----  RESPONSIVE HELPERS  ---------------------------------- */
@media (max-width:900px){
  .hero__title{font-size:clamp(44px,10vw,72px)}
  .mercati__grid{gap:12px}
  .stat-card{aspect-ratio:1/1}
}
@media (max-width:600px){
  .mercati__grid{grid-template-columns:1fr}
}

/* ═════════════════════════════════════════════════════════
   NVI LANG SWITCHER
   ═════════════════════════════════════════════════════════ */
.nav__lang { display:inline-flex; align-items:center; }
.nvi-lang-switcher {
  list-style:none; margin:0; padding:0;
  display:inline-flex; gap:12px; align-items:center;
  font-size:12px; letter-spacing:.12em; text-transform:uppercase;
}
.nvi-lang-switcher li { display:inline-flex; }
.nvi-lang-switcher a {
  color: var(--color-cream, #FFFDFA);
  opacity: .65;
  text-decoration: none;
  padding: 4px 6px;
  transition: opacity .25s ease;
}
.nvi-lang-switcher a:hover { opacity: 1; }
.nvi-lang-switcher .current-lang a,
.nvi-lang-switcher .is-active a { opacity: 1; font-weight: 500; }

/* ═════════════════════════════════════════════════════════
   ACCESSIBILITÀ — Skip Link & Screen Reader Only
   Il link "Salta al contenuto" è invisibile ma accessibile a
   screen reader e tastiera (compliance WCAG 2.1 SC 2.4.1).
   Diventa visibile solo quando focalizzato con Tab.
   ═════════════════════════════════════════════════════════ */
.sr-only,
.skip-link {
  position: absolute !important;
  left: -10000px !important;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link:focus {
  position: fixed !important;
  left: 16px !important;
  top: 16px !important;
  width: auto;
  height: auto;
  clip: auto;
  padding: 14px 22px;
  background: var(--color-forest-900);
  color: var(--color-cream);
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: .04em;
  border-radius: 12px;
  border: 2px solid var(--color-cream);
  z-index: 9999;
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}

/* Fallback testuale quando un brand non ha logo */
.lp-brands-index__fallback{
  display:flex; align-items:center; justify-content:center;
  width:100%; height:100%; min-height:80px;
  font-family: var(--font-display, serif);
  font-size: 18px; font-style: italic;
  color: var(--color-forest, #41594C);
  text-align: center; padding: 12px;
}

/* ============================================================
   PARALLAX VIDEO / SEQUENCE — modalità arte laterale prodotti
   Stili condivisi per tutti i brand. Ogni brand mantiene il suo
   contenitore .X-manifesto__art con CSS scoped, queste regole
   si applicano via modificatori --parallax-video / --video.
   ============================================================ */

/* Sequence: container portrait 9:16 con fondo brand-specific (configurato da ACF
   campo art_sequence_bg, applicato via inline style sul wrapper).
   Il #010101 qui è solo FALLBACK se manca lo style inline.
   Match generico: qualunque wrapper brand che termina in --parallax-video
   (oks-manifesto__art--parallax-video, dos-manifesto__media--parallax-video, ecc.) */
[class*="--parallax-video"]:not(img):not(video){
  aspect-ratio: 9/16;
  background: #010101; /* fallback — sovrascritto da inline style brand-specific */
  max-width: 480px;
  width: 100%;
  margin-left: auto;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}
[class*="--parallax-video"] img,
[class*="--parallax-video"] .parallax-img{
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block; padding: 0; transform: none;
  border-radius: 0;
  filter: none;
}
[class*="--parallax-video"] [data-parallax-video]{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
}

/* La sezione padre riceve il colore brand-specific via JS (style inline con !important).
   La classe .has-parallax-video è solo un marker, il colore arriva dal data-parallax-bg. */

/* Video MP4: stesso formato 9:16, fondo brand-specific (stesso campo art_sequence_bg).
   Il #010101 qui è solo fallback. */
[class*="--video"]:not([class*="--parallax-video"]):not(video):not(img){
  aspect-ratio: 9/16;
  background: #010101; /* fallback */
  max-width: 480px;
  width: 100%;
  margin-left: auto;
  position: relative;
  overflow: hidden;
}
[class*="--video"]:not([class*="--parallax-video"]) video,
[class*="--video"] .parallax-video-el{
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}
