@media (max-width: 980px) {
  html, body { overflow-x: hidden !important; }

  section, .section {
    height: auto !important;
    min-height: auto !important;
    padding: 60px 0 !important;
  }

  /* Hero */
  .hero.hero--sofra {
    height: auto !important;
    min-height: 100vh !important;
    padding: 96px 18px 56px !important;
    background-position: center;
  }
  .hero .hero-content { padding: 0 14px !important; }
  .hero-title .script {
    font-size: 2.3rem !important;
  }
  .hero-title .script::after{
    width: 130px !important;
    height: 3px !important;
    margin: 12px auto 10px !important;
  }
  .hero-title .block {
    font-size: 2.6rem !important;
    letter-spacing: .14em !important;
  }
  .hero-divider{
    width: 100px !important;
    height: 100px !important;
    border-width: 2px !important;
  }
  .hero-divider img{
    border-radius: 50% !important;
  }
  .hero-content .btn { font-size: 1rem !important; padding: 14px 36px !important; }
  .hero .buttons { flex-direction: column !important; gap: 18px !important; margin-top: 24px !important; }
  .hero .buttons .btn { width: 100% !important; max-width: 320px !important; margin: 0 auto !important; }

  /* Griglieria (Our Story) */
  #griglieria.section--story .story-grid { grid-template-columns: 1fr !important; gap: 32px !important; align-items: center !important; }
  #griglieria .story-copy,
  #griglieria .story-images { transform: none !important; margin: 0 auto !important; text-align: center; }
  #griglieria .story-media img { width: 100%; height: auto; border-radius: 10px; }

  /* I nostri piatti speciali */
  #piatti-speciali .section-content { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 24px; }
  #piatti-speciali img { width: 80%; max-width: 350px; height: auto; border-radius: 50%; }

  /* Panineria (Kebab Gourmet) */
  #panineria .story-grid { grid-template-columns: 1fr !important; gap: 32px !important; align-items: center !important; }
  #panineria .story-copy,
  #panineria .story-images { transform: none !important; margin: 0 auto !important; text-align: center; }
  #panineria .story-media img { width: 100%; height: auto; border-radius: 12px; }

  /* Spazi sezioni */
  #griglieria,
  #piatti-speciali,
  #panineria,
  #instagram,
  #contatti { margin: 0 !important; }

  /* Instagram e galleria */
  #instagram { margin-top: 50px !important; padding: 40px 0 !important; }
  #instagram iframe, #instagram img { max-width: 100%; height: auto; }

  /* Bottone menu */
  .btn.small { display: block; margin: 0 auto 40px; font-size: 1rem; }

  /* WhatsApp */
  #whatsapp-float { bottom: 16px !important; right: 16px !important; width: 58px !important; height: 58px !important; border-radius: 50%; }

  /* Footer */
  .footer-grid { flex-direction: column; text-align: center; }
}

/* ===== Mobile: Typography, spacing & image behavior fixes ===== */
@media (max-width: 980px) {
  /* Contenitore più arioso sui lati */
  .container { padding-left: 18px !important; padding-right: 18px !important; }

  /* Titoli di sezione compatti e centrati */
  .section h2,
  .section .section-title,
  .section .title,
  .section .title-l { font-size: 1.6rem !important; line-height: 1.2 !important; text-align: center !important; margin: 0 0 14px !important; }

  /* Paragrafi più leggibili */
  .story-copy,
  .section .copy,
  .section p { font-size: 0.98rem !important; line-height: 1.6 !important; }
  .story-copy p { margin: 0 0 14px !important; }

  /* Ordine: testo prima, immagine dopo (tutte le sezioni critiche) */
  #griglieria .story-copy { order: 1 !important; }
  #griglieria .story-images { order: 2 !important; }
  #griglieria-mirror .story-copy { order: 1 !important; }
  #griglieria-mirror .story-images { order: 2 !important; }
  #panineria .story-copy { order: 1 !important; }
  #panineria .story-images { order: 2 !important; }

  /* Figure e immagini sempre nel flusso, senza sovrapposizioni */
  figure.story-media, .story-media { position: static !important; margin: 12px auto 0 !important; width: 100% !important; max-width: 420px !important; }
  .story-media img { display: block !important; width: 100% !important; height: auto !important; object-fit: cover !important; border-radius: 10px !important; }

  /* Spaziatura verticale tra testo e immagini */
  #griglieria .story-copy + .story-images,
  #griglieria-mirror .story-copy + .story-images,
  #panineria .story-copy + .story-images { margin-top: 8px !important; }

  /* Evita che i blocchi attacchino al bordo dello schermo */
  #griglieria, #griglieria-mirror, #panineria { padding-top: 36px !important; padding-bottom: 36px !important; }
}

