:root {
  color-scheme: light;
  --page: #f7f8f3;
  --ink: #17211f;
  --muted: #60706a;
  --line: #d9ded7;
  --panel: #fff;
  --accent: #b6402f;
  --accent-strong: #7e2a22;
  --on-accent: #fff;
  --green: #2f5d50;
  --on-green: #fff;
  --gold: #b9872f;
  --star-empty: #d4cfc1;
  --whatsapp: #25d366;
  --whatsapp-strong: #128c7e;
  --on-whatsapp: #0b1a14;
  --header-bg: rgba(247, 248, 243, 0.94);
  --nav-hover: #e8ede7;
  --hero-media-bg: #26332d;
  --english: #71817a;
  --lightbox-bg: rgba(10, 12, 11, 0.92);
  --font-heading: Georgia, "Times New Roman", serif;
  --font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --radius-ctl: 8px;
  --radius-card: 8px;
  --radius-media: 8px;
  --btn-bg: var(--accent);
  --btn-ink: var(--on-accent);
  --btn-border: transparent;
  --btn-hover-bg: var(--accent-strong);
  --btn-hover-ink: var(--on-accent);
  --btn-hover-shadow: none;
  --btn-hover-transform: none;
  --heading-weight: 500;
  --heading-spacing: 0;
  --nav-underline: 0px;
  font-family: var(--font-body);
}

