/* Grotta Marcello – Menù v2: stile front-end (scoped sotto .gm-menu) */

.gm-menu {
	--gm-bg:     #1d1712;
	--gm-soft:   #261e17;
	--gm-panel:  #2c231b;
	--gm-edge:   rgba(65,52,38,.6);
	--gm-sand:   #eadfca;
	--gm-muted:  #b39c82;
	--gm-faint:  #8a7561;
	--gm-wine:   #a4636e;
	--gm-amber:  #d9a45b;
	--gm-serif:  'Bodoni Moda','Bodoni MT',Georgia,serif;
	--gm-sans:   'Karla','Segoe UI',sans-serif;

	background:    var(--gm-bg);
	color:         var(--gm-sand);
	font-family:   var(--gm-sans);
	max-width:     820px;
	margin:        0 auto;
	padding:       36px 22px 48px;
	border-radius: 14px;
	line-height:   1.5;
}
.gm-menu *, .gm-menu *::before, .gm-menu *::after { box-sizing: border-box; }
.gm-menu button { font-family: inherit; cursor: pointer; background: none; border: none; color: inherit; }
.gm-menu button:focus-visible { outline: 2px solid var(--gm-amber); outline-offset: 2px; }

/* ── Intestazione ─────────────────────────────────────────── */
.gm-head      { text-align: center; margin-bottom: 18px; }
.gm-title     { font-family: var(--gm-serif); font-weight: 400; font-optical-sizing: auto; font-size: clamp(30px,6vw,42px); letter-spacing: .08em; margin: 8px 0 0; color: var(--gm-sand); }
.gm-tagline   { font-family: var(--gm-serif); font-style: italic; color: var(--gm-wine); font-size: 14px; letter-spacing: .12em; margin-top: 6px; }

/* ── Filtri dietetici ─────────────────────────────────────── */
.gm-filters       { margin: 22px 0 0; }
/* Riduci lo spazio tra filtri/sottocategorie/descrizione e la prima sezione */
.gm-filters + .gm-section .gm-section-head,
.gm-subcats + .gm-section .gm-section-head,
.gm-orario-note + .gm-section .gm-section-head { margin-top: 4px; }
.gm-filters-label { display: block; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--gm-faint); margin-bottom: 8px; }
.gm-filters-row   { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
/* Due gruppi di filtri: ingredienti/diete e tipologia */
.gm-filters-group { margin-bottom: 10px; }
.gm-filters-sub   { display: block; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--gm-amber); margin-bottom: 6px; opacity: .85; }
/* Avviso intolleranze/su richiesta, dentro la tendina dei filtri */
.gm-filters-note {
  font-size: 12.5px; line-height: 1.55; color: var(--gm-faint);
  margin: 14px 0 2px; padding: 10px 12px; border-radius: 6px;
  background: rgba(192,120,48,.08);
  background: color-mix(in srgb, var(--gm-amber) 9%, transparent);
  border-left: 2px solid var(--gm-amber);
}
.gm-filters-note-label { display: block; color: var(--gm-wine); font-weight: 700; margin-bottom: 3px; }
.gm-filters-note-text { display: block; }
/* Pulsante "Filtra" mobile: nascosto su desktop */
.gm-filters-toggle { display: none; }
.gm-ft-caret { display: inline-block; transition: transform .2s; font-size: 10px; }
.gm-chip { font-size: 12.5px; letter-spacing: .04em; padding: 6px 14px; border-radius: 999px; border: 1px solid var(--gm-edge); color: var(--gm-muted); transition: all .15s ease; }
.gm-chip.is-active { background: var(--gm-tag,var(--gm-amber)); border-color: var(--gm-tag,var(--gm-amber)); color: var(--gm-bg); font-weight: 700; }
.gm-clear { font-size: 12px; color: var(--gm-amber); text-decoration: underline; padding: 4px 6px; }

/* ── Fasce orarie ─────────────────────────────────────────── */
.gm-fasce { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); margin: 24px 0 0; border: 1px solid var(--gm-edge); border-radius: 14px; overflow: hidden; }
/* Blocchi separati (Cucina / Beverage) */
.gm-blocco-fasce + .gm-blocco-fasce { margin-top: 22px; }
.gm-blocco-fasce .gm-fasce { margin-top: 8px; }
.gm-blocco-label {
  font-family: var(--gm-serif); font-style: italic; font-size: 18px;
  color: var(--gm-wine); letter-spacing: .04em; text-align: center;
}
.gm-fascia-btn { font-family: var(--gm-serif); font-optical-sizing: auto; font-size: 15px; letter-spacing: .06em; padding: 14px 10px; text-align: center; color: var(--gm-muted); transition: all .15s; }
.gm-fascia-btn + .gm-fascia-btn { border-left: 1px solid var(--gm-edge); }
.gm-fascia-btn.is-active { background: var(--gm-panel); color: var(--gm-amber); }
.gm-fascia-btn .orario { display: block; font-family: var(--gm-sans); font-size: 11px; letter-spacing: .08em; color: var(--gm-faint); margin-top: 3px; }
.gm-fascia-btn.is-active .orario { color: var(--gm-muted); }

