
:root{
  --bg:#CBB89C; /* beige generale */
  --bg2:#FAF7F2;
  --text:#1b1b1b; --muted:#555;
  --brand:#c6a27a; --brand2:#9b7b56; --accent:#7c644b;
  --max:1200px; --r:14px; --sh:0 10px 30px rgba(0,0,0,.08);
  --white:#FAF7F2; --line:#e6e2dc; --ink:#111; --ink2:#444;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui}
a{color:var(--brand);text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:var(--max);margin:0 auto;padding:0 24px}

header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.6);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:center;height:64px;position:relative}

.burger{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:10px;background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.08);display:grid;place-items:center;cursor:pointer}
.burger span,.burger::before,.burger::after{content:"";display:block;width:18px;height:2px;background:#111;border-radius:2px;transition:.25s}
.burger::before{transform:translateY(-6px)}
.burger::after{transform:translateY(6px)}
.burger.open span{opacity:0}
.burger.open::before{transform:rotate(45deg)}
.burger.open::after{transform:rotate(-45deg)}
{display:flex;gap:12px;align-items:center}
.logo{width:36px;height:36px;border-radius:50%;background:#111 url('assets/logo.png') center/cover;border:1px solid rgba(0,0,0,.06)}
.title{font-family:"Playfair Display",serif;font-size:20px line-height:1;  line-height:1;}
.nav-spacer{width:36px;position:absolute;right:16px;top:50%;transform:translateY(-50%)}
nav ul{display:none;position:absolute;top:64px;left:0;right:0;background:var(--bg2);padding:18px;border-bottom:1px solid rgba(0,0,0,.06);z-index:50}
nav ul.open{display:flex;flex-direction:column;gap:14px}
.lang-switch button{background:none;border:0;color:#fff;cursor:pointer}
.btn{display:inline-block;padding:10px 16px;border-radius:999px;border:1px solid rgba(0,0,0,.12);transition:.2s;color:#1b1b1b}
.btn:hover{transform:translateY(-1px);border-color:rgba(0,0,0,.25)}
.btn-primary{background:linear-gradient(180deg,var(--brand),var(--brand2));color:#0c0c0c;border:none}

@media (min-width:901px){
  .burger{display:none}
  .nav{justify-content:space-between}
  nav ul{display:flex;position:static;padding:0;border:0;background:transparent;gap:18px}
}

.hero{position:relative;min-height:78vh;display:grid;place-items:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:url('assets/hero.jpg') center/cover no-repeat;filter:contrast(1.02) brightness(.92) saturate(1.04); transform:scale(1.06); animation:heroZoom 6s ease-out both}
.hero::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(0,0,0,.30),rgba(0,0,0,.18) 35%,rgba(0,0,0,.45))}
@keyframes heroZoom{0%{transform:scale(1.14);opacity:.2}100%{transform:scale(1.06);opacity:1}}
.hero-inner{position:relative;z-index:1;text-align:center;padding:80px 24px;animation:fadeUp .6s .1s both ease-out
  position:relative;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.kicker {
  color: #FAF7F2;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.hero h1 {
  color: #CBB89C;
  font-family: 'Playfair Display', serif;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.2;
  text-shadow: 1px 2px 6px rgba(0,0,0,0.35);
}
.hero p{max-width:760px;margin:0 auto 28px;color:#f0f4f3;text-shadow:0 2px 6px rgba(0,0,0,.55);font-size:clamp(16px,2.2vw,19px)}
.pill{display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:16px 0 30px}
.pill span{border:1px solid rgba(255,255,255,.14);padding:8px 12px;border-radius:999px;color:#eaeaea;background:rgba(0,0,0,.25)}

section{padding:96px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin:34px 0}
h2{font-family:"Playfair Display",serif;font-size:clamp(26px,3.5vw,38px);margin:0;font-weight:400;letter-spacing:.2px}
.muted{color:var(--muted)}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:1000px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid{grid-template-columns:1fr}}
.card{box-shadow:0 14px 32px rgba(0,0,0,0.22); background:#FAF7F2;border-radius:var(--r);overflow:hidden;border:1px solid rgba(0,0,0,.06)}
.card .body{padding:16px 16px 18px}
.tag{display:inline-block;background:rgba(198,162,122,.15);color:var(--accent);
  border:1px solid rgba(198,162,122,.25);padding:6px 10px;border-radius:999px;font-size:12px}
.meta{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:14px;margin-top:8px}

.slider{position:relative;height:260px;background:#111}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .6s;overflow:hidden}
.slide img{width:100%;height:100%;object-fit:cover}
.slide.active{opacity:1}

.hscroll{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:10px}
.hscroll img{height:220px;flex:0 0 auto;border-radius:12px;border:1px solid rgba(0,0,0,.06);scroll-snap-align:center}

.cta{background:#F0EBE4;border:1px solid rgba(0,0,0,.06);padding:28px;border-radius:var(--r);text-align:center}
.cta .btn-group{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.cta .btn-group .btn{padding:8px 14px;font-size:0.95rem}

footer{padding:0;background:var(--white)}
.footer-inner{max-width:var(--max);margin:0 auto;padding:42px 24px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:22px;color:var(--ink)}
@media (max-width:900px){.footer-inner{grid-template-columns:1fr 1fr}}
footer h4{margin:0 0 10px 0;color:var(--ink);font-weight:600;letter-spacing:.2px}
footer .small{color:var(--ink2)}
footer .col{border-left:1px solid var(--line);padding-left:18px}
footer .col:first-child{border:0;padding-left:0}
footer a{color:var(--ink2)}
footer .brandline{border-top:1px solid var(--line);padding:12px 24px;text-align:center;color:#555;background:#FAF7F2}
.socials{display:flex;gap:14px;align-items:center}
.icon{width:28px;height:28px;display:inline-grid;place-items:center;border-radius:8px;border:1px solid #ddd;background:#fff;transition:.2s}
.icon svg{width:18px;height:18px;fill:#222}
.icon:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.icon.ig:hover svg{fill:url(#ig-grad)}
.icon.fb:hover svg{fill:#1877F2}
.icon.mail:hover svg{fill:#22a6b3}

@media (max-width:600px){
  body{font-size:16px;line-height:1.6}
  h1{font-size:1.9rem}
  h2{font-size:1.5rem}
  .hero p, .small{font-size:0.95rem}
  .nav{height:56px}
  nav ul{padding:20px}
  nav ul a{font-size:1.05rem}
  .btn{padding:14px 20px;font-size:1rem}
  .btn-primary{font-weight:600}
  .hero-inner{padding:60px 16px
  position:relative;
}
  .pill{gap:6px}
  .pill span{padding:6px 10px;font-size:0.9rem}
  .grid{grid-template-columns:1fr !important;gap:18px}
  .card .body{padding:18px}
  .meta{font-size:0.9rem}
  footer .footer-inner{grid-template-columns:1fr}
  .hscroll img{height:200px}
}

/* Soft transition into white footer */
.soft-break{height:72px;background:linear-gradient(180deg, rgba(203,184,156,0) 0%, #FAF7F2 100%);}

.cta h2{text-align:center;margin-top:0;margin-bottom:14px}

main{padding-bottom:40px}


/* === Legibility upgrades (hero) === */
.hero-inner::before{
  content:"";
  position:absolute;
  left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(980px, 92%); height:64%;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.35) 0%, rgba(0,0,0,.25) 35%, rgba(0,0,0,0) 75%);
  z-index:-1; /* stays behind text */
  border-radius:24px;
  filter: blur(2px);
}
.kicker {
  color: #FAF7F2;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.hero h1 {
  color: #CBB89C;
  font-family: 'Playfair Display', serif;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.2;
  text-shadow: 1px 2px 6px rgba(0,0,0,0.35);
}
.hero p{  text-shadow: 0 2px 10px rgba(0,0,0,.6), 0 1px 0 rgba(0,0,0,.35); }

.brand { display: flex; align-items: center; gap: 8px; }


@media (max-width:600px){
  .hero h1{
    font-size: 2.3rem;
    line-height: 1.15;
    max-width: 16ch;
    margin-left: auto;
    margin-right: auto;
    text-shadow: 1px 2px 8px rgba(0,0,0,0.45);
    hyphens: auto;
    -webkit-hyphens: auto;
    text-wrap: balance;
    text-align: center;
  }
  .hero p{
    font-size: 1rem;
    max-width: 32ch;
    margin-left: auto;
    margin-right: auto;
    text-shadow: 0 1px 4px rgba(0,0,0,0.5);
    text-align: center;
  }
  .kicker{
    font-size: 0.8rem;
    letter-spacing: 1.5px;
  }
}



/* Spaziatura migliorata per sezioni e titoli */
.section-head {
  margin-top: 80px;
  margin-bottom: 40px;
  text-align: center;
}
.section-head h2 {
  margin-bottom: 16px;
}
section {
  padding-top: 60px;
  padding-bottom: 60px;
}



/* Spaziatura uniforme per la sezione "Dove siamo" */


/* Linea sottile sotto i paragrafi */




@media (max-width:600px){
  .section-head {
    margin-top: 80px;
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    padding-bottom: 20px;
  }
  
}



@media (max-width:600px){
  .section-head {
    margin-top: 80px;
    margin-bottom: 40px;
    text-align: center;
    position: relative;
  }
  
}



@media (max-width:600px){
  .section-head h2 {
    text-align: left;
  }
}



@media (max-width:600px){
  .section-head h2 {
    text-align: left;
  }
}











@media (max-width:600px){
  .section-head p.muted {
    font-size: 0.85rem;
    position: relative;
    top: -6px;
    margin-bottom: 16px;
  }
}



/* Stile per il link di Google Maps nel footer */
a[href*="google.com/maps"] {
  color: #000;
  font-weight: 500;
  text-decoration: none;
}
a[href*="google.com/maps"]:hover {
  text-decoration: underline;
}



/* Stile per tutti i link di Google Maps */
a[href*="google.com/maps"] {
  color: #000;
  font-weight: 500;
  text-decoration: none;
}
a[href*="google.com/maps"]:hover {
  text-decoration: underline;
}



@media (hover:hover){
}

/* Feature cards (cornice nera, ombra, titoli centrati in grassetto) */



@media (hover:hover){
}

/* Feature cards - corniciate su sfondo pagina */
.card.feature-card{
  background: transparent;
  border: 2px solid #000;
  border-radius: 20px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}
.card.feature-card .body{
  text-align: center;
  padding: 24px 20px 24px;
}
.card.feature-card h3{
  text-align: center;
  font-weight: 700;
  margin: 0 0 8px;
}
.card.feature-card p{ margin: 0; }
@media (hover:hover){
  .card.feature-card:hover{
    box-shadow: 0 12px 30px rgba(0,0,0,0.16);
    transform: translateY(-1px);
    transition: box-shadow .2s ease, transform .2s ease;
  }
}

/* Allineamento titolo + indirizzo in "Dove siamo?" centrati */





/* Layout uniforme per "Dove siamo?" su desktop e mobile:
   titolo centrato sopra, indirizzo sotto, centrato */


#dove-siamo .section-head p,
#dove-siamo .section-head a,



/* "Dove siamo?" - Mobile first: flex centrato con wrap */
#dove-siamo .section-head{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:12px;
  flex-wrap:wrap;
}
#dove-siamo .section-head h2{ margin:0; }
#dove-siamo .section-head p,
#dove-siamo .section-head a,
#dove-siamo .section-head span{
  margin:0;
  display:inline-block;
  line-height:1.3;
}

/* Desktop (>= 992px): titolo sopra e indirizzo sotto, entrambi centrati */
@media (min-width: 992px){
  #dove-siamo .section-head{
    display:block;
  }
  #dove-siamo .section-head h2{ margin:0 0 8px; }
}


/* === Interlinea 2: spazio tra titoli e testo === */
h2, h3{
  margin-top: 0;
  margin-bottom: 0.6em; /* ridotto */
}
/* Evita spazio aggiuntivo sopra ai paragrafi che seguono un titolo */
h2 + p, h3 + p{ margin-top: 0; }
/* Se il titolo è usato come intestazione di sezione senza testo immediato sotto, riduci ancora un filo */
.section-head h2, .section-head h3{ margin-bottom: 0.4em; }


  .section-head h2, .section-head h3{
    margin-bottom: 0.3em;
  }
}

/* Margini titoli ancora più stretti su mobile */
@media (max-width: 767px){
  h2, h3{
    margin-bottom: 0.25em;
  }
  .section-head h2, .section-head h3{
    margin-bottom: 0.15em;
  }
}


/* Riduzione margini section-head (spazio tra titolo e contenuto) */
.section-head{ margin: 28px 0; } /* leggermente meno anche su desktop */

@media (max-width: 767px){
  .section-head{ margin: 16px 0; }
  .section-head .muted{ margin-bottom: 8px; top: -4px; }
}


/* Titoli con più spazio sopra e meno sotto */
h2, h3{
  margin-top: 1.2em;
  margin-bottom: 0.4em;
}
.section-head h2, .section-head h3{
  margin-top: 1.4em;
  margin-bottom: 0.3em;
}


/* Aumenta spazio sopra i titoli su mobile */
@media (max-width: 767px){
  h2, h3{
    margin-top: 1.6em;
    margin-bottom: 0.4em;
  }
  .section-head h2, .section-head h3{
    margin-top: 1.8em;
    margin-bottom: 0.3em;
  }
}


/* Maggior distanziamento nella sezione "Dove siamo?" */
#dove-siamo h2{
  margin-top: 1.8em;
}
#dove-siamo .section-head{
  margin-bottom: 1.5em;
}


/* OVERRIDE forte per distanze in "Dove siamo?" */
#dove-siamo .section-head h2{
  margin-top: 2.2rem !important;   /* più spazio dal blocco sopra */
  margin-bottom: 0.6rem !important; /* meno spazio sotto il titolo */
}
#dove-siamo .section-head{
  margin-bottom: 1.5rem !important; /* più aria sotto l'indirizzo */
}


/* Override desktop per distanze "Dove siamo?" */
@media (min-width: 992px){
  #dove-siamo .section-head h2{
    margin-top: 2.6rem !important;
    margin-bottom: 0.6rem !important;
  }
  #dove-siamo .section-head{
    margin-bottom: 2rem !important;
  }
}


/* Override definitivo per distanze in "Dove siamo?" (tutte le viewport) */
#dove-siamo .section-head{
  margin-top: 2.4rem !important;   /* aumenta lo spazio sopra il titolo */
  margin-bottom: 2rem !important;  /* più aria sotto l'indirizzo */
}
#dove-siamo .section-head h2{
  margin-bottom: 0.6rem !important; /* compatta lo spazio sotto il titolo */
}


/* Fix gap tra titolo "Dove siamo?" e indirizzo */
#dove-siamo .section-head{
  margin-top: 2rem !important;     /* aria sopra la sezione (leggermente meno) */
  margin-bottom: 1.6rem !important;/* aria sotto la sezione */
}
#dove-siamo .section-head h2{
  margin-bottom: 0.2rem !important; /* gap molto compatto sotto al titolo */
}
#dove-siamo .section-head .muted{
  margin-top: 0 !important;
  top: 0 !important;               /* elimina lo scostamento verticale */
}
#dove-siamo .section-head h2 + p,
#dove-siamo .section-head h2 + .muted{
  margin-top: 0 !important;        /* sicurezza: nessun margine sopra l'indirizzo */
}


