/* ==========================================================================
   AZIENDA AGRICOLA FRANCESCO LOI — Design System
   Sito statico, accessibile (WCAG 2.1 AA), responsive, senza dipendenze.
   Organizzazione: 1) Font  2) Token  3) Reset  4) Base  5) Utility
   6) Layout  7) Header/Nav  8) Bottoni  9) Hero  10) Componenti
   11) Form  12) Footer  13) Lightbox  14) Responsive  15) Motion/Print
   ========================================================================== */

/* 1) FONT SELF-HOSTED ------------------------------------------------------ */
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Fraunces";src:url("../fonts/fraunces-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* 2) DESIGN TOKEN ---------------------------------------------------------- */
:root{
  /* Palette — "Salvia & Calce": calce luminosa, verdi salvia/bosco desaturati, accento argilla */
  --olive-900:#28311Fcc; --olive-900s:#28311F;  /* verde bosco profondo (sezione scura intensa) */
  --olive-800:#37422F;   /* verde bosco (sezione scura) */
  --olive-700:#4A5840;   /* brand primario — salvia profonda (testo/bottoni su chiaro) */
  --olive-600:#5E6E4C;
  --olive-500:#7C8C64;   /* salvia */
  --olive-400:#A2AE8C;   /* salvia tenue */
  --cream-50:#F7F6F1;    /* sfondo pagina — calce/off-white */
  --cream-100:#EFEEE4;   /* superficie alternata */
  --cream-200:#E6E5D8;
  --sand-300:#D8D6C5;
  --wine-700:#A85E35;    /* argilla — accento caldo */
  --wine-600:#BC7345;
  --terra-500:#B97A4C;   /* terracotta tenue */
  --gold-500:#DBC18C;    /* oro tenue — leggibile (AA) sui verdi scuri */

  /* Ruoli semantici */
  --bg:var(--cream-50);
  --bg-alt:var(--cream-100);
  --surface:#FFFFFF;
  --ink:#2B2F26;         /* testo principale su calce */
  --ink-soft:#5C6151;    /* testo secondario — grigio-salvia */
  --line:#E1DFD2;        /* bordi sottili (hairline) su chiaro */
  --brand:var(--olive-700);
  --accent:var(--wine-700);
  --on-dark:#EEF0E6;     /* testo sui verdi scuri */
  --on-dark-soft:#C4C9B5;
  --focus:#5E6E48;

  /* Tipografia */
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --fs-xs:.78rem; --fs-sm:.875rem;
  --fs-base:clamp(1rem,.96rem + .2vw,1.12rem);
  --fs-lead:clamp(1.12rem,1.02rem + .45vw,1.35rem);
  --fs-h3:clamp(1.35rem,1.18rem + .8vw,1.85rem);
  --fs-h2:clamp(1.85rem,1.5rem + 1.7vw,2.85rem);
  --fs-h1:clamp(2.3rem,1.8rem + 2.5vw,3.7rem);
  --fs-display:clamp(2.8rem,2rem + 4.2vw,5.5rem);
  --lh-tight:1.05; --lh-snug:1.22; --lh:1.7;
  --tracking:.18em;

  /* Spaziatura / layout — più aria per un look aperto */
  --gutter:clamp(1.15rem,4vw,2.75rem);
  --maxw:1180px; --maxw-narrow:740px; --maxw-wide:1320px;
  --section-pad:clamp(4.25rem,2.6rem + 7vw,8.5rem);
  --gap:clamp(1.4rem,2.6vw,2.25rem);

  /* Forma — ombre leggerissime, ci appoggiamo a bordi sottili */
  --r-sm:8px; --r:16px; --r-lg:24px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(40,49,31,.05),0 1px 3px rgba(40,49,31,.04);
  --shadow:0 6px 20px rgba(40,49,31,.06),0 12px 36px rgba(40,49,31,.05);
  --shadow-lg:0 22px 56px rgba(40,49,31,.13);
  --t:.3s cubic-bezier(.4,0,.2,1);
  --t-slow:.6s cubic-bezier(.4,0,.2,1);
}

/* 3) RESET ----------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
html:focus-within{scroll-padding-top:6rem}
body{min-height:100svh;line-height:var(--lh);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,picture,svg,video{display:block;max-width:100%}
img{height:auto}
input,button,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:0}
ul[role="list"],ol[role="list"]{list-style:none;padding:0}
a{color:inherit}
:where(h1,h2,h3,h4){text-wrap:balance}
p{text-wrap:pretty}

/* 4) BASE ------------------------------------------------------------------ */
body{
  font-family:var(--font-body);
  font-size:var(--fs-base);
  color:var(--ink);
  background:var(--bg);
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:var(--lh-snug);color:var(--brand);letter-spacing:-.015em}
h1{font-size:var(--fs-h1);line-height:var(--lh-tight);font-weight:400}
h2{font-size:var(--fs-h2);font-weight:400}
h3{font-size:var(--fs-h3)}
a{color:var(--accent);text-underline-offset:.18em;text-decoration-thickness:1px}
a:hover{text-decoration-color:rgba(110,36,54,.4)}
strong,b{font-weight:600}
::selection{background:var(--olive-700);color:var(--cream-100)}

/* Focus visibile coerente */
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;border-radius:3px}
.section--olive :focus-visible,.site-footer :focus-visible,.hero__panel :focus-visible{outline-color:var(--cream-100)}

/* 5) UTILITY --------------------------------------------------------------- */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:1rem;top:-100%;z-index:1000;background:var(--olive-700);color:var(--cream-100);padding:.7rem 1.1rem;border-radius:0 0 var(--r-sm) var(--r-sm);font-weight:600;text-decoration:none;transition:top var(--t)}
.skip-link:focus{top:0}
.text-center{text-align:center}
[hidden]{display:none!important}

/* Animazione di comparsa (disattivata se reduced-motion o no-JS) */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity var(--t-slow),transform var(--t-slow)}
.js .reveal.is-visible{opacity:1;transform:none}

/* 6) LAYOUT ---------------------------------------------------------------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--maxw-narrow)}
.container--wide{max-width:var(--maxw-wide)}
.section{padding-block:var(--section-pad);background-image:radial-gradient(56% 46% at 8% -8%,rgba(124,140,100,.10),transparent 60%),radial-gradient(48% 48% at 94% 108%,rgba(168,94,53,.05),transparent 62%)}
.section--tight{padding-block:clamp(2.5rem,1.6rem + 4vw,4.5rem)}
.section--olive{background:var(--olive-800);color:var(--on-dark);background-image:radial-gradient(90% 80% at 100% 0,rgba(124,140,100,.34),transparent 58%),radial-gradient(72% 70% at 0 100%,rgba(28,34,18,.5),transparent 60%)}
.section--olive h2,.section--olive h3{color:var(--cream-100)}
.section--deep{background:radial-gradient(95% 78% at 82% 6%,rgba(94,110,72,.42),transparent 58%),radial-gradient(78% 66% at 6% 96%,rgba(16,22,10,.55),transparent 60%),var(--olive-900s);color:var(--on-dark)}
.section--deep h2,.section--deep h3{color:var(--cream-100)}
.section--alt{background:radial-gradient(58% 52% at 90% 4%,rgba(168,94,53,.06),transparent 60%),radial-gradient(56% 50% at 5% 98%,rgba(124,140,100,.13),transparent 62%),var(--bg-alt)}
.section--sand{background:linear-gradient(180deg,var(--cream-100),var(--cream-200))}

/* intestazione di sezione */
.section-head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3.25rem)}
.section-head--center{margin-inline:auto;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-body);font-weight:600;font-size:var(--fs-sm);letter-spacing:var(--tracking);text-transform:uppercase;color:var(--accent);margin-bottom:.9rem}
.eyebrow::before{content:"";width:1.8rem;height:1px;background:currentColor;opacity:.7}
.section-head--center .eyebrow::before{display:none}
.section--olive .eyebrow,.section--deep .eyebrow{color:var(--gold-500)}
.hero__eyebrow{color:var(--accent)}
.lead{font-size:var(--fs-lead);line-height:1.55;color:var(--ink-soft)}
.section--olive .lead,.section--deep .lead{color:var(--on-dark-soft)}

