/* ============================================================
   BASICS & RESET
   ============================================================ */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
[hidden]{ display:none !important; }

:root{
  --pad: 18px;
  --line: rgba(0,0,0,.12);
  --greenwood-light: #8FA998; /* Verde salvia chiaro e minimal */
}

body{
  background:#f6f1ea;
  color:#151515;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* HEADER */
.header{
  position: sticky;
  top: 0;
  z-index: 50;
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 14px var(--pad);
  background: rgba(246,241,234,.92);
  backdrop-filter: blur(6px);
}

.menu-btn{
  border:0;
  background: transparent;
  font-size: 22px;
  cursor: pointer;
  padding: 6px 8px;
  line-height: 1;
}

.logo{
  display:flex;
  align-items: baseline;
  gap: 10px;
}
.logo-mark{ font-size: 18px; }
.logo-text{
  font-size: 14px;
  letter-spacing: .8px;
  text-transform: uppercase;
  opacity: .9;
}

/* ============================================================
   HERO (CARD COME LA FOTO)
   ============================================================ */
.hero{
  min-height: 70vh;
  padding: 24px var(--pad);
  position: relative;

  /* cover */
  background-color:#111;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* ✅ slider verticale “1 card alla volta” */
  display:flex;
  flex-direction: column;
  gap: 14px;
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
}

.hero-card{
  scroll-snap-align: center;
  width: min(520px, 100%);
  margin: auto;            /* centra orizzontale */
}

/* card trasparente sopra immagine */
.hero-card{
  max-width: 520px;
  padding: 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.25);
}

.hero-card h1{
  margin:0 0 8px 0;
  font-size: 34px;
  line-height: 1.05;
  letter-spacing: -0.5px;
  font-weight: 700;
  color:#6b3a32;
}

.hero-card p{
  margin:0 0 10px 0;
  color:#111;
  opacity:.9;
  line-height: 1.45;
  font-size: 14px;
}

.heroText{ opacity:.75; }

.heroBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top: 10px;
  padding: 12px 18px;
  border-radius: 999px;
  background:#6b3a32;
  color:#fff;
  text-decoration:none;
  font-weight: 800;
  letter-spacing: .12em;
  font-size: 12px;
}
/* ============================================================
   MENU ACCORDEON (GREENWOOD CHIARO)
   ============================================================ */
.menu{
  padding: 10px var(--pad);
}

.menu-section{
  margin-bottom: 8px;
}

.menu-title{
  width:100%;
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding: 18px 20px;
  background: var(--greenwood-light);
  border: 0;
  cursor: pointer;
  color: #ffffff;
  text-align: left;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
}

.menu-title h2{
  margin:0;
  font-size: 20px;
  font-weight: 700;
  color:#ffffff;
  text-transform: none;
}

.plus{
  font-size: 24px;
  font-weight: 300;
  color:#ffffff;
}

.menu-content{
  padding-bottom: 14px;
}

/* ============================================================
   PRODOTTI (TITOLI MINIMAL E INGREDIENTI LEGGIBILI)
   ============================================================ */
.item{
  padding: 16px 0;
  border-top: 1px solid rgba(0,0,0,.08);
}

.item-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  
  /* Titolo Prodotto */
  font-size: 14px;            
  font-weight: 500;           
  text-transform: uppercase;  
  letter-spacing: 1.2px;      
  color: #151515;
  line-height: 1.3;
}

.item-desc{
  margin-top: 5px;
  /* Ingredienti: Ingranditi a 13px per leggibilità */
  font-size: 13px; 
  font-weight: 300;           
  color: rgba(0,0,0,.55);      
  text-transform: none;       
  font-style: italic;         
  letter-spacing: 0.3px;
  line-height: 1.5;
}

/* FOOTER NOTES */
.note{
  padding: 18px var(--pad) 34px;
  color: rgba(0,0,0,.45);
  font-size: 14px;
}
.note p{ margin:0; }

/* ============================================================
   MENU MOBILE A TENDINA (INTEGRALE)
   ============================================================ */
.menu-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.3);
  z-index: 9998;
  backdrop-filter: blur(2px);
}