/* Forza layout verticale in "Dove siamo?" per tutte le viewport */
#dove-siamo .section-head{
  display: block !important;
  text-align: center !important;
}
#dove-siamo .section-head h2{
  margin-bottom: 0.4rem !important;
}
#dove-siamo .section-head p,
#dove-siamo .section-head .muted{
  display: block !important;
  margin-top: 0.2rem !important;
}


/* Differenziazione margini titolo "Dove siamo?" per mobile verticale e desktop */

/* Mobile verticale */
@media (max-width: 767px){
  #dove-siamo .section-head h2{
    margin-bottom: 0.8rem !important; /* più aria sotto al titolo */
  }
}

/* Tablet orizzontale e desktop */
@media (min-width: 768px){
  #dove-siamo .section-head h2{
    margin-bottom: 0.4rem !important; /* più compatto */
  }
}


/* Centratura definitiva del titolo e indirizzo in "Dove siamo?" */
#dove-siamo .section-head{
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}
#dove-siamo .section-head h2,
#dove-siamo .section-head p,
#dove-siamo .section-head .muted{
  width: 100%;
  text-align: center !important;
}


/* Avvicina l'indirizzo al titolo in "Dove siamo?" */
#dove-siamo .section-head h2{
  margin-bottom: 0.3rem !important;
}


