/* ============================================================================
   STYLE.CSS  —  SCHELETRO ESTETICO "PREMIUM" (BASE)
   ----------------------------------------------------------------------------
   Filosofia (eredità Barman PRO):
   - Layout stabili: niente micro-sfarfallii al tocco, immagini con aspect-ratio.
   - Tap target >= 44x44px su mobile.
   - Stati chiari: :hover, :active, :disabled, :focus-visible.
   - Performance: poche ombre, transizioni brevi, rispetto di reduced-motion.
   I colori/font reali arrivano da config.js (token --c-* qui sotto sono i default).
   Claude personalizza questo file per ogni cliente: questa è la base solida.
   ========================================================================== */

/* --- 1) TOKEN DI DESIGN --------------------------------------------------- */
:root {
  /* Colori (sovrascritti da config.js a runtime) */
  --c-primario:   #7a1f1f;
  --c-secondario: #caa24a;
  --c-sfondo:     #fbf7f0;
  --c-testo:      #241f1c;

  /* Derivati */
  --c-superficie: #ffffff;
  --c-bordo:      color-mix(in srgb, var(--c-testo) 12%, transparent);
  --c-tenue:      color-mix(in srgb, var(--c-testo) 60%, transparent);
  --c-primario-scuro: color-mix(in srgb, var(--c-primario) 82%, black);
  --c-su-primario: #ffffff;

  /* Tipografia */
  --font-titoli: 'Playfair Display', Georgia, serif;
  --font-testo:  'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  /* Scala tipografica fluida (clamp = si adatta allo schermo senza scatti) */
  --fs-hero:  clamp(2.4rem, 7vw, 4.2rem);
  --fs-h2:    clamp(1.6rem, 4.2vw, 2.4rem);
  --fs-h3:    clamp(1.2rem, 3vw, 1.5rem);
  --fs-base:  clamp(1rem, 2.4vw, 1.075rem);
  --fs-small: 0.875rem;

  /* Spaziatura (scala coerente) */
  --sp-1: 0.25rem;  --sp-2: 0.5rem;  --sp-3: 0.75rem;  --sp-4: 1rem;
  --sp-5: 1.5rem;   --sp-6: 2rem;    --sp-8: 3rem;      --sp-10: 4.5rem;

  /* Forme */
  --raggio:    14px;
  --raggio-sm: 9px;
  --raggio-pill: 999px;

  /* Ombre (leggere, premium) */
  --ombra-1: 0 1px 2px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.05);
  --ombra-2: 0 8px 24px rgba(0,0,0,.10);

  /* Movimento */
  --t-veloce: 120ms ease;
  --t-medio:  220ms cubic-bezier(.2,.7,.3,1);

  /* Layout */
  --contenitore: 1060px;
  --header-h: 64px;
}

/* --- 2) RESET ESSENZIALE ------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-testo);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--c-testo);
  background: var(--c-sfondo);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  /* spazio in fondo per non finire sotto la barra azioni mobile */
  padding-bottom: env(safe-area-inset-bottom);
}
img, picture, svg { display: block; max-width: 100%; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
h1, h2, h3, h4 { font-family: var(--font-titoli); line-height: 1.15; font-weight: 700; }
button { font: inherit; cursor: pointer; }

/* Rispetta chi preferisce meno animazioni */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* --- 3) UTILITY ---------------------------------------------------------- */
.contenitore { width: min(100% - 2rem, var(--contenitore)); margin-inline: auto; }
.sezione { padding-block: var(--sp-10); }
.sezione__occhiello {
  display: inline-block; font-family: var(--font-testo); font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; font-size: var(--fs-small);
  color: var(--c-primario);
}
.sezione__titolo { font-size: var(--fs-h2); margin-top: var(--sp-2); margin-bottom: var(--sp-5); }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* Focus visibile e coerente ovunque (accessibilità) */
:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--c-secondario) 70%, var(--c-testo));
  outline-offset: 2px;
  border-radius: 4px;
}