* { box-sizing: border-box; }
html { background: var(--page); color: var(--ink); scroll-behavior: smooth; }
body { margin: 0; font-size: 18px; line-height: 1.6; letter-spacing: 0; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
p, h1, h2, h3 { margin: 0; }
.site-header {
  align-items: center;
  background: var(--header-bg);
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 24px;
  justify-content: space-between;
  min-height: 72px;
  padding: 14px 32px;
  position: sticky;
  top: 0;
  z-index: 2;
}
/* min-width: 0 + overflow-wrap: anywhere: il nome nel brand è un flex item e
   senza queste regole una parola lunga allargherebbe l'header (anche sottile/
   centrato) oltre il viewport invece di andare a capo. */
.brand { align-items: center; display: inline-flex; font-weight: 800; gap: 12px; -webkit-hyphens: auto; hyphens: auto; min-width: 0; overflow-wrap: anywhere; }
.brand-logo { display: block; height: 46px; max-width: 240px; object-fit: contain; width: auto; }
.brand-mark {
  align-items: center;
  background: var(--green);
  border-radius: var(--radius-ctl);
  color: var(--on-green);
  display: inline-flex;
  height: 40px;
  justify-content: center;
  width: 40px;
}
.nav-links { display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; }
/* La sottolineatura che "scorre" in hover è un gradiente in background-image:
   alta var(--nav-underline) (0 = tema con pastiglia --nav-hover, niente riga).
   Attenzione: l'hover imposta background-COLOR, mai lo shorthand, o cancella
   la riga. */
.nav-links a {
  background-image: linear-gradient(currentColor, currentColor);
  background-position: 0 100%;
  background-repeat: no-repeat;
  background-size: 0% var(--nav-underline);
  border-radius: var(--radius-ctl);
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
  padding: 10px 12px;
  transition: background-size .2s ease, background-color .15s ease, color .15s ease;
}
.nav-links a:hover, .nav-links a:focus-visible { background-color: var(--nav-hover); background-size: 100% var(--nav-underline); color: var(--ink); outline: none; }
/* Burger e chiusura del menu mobile (:target): nascosti ovunque di default;
   li mostra solo la variante header che prevede il menu a schermo intero. */
.nav-burger, .nav-close { display: none; }
/* Header "centrato": brand centrato sopra, navigazione centrata sotto. */
.header--centrato { flex-direction: column; gap: 8px; justify-content: center; padding: 18px 32px 12px; text-align: center; }
.header--centrato .nav-links { justify-content: center; }
/* Header "sottile": barra più bassa, brand ridotto, nav a destra (default). */
.header--sottile { gap: 18px; min-height: 54px; padding: 6px 28px; }
.header--sottile .brand { font-size: 15px; gap: 9px; }
.header--sottile .brand-logo { height: 32px; max-width: 190px; }
.header--sottile .brand-mark { font-size: 14px; height: 28px; width: 28px; }
.header--sottile .nav-links a { font-size: 13px; padding: 7px 10px; }
/* Switch lingua CSS-only: i radio nascosti (in cima al body) mostrano la lingua
   attiva. Solo l'interfaccia è bilingue; i contenuti restano in lingua originale. */
.lang-radio { height: 0; opacity: 0; pointer-events: none; position: absolute; width: 0; }
.t-en { display: none; }
#lang-en:checked ~ * .t-it { display: none; }
#lang-en:checked ~ * .t-en { display: inline; }
.lang-switch {
  align-items: stretch;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  gap: 2px;
  padding: 2px;
}
.lang-opt {
  align-items: center;
  border-radius: 999px;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  justify-content: center;
  line-height: 1;
  min-width: 38px;
  padding: 6px 12px;
  transition: background .15s ease, color .15s ease;
}
.lang-opt:hover { color: var(--ink); }
#lang-it:checked ~ * .lang-opt-it,
#lang-en:checked ~ * .lang-opt-en { background: var(--accent); color: var(--on-accent); }
/* Titoli a prova di nomi lunghi (bug produzione "Da Gino al Parlamento"): la
   parola che non entra nella colonna si spezza con trattino (le pagine
   dichiarano lang="it", quindi la sillabazione è italiana) invece di sbordare
   oltre il viewport. Con nomi normali non cambia nulla. */
h1, h2, h3 { -webkit-hyphens: auto; hyphens: auto; overflow-wrap: break-word; }
h1 { font-family: var(--font-heading); font-size: clamp(44px, 4.9vw, 68px); font-weight: var(--heading-weight); letter-spacing: var(--heading-spacing); line-height: 1; max-width: 820px; }
.english { color: var(--english); font-size: .92em; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.button {
  align-items: center;
  border: 1px solid transparent;
  border-radius: var(--radius-ctl);
  display: inline-flex;
  font-size: 15px;
  font-weight: 800;
  gap: 8px;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
/* Il bottone primario è interamente token-driven: pieno (default), contorno o
   inverti sono scelte del TEMA (btn*), non regole nuove. */
.button.primary { background: var(--btn-bg); border-color: var(--btn-border); color: var(--btn-ink); }
.button.primary:hover, .button.primary:focus-visible {
  background: var(--btn-hover-bg);
  box-shadow: var(--btn-hover-shadow);
  color: var(--btn-hover-ink);
  transform: var(--btn-hover-transform);
}
.button.secondary { border: 1px solid var(--line); color: var(--ink); }
.button.whatsapp { background: var(--whatsapp); color: var(--on-whatsapp); }
.button.whatsapp:hover, .button.whatsapp:focus-visible { background: var(--whatsapp-strong); color: #fff; }
.button .icon { display: inline-block; flex: 0 0 auto; height: 18px; width: 18px; }
.section { border-top: 1px solid var(--line); padding: 78px 56px; }
.section-label { color: var(--accent); font-size: 13px; font-weight: 900; margin-bottom: 18px; text-transform: uppercase; }
.section-grid, .contact-layout { display: grid; gap: 42px; grid-template-columns: minmax(240px, .78fr) minmax(0, 1.22fr); }
h2 { font-family: var(--font-heading); font-size: 44px; font-weight: var(--heading-weight); letter-spacing: var(--heading-spacing); line-height: 1.05; }
.copy-stack { display: grid; gap: 18px; }
.lead { font-size: 22px; line-height: 1.45; }
.cards { display: grid; gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 28px; }
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  display: grid;
  gap: 12px;
  padding: 20px;
}
.site-footer {
  align-items: center;
  border-top: 1px solid var(--line);
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  gap: 14px;
  justify-content: space-between;
  padding: 28px 36px;
}
@media (max-width: 840px) {
  body { font-size: 16px; }
  .site-header { align-items: flex-start; flex-direction: column; padding: 14px 18px; }
  h1 { font-size: clamp(36px, 11.2vw, 44px); }
  .section { padding: 54px 22px; }
  .section-grid, .contact-layout, .cards { grid-template-columns: 1fr; }
  h2 { font-size: 34px; }
  /* Header centrato: resta centrato anche impilato su mobile. */
  .header--centrato { align-items: center; padding: 14px 18px 10px; }
  /* Header sottile: su mobile una sola riga brand + burger; la nav diventa un
     menu a schermo intero CSS-only via :target (il click su una voce cambia il
     fragment e quindi lo chiude da solo — nessun JS, come il lightbox). */
  .header--sottile { align-items: center; flex-direction: row; gap: 10px; padding: 8px 14px; }
  .header--sottile .nav-burger { display: inline-flex; flex-direction: column; gap: 5px; margin-left: auto; padding: 12px 10px; }
  .nav-burger span { background: var(--ink); border-radius: 999px; display: block; height: 2px; width: 22px; }
  .header--sottile .nav-links { display: none; }
  /* A menu aperto l'header deve salire sopra ogni z-index di pagina (i pallini
     dello slider stanno a z:2 come l'header): lo sticky crea uno stacking
     context che altrimenti intrappola l'overlay sotto ciò che viene dopo. */
  .header--sottile:has(.nav-links:target) { z-index: 60; }
  .header--sottile .nav-links:target {
    align-content: center;
    background: var(--page);
    display: grid;
    gap: 8px;
    inset: 0;
    justify-content: center;
    justify-items: center;
    padding: 24px;
    position: fixed;
    z-index: 60;
  }
  .header--sottile .nav-links:target a { font-family: var(--font-heading); font-size: 27px; font-weight: var(--heading-weight); padding: 12px 20px; }
  .header--sottile .nav-links:target .nav-close { align-items: center; display: flex; font-family: inherit; font-size: 32px; padding: 4px 16px; position: absolute; right: 12px; top: 10px; }
  .header--sottile .nav-links:target .lang-switch { margin-top: 16px; }
}

.hero { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr); height: 100svh; max-height: 750px; min-height: 540px; }
.hero-media { background: var(--hero-media-bg); height: 100%; overflow: hidden; position: relative; }
/* Scroll-snap: swipe nativo su touch/trackpad. Le ancore dei pallini portano allo slide. */
.hero-slider {
  display: flex;
  height: 100%;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  width: 100%;
}
.hero-slider::-webkit-scrollbar { display: none; }
.hero-slide { flex: 0 0 100%; height: 100%; scroll-snap-align: start; }
.hero-slide img { height: 100%; object-fit: cover; width: 100%; }
.hero-dots { bottom: 18px; display: flex; gap: 8px; justify-content: center; left: 0; position: absolute; right: 0; z-index: 1; }
.hero-dot {
  background: rgba(255, 255, 255, 0.5);
  border-radius: 999px;
  cursor: pointer;
  height: 9px;
  transition: background .2s ease, transform .2s ease;
  width: 9px;
}
.hero-dot:hover, .hero-dot:focus-visible { background: #fff; outline: none; transform: scale(1.3); }
/* Layout "fullscreen": foto a tutto schermo, testo in sovrimpressione su una
   sfumatura scura (testo chiaro, indipendente dal tema). Lo "split" è il default. */
.hero--fullscreen { display: block; position: relative; }
.hero--fullscreen .hero-media { inset: 0; position: absolute; }
.hero--fullscreen .hero-content {
  align-self: stretch;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.6) 38%, rgba(0, 0, 0, 0.25) 68%, rgba(0, 0, 0, 0) 100%);
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: flex-end;
  max-width: none;
  overflow: hidden;
  padding: 76px 8vw 72px;
  position: relative;
  z-index: 1;
}
.hero--fullscreen h1,
.hero--fullscreen .google-rating,
.hero--fullscreen .google-rating .count { color: #fff; }
.hero--fullscreen h1,
.hero--fullscreen .hero-subtitle { text-shadow: 0 1px 14px rgba(0, 0, 0, 0.55); }
.hero--fullscreen .hero-subtitle { color: rgba(255, 255, 255, 0.95); }
.hero--fullscreen .eyebrow .price { color: #fff; }
.hero--fullscreen .button.secondary { border-color: rgba(255, 255, 255, 0.65); color: #fff; }
.hero--fullscreen .hero-dots { z-index: 2; }
/* Layout "centrato": foto di sfondo, testo centrato su scrim uniforme. */
.hero--centrato { display: block; position: relative; }
.hero--centrato .hero-media { inset: 0; position: absolute; }
.hero--centrato .hero-content {
  align-items: center;
  background: linear-gradient(rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.7));
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  max-width: none;
  overflow: hidden;
  padding: 76px 6vw;
  position: relative;
  text-align: center;
  z-index: 1;
}
.hero--centrato h1, .hero--centrato .hero-subtitle { max-width: 760px; text-shadow: 0 1px 14px rgba(0, 0, 0, 0.55); }
.hero--centrato h1, .hero--centrato .google-rating, .hero--centrato .google-rating .count { color: #fff; }
.hero--centrato .hero-subtitle { color: rgba(255, 255, 255, 0.95); }
.hero--centrato .actions, .hero--centrato .google-rating { justify-content: center; }
.hero--centrato .button.secondary { border-color: rgba(255, 255, 255, 0.65); color: #fff; }
.hero--centrato .hero-dots { z-index: 2; }
/* Sullo scrim scuro il primario è SEMPRE pieno, qualunque sia la costruzione
   del tema o l'override dell'utente: un bottone "contorno" su foto scura è un
   rischio di leggibilità strutturale (stesso principio del secondary qui sopra).
   Su mobile questi hero tornano su fondo pagina e il primario torna token-driven. */
.hero--fullscreen .button.primary, .hero--centrato .button.primary { background: var(--accent); border-color: transparent; color: var(--on-accent); }
.hero--fullscreen .button.primary:hover, .hero--fullscreen .button.primary:focus-visible,
.hero--centrato .button.primary:hover, .hero--centrato .button.primary:focus-visible { background: var(--accent-strong); color: var(--on-accent); }
/* Layout "vetrina": foto di sfondo, contenuto in una card su fondo pieno (sempre leggibile). */
.hero--vetrina { display: grid; grid-template-columns: 1fr; align-items: center; position: relative; }
.hero--vetrina .hero-media { grid-area: 1 / 1; height: 100%; }
.hero--vetrina .hero-content {
  align-self: center;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius-card) + 8px);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
  grid-area: 1 / 1;
  justify-self: start;
  margin: 0 0 0 6vw;
  max-width: 520px;
  overflow: visible;
  padding: 40px;
  z-index: 1;
}
/* Layout "editoriale": split asimmetrico col titolo grande. */
.hero--editoriale { grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.72fr); }
.hero--editoriale .hero-content { padding: 88px 56px 96px; }
/* Titolo fluido: 82px pieni solo dove la colonna li regge (>=1440px circa); su
   viewport più stretti scala col viewport invece di sbordare. Le parole che
   comunque non entrano si sillabano (regola h1 in base.ts). */
.hero--editoriale h1 { font-size: clamp(52px, 5.7vw, 82px); }
/* Con nomi attività molto lunghi il titolone supera l'altezza fissa dell'hero
   e la colonna debordava sopra la sezione successiva (e sotto l'header sticky).
   Qui l'hero cresce col contenuto; il minimo replica ESATTAMENTE l'altezza di
   prima (clamp base: min 540px, 100svh, max 750px), quindi con nomi normali
   non cambia nulla e con nomi lunghi le foto si allungano insieme al testo. */
.hero--editoriale { height: auto; max-height: none; min-height: clamp(540px, 100svh, 750px); }
/* min-width: 0: la colonna del testo non deve mai allargarsi oltre il proprio
   track per colpa di una parola lunga; overflow-wrap (ereditato da eyebrow,
   sottotitolo, bottoni) spezza ciò che comunque non entra. */
.hero-content { align-self: center; min-width: 0; overflow-wrap: break-word; padding: 76px 60px 92px; }
.eyebrow { color: var(--gold); font-size: 14px; font-weight: 800; margin-bottom: 20px; text-transform: uppercase; }
.eyebrow .price { color: var(--green); margin-left: 6px; }
.status-notice {
  background: var(--accent);
  border-radius: var(--radius-ctl);
  color: var(--on-accent);
  display: inline-block;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
  margin-bottom: 18px;
  padding: 6px 12px;
  text-transform: uppercase;
}
.google-rating {
  align-items: baseline;
  color: var(--ink);
  display: inline-flex;
  flex-wrap: wrap;
  font-size: 15px;
  font-weight: 700;
  gap: 6px;
  margin-bottom: 18px;
}
.google-rating .stars { color: var(--gold); letter-spacing: 1px; }
.google-rating .count { color: var(--muted); font-weight: 600; }
.hero-subtitle { color: var(--muted); font-size: 21px; line-height: 1.42; margin-top: 26px; max-width: 640px; }
.hero-content { overflow: auto; }
@media (prefers-reduced-motion: reduce) {
  .hero-slider { scroll-behavior: auto; }
}
@media (max-width: 840px) {
  .hero { display: block; height: auto; max-height: none; min-height: 0; }
  .hero-media { height: 330px; min-height: 330px; }
  /* Su mobile i layout con overlay (fullscreen, centrato) tornano impilati e a
     colori-tema: l'overlay su foto è scomodo su telefono. */
  .hero--fullscreen .hero-media,
  .hero--centrato .hero-media { position: static; }
  .hero--fullscreen .hero-content,
  .hero--centrato .hero-content {
    background: none;
    height: auto;
    max-width: none;
    overflow: visible;
    padding: 44px 22px 54px;
    text-align: left;
  }
  .hero--fullscreen h1, .hero--fullscreen .hero-subtitle,
  .hero--centrato h1, .hero--centrato .hero-subtitle { text-shadow: none; }
  .hero--fullscreen h1, .hero--fullscreen .google-rating, .hero--fullscreen .google-rating .count,
  .hero--centrato h1, .hero--centrato .google-rating, .hero--centrato .google-rating .count { color: var(--ink); }
  .hero--fullscreen .hero-subtitle, .hero--centrato .hero-subtitle { color: var(--muted); }
  .hero--fullscreen .eyebrow .price, .hero--centrato .eyebrow .price { color: var(--green); }
  .hero--fullscreen .button.secondary, .hero--centrato .button.secondary { border-color: var(--line); color: var(--ink); }
  .hero--fullscreen .button.primary, .hero--centrato .button.primary { background: var(--btn-bg); border-color: var(--btn-border); color: var(--btn-ink); }
  .hero--fullscreen .button.primary:hover, .hero--fullscreen .button.primary:focus-visible,
  .hero--centrato .button.primary:hover, .hero--centrato .button.primary:focus-visible { background: var(--btn-hover-bg); color: var(--btn-hover-ink); }
  .hero--centrato .actions, .hero--centrato .google-rating { justify-content: flex-start; }
  /* Vetrina: foto sopra, card piena sotto (leggermente sovrapposta). */
  .hero--vetrina { display: block; }
  .hero--vetrina .hero-media { height: 300px; min-height: 300px; }
  .hero--vetrina .hero-content { border-radius: calc(var(--radius-card) + 6px); margin: -28px 16px 0; max-width: none; padding: 28px 22px; }
  /* Editoriale: titolo ridotto su mobile. */
  .hero--editoriale h1 { font-size: 40px; }
  .hero--editoriale .hero-content { padding: 44px 22px 54px; }
  .hero-content { overflow: visible; padding: 44px 22px 54px; }
  .hero-subtitle, .lead { font-size: 19px; }
}

.gallery {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  margin-top: 28px;
}
.gallery figure { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-media); margin: 0; overflow: hidden; }
.gallery img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.gallery-link { display: block; }
.gallery-link:hover img, .gallery-link:focus-visible img { opacity: .92; }
/* Variante "mosaico": tessere di taglie diverse su una griglia densa. Il
   pattern è deterministico (nth-child), quindi identico a ogni build. */
.gallery--mosaico { grid-auto-flow: dense; grid-auto-rows: 170px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.gallery--mosaico figure { height: 100%; }
.gallery--mosaico .gallery-link { height: 100%; }
.gallery--mosaico img { aspect-ratio: auto; height: 100%; }
.gallery--mosaico figure:nth-child(5n + 1) { grid-column: span 2; grid-row: span 2; }
.gallery--mosaico figure:nth-child(8n + 4) { grid-row: span 2; }
/* Variante "pellicola": una sola riga orizzontale a scroll-snap, foto grandi.
   Lo scorrimento è nativo (touch/trackpad/rotella), nessun JS. */
.gallery--pellicola {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 12px;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
}
.gallery--pellicola figure { flex: 0 0 min(460px, 78vw); scroll-snap-align: start; }
.gallery--pellicola img { aspect-ratio: 3 / 2; }
.lightbox {
  align-items: center;
  background: var(--lightbox-bg);
  display: flex;
  inset: 0;
  justify-content: center;
  opacity: 0;
  padding: 28px;
  position: fixed;
  visibility: hidden;
  z-index: 50;
}
.lightbox:target { opacity: 1; visibility: visible; }
.lightbox img { border-radius: var(--radius-media); height: auto; max-height: 92vh; max-width: 84vw; object-fit: contain; width: auto; }
.lightbox-close {
  color: #fff;
  font-size: 44px;
  line-height: 1;
  position: absolute;
  right: 28px;
  top: 18px;
  z-index: 1;
}
.lightbox-nav {
  align-items: center;
  background: rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  color: #fff;
  display: flex;
  font-size: 34px;
  height: 52px;
  justify-content: center;
  line-height: 1;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
}
.lightbox-nav:hover, .lightbox-nav:focus-visible { background: rgba(255, 255, 255, 0.3); outline: none; }
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }
.lightbox-counter {
  bottom: 22px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  left: 0;
  position: absolute;
  right: 0;
  text-align: center;
}
@media (prefers-reduced-motion: reduce) {
  .gallery--pellicola { scroll-behavior: auto; }
}
@media (max-width: 840px) {
  /* Mosaico: due colonne con tessere più basse (le span del pattern restano). */
  .gallery--mosaico { grid-auto-rows: 120px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  /* Pellicola: foto larghe ma con la successiva che "sbircia" dal bordo,
     così si capisce a colpo d'occhio che la striscia scorre. */
  .gallery--pellicola figure { flex-basis: min(300px, 80vw); }
}

.features {
  display: grid;
  gap: 12px 20px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  list-style: none;
  margin: 28px 0 0;
  padding: 0;
}
.feature { align-items: center; color: var(--ink); display: flex; font-weight: 600; gap: 10px; }
.feature .icon { color: var(--green); flex: 0 0 auto; height: 20px; width: 20px; }
/* Variante "schede": ogni voce è una piccola card con l'icona accentata in
   una pastiglia tonda (fondo --nav-hover, translucenza del tema). */
.features--schede { gap: 14px; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
.features--schede .feature {
  align-items: flex-start;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius-card) + 2px);
  flex-direction: column;
  gap: 12px;
  padding: 18px;
}
.features--schede .feature .icon {
  background: var(--nav-hover);
  border-radius: 999px;
  color: var(--accent);
  height: 32px;
  padding: 7px;
  width: 32px;
}
/* Variante "elenco": lista compatta e leggera su due colonne, righe separate. */
.features--elenco { gap: 0 36px; grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 880px; }
.features--elenco .feature { border-bottom: 1px solid var(--line); font-size: 15px; font-weight: 500; padding: 10px 2px; }
.features--elenco .feature .icon { color: var(--accent); height: 16px; width: 16px; }
@media (max-width: 840px) {
  /* Schede: due colonne compatte su mobile (una sola colonna di card diventa
     un tunnel verticale monotono con 8+ voci). */
  .features--schede { gap: 10px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .features--schede .feature { gap: 10px; padding: 14px; }
  .features--elenco { grid-template-columns: 1fr; }
}

.review-ticker { margin-top: 28px; overflow: hidden; }
.review-track { display: flex; width: max-content; animation: ticker 48s linear infinite; }
.review-ticker:hover .review-track, .review-ticker:focus-within .review-track { animation-play-state: paused; }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.review-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  cursor: pointer;
  display: flex;
  flex: 0 0 300px;
  flex-direction: column;
  gap: 12px;
  margin: 0 14px 0 0;
  max-width: 300px;
  padding: 18px;
  transition: border-color .2s ease;
}
.review-card:hover, .review-card:focus-visible { border-color: var(--accent); outline: none; }
.review-card blockquote { margin: 0; }
.review-card blockquote p {
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  color: var(--ink);
  display: -webkit-box;
  font-size: 15px;
  line-height: 1.5;
  line-clamp: 4;
  overflow: hidden;
}
.review-meta {
  align-items: center;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  font-weight: 800;
  gap: 10px;
  justify-content: space-between;
  margin-top: auto;
}
.stars { color: var(--gold); letter-spacing: 1px; }
.stars .empty { color: var(--star-empty); }
.review-card .rating-text { color: var(--ink); }
/* Nomi autore lunghissimi (una sola parola): si spezzano invece di sbordare
   dalla card (nastro, griglia, citazione) o dal modal. */
.review-author, .review-modal-author { min-width: 0; overflow-wrap: anywhere; }
/* Variante "griglia": card statiche in griglia, niente autoscroll. La copia
   duplicata del loop (aria-hidden) viene nascosta: serve solo al nastro. */
.reviews--griglia .review-ticker { overflow: visible; }
.reviews--griglia .review-track {
  animation: none;
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  width: auto;
}
.reviews--griglia .review-card { margin: 0; max-width: none; }
.reviews--griglia .review-card blockquote p { -webkit-line-clamp: 6; line-clamp: 6; }
.reviews--griglia .review-card[aria-hidden="true"] { display: none; }
/* Variante "citazione": ogni recensione è una grande citazione centrata in
   serif (--font-heading), col testo COMPLETO in pagina (niente clamp: il modal
   resta raggiungibile ma non è necessario). Lunghezza riga limitata in ch. */
.reviews--citazione .section-label, .reviews--citazione h2 { text-align: center; }
.reviews--citazione h2 { margin-left: auto; margin-right: auto; }
.reviews--citazione > p { margin: 0 auto; max-width: 62ch; text-align: center; }
.reviews--citazione .review-ticker { overflow: visible; }
.reviews--citazione .review-track {
  animation: none;
  display: grid;
  gap: 52px;
  justify-items: center;
  margin-top: 14px;
  width: auto;
}
.reviews--citazione .review-card {
  background: none;
  border: none;
  margin: 0;
  max-width: 640px;
  padding: 0 12px;
  text-align: center;
  width: 100%;
}
.reviews--citazione .review-card[aria-hidden="true"] { display: none; }
.reviews--citazione .review-card::before {
  color: var(--accent);
  content: "\201C";
  display: block;
  font-family: var(--font-heading);
  font-size: 64px;
  line-height: .55;
  opacity: .6;
}
.reviews--citazione .review-card blockquote p {
  -webkit-line-clamp: none;
  color: var(--ink);
  display: block;
  font-family: var(--font-heading);
  font-size: 25px;
  line-clamp: none;
  line-height: 1.4;
  margin: 0 auto;
  max-width: 44ch;
  overflow: visible;
}
.reviews--citazione .review-meta { gap: 12px; justify-content: center; margin-top: 2px; }
.reviews--citazione .review-card:hover, .reviews--citazione .review-card:focus-visible { opacity: .85; }
.review-modal {
  align-items: center;
  background: var(--lightbox-bg);
  display: flex;
  inset: 0;
  justify-content: center;
  opacity: 0;
  padding: 24px;
  position: fixed;
  visibility: hidden;
  z-index: 60;
}
.review-modal:target { opacity: 1; visibility: visible; }
.review-modal-card {
  background: var(--panel);
  border-radius: calc(var(--radius-card) + 4px);
  color: var(--ink);
  max-height: 86vh;
  max-width: 560px;
  overflow: auto;
  padding: 32px;
  position: relative;
  width: 100%;
}
.review-modal-card .stars { font-size: 18px; letter-spacing: 2px; }
.review-modal-card blockquote { margin: 16px 0 0; }
.review-modal-card blockquote p { font-size: 19px; line-height: 1.55; }
.review-modal-author { color: var(--muted); font-weight: 800; margin-top: 18px; }
.modal-close {
  color: var(--muted);
  font-size: 32px;
  line-height: 1;
  position: absolute;
  right: 18px;
  top: 8px;
}
@media (prefers-reduced-motion: reduce) {
  .review-track { animation: none; }
  .review-ticker { overflow-x: auto; }
}
@media (max-width: 840px) {
  /* Citazione: corpo più contenuto su mobile, spaziatura ridotta. */
  .reviews--citazione .review-track { gap: 40px; }
  .reviews--citazione .review-card blockquote p { font-size: 20px; }
  .reviews--citazione .review-card::before { font-size: 52px; }
}

.value-list, .hours-list { display: grid; gap: 10px; list-style: none; margin: 18px 0 0; padding: 0; }
.value-list li, .hours-list li {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-card);
  padding: 14px 16px;
}
/* overflow-wrap: l'indirizzo contiene il nome dell'attività così com'è; una
   parola lunga si spezza invece di sbordare dalla colonna dei contatti. */