.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: #ffffff;
  transform: translateY(-105%);
  transition: transform .3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.mobile-menu.is-open {
  transform: translateY(0);
}

.mobile-menu__head {
  padding: 40px 0 30px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-bottom: 1px solid #f2f2f2; 
}

.mobile-logo {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.mobile-logo__mark {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-size: 56px; 
  letter-spacing: -3px;
  line-height: 1;
  color: #000;
}

.mobile-logo__text {
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-size: 11px; 
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: #000;
  margin-top: 8px;
  font-weight: 400;
}

.mobile-menu__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mobile-menu__list li {
  border-bottom: 1px solid #f2f2f2;
}

.mobile-menu__link {
  display: block;
  padding: 22px var(--pad);
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 13px;
  color: #444;    
  text-decoration: none;
  transition: background 0.2s;
}

.mobile-menu__link:active {
  background: #fafafa;
  color: #000;
}

/* LANGUAGE SELECTOR */
.langbar{
  display: flex;
  gap: 10px;
  padding: 10px var(--pad);
}

.langbtn{
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font: 600 13px system-ui, sans-serif;
  cursor: pointer;
}

.langbtn.is-active{
  border-color: rgba(0,0,0,.45);
}

/* --- SEZIONE INFO PROFESSIONALE --- */
.info-block {
  padding: 45px 20px;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  background: transparent;
}

.info-block h2 {
  margin: 0 0 20px 0;
  font-size: 26px;
  font-weight: 600;
  color: #151515;
  letter-spacing: -0.5px;
}

/* La linea verde salvia sotto il titolo */
.info-block h2::after {
  content: '';
  display: block;
  width: 40px;
  height: 3px;
  background: #8FA998; /* Il tuo verde Greenwood */
  margin-top: 12px;
}

.info-block p {
  font-size: 16px;
  line-height: 1.7; /* Rende la lettura molto più riposante */
  color: #444;
  margin-bottom: 10px;
}

.info-highlight {
  display: block;
  font-weight: 600;
  margin-top: 15px;
  color: #151515;
  font-size: 17px;
}

/* blocca overlay “fantasma” su iPhone */
[hidden]{ display:none !important; }

.menu-backdrop{ pointer-events:auto; }
.menu-backdrop[hidden]{ pointer-events:none; }

.mobile-menu{ pointer-events:none; }
.mobile-menu.is-open{ pointer-events:auto; }


/* =========================
   HOME CONTENT + BOTTONI
   ========================= */
.home-content{
  padding: 22px var(--pad);
  background: #fcfaf7;
}

.home-content h1{
  margin: 0 0 10px 0;
  font-size: 26px;
  letter-spacing: .5px;
}

.home-content p{
  margin: 0 0 16px 0;
  opacity: .8;
  line-height: 1.45;
}

.home-actions{
  display:flex;
  gap:10px;
  flex-wrap: wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius: 14px;
  text-decoration:none;
  font-weight:700;
  border:1px solid rgba(0,0,0,.12);
}

.btn.primary{
  background:#151515;
  color:#fff;
  border-color:#151515;
}

.btn.secondary{
  background:#fff;
  color:#151515;
}

/* =========================
   HOME GRID
   ========================= */
.home-grid{
  padding: 18px var(--pad) 30px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  background:#f6f1ea;
}

.home-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:16px 14px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  text-decoration:none;
  color:#151515;
  font-weight:700;
}

.home-card span{
  font-size:18px;
}

#homeCards{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.home-card{ max-width: 520px; }

.home-hero-card{
  margin-bottom: 14px;
}


/* =========================
   HOME CARDS (nuova sezione sotto la cover)
   ========================= */
.home-cards{
  padding: 18px var(--pad) 30px;
  display: grid;
  gap: 14px;
  background: #f6f1ea;
}

/* Card stile “bello” come prima */
.home-hero-card{
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 22px;
  padding: 22px 20px;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);

  max-width: 620px;
  margin: 0 auto; /* centra */
}

.home-hero-card h1{
  margin: 0 0 10px 0;
  font-size: 34px;
  line-height: 1;
}