/* Titolo e indirizzo vicini, aria solo sotto al blocco */
#dove-siamo .section-head h2{
  margin-bottom: 0.1rem !important;
}
#dove-siamo .section-head{
  margin-bottom: 2rem !important;
}


/* Più spazio sotto l'indirizzo in "Dove siamo?" */
#dove-siamo .section-head{
  margin-bottom: 3rem !important;
}

/* Riduci larghezza del blocco prenotazione su desktop e centrala */
@media (min-width: 992px){
  #prenota{
    max-width: 800px;
    margin: 0 auto;
  }
}


/* === Lightbox immagini galleria (custom, senza librerie) === */
#lightbox{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  z-index: 9999;
}
#lightbox.open{ display: flex; }
#lightbox img{
  max-width: 90vw;
  max-height: 90vh;
  border-radius: 12px;
  box-shadow: var(--sh);
  cursor: zoom-out;
}
/* cursore zoom per le miniature */
#galleria .hscroll img{ cursor: zoom-in; }




/* === Header layout mobile/desktop === */
header{
  position: sticky; top: 0; z-index: 1000;
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
}
header .header-inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 10px 16px;
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* mobile: burger | brand | cta */
  align-items: center;
  gap: 10px;
}

/* Brand stacked: logo sopra, nome sotto, centrati */
header .brand{
  display: grid; place-items: center;
  grid-template-rows: auto auto;
  gap: 4px;
}
header .brand .logo{ display:block; }
header .brand .title{ display:block; line-height:1; }

/* CTA a destra su mobile, a sinistra su desktop */
header .header-cta{ justify-self: end; }
header .header-cta .btn{ white-space: nowrap; padding: 8px 14px; border-radius: 999px; font-weight:600; }

/* HAMBURGER raffinato a sinistra */
#burger{
  display:block;
  justify-self: start;
  width: 30px; height: 30px;
  background: transparent; border: 0; padding: 0; margin: 0;
}
#burger span{
  display:block;
  height: 3px; width: 100%;
  margin: 5px 0;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
}

/* Drawer mobile */
@media (max-width: 991px){
  header nav{ display:none; }              /* menu nascosto, si apre come drawer */
  #burger{ display:block; }
  header nav ul#mainmenu{
    position: fixed;
    right: 0; top: 0;
    height: 100vh; width: 80vw; max-width: 320px;
    background: var(--bg2);
    border-left: 1px solid var(--line);
    padding: 80px 20px 20px;
    box-shadow: -20px 0 30px rgba(0,0,0,.12);
    transform: translateX(100%);
    transition: transform .25s ease;
    z-index: 9999;
    display: flex; flex-direction: column; gap: 16px;
  }
  body.nav-open header nav{ display:block; }
  body.nav-open header nav ul#mainmenu{ transform: translateX(0); }

  #nav-overlay{
    position: fixed; inset: 0;
    background: rgba(0,0,0,.35);
    opacity: 0; pointer-events: none;
    transition: opacity .25s ease;
    z-index: 9998;
  }
  body.nav-open #nav-overlay{ opacity: 1; pointer-events: auto; }
  body.nav-open{ overflow: hidden; }

  /* animazione burger -> X */
  body.nav-open #burger span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
  body.nav-open #burger span:nth-child(2){ opacity: 0; }
  body.nav-open #burger span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }
}

/* Desktop: CTA sinistra, brand centro, menu a destra */
@media (min-width: 992px){
  #burger{ display:none; }
  header nav{ display:block; justify-self: end; }
  header nav ul#mainmenu{ display:flex; gap: 24px; align-items:center; }
  header .header-cta{ justify-self: start; }
}


/* === Mobile header refinement: grid areas for perfect placement === */
header .header-inner{
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "burger brand cta";
}
#burger{ grid-area: burger; }
header .brand{ grid-area: brand; }
header .header-cta{ grid-area: cta; }

/* Brand stacked and perfectly centered */
header .brand{
  display: grid;
  grid-auto-rows: min-content;
  justify-items: center;
  align-items: center;
  gap: 2px;
}
header .brand .logo{ line-height: 1; }
header .brand .title{ line-height: 1; text-align: center; white-space: nowrap; }

/* Hamburger: refined look + larger touch target */
#burger{
  width: 30px; height: 30px; /* touch target 36x32 */
  padding: 4px 0;
}
#burger span{
  height: 3.2px;
  border-radius: 3px;
  margin: 4.2px 0;
}
/* a hair longer visual */
#burger span::before{ content:""; }

/* Desktop keeps previous arrangement: CTA | Brand | Nav */
@media (min-width: 992px){
  header .header-inner{
    grid-template-columns: 1fr auto 1fr;
    grid-template-areas: "cta brand nav";
  }
  header .header-cta{ justify-self: start; }
  header nav{ display:block; justify-self: end; }
}