/* prosa long-form */
.prose{max-width:68ch}
.prose>*+*{margin-top:1.1em}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.4em}
.prose p,.prose li{font-size:var(--fs-base);line-height:var(--lh)}
.prose .lead{margin-bottom:.4em}
.prose ul{padding-left:1.2em}
.prose li{margin-top:.4em}

/* 7) HEADER / NAV ---------------------------------------------------------- */
/* PERF: header smerigliato ma più leggero da comporre durante lo scroll.
   Tolto saturate(130%) (impercettibile sul crema) e blur 9→6: il backdrop-filter
   si ri-rasterizza ad ogni frame di scroll, e blur+saturate è la combinazione più
   costosa. Resta l'effetto frosted (il blur), solo meno pesante per il compositor. */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,246,241,.82);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);transition:box-shadow var(--t),background var(--t)}
.site-header.is-scrolled{box-shadow:var(--shadow-sm);background:rgba(247,246,241,.94)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px}
.brand{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--brand);flex:none}
.brand__mark{display:inline-flex;align-items:center;color:var(--olive-700);flex:none}
.brand__mark svg{width:100%;height:100%}
.brand__logo{height:clamp(36px,3.6vw,44px);width:auto;display:block}
.brand__text{display:none}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.12rem;letter-spacing:.02em}
.brand__tag{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-soft);margin-top:.28rem}

.nav{display:flex;align-items:center;gap:clamp(.8rem,1.5vw,1.4rem)}
.nav__list{display:flex;align-items:center;gap:clamp(.65rem,1.2vw,1.25rem);list-style:none;padding:0}
.nav__link{font-size:.9rem;font-weight:500;color:var(--ink);text-decoration:none;padding:.4rem 0;position:relative;white-space:nowrap}
.nav__link::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.nav__link:hover::after,.nav__link[aria-current="page"]::after{transform:scaleX(1)}
.nav__link[aria-current="page"]{color:var(--brand)}
.site-header .nav__cta .btn{padding:.66em 1.25em;font-size:.9rem;white-space:nowrap}

.lang-switch{display:inline-flex;align-items:center;gap:.15rem;font-size:.85rem;font-weight:600;border:1px solid var(--line);border-radius:var(--r-pill);padding:.2rem;background:rgba(255,255,255,.5)}
.lang-switch a{text-decoration:none;color:var(--ink-soft);padding:.22rem .6rem;border-radius:var(--r-pill);line-height:1}
.lang-switch a[aria-current="true"]{background:var(--olive-700);color:var(--cream-100)}

.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--brand)}
.nav-toggle svg{width:24px;height:24px}
.nav-toggle .icon-close{display:none}
.nav-toggle[aria-expanded="true"] .icon-open{display:none}
.nav-toggle[aria-expanded="true"] .icon-close{display:block}

/* 8) BOTTONI --------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:var(--font-body);font-weight:600;font-size:.97rem;line-height:1;text-decoration:none;padding:.95em 1.6em;border-radius:var(--r-pill);border:1.5px solid transparent;transition:transform var(--t),background var(--t),color var(--t),border-color var(--t),box-shadow var(--t)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn svg{width:1.1em;height:1.1em;flex:none}
.btn--primary{background:var(--olive-700);color:var(--cream-100);box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--olive-800);box-shadow:var(--shadow)}
.btn--accent{background:var(--wine-700);color:#fff}
.btn--accent:hover{background:var(--wine-600)}
.btn--ghost{border-color:var(--olive-700);color:var(--olive-700)}
.btn--ghost:hover{background:var(--olive-700);color:var(--cream-100)}
.btn--light{background:var(--cream-100);color:var(--olive-800)}
.btn--light:hover{background:#fff}
.btn--outline-light{border-color:rgba(243,234,214,.55);color:var(--cream-100)}
.btn--outline-light:hover{background:rgba(243,234,214,.14);border-color:var(--cream-100)}
.btn--lg{font-size:1.02rem;padding:1.05em 1.9em}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem}

.textlink{display:inline-flex;align-items:center;gap:.4em;font-weight:600;color:var(--accent);text-decoration:none}
.textlink svg{width:1em;height:1em;transition:transform var(--t)}
.textlink:hover svg{transform:translateX(4px)}
.section--olive .textlink,.section--deep .textlink{color:var(--gold-500)}

/* 9) HERO (home) ----------------------------------------------------------- */
/* Hero immersivo: alto UNA schermata (header escluso), testo nel container,
   foto o VIDEO a tutta larghezza con velo calce per testo scuro leggibile. */
.hero{position:relative;isolation:isolate;overflow:hidden;display:flex;align-items:center;
  min-height:calc(100svh - 74px);background:var(--olive-800);color:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__media picture{display:block;width:100%;height:100%}
.hero__media img,.hero__media video{width:100%;height:100%;object-fit:cover;object-position:center 32%;will-change:transform}
/* velo SCURO elegante: la foto resta nitida (non sbiadita) e il testo chiaro è
   ben leggibile; il fondo scuro rende pulita la transizione con la sezione dopo. */
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(96deg,rgba(20,26,13,.86) 0%,rgba(20,26,13,.62) 30%,rgba(20,26,13,.2) 58%,rgba(20,26,13,.04) 82%),
            linear-gradient(0deg,rgba(20,26,13,.55),rgba(20,26,13,.12) 36%,transparent 60%)}
