/* =======================================================================
   LeoGrill Theme — warm artisan palette + dark mode
   Caricato DOPO site.css: override mirato, non rompe il layout.
   ======================================================================= */

/* UI compatta: base 13px (81.25%). Tutti i rem scalano proporzionalmente. */
html {
  font-size: 81.25%;
}

:root {
  /* Palette warm-artisan */
  --lg-primary: #c44536;        /* rust / terracotta */
  --lg-primary-600: #a83826;
  --lg-primary-700: #8a2b1d;
  --lg-secondary: #3d5a3c;      /* verde bosco */
  --lg-secondary-600: #2f4830;
  --lg-accent: #d4a54a;         /* ottone / mustard */
  --lg-accent-600: #b88830;
  --lg-success: #5a8a4f;        /* salvia */
  --lg-info: #6b8e7f;           /* salvia-teal */
  --lg-warning: #d4a54a;
  --lg-danger: #a83826;

  /* Surfaces (light) */
  --lg-bg: #faf6ee;             /* panna */
  --lg-surface: #ffffff;
  --lg-surface-2: #f2ecdf;
  --lg-surface-3: #e8dfcb;
  --lg-border: rgba(43, 38, 32, 0.10);
  --lg-border-strong: rgba(43, 38, 32, 0.18);

  /* Text */
  --lg-text: #2b2620;           /* caffè scuro */
  --lg-text-muted: #6b5f52;
  --lg-text-soft: #9d9081;

  /* Shadows — soft, warm */
  --lg-shadow-sm: 0 2px 6px rgba(43, 38, 32, 0.06);
  --lg-shadow-md: 0 8px 20px rgba(43, 38, 32, 0.08);
  --lg-shadow-lg: 0 20px 40px rgba(43, 38, 32, 0.10);

  /* Radii */
  --lg-radius-sm: 8px;
  --lg-radius: 12px;
  --lg-radius-lg: 18px;
  --lg-radius-xl: 24px;
  --lg-radius-pill: 999px;

  /* Typography */
  --lg-font-sans: "Plus Jakarta Sans", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --lg-font-display: "Fraunces", "Plus Jakarta Sans", Georgia, serif;

  /* Legacy alias — sono ancora usati da site.css/dashboards.css/admin-tenants.css */
  --kiosk-primary: var(--lg-primary);
  --kiosk-accent: var(--lg-accent);
  --kiosk-bg: var(--lg-bg);
  --kiosk-panel: var(--lg-surface);
  --kiosk-soft-border: var(--lg-border);

  /* Mantengo i vecchi nomi mk-* per non rompere theme previsto */
  --mk-text: var(--lg-text);
  --mk-text-muted: var(--lg-text-muted);
  --mk-border: var(--lg-border);
  --mk-surface: var(--lg-surface);
  --mk-surface-2: var(--lg-surface-2);
  --mk-primary: var(--lg-primary);
}

[data-theme="dark"] {
  --lg-bg: #1a1612;             /* off-black caldo */
  --lg-surface: #251f18;
  --lg-surface-2: #2e2720;
  --lg-surface-3: #3a332a;
  --lg-border: rgba(250, 246, 238, 0.08);
  --lg-border-strong: rgba(250, 246, 238, 0.18);

  --lg-text: #f5eddb;
  --lg-text-muted: #b8a890;
  --lg-text-soft: #8a7d6a;

  /* Accenti un filo più saturi su fondo scuro */
  --lg-primary: #d8564a;
  --lg-accent: #e0b560;
  --lg-success: #6fa45f;

  --lg-shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.4);
  --lg-shadow-md: 0 10px 28px rgba(0, 0, 0, 0.45);
  --lg-shadow-lg: 0 20px 50px rgba(0, 0, 0, 0.55);

  --kiosk-panel: var(--lg-surface);
  --kiosk-bg: var(--lg-bg);
  --kiosk-soft-border: var(--lg-border);
}

/* ===== Tipografia ===== */
html, body {
  font-family: var(--lg-font-sans);
  color: var(--lg-text);
}

body {
  background:
    radial-gradient(900px 500px at 110% -20%, rgba(196, 69, 54, 0.06), transparent 55%),
    radial-gradient(800px 500px at -10% 110%, rgba(61, 90, 60, 0.06), transparent 55%),
    linear-gradient(180deg, var(--lg-bg) 0%, var(--lg-surface-2) 100%) !important;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background-color .25s ease, color .25s ease;
}