/* === Correzioni finali layout mobile testi + immagini === */
@media (max-width: 980px) {
  /* Sezioni principali - padding e centratura */
  #griglieria, #griglieria-mirror, #panineria { margin: 0 auto !important; padding: 40px 0 !important; max-width: 620px !important; width: 92% !important; }

  /* Titoli e testi */
  #griglieria h2, #griglieria-mirror h2, #panineria h2 { font-size: 1.6rem !important; text-align: center !important; margin-bottom: 14px !important; }
  #griglieria p, #griglieria-mirror p, #panineria p { font-size: 0.95rem !important; line-height: 1.6 !important; text-align: center !important; margin: 0 0 16px !important; }

  /* Allineamento e ordine */
  #griglieria .story-copy, #griglieria-mirror .story-copy, #panineria .story-copy { order: 1 !important; text-align: center !important; margin-bottom: 20px !important; }
  #griglieria .story-images, #griglieria-mirror .story-images, #panineria .story-images { order: 2 !important; display: flex !important; justify-content: center !important; }

  /* Immagini responsive e rotonde dove serve */
  .story-images img, .story-media img { width: 100% !important; max-width: 420px !important; height: auto !important; border-radius: 10px !important; object-fit: cover !important; }

  /* Spaziatura aggiuntiva per chiarezza */
  .story-copy + .story-images { margin-top: 20px !important; }
}