address { display: grid; font-style: normal; gap: 6px; overflow-wrap: break-word; }
.contact-hours .hours-title { font-size: 18px; font-weight: 800; margin: 0 0 10px; }
/* Variante "schede": titolo a tutta larghezza, poi indirizzo, azioni e orari
   come card affiancate. display:contents "apre" .contact-main così i suoi
   figli diventano item della griglia accanto a .contact-hours. */
.contact--schede .contact-layout { align-items: stretch; gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.contact--schede .contact-main { display: contents; }
.contact--schede .contact-main h2 { grid-column: 1 / -1; margin-bottom: 4px; }
.contact--schede .contact-main address,
.contact--schede .contact-main .actions,
.contact--schede .contact-hours {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius-card) + 4px);
  padding: 24px;
}
.contact--schede .contact-main address { align-content: start; }
.contact--schede .contact-main .actions { align-content: start; align-items: stretch; flex-direction: column; margin-top: 0; }
.contact--schede .hours-list { gap: 0; margin-top: 6px; }
.contact--schede .hours-list li { background: none; border: none; border-bottom: 1px solid var(--line); border-radius: 0; padding: 9px 0; }
.contact--schede .hours-list li:last-child { border-bottom: none; }
/* Variante "centrato": colonna unica centrata, lunghezza riga contenuta. */
.contact--centrato .section-label { text-align: center; }
.contact--centrato .contact-layout {
  gap: 30px;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  margin: 0 auto;
  max-width: 660px;
  text-align: center;
}
.contact--centrato .contact-main { display: grid; justify-items: center; }
.contact--centrato .contact-main h2 { margin-left: auto; margin-right: auto; }
.contact--centrato address { justify-items: center; margin-top: 14px; }
.contact--centrato .contact-main .actions { justify-content: center; }
.contact--centrato .contact-hours { max-width: 460px; width: 100%; }
.contact--centrato .contact-hours .hours-title { text-align: center; }
@media (max-width: 840px) {
  /* Schede: le card tornano impilate (la regola base 1fr da sola perderebbe
     contro la specificità della griglia a 3 colonne qui sopra). */
  .contact--schede .contact-layout { grid-template-columns: 1fr; }
}

.legal-doc { margin: 0 auto; max-width: 820px; }
.legal-meta { color: var(--muted); font-size: 14px; margin: 4px 0 0; }
.legal-section { margin-top: 32px; }
.legal-section h2 { font-size: 26px; line-height: 1.15; margin-bottom: 10px; }
.legal-section p { color: var(--ink); line-height: 1.6; }
.legal-list { color: var(--ink); display: grid; gap: 8px; margin: 10px 0 0; padding-left: 20px; }
.legal-list li { line-height: 1.55; }
.impressum { display: grid; gap: 6px 18px; grid-template-columns: max-content 1fr; margin: 0; }
.impressum dt { color: var(--muted); font-weight: 700; }
.impressum dd { margin: 0; }