/* --- 4) BOTTONI (con tutti gli stati) ------------------------------------ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 48px; min-width: 48px;            /* tap target generoso */
  padding: 0 var(--sp-5);
  border: 1px solid transparent; border-radius: var(--raggio-pill);
  font-weight: 600; font-size: 1rem; line-height: 1;
  text-align: center;
  transition: transform var(--t-veloce), background var(--t-medio), box-shadow var(--t-medio);
  -webkit-tap-highlight-color: transparent;     /* niente flash blu al tap */
  user-select: none;
}
.btn:active { transform: translateY(1px) scale(.99); }   /* feedback al tocco */
.btn:disabled, .btn[aria-disabled="true"] {
  opacity: .5; cursor: not-allowed; transform: none;
}

.btn--primario {
  background: var(--c-primario); color: var(--c-su-primario);
  box-shadow: var(--ombra-1);
}
.btn--primario:hover { background: var(--c-primario-scuro); }

.btn--secondario {
  background: var(--c-superficie); color: var(--c-testo);
  border-color: var(--c-bordo); box-shadow: var(--ombra-1);
}
.btn--secondario:hover { border-color: color-mix(in srgb, var(--c-testo) 28%, transparent); }

.btn--ghost { background: transparent; color: var(--c-testo); }
.btn--oro {
  background: var(--c-secondario);
  color: color-mix(in srgb, var(--c-testo) 92%, black);
}

/* --- 5) HEADER ----------------------------------------------------------- */
.header {
  position: sticky; top: 0; z-index: 50;
  height: var(--header-h);
  display: flex; align-items: center;
  background: color-mix(in srgb, var(--c-sfondo) 86%, transparent);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-medio), background var(--t-medio);
}
.header.is-scrolled {
  border-bottom-color: var(--c-bordo);
  background: color-mix(in srgb, var(--c-sfondo) 94%, transparent);
}
.header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); width: 100%; }
.header__brand { font-family: var(--font-titoli); font-weight: 700; font-size: 1.2rem; }
.nav { display: flex; align-items: center; gap: var(--sp-5); }
.nav a { font-size: .95rem; font-weight: 500; padding: var(--sp-2); border-radius: var(--raggio-sm); }
.nav a:hover { color: var(--c-primario); }
.nav__toggle {
  display: none; width: 48px; height: 48px; border: 1px solid var(--c-bordo);
  border-radius: var(--raggio-sm); background: var(--c-superficie);
  align-items: center; justify-content: center;
}
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after {
  content: ""; display: block; width: 20px; height: 2px; background: var(--c-testo);
  position: relative; transition: transform var(--t-medio);
}
.nav__toggle span::before { position: absolute; top: -6px; }
.nav__toggle span::after  { position: absolute; top: 6px; }

@media (max-width: 720px) {
  .nav__toggle { display: inline-flex; }
  .nav {
    position: absolute; top: var(--header-h); left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--c-superficie); border-bottom: 1px solid var(--c-bordo);
    box-shadow: var(--ombra-2);
    /* nascosto senza causare reflow improvvisi */
    display: none;
  }
  .nav.is-open { display: flex; }
  .nav a { padding: var(--sp-4); border-bottom: 1px solid var(--c-bordo); min-height: 48px; display: flex; align-items: center; }
}

/* --- 6) HERO ------------------------------------------------------------- */
.hero {
  position: relative; overflow: hidden;
  padding-block: clamp(3rem, 12vw, 7rem);
  text-align: center;
  background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--c-secondario) 16%, transparent), transparent 60%),
    var(--c-sfondo);
}
.hero__tipo { color: var(--c-primario); font-weight: 600; letter-spacing: .12em; text-transform: uppercase; font-size: var(--fs-small); }
.hero__nome { font-size: var(--fs-hero); margin-block: var(--sp-3) var(--sp-2); }
.hero__tagline { font-size: var(--fs-h3); color: var(--c-tenue); font-style: italic; }
.hero__sottotitolo { max-width: 42ch; margin: var(--sp-4) auto 0; color: var(--c-tenue); }
.hero__azioni { display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: center; margin-top: var(--sp-6); }
.hero__filetto {
  width: 64px; height: 3px; margin: var(--sp-5) auto 0;
  background: var(--c-secondario); border-radius: var(--raggio-pill);
}