/* Nasconde eventuali vecchi pulsanti hamburger sovrapposti */
header button:not(#burger){ display: none !important; }
/* Centra brand perfettamente nell'header */
header .header-inner{
  grid-template-columns: auto 1fr auto;            /* burger | brand | cta */
  grid-template-areas: "burger brand cta";
}
#burger{ grid-area: burger; justify-self: start; }
header .brand{ grid-area: brand; justify-self: center; }
header .header-cta{ grid-area: cta; justify-self: end; }

/* Hamburger: linee più sottili */
#burger{ width: 30px; height: 30px; padding: 3px 0; }
#burger span{ height: 2.4px; margin: 4px 0; border-radius: 2px; }

/* Bottone Prenota più compatto */
header .header-cta .btn{
  padding: 6px 12px;
  font-size: 0.95rem;
}


/* Refinements v34 */
#burger{ width: 26px; height: 26px; }
#burger span{ height: 2.2px; margin: 4px 0; }

header .brand{
  justify-self: center;
  align-items: center;
  text-align: center;
}

header .header-cta .btn{
  padding: 5px 10px;
  font-size: 0.85rem;
}


/* === Brand perfectly centered in header === */
header .header-inner{
  align-items: center; /* vertical centering for all columns */
}
header .brand{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center; /* vertical centering inside brand area */
  text-align: center;
}


/* === Micro-centering brand on mobile === */
header .brand .title{ margin: 0; line-height: 1; display: block; }
header .brand .logo{ margin: 0 auto 2px auto; display: block; }

@media (max-width: 991px){
  header .brand{ transform: translateY(-2px); } /* nudge up */
}


/* === Fix centratura orizzontale brand === */
header .header-inner{
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* colonne simmetriche */
  grid-template-areas: "burger brand cta";
  align-items: center;
}
#burger{ grid-area: burger; justify-self: start; }
header .brand{ 
  grid-area: brand; 
  justify-self: center; 
  text-align: center; 
}
header .header-cta{ grid-area: cta; justify-self: end; }


/* === Header desktop refinement === */
@media (min-width: 992px){
  header .header-inner{
    display: grid;
    grid-template-columns: 1fr auto 1fr;     /* cta | brand | nav */
    grid-template-areas: "cta brand nav";
    align-items: center;
    min-height: 72px;
    padding: 12px 20px;
  }
  header .header-cta{ grid-area: cta; justify-self: start; }
  header .brand{ grid-area: brand; justify-self: center; text-align: center; }
  header nav{ grid-area: nav; justify-self: end; display: block; }
  #burger{ display: none !important; }
  /* Menu orizzontale "raffinato" */
  header nav ul#mainmenu{
    display: flex;
    gap: 28px;
    align-items: center;
  }
  header nav ul#mainmenu a{
    text-decoration: none;
    padding: 6px 0;
    position: relative;
    font-weight: 500;
  }
  header nav ul#mainmenu a::after{
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 2px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .2s ease;
    background: currentColor;
    opacity: .85;
  }
  header nav ul#mainmenu a:hover::after{
    transform: scaleX(1);
  }
}


/* === Desktop header fixes (v39) === */
@media (min-width: 992px){
  /* Colonne simmetriche: brand davvero centrato */
  header .header-inner{
    grid-template-columns: 1fr auto 1fr;      /* sx | centro | dx */
    grid-template-areas: "cta brand nav";
  }
  header .header-cta{ grid-area: cta; justify-self: start; margin-left: 0; }
  header .brand{ grid-area: brand; justify-self: center; text-align: center; }
  header nav{ grid-area: nav; justify-self: end; display: block; }

  /* CTA più visibile */
  header .header-cta .btn{
    padding: 8px 16px;
    font-size: 1rem;
    border-radius: 999px;
  }

  /* Menu a destra, spacing pulito */
  header nav ul#mainmenu{
    display: flex;
    gap: 28px;
    align-items: center;
    justify-content: flex-end;
  }
  header nav ul#mainmenu a{
    text-decoration: none;
    padding: 8px 0;
    position: relative;
    font-weight: 500;
  }
  header nav ul#mainmenu a::after{
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 2px;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .2s ease;
    background: currentColor;
    opacity: .85;
  }
  header nav ul#mainmenu a:hover::after{
    transform: scaleX(1);
  }

  /* Nascondi eventuale voce menu 'Prenota' (duplicata rispetto al bottone) */
  header nav ul#mainmenu a[href="#prenota"]{ display: none; }
}


/* === Header desktop clean-up (1.zip) === */
@media (min-width: 992px){
  header .header-inner{
    display: grid;
    grid-template-columns: 1fr auto 1fr;   /* CTA | BRAND | NAV */
    grid-template-areas: "cta brand nav";
    align-items: center;
    min-height: 72px;
    padding: 12px 20px;
  }
  header .header-cta{ grid-area: cta; justify-self: start; margin-left: 0; }
  header .brand{ grid-area: brand; justify-self: center; text-align: center; }
  header nav{ grid-area: nav; justify-self: end; display: block; }

  /* Menu pulito a destra */
  header nav ul#mainmenu{ 
    display:flex; gap: 28px; align-items:center; justify-content:flex-end;
    list-style: none; margin: 0; padding: 0;
  }
  header nav ul#mainmenu li{ margin: 0; padding: 0; }
  header nav ul#mainmenu a{
    text-decoration: none; padding: 8px 0; position: relative; font-weight: 500;
  }
  header nav ul#mainmenu a::after{
    content: ""; position: absolute; left: 0; right: 0; bottom: 0;
    height: 2px; transform: scaleX(0); transform-origin: center;
    transition: transform .2s ease; background: currentColor; opacity: .85;
  }
  header nav ul#mainmenu a:hover::after{ transform: scaleX(1); }

  /* Nascondi eventuale voce duplicata Prenota nel menu (se rimane) */
  header nav ul#mainmenu a[href="#prenota"]{ display: none !important; }
}


/* === v2: menu più a destra su desktop === */
@media (min-width: 992px){
  header .header-inner{
    grid-template-columns: 1fr auto 1fr;
    padding-left: 20px;
    padding-right: 12px; /* meno padding a destra per avvicinarlo al bordo */
  }
  header nav{ justify-self: end; text-align: right; }
  header nav ul#mainmenu{ justify-content: flex-end; margin-right: 0; }
}


/* === Header desktop layout (3.zip) === */
@media (min-width: 992px){
  header .header-inner{
    display: grid;
    grid-template-columns: 1fr auto 1fr;    /* sx (CTA) | centro (BRAND) | dx (MENU) */
    grid-template-areas: "cta brand nav";
    align-items: center;
    padding-left: 20px; padding-right: 20px;
    min-height: 72px;
  }
  header .header-cta{ grid-area: cta; justify-self: start; margin-left: 0; }
  header .brand{ grid-area: brand; justify-self: center; text-align: center; }
  header nav{ 
    grid-area: nav; 
    justify-self: stretch;   /* prendi tutta la colonna di destra */
    width: 100%;
    display: block;
  }
  header nav ul#mainmenu{
    list-style: none; margin: 0; padding: 0;
    display: flex; gap: 28px; 
    justify-content: flex-end;  /* spingi le voci fino al bordo destro */
    align-items: center;
    width: 100%;
  }
  header nav ul#mainmenu li{ margin: 0; padding: 0; }
  header nav ul#mainmenu a{
    text-decoration: none; padding: 8px 0; position: relative; font-weight: 500;
  }
  header nav ul#mainmenu a::after{
    content: ""; position: absolute; left: 0; right: 0; bottom: 0;
    height: 2px; transform: scaleX(0); transform-origin: center;
    transition: transform .2s ease; background: currentColor; opacity: .85;
  }
  header nav ul#mainmenu a:hover::after{ transform: scaleX(1); }
}