.home-hero-card p{
  margin: 0 0 16px 0;
  opacity: .8;
  line-height: 1.45;
}

/* bottone dentro card */
.home-hero-card .heroBtn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  background: #7b3f36; /* puoi cambiare */
  color: #fff;
}

/* =========================
   HOME CARD – STILE GLASS (ERRICO PORZIO)
   ========================= */

.home-hero-card{
  max-width: 520px;
  margin: 0 auto;
  padding: 22px 20px;

  border-radius: 22px;

  /* GLASS EFFECT */
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.home-hero-card h1{
  margin: 0 0 10px 0;
  font-size: 34px;
  line-height: 1.05;
  color: #6b3a32;
}

.home-hero-card p{
  margin: 0 0 16px 0;
  font-size: 15px;
  line-height: 1.5;
  color: #111;
  opacity: .85;
}

.home-hero-card .heroBtn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  background: #6b3a32;
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  letter-spacing: .12em;
  font-size: 12px;
}

/* === STILE GLASS "ERRICO PORZIO" SOLO PER LE CARD === */
#homeCards .home-hero-card {
  /* 1. Trasparenza e Colore */
  background: rgba(255, 255, 255, 0.65) !important;
  
  /* 2. Effetto Vetro (Blur + Saturazione) */
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;

  /* 3. Bordo sottile "luccicante" */
  border: 1px solid rgba(255, 255, 255, 0.4) !important;
  
  /* 4. Ombra morbida e profonda */
  box-shadow: 0 15px 35px rgba(0,0,0,0.12) !important;
  
  border-radius: 28px !important; /* Angoli più tondi come Porzio */
  padding: 30px 25px !important;
  max-width: 520px !important;
  margin: 0 auto 20px auto !important;
}

/* Titolo della card più elegante */
#homeCards .home-hero-card h1 {
  color: #6b3a32 !important;
  font-size: 32px !important;
  font-weight: 800 !important;
  letter-spacing: -1px !important;
  line-height: 1.1 !important;
  margin-bottom: 15px !important;
}

/* Testo della card più leggibile */
#homeCards .home-hero-card p {
  color: #1a1a1a !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  opacity: 1 !important;
}

/* =========================
   STRIP PIATTI – SCROLL ORIZZONTALE
   ========================= */

.piatti-strip{
  padding: 26px var(--pad) 10px;
  background: #f6f1ea;
}

.piatti-title{
  margin: 0 0 14px 4px;
  font-size: 26px;
  font-weight: 700;
  color: #151515;
}

