/* Favorita clone — stile statico responsive */
:root{
  --bg: #f5f2ee;
  --paper: #fbfaf7;
  --text: #1b1b1b;
  --muted: #7b7b7b;
  --black: #0f0f10;
  --overlay: rgba(0,0,0,.42);
  --overlay-2: rgba(0,0,0,.55);
  --wine: #7a4b58;
  --wine-2: #6a3d49;
  --white: #ffffff;
  --shadow: 0 18px 45px rgba(0,0,0,.12);
  --radius: 0px;
  --container: 1120px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: #ffffff;
  line-height: 1.6;
}

img{ max-width:100%; display:block; }

.container{
  width:min(var(--container), calc(100% - 48px));
  margin-inline:auto;
}

.narrow{ width:min(760px, calc(100% - 48px)); }

a{ color:inherit; text-decoration:none; }
a:hover{ opacity:.9; }

.topbar{
  background: rgb(0 0 0 / 11%);
  color: rgba(255,255,255,.75);
  position:absolute;
  top:0; left:0; right:0;
  z-index: 10;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.topbar__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 10px 0;
  gap: 16px;
}
.topbar__left, .topbar__right{ display:flex; align-items:center; gap: 12px; flex-wrap:wrap;color: #ffffff; }
.topbar__dot{ opacity:.45; }
.topbar__label{ margin-right: 4px; }
.topbar__icon{
  width: 20px; height: 20px;
  display:grid; place-items:center;
}

.hero{
  min-height: 78vh;
  background-image: var(--hero-image);
  background-size: cover;
  background-position: center;
  position:relative;
  padding-top: 44px; /* topbar space */
}
.hero__overlay{
  position:absolute; inset:0;
  background: transparent;
}
.hero__nav{
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 22px 0 0;
  z-index: 2;
}
.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(255,255,255,.75);
}
.brand__mark{
  width: 28px;
  height: 22px;
  border: 2px solid rgba(255,255,255,.75);
  display:grid;
  place-items:center;
  font-size: 10px;
  line-height:1;
}
.brand__name{
  font-family: Playfair Display, Georgia, serif;
  font-weight: 300;
  font-size: 28px;
  letter-spacing: .02em;
}
.hero__actions{
  display:flex;
  align-items:center;
  gap: 18px;
  color: rgba(255,255,255,.75);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 12px;
}
.hero__book {
    color: #ffffff;
}
.burger{
  width: 42px; height: 42px;
  border:0;
  background: transparent;
  cursor:pointer;
  display:grid;
  align-content:center;
  gap: 6px;
}
.burger span{
  height: 2px;
  width: 22px;
  background: #ffffff;
  display:block;
}

.hero__content{
  position:relative;
  z-index:2;
  padding: 120px 0 290px;
  text-align:center;
  color: rgba(255,255,255,.72);
}
.hero__content h1{
  margin:0 0 10px;
  font-family: Playfair Display, Georgia, serif;
  font-weight: 300;
  font-size: clamp(42px, 5vw, 80px);
  letter-spacing: .08em;
}
.hero__gift{
 display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    background: #ffffff;
    padding: 12px;
    color: #000000;
    font-weight: 600;
}
.hero__gifticon{ filter: grayscale(1); opacity:.9; }
.hero__skew{
  position:absolute;
  left:0; right:0; bottom:-1px;
  height: 90px;
  background: var(--bg);
  transform: skewY(-3deg);
  transform-origin: bottom left;
  z-index: 3;
}

.section{ padding: 80px 0; }
.section--intro{
  padding-top: 56px;
  text-align:center;
  background: #ffffff;
      padding-bottom: 10px;
}
.eyebrow{
  margin: 0 0 18px;
    font-size: 28px;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: #020202;
}
.lead {
    margin: 0 auto;
    font-weight: 300;
    color: #000000;
    font-size: 16px;
    line-height: 1.6;
    max-width: 800px;
}