/* === Mobile hard-fix: grids, transforms, and image flow === */
@media (max-width: 980px) {
  /* Forza tutte le griglie a una colonna */
  .grid-2, .grid-3, .grid-4, .story-grid { grid-template-columns: 1fr !important; gap: 24px !important; }

  /* Neutralizza trasformazioni/movimenti inline che causano sovrapposizioni */
  #griglieria [style*="transform"],
  #griglieria-mirror [style*="transform"],
  #panineria [style*="transform"] { transform: none !important; top: auto !important; left: auto !important; right: auto !important; bottom: auto !important; }

  /* Evita posizionamenti assoluti nelle figure */
  #griglieria .story-media,
  #griglieria-mirror .story-media,
  #panineria .story-media { position: static !important; }

  /* Larghezze contenuti testuali controllate e centrate */
  #griglieria .story-copy,
  #griglieria-mirror .story-copy,
  #panineria .story-copy { width: 100% !important; max-width: 620px !important; margin-inline: auto !important; }

  /* Immagini sempre nel flusso, no altezza fissa */
  #griglieria .story-images img,
  #griglieria-mirror .story-images img,
  #panineria .story-images img { width: 100% !important; height: auto !important; max-width: 420px !important; object-fit: cover !important; display: block !important; margin-inline: auto !important; }

  /* Spaziatura verticale coerente */
  #griglieria .story-copy + .story-images,
  #griglieria-mirror .story-copy + .story-images,
  #panineria .story-copy + .story-images { margin-top: 16px !important; }
}
/* === ULTIMATE MOBILE OVERRIDES (beats inline/JS) === */
@media (max-width: 980px) {
  /* 1) Sezioni: invalida qualsiasi altezza/trasformazione inline */
  section[style*="height"], .section[style*="height"],
  #griglieria[style], #griglieria-mirror[style], #panineria[style], #instagram[style], #contatti[style] { height: auto !important; min-height: auto !important; margin-top: 0 !important; margin-bottom: 0 !important; }

  /* 2) Dentro le sezioni: azzera transform/margini forzati su qualsiasi elemento */
  #griglieria *[style*="transform"],
  #griglieria-mirror *[style*="transform"],
  #panineria *[style*="transform"] { transform: none !important; top:auto !important; left:auto !important; right:auto !important; bottom:auto !important; }
  #griglieria *[style*="margin"],
  #griglieria-mirror *[style*="margin"],
  #panineria *[style*="margin"] { margin: initial !important; }

  /* 3) Griglia a colonna unica con massima specificità */
  html body #griglieria .story-grid,
  html body #griglieria-mirror .story-grid,
  html body #panineria .story-grid { display: grid !important; grid-template-columns: 1fr !important; gap: 28px !important; align-items: start !important; }

  /* 4) Ordine: testo prima, immagine dopo */
  html body #griglieria .story-copy,
  html body #griglieria-mirror .story-copy,
  html body #panineria .story-copy { order: 1 !important; }
  html body #griglieria .story-images,
  html body #griglieria-mirror .story-images,
  html body #panineria .story-images { order: 2 !important; }

  /* 5) Figure non assolute e immagini fluide */
  html body #griglieria .story-media,
  html body #griglieria-mirror .story-media,
  html body #panineria .story-media { position: static !important; }
  html body #griglieria .story-media img,
  html body #griglieria-mirror .story-media img,
  html body #panineria .story-media img,
  html body #griglieria .story-images img,
  html body #griglieria-mirror .story-images img,
  html body #panineria .story-images img { width: 100% !important; height: auto !important; max-width: 420px !important; object-fit: cover !important; display: block !important; margin-inline: auto !important; }

  /* 6) Tipografia e spazi coerenti */
  html body #griglieria h2, html body #griglieria-mirror h2, html body #panineria h2 { text-align:center !important; margin: 0 0 12px !important; font-size: 1.6rem !important; }
  html body #griglieria p, html body #griglieria-mirror p, html body #panineria p { text-align:center !important; line-height:1.6 !important; margin:0 0 14px !important; }
  html body .story-copy + .story-images { margin-top: 16px !important; }
}
/* === PANINERIA (Kebab Gourmet) — mobile fix definitivo === */
@media (max-width: 980px){
  /* Sblocca tutto su Panineria anche se c'è inline style */
  #panineria, #panineria[style]{ height:auto !important; min-height:auto !important; margin:0 !important; padding:44px 0 !important; width:92% !important; max-width:640px !important; margin-inline:auto !important; overflow:visible !important; clear:both !important; }

  /* Griglia a colonna unica e in ordine testo -> immagine */
  #panineria .story-grid{ display:block !important; }
  #panineria .story-copy{ order:1 !important; margin:0 0 16px !important; text-align:center !important; }
  #panineria .story-images{ order:2 !important; margin:8px auto 0 !important; display:block !important; text-align:center !important; }

  /* Annulla trasformazioni/posizionamenti che creano sovrapposizioni */
  #panineria *[style*="transform"],
  #panineria *[style*="top"],
  #panineria *[style*="left"],
  #panineria *[style*="right"],
  #panineria *[style*="bottom"]{ transform:none !important; top:auto !important; left:auto !important; right:auto !important; bottom:auto !important; }

  /* Figure e immagini: sempre nel flusso, dimensioni controllate */
  #panineria .story-media, #panineria figure.story-media{ position:static !important; margin:0 auto !important; max-width:440px !important; width:100% !important; }
  #panineria .story-media img, #panineria .story-images img{ display:block !important; width:100% !important; height:auto !important; max-width:440px !important; object-fit:cover !important; border-radius:12px !important; margin:0 auto !important; }

  /* Card/box interni: niente altezza fissa */
  #panineria .menu-card, #panineria .image-card{ height:auto !important; min-height:auto !important; }

  /* Spazio extra sotto per non toccare Instagram o pulsanti */
  #panineria{ padding-bottom:64px !important; }
}