/* contenitore scroll */
.piatti-scroll{
  display: flex;
  gap: 18px;
  overflow-x: auto;
  padding-bottom: 14px;

  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

/* nasconde scrollbar (iOS style) */
.piatti-scroll::-webkit-scrollbar{
  display: none;
}

/* singolo piatto */
.piatto-card{
  flex: 0 0 auto;
  width: 140px;
  text-align: center;
  scroll-snap-align: start;
}

/* immagine piatto */
.piatto-card img{
  width: 140px;
  height: 140px;
  object-fit: cover;      /* ✅ riempie bene il cerchio */
  border-radius: 50%;
  display: block;         /* ✅ evita comportamenti strani inline */
  background: #f2f2f2;    /* ✅ se manca immagine, sfondo pulito */
}

/* nome piatto */
.piatto-card span{
  display: block;
  margin-top: 8px;
  font-size: 15px;
  font-weight: 600;
  color: #151515;
}

.strip-categories{
  display:flex;
  gap:12px;
  overflow:auto;
  padding: 0 var(--pad);
  margin: 18px 0 10px 0;
}
.cat-btn{
  border:1px solid rgba(0,0,0,.15);
  background:#fff;
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.cat-btn.is-active{
  background: var(--greenwood);
  color:#fff;
  border-color: transparent;
}

#stripItemsGrid{
  display: flex !important;
  flex-direction: column !important;
  gap: 14px;
}

.piatti-title {
  font-weight: 300;
  letter-spacing: 0.6px;
}

/* =========================
   FIX: TOGLIE SCRITTA NERA SOPRA LE COPERTINE (pagine interne)
   Non tocca le card HOME
   ========================= */

.hero > h1,
.hero > h2,
.hero > p,
.hero .heroText {
  display: none !important;
}

/* se nelle pagine interne c'è una card dentro la hero, la nascondo */
.hero .hero-card:not(.home-hero-card){
  display: none !important;
}

.lang-btn{
  margin-left: auto;
  margin-right: 12px;
  border: 1px solid rgba(255,255,255,.5);
  background: rgba(0,0,0,.25);
  color: #fff;
  padding: 8px 10px;
  border-radius: 12px;
  font: inherit;
  cursor: pointer;
  letter-spacing: .06em;
}

/* ====== LANGUAGE BUTTON (flags) ====== */
.lang-btn{
  margin-left:auto;
  margin-right: 12px;
  width: 54px;
  height: 34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;

  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  border-radius: 999px;
  cursor: pointer;
  padding: 0;
}

/* pallini-flag */
.lang-btn .flag{
  width: 18px;
  height: 18px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 2px 6px rgba(0,0,0,.10);
}

/* 🇮🇹 IT flag */
.lang-btn .flag-it{
  background:
    linear-gradient(90deg,
      #009246 0 33.33%,
      #ffffff 33.33% 66.66%,
      #ce2b37 66.66% 100%);
}

/* 🇬🇧 EN flag (stile semplice, pulito, riconoscibile) */
.lang-btn .flag-en{
  background:
    linear-gradient(#012169, #012169);
  position: relative;
}
.lang-btn .flag-en::before,
.lang-btn .flag-en::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent 42%, #fff 42% 58%, transparent 58%),
    linear-gradient(transparent 42%, #fff 42% 58%, transparent 58%);
  opacity: .95;
}
.lang-btn .flag-en::after{
  background:
    linear-gradient(90deg, transparent 46%, #C8102E 46% 54%, transparent 54%),
    linear-gradient(transparent 46%, #C8102E 46% 54%, transparent 54%);
}

/* mostra solo la bandiera della lingua ATTIVA */
.lang-btn.is-it .flag-en{ display:none; }
.lang-btn.is-en .flag-it{ display:none; }

/* =========================
   SCROLL REVEAL (globale)
   ========================= */
.reveal{
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .85s ease, transform .85s ease;
  will-change: opacity, transform;
}

.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Accessibilità: se l’utente ha “riduci animazioni” */
@media (prefers-reduced-motion: reduce){
  .reveal{
    transition: none;
    transform: none;
    opacity: 1;
  }
}

/* ===== Reviews: stile chat ===== */
.reviews-chat{
  padding: 22px 0 40px;
  margin-top: 18px;
}

.reviews-title{
  margin: 0 0 10px;
  font-size: 26px;
  font-weight: 300;
  letter-spacing: .6px;
}

.reviews-note{
  margin: 0 0 16px;
  font-size: 13px;
  font-style: italic;
  color: #2f6b4f;
  opacity: .85;
  line-height: 1.5;
  max-width: 520px;
}

.chat{
  display:flex;
  flex-direction: column;
  gap: 14px;
  max-width: 520px;
}

.bubble{
  max-width: 92%;
  padding: 14px 16px;
  border-radius: 18px;
  line-height: 1.55;
  font-size: 15px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
  white-space: pre-line;
}

.bubble.left{
  align-self: flex-start;
  border-top-left-radius: 8px;
}

.bubble.right{
  align-self: flex-end;
  background: rgba(143,169,152,.22);
  border-top-right-radius: 8px;
}

.meta{
  margin-top: 10px;
  font-size: 12px;
  opacity: .7;
  display:flex;
  justify-content:flex-end;
}

.stars{ letter-spacing: 1px; }

.logo-mark-img{
  height: 42px;
  width: auto;
  object-fit: contain;
  display: block;
}

.mobile-logo__img {
  width: 90px;        /* aumenta dimensione */
  height: auto;       /* mantiene proporzione */
  display: block;
  margin: 0 auto;
}