.hero__content{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;gap:1.2rem;padding-block:clamp(1.4rem,4vh,2.6rem)}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:var(--fs-sm);letter-spacing:var(--tracking);text-transform:uppercase;color:var(--gold-500)}
.hero__title{font-size:var(--fs-display);font-weight:400;color:var(--cream-50);line-height:1.04;max-width:12ch;letter-spacing:-.02em;text-shadow:0 2px 24px rgba(12,16,8,.4)}
.hero__title em{font-style:italic;color:var(--gold-500);font-weight:400}
.hero__lead{font-size:var(--fs-lead);color:rgba(238,240,230,.92);max-width:46ch;line-height:1.6;text-shadow:0 1px 12px rgba(12,16,8,.35)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.5rem}
/* bottoni chiari sugli hero scuri (home + interni) */
.hero .btn--primary,.page-hero--media .btn--primary{background:var(--cream-50);color:var(--olive-800);box-shadow:0 8px 24px rgba(12,16,8,.28)}
.hero .btn--primary:hover,.page-hero--media .btn--primary:hover{background:#fff}
.hero .btn--ghost,.page-hero--media .btn--ghost{border-color:rgba(243,234,214,.6);color:var(--cream-100)}
.hero .btn--ghost:hover,.page-hero--media .btn--ghost:hover{background:rgba(243,234,214,.14);border-color:var(--cream-100);color:#fff}
.hero__scroll{position:absolute;left:50%;transform:translateX(-50%);bottom:1.25rem;z-index:2;display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.hero__scroll svg{width:1rem;height:1rem;animation:nudge 2s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* hero interno (pagine secondarie) */
.page-hero{background:var(--olive-700);color:var(--on-dark);background-image:radial-gradient(110% 130% at 100% 0,rgba(107,112,73,.4),transparent 55%);padding-block:clamp(3rem,2rem + 6vw,6rem)}
.page-hero__inner{max-width:60ch}
.page-hero__title{color:var(--cream-100);font-size:var(--fs-h1)}
.page-hero__lead{margin-top:1.1rem;font-size:var(--fs-lead);color:var(--on-dark-soft);line-height:1.55}
.breadcrumb{font-size:.85rem;color:var(--on-dark-soft);margin-bottom:1.1rem}
.breadcrumb a{color:var(--on-dark-soft);text-decoration:none}
.breadcrumb a:hover{color:var(--cream-100)}

/* 9b) HERO IMMERSIVO — pagine interne: foto o video a tutta larghezza ------- */
/* Velo CHIARO (calce) per testo scuro leggibile su foto, video e segnaposto.
   Per inserire il media reale, sostituire il blocco .placeholder dentro
   .page-hero__media con <picture> o <video>. */
.page-hero--media{position:relative;isolation:isolate;overflow:hidden;display:flex;align-items:flex-end;
  /* min alzato a 550 (> del contenuto più alto, Esperienze ~538) così TUTTE le hero foto hanno la stessa altezza */
  min-height:clamp(550px,64vh,560px);padding:0;background:var(--bg)}
.page-hero__media{position:absolute;inset:0;z-index:0}
.page-hero__media picture{display:block;width:100%;height:100%}
.page-hero__media img,.page-hero__media video{width:100%;height:100%;object-fit:cover;object-position:center 40%}
/* velo SCURO (non più calce): foto nitida, testo chiaro leggibile, fondo scuro
   che si raccorda in modo pulito con la sezione successiva. */
.page-hero--media::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(0deg,rgba(20,26,13,.9) 0%,rgba(20,26,13,.5) 40%,rgba(20,26,13,.1) 76%,transparent),
            linear-gradient(90deg,rgba(20,26,13,.5),transparent 55%)}
.page-hero__content{position:relative;z-index:2;width:100%;padding-block:clamp(2.6rem,2rem + 4vw,4.6rem)}
.page-hero--media .page-hero__title{color:var(--cream-50);text-shadow:0 2px 22px rgba(12,16,8,.4)}
.page-hero--media .page-hero__lead{color:rgba(238,240,230,.92);max-width:56ch;text-shadow:0 1px 12px rgba(12,16,8,.3)}
.page-hero--media .breadcrumb,.page-hero--media .breadcrumb a{color:rgba(238,240,230,.8)}
.page-hero--media .breadcrumb a:hover{color:var(--cream-100)}
.page-hero--media .btn-row{margin-top:1.7rem}
.page-hero--media .hero__scroll{left:auto;right:var(--gutter);bottom:1.15rem;z-index:2;color:var(--ink-soft)}
@media (max-width:600px){
  .page-hero--media{min-height:clamp(330px,54vh,460px)}
  .page-hero--media .hero__scroll{display:none}
}

/* 10) COMPONENTI ----------------------------------------------------------- */
/* griglia pilastri/valori */
.grid{display:grid;gap:var(--gap)}
.pillars{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.pillar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.4rem,2.5vw,2rem);box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pillar__icon{width:54px;height:54px;display:grid;place-items:center;border-radius:50%;background:var(--cream-100);color:var(--olive-700);margin-bottom:1.1rem}
.pillar__icon svg{width:28px;height:28px}
.pillar h3{font-size:1.25rem;margin-bottom:.5rem}
.pillar p{color:var(--ink-soft);font-size:.97rem;line-height:1.55}
.section--olive .pillar{background:rgba(243,234,214,.06);border-color:rgba(243,234,214,.16)}
.section--olive .pillar p{color:var(--on-dark-soft)}
.section--olive .pillar__icon{background:rgba(243,234,214,.12);color:var(--cream-100)}

/* feature: media + testo affiancati */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,4rem);align-items:center}
.feature--reverse .feature__media{order:2}
.feature__body{max-width:54ch}
.feature__body h2{margin-bottom:1rem}
.feature__body>p+p{margin-top:1rem}
.feature__body .btn-row,.feature__body .textlink{margin-top:1.6rem}
.feature__media .media,.feature__media .placeholder{aspect-ratio:4/5}
.feature--wide .feature__media .media,.feature--wide .feature__media .placeholder{aspect-ratio:3/4}

/* media + placeholder */
.media{position:relative;overflow:hidden;border-radius:var(--r-lg);background:var(--cream-200);box-shadow:var(--shadow)}
.media picture{display:block;width:100%;height:100%}
.media img,.media video{width:100%;height:100%;object-fit:cover}
.media--square{aspect-ratio:1}
.media--portrait{aspect-ratio:4/5}
.media--wide{aspect-ratio:16/10}
.media--frame{border:1px solid var(--line)}
.figure{margin:0}
.figure figcaption,.media__caption{font-size:.82rem;color:var(--ink-soft);margin-top:.6rem;font-style:italic}

/* TILE ILLUSTRATA — pannello grafico a tema (niente foto): gradiente caldo,
   trama a "acini/terra", icona a tema e didascalia. Sostituisce i vecchi segnaposto. */
.placeholder{position:relative;overflow:hidden;border-radius:var(--r-lg);display:grid;place-items:center;text-align:center;
  color:var(--olive-700);border:1px solid var(--line);
  background:
    radial-gradient(circle at 22% 26%,rgba(74,88,64,.08) 0 3px,transparent 4px) 0 0/34px 34px,
    radial-gradient(circle at 68% 72%,rgba(168,94,53,.06) 0 2.5px,transparent 4px) 0 0/46px 46px,
    radial-gradient(130% 120% at 82% 6%,var(--cream-100),var(--cream-200) 60%,var(--sand-300))}
.placeholder::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 60% at 84% 12%,rgba(219,193,140,.22),transparent 70%)}
.placeholder__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.8rem;padding:1.7rem}
.placeholder__icon{width:clamp(46px,7vw,72px);height:clamp(46px,7vw,72px);opacity:.92;color:var(--olive-500)}
.placeholder__label{font-family:var(--font-display);font-size:clamp(1rem,1.6vw,1.2rem);letter-spacing:.005em;color:var(--brand);max-width:24ch;font-weight:500;line-height:1.25}
.placeholder__tag{display:none}

/* HERO GRAFICO — scena illustrata "wine country" dipinta in CSS (colline, pale,
   filari, grappolo, sole), niente immagini. Riempie il livello media dell'hero. */
.hero-art{position:relative;height:100%;overflow:hidden;
  background:
    radial-gradient(60% 55% at 82% 4%,rgba(219,193,140,.4),transparent 62%),
    radial-gradient(66% 70% at 10% 102%,rgba(124,140,100,.26),transparent 66%),
    linear-gradient(165deg,var(--cream-50),var(--cream-100) 56%,var(--cream-200))}
.hero-art__sun{position:absolute;top:9%;left:60%;width:clamp(70px,9vw,120px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(219,193,140,.85),rgba(219,193,140,.12) 60%,transparent 72%)}
.hero-art::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.82;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 300' preserveAspectRatio='xMidYMax slice'%3E%3Cpath d='M0 150 C200 110 380 170 560 142 S920 100 1200 160 L1200 300 0 300Z' fill='%237C8C64' fill-opacity='0.14'/%3E%3Cpath d='M0 188 C220 152 470 208 760 174 S1080 158 1200 190 L1200 300 0 300Z' fill='%235E6E4C' fill-opacity='0.14'/%3E%3Cpath d='M0 226 C260 198 520 242 820 214 S1100 206 1200 230 L1200 300 0 300Z' fill='%234A5840' fill-opacity='0.16'/%3E%3Cpath d='M0 150 C200 110 380 170 560 142 S920 100 1200 160' fill='none' stroke='%234A5840' stroke-width='2' opacity='0.35'/%3E%3Cg stroke='%2337422F' stroke-width='2' fill='none' opacity='0.5' stroke-linecap='round'%3E%3Cpath d='M250 122 V96 M250 96 l-11 -6 M250 96 l12 -5 M250 96 l-1 13'/%3E%3Cpath d='M372 114 V88 M372 88 l-11 -6 M372 88 l12 -5 M372 88 l-1 13'/%3E%3Cpath d='M474 132 V106 M474 106 l-11 -6 M474 106 l12 -5 M474 106 l-1 13'/%3E%3C/g%3E%3Cg stroke='%234A5840' stroke-width='2.2' fill='none' opacity='0.38' stroke-linecap='round'%3E%3Cpath d='M0 58 C60 54 110 78 150 68 S250 38 330 62'/%3E%3Cpath d='M150 68 c-6 -12 2 -22 14 -22 M150 68 c10 -8 24 -4 28 8'/%3E%3Cpath d='M250 54 c-6 -12 2 -22 14 -22 M250 54 c10 -8 24 -4 28 8'/%3E%3C/g%3E%3Cg opacity='0.4'%3E%3Cpath d='M620 232 V202' stroke='%2337422F' stroke-width='2'/%3E%3Cellipse cx='620' cy='190' rx='16' ry='22' fill='%234A5840' fill-opacity='0.16'/%3E%3Cpath d='M884 236 V210' stroke='%2337422F' stroke-width='2'/%3E%3Cellipse cx='884' cy='198' rx='13' ry='18' fill='%234A5840' fill-opacity='0.16'/%3E%3C/g%3E%3Cg stroke='%234A5840' stroke-width='2' stroke-linecap='round' opacity='0.26'%3E%3Cpath d='M60 300 V250'/%3E%3Cpath d='M130 300 V256'/%3E%3Cpath d='M200 300 V250'/%3E%3Cpath d='M270 300 V258'/%3E%3Cpath d='M340 300 V252'/%3E%3Cpath d='M410 300 V258'/%3E%3Cpath d='M480 300 V252'/%3E%3Cpath d='M550 300 V258'/%3E%3C/g%3E%3Cg fill='%23A85E35' fill-opacity='0.22'%3E%3Ccircle cx='1024' cy='196' r='8'/%3E%3Ccircle cx='1042' cy='196' r='8'/%3E%3Ccircle cx='1033' cy='211' r='8'/%3E%3Ccircle cx='1051' cy='211' r='8'/%3E%3Ccircle cx='1042' cy='226' r='8'/%3E%3Ccircle cx='150' cy='150' r='6'/%3E%3Ccircle cx='164' cy='150' r='6'/%3E%3Ccircle cx='157' cy='162' r='6'/%3E%3C/g%3E%3C/svg%3E") no-repeat center bottom/cover}
.hero-art__focal{position:absolute;top:11%;right:7%;width:clamp(88px,14vw,190px);height:clamp(88px,14vw,190px);color:var(--olive-600);opacity:.26;z-index:1}
.hero-art__focal svg{width:100%;height:100%}
/* hero grafico: velo calce più leggero (non c'è una foto da scurire) */
.page-hero--art::after{background:
  linear-gradient(0deg,rgba(247,246,241,.86),rgba(247,246,241,.34) 52%,transparent),
  linear-gradient(90deg,rgba(247,246,241,.66),transparent 56%)}