/* === FIX layout mobile Panini Gourmet === */
@media (max-width: 980px) {
  #panineria .menu-card,
  #panineria .image-card { display: flex !important; flex-direction: column !important; align-items: center !important; text-align: center !important; background: #fffbea !important; border-radius: 12px !important; padding: 16px !important; width: 100% !important; box-shadow: 0 2px 6px rgba(0,0,0,0.08) !important; }

  /* Immagine principale sopra il menu (non toccare le icone piccole nelle card) */
  #panineria .image-card img,
  #panineria .story-images img { display: block !important; width: 90% !important; max-width: 360px !important; height: auto !important; margin: 0 auto 12px !important; border-radius: 12px !important; object-fit: cover !important; }

  /* Icone/miniature dentro le singole card rimangono piccole */
  #panineria .menu-card img { width: 42px !important; height: auto !important; margin: 0 8px 0 0 !important; border-radius: 8px !important; }

  #panineria .menu-card h3,
  #panineria .menu-card p { text-align: center !important; }

  /* spacing generale sezione */
  #panineria .story-grid { display: flex !important; flex-direction: column !important; gap: 24px !important; align-items: center !important; }
}
/* === PANINERIA: immagine sopra il menu (override finale) === */
@media (max-width: 980px){
  html body #panineria .story-grid{ display:flex !important; flex-direction:column !important; align-items:center !important; gap:18px !important; }
  html body #panineria .story-images{ order:1 !important; width:100% !important; display:flex !important; justify-content:center !important; margin:0 auto 12px !important; }
  html body #panineria .story-copy{ order:2 !important; width:100% !important; max-width:640px !important; text-align:center !important; }
  html body #panineria .story-images img{ width:85% !important; max-width:360px !important; height:auto !important; }
}

/* === PANINERIA: posiziona .image-card sopra il primo .menu-card su mobile === */
@media (max-width: 980px) {
  #panineria .story-grid { display: flex !important; flex-direction: column !important; align-items: center !important; gap: 20px !important; }

  /* L'immagine principale sopra la prima card del menu */
  #panineria .image-card { order: 0 !important; width: 100% !important; max-width: 440px !important; margin: 0 auto 20px !important; text-align: center !important; }
  #panineria .menu-card:first-of-type { order: 1 !important; }
  #panineria .menu-card:not(:first-of-type) { order: 2 !important; }
  #panineria .image-card img { display: block !important; width: 85% !important; max-width: 360px !important; height: auto !important; border-radius: 12px !important; margin: 0 auto !important; object-fit: cover !important; }
}

/* === PANINERIA: centra tutta la sezione su mobile === */
@media (max-width: 980px) {
  #panineria { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; text-align: center !important; margin: 0 auto !important; padding: 40px 0 !important; width: 92% !important; max-width: 640px !important; }
  #panineria .story-grid { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; gap: 24px !important; width: 100% !important; text-align: center !important; }
  #panineria .story-copy,
  #panineria .menu-card,
  #panineria .image-card { text-align: center !important; margin: 0 auto !important; }
  #panineria .image-card img,
  #panineria .story-images img { display: block !important; margin: 0 auto !important; width: 85% !important; max-width: 360px !important; height: auto !important; border-radius: 12px !important; object-fit: cover !important; }
}
/* === MOBILE: Panineria senza immagine, contenuto centrato === */
@media (max-width: 980px){
  /* Nascondi SOLO l'immagine/figure della sezione Panineria */
  #panineria .story-images,
  #panineria .image-card,
  #panineria figure.story-media { display: none !important; }

  /* Mantieni il contenuto centrato e con larghezza controllata */
  #panineria,
  #panineria .story-grid,
  #panineria .story-copy { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; text-align: center !important; width: 92% !important; max-width: 640px !important; margin: 0 auto !important; gap: 18px !important; }
  #panineria .menu-card { width: 100% !important; }
}
/* === MOBILE: Panineria — forza centratura completa dei contenuti === */
@media (max-width: 980px){
  /* wrapper sempre centrato */
  #panineria, #panineria .story-grid, #panineria .story-copy { margin-inline: auto !important; text-align: center !important; display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; width: 92% !important; max-width: 640px !important; gap: 18px !important; }

  /* liste/menu in colonna e centrati */
  #panineria .menu,
  #panineria .menu-list,
  #panineria .menu-grid,
  #panineria .cards,
  #panineria .menu-items { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; width: 100% !important; gap: 12px !important; }

  /* card centrata e a larghezza controllata */
  #panineria .menu-card { width: 100% !important; max-width: 640px !important; margin-inline: auto !important; text-align: center !important; align-items: center !important; }

  /* righe interne che usano space-between → centrale su mobile */
  #panineria .menu-card .row,
  #panineria .menu-row,
  #panineria .menu-line { display: flex !important; flex-wrap: wrap !important; justify-content: center !important; align-items: center !important; gap: 6px !important; }

  /* prezzi e label senza offset a sinistra */
  #panineria [class*="price"],
  #panineria .price,
  #panineria .amount { margin-left: 0 !important; }

  /* liste classiche */
  #panineria ul,
  #panineria li { list-style: none !important; padding: 0 !important; margin: 0 auto !important; text-align: center !important; }
}