.location{
  display:grid;
  grid-template-columns: 1.5fr .8fr;
  gap: 32px;
  align-items:start;
  position:relative;
}
.location__grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.location__grid img{
  
  object-fit: cover;
  box-shadow: var(--shadow);
}
.card{
  background: var(--paper);
  box-shadow: var(--shadow);
  padding: 34px 34px;
}
.card--paper{ background: #ffffff; }
.location__card{
  margin-top: 26px;
  align-self:center;
  justify-self: end;
  width: min(420px, 100%);
}
.card__title{
  margin: 6px 0 16px;
    font-family: Playfair Display, Georgia, serif;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #000000;
    font-size: 37px;
    text-align: center;
}
.muted{ color: rgba(0,0,0,.45); }

.banner{
  position:relative;
  min-height: 260px;
  background-image: var(--banner-image);
  background-size: cover;
  background-position: center;
  display:grid;
  place-items:center;
  text-align:center;
}
.banner__overlay{
  position:absolute; inset:0;
  background: var(--overlay);
}
.banner__overlay--soft{ background: rgba(0,0,0,.35); }
.banner__content{
  position:relative;
  z-index: 1;
  padding: 70px 0;
  color: rgba(255,255,255,.78);
}
.banner__content h2{
  margin: 0 0 18px;
  font-family: Playfair Display, Georgia, serif;
  font-weight: 300;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: clamp(26px, 3.1vw, 46px);
}

.kicker{
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(0,0,0,.45);
}
.kicker--light{ color: rgba(255,255,255,.7); }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 11px 18px;
  border: 1px solid rgba(255,255,255,.7);
  color: rgba(255,255,255,.9);
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  background: transparent;
  cursor:pointer;
}
.btn--ghost:hover{ background: rgba(255,255,255,.08); }
.btn--wine{
  border-color: transparent;
  background: var(--wine);
  color: rgba(255,255,255,.95);
  padding: 11px 18px;
}
.btn--wine:hover{ background: var(--wine-2); }

.feature{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 0;
  align-items:center;
}
.feature__media{
  box-shadow: var(--shadow);
  background:#ddd;
}
.feature__media img{ height: 580px; width:100%; object-fit: cover; }
.feature__card{
  max-width: 520px;
  justify-self:end;
  margin-left: -36px;
}
.feature__card .kicker{ margin-bottom: 8px; }

.banner--dark{
  background: linear-gradient(to right, #050505, #141416);
  min-height: 220px;
}
.banner--dark .banner__overlay{ display:none; }
.banner--dark .banner__content{ padding: 78px 0; }

.card--center{
  max-width: 620px;
  margin: 0 auto;
  text-align:center;
}

.footer{
  background: #332b28;
  color: rgba(255,255,255,.7);
  padding: 70px 0 22px;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 42px;
  align-items:start;
}
.brand--footer{ color: rgba(255,255,255,.8); margin-bottom: 18px; }
.footer__title{
  font-size: 15px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: 10px;
  width: 100%;
}
.footer__text{ font-size: 13px; line-height: 1.7; color:#bab0b0; }
.footer__block{ margin-bottom: 18px; }
.footer__link{ display:inline-block; margin-top: 2px; }
.footer__badges{ display:flex; gap: 12px; flex-wrap:wrap; margin-top: 18px; }
.badge{
  border: 1px solid rgba(255,255,255,.25);
  padding: 10px 12px;
  font-size: 12px;
  letter-spacing:.08em;
  opacity:.85;
}
.newsletter{
  display:grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-top: 14px;
}
.newsletter input{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  padding: 11px 12px;
  color: rgba(255,255,255,.85);
  outline:none;
}
.newsletter input::placeholder{ color: rgba(255,255,255,.45); }
.footer__social{
  display:flex;
  gap: 10px;
  margin-top: 14px;
}
.footer__social a{
  width: 28px; height: 28px;
  display:grid; place-items:center;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 99px;
  font-size: 12px;
}
.footer__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 16px;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: 38px;
  padding-top: 25px;
    padding-bottom: 14px;
}
.footer__small {
    font-size: 13px;
    font-weight: 300;
    color: #ffffff;
    letter-spacing: 0.4px;
}
/* Menu overlay */
.menu{
  position:fixed;
  inset:0;
  display:none;
  z-index: 50;
}
.menu.is-open{ display:block; }
.menu__backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.62);
}
.menu__panel{
  position:absolute;
  top:0; right:0;
  width: min(520px, 92vw);
  height: 100%;
  background: #000;
  color: rgba(255,255,255,.75);
  padding: 34px 36px;
  display:flex;
  flex-direction:column;
  gap: 26px;
}
.menu__close{
  position:absolute;
  top: 20px;
  right: 22px;
  width: 44px; height: 44px;
  border:0;
  background: transparent;
  color: rgba(255,255,255,.75);
  font-size: 30px;
  cursor:pointer;
}
.menu__nav{
  margin-top: 38px;
  display:flex;
  flex-direction:column;
  gap: 9px;
}
.menu__nav a{
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
}
.menu__nav a:first-child{ color: rgba(255,255,255,.85); }
.menu__brand{
  margin-top: auto;
  display:flex;
  align-items:center;
  gap: 12px;
  padding-top: 18px;
}
.brand__mark--menu{
  width: 36px; height: 28px;
  border-color: rgba(255,255,255,.7);
}
.brand__name--menu{
  font-size: 40px;
  color: rgba(255,255,255,.9);
}