/* === Desktop layout hard-fix (4.zip) === */
@media (min-width: 992px){
  header .header-inner{
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important; /* CTA | BRAND | NAV */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    padding-left: 20px !important; padding-right: 20px !important;
    min-height: 72px !important;
  }
  header .header-cta{ grid-area: cta !important; justify-self: start !important; margin-left: 0 !important; }
  header .brand{ grid-area: brand !important; justify-self: center !important; text-align: center !important; }
  header nav{ grid-area: nav !important; justify-self: end !important; width: 100% !important; display: block !important; }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important; align-items: center !important; width: 100% !important;
  }
  header nav ul#mainmenu li{ margin: 0 !important; padding: 0 !important; list-style: none !important; }
  #burger{ display: none !important; }
  /* Nascondi eventuale link 'Prenota' nel menu */
  header nav ul#mainmenu a[href="#prenota"]{ display: none !important; }
}


/* === Header desktop full-width hard fix (5.zip) === */
@media (min-width: 992px){
  header .header-inner{
    max-width: none !important;
    width: 100vw !important;       /* occupa tutta la viewport */
    margin: 0 !important;
    padding-left: 24px !important; 
    padding-right: 24px !important;
    box-sizing: border-box !important;

    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;  /* simmetrico */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    min-height: 72px !important;
  }
  header .header-cta{ grid-area: cta !important; justify-self: start !important; }
  header .brand{ grid-area: brand !important; justify-self: center !important; text-align: center !important; }
  header nav{ grid-area: nav !important; justify-self: stretch !important; width: 100% !important; display: block !important; }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 32px !important;
    justify-content: flex-end !important; align-items: center !important; width: 100% !important;
  }
  header nav ul#mainmenu li{ list-style: none !important; margin: 0 !important; padding: 0 !important; }
  header nav ul#mainmenu a[href*="prenota"]{ display: none !important; }
}


/* === Desktop: brand centrato assoluto (6.zip) === */
@media (min-width: 992px){
  header .header-inner{ position: relative !important; }
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    margin: 0 !important;
  }
  /* Manteniamo CTA e menu nelle rispettive colonne */
  header .header-cta{ position: static !important; }
  header nav{ position: static !important; }
}


/* === Desktop: menu solo a destra, brand centrato (7.zip) === */
@media (min-width: 992px){
  header .header-inner{
    display: grid !important;
    grid-template-columns: 1fr 0 1fr !important; /* sx | (brand assoluto) | dx */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    position: relative !important;
  }
  header .brand{
    position: absolute !important;
    left: 50% !important; top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    z-index: 2 !important;
    pointer-events: auto;
  }
  header .header-cta{ grid-area: cta !important; justify-self: start !important; z-index: 1; }
  header nav{
    grid-area: nav !important;
    justify-self: stretch !important;
    width: 100% !important;
    z-index: 1;
  }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important;  /* tutto a destra */
    align-items: center !important;
    width: 100% !important;
  }
}


/* === Desktop: nav confinato nella metà destra (8.zip) === */
@media (min-width: 992px){
  header .header-inner{
    grid-template-columns: minmax(0,1fr) 0 minmax(0,1fr) !important;
    position: relative !important;
  }
  header nav{
    grid-area: nav !important;
    grid-column: 3 / 4 !important;      /* assicura colonna destra */
    justify-self: end !important;
    width: calc(50vw - 24px) !important; /* nav non supera la metà */
    max-width: calc(50vw - 24px) !important;
    margin-left: auto !important;
    padding-left: 16px !important;       /* piccolo distacco dal centro */
    z-index: 1 !important;
    display: block !important;
  }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important; align-items: center !important;
    width: 100% !important;
  }
}


/* === Desktop: respiro menu dal margine destro (1.zip rigenerato) === */
@media (min-width: 992px){
  :root{ --edge-gutter: 32px; }
  header nav{
    padding-right: var(--edge-gutter) !important;  /* aria dal bordo destro */
    padding-left: 0 !important;                    /* niente aria dal centro */
    box-sizing: border-box !important;
  }
  header nav ul#mainmenu{
    justify-content: flex-end !important;
  }
}


/* === Desktop: brand centrato con grid, nessuna sovrapposizione (clean) === */
@media (min-width: 992px){
  :root{ --edge-gutter: 32px; }

  header .header-inner{
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;  /* sinistra | centro | destra */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    padding-left: var(--edge-gutter) !important;
    padding-right: var(--edge-gutter) !important;
    min-height: 72px !important;
  }

  /* BRAND: torna statico e sta nell'area centrale */
  header .brand{
    grid-area: brand !important;
    position: static !important;
    left: auto !important; top: auto !important;
    transform: none !important;
    z-index: 2 !important;
    text-align: center !important;
    pointer-events: auto !important;
    justify-self: center !important;
  }

  /* CTA a sinistra */
  header .header-cta{
    grid-area: cta !important;
    justify-self: start !important;
  }

  /* NAV a destra, solo larghezza contenuto, con respiro dal margine destro */
  header nav{
    grid-area: nav !important;
    justify-self: end !important;
    width: auto !important;
    max-width: none !important;
    padding-right: 0 !important;
  }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important; align-items: center !important;
  }
}


/* === Desktop header anti-overlap fix (2025-08-29) === */
@media (min-width: 992px){
  header .header-inner{
    display: grid !important;
    grid-template-columns: auto 1fr auto !important; /* CTA | BRAND | NAV */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    position: relative !important;
    column-gap: 20px !important;
    min-height: 72px !important;
  }
  header .header-cta{ grid-area: cta !important; justify-self: start !important; }
  header .brand{
    grid-area: brand !important;
    position: static !important;
    left: auto !important; top: auto !important;
    transform: none !important;
    text-align: center !important;
    z-index: 1 !important;
  }
  header .brand .logo{
    max-height: 44px !important;
    width: auto !important;
  }
  header nav{
    grid-area: nav !important;
    position: static !important;
    justify-self: end !important;
    display: block !important;
    z-index: 1 !important;
  }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important; align-items: center !important;
  }
  header nav ul#mainmenu > li{ margin: 0 !important; padding: 0 !important; }
  .nav-spacer{ display: none !important; }
}


/* === Desktop header layout (centrato) – 2025-08-29 === */
@media (min-width: 992px){
  header .header-inner{
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important; /* sinistra (CTA) | BRAND | destra (NAV) */
    grid-template-areas: "cta brand nav" !important;
    align-items: center !important;
    position: relative !important;
    column-gap: 24px !important;
    min-height: 76px !important;
  }
  /* CTA: posizione invariata */
  header .header-cta{ 
    grid-area: cta !important; 
    justify-self: start !important; 
  }
  /* BRAND centrato orizzontalmente */
  header .brand{
    grid-area: brand !important;
    position: static !important;
    left: auto !important; top: auto !important;
    transform: none !important;
    text-align: center !important;
    justify-self: center !important;
    z-index: 1 !important;
  }
  header .brand .logo{
    max-height: 44px !important;
    width: auto !important;
  }
  /* MENU a destra, termina a filo */
  header nav{
    grid-area: nav !important;
    position: static !important;
    justify-self: end !important;
    display: block !important;
    z-index: 1 !important;
  }
  header nav ul#mainmenu{
    list-style: none !important; margin: 0 !important; padding: 0 !important;
    display: flex !important; gap: 28px !important;
    justify-content: flex-end !important; align-items: center !important;
  }
  header nav ul#mainmenu > li{ margin: 0 !important; padding: 0 !important; }
  .nav-spacer{ display: none !important; }
}