/* ── Pannelli fascia ──────────────────────────────────────── */
.gm-fascia-panel         { display: none; }
.gm-fascia-panel.is-active { display: block; }
.gm-orario-note { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--gm-faint); margin: 14px 0 2px; }

/* ── Sottocategorie ───────────────────────────────────────── */
.gm-subcats { display: flex; flex-wrap: wrap; gap: 8px; padding: 18px 0 8px; }
.gm-subcats::-webkit-scrollbar { display: none; }
.gm-subcat-btn { white-space: nowrap; font-family: var(--gm-sans); font-size: 12.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 7px 16px; border-radius: 999px; border: 1px solid var(--gm-edge); color: var(--gm-muted); transition: all .15s; }
.gm-subcat-btn.is-active { background: var(--gm-amber); border-color: var(--gm-amber); color: var(--gm-bg); }

/* ── Sezioni e piatti ─────────────────────────────────────── */
.gm-section              { display: block; }
.gm-section.gm-sect-hidden { display: none; }
.gm-section-head  { display: flex; align-items: center; gap: 12px; margin: 24px 0 4px; }
.gm-section-head h3 { font-family: var(--gm-serif); font-weight: 400; font-optical-sizing: auto; font-size: 25px; letter-spacing: .06em; margin: 0; color: var(--gm-sand); }
.gm-rule          { flex: 1; border-bottom: 1px solid var(--gm-edge); }
.gm-section-note  { font-family: var(--gm-serif); font-style: italic; font-size: 13.5px; color: var(--gm-wine); margin-bottom: 6px; }
.gm-dish          { padding: 14px 0; border-bottom: 1px solid var(--gm-edge); }
.gm-dish.gm-hidden { display: none; }
.gm-gruppo.gm-hidden, .gm-sottogruppo.gm-hidden { display: none; }
.gm-dish-line     { display: flex; align-items: baseline; gap: 10px; }
.gm-dish-name     { font-family: var(--gm-serif); font-optical-sizing: auto; font-size: 18px; color: var(--gm-sand); }
.gm-dots          { flex: 1; border-bottom: 1px dotted var(--gm-faint); transform: translateY(-4px); }
.gm-price         { font-family: var(--gm-serif); font-optical-sizing: auto; font-size: 17px; color: var(--gm-amber); white-space: nowrap; }
.gm-dish-desc     { font-size: 13.5px; color: var(--gm-muted); margin-top: 4px; max-width: 85%; }
.gm-badges        { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; }
.gm-badge         { font-size: 10.5px; letter-spacing: .06em; padding: 1px 8px; border-radius: 999px; border: 1px solid var(--gm-tag,var(--gm-amber)); color: var(--gm-tag,var(--gm-amber)); white-space: nowrap; }
.gm-empty         { padding: 28px 0; text-align: center; color: var(--gm-faint); font-size: 14px; }

/* ── Allergeni ────────────────────────────────────────────── */
.gm-allergeni        { margin-top: 34px; border-top: 1px solid var(--gm-edge); padding-top: 16px; }
.gm-allergeni-toggle { font-size: 13px; color: var(--gm-muted); text-decoration: underline; padding: 0; }
.gm-allergeni-text   { font-size: 12.5px; color: var(--gm-faint); line-height: 1.7; margin-top: 10px; }

@media (max-width: 600px) {
  .gm-subcats { flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-right: 24px; }
  .gm-subcats::-webkit-scrollbar { display: none; }
  /* Sfumatura a destra per suggerire lo scorrimento */
  .gm-subcats-wrap { position: relative; }

  /* Filtri caratteristiche raccolti dietro il pulsante "Filtra" */
  .gm-filters-label { display: none; }
  .gm-filters-toggle {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--gm-sans); font-size: 15px; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase; color: #fff;
    background: var(--gm-wine); border: 1px solid var(--gm-wine);
    border-radius: 999px; padding: 12px 26px; cursor: pointer;
    box-shadow: 0 3px 10px rgba(133,86,91,.32);
  }
  .gm-filters-toggle:hover { background: var(--gm-amber); border-color: var(--gm-amber); }
  .gm-ft-caret { font-size: 13px; }
  .gm-filters-group {
    overflow: hidden; max-height: 0; opacity: 0; margin-top: 0; margin-bottom: 0;
    transition: max-height .28s ease, opacity .2s ease, margin .28s ease;
  }
  .gm-filters.is-open .gm-filters-group {
    max-height: 600px; opacity: 1; margin-top: 14px; margin-bottom: 10px;
  }
  .gm-filters-note {
    overflow: hidden; max-height: 0; opacity: 0;
    margin-top: 0; margin-bottom: 0; padding-top: 0; padding-bottom: 0;
    transition: max-height .28s ease, opacity .2s ease, margin .28s ease, padding .28s ease;
  }
  .gm-filters.is-open .gm-filters-note {
    max-height: 400px; opacity: 1; margin-top: 12px; padding-top: 10px; padding-bottom: 10px;
  }
  .gm-filters.is-open .gm-ft-caret { transform: rotate(180deg); }
  /* Testi dei filtri leggermente piu grandi su mobile */
  .gm-chip { font-size: 14px; padding: 8px 14px; }
  .gm-filters-sub { font-size: 12px; }
}

