/* Minimal mobile-first UI */
:root{ --bg:#0b1020; --fg:#e5e7eb; --muted:#9ca3af; --primary:#0ea5e9; --card:#111827; --danger:#ef4444; }
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--bg); color:var(--fg); font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial; }
.container{ max-width:920px; margin:0 auto; padding:16px; }

/* bordo appbar più soft */
.appbar{ position:sticky; top:0; z-index:10; background:#0b1228; border-bottom:1px solid #e5e7eb; padding:10px 16px; display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; gap:8px; align-items:center; font-weight:700; }

button{ background:#1f2937; color:var(--fg); border:none; border-radius:10px; padding:10px 14px; cursor:pointer; }
button.primary{ background:var(--primary); color:#001018; font-weight:700; }
button.danger{ background:var(--danger); color:#1a0b0b; font-weight:700; }
button.ghost{ background:transparent; border:1px solid #374151; }
button:disabled{ opacity:0.6; cursor:not-allowed; }

input, textarea{ width:100%; padding:10px 12px; border-radius:10px; border:1px solid #374151; background:#0b1228; color:var(--fg); }
label{ display:block; margin:10px 0 6px; color:#cbd5e1; }
.view.hidden{ display:none; }

/* CARD: bordo grigio chiaro */
.card{ background:var(--card); border:1px solid #e5e7eb; border-radius:14px; padding:14px; margin:10px 0; }

.grid-2{ display:grid; grid-template-columns:1fr; gap:12px; }
@media(min-width:720px){ .grid-2{ grid-template-columns:1fr 1fr; } }

.row{ display:flex; gap:10px; align-items:center; margin-top:12px; }
.row.wrap{ flex-wrap:wrap; }

/* LIST: bordo grigio chiaro di default */
.list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.list li{ background:#0b1228; border:1px solid #e5e7eb; border-radius:12px; padding:10px; display:flex; justify-content:space-between; align-items:center; gap:8px; }

/* “Attività di oggi” (salesList) visivo chiaro coerente con la ricerca */
#salesList li{
  background:#f3f4f6;
  color:#111;
  border:1px solid #e5e7eb;
}

/* testo secondario generico */
.muted{ color:var(--muted); }

/* toast con bordo soft */
.toast{ position:fixed; left:50%; transform:translateX(-50%); bottom:24px; background:#111827; border:1px solid #e5e7eb; padding:10px 14px; border-radius:12px; }
.toast.hidden{ display:none; }

/* tag & chip: bordo soft */
.tag-zone{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{ display:inline-flex; align-items:center; gap:8px; padding:6px 10px; background:#0b1228; border:1px solid #e5e7eb; border-radius:999px; }
.tag{ padding:6px 10px; border:1px solid #e5e7eb; border-radius:999px; cursor:pointer; }
.tag.active{ background:var(--primary); color:#001018; border-color:transparent; }

/* layout form compatto su desktop */
.form { max-width: 680px; }
.inp { width: 100%; max-width: 640px; }

/* assicura input bianchi e leggibili */
input, textarea {
  background: #fff;
  color: #0b1220;
}

/* bottone accanto all'input su desktop senza allargare tutto */
@media (min-width: 768px) {
  #otp-identifier { flex: 1 1 auto; }
}

/* stato invio + piccolo spinner */
.status { display: inline-flex; align-items: center; gap: 8px; margin: 8px 0; color:#0b1220; }
.status::before {
  content: "";
  width: 12px; height: 12px; border-radius: 50%;
  border: 2px solid currentColor; border-right-color: transparent;
  display:inline-block; animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Risultati ricerca cliente: sfondo grigio chiaro */
#sale-customer-results li {
  background: #f3f4f6;
  color: #111;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 12px 14px;
  margin: 8px 0;
}
#sale-customer-results li .muted { color: #6b7280; }
#sale-customer-results li:hover { background: #eef2f7; }
#sale-customer-results li button.secondary {
  background: #eef2f7;
  color: #111;
  border: 1px solid #e5e7eb;
}

/* Barra azioni della vendita */
.sale-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:12px;
}
.sale-actions .actions-right{
  display:flex;
  align-items:center;
  gap:8px;
}
#pointsPreview{
  font-weight:600;
  color:#0b6;
}

/* Mobile: manda a capo con ordine sensato */
@media (max-width: 520px){
  .sale-actions{ flex-wrap:wrap; }
  .sale-actions .actions-right{ width:100%; justify-content:flex-end; }
}

/* icon button chiara */
.icon-btn{
  background:#eef2f7; border:1px solid #e5e7eb; border-radius:10px;
  padding:6px 10px; font-size:16px; line-height:1; cursor:pointer;
}
.icon-btn:hover{ background:#e9eef5; }

/* posiziona l'Exit nell’angolo della card Home */
#home{ position: relative; }
.home-actions{
  position:absolute; top:12px; right:12px;
  display:flex; gap:8px; align-items:center;
}

/* Premi non disponibili (redeem) */
.reward-disabled{
  opacity: .55;
}
.reward-disabled button{
  opacity: .7;
  cursor: not-allowed;
}

/* CTA soft per la consegna premio */
button.danger-soft{
  background: #fee2e2;      /* rosso molto chiaro */
  color: #7f1d1d;           /* testo rosso scuro */
  border: 1px solid #fecaca;
  font-weight: 700;
}
button.danger-soft:hover{ background:#fecaca; }
button.danger-soft:active{ background:#fca5a5; }
button.danger-soft:focus{ outline:2px solid #fca5a5; outline-offset:2px; }

/* ===== Tabs (linguette) ===== */
.tabs{
  display:inline-flex;
  gap:2px;
  background:#eef2f7;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:2px;
  margin:8px 0 10px;
}
.tabs .tab{
  background:transparent;
  border:0;
  padding:8px 12px;
  border-radius:10px;
  font-weight:600;
  color:#374151;
  cursor:pointer;
}
.tabs .tab.active{
  background:#fff;
  color:#111;
  border:1px solid #e5e7eb;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.tabs .tab:focus-visible{ outline:2px solid var(--primary); outline-offset:2px; }

/* bottone soft per Consegna premio (già usato in setMode) */
button.danger-soft{
  background:#fee2e2; color:#7f1d1d; border:1px solid #fecaca; font-weight:700;
}
button.danger-soft:hover{ background:#fecaca; }
button.danger-soft:active{ background:#fca5a5; }
button.danger-soft:focus{ outline:2px solid #fca5a5; outline-offset:2px; }

/* === Rewards grid (stile card tipo Glide) === */
.rewards-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap:12px;
}

.reward-card{
  background:#f3f4f6;
  border:1px solid #e5e7eb;
  border-radius:12px;
  overflow:hidden;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .12s ease;
}
.reward-card:hover{ transform: translateY(-1px); box-shadow: 0 2px 10px rgba(0,0,0,.06); }

.reward-card.disabled{
  opacity:.45;
  filter: grayscale(.15);
  cursor:not-allowed;
}

.reward-card.selected{
  outline:2px solid var(--primary);
  box-shadow: 0 0 0 3px rgba(14,165,233,.25);
}

.reward-imgwrap{
  position:relative;
  width:100%;
  padding-top:75%; /* 4:3 */
  background:#e5e7eb;
}
.reward-imgwrap > img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; /* fill */
  display:block;
}

.reward-body{ padding:10px 12px; }
.reward-title{ font-weight:600; color:#111; }
.reward-points{ color:#6b7280; font-size:.92rem; }

/* testo saldo nel blocco premi */
#rewardsBlock .reward-balance{ margin-top:8px; color:#6b7280; }

/* Griglia card premi */
.rewards-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:12px;
}
@media (min-width: 740px){
  .rewards-grid{ grid-template-columns: repeat(3, 1fr); }
}

.reward-card{
  background:#f3f4f6;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:8px;
  text-align:left;
  cursor:pointer;
}
.reward-card[disabled]{ opacity:.55; cursor:not-allowed; }
.reward-card.selected{ outline:2px solid var(--primary); outline-offset:2px; }

/* 4:3, immagine “fill” */
.reward-card__img{
  width:100%;
  padding-top:75%;              /* 4:3 */
  background:#e5e7eb;
  background-size:cover;
  background-position:center;
  border-radius:10px;
}

/* Testi card */
.reward-card__title{
  font-weight:600; margin:8px 4px 2px;
  color:#111;
}
.reward-card__points{
  margin:0 4px 4px; font-size:.9rem;
  color:#6b7280;
}

/* Tag disabilitati (auto-esclusi o non applicabili): grigi, leggibili, non “sbiaditi” */
.tag:disabled,
.tag[disabled],
.tag.disabled,
.tag.not-applicable {
  background: #9ca3af;         /* grigio come negli esempi */
  color: #fff;                  /* testo leggibile */
  border-color: #9ca3af;        /* bordo uniforme */
  cursor: not-allowed;
  opacity: 1;                   /* sovrascrive button:disabled { opacity:.6 } */
  box-shadow: none;
}
.tag:disabled:hover,
.tag.disabled:hover,
.tag.not-applicable:hover {
  transform: none;
}

.badge {
  display:inline-block; padding:2px 8px; border-radius:999px;
  background:#111; color:#fff; font-size:12px;
}
.badge.soft { background:#e5e7eb; color:#111; }
.warn { color:#b45309; font-weight:600; }
.hidden { display:none !important; }

.spinner {
  width:28px; height:28px; border-radius:50%;
  border:3px solid #e5e7eb; border-top-color:#0b6;
  animation: sp 0.8s linear infinite; margin: 8px auto 6px;
}
@keyframes sp { to { transform: rotate(360deg); } }



/* ===== MODAL MODERNA (Close Day + Settings) ===== */

/* 1) Il contenitore <dialog> dev’essere “invisibile” */
dialog{
  border: 0;
  padding: 0;
  background: transparent;   /* << rimuove il rettangolo bianco spigoloso */
  outline: none;             /* niente contorno di focus */
}

/* Centra il contenuto quando il dialog è aperto */
#dlg-close-day[open],
#dlg-settings[open]{
  display: grid;
  place-items: center;
}

/* Overlay */
#dlg-close-day::backdrop,
#dlg-settings::backdrop{
  background: rgba(2,6,23,.45);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

/* 2) Il pannello interno: raggio + ombra + clipping agli angoli */
/* (override delle min/max inline nel form della chiusura) */
#dlg-close-day form,
#dlg-settings .dlg{
  width: clamp(340px, 92vw, 560px) !important;
  min-width: 0 !important;
  max-width: none !important;

  margin: 0;
  padding: 20px 22px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  overflow: hidden;          /* << taglia eventuali “sbordi” agli angoli */
  box-shadow:
    0 20px 50px rgba(0,0,0,.12),
    0  4px 12px rgba(0,0,0,.08);
  animation: modalIn .18s ease-out;
}

/* Titoli e testo tenue */
#dlg-close-day h3,
#dlg-settings h3{ margin: 0 0 8px; font-size: 1.1rem; }
#dlg-close-day p.muted,
#dlg-settings .muted{ color:#6b7280; }

/* Badge */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 8px; border-radius:999px; font-size:.85rem; font-weight:600;
  background:#0f172a; color:#fff;
}
.badge.soft{ background:#eef2f7; color:#0b1220; }

/* Bottoni “soft danger” (se usati) */
.btn.danger-soft{ background:#fee2e2; color:#991b1b; }
.btn.danger-soft:hover{ filter:brightness(.97); }

/* Spinner */
.spinner{
  width:24px; height:24px; border-radius:50%;
  border:3px solid #e5e7eb; border-top-color: var(--primary);
  margin: 10px auto;
  animation: spin .8s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

/* Footer azioni */
#dlg-close-day #btnCloseCancel,
#dlg-settings #settingsClose{ background:#eef2f7; color:#111; }
#dlg-close-day #btnCloseSend,
#dlg-settings #settingsSave{ background:var(--primary); color:#fff; }

/* Stato busy */
#dlg-close-day [data-state="busy"] p{ color:#6b7280; }

/* Ingresso */
@keyframes modalIn{
  from{ opacity:0; transform: translateY(6px) scale(.98); }
  to  { opacity:1; transform: none; }
}