/* === Header desktop fix v2 (centratura robusta + menu a destra) — 2025-08-29 === */
@media (min-width: 992px){
  /* 1) Layout interno del contenitore nav: [spacer | brand | nav] */
  header .container.nav{
    display: grid !important;
    grid-template-columns: minmax(120px, 1fr) auto 1fr !important;
    grid-template-areas: "spacer brand nav" !important;
    align-items: center !important;
    column-gap: 24px !important;
    width: 100% !important;
  }
  header .container.nav .nav-spacer{ grid-area: spacer !important; display: block !important; }
  header .container.nav .brand{ grid-area: brand !important; text-align: center !important; }
  header .container.nav nav{ grid-area: nav !important; justify-self: end !important; }
  header .container.nav nav ul#mainmenu{
    display: flex !important; gap: 28px !important; margin: 0 !important; padding: 0 !important;
    list-style: none !important; align-items: center !important; justify-content: flex-end !important;
  }

  /* 2) L'header principale resta un contenitore; CTA rimane dov'è */
  header .header-inner{
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    min-height: 76px !important;
  }
  /* Manteniamo la CTA sul lato sinistro della testata, posizione invariata */
  
  /* 3) Ripristina dimensioni del logo (evita la 'linea') */
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: inline-block !important;
  }
}


/* === Header desktop fix v3 — CTA a sinistra, brand centrato, menu a destra === */
@media (min-width: 992px){
  /* Header container come flex per controllare l'ordine */
  header .header-inner{
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    min-height: 76px !important;
  }
  /* CTA resta nella posizione originale: LATO SINISTRO su desktop */
  header .header-cta{
    order: -1 !important;
    margin-right: auto !important; /* spinge il blocco nav a destra */
  }
  /* Il blocco nav occupa lo spazio rimanente */
  header .container.nav{
    flex: 1 1 auto !important;
    display: grid !important;
    grid-template-columns: minmax(120px, 1fr) auto 1fr !important; /* spacer | brand | nav */
    grid-template-areas: "spacer brand nav" !important;
    align-items: center !important;
    column-gap: 24px !important;
  }
  header .container.nav .nav-spacer{ grid-area: spacer !important; display: block !important; }
  header .container.nav .brand{ grid-area: brand !important; text-align: center !important; }
  header .container.nav nav{ grid-area: nav !important; justify-self: end !important; }
  header .container.nav nav ul#mainmenu{
    display: flex !important; gap: 28px !important; margin: 0 !important; padding: 0 !important;
    list-style: none !important; align-items: center !important; justify-content: flex-end !important;
  }
  /* Logo dimensioni fisse per evitare che diventi una "linea" */
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: inline-block !important;
  }
}


/* === Header desktop fix v4 — brand centrato assoluto === */
@media (min-width: 992px){
  header .header-inner{
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 76px !important;
    padding: 0 24px !important;
  }
  /* CTA resta a sinistra */
  header .header-cta{ order: -1 !important; }
  /* Brand assoluto al centro */
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
    text-align: center !important;
    z-index: 2 !important;
  }
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: inline-block !important;
  }
  /* Menu a destra */
  header .container.nav{
    flex: 1 1 auto !important;
    display: flex !important;
    justify-content: flex-end !important;
  }
  header .container.nav nav ul#mainmenu{
    display: flex !important;
    gap: 28px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: center !important;
    justify-content: flex-end !important;
  }
}


/* === Header desktop fix v4 — Brand centrato assoluto === */
@media (min-width: 992px){
  /* Contenitore dell'header come contesto per posizionamento assoluto */
  header .header-inner{
    position: relative !important;
    min-height: 80px !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
  }
  /* CTA a sinistra (posizione invariata) */
  header .header-cta{
    order: -1 !important;
    margin-right: auto !important;
  }
  /* Brand centrato rispetto all'intero header */
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    z-index: 2 !important;
    white-space: nowrap !important;
  }
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: block !important;
    margin: 0 auto 4px auto !important;
  }
  /* Nav a destra, a filo */
  header .container.nav{
    flex: 0 1 auto !important;
  }
  header .container.nav .nav-spacer{ display: none !important; }
  header .container.nav{
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    width: 100% !important;
  }
  header .container.nav nav{
    margin-left: auto !important;
  }
  header nav ul#mainmenu{
    list-style: none !important;
    display: flex !important;
    gap: 28px !important;
    margin: 0 !important; padding: 0 !important;
    align-items: center !important;
    justify-content: flex-end !important;
  }
}


/* === Header desktop fix v5 — Brand centrato orizzontalmente === */
@media (min-width: 992px){
  header .header-inner{
    position: relative !important;
    min-height: 80px !important;
  }
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    z-index: 5 !important;
  }
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: block !important;
    margin: 0 auto 4px auto !important;
  }
}


/* === Header desktop fix v5 — Centro orizzontale assoluto del brand === */
@media (min-width: 992px){
  header{
    width: 100% !important;
  }
  header .header-inner{
    position: relative !important;
    width: 100% !important;
    margin: 0 auto !important;
    min-height: 80px !important;
  }
  /* Centro esatto: 50% della larghezza dell'header */
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 2 !important;
    text-align: center !important;
    white-space: nowrap !important;
  }
  /* Dimensioni stabili del logo */
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: block !important;
    margin: 0 auto 4px auto !important;
  }
}


/* === Header desktop fix v6 — Brand centrato orizzontalmente rispetto all'intero header === */
@media (min-width: 992px){
  /* 1) Il contenitore principale dell'header diventa il riferimento per il posizionamento assoluto */
  header .header-inner{
    position: relative !important;
    width: 100% !important;
    min-height: 80px !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
  }

  /* 2) Qualsiasi ancestor del brand NON deve essere 'positioned', così .brand guarda a .header-inner */
  header .container.nav,
  header .container.nav *{
    position: static !important;
  }

  /* 3) Logo+Nome esattamente centrati in orizzontale nel bar dell'header */
  header .brand{
    position: absolute !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    /* opzionale: centratura verticale "gentile" */
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    white-space: nowrap !important;
    z-index: 5 !important;
  }

  /* 4) CTA a sinistra e menu a destra restano nel loro flusso */
  header .header-cta{ order: -1 !important; margin-right: auto !important; }
  header .container.nav{ flex: 1 1 auto !important; display: flex !important; justify-content: flex-end !important; align-items: center !important; }
  header nav ul#mainmenu{
    display: flex !important; gap: 28px !important; margin: 0 !important; padding: 0 !important;
    list-style: none !important; justify-content: flex-end !important; align-items: center !important;
  }

  /* 5) Dimensioni stabili del logo per evitare 'linea' */
  header .brand .logo{
    width: 36px !important;
    height: 36px !important;
    display: block !important;
    margin: 0 auto 4px auto !important;
  }

  /* 6) Nascondo spacer che non serve più su desktop */
  header .nav-spacer{ display: none !important; }
}