/* esperienze */
.cards{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.exp-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.exp-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.exp-card__media,.exp-card .placeholder{aspect-ratio:3/2;border-radius:0;border-left:0;border-right:0;border-top:0}
.exp-card__body{display:flex;flex-direction:column;gap:.7rem;padding:clamp(1.3rem,2vw,1.7rem);flex:1}
.exp-card__title{font-size:1.3rem}
.exp-card__text{color:var(--ink-soft);font-size:.96rem;line-height:1.55;flex:1}
.exp-card__meta{display:flex;flex-wrap:wrap;gap:.5rem .9rem;font-size:.85rem;color:var(--ink-soft)}
.meta-item{display:inline-flex;align-items:center;gap:.4em}
.meta-item svg{width:1.05em;height:1.05em;color:var(--olive-500);flex:none}
.exp-card__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.4rem;border-top:1px solid var(--line);margin-top:.3rem}
.price{font-family:var(--font-display);font-weight:600;color:var(--brand);font-size:1.05rem}
.price small{font-family:var(--font-body);font-weight:500;font-size:.72rem;color:var(--ink-soft);letter-spacing:.02em}

/* badge */
.badge{display:inline-flex;align-items:center;gap:.4em;font-size:.74rem;font-weight:600;letter-spacing:.02em;padding:.32em .7em;border-radius:var(--r-pill);background:var(--cream-100);color:var(--olive-700);border:1px solid var(--line)}
.badge svg{width:1.05em;height:1.05em}
.badge--access{background:#1F5C4D;color:#fff;border-color:transparent}
.badge--season{background:var(--terra-500);color:#fff;border-color:transparent}
.badge-row{display:flex;flex-wrap:wrap;gap:.5rem}

/* vini */
.wine{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.wine--reverse .wine__media{order:2}
.wine__media{display:grid;place-items:center;background:radial-gradient(60% 70% at 50% 40%,var(--cream-100),transparent 75%);padding:1rem}
.wine__media img{max-height:520px;width:auto;filter:drop-shadow(0 24px 30px rgba(35,39,22,.28))}
.wine__kicker{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem}
.wine__dot{width:.85rem;height:.85rem;border-radius:50%;flex:none}
.wine__dot--white{background:linear-gradient(135deg,#EBDFA8,#C8B66B)}
.wine__dot--red{background:linear-gradient(135deg,#7E2A3C,#4E1622)}
.wine__variety{font-size:var(--fs-sm);font-weight:600;letter-spacing:var(--tracking);text-transform:uppercase;color:var(--accent)}
.wine__name{font-size:clamp(2rem,1.5rem + 2vw,3rem);margin-bottom:.3rem}
.wine__name span{display:block;font-size:.5em;font-style:italic;color:var(--ink-soft);font-weight:400;letter-spacing:.02em}
.wine__desc{color:var(--ink-soft);max-width:52ch;margin-bottom:1.4rem}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:.1rem 1.5rem;border-top:1px solid var(--line);padding-top:1.2rem;margin-top:1.6rem;margin-bottom:1.4rem}
.specs__row{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.92rem}
.specs__row dt{color:var(--ink-soft)}
.specs__row dd{font-weight:600;color:var(--brand);text-align:right}
.wine__pairing{display:flex;gap:.6rem;align-items:flex-start;color:var(--ink-soft);font-size:.95rem}
.wine__pairing svg{color:var(--olive-500);flex:none;margin-top:.1rem}
.wine__pairing strong{color:var(--brand)}

/* striscia statistiche / numeri */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--gap);text-align:center}
.stat__num{font-family:var(--font-display);font-weight:600;font-size:clamp(2.2rem,1.6rem + 2.4vw,3.4rem);color:var(--gold-500);line-height:1}
.stat__label{margin-top:.5rem;font-size:.9rem;color:var(--on-dark-soft);letter-spacing:.02em}

/* citazione */
.quote{max-width:30ch;margin-inline:auto;text-align:center}
.quote__text{font-family:var(--font-display);font-style:italic;font-size:clamp(1.5rem,1.1rem + 1.8vw,2.4rem);line-height:1.3;color:var(--cream-100)}
.quote__cite{display:block;margin-top:1.3rem;font-family:var(--font-body);font-style:normal;font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-500)}

/* lista con check */
.checklist{list-style:none;padding:0;display:grid;gap:.9rem}
.checklist li{display:flex;gap:.8rem;align-items:flex-start;line-height:1.5}
.checklist svg{width:1.4rem;height:1.4rem;flex:none;color:var(--olive-500);margin-top:.1rem}
.section--olive .checklist svg,.section--deep .checklist svg{color:var(--gold-500)}

/* CTA band */
.cta-band{text-align:center}
.cta-band__inner{max-width:60ch;margin-inline:auto;display:flex;flex-direction:column;align-items:center;gap:1.3rem}
.cta-band h2{color:var(--cream-100)}
.cta-band .lead{color:var(--on-dark-soft)}

/* divisore decorativo */
.leaf-divider{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--olive-400)}
.leaf-divider::before,.leaf-divider::after{content:"";height:1px;width:min(28vw,140px);background:currentColor;opacity:.5}
.leaf-divider svg{width:26px;height:26px}

/* componenti pagine interne */
:target{scroll-margin-top:5.5rem}
.cols-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:clamp(1.6rem,4vw,3.5rem)}
.timeline{display:grid;border-left:2px solid var(--line);padding-left:1.6rem;margin-left:.3rem}
.timeline__item{position:relative;padding-bottom:1.7rem}
.timeline__item:last-child{padding-bottom:0}
.timeline__item::before{content:"";position:absolute;left:calc(-1.6rem - 7px);top:.4rem;width:12px;height:12px;border-radius:50%;background:var(--olive-600);box-shadow:0 0 0 3px var(--bg)}
.timeline__year{font-family:var(--font-display);font-weight:600;color:var(--accent);font-size:.95rem}
.timeline__title{font-weight:600;color:var(--brand);margin-top:.05rem}
.timeline__desc{color:var(--ink-soft);font-size:.94rem;margin-top:.15rem;line-height:1.5}
.facts{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem;padding:0;list-style:none}
.fact{display:inline-flex;align-items:center;gap:.45em;font-size:.85rem;font-weight:600;color:var(--brand);background:var(--cream-100);border:1px solid var(--line);border-radius:var(--r-pill);padding:.45em .95em}
.fact svg{width:1.05em;height:1.05em;color:var(--olive-500)}
.error-page{min-height:62vh;display:grid;place-items:center;text-align:center}
.error-page .big{font-family:var(--font-display);font-size:clamp(4rem,3rem + 8vw,8rem);color:var(--olive-600);line-height:1}

/* 11) FORM ----------------------------------------------------------------- */
.form{display:grid;gap:1.15rem}
.form__row{display:grid;gap:1.15rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field__label{font-weight:600;font-size:.92rem;color:var(--brand)}
.field .req{color:var(--wine-700)}
.field__hint{font-size:.82rem;color:var(--ink-soft)}
.field input,.field select,.field textarea{
  width:100%;padding:.8rem .95rem;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-sm);
  color:var(--ink);font-size:1rem;transition:border-color var(--t),box-shadow var(--t)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--olive-600);box-shadow:0 0 0 3px rgba(107,112,73,.22)}