/* Filtri dietro il pulsante anche su DESKTOP (opzione backend) */
@media (min-width: 601px) {
  .gm-filters-desktop-toggle .gm-filters-label { display: none; }
  .gm-filters-desktop-toggle .gm-filters-toggle {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--gm-sans); font-size: 15px; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase; color: #fff;
    background: var(--gm-wine); border: 1px solid var(--gm-wine);
    border-radius: 999px; padding: 12px 26px; cursor: pointer;
    box-shadow: 0 3px 10px rgba(133,86,91,.32);
  }
  .gm-filters-desktop-toggle .gm-filters-toggle:hover { background: var(--gm-amber); border-color: var(--gm-amber); }
  .gm-filters-desktop-toggle .gm-filters-group {
    overflow: hidden; max-height: 0; opacity: 0; margin-top: 0; margin-bottom: 0;
    transition: max-height .28s ease, opacity .2s ease, margin .28s ease;
  }
  .gm-filters-desktop-toggle.is-open .gm-filters-group {
    max-height: 600px; opacity: 1; margin-top: 12px; margin-bottom: 10px;
  }
  .gm-filters-desktop-toggle .gm-filters-note {
    overflow: hidden; max-height: 0; opacity: 0;
    margin-top: 0; margin-bottom: 0; padding-top: 0; padding-bottom: 0;
    transition: max-height .28s ease, opacity .2s ease, margin .28s ease, padding .28s ease;
  }
  .gm-filters-desktop-toggle.is-open .gm-filters-note {
    max-height: 400px; opacity: 1; margin-top: 12px; padding-top: 10px; padding-bottom: 10px;
  }
  .gm-filters-desktop-toggle.is-open .gm-ft-caret { transform: rotate(180deg); }
}

@media (prefers-reduced-motion: reduce) { .gm-menu * { transition: none !important; } }

/* ── Gruppi / sottosezioni ────────────────────────────────── */
.gm-gruppo {
  font-family: 'Bodoni Moda', Georgia, serif;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gm-wine);
  margin: 26px 0 12px;
  padding: 0;
  border: none;
  background: none;
  display: flex;
  align-items: center;
  gap: 14px;
}
.gm-gruppo::after {
  content: "";
  flex: 1;
  height: 2px;
  background: var(--gm-wine);
  opacity: .45;
}

.gm-sottogruppo {
  font-family: 'Bodoni Moda', Georgia, serif;
  font-size: 13px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gm-wine);
  margin: 18px 0 6px;
  padding: 0;
  border: none;
  display: flex;
  align-items: center;
  gap: 12px;
  opacity: .9;
}
.gm-sottogruppo::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--gm-edge);
}

/* ── Allergeni: body con link ─────────────────────────────── */
.gm-allergeni-body { margin-top: 10px; }
.gm-allergeni-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-size: 13px;
  font-family: var(--gm-sans);
  color: var(--gm-amber);
  text-decoration: none;
  border: 1px solid var(--gm-amber);
  border-radius: 999px;
  padding: 8px 18px;
  transition: background .15s, color .15s;
}
.gm-allergeni-link:hover {
  background: var(--gm-amber);
  color: var(--gm-bg);
}

/* ── Filtri nascosti per fascia ───────────────────────────── */
.gm-chip[hidden] { display: none; }
.gm-fasce { grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); }
@media (max-width: 480px) {
  /* Ogni fascia su una riga intera: niente piu split sbilanciato 2+1 */
  .gm-fasce { grid-template-columns: 1fr; }
  .gm-fascia-btn { border-left: none; }
  .gm-fascia-btn + .gm-fascia-btn { border-top: 1px solid var(--gm-edge); }
}

/* ── Ricerca rapida Gin ────────────────────────────────────── */
.gm-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 14px 0 10px;
  padding: 8px 12px;
  border: 1px solid var(--gm-edge);
  border-radius: 999px;
  background: var(--gm-soft);
}
.gm-search-wrap .ti { color: var(--gm-faint); font-size: 16px; flex-shrink: 0; }
.gm-search-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-family: var(--gm-sans);
  font-size: 16px;
  color: var(--gm-sand);
}
.gm-search-input::placeholder { color: var(--gm-faint); }
.gm-search-clear {
  background: none;
  border: none;
  color: var(--gm-faint);
  font-size: 18px;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.gm-search-clear:hover { color: var(--gm-sand); }
.gm-dish.gm-search-hidden { display: none; }