/* === Header desktop fix v7 — Centro rispetto all'intera barra (rimuovi max-width) === */
@media (min-width: 992px){
  /* L'header-inner occupa tutta la larghezza della barra */
  header .header-inner{
    max-width: none !important;   /* <-- elimina il vincolo che ti spostava il centro */
    width: 100% !important;
    margin: 0 !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    min-height: 80px !important;
    box-sizing: border-box !important;
  }
  /* Brand centrato orizzontalmente nella barra */
  header .brand{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    text-align: center !important;
    white-space: nowrap !important;
    z-index: 5 !important;
  }
  /* CTA e menu restano ai lati */
  header .header-cta{ order: -1 !important; margin-right: auto !important; }
  header .container.nav{ flex: 1 1 auto !important; display: flex !important; justify-content: flex-end !important; }
  header .container.nav .nav-spacer{ display: none !important; }
  header nav ul#mainmenu{ display: flex !important; gap: 28px !important; margin: 0 !important; padding: 0 !important; list-style: none !important; }
}


/* === CTA labels responsive + brand compact (solo desktop) — v8 === */
/* Mobile: mostra "Prenota", nascondi "Prenota ora" */
@media (max-width: 991.98px){
  #cta-prenota .label-desktop{ display: none !important; }
  #cta-prenota .label-mobile{ display: inline !important; }
}

/* Desktop: mostra "Prenota ora", nascondi "Prenota" e compatta brand */
@media (min-width: 992px){
  #cta-prenota .label-desktop{ display: inline !important; }
  #cta-prenota .label-mobile{ display: none !important; }

  /* Compattazione logo+nome nell'header */
  header .brand{ gap: 4px !important; }
  header .brand .logo{
    width: 28px !important;
    height: 28px !important;
  }
  header .brand .title{
    font-size: 18px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
  }
}


/* === Header desktop fix v8 — Brand centrato matematico rispetto a .header-inner === */
@media (min-width: 992px){
  header .header-inner{
    /* Manteniamo il max-width originale (contenuto centrato) */
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;  /* sinistra | BRAND | destra  */
    grid-template-areas: "left brand right" !important;
    align-items: center !important;
    position: relative !important;
    gap: 16px !important;
  }
  header .header-cta{ grid-area: left !important; justify-self: start !important; margin: 0 !important; }
  header .brand{
    grid-area: brand !important;
    position: static !important;      /* niente assoluto */
    left: auto !important; top: auto !important; transform: none !important;
    justify-self: center !important;  /* centro matematico del contenitore */
    text-align: center !important;
    white-space: nowrap !important;
  }
  header .container.nav{
    grid-area: right !important;
    justify-self: end !important;
    display: block !important;
  }
  header .container.nav .nav-spacer{ display: none !important; }
  header nav ul#mainmenu{
    display: flex !important; gap: 28px !important; margin: 0 !important; padding: 0 !important;
    list-style: none !important; align-items: center !important; justify-content: flex-end !important;
  }
}


/* =====================
   CLEAN HEADER (from scratch) — desktop & mobile
   ===================== */
.site-header{ position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.7); backdrop-filter: blur(10px); border-bottom: 1px solid rgba(0,0,0,.06); }
.site-header__inner{ max-width: var(--max, 1200px); margin: 0 auto; padding: 10px 16px; box-sizing: border-box; }

/* Base elements */
.site-header__brand{ text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.site-header__brand .brand__logo{ width: 32px; height: 32px; border-radius: 50%; background: #111 url('assets/logo.png') center/cover no-repeat; display: inline-block; }
.site-header__brand .brand__title{ font-weight: 700; line-height: 1; white-space: nowrap; }
.site-header__nav ul{ margin: 0; padding: 0; list-style: none; display: flex; gap: 24px; align-items: center; }
.site-header__nav a{ text-decoration: none; position: relative; }
#cta-prenota{ white-space: nowrap; border-radius: 999px; padding: 8px 14px; font-weight: 600; display: inline-block; }

/* Mobile first: SOLO CTA visibile */
@media (max-width: 991.98px){
  .site-header__inner{ display: flex; align-items: center; justify-content: flex-start; }
  .site-header__brand, .site-header__nav{ display: none !important; } /* nascondi tutto tranne il bottone */
  #cta-prenota .label-mobile{ display: inline; }
  #cta-prenota .label-desktop{ display: none; }
}

/* Desktop: CTA sinistra, BRAND centrato, MENU destra */
@media (min-width: 992px){
  .site-header__inner{
    display: grid;
    grid-template-columns: 1fr auto 1fr;         /* sinistra | centro | destra */
    grid-template-areas: "cta brand nav";
    align-items: center;
    min-height: 76px;
  }
  .site-header__cta{ grid-area: cta; justify-self: start; }
  .site-header__brand{ grid-area: brand; justify-self: center; }
  .site-header__nav{ grid-area: nav; justify-self: end; }

  /* Etichette CTA */
  #cta-prenota .label-mobile{ display: none; }
  #cta-prenota .label-desktop{ display: inline; }

  /* Compattazione elegante del brand su desktop */
  .site-header__brand .brand__logo{ width: 28px; height: 28px; }
  .site-header__brand .brand__title{ font-size: 18px; }
}


/* === Modifiche header v16 — brand verticale, menu più a destra, header semi-trasparente === */

/* Header semi-trasparente su tutte le viewport */
.site-header{
  background: rgba(255,255,255,.5) !important;
  backdrop-filter: blur(10px) !important;
}

/* Desktop: brand con titolo sotto al logo e menu spostato verso destra */
@media (min-width: 992px){
  .site-header__brand{
    display: flex !important;
    flex-direction: column !important;  /* logo sopra, titolo sotto */
    align-items: center !important;
    gap: 4px !important;
    text-align: center !important;
  }
  .site-header__brand .brand__title{
    font-size: 16px !important;
    line-height: 1.1 !important;
  }
  /* Spingi leggermente il menu verso destra */
  .site-header__nav{
    padding-right: 32px !important;     /* Regola se vuoi più/meno spazio */
  }
}


/* === Modifiche header v16 === */
@media (min-width: 992px){
  /* Brand in colonna: logo sopra, testo sotto */
  .site-header__brand{
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 4px !important;
  }
  .site-header__brand .brand__title{
    font-size: 16px !important;
  }

  /* Sposta il menu un po' a destra */
  .site-header__nav{
    padding-right: 32px !important; /* regolabile */
  }
}

/* Header semi-trasparente */
.site-header{
  background: rgba(255,255,255,.5) !important;
  backdrop-filter: blur(10px) !important;
}


/* === Header tweaks v17 — font brand, CTA snella, menu uppercase piccolo, logo più grande === */

/* Brand: font più raffinato e nero */
.site-header__brand .brand__title{
  font-family: "Playfair Display", serif !important; /* elegante */
  color: #000 !important;
}

/* Desktop refinements */
@media (min-width: 992px){
  /* Logo un po' più grande */
  .site-header__brand .brand__logo{
    width: 34px !important;
    height: 34px !important;
  }

  /* CTA "Prenota ora": snellita (meno padding, peso testo leggero) */
  #cta-prenota{
    padding: 6px 12px !important;
    font-weight: 500 !important;
  }

  /* Menu: leggermente più a sinistra e tutto maiuscolo ma piccolo */
  .site-header__nav{
    padding-right: 8px !important; /* prima 32px */
  }
  .site-header__nav #mainmenu a{
    text-transform: uppercase !important;
    font-size: 12.5px !important;
    letter-spacing: 0.06em !important;
  }
}