/* --- 7) STORIA ----------------------------------------------------------- */
.storia { background: var(--c-superficie); }
.storia__corpo { max-width: 60ch; }
.storia__corpo p + p { margin-top: var(--sp-4); }
.storia__corpo p:first-of-type::first-letter {
  font-family: var(--font-titoli); font-size: 3.2rem; line-height: .8;
  float: left; padding: 4px 10px 0 0; color: var(--c-primario);
}

/* --- 8) MENÙ ------------------------------------------------------------- */
.menu__intestazione { text-align: center; margin-bottom: var(--sp-6); }
.menu-categorie {
  position: sticky; top: var(--header-h); z-index: 30;
  display: flex; gap: var(--sp-2); overflow-x: auto; padding: var(--sp-3) 0;
  margin-bottom: var(--sp-5);
  background: color-mix(in srgb, var(--c-sfondo) 92%, transparent);
  backdrop-filter: blur(8px);
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.menu-categorie::-webkit-scrollbar { display: none; }
.chip {
  flex: 0 0 auto; min-height: 40px; display: inline-flex; align-items: center;
  padding: 0 var(--sp-4); border-radius: var(--raggio-pill);
  border: 1px solid var(--c-bordo); background: var(--c-superficie);
  font-size: .9rem; font-weight: 600; white-space: nowrap;
  transition: background var(--t-veloce), border-color var(--t-veloce);
}
.chip:hover { border-color: var(--c-primario); color: var(--c-primario); }
.chip:active { transform: scale(.97); }

.menu-categoria { margin-bottom: var(--sp-8); scroll-margin-top: calc(var(--header-h) + 60px); }
.menu-categoria__titolo {
  font-size: var(--fs-h3); color: var(--c-primario);
  padding-bottom: var(--sp-2); margin-bottom: var(--sp-4);
  border-bottom: 2px solid color-mix(in srgb, var(--c-secondario) 60%, transparent);
}
.menu-lista { display: grid; gap: var(--sp-2); }

.piatto {
  display: flex; gap: var(--sp-4); align-items: flex-start;
  padding: var(--sp-4); border-radius: var(--raggio);
  transition: background var(--t-veloce);
}
.piatto:hover { background: color-mix(in srgb, var(--c-secondario) 8%, transparent); }
.piatto__foto {
  width: 72px; height: 72px; border-radius: var(--raggio-sm);
  object-fit: cover; flex: 0 0 auto; background: var(--c-bordo);
}
.piatto__corpo { flex: 1 1 auto; min-width: 0; }
.piatto__riga { display: flex; align-items: baseline; gap: var(--sp-2); }
.piatto__nome { font-size: 1.075rem; font-weight: 700; }
.piatto__dots { flex: 1 1 auto; border-bottom: 1px dotted var(--c-bordo); transform: translateY(-3px); }
.piatto__prezzo { font-weight: 700; color: var(--c-primario); white-space: nowrap; font-variant-numeric: tabular-nums; }
.piatto__desc { color: var(--c-tenue); font-size: .95rem; margin-top: var(--sp-1); }
.piatto__tags { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-2); }
.piatto__tag {
  font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  padding: 2px 8px; border-radius: var(--raggio-pill);
  background: color-mix(in srgb, var(--c-secondario) 22%, transparent);
  color: color-mix(in srgb, var(--c-testo) 80%, black);
}
.piatto--esaurito { opacity: .55; }
.piatto__badge {
  display: inline-block; margin-top: var(--sp-2); font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--c-primario);
}
.piatto__allergeni { margin-top: var(--sp-2); font-size: .78rem; color: var(--c-tenue); }
.piatto__allergeni span { font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }

.menu-errore { text-align: center; padding: var(--sp-8) 0; color: var(--c-tenue); }
.menu-errore .btn { margin-top: var(--sp-4); }

/* Scheletri di caricamento (prevengono i salti di layout) */
.skeleton {
  position: relative; overflow: hidden; border-radius: var(--raggio-sm);
  background: color-mix(in srgb, var(--c-testo) 9%, transparent);
}
.skeleton::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--c-superficie) 60%, transparent), transparent);
  transform: translateX(-100%); animation: shimmer 1.3s infinite;
}
.skeleton--titolo { height: 22px; width: 40%; margin-bottom: var(--sp-4); }
.skeleton--riga   { height: 18px; width: 70%; margin: var(--sp-3) 0; }
.skeleton--desc   { height: 14px; width: 90%; }
@keyframes shimmer { 100% { transform: translateX(100%); } }