[data-theme="dark"] body {
  background:
    radial-gradient(900px 500px at 110% -20%, rgba(216, 86, 74, 0.10), transparent 55%),
    radial-gradient(800px 500px at -10% 110%, rgba(111, 164, 95, 0.08), transparent 55%),
    linear-gradient(180deg, #1a1612 0%, #251f18 100%) !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--lg-font-sans);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--lg-text);
}

.display-1, .display-2, .display-3, .display-4, .display-5, .display-6,
.mk-display, .lg-display {
  font-family: var(--lg-font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--lg-text);
}

/* ===== Navbar ===== */
.kiosk-navbar {
  background: linear-gradient(180deg, #2b2620 0%, #1f1a14 100%) !important;
  border-bottom: 1px solid rgba(212, 165, 74, 0.18);
  box-shadow: 0 6px 18px rgba(43, 38, 32, 0.12);
  padding-top: .6rem;
  padding-bottom: .6rem;
}

[data-theme="dark"] .kiosk-navbar {
  background: linear-gradient(180deg, #14100c 0%, #1a1612 100%) !important;
}

.navbar-brand {
  display: inline-flex !important;
  align-items: center;
  gap: .65rem;
  font-family: var(--lg-font-display);
  font-weight: 700;
  letter-spacing: -0.01em;
  font-size: 1.35rem;
  color: #faf6ee !important;
}

.brand-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  flex-shrink: 0;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

.brand-logo img, .brand-logo svg { width: 100%; height: 100%; display: block; }

.brand-wordmark {
  color: #faf6ee;
}

.brand-wordmark .lg-accent { color: var(--lg-accent); }

/* ===== Buttons ===== */
.btn {
  border-radius: var(--lg-radius);
  font-weight: 600;
  letter-spacing: -0.005em;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, color .15s ease;
}

.btn:hover:not(:disabled):not(.disabled) {
  transform: translateY(-1px);
}

.btn-sm { border-radius: var(--lg-radius-sm); }
.btn-lg { border-radius: var(--lg-radius-lg); }

.btn-primary {
  background: var(--lg-primary);
  border: 1.5px solid var(--lg-primary);
  color: #fff;
  box-shadow: var(--lg-shadow-sm);
}
.btn-primary:hover:not(:disabled),
.btn-primary:focus:not(:disabled) {
  background: var(--lg-primary-600);
  border-color: var(--lg-primary-600);
  color: #fff;
  box-shadow: var(--lg-shadow-md);
}

.btn-success {
  background: var(--lg-success);
  border: 1.5px solid var(--lg-success);
  color: #fff;
}
.btn-success:hover:not(:disabled) { background: #456d3d; border-color: #456d3d; color: #fff; }

.btn-warning {
  background: var(--lg-accent);
  border: 1.5px solid var(--lg-accent);
  color: #2b2620;
  font-weight: 700;
}
.btn-warning:hover:not(:disabled) { background: var(--lg-accent-600); border-color: var(--lg-accent-600); color: #2b2620; }

.btn-info {
  background: var(--lg-info);
  border: 1.5px solid var(--lg-info);
  color: #fff;
}
.btn-info:hover:not(:disabled) { background: #56776a; border-color: #56776a; color: #fff; }

.btn-danger {
  background: var(--lg-danger);
  border: 1.5px solid var(--lg-danger);
  color: #fff;
}
.btn-danger:hover:not(:disabled) { background: var(--lg-primary-700); border-color: var(--lg-primary-700); color: #fff; }

.btn-secondary {
  background: #4a4236;
  border: 1.5px solid #4a4236;
  color: #faf6ee;
}
.btn-secondary:hover:not(:disabled) { background: #3a3329; border-color: #3a3329; color: #faf6ee; }

.btn-outline-secondary {
  border: 1.5px solid var(--lg-border-strong);
  color: var(--lg-text);
  background: transparent;
}
.btn-outline-secondary:hover:not(:disabled) {
  background: var(--lg-surface-2);
  border-color: var(--lg-text-muted);
  color: var(--lg-text);
}

/* Outline light (navbar pills) */
.kiosk-navbar .btn-outline-light {
  border: 1.5px solid rgba(250, 246, 238, 0.22);
  color: #faf6ee;
  background: rgba(250, 246, 238, 0.04);
  font-weight: 600;
}
.kiosk-navbar .btn-outline-light:hover {
  background: rgba(250, 246, 238, 0.12);
  border-color: rgba(250, 246, 238, 0.45);
  color: #faf6ee;
}

.kiosk-navbar .btn-outline-info {
  border: 1.5px solid rgba(107, 142, 127, 0.55);
  color: #a7c4b6;
  background: rgba(107, 142, 127, 0.08);
}
.kiosk-navbar .btn-outline-info:hover {
  background: rgba(107, 142, 127, 0.22);
  color: #faf6ee;
}

.kiosk-navbar .btn-warning {
  background: var(--lg-accent);
  color: #2b2620;
  box-shadow: 0 4px 12px rgba(212, 165, 74, 0.3);
}
.kiosk-navbar .btn-success {
  background: var(--lg-success);
  color: #fff;
  box-shadow: 0 4px 12px rgba(90, 138, 79, 0.25);
}
.kiosk-navbar .btn-info {
  background: var(--lg-info);
  color: #fff;
}
.kiosk-navbar .btn-danger {
  background: var(--lg-danger);
  color: #fff;
}

/* ===== Forms ===== */
.form-control, .form-select {
  border-radius: var(--lg-radius);
  border: 1.5px solid var(--lg-border);
  background: var(--lg-surface);
  color: var(--lg-text);
  padding: .6rem .9rem;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.form-control:focus, .form-select:focus {
  border-color: var(--lg-primary);
  box-shadow: 0 0 0 4px rgba(196, 69, 54, 0.14);
  background: var(--lg-surface);
  color: var(--lg-text);
}
.form-control::placeholder { color: var(--lg-text-soft); }

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background: var(--lg-surface-2);
  color: var(--lg-text);
  border-color: var(--lg-border);
}
[data-theme="dark"] .form-control::placeholder { color: var(--lg-text-soft); }

.form-label {
  font-weight: 700;
  font-size: .88rem;
  color: var(--lg-text-muted);
  letter-spacing: .01em;
}

/* ===== Cards ===== */
.card {
  border: 1px solid var(--lg-border);
  border-radius: var(--lg-radius-lg);
  background: var(--lg-surface);
  box-shadow: var(--lg-shadow-sm);
  color: var(--lg-text);
}

.card-header {
  background: transparent;
  border-bottom: 1px solid var(--lg-border);
  font-weight: 700;
}

.kiosk-card {
  background: var(--lg-surface) !important;
  border: 1px solid var(--lg-border);
  border-radius: var(--lg-radius-lg) !important;
  backdrop-filter: blur(10px);
}

[data-theme="dark"] .card,
[data-theme="dark"] .kiosk-card {
  background: var(--lg-surface);
  border-color: var(--lg-border);
  color: var(--lg-text);
}

/* ===== Tables ===== */
.table {
  color: var(--lg-text);
  --bs-table-bg: transparent;
  --bs-table-color: var(--lg-text);
  --bs-table-border-color: var(--lg-border);
}
.table > :not(caption) > * > * {
  background-color: transparent;
  color: var(--lg-text);
  border-bottom-color: var(--lg-border);
}
.table > thead { color: var(--lg-text-muted); }

.table-light {
  --bs-table-bg: var(--lg-surface-2);
  --bs-table-color: var(--lg-text);
}

[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(250, 246, 238, 0.03);
  color: var(--lg-text);
}
[data-theme="dark"] .table-hover > tbody > tr:hover > * {
  background-color: rgba(196, 69, 54, 0.08);
  color: var(--lg-text);
}

/* ===== Badges ===== */
.badge {
  font-weight: 700;
  letter-spacing: .01em;
  padding: .4em .7em;
  border-radius: var(--lg-radius-pill);
}
.badge.text-bg-light {
  background: var(--lg-surface-2) !important;
  color: var(--lg-text) !important;
  border: 1px solid var(--lg-border);
}
.badge.text-bg-primary {
  background: var(--lg-primary) !important;
  color: #fff !important;
}
.badge.text-bg-success {
  background: var(--lg-success) !important;
  color: #fff !important;
}
.badge.text-bg-warning {
  background: var(--lg-accent) !important;
  color: #2b2620 !important;
}
.badge.text-bg-danger {
  background: var(--lg-danger) !important;
  color: #fff !important;
}
.badge.text-bg-info {
  background: var(--lg-info) !important;
  color: #fff !important;
}

/* ===== Modal ===== */
.modal-content {
  border-radius: var(--lg-radius-xl);
  border: 1px solid var(--lg-border);
  background: var(--lg-surface);
  box-shadow: var(--lg-shadow-lg);
  color: var(--lg-text);
}
.modal-header, .modal-footer {
  border-color: var(--lg-border);
}

/* ===== Alerts ===== */
.alert {
  border-radius: var(--lg-radius);
  border: 1px solid var(--lg-border);
  font-weight: 600;
}
.alert-success { background: rgba(90, 138, 79, 0.1); color: #3c5f33; border-color: rgba(90, 138, 79, 0.28); }
.alert-warning { background: rgba(212, 165, 74, 0.12); color: #8a6a1f; border-color: rgba(212, 165, 74, 0.3); }
.alert-danger  { background: rgba(196, 69, 54, 0.09); color: #8a2b1d; border-color: rgba(196, 69, 54, 0.28); }
.alert-info    { background: rgba(107, 142, 127, 0.10); color: #3d5a4f; border-color: rgba(107, 142, 127, 0.3); }

[data-theme="dark"] .alert-success { color: #a7d29a; }
[data-theme="dark"] .alert-warning { color: #eacf8a; }
[data-theme="dark"] .alert-danger  { color: #eaa395; }
[data-theme="dark"] .alert-info    { color: #a7c4b6; }

/* ===== Scrollbar ===== */
* { scrollbar-width: thin; scrollbar-color: var(--lg-border-strong) transparent; }
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--lg-border-strong);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--lg-primary);
  background-clip: padding-box;
  border: 3px solid transparent;
}

/* ===== Theme toggle button ===== */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1.5px solid rgba(250, 246, 238, 0.22);
  background: rgba(250, 246, 238, 0.06);
  color: #faf6ee;
  font-size: 1.05rem;
  cursor: pointer;
  transition: background .18s ease, transform .25s ease, border-color .18s ease;
}
.theme-toggle:hover {
  background: rgba(250, 246, 238, 0.14);
  border-color: rgba(250, 246, 238, 0.5);
  transform: rotate(14deg) scale(1.05);
}
.theme-toggle .bi-sun-fill,
.theme-toggle .bi-moon-stars-fill { display: none; }
.theme-toggle .bi-moon-stars-fill { display: inline-block; }
[data-theme="dark"] .theme-toggle .bi-moon-stars-fill { display: none; }
[data-theme="dark"] .theme-toggle .bi-sun-fill { display: inline-block; color: var(--lg-accent); }

/* ===== Category filter pills ===== */
.category-filter {
  background: var(--lg-surface);
  border: 1.5px solid var(--lg-border);
  color: var(--lg-text);
  font-weight: 600;
  transition: all .15s ease;
}
.category-filter:hover {
  border-color: var(--lg-primary);
  color: var(--lg-primary);
}
.category-filter.active,
.category-filter.btn-primary {
  background: var(--lg-primary) !important;
  border-color: var(--lg-primary) !important;
  color: #fff !important;
  box-shadow: 0 4px 10px rgba(196, 69, 54, 0.24) !important;
}

/* ===== Product buttons ===== */
.product-button {
  border-radius: var(--lg-radius-lg) !important;
  box-shadow: var(--lg-shadow-md);
  border: 1px solid var(--lg-border);
}
.product-button:hover:not(:disabled):not(.is-sold-out) {
  box-shadow: var(--lg-shadow-lg), 0 0 0 2px rgba(196, 69, 54, 0.14);
}

/* ===== Dark mode fixes per componenti esistenti ===== */
[data-theme="dark"] .text-muted { color: var(--lg-text-muted) !important; }
[data-theme="dark"] .text-dark  { color: var(--lg-text) !important; }
[data-theme="dark"] .text-body  { color: var(--lg-text) !important; }
[data-theme="dark"] .text-secondary { color: var(--lg-text-muted) !important; }
[data-theme="dark"] .bg-light  { background-color: var(--lg-surface-2) !important; color: var(--lg-text); }
[data-theme="dark"] .bg-white  { background-color: var(--lg-surface) !important; color: var(--lg-text); }
[data-theme="dark"] .bg-body   { background-color: var(--lg-surface) !important; }

[data-theme="dark"] .cart-line,
[data-theme="dark"] .kitchen-item-row,
[data-theme="dark"] .supervision-stat-box,
[data-theme="dark"] .supervision-list-row,
[data-theme="dark"] .insight-card,
[data-theme="dark"] .product-insight {
  background: var(--lg-surface-2);
  border-color: var(--lg-border);
  color: var(--lg-text);
}

[data-theme="dark"] .kitchen-column-header,
[data-theme="dark"] .kitchen-empty-column,
[data-theme="dark"] .inventory-mini-pill,
[data-theme="dark"] .inventory-pill,
[data-theme="dark"] .preset-panel,
[data-theme="dark"] .operator-shortcuts,
[data-theme="dark"] .smart-suggestions-panel,
[data-theme="dark"] .smart-insight-pill,
[data-theme="dark"] .tenant-card {
  background: rgba(250, 246, 238, 0.02) !important;
  border-color: var(--lg-border) !important;
  color: var(--lg-text);
}

[data-theme="dark"] .inventory-mini-label,
[data-theme="dark"] .owner-kicker,
[data-theme="dark"] .tenant-admin-kicker {
  color: var(--lg-text-muted) !important;
}
[data-theme="dark"] .inventory-mini-value,
[data-theme="dark"] .inventory-mini-detail {
  color: var(--lg-text) !important;
}

[data-theme="dark"] .filter-bar {
  background: rgba(250, 246, 238, 0.03);
  border-color: var(--lg-border);
}

[data-theme="dark"] .panel-badge,
[data-theme="dark"] .receipt-pill {
  background: rgba(250, 246, 238, 0.08);
  color: var(--lg-text);
}

[data-theme="dark"] .summary-row .text-muted { color: var(--lg-text-muted) !important; }
[data-theme="dark"] .total-row {
  background: linear-gradient(135deg, rgba(196, 69, 54, 0.14), rgba(212, 165, 74, 0.14));
  color: var(--lg-text);
}
[data-theme="dark"] .change-row {
  border-color: var(--lg-border);
  color: var(--lg-text);
}

[data-theme="dark"] .kitchen-stat,
[data-theme="dark"] .supervision-metric {
  background: rgba(250, 246, 238, 0.03);
  border-color: var(--lg-border);
  color: var(--lg-text);
}

[data-theme="dark"] .operator-shortcut-btn.active,
[data-theme="dark"] .smart-suggestion-btn.active,
[data-theme="dark"] .top-rank,
[data-theme="dark"] .smart-suggestion-rank {
  background: var(--lg-primary) !important;
  border-color: var(--lg-primary) !important;
  color: #fff !important;
}

[data-theme="dark"] hr { border-color: var(--lg-border); opacity: 1; }

.dropdown-menu {
  border-radius: var(--lg-radius-lg);
  border: 1px solid var(--lg-border);
  box-shadow: var(--lg-shadow-lg);
  padding: .4rem;
  min-width: 220px;
  background: var(--lg-surface);
  color: var(--lg-text);
}
.dropdown-item {
  border-radius: var(--lg-radius);
  padding: .5rem .75rem;
  font-weight: 500;
  color: var(--lg-text);
  display: flex;
  align-items: center;
  gap: .55rem;
}
.dropdown-item > .bi { width: 1em; text-align: center; opacity: .85; }
.dropdown-item:hover,
.dropdown-item:focus {
  background: rgba(196, 69, 54, 0.10);
  color: var(--lg-primary);
}
.dropdown-item.active,
.dropdown-item:active {
  background: var(--lg-primary);
  color: #fff;
}
.dropdown-divider { border-color: var(--lg-border); margin: .35rem 0; }

.kiosk-navbar .dropdown-toggle::after {
  margin-left: .4rem;
  border-top-color: currentColor;
  opacity: .6;
}

[data-theme="dark"] .dropdown-menu {
  background: var(--lg-surface);
  border-color: var(--lg-border);
  color: var(--lg-text);
}
[data-theme="dark"] .dropdown-item { color: var(--lg-text); }
[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
  background: rgba(216, 86, 74, 0.16);
  color: var(--lg-primary);
}

[data-theme="dark"] .offcanvas {
  background: var(--lg-surface);
  color: var(--lg-text);
}

[data-theme="dark"] .btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
}

/* ===== Page entrance animation ===== */
main.container-fluid > * {
  animation: lgFadeIn .3s ease both;
}
@keyframes lgFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ===== Ribbon decorativo ===== */
.mk-ribbon,
.lg-ribbon {
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--lg-primary), var(--lg-accent), var(--lg-secondary));
}

/* ===== Navbar nav items ===== */
.kiosk-navbar .nav-actions {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  align-items: center;
}
.kiosk-navbar .nav-sep {
  width: 1px;
  height: 22px;
  background: rgba(250, 246, 238, 0.16);
  margin: 0 .3rem;
}
@media (max-width: 991.98px) {
  .kiosk-navbar .nav-actions { display: none; }
}

.mk-offcanvas .btn {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  padding: .8rem 1rem;
  border-radius: var(--lg-radius);
  font-weight: 600;
}

/* Dashboard tokens — raffresca gradienti con palette sobria */
.dash-primary { background: linear-gradient(135deg, #c44536, #8a2b1d) !important; }
.dash-success { background: linear-gradient(135deg, #5a8a4f, #3d5a3c) !important; }
.dash-purple  { background: linear-gradient(135deg, #7a5c3a, #4a3929) !important; }
.dash-warning { background: linear-gradient(135deg, #d4a54a, #b88830) !important; }
.stat-primary { background: linear-gradient(135deg, #c44536, #8a2b1d) !important; }
.stat-success { background: linear-gradient(135deg, #5a8a4f, #3d5a3c) !important; }
.stat-dark    { background: linear-gradient(135deg, #3a3329, #1f1a14) !important; }

/* Kitchen cards — colori stato coerenti */
.kitchen-order-card.Pending        { border-left-color: var(--lg-info) !important; }
.kitchen-order-card.InPreparation  { border-left-color: var(--lg-accent) !important; }
.kitchen-order-card.Ready          { border-left-color: var(--lg-success) !important; }

/* Link color */
a { color: var(--lg-primary); text-decoration-color: rgba(196, 69, 54, 0.35); }
a:hover { color: var(--lg-primary-700); }
[data-theme="dark"] a { color: #e28a7a; }
[data-theme="dark"] a:hover { color: #f0a598; }

/* Focus ring accessibile */
:focus-visible {
  outline: 2px solid var(--lg-primary);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Utility */
.lg-text-gradient,
.mk-text-gradient {
  background: linear-gradient(135deg, var(--lg-primary) 0%, var(--lg-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Product button sold-out override per coerenza */
.product-button.is-sold-out::after {
  background: rgba(43, 38, 32, 0.92);
  color: #faf6ee;
}

/* ===== Inventory pills fissate in basso a sinistra ===== */
#inventorySummaryCompact {
  position: fixed;
  left: 1rem;
  bottom: 1rem;
  z-index: 40;
  margin: 0 !important;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  max-width: calc(100vw - 2rem);
  pointer-events: none;
}

#inventorySummaryCompact .inventory-mini-pill {
  min-width: 0 !important;
  max-width: none !important;
  padding: .55rem .8rem !important;
  background: var(--lg-surface) !important;
  border: 1px solid var(--lg-border) !important;
  box-shadow: var(--lg-shadow-md) !important;
  pointer-events: auto;
  display: inline-flex;
  flex-direction: column;
  gap: .12rem;
}

#inventorySummaryCompact .inventory-mini-label,
#inventorySummaryCompact .inventory-mini-value,
#inventorySummaryCompact .inventory-mini-detail {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(42ch, calc(100vw - 4rem));
  display: block;
}

#inventorySummaryCompact .inventory-mini-value {
  font-size: 1.35rem;
  line-height: 1;
  font-weight: 800;
}

[data-theme="dark"] #inventorySummaryCompact .inventory-mini-pill {
  background: var(--lg-surface) !important;
  border-color: var(--lg-border) !important;
}

body.stress-mode #inventorySummaryCompact { display: none !important; }

@media (max-width: 575.98px) {
  #inventorySummaryCompact { left: .5rem; bottom: .5rem; }
  #inventorySummaryCompact .inventory-mini-pill { padding: .45rem .65rem !important; }
  #inventorySummaryCompact .inventory-mini-value { font-size: 1.15rem; }
}

/* ===== Toast fluttuanti ===== */
.lg-toast-container {
  position: fixed;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1055;
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  gap: .5rem;
  pointer-events: none;
  max-width: 420px;
  width: max-content;
}
.lg-toast {
  background: var(--lg-surface);
  border: 1px solid var(--lg-border);
  border-left: 4px solid var(--lg-primary);
  border-radius: var(--lg-radius);
  box-shadow: var(--lg-shadow-lg);
  padding: .6rem .75rem .6rem .85rem;
  display: flex;
  align-items: center;
  gap: .6rem;
  pointer-events: auto;
  min-width: 240px;
  transform: translateY(14px);
  opacity: 0;
  transition: transform .22s ease, opacity .22s ease;
}
.lg-toast.is-visible { transform: translateY(0); opacity: 1; }
.lg-toast.is-leaving { transform: translateY(14px); opacity: 0; }
.lg-toast-icon { font-size: 1.15rem; flex-shrink: 0; }
.lg-toast-msg { flex: 1; font-weight: 600; font-size: .92rem; color: var(--lg-text); line-height: 1.25; }
.lg-toast-action {
  background: none;
  border: 0;
  color: var(--lg-primary);
  font-weight: 700;
  padding: 0 .25rem;
  cursor: pointer;
  text-decoration: underline;
}
.lg-toast-action:hover { color: var(--lg-primary-700); }
.lg-toast-close {
  background: none;
  border: 0;
  color: var(--lg-text-muted);
  font-size: 1.35rem;
  line-height: 1;
  padding: 0 .25rem;
  cursor: pointer;
}
.lg-toast-close:hover { color: var(--lg-text); }

.lg-toast-success { border-left-color: var(--lg-success); }
.lg-toast-success .lg-toast-icon { color: var(--lg-success); }
.lg-toast-danger { border-left-color: var(--lg-danger); }
.lg-toast-danger .lg-toast-icon { color: var(--lg-danger); }
.lg-toast-warning { border-left-color: var(--lg-warning); }
.lg-toast-warning .lg-toast-icon { color: var(--lg-warning); }
.lg-toast-secondary { border-left-color: var(--lg-text-muted); }
.lg-toast-secondary .lg-toast-icon { color: var(--lg-text-muted); }

@media (max-width: 575.98px) {
  .lg-toast-container { bottom: .75rem; left: .5rem; right: .5rem; transform: none; max-width: none; width: auto; }
  .lg-toast { min-width: 0; }
}

/* ===== Titoli compatti delle card della colonna suggeriti ===== */
.suggestions-zone-title {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 800;
  color: var(--lg-text-muted);
  display: flex;
  align-items: center;
}
[data-theme="dark"] .suggestions-zone-title { color: var(--lg-text-muted); }

/* ===== Product button più compatto per grid denser ===== */
.product-button {
  min-height: 112px !important;
  padding: .75rem .55rem !important;
  font-size: .9rem !important;
}
.product-button .fs-2 { font-size: 1.1rem !important; }
.product-button .product-title {
  min-height: auto !important;
  font-size: .92rem !important;
  line-height: 1.15;
}
.product-button .small.opacity-75 {
  font-size: .72rem !important;
  line-height: 1;
}
.product-button .badge {
  font-size: .72rem !important;
  padding: .25em .55em !important;
}
.product-button .mt-2 { margin-top: .35rem !important; }
.product-button .mb-2 { margin-bottom: .25rem !important; }

/* ===== POS 3-colonne: prodotti | suggeriti | scontrino ===== */
.suggestions-zone {
  min-width: 0;
  position: sticky;
  top: 1rem;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.suggestions-zone .preset-panel,
.suggestions-zone .smart-suggestions-panel {
  padding: .85rem 1rem;
  border: 1px solid var(--lg-border);
  border-radius: var(--lg-radius-lg);
  background: var(--lg-surface);
  margin: 0;
}

[data-theme="dark"] .suggestions-zone .preset-panel,
[data-theme="dark"] .suggestions-zone .smart-suggestions-panel {
  background: var(--lg-surface);
  border-color: var(--lg-border);
}

/* Preset: bottoni stackati full-width nella colonna stretta */
.suggestions-zone .preset-panel .preset-button {
  width: 100%;
  min-width: 0;
  justify-content: flex-start;
  text-align: left;
  padding: .7rem .9rem;
  font-size: .95rem;
  border-radius: var(--lg-radius);
  box-shadow: none;
}

/* Suggeriti: pillole stackate in verticale che riempiono la colonna */
.suggestions-zone #smartInsightsList,
.suggestions-zone #smartSuggestionsList {
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
}

.suggestions-zone .smart-insight-pill,
.suggestions-zone .smart-suggestion-btn {
  min-width: 0 !important;
  width: 100% !important;
  text-align: left;
}

.suggestions-zone .smart-suggestion-btn {
  padding: .7rem .85rem .7rem 2.6rem;
}

.suggestions-zone .smart-suggestion-rank {
  left: .7rem;
}

.suggestions-zone .smart-suggestion-title {
  font-size: .95rem;
}
.suggestions-zone .smart-suggestion-subtitle,
.suggestions-zone .smart-insight-subtitle {
  font-size: .82rem;
  line-height: 1.25;
}

/* Desktop ≥1200px: 3 colonne */
@media (min-width: 1200px) {
  .kiosk-main-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 260px) var(--lg-checkout-width, 380px) !important;
    gap: 1rem;
    align-items: start;
  }
  .kiosk-main-row > .product-zone,
  .kiosk-main-row > .suggestions-zone,
  .kiosk-main-row > .checkout-zone {
    min-width: 0;
    width: auto !important;
    max-width: none !important;
    flex: none !important;
  }
}

/* Sotto 1200px: stack (suggeriti sopra lo scontrino) */
@media (max-width: 1199.98px) {
  .suggestions-zone { order: 2; margin-top: 1rem; }
  .checkout-zone { order: 3; }
  .suggestions-zone .smart-suggestions-panel { position: static; }
  .suggestions-zone #smartInsightsList,
  .suggestions-zone #smartSuggestionsList {
    flex-direction: row !important;
    flex-wrap: wrap !important;
  }
  .suggestions-zone .smart-insight-pill,
  .suggestions-zone .smart-suggestion-btn {
    width: auto !important;
    min-width: 200px !important;
  }
}

/* ===== POS header (two-row, predictable layout) ===== */
.pos-header {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-bottom: 1.1rem;
}

.pos-header-row {
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-wrap: wrap;
}

.pos-header-row-tools .search-box.pos-search {
  flex: 1 1 260px;
}

.pos-header .pos-title {
  font-size: 1.55rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.1;
  margin: 0;
  white-space: nowrap;
}

.pos-header-spacer {
  flex: 1 1 auto;
  min-width: 0;
}

.pos-header .search-box.pos-search {
  flex: 1 1 220px;
  min-width: 180px;
  max-width: 420px;
  position: relative;
  margin: 0;
}
.pos-header .search-box.pos-search input {
  padding-left: 2.5rem;
  min-height: 42px;
  font-size: 1rem;
  border-radius: var(--lg-radius);
}
.pos-header .search-box.pos-search i {
  position: absolute;
  top: 50%;
  left: .85rem;
  transform: translateY(-50%);
  color: var(--lg-text-muted);
}

.pos-header .pos-operator-input {
  flex: 0 0 auto;
  width: 150px;
  min-height: 42px;
  font-size: 1rem;
  border-radius: var(--lg-radius);
}

.pos-header .pos-toolbar-btn {
  min-height: 42px;
  padding: .45rem 1rem;
  border-radius: var(--lg-radius);
  font-weight: 700;
  font-size: .95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
}

.pos-header .cassa-sync-badge,
.pos-header .stress-badge {
  font-size: .72rem;
  padding: .35em .6em;
  letter-spacing: .02em;
}

.operator-shortcuts-inline {
  display: inline-flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-left: auto;
}

.operator-shortcuts-inline .operator-shortcut-btn {
  padding: .25rem .7rem;
  font-size: .82rem;
  min-height: 30px;
  border-radius: var(--lg-radius-pill);
  font-weight: 600;
}

.operator-shortcuts-inline .operator-shortcut-btn.active {
  background-color: var(--bs-primary, #0d6efd);
  color: #fff;
  border-color: var(--bs-primary, #0d6efd);
}

@media (max-width: 991.98px) {
  .pos-header .pos-title { font-size: 1.2rem; }
  .pos-header .search-box.pos-search { flex-basis: 100%; max-width: none; }
  .pos-header .pos-operator-input { flex: 1 1 120px; width: auto; }
  .operator-shortcuts-inline { margin-left: 0; }
}

/* ===== Scontrino compatto ===== */
.checkout-primary .total-row {
  background: linear-gradient(135deg, rgba(196, 69, 54, 0.12), rgba(212, 165, 74, 0.12));
  padding: .6rem .9rem;
  border-radius: var(--lg-radius);
  margin: 0;
}
[data-theme="dark"] .checkout-primary .total-row {
  background: linear-gradient(135deg, rgba(216, 86, 74, 0.18), rgba(224, 181, 96, 0.14));
}
.checkout-primary .checkout-main-btn {
  min-height: 54px;
  font-weight: 700;
}

.cart-items-compact {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  max-height: 42vh;
  overflow-y: auto;
  padding-right: .25rem;
}

.cart-items-compact .cart-line {
  padding: .5rem .65rem;
  margin: 0;
  border-radius: var(--lg-radius);
  background: var(--lg-surface-2);
  border: 1px solid var(--lg-border);
}
[data-theme="dark"] .cart-items-compact .cart-line {
  background: rgba(250, 246, 238, 0.04);
}

.cart-line-main {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: .5rem;
  min-width: 0;
}
.cart-line-info { min-width: 0; flex: 1; }
.cart-line-name {
  font-weight: 600;
  font-size: .95rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cart-line-unit {
  font-size: .76rem;
  color: var(--lg-text-muted);
  line-height: 1.2;
  margin-top: .1rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cart-line-variants { color: var(--lg-primary); font-weight: 600; }
.cart-line-total {
  font-weight: 700;
  font-size: .98rem;
  white-space: nowrap;
}
.cart-line-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .4rem;
  margin-top: .35rem;
}
.cart-items-compact .cart-line .quantity-box {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}
.cart-items-compact .cart-line .qty-btn {
  width: 30px !important;
  height: 30px !important;
  min-height: 0 !important;
  padding: 0 !important;
  border-radius: 999px !important;
  font-size: .85rem !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cart-items-compact .cart-line .quantity-value {
  min-width: 22px;
  text-align: center;
  font-weight: 700;
  font-size: .95rem;
}
.cart-line-tools {
  display: inline-flex;
  gap: .3rem;
}
.cart-items-compact .cart-line .cart-line-tools .btn {
  padding: .2rem .5rem !important;
  min-height: 30px !important;
  font-size: .85rem !important;
  border-radius: var(--lg-radius) !important;
  min-width: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Scrollbar del cart compatta */
.cart-items-compact::-webkit-scrollbar { width: 6px; }

/* Keypad toggle */
#toggleKeypadBtn {
  font-size: .82rem;
  color: var(--lg-text-muted);
}
#toggleKeypadBtn:hover { color: var(--lg-primary); }
#toggleKeypadBtn[aria-expanded="true"] { color: var(--lg-primary); }

body.stress-mode .cart-items-compact { max-height: 36vh; }

/* ===== Barra di stato operativa ===== */
.ops-status-strip {
  background: linear-gradient(180deg, var(--lg-surface-2), var(--lg-surface-3));
  border-bottom: 1px solid var(--lg-border);
  padding: .4rem .5rem;
  font-size: .82rem;
}
[data-theme="dark"] .ops-status-strip {
  background: rgba(255,255,255,.03);
  border-bottom-color: rgba(255,255,255,.08);
}

.ops-status-strip .ops-stat {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .15rem .55rem;
  border-radius: var(--lg-radius-pill);
  background: rgba(0,0,0,.05);
  color: var(--lg-text);
  font-weight: 600;
  white-space: nowrap;
}
[data-theme="dark"] .ops-status-strip .ops-stat {
  background: rgba(255,255,255,.06);
  color: var(--lg-text);
}

.ops-status-strip .ops-stat.is-warn {
  background: rgba(212,165,74,.22);
  color: var(--lg-primary-700);
}
.ops-status-strip .ops-stat.is-danger {
  background: rgba(196,69,54,.18);
  color: var(--lg-primary-700);
}
.ops-status-strip .ops-stat.is-ok {
  background: rgba(90,138,79,.2);
  color: var(--lg-secondary-600);
}
[data-theme="dark"] .ops-status-strip .ops-stat.is-ok { color: #bfe0a8; }
[data-theme="dark"] .ops-status-strip .ops-stat.is-warn { color: #f5d59a; }
[data-theme="dark"] .ops-status-strip .ops-stat.is-danger { color: #f4b9b0; }

.ops-status-strip .ops-stat i { font-size: .95rem; }

.ops-status-strip .ops-action {
  font-weight: 600;
  border-color: rgba(43,38,32,.25);
  color: var(--lg-text);
}
.ops-status-strip .ops-action:hover { background: rgba(0,0,0,.06); color: var(--lg-text); }
[data-theme="dark"] .ops-status-strip .ops-action {
  border-color: rgba(255,255,255,.25);
  color: #f0ece4;
}
[data-theme="dark"] .ops-status-strip .ops-action:hover { background: rgba(255,255,255,.08); }

/* Last orders modal rows */
.last-order-row {
  border: 1px solid var(--lg-border);
  border-radius: var(--lg-radius);
  padding: .6rem .75rem;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  background: var(--lg-surface);
}
.last-order-row.is-cancelled { opacity: .55; text-decoration: line-through; }
.last-order-row .lo-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
}
.last-order-row .lo-title { font-weight: 700; }
.last-order-row .lo-meta { font-size: .78rem; color: var(--lg-text-muted); }
.last-order-row .lo-total { font-weight: 800; font-size: 1.05rem; }
.last-order-row .lo-actions { display: flex; gap: .4rem; flex-wrap: wrap; }
.last-order-row .lo-cancel-form {
  display: none;
  gap: .4rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: .25rem;
}
.last-order-row .lo-cancel-form.is-open { display: flex; }
.last-order-row .lo-cancel-form input[type="password"] {
  width: 110px;
  min-height: 32px;
  padding: .2rem .5rem;
  border-radius: var(--lg-radius-sm);
  border: 1px solid var(--lg-border-strong);
  font-weight: 700;
  letter-spacing: .2em;
}

/* Checkout zone resizer (drag handle) */
.checkout-zone { position: relative; }

/* Scontrino "sempre pronto": sticky su desktop */
@media (min-width: 1200px) {
  .sticky-top-cart {
    position: sticky;
    top: .75rem;
    max-height: calc(100vh - 1.5rem);
    display: flex;
    flex-direction: column;
  }
  .sticky-top-cart > .card-body {
    overflow-y: auto;
    flex: 1 1 auto;
  }
}

/* Totale e Resto "a occhio": numeri grandi */
.checkout-primary .total-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.checkout-primary .total-row #cartTotal {
  font-size: 2.1rem;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1;
}
.change-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.change-row #changeAmount {
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: -.01em;
}

/* Hint shortcut sotto il bottone contanti esatti */
.kbd-hint {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .72rem;
  opacity: .75;
  font-weight: 500;
}
.kbd-hint kbd {
  background: rgba(0,0,0,.18);
  color: inherit;
  border-radius: 4px;
  padding: .05rem .35rem;
  font-family: inherit;
  font-weight: 700;
  font-size: .68rem;
}

.checkout-resizer {
  position: absolute;
  left: -8px;
  top: 0;
  bottom: 0;
  width: 16px;
  cursor: ew-resize;
  z-index: 30;
  display: none;
  touch-action: none;
  background: transparent;
}
.checkout-resizer::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 64px;
  border-radius: 999px;
  background: var(--lg-border-strong);
  transition: background .18s ease, height .18s ease, width .18s ease;
}
.checkout-resizer:hover::before,
.checkout-resizer.is-dragging::before {
  background: var(--lg-primary);
  height: 96px;
  width: 4px;
}

@media (min-width: 1200px) {
  .checkout-resizer { display: block; }
}

body.resizing-checkout {
  cursor: ew-resize !important;
  user-select: none !important;
}
body.resizing-checkout * { cursor: ew-resize !important; }

/* Stress mode: nascondo la colonna per massima pulizia */
body.stress-mode .suggestions-zone { display: none !important; }
body.stress-mode .checkout-resizer { display: none !important; }
body.stress-mode .kiosk-main-row {
  grid-template-columns: minmax(0, 1.58fr) minmax(420px, .98fr) !important;
}

/* ===== Mascot hero (Public landing) ===== */
.lg-mascot-stage {
  position: relative;
  aspect-ratio: 1 / 1;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lg-mascot-stage::before {
  content: "";
  position: absolute;
  inset: 10% 10% 10% 10%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(212, 165, 74, 0.35), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(196, 69, 54, 0.22), transparent 60%),
    radial-gradient(circle, rgba(250, 246, 238, 0.95), rgba(250, 246, 238, 0.4) 60%, transparent 100%);
  filter: blur(18px);
  z-index: 0;
}

[data-theme="dark"] .lg-mascot-stage::before {
  background:
    radial-gradient(circle at 30% 30%, rgba(224, 181, 96, 0.28), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(216, 86, 74, 0.24), transparent 60%),
    radial-gradient(circle, rgba(37, 31, 24, 0.85), rgba(37, 31, 24, 0.3) 60%, transparent 100%);
}

.lg-mascot-art {
  position: relative;
  z-index: 1;
  width: 92%;
  max-width: 460px;
  height: auto;
  display: block;
  filter: drop-shadow(0 18px 28px rgba(43, 38, 32, 0.25));
  animation: lgMascotFloat 6s ease-in-out infinite;
}

@keyframes lgMascotFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}

.lg-mascot-badge {
  position: absolute;
  z-index: 2;
  background: var(--lg-surface);
  border: 1px solid var(--lg-border);
  border-radius: var(--lg-radius-lg);
  padding: .85rem 1rem;
  box-shadow: var(--lg-shadow-lg);
  min-width: 190px;
  color: var(--lg-text);
}

.lg-mascot-badge-top {
  top: 4%;
  right: -2%;
  animation: lgBadgeFloat1 7s ease-in-out infinite;
}

.lg-mascot-badge-bottom {
  bottom: 6%;
  left: -4%;
  animation: lgBadgeFloat2 8s ease-in-out infinite;
}

@keyframes lgBadgeFloat1 {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
@keyframes lgBadgeFloat2 {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(6px); }
}

@media (max-width: 1199.98px) {
  .lg-mascot-stage { max-width: 420px; }
  .lg-mascot-badge-top { right: 2%; }
  .lg-mascot-badge-bottom { left: 2%; }
}

@media (max-width: 575.98px) {
  .lg-mascot-badge { min-width: 150px; padding: .6rem .75rem; font-size: .88rem; }
}

/* ===== Login mascot ===== */
.lg-login-mascot {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(212, 165, 74, 0.25), transparent 60%),
    radial-gradient(circle, var(--lg-surface-2), var(--lg-surface));
  border: 1px solid var(--lg-border);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--lg-shadow-md);
  animation: lgMascotFloat 5s ease-in-out infinite;
}

.lg-login-mascot img {
  width: 92%;
  height: 92%;
  filter: drop-shadow(0 8px 12px rgba(43, 38, 32, 0.2));
}

/* ── Compact inventory pills inside the ops-status-strip ─────────────────── */
.ops-inventory-pills {
  margin-left: .25rem;
  padding-left: .5rem;
  border-left: 1px solid rgba(0, 0, 0, .1);
}
[data-theme="dark"] .ops-inventory-pills {
  border-left-color: rgba(255, 255, 255, .1);
}

.ops-inv-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .12rem .55rem;
  border-radius: var(--lg-radius-pill);
  font-size: .72rem;
  font-weight: 600;
  white-space: nowrap;
  cursor: help;
  background: rgba(0, 0, 0, .04);
  color: var(--lg-text-muted);
  border: 1px solid transparent;
  transition: background .15s ease, color .15s ease;
}
.ops-inv-pill:hover {
  background: rgba(0, 0, 0, .08);
}
[data-theme="dark"] .ops-inv-pill {
  background: rgba(255, 255, 255, .05);
  color: var(--lg-text-muted);
}
[data-theme="dark"] .ops-inv-pill:hover {
  background: rgba(255, 255, 255, .1);
}

.ops-inv-pill .ops-inv-pill-cat {
  text-transform: uppercase;
  letter-spacing: .04em;
  opacity: .8;
  font-size: .68rem;
}
.ops-inv-pill .ops-inv-pill-num {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--lg-text);
}

.ops-inv-pill.is-warn {
  background: rgba(212, 165, 74, .18);
  color: var(--lg-primary-700);
  border-color: rgba(212, 165, 74, .3);
}
.ops-inv-pill.is-warn .ops-inv-pill-num { color: var(--lg-primary-700); }

.ops-inv-pill.is-empty {
  background: rgba(196, 69, 54, .14);
  color: var(--lg-primary);
  border-color: rgba(196, 69, 54, .25);
}
.ops-inv-pill.is-empty .ops-inv-pill-num { color: var(--lg-primary); }

.ops-inv-pill.is-ok .ops-inv-pill-num { color: var(--lg-secondary, var(--lg-text)); }

@media (max-width: 767.98px) {
  .ops-inventory-pills {
    border-left: 0;
    padding-left: 0;
    margin-left: 0;
    width: 100%;
  }
  .ops-inv-pill { font-size: .68rem; padding: .1rem .45rem; }
}

/* ── Popover dettaglio scorte (al hover/focus della pill) ────────────────── */
.ops-inv-pill {
  position: relative;
}

.ops-inv-popover {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 240px;
  max-width: 320px;
  background: #fff;
  color: var(--lg-text);
  border-radius: 12px;
  box-shadow: 0 14px 40px rgba(43, 38, 32, .18), 0 0 0 1px rgba(43, 38, 32, .06);
  padding: 12px 14px;
  font-weight: 500;
  font-size: .82rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
  z-index: 1050;
  cursor: default;
}
[data-theme="dark"] .ops-inv-popover {
  background: #1d2530;
  color: #f0e9dd;
  box-shadow: 0 14px 40px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .08);
}

.ops-inv-pill:hover > .ops-inv-popover,
.ops-inv-pill:focus > .ops-inv-popover,
.ops-inv-pill:focus-within > .ops-inv-popover {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.ops-inv-pop-arrow {
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 12px; height: 12px;
  background: #fff;
  border-top: 1px solid rgba(43, 38, 32, .06);
  border-left: 1px solid rgba(43, 38, 32, .06);
}
[data-theme="dark"] .ops-inv-pop-arrow {
  background: #1d2530;
  border-top-color: rgba(255, 255, 255, .08);
  border-left-color: rgba(255, 255, 255, .08);
}

.ops-inv-pop-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(43, 38, 32, .08);
  margin-bottom: 8px;
}
[data-theme="dark"] .ops-inv-pop-head {
  border-bottom-color: rgba(255, 255, 255, .08);
}
.ops-inv-pop-cat {
  font-family: "Fraunces", serif;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -.01em;
}
.ops-inv-pop-total {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--lg-primary);
}

.ops-inv-pop-sub {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  margin-bottom: 8px;
  opacity: .85;
}
.ops-inv-pop-sub.is-empty { color: var(--lg-primary); }
.ops-inv-pop-sub.is-warn { color: #9a7a2e; }
.ops-inv-pop-sub.is-ok { color: var(--lg-secondary, #3d5a3c); }

.ops-inv-pop-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 280px;
  overflow-y: auto;
}

.ops-inv-pop-row {
  display: grid;
  grid-template-columns: 16px 1fr auto auto;
  align-items: center;
  gap: 8px;
  padding: 4px 6px;
  border-radius: 6px;
  font-size: .82rem;
}
.ops-inv-pop-row.is-empty {
  background: rgba(196, 69, 54, .08);
  color: var(--lg-primary);
}
.ops-inv-pop-row.is-warn {
  background: rgba(212, 165, 74, .12);
  color: #9a7a2e;
}
[data-theme="dark"] .ops-inv-pop-row.is-warn {
  color: #f5d59a;
}
.ops-inv-pop-row.is-ok {
  color: var(--lg-text-muted);
}
.ops-inv-pop-row > i {
  font-size: .9rem;
  opacity: .9;
}
.ops-inv-pop-row.is-ok > i { color: var(--lg-secondary, #3d5a3c); opacity: .55; }

.ops-inv-pop-name {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ops-inv-pop-qty {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.ops-inv-pop-thr {
  font-size: .68rem;
  opacity: .55;
  font-weight: 500;
}

/* Mobile: popover left-aligned to avoid overflow */
@media (max-width: 575.98px) {
  .ops-inv-popover {
    left: 0;
    transform: translateY(-6px);
    min-width: 200px;
    max-width: calc(100vw - 32px);
  }
  .ops-inv-pill:hover > .ops-inv-popover,
  .ops-inv-pill:focus > .ops-inv-popover,
  .ops-inv-pill:focus-within > .ops-inv-popover {
    transform: translateY(0);
  }
  .ops-inv-pop-arrow { left: 24px; transform: rotate(45deg); }
}

/* ── Dashboard cards: safety net + dark mode hardening ─────────────────── */

/* Bare .dash-card (no color modifier): use a proper surface card so the
   text doesn't end up white-on-cream. This also catches any future card
   added without a color modifier. Specificity matches ':not()' on modifiers. */
.dash-card:not(.dash-primary):not(.dash-success):not(.dash-purple):not(.dash-warning):not(.dash-danger):not(.dash-info) {
  background: var(--lg-surface) !important;
  color: var(--lg-text) !important;
  border: 1px solid var(--lg-border);
}
.dash-card:not(.dash-primary):not(.dash-success):not(.dash-purple):not(.dash-warning):not(.dash-danger):not(.dash-info) .dash-label {
  color: var(--lg-text-muted);
}
.dash-card:not(.dash-primary):not(.dash-success):not(.dash-purple):not(.dash-warning):not(.dash-danger):not(.dash-info) .dash-value {
  color: var(--lg-text);
}

/* Dark-mode: slightly different backgrounds so colored cards don't look
   overly saturated on the dark canvas, and the bare surface card stays legible. */
[data-theme="dark"] .dash-card {
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
}
[data-theme="dark"] .dash-primary { background: linear-gradient(135deg, #a83826, #6a1f14) !important; }
[data-theme="dark"] .dash-success { background: linear-gradient(135deg, #4a7a3f, #2d4a2c) !important; }
[data-theme="dark"] .dash-purple  { background: linear-gradient(135deg, #8a6840, #4a3929) !important; }
[data-theme="dark"] .dash-warning { background: linear-gradient(135deg, #b88830, #7a5820) !important; }

/* All .dash-value and .dash-label inside colored cards stay white regardless of theme */
[data-theme="dark"] .dash-primary .dash-value,
[data-theme="dark"] .dash-primary .dash-label,
[data-theme="dark"] .dash-success .dash-value,
[data-theme="dark"] .dash-success .dash-label,
[data-theme="dark"] .dash-purple .dash-value,
[data-theme="dark"] .dash-purple .dash-label,
[data-theme="dark"] .dash-warning .dash-value,
[data-theme="dark"] .dash-warning .dash-label {
  color: #fff !important;
}

/* Super Dashboard + Owner: 'h3 fw-bold' titles, subtitles, and card bodies
   in dark mode — they were using hardcoded light backgrounds → dark text
   inherited from Bootstrap which looked invisible. */
[data-theme="dark"] .card:not(.lg-mag-mockup):not(.lg-case-card):not(.lg-showcase-panel) {
  background: var(--lg-surface);
  color: var(--lg-text);
  border-color: var(--lg-border);
}
[data-theme="dark"] .card .card-body { color: var(--lg-text); }
[data-theme="dark"] .card .card-header,
[data-theme="dark"] .card .card-footer {
  background: transparent;
  border-color: var(--lg-border);
  color: var(--lg-text);
}
[data-theme="dark"] .table { color: var(--lg-text); }
[data-theme="dark"] .table-light,
[data-theme="dark"] .table thead.table-light > tr > th {
  background: var(--lg-surface-2);
  color: var(--lg-text);
  border-color: var(--lg-border);
}
[data-theme="dark"] .table tr > td,
[data-theme="dark"] .table tr > th {
  border-color: var(--lg-border);
}

/* Form labels + placeholders in dark mode */
[data-theme="dark"] .form-label { color: var(--lg-text); }
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background-color: var(--lg-surface-2);
  border-color: var(--lg-border);
  color: var(--lg-text);
}
[data-theme="dark"] .form-control::placeholder { color: var(--lg-text-muted); opacity: .6; }
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background-color: var(--lg-surface);
  color: var(--lg-text);
  border-color: var(--lg-primary);
}
[data-theme="dark"] .form-text { color: var(--lg-text-muted); }

/* Muted text + small text in dark mode (Bootstrap .text-muted is often #6c757d = illegible) */
[data-theme="dark"] .text-muted,
[data-theme="dark"] .text-secondary {
  color: var(--lg-text-muted) !important;
}

/* Range picker pills + btn-outline-dark in dark mode */
[data-theme="dark"] .btn-outline-dark {
  color: var(--lg-text);
  border-color: var(--lg-border);
}
[data-theme="dark"] .btn-outline-dark:hover,
[data-theme="dark"] .btn-outline-dark.active {
  background: var(--lg-text);
  color: var(--lg-surface);
  border-color: var(--lg-text);
}
[data-theme="dark"] .super-range-btn.active,
[data-theme="dark"] .super-dashboard-page .super-range-btn.active,
[data-theme="dark"] .super-tenant-page .super-range-btn.active {
  background-color: var(--lg-primary);
  color: #fff;
  border-color: var(--lg-primary);
}

/* Badges often use text-bg-light which is nearly invisible on dark cards */
[data-theme="dark"] .badge.text-bg-light,
[data-theme="dark"] .badge.bg-light {
  background: var(--lg-surface-2) !important;
  color: var(--lg-text) !important;
}

/* Dropdown menus in dark mode: keep readable */
[data-theme="dark"] .dropdown-menu {
  background: var(--lg-surface);
  border-color: var(--lg-border);
  color: var(--lg-text);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.4);
}
[data-theme="dark"] .dropdown-item { color: var(--lg-text); }
[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
  background: var(--lg-surface-2);
  color: var(--lg-text);
}
[data-theme="dark"] .dropdown-divider { border-color: var(--lg-border); }

/* Alerts in dark mode */
[data-theme="dark"] .alert-info {
  background: rgba(13, 110, 253, 0.12);
  color: #b6d4ff;
  border-color: rgba(13, 110, 253, 0.3);
}
[data-theme="dark"] .alert-warning {
  background: rgba(212, 165, 74, 0.14);
  color: #f5d59a;
  border-color: rgba(212, 165, 74, 0.3);
}
[data-theme="dark"] .alert-success {
  background: rgba(61, 90, 60, 0.14);
  color: #b6daae;
  border-color: rgba(61, 90, 60, 0.4);
}
[data-theme="dark"] .alert-danger {
  background: rgba(196, 69, 54, 0.14);
  color: #f0a39a;
  border-color: rgba(196, 69, 54, 0.3);
}

/* Modal in dark mode */
[data-theme="dark"] .modal-content {
  background: var(--lg-surface);
  color: var(--lg-text);
  border-color: var(--lg-border);
}
[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
  border-color: var(--lg-border);
}
[data-theme="dark"] .modal-backdrop.show { opacity: 0.7; }
[data-theme="dark"] .btn-close { filter: invert(1) grayscale(100%) brightness(1.5); }