/* === Mobile header fix: centered brand + hamburger left + CTA right === */
.site-header__hamburger{ display:none; background:none; border:0; font-size:28px; line-height:1; padding:6px 8px; cursor:pointer; }
@media (max-width: 767px){
  .site-header__inner{ display:flex; align-items:center; justify-content:space-between; position:relative; }
  .site-header__hamburger{ display:block; }
  .site-header__brand{ position:absolute; left:50%; transform:translateX(-50%); display:flex; align-items:center; gap:8px; text-decoration:none; }
  .site-header__nav{ display:none; } /* hidden by default on mobile */
  /* align CTA to the right naturally */
  #cta-prenota{ margin-left:auto; }
  /* When nav is open */
  body.nav-open .site-header__nav{ display:block; position:absolute; top:100%; left:0; right:0; background:rgba(248,244,238,0.98); backdrop-filter:saturate(140%) blur(6px); border-bottom:1px solid rgba(0,0,0,.06); }
  body.nav-open .site-header__nav ul{ list-style:none; margin:0; padding:12px 16px; display:flex; flex-direction:column; gap:10px; }
  body.nav-open .site-header__nav a{ display:block; padding:10px 4px; text-decoration:none; }
}



/* === OVERRIDE: mobile header layout (≤991.98px) === */
@media (max-width: 991.98px){
  .site-header__inner{ display:flex !important; align-items:center !important; justify-content:space-between !important; position:relative !important; }
  /* Show brand centered */
  .site-header__brand{ display:flex !important; position:absolute !important; left:50% !important; transform:translateX(-50%) !important; align-items:center !important; gap:8px !important; }
  /* Hide desktop nav by default */
  .site-header__nav{ display:none !important; }
  /* CTA stays on the right */
  .site-header__cta{ margin-left:auto !important; }
  /* Hamburger on the left */
  .site-header__hamburger{ display:block !important; background:none; border:0; font-size:28px; line-height:1; padding:6px 8px; cursor:pointer; }
  /* When nav open */
  body.nav-open .site-header__nav{ display:block !important; position:absolute !important; top:100% !important; left:0 !important; right:0 !important; background:rgba(248,244,238,0.98) !important; border-bottom:1px solid rgba(0,0,0,.06) !important; }
  body.nav-open .site-header__nav ul{ margin:0 !important; padding:12px 16px !important; list-style:none !important; display:flex !important; flex-direction:column !important; gap:10px !important; }
  body.nav-open .site-header__nav a{ display:block !important; padding:10px 4px !important; }
}



/* === HEADER FINAL FIX === */
@media (max-width: 991.98px){
  /* Brand vertical: logo above, text below */
  .site-header__brand{ flex-direction:column !important; gap:4px !important; text-align:center !important; }
  .site-header__brand .brand__logo{ width:34px !important; height:34px !important; display:block !important; margin:0 auto; }
  .site-header__brand .brand__title{ font-size:15px !important; line-height:1.1 !important; }
  /* CTA slimmer */
  #cta-prenota{ padding:6px 12px !important; font-weight:500 !important; font-size:14px !important; }
}



/* === TWEAK 2: hamburger visible left, stacked brand, slimmer CTA (mobile) === */
@media (max-width: 991.98px){
  /* Hamburger always visible on mobile, aligned left */
  .site-header__hamburger{ 
    display:block !important; 
    background:none; border:0; font-size:28px; line-height:1; padding:6px 10px; cursor:pointer; 
    margin-right:8px; 
    z-index: 2;
  }

  /* Brand in colonna (logo sopra, nome sotto) e centrato in header */
  .site-header__brand{
    display:flex !important; flex-direction: column !important; align-items:center !important; gap:4px !important;
    position:absolute !important; left:50% !important; transform:translateX(-50%) !important; text-align:center !important;
  }
  .site-header__brand .brand__title{ 
    font-size:16px !important; line-height:1.1 !important; 
  }

  /* CTA più snella a destra */
  #cta-prenota{ 
    padding:6px 12px !important; 
    font-weight:500 !important; 
  }
}



/* === TWEAK 3: fix hamburger menu display, adjust brand style === */
@media (max-width: 991.98px){
  /* Logo leggermente più piccolo */
  .site-header__brand .brand__logo{
    width:28px !important;
    height:28px !important;
  }
  /* Nome azienda senza grassetto */
  .site-header__brand .brand__title{
    font-weight:400 !important;
  }
}

/* Forza visibilità hamburger menu toggling */
body.nav-open .site-header__nav{ display:block !important; }
body.nav-open .site-header__nav ul{ display:flex !important; flex-direction:column !important; gap:12px !important; padding:12px 16px !important; margin:0 !important; }
body.nav-open .site-header__nav a{ padding:8px 0 !important; }



/* === TWEAK 3: visibility & sizing fixes (mobile) === */
@media (max-width: 991.98px){
  /* Layering: make sure hamburger is on top and brand doesn't cover it */
  .site-header__brand{ z-index: 1 !important; }
  .site-header__hamburger{ z-index: 3 !important; color: #000 !important; }

  /* Brand typography: remove bold from the title */
  .site-header__brand .brand__title{ font-weight: 400 !important; }

  /* Logo smaller so it fits the header nicely */
  .site-header__brand .brand__logo{ width: 26px !important; height: 26px !important; }

  /* Header height to avoid clipping */
  .site-header__inner{ min-height: 64px !important; }
}

/* Ensure the nav becomes visible when toggled */
body.nav-open .site-header__nav{ display:block !important; }



/* === FINAL NAV VISIBILITY FIX === */
@media (max-width: 991.98px){
  body.nav-open .site-header__nav{
    display:block !important;
    position:absolute !important;
    top:100% !important;
    left:0 !important;
    right:0 !important;
    background:#f5f1eb !important;
    z-index: 100 !important;
  }
  body.nav-open .site-header__nav ul{
    display:flex !important;
    flex-direction:column !important;
    padding:14px 18px !important;
    margin:0 !important;
    gap:12px !important;
  }
  body.nav-open .site-header__nav a{
    display:block !important;
    padding:10px 6px !important;
    color:#000 !important;
  }
}



/* === TWEAK 4: force hamburger visible at far-left on mobile === */
@media (max-width: 991.98px){
  .site-header__inner{ position: relative !important; }
  #hamburger.site-header__hamburger{
    position: absolute !important;
    left: 8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    display: block !important;
  }
}



/* === Remove bold from brand title === */
.site-header__brand .brand__title{ font-weight:400 !important; }

/* === Desktop CTA: uppercase, bold, current size kept (14px) === */
@media (min-width: 992px){
  #cta-prenota .label-desktop{
    text-transform: uppercase !important;
    font-weight: 700 !important;
    font-size: 14px !important;
  }
}

/* === Mobile CTA: uppercase + bold, smaller font === */
@media (max-width: 991.98px){
  #cta-prenota .label-mobile{
    text-transform: uppercase !important;
    font-weight: 700 !important;
    font-size: 13px !important;
  }
}