.field input:user-invalid,.field textarea:user-invalid,.field input[aria-invalid="true"]{border-color:var(--wine-600);box-shadow:0 0 0 3px rgba(138,46,69,.16)}
.field__error{font-size:.82rem;color:var(--wine-600);font-weight:600;min-height:1em}
.checkbox{display:flex;gap:.7rem;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);line-height:1.45}
.checkbox input{width:1.25rem;height:1.25rem;margin-top:.15rem;flex:none;accent-color:var(--olive-700)}
.checkbox a{font-weight:600}
.form-status{font-weight:600;border-radius:var(--r-sm);padding:.9rem 1.1rem}
.form-status:empty{display:none;padding:0}
.form-status[data-state="success"]{background:#E4F0E6;color:#1F5C3A;border:1px solid #BBD9C0}
.form-status[data-state="error"]{background:#F6E2E6;color:#8A2E45;border:1px solid #E3BCC6}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* contatti */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-sm)}
.contact-methods{display:grid;gap:1.1rem;margin:0;padding:0;list-style:none}
.contact-method{display:flex;gap:.95rem;align-items:flex-start}
.contact-method__icon{width:44px;height:44px;flex:none;display:grid;place-items:center;border-radius:50%;background:var(--cream-100);color:var(--olive-700)}
.contact-method__icon svg{width:22px;height:22px}
.contact-method .cm-label{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.15rem}
.contact-method .cm-value{font-weight:600;color:var(--brand)}
.contact-method a{color:var(--brand);text-decoration:none}
.contact-method a:hover{color:var(--accent)}
.map{border:0;width:100%;aspect-ratio:16/10;border-radius:var(--r-lg);filter:grayscale(.2) contrast(1.02)}
.quick-contacts{display:flex;flex-wrap:wrap;gap:.7rem}

/* 12) FOOTER --------------------------------------------------------------- */
.site-footer{background:var(--bg-alt);color:var(--ink-soft);border-top:1px solid var(--line);padding-block:clamp(3rem,5vw,4.5rem) 1.5rem;font-size:.93rem}
.site-footer a{color:var(--ink-soft);text-decoration:none}
.site-footer a:hover{color:var(--brand)}
.footer-top{display:grid;grid-template-columns:1.6fr .9fr 1.35fr .85fr;gap:clamp(1.6rem,3vw,2.5rem);padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
.footer-brand .brand__name{color:var(--brand)}
.footer-brand .brand__tag{color:var(--ink-soft)}
.footer-brand .brand__mark{color:var(--brand)}
.footer-brand .brand__logo{height:clamp(38px,4vw,48px)}
.footer-brand p{margin-top:1rem;max-width:34ch;line-height:1.55}
.footer-col h3{font-family:var(--font-body);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-weight:700}
.footer-col ul{list-style:none;padding:0;display:grid;gap:.6rem}
.social{display:flex;gap:.6rem;margin-top:1.2rem}
.social__link{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line);color:var(--brand);transition:background var(--t),border-color var(--t)}
.social__link:hover{background:var(--cream-200);border-color:var(--brand)}
.social__link svg{width:20px;height:20px}
/* contatti del footer con micro-icone */
.footer-contacts{list-style:none;padding:0;display:grid;gap:.72rem;margin:0}
.footer-contacts li{display:flex;align-items:flex-start;gap:.6rem;line-height:1.45}
.footer-contacts__ic{flex:none;width:18px;height:18px;color:var(--accent);margin-top:.12rem}
.footer-contacts__ic svg{width:18px;height:18px;display:block}
.footer-contacts a,.footer-contacts__txt{overflow-wrap:anywhere}
.footer-book{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.2rem;font-weight:600;color:var(--brand)!important}
.footer-book svg{width:17px;height:17px;transition:transform var(--t)}
.footer-book:hover svg{transform:translateX(3px)}

.footer-bottom{padding-top:1.5rem;font-size:.82rem;color:var(--ink-soft)}
.footer-bottom__main{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:baseline}
.footer-bottom a{text-decoration:underline;text-underline-offset:.15em}
.footer-legal{max-width:70ch;line-height:1.5}
.footer-credit{margin-top:1.1rem;padding-top:.95rem;border-top:1px solid var(--line);font-size:.78rem;color:var(--ink-soft);line-height:1.55}
.footer-credit strong{color:var(--brand);font-weight:600}

/* 13) LIGHTBOX ------------------------------------------------------------- */
.zoomable{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);background:rgba(35,39,22,.92);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{max-width:100%;max-height:90vh;width:auto;border-radius:var(--r);box-shadow:var(--shadow-lg)}
.lightbox__close{position:absolute;top:1.1rem;right:1.1rem;width:48px;height:48px;border-radius:50%;background:rgba(243,234,214,.14);color:var(--cream-100);display:grid;place-items:center}
.lightbox__close:hover{background:rgba(243,234,214,.26)}
.lightbox__close svg{width:24px;height:24px}
body.no-scroll{overflow:hidden}

/* 14) RESPONSIVE ----------------------------------------------------------- */
@media (max-width:900px){
  .hero{min-height:calc(100svh - 70px)}
  .hero__media img,.hero__media video{object-position:64% 30%}
  /* su mobile il testo è centrato e a tutta larghezza: velo scuro più uniforme per leggibilità */
  .hero::after{background:linear-gradient(0deg,rgba(20,26,13,.9) 0%,rgba(20,26,13,.62) 42%,rgba(20,26,13,.4) 72%,rgba(20,26,13,.18))}
  .hero__title{max-width:20ch}
  .hero__scroll{display:none}
  .wine,.wine--reverse{grid-template-columns:1fr;gap:1.5rem}
  .wine--reverse .wine__media{order:0}
  .wine__media img{max-height:380px}
  .contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
/* NAV: l'hamburger compare quando il logo orizzontale + il menu completo non ci stanno più.
   Niente backdrop-filter qui: creerebbe un containing block per il drawer fixed. */
@media (max-width:1100px){
  .site-header,.site-header.is-scrolled{-webkit-backdrop-filter:none;backdrop-filter:none;background:var(--cream-50)}
  .brand__logo{height:clamp(36px,4.6vw,48px)}
  .js .nav-toggle{display:inline-flex}
  .js .nav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
     background:var(--cream-50);box-shadow:var(--shadow-lg);padding:5.5rem 1.6rem 2rem;transform:translateX(100%);transition:transform var(--t);overflow-y:auto;border-left:1px solid var(--line)}
  .js .nav.is-open{transform:translateX(0)}
  .nav__list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav__item{border-bottom:1px solid var(--line)}
  .nav__link{display:block;padding:.95rem 0;font-size:1.1rem;white-space:normal}
  .nav__link::after{display:none}
  .nav__cta{margin-top:1.3rem}
  .site-header .nav__cta .btn{width:100%;padding:.95em 1.6em;font-size:.97rem}
  .lang-switch{margin-top:1.3rem;align-self:flex-start}
  .nav-backdrop{position:fixed;inset:0;background:rgba(35,39,22,.45);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t);z-index:99}
  .nav-backdrop.is-open{opacity:1;visibility:visible}
}
@media (max-width:760px){
  .feature,.feature--reverse{grid-template-columns:1fr;gap:1.5rem}
  .feature--reverse .feature__media{order:0}
  .feature__media .media,.feature__media .placeholder{aspect-ratio:16/11}
  .specs{grid-template-columns:1fr}
}
@media (max-width:480px){
  .brand__tag{display:none}
  .btn-row .btn,.hero__actions .btn{width:100%}
  .cards{grid-template-columns:1fr}
}

/* 16) DECORI NATURALI + INTERAZIONI MODERNE -------------------------------- */
/* Decori line-art (vite, grappoli, foglie, colline, sole) iniettati via JS in
   ogni sezione: galleggiano lentamente, derivano allo scroll (--py) e al mouse
   (--mpx/--mpy). Tutto su transform GPU; animati solo quando la sezione è in vista. */
.section{position:relative}
.section>.container{position:relative;z-index:1}
.has-deco,.has-decor{overflow:clip}
.section__decor{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;contain:layout paint style}
.deco{position:absolute;display:block;pointer-events:none;color:var(--olive-400);opacity:.42;
  transform:translate3d(var(--mpx,0px),calc(var(--py,0px) + var(--mpy,0px)),0)}
.deco svg{width:100%;height:100%;display:block;overflow:visible}
.deco--tr{top:-3%;right:-2%;width:clamp(120px,15vw,250px)}
.deco--bl{bottom:-5%;left:-3%;width:clamp(120px,15vw,230px)}
.deco--tl{top:-3%;left:-2%;width:clamp(110px,13vw,210px)}
.deco--br{bottom:-4%;right:-3%;width:clamp(120px,14vw,230px)}
.deco--grapes{color:var(--accent);opacity:.13}
.deco--vine{color:var(--olive-500);opacity:.2}
.deco--leaf{color:var(--olive-400);opacity:.28}
.section--olive .deco,.section--deep .deco,.site-footer .deco{color:var(--gold-500);opacity:.12}
.section--olive .deco--vine,.section--deep .deco--vine{color:var(--olive-400);opacity:.16}
/* galleggio leggero sull'SVG interno (così non sovrascrive il transform di scroll/mouse del .deco).
   Parte solo quando la sezione è vicina (IO → .is-near) */
.deco svg{animation:floaty 17s ease-in-out infinite paused}
.is-near .deco.float-0 svg{animation-play-state:running}
.is-near .deco.float-1 svg{animation-play-state:running;animation-duration:21s;animation-direction:alternate-reverse}
.is-near .deco.float-2 svg{animation-play-state:running;animation-duration:25s}
/* aloni organici tenui (salvia + argilla) su sezioni chiare */
.section--alt::before,.section--sand::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(38% 48% at 88% 8%,rgba(124,140,100,.12),transparent 70%),
            radial-gradient(34% 44% at 6% 96%,rgba(168,94,53,.07),transparent 72%)}