/* --- 9) GALLERIA --------------------------------------------------------- */
.galleria { background: var(--c-superficie); }
.galleria__griglia {
  display: grid; gap: var(--sp-3);
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.galleria__item { margin: 0; border-radius: var(--raggio); overflow: hidden; box-shadow: var(--ombra-1); background: var(--c-bordo); }
.galleria__item img {
  width: 100%; aspect-ratio: 4 / 3; object-fit: cover;   /* aspect-ratio = niente reflow */
  transition: transform var(--t-medio);
}
.galleria__item:hover img { transform: scale(1.04); }
.galleria__item figcaption { padding: var(--sp-2) var(--sp-3); font-size: var(--fs-small); color: var(--c-tenue); }

/* --- 10) INFO (orari + contatti) ----------------------------------------- */
.info__griglia { display: grid; gap: var(--sp-6); grid-template-columns: 1fr 1fr; }
@media (max-width: 720px) { .info__griglia { grid-template-columns: 1fr; } }

.card {
  background: var(--c-superficie); border: 1px solid var(--c-bordo);
  border-radius: var(--raggio); padding: var(--sp-6); box-shadow: var(--ombra-1);
}
.card h3 { font-size: var(--fs-h3); margin-bottom: var(--sp-4); }

.orari__riga { display: flex; justify-content: space-between; gap: var(--sp-4); padding: var(--sp-2) 0; border-bottom: 1px solid var(--c-bordo); }
.orari__riga:last-child { border-bottom: 0; }
.orari__riga--oggi { font-weight: 700; color: var(--c-primario); }
.orari__riga--oggi .orari__giorno::after { content: " · oggi"; font-weight: 600; color: var(--c-secondario); }

.contatti__voce { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2) 0; }
.contatti__azioni { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-4); }

/* --- 11) RECENSIONI (richiamo) ------------------------------------------- */
.recensioni { text-align: center; }
.recensioni__stelle { color: var(--c-secondario); font-size: 1.6rem; letter-spacing: .1em; }
.recensioni p { max-width: 48ch; margin: var(--sp-3) auto var(--sp-5); color: var(--c-tenue); }

/* --- 12) FOOTER ---------------------------------------------------------- */
.footer { background: var(--c-primario); color: var(--c-su-primario); padding-block: var(--sp-8); }
.footer a { color: var(--c-su-primario); }
.footer__brand { font-family: var(--font-titoli); font-size: 1.4rem; }
.footer__social { display: flex; gap: var(--sp-4); margin-top: var(--sp-4); }
.footer__social a { min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.25); border-radius: var(--raggio-pill); padding-inline: var(--sp-4); }
.footer__nota { margin-top: var(--sp-6); font-size: var(--fs-small); opacity: .75; }
.footer__legale { margin-top: var(--sp-2); font-size: var(--fs-small); opacity: .6; line-height: 1.5; }

/* --- 13) BARRA AZIONI MOBILE (utile per il tap NFC) ---------------------- */
.azioni-mobile {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  display: none; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3) calc(var(--sp-2) + env(safe-area-inset-bottom));
  background: color-mix(in srgb, var(--c-sfondo) 96%, transparent);
  border-top: 1px solid var(--c-bordo);
  backdrop-filter: blur(8px);
}
.azioni-mobile .btn { flex: 1 1 0; padding-inline: var(--sp-3); font-size: .92rem; }
@media (max-width: 720px) {
  .azioni-mobile { display: flex; }
  body { padding-bottom: 72px; }   /* spazio per non coprire il footer */
}

/* --- 14) ELEMENTI NASCOSTI (hidden) -------------------------------------- */
[hidden] { display: none !important; }

/* --- 15) STATI "TAB" ATTIVI (navigazione stile SPA) ---------------------- */
/* La scheda attiva segue la sezione visibile, senza ricaricare la pagina. */
.nav a.is-active { color: var(--c-primario); }
.nav a.is-active::after {
  content: ""; display: block; height: 2px; margin-top: 3px;
  border-radius: 2px; background: var(--c-secondario);
}
.azioni-mobile .btn.is-active {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--c-primario) 55%, transparent);
}
@media (max-width: 720px) {
  /* nel menù a tendina la sottolineatura non serve */
  .nav a.is-active::after { display: none; }
  .nav a.is-active { background: color-mix(in srgb, var(--c-primario) 8%, transparent); }
}

