/* ==========================================================================
   Ostemio · Menù QR (lato cliente)
   Pagina raggiunta scansionando il QR code al tavolo. Due varianti cromatiche
   selezionabili dal cliente (chiaro/scuro), stessa struttura testuale.
   Indipendente dal tema scelto dal ristoratore nel pannello: usa variabili
   --cm-* dedicate, ma riusa l'attributo data-theme-mode già previsto in
   base.css per il toggle automatico del wordmark/marchio chiaro/scuro.
   ========================================================================== */
:root{
  --cm-bg:#faf8f4;
  --cm-bg2:#ffffff;
  --cm-txt:#1c1410;
  --cm-txt2:#5a4a3a;
  --cm-txt3:#8a7a6a;
  --cm-border:rgba(28,20,16,.12);
}
html[data-theme-mode="scuro"]{
  --cm-bg:#1c1410;
  --cm-bg2:#241b15;
  --cm-txt:#f5edd8;
  --cm-txt2:#cbb89a;
  --cm-txt3:#a08f7a;
  --cm-border:rgba(245,237,216,.16);
}

body{background:var(--cm-bg)}

.cm-page{
  max-width:480px;margin-inline:auto;min-height:100dvh;
  display:flex;flex-direction:column;
  background:var(--cm-bg);color:var(--cm-txt);
  transition:background var(--dur-medium) var(--ease-smooth),color var(--dur-medium) var(--ease-smooth);
}

/* ── header ── */
.cm-header{
  padding:calc(var(--sp-5) + var(--safe-top)) var(--sp-4) var(--sp-4);
  text-align:center;position:relative;
}
.cm-theme-toggle{
  position:absolute;top:calc(var(--sp-3) + var(--safe-top));right:var(--sp-4);
  width:32px;height:32px;border-radius:50%;
  border:.5px solid var(--cm-border);background:var(--cm-bg2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--cm-txt3);font-size:15px;
  transition:color var(--dur-fast) var(--ease-smooth);
}
.cm-theme-toggle:hover{color:var(--terra)}
.cm-restaurant-name{
  font-size:26px;font-style:italic;color:var(--cm-txt);margin:0 0 10px;
}
.cm-table-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 13px;border-radius:99px;
  border:.5px solid var(--cm-border);
  font-size:11px;font-weight:500;color:var(--cm-txt2);
}
.cm-table-pill i{font-size:13px;color:var(--terra)}

/* ── striscia info secondaria ── */
.cm-info-strip{
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);
  padding:0 var(--sp-4) var(--sp-3);
  border-bottom:.5px solid var(--cm-border);
}
.cm-info-left{
  display:flex;align-items:center;gap:6px;
  font-size:10px;color:var(--cm-txt3);
}
.cm-info-left i{font-size:13px}
.cm-lang-toggle{display:flex;gap:4px;flex-shrink:0}
.cm-lang-btn{
  font-size:10px;font-weight:600;padding:4px 9px;border-radius:99px;
  border:.5px solid var(--cm-border);background:transparent;color:var(--cm-txt3);cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth);
}
.cm-lang-btn.is-active{background:var(--terra);color:var(--crema);border-color:var(--terra)}

/* ── filtro categorie ── */
.cm-cat-row{
  display:flex;gap:7px;overflow-x:auto;
  padding:var(--sp-3) var(--sp-4);
  border-bottom:.5px solid var(--cm-border);
  scrollbar-width:none;
}
.cm-cat-row::-webkit-scrollbar{display:none}
.cm-cat-pill{
  flex-shrink:0;font-size:11px;font-weight:500;padding:7px 14px;border-radius:99px;
  border:.5px solid var(--cm-border);background:transparent;color:var(--cm-txt2);cursor:pointer;
  white-space:nowrap;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth),border-color var(--dur-fast) var(--ease-smooth);
}
.cm-cat-pill.is-active{background:var(--terra);color:var(--crema);border-color:var(--terra)}

/* ── elenco piatti ── */
.cm-body{flex:1;padding:var(--sp-2) var(--sp-4) var(--sp-6)}
.cm-cat-section{margin-top:var(--sp-5)}
.cm-cat-section:first-child{margin-top:var(--sp-4)}
.cm-cat-label{
  font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--terra);margin-bottom:var(--sp-3);
}
.cm-dish-row{padding:10px 0;border-bottom:.5px solid var(--cm-border)}
.cm-cat-section .cm-dish-row:last-child{border-bottom:none}
.cm-dish-line{display:flex;align-items:baseline;gap:6px}
.cm-dish-name{font-size:14px;font-style:italic;color:var(--cm-txt);flex-shrink:0}
.cm-dish-leader{flex:1;border-bottom:1.5px dotted var(--cm-border);margin-bottom:4px}
.cm-dish-price{font-size:13px;font-weight:600;color:var(--terra);flex-shrink:0}
.cm-dish-desc{font-size:11px;font-style:italic;color:var(--cm-txt3);margin-top:3px;line-height:1.5}
.cm-empty{font-size:12px;color:var(--cm-txt3);text-align:center;padding:var(--sp-8) 0}

/* ── footer allergeni ── */
.cm-footnote{
  display:flex;gap:7px;align-items:flex-start;
  padding:var(--sp-3) var(--sp-4);
  border-top:.5px solid var(--cm-border);
  font-size:10px;line-height:1.6;color:var(--cm-txt3);
}
.cm-footnote i{font-size:13px;flex-shrink:0;margin-top:1px}

/* ── striscia brand ── */
.cm-brand-strip{
  display:flex;align-items:center;justify-content:center;gap:7px;
  padding:var(--sp-4) var(--sp-4) calc(var(--sp-5) + var(--safe-bottom));
  font-size:10px;color:var(--cm-txt3);
}
.cm-brand-mark{width:18px;height:18px;flex-shrink:0}

@media (min-width:560px){
  body{background:var(--bg2,#f5f3ef)}
  .cm-page{box-shadow:0 0 0 1px var(--cm-border),0 24px 64px rgba(28,20,16,.12)}
}