/* === PANINERIA — mobile: centra tutto e nascondi l'immagine laterale === */
@media (max-width: 980px){
  /* Nascondi SOLO l'immagine laterale */
  #panineria figure.image-card,
  #panineria .story-images,
  #panineria figure.story-media { display: none !important; }

  /* Wrapper/row centrati (anche se è .two-col o .two-col.reverse) */
  #panineria .container,
  #panineria .two-col,
  #panineria .two-col.reverse,
  #panineria .story-grid { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; text-align: center !important; margin-inline: auto !important; width: 92% !important; max-width: 640px !important; gap: 18px !important; }

  /* Liste/card del menu al centro, senza padding sinistro */
  #panineria .menu,
  #panineria .menu-list,
  #panineria .menu-grid,
  #panineria .cards,
  #panineria .menu-items { display: flex !important; flex-direction: column !important; align-items: center !important; justify-content: center !important; width: 100% !important; gap: 12px !important; padding-left: 0 !important; }
  #panineria ul, #panineria li { list-style: none !important; padding-left: 0 !important; margin: 0 auto !important; text-align: center !important; }

  /* Singola card centrata */
  #panineria .menu-card { width: 100% !important; max-width: 360px !important; margin: 0 auto 12px !important; text-align: center !important; }

  /* Annulla offset/transform residui */
  #panineria *[style*="transform"],
  #panineria *[style*="left"],
  #panineria *[style*="right"],
  #panineria *[style*="margin-left"]{ transform: none !important; left: auto !important; right: auto !important; margin-left: 0 !important; }
}

