/* ==========================================================================
   Ostemio · Componenti UI del pannello ristoratore
   ========================================================================== */

/* ── bottone generico header (es. "Aggiungi") ── */
.ost-btn-header{
  font-size:12px;font-weight:500;
  background:var(--terra);color:var(--crema);
  border:none;border-radius:7px;
  height:28px;padding:0 12px;
  display:inline-flex;align-items:center;gap:4px;
  cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth),transform var(--dur-micro) var(--ease-spring);
}
.ost-btn-header:hover{background:var(--terra-l)}
.ost-btn-header:active{transform:scale(.95)}

/* ── stat grid (dashboard) ── */
.ost-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);padding:var(--sp-3) var(--sp-3) 0}
.ost-stat{background:var(--bg2);border-radius:var(--radius-md);padding:11px 12px;border:.5px solid var(--border)}
.ost-stat-lbl{font-size:9px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--txt3);display:block;margin-bottom:4px}
.ost-stat-val{font-size:24px;font-weight:600;color:var(--txt);line-height:1}
.ost-stat-sub{font-size:10px;font-weight:300;color:var(--txt3);margin-top:3px}
.ost-stat-trend{font-size:10px;font-weight:500;display:flex;align-items:center;gap:2px;margin-top:4px}
.ost-stat-trend.up{color:var(--s-ok)}
.ost-stat-trend.dn{color:var(--s-no)}

/* ── etichetta di sezione ── */
.ost-sec-lbl{
  font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--txt3);padding:var(--sp-3) var(--sp-3) var(--sp-2);
  display:flex;align-items:center;justify-content:space-between;
}
.ost-sec-action{font-size:11px;font-weight:500;color:var(--terra);letter-spacing:0;text-transform:none;text-decoration:none;cursor:pointer;background:none;border:none;padding:0}
.ost-sec-action:hover{color:var(--terra-l)}

/* ── chip di stato ── */
.ost-chip{font-size:10px;font-weight:500;padding:2px 8px;border-radius:99px;flex-shrink:0;transition:background var(--dur-medium) var(--ease-smooth),color var(--dur-medium) var(--ease-smooth)}
.ost-chip.chip-att{background:var(--s-warn-bg);color:var(--s-warn)}
.ost-chip.chip-ok{background:var(--s-ok-bg);color:var(--s-ok)}
.ost-chip.chip-no{background:var(--s-no-bg);color:var(--s-no)}
.ost-chip.chip-wait{background:var(--s-wait-bg);color:var(--s-wait)}

/* ── card prenotazione ── */
.ost-card-pren{
  margin:0 var(--sp-3) var(--sp-2);
  background:var(--bg3);border-radius:var(--radius-md);
  border:.5px solid var(--border);overflow:hidden;
  transition:opacity var(--dur-slow) var(--ease-smooth);
}
.ost-pren-head{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);border-bottom:.5px solid var(--border)}
.ost-pren-name{font-size:13px;font-weight:500;color:var(--txt)}
.ost-pren-phone{font-size:10px;color:var(--txt3)}
.ost-pren-body{padding:8px 12px}
.ost-pren-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--txt2);margin-bottom:4px}
.ost-pren-row:last-child{margin-bottom:0}
.ost-pren-row i{font-size:13px;color:var(--terra);flex-shrink:0}
.ost-pren-row.is-alert i{color:var(--s-no)}
.ost-pren-foot{padding:8px 12px;border-top:.5px solid var(--border);display:flex;gap:6px}

.ost-btn{
  flex:1;font-size:12px;font-weight:500;height:34px;
  border-radius:8px;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:5px;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth);
}
.ost-btn.btn-ok{background:var(--s-ok-bg);color:var(--s-ok)}
.ost-btn.btn-ok:hover{background:var(--s-ok);color:#fff}
.ost-btn.btn-no{background:var(--s-no-bg);color:var(--s-no)}
.ost-btn.btn-no:hover{background:var(--s-no);color:#fff}
.ost-btn.btn-ghost{background:var(--bg2);color:var(--txt2);border:.5px solid var(--border2)}
.ost-btn:disabled{opacity:.5;cursor:default}

/* ── filtro pillole (Prenotazioni) ── */
.ost-pill-row{display:flex;gap:6px;overflow-x:auto;padding:var(--sp-2) var(--sp-3);flex-shrink:0}
.ost-pill-row::-webkit-scrollbar{display:none}
.ost-pill{
  font-size:11px;font-weight:500;padding:5px 13px;border-radius:99px;
  background:transparent;color:var(--txt2);border:.5px solid var(--border2);
  white-space:nowrap;flex-shrink:0;cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth),border-color var(--dur-fast) var(--ease-smooth);
}
.ost-pill.is-active{background:var(--terra);color:var(--crema);border-color:var(--terra)}

/* ── gestione menù ── */
.ost-cat-row{display:flex;gap:6px;overflow-x:auto;padding:var(--sp-2) var(--sp-3);border-bottom:.5px solid var(--border);flex-shrink:0;background:var(--bg3)}
.ost-cat-row::-webkit-scrollbar{display:none}
.ost-cat-btn{
  font-size:11px;font-weight:500;padding:4px 12px;border-radius:99px;
  background:transparent;color:var(--txt2);border:.5px solid var(--border2);
  white-space:nowrap;flex-shrink:0;cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth),border-color var(--dur-fast) var(--ease-smooth);
}
.ost-cat-btn.is-active{background:var(--terra);color:var(--crema);border-color:var(--terra)}