/* reveal: varianti direzionali + scala (oltre al fade-up base) */
.js .reveal--left{transform:translateX(-30px)}
.js .reveal--right{transform:translateX(30px)}
.js .reveal--scale{opacity:0;transform:scale(.93)}
.js .reveal--left.is-visible,.js .reveal--right.is-visible,.js .reveal--scale.is-visible{opacity:1;transform:none}

/* hover ricchi su card e media */
.exp-card__media img,.media img,.media video{transition:transform .6s cubic-bezier(.4,0,.2,1)}
.exp-card:hover .exp-card__media img{transform:scale(1.06)}
.media.zoomable:hover img,.media.zoomable:hover video{transform:scale(1.04)}
.pillar__icon{transition:transform var(--t),background var(--t),color var(--t)}
.pillar:hover .pillar__icon{transform:rotate(-6deg) scale(1.08);background:var(--accent);color:#fff}

/* barra di avanzamento scroll (transform:scaleX → niente reflow) */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:left;z-index:200;
  background:linear-gradient(90deg,var(--olive-500),var(--accent));will-change:transform}

/* CURSORE — grappolo d'uva (desktop, puntatore fine, no reduced-motion) */
.cursor-grape{position:fixed;top:0;left:0;z-index:9999;width:30px;height:38px;pointer-events:none;
  color:var(--accent);opacity:0;transition:opacity .3s,width .25s cubic-bezier(.34,1.56,.64,1),height .25s cubic-bezier(.34,1.56,.64,1)}
.cursor-grape.is-shown{opacity:1}
.cursor-grape svg{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 4px rgba(40,49,31,.25))}
.cursor-grape .cur-leaf{color:var(--olive-500)}
.cursor-grape.is-hover{width:38px;height:48px}
.cursor-grape.is-down{transform-box:fill-box}
.cursor-grape.is-down svg{transform:scale(.86);transition:transform .12s}
.cursor-grape.is-dark{color:var(--gold-500)}
.cursor-grape.is-dark .cur-leaf{color:var(--olive-400)}
.cursor-label{position:absolute;top:50%;left:120%;transform:translateY(-50%);font-size:.6rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);white-space:nowrap;opacity:0;transition:opacity .2s}
.cursor-grape.is-media .cursor-label{opacity:1}
.cursor-grape.is-dark .cursor-label{color:var(--gold-500)}
/* aura morbida che insegue (sostituisce il vecchio anello) */
.cursor-aura{position:fixed;top:0;left:0;z-index:9998;width:44px;height:44px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(168,94,53,.16),transparent 70%);opacity:0;
  transition:opacity .35s,width .3s cubic-bezier(.34,1.56,.64,1),height .3s cubic-bezier(.34,1.56,.64,1)}
.cursor-aura.is-shown{opacity:1}
.has-cursor .cursor-grape.is-hover~.cursor-aura,.has-cursor .cursor-grape.is-media~.cursor-aura{width:70px;height:70px}
body.has-cursor,body.has-cursor *{cursor:none!important}
body.has-cursor input,body.has-cursor textarea,body.has-cursor select{cursor:text!important}

/* SCROLLER ORIZZONTALE "PINNATO" — su desktop la pagina si BLOCCA e la sezione
   scorre interamente in orizzontale (progresso scroll → translateX, via JS).
   Su mobile / no-JS / reduced-motion: scorrimento orizzontale nativo (swipe). */
.scroller{position:relative;isolation:isolate}
.scroller__sticky{padding-block:var(--section-pad)}
.scroller__head{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);margin-bottom:clamp(1.4rem,3vw,2.2rem)}
.scroller__head .lead{max-width:54ch}
.scroller__viewport{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--olive-400) transparent}
/* a11y: la striscia è focalizzabile da tastiera (tabindex=0) → focus visibile */
.scroller__viewport:focus-visible{outline:3px solid var(--focus);outline-offset:-3px;border-radius:var(--r)}
.scroller__viewport::-webkit-scrollbar{height:8px}
.scroller__viewport::-webkit-scrollbar-thumb{background:var(--olive-400);border-radius:999px}
.scroller__track{display:flex;gap:clamp(1.3rem,2.4vw,2.2rem);width:max-content;padding-inline:var(--gutter)}
.scroller__card{flex:0 0 clamp(280px,38vw,540px);scroll-snap-align:start;position:relative;isolation:isolate;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:box-shadow var(--t),transform .14s cubic-bezier(.2,.7,.3,1)}
.scroller__card:hover{box-shadow:var(--shadow);will-change:transform}
.scroller__media{position:relative;aspect-ratio:16/10;overflow:hidden;
  background:radial-gradient(120% 130% at 78% 6%,var(--cream-100),var(--cream-200) 64%,var(--sand-300))}
.scroller__media img{width:100%;height:100%;object-fit:cover}
.scroller__icon{position:absolute;inset:0;margin:auto;width:40%;height:40%;color:var(--olive-400);opacity:.5;
  transition:transform .5s cubic-bezier(.4,0,.2,1),color .4s,opacity .4s}
.scroller__icon svg{width:100%;height:100%}
.scroller__card:hover .scroller__icon{transform:scale(1.08) rotate(-4deg);color:var(--accent);opacity:.68}
/* pattern decorativo a tema (puntini "uva/terra") nel media, niente foto */
.scroller__media::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:radial-gradient(circle at 18% 26%,rgba(74,88,64,.10) 0 3px,transparent 4px) 0 0/30px 30px,
            radial-gradient(circle at 70% 64%,rgba(168,94,53,.08) 0 2.5px,transparent 4px) 0 0/38px 38px}
.scroller__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 56%,rgba(40,49,31,.10));pointer-events:none}
.scroller__num{position:absolute;top:.85rem;left:1.05rem;z-index:2;font-family:var(--font-display);font-weight:600;
  font-size:1.05rem;color:#fff;width:2.1rem;height:2.1rem;display:grid;place-items:center;border-radius:50%;
  background:rgba(40,49,31,.55)}