/* --- Header sempre fisso anche su mobile --- */
@media (max-width: 980px){
  .site-header { position: fixed; top: 0; left:0; right:0; z-index: 1000; background: #2f4e36; border-bottom: 1px solid rgba(0,0,0,.08); }

  /* nascondi completamente l'icona hamburger e qualunque overlay mobile */
  .nav-toggle,
  .mobile-nav,
  .nav-overlay,
  .menu-toggle { display:none !important; }

  /* mostra il menu desktop anche su mobile */
  .nav .menu { display:flex !important; align-items:center; justify-content:center; gap: 14px; padding: 10px 8px; height: 56px; }
  .nav .menu a { color:#fff !important; text-decoration:none; font-weight:600; font-size: 14px; padding: 8px 10px; border-radius: 6px; white-space: nowrap; }
  .nav .menu a:hover { background: rgba(255,255,255,.10); }

  /* se le voci sono tante, abilita lo scroll orizzontale elegante */
  .nav .menu { overflow-x:auto; -webkit-overflow-scrolling: touch; }
  .nav .menu::-webkit-scrollbar { display:none; }

  /* il logo su mobile un filo più piccolo per lasciare spazio alle voci */
  .brand { font-size: 18px !important; }
}
/* --- MOBILE HEADER: same solid style as desktop, no transparency --- */
@media (max-width: 980px){
  /* force solid background like desktop */
  .site-header,
  .site-header.is-solid,
  .site-header.is-transparent,
  header.site-header { background: #2f4e36 !important; color:#ffffff !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important; box-shadow: 0 1px 0 rgba(0,0,0,.08) !important; }

  /* ensure any state class used on desktop doesn't re‑introduce transparency */
  .site-header.is-transparent:before,
  .site-header:before { display:none !important; }

  /* brand + icons in white like desktop */
  .brand, .brand *,
  .nav .menu a,
  .nav .menu a:link,
  .nav .menu a:visited { color:#ffffff !important; }
  .nav .menu a:hover { background: rgba(255,255,255,.10) !important; }

  /* social icons and SVGs */
  .site-header svg, .site-header i, .site-header .social a { color:#ffffff !important; fill:#ffffff !important; }

  /* keep menu visible (no hamburger) and centered */
  .nav-toggle, .mobile-nav, .nav-overlay, .menu-toggle { display:none !important; }
  .nav .menu { display:flex !important; align-items:center !important; justify-content:center !important; gap:14px; padding:10px 8px; height:56px; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .nav .menu::-webkit-scrollbar { display:none; }
}

@media (max-width:980px){
  .nav .menu .menu-link { color:#fff; font-weight:600; font-size:14px; padding:8px 10px; border-radius:6px; text-decoration:none; white-space:nowrap; }
  .nav .menu .menu-link:hover { background:rgba(255,255,255,.10); }
}


/* === HEADER MOBILE: usa nav diretto (nessun wrapper .menu) === */
@media (max-width: 980px){
    .site-header{ position: fixed; top:0; left:0; right:0; z-index:1000; background:#2f4e36 !important; }
    /* nascondi hamburger/overlay */
    .nav-toggle, .mobile-nav, .nav-overlay, .menu-toggle{ display:none !important; }
  
    /* mostra e centra i link dentro <nav class="nav"> */
    .site-header .nav{
      position:static !important;
      inset:auto !important;
      width:100% !important;
      display:flex !important;
      align-items:center !important;
      justify-content:center !important;
      flex-wrap:nowrap !important;
      gap:10px !important;
      padding:12px 8px !important;
      height:auto !important;
      overflow-x:auto; -webkit-overflow-scrolling:touch;
      background:transparent !important;
    }
    .site-header .nav a{
      display:inline-block !important;
      color:#fff !important;
      text-decoration:none !important;
      font-weight:600 !important;
      font-size:13px !important;
      padding:6px 10px !important;
      border-radius:6px !important;
      white-space:nowrap !important;
      background:transparent !important;
      box-shadow:none !important;
    }
    .site-header .nav-wrap{
      grid-template-columns:1fr !important;
      justify-items:center !important;
      gap:4px !important;
    }
    .nav-right{display:none !important;}
    .site-header .nav a:hover{ background:rgba(255,255,255,.10) !important; }
  
    /* CHIAMACI in giallo */
    .site-header .nav a[href^="tel:"]{ color:#FFD34D !important; font-weight:700 !important; }
  }
/* === HEADER MOBILE: CHIAMACI giallo SOLO nel menu top === */
@media (max-width: 980px){
  /* reset globale per link tel fuori dall'header (evita bottoni strani in basso) */
  body a[href^="tel:"]{
    color: inherit !important;
    background: transparent !important;
    position: static !important;
  }
  .hero .buttons .btn[href^="tel:"]{
    background: var(--accent) !important;
    color: #f4f4f4 !important;
    border: 2px solid transparent !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    box-shadow: var(--shadow) !important;
  }
  /* applica il giallo SOLO al link tel dentro l'header */
  .site-header .nav a[href^="tel:"]{
    color:#FFD34D !important;
    font-weight:700 !important;
  }
  .site-header .nav a[href^="tel:"]:hover{
    background: rgba(255,211,77,.16) !important;
  }
}