/* --- 16) TRANSIZIONI DI COMPARSA DELLE SEZIONI --------------------------- */
.reveal {
  opacity: 0; transform: translateY(18px); will-change: opacity, transform;
  transition: opacity .5s ease, transform .5s cubic-bezier(.2,.7,.3,1);
}
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ===== Avviso del locale (gestito dal pannello) ===== */
.avviso-locale {
  background: var(--c-primario);
  color: var(--c-su-primario);
  text-align: center;
  padding: 10px 16px;
  font-family: var(--font-testo);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: .01em;
}

/* ===== Eventi e novità (dal pannello) ===== */
.eventi { text-align: center; }
.eventi__lista {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-5);
  text-align: left;
}
.evento {
  background: var(--c-superficie);
  border: 1px solid var(--c-bordo);
  border-radius: var(--raggio);
  overflow: hidden;
  box-shadow: var(--ombra-1);
  display: flex;
  flex-direction: column;
}
.evento__foto {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
  background: var(--c-bordo);
}
.evento__corpo { padding: var(--sp-5); }
.evento__data {
  font-family: var(--font-testo);
  font-size: var(--fs-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--c-secondario);
  margin: 0 0 var(--sp-2);
}
.evento__titolo {
  font-family: var(--font-titoli);
  font-size: var(--fs-h3);
  color: var(--c-primario);
  margin: 0 0 var(--sp-2);
  line-height: 1.15;
}
.evento__desc { margin: 0; color: var(--c-testo); }

/* ============================================================================
   SU MISURA — STUDIO ESTETICO NINFEA (pacchetto Base, pagina singola)
   Mood: calmo, pulito, "premium accessibile". Angoli più morbidi e ombre più
   leggere del default per un'atmosfera da spa, non da ristorante.
   ========================================================================== */
:root {
  --raggio: 20px;
  --raggio-sm: 14px;
  --ombra-1: 0 1px 3px rgba(42,43,38,.05), 0 4px 14px rgba(42,43,38,.05);
}

/* Banner sito dimostrativo (stessa convenzione di tutti i siti di prova) */
.demo-banner {
  background: var(--c-testo); color: var(--c-sfondo);
  text-align: center; font-size: .82rem; line-height: 1.4;
  padding: 8px var(--sp-4);
}

/* Hero: velo di colore disteso, in attesa della foto vera dello studio */
.hero {
  background:
    radial-gradient(90% 70% at 50% -10%, color-mix(in srgb, var(--c-primario) 12%, transparent), transparent 65%),
    radial-gradient(70% 60% at 85% 110%, color-mix(in srgb, var(--c-secondario) 14%, transparent), transparent 60%),
    var(--c-sfondo);
}
.hero__tagline { font-weight: 500; }

/* Hero CON FOTO: attivare aggiungendo class="hero--foto" alla <section class="hero">
   in index.html e mettendo il file in assets/ (consigliato: assets/foto-hero.jpg,
   1600px di larghezza, sotto i 300KB). Testo chiaro su velo scuro per la leggibilità. */
.hero--foto {
  background:
    linear-gradient(180deg, rgba(30,33,26,.55), rgba(30,33,26,.72)),
    url("../assets/foto-hero.jpg") center / cover no-repeat;
}
.hero--foto .hero__tipo,
.hero--foto .hero__tagline { color: rgba(250,247,242,.92); }
.hero--foto .hero__nome,
.hero--foto .hero__sottotitolo { color: #faf7f2; }

/* Titoli di sezione: occhiello più minuto, tono da studio non da trattoria */
.sezione__occhiello { letter-spacing: .18em; }

/* Listino trattamenti: card più arrotondate, meno "menù ristorante" */
.piatto { border: 1px solid transparent; }
.piatto:hover { border-color: color-mix(in srgb, var(--c-secondario) 30%, transparent); }
.menu-categoria__titolo { border-bottom-style: dotted; }