.scroller__body{display:flex;flex-direction:column;gap:.45rem;padding:clamp(1.2rem,2vw,1.6rem);flex:1}
.scroller__body h3{font-size:1.25rem}
.scroller__body p{color:var(--ink-soft);font-size:.94rem;line-height:1.55}
.scroller__tag{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.scroller__progress{max-width:var(--maxw);margin:clamp(1.3rem,3vw,2rem) auto 0;padding-inline:var(--gutter);
  display:flex;align-items:center;gap:.85rem;color:var(--ink-soft);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase}
.scroller__progress .bar{flex:1;height:3px;background:var(--line);border-radius:999px;overflow:hidden}
.scroller__progress .bar i{display:block;height:100%;width:12%;border-radius:999px;
  background:linear-gradient(90deg,var(--olive-500),var(--accent));transition:width .15s linear}
/* su sezioni verdi le card dello scroller restano BIANCHE e leggibili (testo scuro) */
.section--olive .scroller__card,.section--deep .scroller__card{background:var(--surface);border-color:rgba(243,234,214,.22)}
/* card bianche su verde: il titolo NON deve ereditare il crema della sezione (illeggibile) → torna brand */
.section--olive .scroller__card h3,.section--deep .scroller__card h3{color:var(--brand)}
@media (max-width:760px){ .scroller__card{flex-basis:80vw} }

/* PINNATO: attivo solo con JS (.is-pinned), schermo ampio e animazioni consentite */
@media (prefers-reduced-motion:no-preference) and (min-width:820px){
  .scroller.is-pinned .scroller__pin{height:calc(var(--span,3) * 100vh)}
  .scroller.is-pinned .scroller__sticky{position:sticky;top:74px;height:calc(100svh - 74px);
    display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding-block:clamp(1.4rem,4vh,2.6rem)}
  .scroller.is-pinned .scroller__viewport{overflow:visible;scroll-snap-type:none}
  .scroller.is-pinned .scroller__track{will-change:transform;flex:1;align-items:stretch}
  .scroller.is-pinned .scroller__card{height:auto}
  /* pinnato: niente striscia media (si espandeva a riempire le card più corte → incoerenza) */
  .scroller.is-pinned .scroller__media{display:none}
}

/* PROFILO DEGUSTATIVO (pagina Vini) */
.tasting{display:grid;gap:.85rem;margin:1.4rem 0}
.tasting__row{display:grid;grid-template-columns:8.5rem 1fr;align-items:center;gap:.9rem}
.tasting__name{font-size:.86rem;font-weight:600;color:var(--ink-soft)}
.tasting__bar{height:7px;border-radius:999px;background:var(--cream-200);overflow:hidden}
.tasting__fill{height:100%;border-radius:999px;width:0;
  background:linear-gradient(90deg,var(--olive-500),var(--olive-700));transition:width 1.1s cubic-bezier(.3,0,.1,1)}
.tasting.is-in .tasting__fill{width:var(--val)}
.wine--reverse .tasting__fill{background:linear-gradient(90deg,var(--terra-500),var(--wine-700))}
.aromas{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.2rem}
.aroma{display:inline-flex;align-items:center;gap:.45em;font-size:.82rem;font-weight:600;color:var(--brand);
  background:var(--cream-100);border:1px solid var(--line);border-radius:var(--r-pill);padding:.4em .85em;transition:transform var(--t),background var(--t)}
.aroma:hover{transform:translateY(-2px);background:#fff}
.aroma svg{width:1.05em;height:1.05em;color:var(--olive-500)}

@media (max-width:760px){
  .tasting__row{grid-template-columns:7rem 1fr}
  .rail__viewport>*{flex-basis:80vw}
}

@keyframes floaty{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-16px) rotate(2.5deg)}}

/* 17) ATMOSFERA — grana di pellicola + sfondi vivi (niente tinte piatte) --- */
/* Grana sottilissima su tutto: profondità + maschera l'upscaling delle foto.
   PERF: niente mix-blend-mode (costoso); livello fisso compositato una sola volta
   (translateZ) → non si ridipinge allo scroll. */
body::after{content:"";position:fixed;inset:0;z-index:300;pointer-events:none;opacity:.035;
  transform:translateZ(0);
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:160px}
/* SPOTLIGHT — bagliore che segue il mouse, COMPOSITATO (JS muove .spot-glow con
   transform: niente ridisegno del gradiente ogni frame → puntatore sempre fluido). */
.spotlight{position:relative;isolation:isolate;overflow:clip}
.spot-glow{position:absolute;top:0;left:0;width:560px;height:560px;margin:-280px;border-radius:50%;
  pointer-events:none;z-index:0;opacity:0;transition:opacity .5s ease}
.spotlight.is-live .spot-glow{opacity:1}
/* sezioni SCURE: schiarisce lo sfondo (salvia) */
.spotlight--deep .spot-glow{background:radial-gradient(circle,rgba(124,140,100,.24),transparent 62%)}
/* sezioni CHIARE: velo caldo MOLTO leggero (no blend, intensità ridotta) */
.spotlight--light .spot-glow{width:420px;height:420px;margin:-210px;
  background:radial-gradient(circle,rgba(219,193,140,.12),transparent 68%)}
.spotlight>.container,.spotlight>*{position:relative;z-index:1}
.spotlight>.spot-glow,.spotlight>.section__decor{position:absolute;z-index:0}

/* CARD SPETTACOLARI — sheen al passaggio, accento, profondità */
.exp-card{position:relative;isolation:isolate;border-top:3px solid transparent}
.exp-card::after{content:"";position:absolute;inset:0;z-index:4;pointer-events:none;border-radius:inherit;opacity:0;
  background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.55) 50%,transparent 58%);background-size:250% 100%;background-position:130% 0;transition:opacity .35s}
.exp-card:hover::after{opacity:1;animation:shine .9s ease forwards}
@keyframes shine{to{background-position:-30% 0}}
.exp-card:hover{border-top-color:var(--accent)}
.exp-card__media::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,transparent 52%,rgba(40,49,31,.40));opacity:.5;transition:opacity .4s}
.exp-card:hover .exp-card__media::before{opacity:.78}
.exp-card__body{position:relative;z-index:3}
.pillar{position:relative;overflow:hidden}
.pillar::before{content:"";position:absolute;inset:-30% -30% auto auto;width:80%;height:80%;pointer-events:none;
  background:radial-gradient(circle at 70% 30%,rgba(124,140,100,.18),transparent 68%);opacity:0;transition:opacity .5s}
.pillar:hover::before{opacity:1}
.pillar>*{position:relative}
.wine__media{position:relative}
.wine__media::before{content:"";position:absolute;inset:6% 10%;z-index:0;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(219,193,140,.30),transparent 64%);opacity:0;transform:scale(.82);transition:opacity .6s,transform .6s}
.wine:hover .wine__media::before{opacity:1;transform:scale(1)}
.wine__media img{position:relative;z-index:1}


/* orb luminosi dell'hero (parallax mouse via --mpx/--mpy; niente blend-mode) */
.hero-orb{position:absolute;z-index:1;pointer-events:none;border-radius:50%;filter:blur(30px);opacity:.5;
  transform:translate3d(var(--mpx,0px),var(--mpy,0px),0)}
.hero-orb--1{width:clamp(180px,26vw,340px);aspect-ratio:1;top:8%;right:16%;background:radial-gradient(circle,rgba(219,193,140,.85),transparent 68%)}
.hero-orb--2{width:clamp(150px,22vw,280px);aspect-ratio:1;bottom:8%;left:6%;background:radial-gradient(circle,rgba(124,140,100,.8),transparent 68%)}
/* CTA band scura: stesso aspetto (gradiente ingrandito, fermo sul frame di riposo
   dell'ex animazione 0%/100%). PERF: niente più animation:bgshift infinita, che
   ridipingeva il gradiente di una sezione grande per sempre, anche fuori schermo. */
.cta-band.section--deep{background-size:170% 170%;background-position:0% 50%}

/* 18) BOTTONI SU SEZIONI VERDI — adattamento automatico (così posso colorare
   di verde qualunque sezione per alternare gli sfondi senza rompere i contrasti) */