/* Responsive */
@media (max-width: 980px){
  .location{ grid-template-columns: 1fr; }
  .location__card{ justify-self: center; margin-top: 18px; }
  .feature{ grid-template-columns: 1fr; }
  .feature__card{ margin-left: 0; justify-self:center; margin-top: -18px; }
  .feature__media img{ height: 240px; }
  .footer__grid{ grid-template-columns: 1fr; gap: 26px; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
}

@media (max-width: 560px){
  .container{ width: calc(100% - 28px); }
  .topbar{ font-size: 10px; }
  .hero__content{ padding: 90px 0 110px; }
  .location__grid img{  }
  .card{ padding: 26px 22px; }
  .menu__panel{ padding: 30px 22px; }
  .menu__nav a{ font-size: 12px; }
  .hero {min-height: 400px !important;}
}

@media (max-width: 767px){
  .topbar__label {display: none !important;}
  .nomobile {display: none !important;}
  .hero__book {display: none !important;}

}

html.no-scroll, body.no-scroll{ overflow:hidden; }


/* --- v2: logo image + topbar jpg icons --- */
.brand__logo{
  display:block;
  height:64px;
  width:auto;
}

.topbar__item--withicon{
  display:flex;
  align-items:center;
  gap:10px;
  color: #ffffff;
}

.topbar__miniicon{
  width:16px;
  height:16px;
  object-fit:contain;
  display:block;
}

.topbar__link{
  color:inherit;
  text-decoration:none;
}

.topbar__icon img{
  width:16px;
  height:16px;
  object-fit:contain;
  display:block;
}


/* --- sticky header (logo + burger) --- */
.hero__navwrap{
  position:relative;
  z-index: 10;
}
.hero__navwrap.is-sticky{
  position:fixed;
  top:0;
  left:0;
  right:0;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.hero__navwrap.is-sticky .hero__nav{
  padding: 14px 0;
}
body.has-sticky-offset{
  /* set via JS to avoid layout jump */
}


/* --- v5: sticky nav (logo + prenota + burger) becomes dark on light background --- */
.js-stickyWrap.is-sticky .hero__book{
  color:#111 !important;
}

.js-stickyWrap.is-sticky .burger span{
  background:#111 !important;
}

/* Logo swap handled in JS; this just prevents any unintended filters */
.js-stickyWrap.is-sticky .brand__logo{
  filter:none;
}

.hero{
  position: relative;
  overflow: hidden;
}

.hero__bg{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.hero__overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero__navwrap,
.hero__content,
.hero__skew{
  position: relative;
  z-index: 2;
}

.hero{
  position: relative;
  overflow: hidden;
}

.hero::after{
  content:"";
  position:absolute;
  left:-30%;
  bottom:0;
  width:160%;
  height:393px;                 /* più alto per sicurezza */
  background:#fff;
  transform: skewY(-3.5deg) translateY(393px);  /* <-- scende di più */
  transform-origin:left bottom;
  z-index:5;
  pointer-events:none;
}

.logofooter {width: 195px; padding-bottom: 30px;}
.footer__block a {color: #bab0b0; display: block; font-size: 12px; letter-spacing: 1px;}
.opening_time span {display: block; font-size: 14px; color: #bab0b0;}

/* ===== GALLERY ===== */
.gallery{
  width: 100%;
  margin: 0;
  padding: 0;
}

.gallery-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  width: 100%;
}

/* ogni card è un button per evitare problemi di click */
.gallery-item{
  border: 0;
  padding: 0;
  margin: 0;
  background: #f2f2f2;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  cursor: pointer;
  display: block;
}

.gallery-item img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform .35s ease;
}

.gallery-item:hover img{
  transform: scale(1.06);
}

/* responsive */
@media (max-width: 1200px){
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .gallery-grid{ grid-template-columns: 1fr; }
}

/* ===== LIGHTBOX ===== */
.lightbox{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

.lightbox.is-open{
  display: block;
}

.lightbox__backdrop{
  position: absolute;
  inset: 0;
  background: rgb(0 0 0 / 95%);
}

.lightbox__panel{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.lightbox__stage{
  width: min(1100px, 92vw);
  height: min(78vh, 820px);
  display: flex;
  align-items: center;
  justify-content: center;
}

#lbImg{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain; /* foto intera */
  border-radius: 12px;
}

.lightbox__close{
  position: absolute;
  top: 16px;
  right: 18px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.15);
  color: #fff;
  font-size: 30px;
  cursor: pointer;
}

.lightbox__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.15);
  color: #fff;
  font-size: 42px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox__prev{ left: 16px; }
.lightbox__next{ right: 16px; }

.lightbox__nav:hover,
.lightbox__close:hover{
  background: rgba(255,255,255,.25);
}


.galleriaimmagini { padding-top:50px; padding-bottom: 100px; }

.logomenu { width: 230px; }


:root{
  --bg: #f6f1ea;
  --ink: #2f2a26;
  --muted: rgba(47,42,38,.55);
  --line: rgba(47,42,38,.14);
  --badge: #4a3a33;
  --btn-border: rgba(47,42,38,.45);
}

.menu-page{
  width: 100%;
  color: var(--ink);
  padding: 18px 0 40px;
  
}

.menu-allergens{
  text-align: center;
  padding: 0 18px;
  font-size: 12px;
  letter-spacing: .04em;
}

.menu-allergens__title{
  font-weight: 700;
  margin-bottom: 4px;
}

.menu-allergens__text{
  color: #000000;
  font-weight: 500;
}

.menu-sep{
  border: 0;
  height: 1px;
  background: var(--line);
  margin: 14px 0 18px;
}

.menu-actions{
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding: 0 18px 22px;
}

.menu-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 12px;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid var(--btn-border);
  background: transparent;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: .08em;
}

.menu-btn:hover{
  background: rgba(0,0,0,.03);
}

/* Griglia principale 2 colonne */
.menu-grid{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  padding: 0 18px;
}

/* Blocchi */
.menu-block{
  margin: 18px 0 0;
}

.menu-block--spaced{
  margin-top: 48px;
}

/* Badge (Coperto, Antipasti, ecc.) */
.menu-badge{
  display: inline-block;
  padding: 6px 12px;
  background: var(--badge);
  color: #fff;
  font-size: 15px;
  letter-spacing: .02em;
  margin-bottom: 10px;
}

/* Riga piatto */
.menu-item{
  position: relative;
  padding: 14px 0 14px;
  border-bottom: 1px solid var(--line);
}

.menu-item__name{
  font-size: 15px;
  line-height: 1.35;
  padding-right: 70px; /* spazio prezzo */
  color: #000000;
}

.menu-item__price{
  position: absolute;
  right: 0;
  top: 14px;
  font-size: 15px;
  white-space: nowrap;
}

.menu-item__meta{
  margin-top: 6px;
  font-size: 12px;
  color: var(--muted);
}

.menu-grid--single{
  grid-template-columns: 1fr;
  gap: 0;
  max-width: 100%;
}

/* Responsive */
@media (max-width: 980px){
  .menu-actions{
    grid-template-columns: 1fr;
  }
  .menu-grid{
    grid-template-columns: 1fr;
    gap: 34px;
  }
}



/* ===== LAYOUT FULL WIDTH ===== */
.contact-split{
  width:100%;
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 90px;
  padding: 30px 60px;
  background: #ffffff;
  color:#2d2a27;
}

/* ===== COLONNA SX ===== */
.contact-title{
  font-size: 54px;
  line-height: 1.05;
  font-weight: 500;
  margin: 0 0 26px;
}

.contact-text{
  font-size: 18px;
  line-height: 1.6;
}

.contact-text a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,.18);
}