.ost-menu-row{display:flex;align-items:center;gap:10px;padding:10px var(--sp-4);border-bottom:.5px solid var(--border);transition:opacity var(--dur-medium) var(--ease-smooth)}
.ost-menu-row:last-child{border-bottom:none}
.ost-menu-row.is-off{opacity:.5}
.ost-menu-icon{width:38px;height:38px;border-radius:8px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ost-menu-name{font-family:var(--pf);font-style:italic;font-size:13px;color:var(--txt);display:block;margin-bottom:2px}
.ost-menu-desc{font-size:10px;color:var(--txt3)}
.ost-menu-price{font-size:13px;font-weight:600;color:var(--terra);flex-shrink:0}
.ost-menu-chevron{font-size:15px;color:var(--txt3);margin-left:4px;flex-shrink:0}
.ost-menu-del{
  width:26px;height:26px;border-radius:7px;flex-shrink:0;margin-left:2px;
  border:none;background:transparent;color:var(--txt3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:15px;
  transition:background var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth);
}
.ost-menu-del:hover{background:var(--s-no-bg);color:var(--s-no)}

.ost-empty-msg{text-align:center;font-size:12px;color:var(--txt3);padding:var(--sp-8) var(--sp-4)}

/* ── sheet "aggiungi piatto" ── */
.ost-sheet-overlay{
  display:none;position:fixed;inset:0;z-index:50;
  background:rgba(28,20,16,.4);
  align-items:flex-end;justify-content:center;
}
.ost-sheet-overlay.is-open{display:flex}
.ost-sheet{
  width:100%;max-width:560px;background:var(--bg3);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  padding:var(--sp-4) var(--sp-4) calc(var(--sp-4) + var(--safe-bottom));
  max-height:88vh;overflow-y:auto;
}
.ost-sheet-title{font-size:14px;font-weight:600;color:var(--txt);margin-bottom:var(--sp-3)}
.ost-sheet-field{margin-bottom:var(--sp-3)}
.ost-sheet-label{display:block;font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--txt3);margin-bottom:5px}
.ost-sheet-input,.ost-sheet-select,.ost-sheet-textarea{
  width:100%;font-size:13px;font-family:var(--dm);color:var(--txt);
  background:var(--bg2);border:.5px solid var(--border2);border-radius:8px;
  padding:9px 11px;outline:none;
  transition:border-color var(--dur-fast) var(--ease-smooth),box-shadow var(--dur-fast) var(--ease-smooth);
}
.ost-sheet-input:focus,.ost-sheet-select:focus,.ost-sheet-textarea:focus{
  border-color:var(--terra);box-shadow:0 0 0 2px rgba(169,65,27,.1);
}
.ost-sheet-textarea{resize:none;min-height:54px}
.ost-sheet-error{font-size:11px;color:var(--s-no);margin-top:6px;display:none}
.ost-sheet-error.is-visible{display:block}
.ost-sheet-btns{display:flex;gap:8px;margin-top:var(--sp-2)}
.ost-sheet-btn{
  flex:1;font-size:12px;font-weight:500;height:38px;border-radius:8px;border:none;cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth),transform var(--dur-micro) var(--ease-spring);
}
.ost-sheet-btn.is-primary{background:var(--terra);color:var(--crema)}
.ost-sheet-btn.is-primary:hover{background:var(--terra-l)}
.ost-sheet-btn.is-ghost{background:var(--bg2);color:var(--txt2);border:.5px solid var(--border2)}
.ost-sheet-btn:active{transform:scale(.97)}
.ost-sheet-delete{
  width:100%;background:none;border:none;cursor:pointer;
  font-size:11px;font-weight:500;color:var(--s-no);text-align:center;
  margin-top:var(--sp-3);padding:4px;
}
.ost-sheet-delete:hover{text-decoration:underline}

/* ── toggle switch ── */
.ost-toggle{position:relative;width:34px;height:20px;flex-shrink:0;display:inline-block}
.ost-toggle input{opacity:0;width:0;height:0;position:absolute}
.ost-toggle-track{position:absolute;inset:0;background:rgba(28,20,16,.2);border-radius:99px;cursor:pointer;transition:background var(--dur-medium) var(--ease-smooth)}
.ost-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform var(--dur-medium) var(--ease-spring);box-shadow:0 1px 3px rgba(0,0,0,.15);pointer-events:none}
.ost-toggle input:checked~.ost-toggle-track{background:var(--terra)}
.ost-toggle input:checked~.ost-toggle-thumb{transform:translateX(14px)}