.section--olive .btn--primary,.section--deep .btn--primary{background:var(--gold-500);color:#2A2E1F}
.section--olive .btn--primary:hover,.section--deep .btn--primary:hover{background:#E6CE9E}
.section--olive .btn--ghost,.section--deep .btn--ghost{border-color:rgba(243,234,214,.5);color:var(--cream-100)}
.section--olive .btn--ghost:hover,.section--deep .btn--ghost:hover{background:rgba(243,234,214,.12);color:#fff;border-color:var(--cream-100)}
.section--olive .price,.section--deep .price{color:var(--gold-500)}
.section--olive .badge,.section--deep .badge{background:rgba(243,234,214,.1);color:var(--cream-100);border-color:rgba(243,234,214,.2)}
.section--olive .wine__name,.section--deep .wine__name{color:var(--cream-100)}
.section--olive .specs__row dd,.section--deep .specs__row dd{color:var(--gold-500)}
.section--olive .specs,.section--olive .specs__row,.section--deep .specs,.section--deep .specs__row{border-color:rgba(243,234,214,.18)}
.section--olive .media,.section--deep .media{box-shadow:0 18px 40px rgba(0,0,0,.3)}
.section--olive .timeline,.section--deep .timeline{border-color:rgba(243,234,214,.24)}
.section--olive .timeline__year,.section--deep .timeline__year{color:var(--gold-500)}
.section--olive .timeline__title,.section--deep .timeline__title{color:var(--cream-100)}
.section--olive .timeline__desc,.section--deep .timeline__desc{color:var(--on-dark-soft)}
.section--olive .timeline__item::before{background:var(--gold-500);box-shadow:0 0 0 3px var(--olive-800)}
.section--deep .timeline__item::before{background:var(--gold-500);box-shadow:0 0 0 3px var(--olive-900s)}

/* 19) TRUST — elementi di fiducia ----------------------------------------- */
/* striscia compatta sotto l'hero */
.trust-bar{border-block:1px solid var(--line);background:var(--bg-alt)}
.trust-bar__row{max-width:var(--maxw);margin-inline:auto;padding:1rem var(--gutter);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.8rem 2rem}
.trust-bar__item{display:inline-flex;align-items:center;gap:.55rem;font-size:.86rem;font-weight:600;color:var(--brand)}
.trust-bar__item svg{width:1.2rem;height:1.2rem;color:var(--olive-500);flex:none}
.trust-bar__sep{width:1px;height:1.4rem;background:var(--line)}
@media (max-width:680px){ .trust-bar__sep{display:none} }

/* sezione trust completa — card premium (icona, barra d'accento, sollevamento) */
.trust__grid{display:grid;gap:clamp(.9rem,1.8vw,1.4rem);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.trust__item{position:relative;display:flex;flex-direction:column;gap:.85rem;padding:clamp(1.5rem,2.4vw,2.1rem);
  border-radius:var(--r-lg);background:rgba(243,234,214,.05);border:1px solid rgba(243,234,214,.14);overflow:hidden;isolation:isolate;
  transition:transform .35s cubic-bezier(.4,0,.2,1),background .35s,border-color .35s,box-shadow .35s}
.trust__item::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;transform:scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,var(--gold-500),var(--olive-400));transition:transform .4s}
.trust__item:hover{transform:translateY(-6px);background:rgba(243,234,214,.1);border-color:rgba(243,234,214,.3);box-shadow:0 22px 50px rgba(0,0,0,.28)}
.trust__item:hover::before{transform:scaleX(1)}
.trust__item>div{display:flex;flex-direction:column;gap:.32rem}
.trust__icon{width:56px;height:56px;flex:none;display:grid;place-items:center;border-radius:50%;
  background:rgba(219,193,140,.14);color:var(--gold-500);transition:transform .4s,background .4s}
.trust__item:hover .trust__icon{transform:rotate(-6deg) scale(1.08);background:rgba(219,193,140,.22)}
.trust__icon svg{width:28px;height:28px}
.trust__t{font-family:var(--font-display);font-weight:500;color:var(--cream-100);font-size:1.18rem;line-height:1.2}
.trust__d{color:var(--on-dark-soft);font-size:.92rem;line-height:1.55}
/* variante chiara */
.trust--light .trust__item{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-sm)}
.trust--light .trust__item:hover{box-shadow:var(--shadow);border-color:var(--olive-400)}
.trust--light .trust__icon{background:var(--cream-100);color:var(--olive-700)}
.trust--light .trust__t{color:var(--brand)}
.trust--light .trust__d{color:var(--ink-soft)}

/* CTA band su sfondo CHIARO (per l'alternanza colori): testo scuro */
.cta-band:not(.section--olive):not(.section--deep) h2{color:var(--brand)}
.cta-band:not(.section--olive):not(.section--deep) .lead{color:var(--ink-soft)}
/* CTA band chiara: i bottoni "per fondo scuro" sparirebbero — riportali allo stile standard del sito (primary pieno salvia + ghost contornato). */
.cta-band:not(.section--olive):not(.section--deep) .btn--light{background:var(--olive-700);color:var(--cream-100);box-shadow:var(--shadow-sm)}
.cta-band:not(.section--olive):not(.section--deep) .btn--light:hover{background:var(--olive-800);box-shadow:var(--shadow)}
.cta-band:not(.section--olive):not(.section--deep) .btn--outline-light{border-color:var(--olive-700);color:var(--olive-700)}
.cta-band:not(.section--olive):not(.section--deep) .btn--outline-light:hover{background:var(--olive-700);color:var(--cream-100);border-color:var(--olive-700)}

/* 15) MOTION / PRINT ------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .js .reveal{opacity:1;transform:none}
  .btn:hover,.pillar:hover,.exp-card:hover{transform:none}
  .cursor-grape,.cursor-aura,.scroll-progress{display:none!important}
  .hero__media img,.hero__media video{transform:none!important}
  .deco svg{animation:none}
  .hero-orb{display:none}
}
@media print{
  .site-header,.site-footer,.nav-toggle,.hero__scroll,.cta-band,.lightbox,.map{display:none!important}
  body{background:#fff;color:#000}
  .section{padding-block:1rem}
  a{text-decoration:underline}
}

/* 20) UTILITY DI ESTRAZIONE -------------------------------------------------
   Classi che sostituiscono 1:1 gli stili inline rimossi dal markup (stessi
   identici valori → nessun cambiamento visivo). In coda al file così, a parità
   di specificità, vincono per ordine sorgente (le hero/bottiglie usano img.* per
   battere regole tipo `.page-hero__media img` come faceva lo stile inline). */
.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}
.u-jc-center{justify-content:center}
.u-ta-center{text-align:center}
.u-ai-start{align-items:start}
.u-mw-none{max-width:none}
.u-mw-34{max-width:34ch}
.u-mw-54{max-width:54ch}
.u-mt-05{margin-top:.5rem}
.u-mt-13{margin-top:1.3rem}
.u-mt-15{margin-top:1.5rem}
.u-mt-16{margin-top:1.6rem}
.u-mt-17{margin-top:1.7rem}
.u-mt-18{margin-top:1.8rem}
.u-mt-2{margin-top:2rem}
.u-mt-22{margin-top:2.2rem}
.u-mt-c1{margin-top:clamp(2.5rem,5vw,4.5rem)}
.u-mt-c2{margin-top:clamp(2.5rem,5vw,4rem)}
.u-mt-c3{margin-top:clamp(2.2rem,4vw,3rem)}
.u-mb-04{margin-bottom:.4rem}
.u-mb-1{margin-bottom:1rem}
.u-mb-13{margin-bottom:1.3rem}
.u-h-xl{font-size:var(--fs-h2);margin:.3rem 0 .6rem}
.u-h-lg{font-size:var(--fs-h3)}
.u-h-404{margin:.4rem 0 1rem}
.u-fs-102{font-size:1.02rem}
.u-fs-105{font-size:1.05rem}
.u-form-intro{font-size:1rem;margin-bottom:1.6rem}
.u-ico-olive{color:var(--olive-500)}
.u-va-2{vertical-align:-2px}
.u-va-3{vertical-align:-3px}
.u-grid-2{grid-template-columns:1fr 1fr}
.u-grid-240{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.u-grid-260{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.scroller--span{--span:3.4}
.footer-bottom--404{border-top:0;justify-content:center;text-align:center}
.footer-credit--404{border-top:0;margin-top:.5rem}
img.wine__bottle-img{display:inline-block;max-height:440px;width:auto;filter:drop-shadow(0 22px 26px rgba(35,39,22,.25))}
img.u-ar-45{aspect-ratio:4/5;object-fit:cover}
img.u-op-12{object-position:center 12%}
img.u-op-30{object-position:center 30%}
img.u-op-42{object-position:center 42%}
img.u-op-45{object-position:center 45%}
img.u-op-48{object-position:center 48%}
img.u-op-50{object-position:center 50%}
img.u-op-55{object-position:center 55%}
img.u-op-58{object-position:center 58%}