.contact-gap{
  margin-top: 26px;
}

/* ===== COLONNA DX (CARD) ===== */
.contact-card{
  background: #ffffff;
  border-radius: 2px;
  box-shadow: 0 0 120px rgba(0,0,0,.06);
  padding: 44px 46px;
  max-width: 720px;
  margin-left: auto;
}

/* griglia 2 colonne come in foto */
.form-grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px 34px;
}

.field label{
  display:block;
  font-size: 18px;
  margin: 0 0 10px;
  color: rgba(45,42,39,.85);
}

.field input{
  width:100%;
  border:0;
  border-bottom: 1px solid rgba(0,0,0,.5);
  padding: 10px 0 8px;
  font-size: 18px;
  background: transparent;
  outline: none;
}

/* textarea come box grande */
.field--textarea{
  margin-top: 22px;
}

.field--textarea textarea{
  width:100%;
  height: 130px;
  border: 1px solid rgba(0,0,0,.6);
  padding: 16px 16px;
  font-size: 18px;
  resize: vertical;
  outline: none;
  background: transparent;
}

/* bottone */
.btn-submit{
  width:100%;
  margin-top: 20px;
  padding: 18px 16px;
  border: 0;
  cursor: pointer;
  background: #a4907f;          /* beige/tortora come foto */
  color: #fff;
  font-size: 16px;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.btn-submit:hover{
  filter: brightness(0.95);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px){
  .contact-split{
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 70px 22px;
  }
  .contact-card{
    margin-left: 0;
    padding: 34px 28px;
    max-width: 100%;
  }
  .contact-title{
    font-size: 42px;
  }
}

@media (max-width: 620px){
  .form-grid-2{
    grid-template-columns: 1fr;
  }
}


.gdpr{
  display:flex;
  gap:12px;
  margin-top: 14px;
  font-size: 14px;
  line-height: 1.4;
  color: rgba(45,42,39,.85);
}
.gdpr input{ margin-top: 4px; }

.form-msg{
  margin-top: 14px;
  font-size: 15px;
  padding: 12px 14px;
  border: 1px solid transparent;
  display:none;
}
.form-msg.is-ok{
  display:block;
  border-color: rgba(20,120,60,.35);
  background: rgba(20,120,60,.08);
}
.form-msg.is-err{
  display:block;
  border-color: rgba(180,30,30,.35);
  background: rgba(180,30,30,.08);
}
.btn-submit.is-loading{
  opacity: .7;
  pointer-events: none;
}


/* honeypot anti-spam: deve essere invisibile */
.hp-field{
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.contact-card{ position: relative; }

.trip {
    width: 84px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 30px;
}


/* ===== STORY (FULL WIDTH) ===== */
.story{
  width: 100%;
  background: #ffffff;
  padding: 10px 0;
  color: #2d2a27;
}

/* riga a 2 colonne */
.story-row{
  width: 100%;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 70px;
  align-items: center;
  padding: 70px 60px;
}

/* inverti immagine/testo */
.story-row--reverse{
  grid-template-columns: 1fr 1.1fr;
}
.story-row--reverse .story-media{
  order: 2;
}
.story-row--reverse .story-text{
  order: 1;
}

.story-text{
  text-align: center;
  max-width: 520px;
  margin: 0 auto;
}

.story-text h2{
  margin: 0 0 18px;
  font-size: 42px;
  font-weight: 500;
  letter-spacing: .01em;
}

.story-text p{
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: #000000;
}

/* cornice immagine */
.story-frame{
  background: #fff;
  max-width: 640px;
}

.story-frame img{
  width: 100%;
  height: auto;
  display: block;
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}

/* nel blocco centrale in foto sembra più "card" */
.story-frame--shadow{
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
}

/* separatore tra blocchi */
.story-sep{
  border: 0;
  height: 1px;
  background: rgba(0,0,0,.08);
  margin: 0;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px){
  .story-row,
  .story-row--reverse{
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 50px 22px;
  }
  .story-row--reverse .story-media,
  .story-row--reverse .story-text{
    order: initial;
  }
  .story-text{
    max-width: 640px;
  }
  .story-text h2{
    font-size: 34px;
  }
}

.menu-grid.menu-grid--balanced{
  display: block;            /* disattiva la grid attuale */
  columns: 2;
  column-gap: 70px;
  padding: 0 18px;
}

.menu-grid.menu-grid--balanced .menu-block{
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  display: inline-block;
  width: 100%;
}

/* mobile: una colonna */
@media (max-width: 980px){
  .menu-grid.menu-grid--balanced{
    columns: 1;
    column-gap: 0;
  }
}


/* ===== HERO SLIDER ===== */

.hero__overlay{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none; /* IMPORTANTISSIMO */
}

.hero__slider{
  position:absolute;
  inset:0;
  z-index:1;
}

.hero__slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .6s ease;
}

.hero__slide.is-active{
  opacity:1;
}

/* frecce */
/* ===== HERO ARROWS (LUXURY) ===== */
.hero__arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index: 999 !important;
  pointer-events:auto;

  width:44px;
  height:44px;
  border-radius:999px;

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

  display:flex;
  align-items:center;
  justify-content:center;

  cursor:pointer;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, opacity .2s ease;
  opacity:.9;
}

.hero__arrow svg{
  width:18px;
  height:18px;
  display:block;
}

.hero__arrow svg path{
  fill:none;
  stroke: rgba(255,255,255,.92);
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hero__prev{ left:16px; }
.hero__next{ right:16px; }

.hero__arrow:hover{
  background: rgba(0,0,0,.28);
  border-color: rgba(255,255,255,.75);
  transform: translateY(-50%) scale(1.03);
}

@media (max-width: 560px){
  .hero__arrow{
    width:40px;
    height:40px;
  }
  .hero__arrow svg{
    width:16px;
    height:16px;
  }
}

/* overlay e contenuti NON devono bloccare i click */
.hero__overlay,
.hero__content,
.hero__navwrap,
.hero__skew{
  pointer-events:none;
}

/* RIATTIVA CLICK LOGO E MENU */
.brand,
.brand a,
.brand__logo,
.hero__nav,
.hero__actions,
.hero__actions a,
.burger{
  pointer-events:auto !important;
}


/* riabilitiamo i click SOLO sugli elementi cliccabili veri */
.hero__actions,
.hero__actions a,
.burger{
  pointer-events:auto;
}