.ost-info-banner{
  display:flex;align-items:flex-start;gap:7px;
  background:var(--s-no-bg);border-radius:9px;padding:9px 12px;margin:var(--sp-2) var(--sp-4);
  border:.5px solid rgba(122,34,56,.12);
}
.ost-info-banner i{font-size:13px;color:var(--s-no);flex-shrink:0;margin-top:1px}
.ost-info-banner span{font-size:11px;color:var(--s-no);line-height:1.5}
.ost-info-banner.is-ok{background:var(--s-ok-bg);border-color:rgba(45,106,74,.15)}
.ost-info-banner.is-ok i,.ost-info-banner.is-ok span{color:var(--s-ok)}

/* ── Ostèmio chat ── */
.ost-quick-wrap{padding:var(--sp-2) var(--sp-3) 6px;border-bottom:.5px solid var(--border);flex-shrink:0}
.ost-quick-lbl{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);margin-bottom:6px}
.ost-quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ost-quick-btn{
  font-size:11px;font-weight:500;padding:7px 10px;border-radius:8px;
  border:.5px solid var(--border2);background:transparent;cursor:pointer;
  color:var(--txt2);text-align:left;display:flex;align-items:center;gap:6px;
  transition:background var(--dur-fast) var(--ease-smooth),border-color var(--dur-fast) var(--ease-smooth),color var(--dur-fast) var(--ease-smooth);
}
.ost-quick-btn:hover{background:rgba(169,65,27,.06);border-color:rgba(169,65,27,.2);color:var(--terra)}
.ost-quick-btn i{font-size:13px;color:var(--terra);flex-shrink:0}

.ost-chat-log{flex:1;min-height:0;padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2)}
.ost-msg{display:flex;gap:7px;align-items:flex-end}
.ost-msg.from-user{flex-direction:row-reverse}
.ost-bubble{font-size:12px;line-height:1.6;max-width:80%}
.ost-msg.from-agent .ost-bubble{background:var(--bg2);border-radius:11px 11px 11px 2px;padding:9px 11px;color:var(--txt)}
.ost-msg.from-user .ost-bubble{background:var(--terra);border-radius:11px 11px 2px 11px;padding:9px 11px;color:var(--crema)}
.ost-msg-avatar{flex-shrink:0}

.ost-action-card{background:var(--s-ok-bg);border-radius:var(--radius-md);padding:11px 13px;border:.5px solid rgba(45,106,74,.15);margin:0 var(--sp-3) var(--sp-2)}
.ost-action-title{font-size:11px;font-weight:500;color:var(--s-ok);margin-bottom:5px}
.ost-action-body{font-size:11px;color:var(--s-ok);margin-bottom:9px}
.ost-action-btns{display:flex;gap:6px}
.ost-action-btn{
  font-size:11px;font-weight:500;padding:5px 13px;border-radius:6px;border:none;cursor:pointer;
  transition:background var(--dur-fast) var(--ease-smooth);
}
.ost-action-btn.is-ok{background:var(--s-ok);color:#fff}
.ost-action-btn.is-ok:hover{background:#236040}
.ost-action-btn.is-ghost{background:rgba(45,106,74,.1);color:var(--s-ok)}

.ost-chat-input-bar{
  padding:10px 12px calc(10px + var(--safe-bottom));
  border-top:.5px solid var(--border);
  display:flex;gap:7px;flex-shrink:0;background:var(--bg3);
}
.ost-chat-input{
  flex:1;font-size:12px;background:var(--bg2);color:var(--txt);
  border:.5px solid var(--border2);border-radius:8px;padding:7px 11px;
  outline:none;transition:border-color var(--dur-fast) var(--ease-smooth),box-shadow var(--dur-fast) var(--ease-smooth);
}
.ost-chat-input:focus{border-color:var(--terra);box-shadow:0 0 0 2px rgba(169,65,27,.1)}
.ost-chat-send{
  width:34px;height:34px;border-radius:8px;background:var(--terra);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--crema);
  transition:background var(--dur-fast) var(--ease-smooth),transform var(--dur-micro) var(--ease-spring);
  flex-shrink:0;
}
.ost-chat-send:hover{background:var(--terra-l)}
.ost-chat-send:active{transform:scale(.92)}

.ost-status-dot{width:5px;height:5px;border-radius:50%;background:var(--s-ok);display:inline-block;flex-shrink:0}
.ost-status-line{font-size:10px;color:var(--s-ok);display:flex;align-items:center;gap:3px}
