/*
 * Mesato — galeria pública do menu.
 * Escopado a .mst-menu (sem reset global, não afeta o tema do cliente).
 * Tokens em --mst-* sobreponíveis: o restaurante pode redefini-los no seu
 * layout (ex.: ligar a uma paleta Divi) sem tocar neste ficheiro.
 * Glassmorphism + ícones Lucide. Sem emojis.
 */
.mst-menu{
  --mst-brand:#B0703E;--mst-brand-dark:#8a5630;
  --mst-ink:#241f1a;--mst-ink-soft:#4b443c;--mst-muted:#857c70;
  --mst-glass:rgba(255,255,255,.58);--mst-glass-strong:rgba(255,255,255,.82);
  --mst-glass-brd:rgba(255,255,255,.7);--mst-line:rgba(120,100,80,.18);
  --mst-radius:18px;--mst-shadow:0 12px 40px rgba(60,40,25,.14);--mst-shadow-sm:0 6px 20px rgba(60,40,25,.10);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--mst-ink);line-height:1.55;max-width:1120px;margin:0 auto;
}
.mst-menu *{box-sizing:border-box}
.mst-menu .mst-ic{width:18px;height:18px;flex:none}

/* Toolbar: pesquisa + filtros */
.mst-menu .mst-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.mst-menu .mst-search{position:relative;flex:1;min-width:220px;max-width:380px;display:flex;align-items:center}
.mst-menu .mst-search .mst-ic{position:absolute;left:14px;color:var(--mst-muted);width:16px;height:16px}
.mst-menu .mst-search input{width:100%;padding:12px 14px 12px 40px;border:1px solid var(--mst-line);border-radius:999px;background:var(--mst-glass-strong);font-size:14px;font-family:inherit;color:var(--mst-ink)}
.mst-menu .mst-search input:focus{outline:none;border-color:var(--mst-brand);box-shadow:0 0 0 3px rgba(176,112,62,.15)}

.mst-menu .mst-chips{display:flex;flex-wrap:wrap;gap:8px}
.mst-menu .mst-chip{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border:1px solid var(--mst-line);border-radius:999px;background:var(--mst-glass-strong);font-size:13.5px;font-weight:600;color:var(--mst-ink-soft);cursor:pointer;font-family:inherit;transition:.18s}
.mst-menu .mst-chip:hover{border-color:var(--mst-brand);color:var(--mst-brand-dark)}
.mst-menu .mst-chip.is-on{background:var(--mst-brand);border-color:var(--mst-brand);color:#fff}

/* Secções por categoria */
.mst-menu .mst-section{margin-bottom:38px}
.mst-menu .mst-section[hidden]{display:none}
.mst-menu .mst-section-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:30px;font-weight:700;letter-spacing:.01em;margin:0 0 16px;color:var(--mst-ink)}
.mst-menu .mst-section-title::after{content:"";display:block;width:56px;height:3px;border-radius:3px;background:var(--mst-brand);margin-top:8px;opacity:.85}

/* Grid de cartões */
.mst-menu .mst-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}

.mst-menu .mst-card{display:flex;flex-direction:column;background:var(--mst-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--mst-glass-brd);border-radius:var(--mst-radius);box-shadow:var(--mst-shadow-sm);overflow:hidden;transition:transform .2s,box-shadow .2s}
.mst-card[hidden]{display:none}
.mst-menu .mst-card:hover{transform:translateY(-4px);box-shadow:var(--mst-shadow)}
.mst-menu .mst-card.is-featured{border-color:rgba(176,112,62,.55)}

.mst-menu .mst-card-media{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,#efe2d2,#d8b48f);display:grid;place-items:center;overflow:hidden}
.mst-menu .mst-card-media img{width:100%;height:100%;object-fit:cover;display:block}
.mst-menu .mst-ph .mst-ic{width:38px;height:38px;color:rgba(40,26,18,.42)}
.mst-menu .mst-flag{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;background:var(--mst-glass-strong);backdrop-filter:blur(8px);font-size:11.5px;font-weight:700;color:var(--mst-brand-dark);box-shadow:var(--mst-shadow-sm)}
.mst-menu .mst-flag .mst-ic{width:13px;height:13px;color:var(--mst-brand)}

.mst-menu .mst-card-body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:9px;flex:1}
.mst-menu .mst-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.mst-menu .mst-card-title{font-size:17px;font-weight:700;margin:0;line-height:1.3;color:var(--mst-ink)}
.mst-menu .mst-price{font-weight:700;font-size:15.5px;color:var(--mst-brand-dark);white-space:nowrap}
.mst-menu .mst-desc{font-size:13.5px;color:var(--mst-ink-soft);margin:0;flex:1}

.mst-menu .mst-allergens{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:2px}
.mst-menu .mst-allergens-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--mst-muted)}
.mst-menu .mst-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:rgba(120,100,80,.10);color:var(--mst-ink-soft)}

.mst-menu .mst-empty{padding:44px;text-align:center;color:var(--mst-muted);border:1px dashed var(--mst-line);border-radius:14px}
.mst-menu .mst-empty[hidden]{display:none}

@media(max-width:520px){
  .mst-menu .mst-grid{grid-template-columns:1fr}
  .mst-menu .mst-section-title{font-size:26px}
}
