/* ═══════════════════════════════════════════════════════════════
   SuperMart POS — Core Stylesheet
   Windows 11 Mica/Acrylic + Emerald + Gaming-luxe · Pixel-perfect
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* Brand — emerald (supermarket) */
  --brand-50:#ecfdf5; --brand-100:#d1fae5; --brand-200:#a7f3d0; --brand-300:#6ee7b7;
  --brand-400:#34d399; --brand-500:#10b981; --brand-600:#059669; --brand-700:#047857;
  --brand-800:#065f46; --brand-900:#064e3b; --brand-950:#022c22;

  --gold-300:#fcd34d; --gold-400:#fbbf24; --gold-500:#f59e0b; --gold-600:#d97706;

  /* Ink / surface */
  --ink:#0f172a; --ink-soft:#334155; --ink-muted:#64748b; --ink-faint:#94a3b8;
  --line:#e9eef5; --line-strong:#d4dde8;
  --bg:#eef2f7; --bg-soft:#f6f9fc;
  --surface:#ffffff;
  --surface-glass:rgba(255,255,255,.78);

  /* Accents (gaming neon) */
  --c-blue:#3b82f6; --c-indigo:#6366f1; --c-violet:#8b5cf6; --c-rose:#f43f5e;
  --c-amber:#f59e0b; --c-sky:#0ea5e9; --c-pink:#ec4899; --c-cyan:#06b6d4; --c-red:#ef4444;

  /* Shadows — layered, soft */
  --shadow-xs:0 1px 2px rgba(15,23,42,.06);
  --shadow-sm:0 2px 8px rgba(15,23,42,.07);
  --shadow:0 8px 24px rgba(15,23,42,.10);
  --shadow-lg:0 18px 48px rgba(15,23,42,.16);
  --shadow-glow:0 10px 30px rgba(16,185,129,.28);

  --radius-sm:10px; --radius:16px; --radius-lg:22px; --radius-xl:28px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  --sidebar-w:264px;
  --navbar-h:66px;
}

[data-theme="emerald"]{ --accent:var(--brand-500); --accent-700:var(--brand-700); }
[data-theme="indigo"]{ --brand-500:#6366f1; --brand-600:#4f46e5; --brand-700:#4338ca; --brand-800:#3730a3; --brand-900:#312e81; --accent:#6366f1; }
[data-theme="violet"]{ --brand-500:#8b5cf6; --brand-600:#7c3aed; --brand-700:#6d28d9; --brand-800:#5b21b6; --brand-900:#4c1d95; --accent:#8b5cf6; }
[data-theme="sky"]{ --brand-500:#0ea5e9; --brand-600:#0284c7; --brand-700:#0369a1; --brand-800:#075985; --brand-900:#0c4a6e; --accent:#0ea5e9; }
[data-theme="rose"]{ --brand-500:#f43f5e; --brand-600:#e11d48; --brand-700:#be123c; --brand-800:#9f1239; --brand-900:#881337; --accent:#f43f5e; }

/* ── Dark mode ──────────────────────────────────────────────── */
:root[data-mode="dark"]{
  --ink:#e8eef7; --ink-soft:#c2cddb; --ink-muted:#8b9bb0; --ink-faint:#5f7088;
  --line:#243247; --line-strong:#33455e;
  --bg:#0b1220; --bg-soft:#151f30;
  --surface:#162032; --surface-glass:rgba(22,32,50,.82);
  --shadow-xs:0 1px 2px rgba(0,0,0,.4); --shadow-sm:0 2px 8px rgba(0,0,0,.45);
  --shadow:0 8px 24px rgba(0,0,0,.5); --shadow-lg:0 18px 48px rgba(0,0,0,.6);
}
:root[data-mode="dark"] body{ background:#0b1220;
  background-image:radial-gradient(1200px 600px at 100% -10%,rgba(16,185,129,.10),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(99,102,241,.08),transparent 55%); }
:root[data-mode="dark"] .nav-icon-btn,
:root[data-mode="dark"] .nav-profile,
:root[data-mode="dark"] .btn-ghost,
:root[data-mode="dark"] .input,
:root[data-mode="dark"] .textarea,
:root[data-mode="dark"] .select,
:root[data-mode="dark"] .nav-search input,
:root[data-mode="dark"] .toolbar .search input,
:root[data-mode="dark"] .chip-group,
:root[data-mode="dark"] .nav-pill,
:root[data-mode="dark"] .prod-card,
:root[data-mode="dark"] .cat-chip,
:root[data-mode="dark"] .pos-search,
:root[data-mode="dark"] .pos-tool-btn,
:root[data-mode="dark"] .code-input,
:root[data-mode="dark"] .discount-input input,
:root[data-mode="dark"] .pay-btn,
:root[data-mode="dark"] .quick-cash button{ background:var(--surface); color:var(--ink); border-color:var(--line); }
:root[data-mode="dark"] .select{ background-image:none; }
:root[data-mode="dark"] .cat-chip i{ background:rgba(255,255,255,.08); }
:root[data-mode="dark"] .cat-chip.active{ background:linear-gradient(135deg,var(--brand-500),var(--brand-700)); color:#fff; border-color:transparent; }
:root[data-mode="dark"] .cat-chip.active i{ background:rgba(255,255,255,.22); }
:root[data-mode="dark"] .cart-item,
:root[data-mode="dark"] .cart-customer,
:root[data-mode="dark"] .cart-summary{ background:var(--bg-soft); }
:root[data-mode="dark"] .data-table tbody tr:hover{ background:rgba(16,185,129,.10); }
:root[data-mode="dark"] .kpi-value,
:root[data-mode="dark"] .modal-body,
:root[data-mode="dark"] .ci-info b{ color:var(--ink); }
:root[data-mode="dark"] .prod-thumb{ background:linear-gradient(135deg,rgba(16,185,129,.12),var(--surface)); }

*{ box-sizing:border-box; }
*::-webkit-scrollbar{ width:10px; height:10px; }
*::-webkit-scrollbar-thumb{ background:var(--line-strong); border-radius:10px; border:2px solid transparent; background-clip:padding-box; }
*::-webkit-scrollbar-thumb:hover{ background:var(--ink-faint); background-clip:padding-box; }

html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:"Sarabun","Kanit",system-ui,sans-serif;
  color:var(--ink); background:var(--bg);
  font-size:15px; line-height:1.6; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1200px 600px at 100% -10%, rgba(16,185,129,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(99,102,241,.08), transparent 55%);
  background-attachment:fixed;
}
h1,h2,h3,h4,h5,.font-display{ font-family:"Kanit",system-ui,sans-serif; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; }

/* ── App shell ─────────────────────────────────────────────── */
.app-shell{ display:flex; min-height:100vh; min-height:100dvh; }

/* ── Sidebar ───────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w); flex-shrink:0; position:sticky; top:0; align-self:flex-start;
  height:100vh; height:100dvh; overflow-y:auto; overflow-x:hidden;
  background:linear-gradient(178deg,var(--brand-900) 0%,var(--brand-950) 100%);
  color:#dcfce7; padding:18px 14px 24px; z-index:40;
  box-shadow:6px 0 30px rgba(2,44,34,.30);
  scrollbar-width:thin;
}
.sidebar::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.18); }
.sb-brand{ display:flex; align-items:center; gap:12px; padding:8px 10px 16px; }
.sb-logo{
  width:46px; height:46px; border-radius:14px; flex-shrink:0;
  background:linear-gradient(135deg,var(--brand-400),var(--brand-600));
  display:grid; place-items:center; color:#fff; font-size:24px;
  box-shadow:0 8px 22px rgba(16,185,129,.45); position:relative;
}
.sb-logo::after{ content:""; position:absolute; inset:-4px; border-radius:18px; background:radial-gradient(circle,rgba(52,211,153,.5),transparent 70%); filter:blur(8px); z-index:-1; }
.sb-brand-text strong{ display:block; font-family:"Kanit"; font-weight:700; font-size:18px; color:#fff; letter-spacing:.3px; }
.sb-brand-text span{ font-size:11.5px; color:#6ee7b7; }

.sb-power{ margin:6px 6px 14px; }
.sb-card{ background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.10); border-radius:14px; padding:11px 13px; backdrop-filter:blur(8px); }
.sb-clock{ text-align:center; margin-bottom:8px; }
.sb-clock-time{ font-family:"Kanit"; font-weight:700; font-size:26px; letter-spacing:1px; color:#fff; text-shadow:0 0 18px rgba(110,231,183,.5); font-variant-numeric:tabular-nums; }
.sb-clock-date{ font-size:11.5px; color:#a7f3d0; }
.sb-user{ display:flex; align-items:center; gap:10px; }
.sb-avatar{ width:36px; height:36px; border-radius:11px; background:linear-gradient(135deg,var(--gold-400),var(--gold-600)); display:grid; place-items:center; color:#78350f; font-weight:700; flex-shrink:0; font-family:"Kanit"; }
.sb-user-info{ min-width:0; }
.sb-user-info b{ display:block; font-size:13px; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.sb-nav{ display:flex; flex-direction:column; gap:2px; }
.sb-group-title{ font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#5eb795; padding:16px 12px 7px; display:flex; align-items:center; gap:7px; }
.sb-group-title::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--brand-400); box-shadow:0 0 8px var(--brand-400); }
.sb-link{
  display:flex; align-items:center; gap:12px; padding:10px 13px; border-radius:12px;
  color:#bbf7d0; font-size:14px; font-weight:500; position:relative;
  transition:all .2s var(--ease);
}
.sb-link i{ font-size:18px; width:22px; text-align:center; flex-shrink:0; }
.sb-link:hover{ background:rgba(255,255,255,.08); color:#fff; transform:translateX(2px); }
.sb-link.active{ background:linear-gradient(90deg,rgba(52,211,153,.22),rgba(52,211,153,.04)); color:#fff; }
.sb-link.active::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:4px; height:62%; border-radius:0 4px 4px 0; background:linear-gradient(var(--brand-300),var(--brand-500)); box-shadow:0 0 12px var(--brand-400); }
.sb-link .sb-badge{ margin-left:auto; background:var(--c-red); color:#fff; font-size:10.5px; font-weight:700; padding:1px 7px; border-radius:999px; }

/* ── Main ──────────────────────────────────────────────────── */
.main{ flex:1; min-width:0; display:flex; flex-direction:column; }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar{
  height:var(--navbar-h); position:sticky; top:0; z-index:30;
  display:flex; align-items:center; gap:14px; padding:0 22px;
  background:var(--surface-glass); backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid var(--line);
}
.nav-toggle{ display:none; width:42px; height:42px; border-radius:12px; border:1px solid var(--line); background:#fff; color:var(--ink-soft); font-size:20px; align-items:center; justify-content:center; }
.nav-page{ display:flex; align-items:center; gap:12px; }
.nav-page-icon{ width:44px; height:44px; border-radius:13px; background:linear-gradient(135deg,var(--brand-100),var(--brand-200)); color:var(--brand-700); display:grid; place-items:center; font-size:21px; }
.nav-page-text h1{ margin:0; font-size:17px; font-weight:700; line-height:1.2; }
.nav-page-text p{ margin:0; font-size:12px; color:var(--ink-muted); }

.nav-search{ flex:1; max-width:420px; position:relative; }
.nav-search input{ width:100%; height:42px; border:1px solid var(--line); border-radius:12px; padding:0 14px 0 42px; background:var(--bg-soft); font-family:inherit; font-size:14px; transition:.2s; }
.nav-search input:focus{ outline:none; border-color:var(--brand-400); background:#fff; box-shadow:0 0 0 4px rgba(16,185,129,.12); }
.nav-search i{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--ink-faint); font-size:17px; }

.nav-right{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.nav-pill{ display:inline-flex; align-items:center; gap:7px; height:38px; padding:0 13px; border-radius:11px; background:var(--bg-soft); border:1px solid var(--line); font-size:12.5px; font-weight:600; color:var(--ink-soft); }
.nav-pill.online{ color:var(--brand-700); }
.nav-pill.online .dot{ width:8px; height:8px; border-radius:50%; background:var(--brand-500); box-shadow:0 0 0 0 rgba(16,185,129,.6); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(16,185,129,.55)} 70%{box-shadow:0 0 0 8px rgba(16,185,129,0)} 100%{box-shadow:0 0 0 0 rgba(16,185,129,0)} }
.nav-clock{ font-variant-numeric:tabular-nums; }
.nav-icon-btn{ width:42px; height:42px; border-radius:12px; border:1px solid var(--line); background:#fff; color:var(--ink-soft); font-size:19px; display:grid; place-items:center; position:relative; transition:.2s; }
.nav-icon-btn:hover{ border-color:var(--brand-300); color:var(--brand-600); transform:translateY(-1px); }
.nav-icon-btn .badge-dot{ position:absolute; top:9px; right:10px; width:8px; height:8px; border-radius:50%; background:var(--c-red); border:2px solid #fff; }

.nav-profile{ display:flex; align-items:center; gap:9px; height:44px; padding:0 6px 0 12px; border-radius:13px; border:1px solid var(--line); background:#fff; transition:.2s; cursor:pointer; }
.nav-profile:hover{ border-color:var(--brand-300); box-shadow:var(--shadow-sm); }
.nav-profile-av{ width:32px; height:32px; border-radius:9px; background:linear-gradient(135deg,var(--brand-400),var(--brand-600)); color:#fff; display:grid; place-items:center; font-weight:700; font-size:14px; font-family:"Kanit"; }
.nav-profile-info{ text-align:right; line-height:1.15; }
.nav-profile-info b{ font-size:13px; display:block; }
.nav-profile-info span{ font-size:11px; color:var(--ink-muted); }

/* Profile dropdown */
.nav-profile-wrap{ position:relative; }
.profile-pop{ position:absolute; top:calc(100% + 10px); right:0; width:268px; background:var(--surface-glass); backdrop-filter:blur(20px); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-lg); padding:8px; opacity:0; visibility:hidden; transform:translateY(-8px) scale(.97); transform-origin:top right; transition:.22s var(--ease); z-index:60; }
.nav-profile-wrap.open .profile-pop{ opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.profile-pop-head{ display:flex; align-items:center; gap:11px; padding:12px 12px 14px; border-bottom:1px solid var(--line); margin-bottom:6px; }
.profile-pop-head .av{ width:46px; height:46px; border-radius:13px; background:linear-gradient(135deg,var(--brand-400),var(--brand-600)); color:#fff; display:grid; place-items:center; font-weight:700; font-size:19px; font-family:"Kanit"; }
.profile-pop-item{ display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:11px; font-size:13.5px; color:var(--ink-soft); transition:.16s; }
.profile-pop-item i{ font-size:17px; color:var(--ink-muted); }
.profile-pop-item:hover{ background:var(--brand-50); color:var(--brand-700); }
.profile-pop-item:hover i{ color:var(--brand-600); }
.profile-pop-item.danger:hover{ background:#fef2f2; color:var(--c-red); }
.profile-pop-item.danger:hover i{ color:var(--c-red); }

/* ── Notification bell dropdown (mirror profile-pop) ───────── */
.nav-notif-wrap{ position:relative; }
.nav-notif-wrap .notif-badge{ position:absolute; top:5px; right:6px; min-width:17px; height:17px; padding:0 4px; border-radius:999px; background:var(--c-red); color:#fff; font-size:10.5px; font-weight:700; font-family:"Kanit"; display:grid; place-items:center; border:2px solid #fff; line-height:1; }
.notif-pop{ position:absolute; top:calc(100% + 10px); right:0; width:330px; max-width:calc(100vw - 28px); background:var(--surface-glass); backdrop-filter:blur(20px); border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow-lg); padding:8px; opacity:0; visibility:hidden; transform:translateY(-8px) scale(.97); transform-origin:top right; transition:.22s var(--ease); z-index:60; }
.nav-notif-wrap.open .notif-pop{ opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.notif-pop-head{ display:flex; align-items:center; justify-content:space-between; padding:10px 12px 12px; border-bottom:1px solid var(--line); margin-bottom:6px; }
.notif-pop-head b{ font-size:14px; display:inline-flex; align-items:center; gap:7px; color:var(--ink); }
.notif-pop-head b i{ color:var(--brand-600); }
.notif-list{ max-height:360px; overflow-y:auto; display:flex; flex-direction:column; gap:2px; }
.notif-item{ display:flex; align-items:flex-start; gap:11px; padding:10px 12px; border-radius:12px; transition:.16s; }
.notif-item:hover{ background:var(--brand-50); }
.notif-item .notif-ic{ flex:0 0 auto; width:38px; height:38px; border-radius:11px; display:grid; place-items:center; font-size:18px; }
.notif-item .notif-body{ min-width:0; line-height:1.3; }
.notif-item .notif-body b{ display:block; font-size:13.5px; color:var(--ink); }
.notif-item .notif-body small{ display:block; font-size:12px; color:var(--ink-muted); margin-top:2px; }
.notif-empty{ display:flex; flex-direction:column; align-items:center; gap:8px; padding:30px 16px; color:var(--ink-muted); font-size:13px; text-align:center; }
.notif-empty i{ font-size:30px; color:var(--brand-300); }
.notif-pop-foot{ display:flex; align-items:center; justify-content:center; gap:7px; margin-top:6px; padding:11px; border-top:1px solid var(--line); font-size:13px; font-weight:600; color:var(--brand-700); border-radius:0 0 12px 12px; transition:.16s; }
.notif-pop-foot:hover{ background:var(--brand-50); }

/* ── Role chip ─────────────────────────────────────────────── */
.role-chip{ display:inline-flex; align-items:center; gap:5px; padding:3px 11px; border-radius:999px; font-size:11.5px; font-weight:700; font-family:"Kanit"; }
.role-chip i{ font-size:12px; }
.role-chip-admin{ background:linear-gradient(135deg,#fde68a,#fbbf24); color:#78350f; }
.role-chip-manager{ background:linear-gradient(135deg,#ddd6fe,#a78bfa); color:#4c1d95; }
.role-chip-cashier{ background:linear-gradient(135deg,#a7f3d0,#34d399); color:#065f46; }
.role-chip-stock{ background:linear-gradient(135deg,#bfdbfe,#60a5fa); color:#1e3a8a; }

/* ── Page container ────────────────────────────────────────── */
.page{ padding:24px 26px 40px; max-width:1640px; width:100%; margin:0 auto; }
@media(max-width:600px){ .page{ padding:16px 14px 90px; } }

/* ── Hero ──────────────────────────────────────────────────── */
.hero{ position:relative; overflow:hidden; border-radius:var(--radius-xl); padding:26px 30px; color:#fff; margin-bottom:22px;
  background:linear-gradient(125deg,var(--brand-700) 0%,var(--brand-800) 55%,var(--brand-950) 100%);
  box-shadow:var(--shadow-glow); }
.hero::before{ content:""; position:absolute; top:-60%; left:-10%; width:60%; height:220%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.10),transparent); transform:rotate(18deg); animation:beam 7s ease-in-out infinite; }
@keyframes beam{ 0%,100%{left:-30%} 50%{left:90%} }
.hero::after{ content:""; position:absolute; right:-40px; bottom:-60px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle,rgba(110,231,183,.35),transparent 65%); }
.hero-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; position:relative; z-index:1; flex-wrap:wrap; }
.hero h1{ margin:0 0 4px; font-size:25px; font-weight:700; }
.hero p{ margin:0; color:#bbf7d0; font-size:14px; }
.hero-deco{ position:absolute; right:26px; top:50%; transform:translateY(-50%); font-size:120px; color:rgba(255,255,255,.08); z-index:0; }
.theme-picker{ display:flex; gap:7px; }
.theme-dot{ width:26px; height:26px; border-radius:9px; border:2px solid rgba(255,255,255,.5); cursor:pointer; transition:.2s; }
.theme-dot:hover,.theme-dot.active{ transform:scale(1.12); border-color:#fff; box-shadow:0 0 0 3px rgba(255,255,255,.25); }

/* ── KPI strip ─────────────────────────────────────────────── */
.kpi-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:14px; margin-bottom:22px; }
.kpi{ position:relative; overflow:hidden; background:var(--surface-glass); backdrop-filter:blur(14px); border:1px solid var(--line); border-radius:var(--radius); padding:16px 17px; box-shadow:var(--shadow-sm); transition:.28s var(--ease); }
.kpi:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--brand-200); }
.kpi::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--k1,var(--brand-400)),var(--k2,var(--brand-600))); }
.kpi-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.kpi-icon{ width:44px; height:44px; border-radius:13px; display:grid; place-items:center; font-size:21px; color:#fff; background:linear-gradient(135deg,var(--k1,var(--brand-400)),var(--k2,var(--brand-600))); box-shadow:0 8px 18px rgba(16,185,129,.30); }
.kpi-delta{ font-size:11.5px; font-weight:700; padding:3px 8px; border-radius:999px; display:inline-flex; align-items:center; gap:3px; }
.kpi-delta.up{ background:var(--brand-50); color:var(--brand-700); }
.kpi-delta.down{ background:#fef2f2; color:var(--c-red); }
.kpi-value{ font-family:"Kanit"; font-weight:700; font-size:26px; line-height:1.1; color:var(--ink); letter-spacing:-.5px; }
.kpi-label{ font-size:12.5px; color:var(--ink-muted); margin-top:2px; }
.kpi-spark{ margin-top:8px; height:26px; }

/* ── Card ──────────────────────────────────────────────────── */
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); }
.card-pad{ padding:18px 20px; }
.card-head{ display:flex; align-items:center; gap:12px; padding:16px 20px; border-bottom:1px solid var(--line); }
.card-head h3{ margin:0; font-size:16px; font-weight:700; display:flex; align-items:center; gap:9px; }
.card-head h3 i{ color:var(--brand-600); font-size:18px; }
.card-head .sub{ font-size:12px; color:var(--ink-muted); }
.card-head .head-actions{ margin-left:auto; display:flex; gap:8px; }

.grid{ display:grid; gap:16px; }
.grid-2{ grid-template-columns:repeat(2,minmax(0,1fr)); }
.grid-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.dash-row{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:16px; margin-bottom:18px; }
.dash-row-2{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; margin-bottom:18px; }
@media(max-width:1100px){ .dash-row,.dash-row-2,.grid-3,.grid-2{ grid-template-columns:1fr; } }

/* ── Charts (SVG) ──────────────────────────────────────────── */
.chart-wrap{ padding:8px 16px 16px; }
.donut-legend{ display:flex; flex-direction:column; gap:9px; padding:6px 18px 16px; }
.donut-legend-item{ display:flex; align-items:center; gap:9px; font-size:13px; }
.donut-legend-item .swatch{ width:11px; height:11px; border-radius:4px; flex-shrink:0; }
.donut-legend-item .val{ margin-left:auto; font-weight:700; font-variant-numeric:tabular-nums; }
.bar-row{ display:flex; align-items:center; gap:11px; padding:7px 18px; }
.bar-row .bar-label{ width:120px; font-size:12.5px; color:var(--ink-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bar-track{ flex:1; height:9px; background:var(--bg); border-radius:999px; overflow:hidden; }
.bar-fill{ height:100%; border-radius:999px; background:linear-gradient(90deg,var(--brand-400),var(--brand-600)); position:relative; transition:width 1s var(--ease); }
.bar-fill::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent); animation:shimmer 2.4s infinite; }
@keyframes shimmer{ 0%{transform:translateX(-100%)} 100%{transform:translateX(100%)} }
.bar-row .bar-val{ width:84px; text-align:right; font-size:12.5px; font-weight:700; font-variant-numeric:tabular-nums; }

/* ── Table ─────────────────────────────────────────────────── */
.table-wrap{ overflow-x:auto; }
.data-table{ width:100%; border-collapse:collapse; font-size:13.5px; }
.data-table thead th{ text-align:left; padding:12px 16px; font-size:11.5px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-muted); border-bottom:1px solid var(--line); white-space:nowrap; }
.data-table tbody td{ padding:13px 16px; border-bottom:1px solid var(--line); vertical-align:middle; }
.data-table tbody tr{ transition:.14s; }
.data-table tbody tr:hover{ background:var(--brand-50); }
.data-table tbody tr:last-child td{ border-bottom:none; }
.t-right{ text-align:right; } .t-center{ text-align:center; }
.cell-prod{ display:flex; align-items:center; gap:11px; }
.cell-prod .thumb{ width:38px; height:38px; border-radius:10px; background:var(--bg); display:grid; place-items:center; color:var(--brand-600); font-size:18px; flex-shrink:0; overflow:hidden; }
.cell-prod b{ font-size:13.5px; } .cell-prod small{ color:var(--ink-muted); font-size:11.5px; }

/* ── Badge ─────────────────────────────────────────────────── */
.badge{ display:inline-flex; align-items:center; gap:5px; padding:3px 10px; border-radius:999px; font-size:11.5px; font-weight:700; }
.badge i{ font-size:11px; }
.badge-green{ background:var(--brand-50); color:var(--brand-700); }
.badge-amber{ background:#fffbeb; color:#b45309; }
.badge-red{ background:#fef2f2; color:#b91c1c; }
.badge-blue{ background:#eff6ff; color:#1d4ed8; }
.badge-gray{ background:#f1f5f9; color:#475569; }
.badge-violet{ background:#f5f3ff; color:#6d28d9; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; height:42px; padding:0 18px; border-radius:12px; border:1px solid transparent; font-family:"Kanit"; font-size:14px; font-weight:600; transition:.2s var(--ease); white-space:nowrap; position:relative; overflow:hidden; }
.btn i{ font-size:17px; }
.btn-primary{ background:linear-gradient(135deg,var(--brand-500),var(--brand-700)); color:#fff; box-shadow:0 8px 20px rgba(16,185,129,.32); }
.btn-primary:hover{ transform:translateY(-1px); box-shadow:0 12px 26px rgba(16,185,129,.42); }
.btn-ghost{ background:#fff; border-color:var(--line-strong); color:var(--ink-soft); }
.btn-ghost:hover{ border-color:var(--brand-300); color:var(--brand-700); background:var(--brand-50); }
.btn-danger{ background:linear-gradient(135deg,#ef4444,#dc2626); color:#fff; box-shadow:0 8px 20px rgba(239,68,68,.3); }
.btn-danger:hover{ transform:translateY(-1px); }
.btn-gold{ background:linear-gradient(135deg,var(--gold-400),var(--gold-600)); color:#78350f; box-shadow:0 8px 20px rgba(245,158,11,.3); }
.btn-sm{ height:34px; padding:0 12px; font-size:13px; border-radius:10px; }
.btn-lg{ height:52px; padding:0 26px; font-size:16px; border-radius:14px; }
.btn-icon{ width:42px; padding:0; }
.btn-block{ width:100%; }
.btn:disabled{ opacity:.55; pointer-events:none; }
.btn .ripple{ position:absolute; border-radius:50%; transform:scale(0); background:rgba(255,255,255,.5); animation:ripple .6s linear; pointer-events:none; }
@keyframes ripple{ to{ transform:scale(4); opacity:0; } }

/* ── Toolbar / filter ──────────────────────────────────────── */
.toolbar{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:18px; }
.toolbar .search{ position:relative; flex:1; min-width:200px; max-width:360px; }
.toolbar .search input{ width:100%; height:44px; border:1px solid var(--line); border-radius:13px; padding:0 14px 0 42px; background:#fff; font-family:inherit; font-size:14px; box-shadow:var(--shadow-xs); }
.toolbar .search input:focus{ outline:none; border-color:var(--brand-400); box-shadow:0 0 0 4px rgba(16,185,129,.12); }
.toolbar .search i{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--ink-faint); font-size:18px; }
.select{ height:44px; border:1px solid var(--line); border-radius:13px; padding:0 36px 0 14px; background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") no-repeat right 13px center; font-family:inherit; font-size:14px; color:var(--ink-soft); box-shadow:var(--shadow-xs); appearance:none; cursor:pointer; }
.chip-group{ display:inline-flex; background:#fff; border:1px solid var(--line); border-radius:12px; padding:3px; gap:2px; box-shadow:var(--shadow-xs); }
.chip{ height:36px; padding:0 14px; border-radius:9px; border:none; background:transparent; font-family:"Kanit"; font-size:13px; font-weight:600; color:var(--ink-muted); transition:.16s; }
.chip.active{ background:var(--brand-600); color:#fff; box-shadow:0 4px 10px rgba(16,185,129,.3); }

/* ── Forms ─────────────────────────────────────────────────── */
.form-grid{ display:grid; gap:16px; grid-template-columns:repeat(2,1fr); }
@media(max-width:640px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:6px; }
.field.col-span{ grid-column:1 / -1; }
.field label{ font-size:13px; font-weight:600; color:var(--ink-soft); }
.field label .req{ color:var(--c-red); }
.input, .textarea{ width:100%; min-height:46px; border:1px solid var(--line-strong); border-radius:12px; padding:11px 14px; font-family:inherit; font-size:14.5px; background:#fff; transition:.18s; }
.textarea{ resize:vertical; min-height:90px; }
.input:focus,.textarea:focus,.select:focus{ outline:none; border-color:var(--brand-400); box-shadow:0 0 0 4px rgba(16,185,129,.12); }
.input.error{ border-color:var(--c-red); box-shadow:0 0 0 4px rgba(239,68,68,.1); }
.field-hint{ font-size:11.5px; color:var(--ink-faint); }

/* ── Modal ─────────────────────────────────────────────────── */
.modal-host{ position:fixed; inset:0; z-index:160; display:none; }
.modal-host.open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(15,23,42,.5); backdrop-filter:blur(4px); opacity:0; transition:.28s; }
.modal-host.open .modal-backdrop{ opacity:1; }
.modal{ position:absolute; top:50%; left:50%; transform:translate(-50%,-46%); width:min(620px,calc(100vw - 32px)); max-height:90vh; overflow:hidden; background:var(--surface); border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); opacity:0; transition:.32s var(--ease-spring); display:flex; flex-direction:column; }
.modal-host.open .modal{ opacity:1; transform:translate(-50%,-50%); }
.modal.wide{ width:min(880px,calc(100vw - 32px)); }
.modal-header{ padding:20px 24px; color:#fff; background:linear-gradient(125deg,var(--brand-600),var(--brand-800)); position:relative; overflow:hidden; flex-shrink:0; }
.modal-header::before{ content:""; position:absolute; right:-30px; top:-40px; width:160px; height:160px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.14),transparent 65%); }
.modal-header h3{ margin:0; font-size:19px; font-weight:700; display:flex; align-items:center; gap:10px; position:relative; }
.modal-header p{ margin:3px 0 0; font-size:12.5px; color:#bbf7d0; position:relative; }
.modal-close{ position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:11px; border:none; background:rgba(255,255,255,.18); color:#fff; font-size:18px; display:grid; place-items:center; z-index:2; transition:.2s; }
.modal-close:hover{ background:rgba(255,255,255,.32); transform:rotate(90deg); }
.modal-body{ padding:22px 24px; overflow-y:auto; flex:1; }
.modal-footer{ padding:16px 24px; border-top:1px solid var(--line); display:flex; gap:10px; justify-content:flex-end; flex-shrink:0; background:var(--bg-soft); }

/* Modal → bottom-sheet on mobile (อยู่เหนือ POS cart sheet เสมอ) */
@media(max-width:600px){
  .modal{ top:auto; bottom:0; left:0; right:0; width:auto; max-width:none; max-height:92vh; border-radius:24px 24px 0 0; transform:translateY(100%); }
  .modal.wide{ width:auto; }
  .modal-host.open .modal{ transform:translateY(0); }
  .modal-footer{ position:sticky; bottom:0; padding-bottom:calc(16px + env(safe-area-inset-bottom)); }
}

/* ── Empty / skeleton ──────────────────────────────────────── */
.empty{ text-align:center; padding:48px 20px; }
.empty-icon{ width:84px; height:84px; border-radius:24px; margin:0 auto 16px; background:var(--brand-50); color:var(--brand-400); display:grid; place-items:center; font-size:40px; }
.empty h4{ margin:0 0 6px; font-size:17px; }
.empty p{ margin:0 0 18px; color:var(--ink-muted); font-size:13.5px; }
.skeleton{ background:linear-gradient(90deg,#eef2f7 25%,#f6f9fc 50%,#eef2f7 75%); background-size:200% 100%; animation:skel 1.4s infinite; border-radius:8px; }
@keyframes skel{ 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── Footer ────────────────────────────────────────────────── */
.app-footer{ margin-top:auto; padding:18px 26px; border-top:1px solid var(--line); background:var(--surface-glass); backdrop-filter:blur(10px); display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.app-footer .copy{ font-size:12.5px; color:var(--ink-muted); display:flex; align-items:center; gap:10px; }
.ver-pill{ background:var(--brand-50); color:var(--brand-700); font-weight:700; padding:2px 9px; border-radius:999px; font-size:11px; }
.dev-block{ display:flex; align-items:center; gap:11px; }
.dev-logo{ width:38px; height:38px; border-radius:50%; object-fit:cover; border:2px solid var(--brand-200); box-shadow:0 0 0 3px rgba(16,185,129,.1); background:var(--brand-50); }
.dev-block .t{ font-size:11px; color:var(--ink-faint); line-height:1.3; }
.dev-block .t b{ display:block; color:var(--ink-soft); font-size:12.5px; }

/* ── Utilities ─────────────────────────────────────────────── */
.flex{ display:flex; } .items-center{ align-items:center; } .gap-2{ gap:8px; } .gap-3{ gap:12px; }
.between{ justify-content:space-between; } .ml-auto{ margin-left:auto; }
.muted{ color:var(--ink-muted); } .text-sm{ font-size:13px; } .text-xs{ font-size:11.5px; }
.fw-700{ font-weight:700; } .mt-2{ margin-top:8px; } .mb-0{ margin-bottom:0; }
.tabnum{ font-variant-numeric:tabular-nums; }
.hide{ display:none !important; }

/* ── App-style touch feedback (mobile) ─────────────────────── */
@media (hover:none) and (pointer:coarse) {
  .btn:active{ transform:scale(.96); }
  .kpi:active, .card:active{ transform:scale(.99); }
  .cat-chip:active, .chip:active, .pay-btn:active, .prod-card:active{ transform:scale(.95); }
  .sb-link:active, .m-nav-item:active, .am-item:active{ transform:scale(.94); }
}

/* ── Mobile App Menu Grid (app-style homepage) ─────────────── */
.app-menu{ display:none; }
.app-greet{ display:none; }
@media(max-width:900px){
  .app-greet{
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    margin:-4px 0 16px; padding:16px 18px; border-radius:20px; color:#fff;
    background:linear-gradient(135deg,var(--brand-600),var(--brand-900)); position:relative; overflow:hidden;
    box-shadow:var(--shadow-glow);
  }
  .app-greet::after{ content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.16),transparent 65%); }
  .app-greet .ag-text{ position:relative; }
  .app-greet .ag-hi{ font-size:12.5px; color:#bbf7d0; }
  .app-greet .ag-name{ font-family:"Kanit"; font-weight:700; font-size:18px; line-height:1.2; }
  .app-greet .ag-av{ width:46px; height:46px; border-radius:14px; background:rgba(255,255,255,.18); display:grid; place-items:center; font-family:"Kanit"; font-weight:700; font-size:20px; position:relative; flex-shrink:0; }

  .app-menu{ display:block; margin-bottom:20px; }
  .app-menu-title{ font-size:13px; font-weight:700; color:var(--ink-soft); margin:0 2px 10px; display:flex; align-items:center; gap:7px; }
  .app-menu-title i{ color:var(--brand-600); }
  .am-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
  .am-item{ display:flex; flex-direction:column; align-items:center; gap:7px; padding:14px 4px; border-radius:18px; background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow-xs); transition:.18s; position:relative; }
  .am-icon{ width:50px; height:50px; border-radius:16px; display:grid; place-items:center; font-size:23px; color:#fff; box-shadow:0 6px 14px rgba(15,23,42,.12); }
  .am-label{ font-size:11px; font-weight:600; color:var(--ink-soft); text-align:center; line-height:1.2; }
  .am-badge{ position:absolute; top:8px; right:10px; min-width:18px; height:18px; padding:0 5px; border-radius:999px; background:var(--c-red); color:#fff; font-size:10px; font-weight:800; display:grid; place-items:center; }
}

/* ── Hero buttons (white-on-gradient) ──────────────────────── */
.hero .hero-btn{ background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.28); color:#fff; backdrop-filter:blur(4px); }
.hero .hero-btn:hover{ background:rgba(255,255,255,.30); color:#fff; transform:translateY(-1px); }

/* ── Import modal ──────────────────────────────────────────── */
.imp-steps{ display:flex; flex-direction:column; gap:10px; margin-bottom:16px; }
.imp-step{ display:flex; align-items:center; gap:12px; padding:12px 14px; border:1px solid var(--line); border-radius:13px; background:var(--bg-soft); }
.imp-step .imp-num{ width:28px; height:28px; border-radius:50%; background:var(--brand-600); color:#fff; display:grid; place-items:center; font-weight:700; font-family:"Kanit"; flex-shrink:0; }
.imp-step > div{ flex:1; min-width:0; } .imp-step b{ display:block; font-size:14px; } .imp-step small{ color:var(--ink-muted); font-size:12px; }
.imp-drop{ border:2px dashed var(--line-strong); border-radius:16px; padding:28px 20px; text-align:center; cursor:pointer; transition:.2s; }
.imp-drop:hover, .imp-drop.drag{ border-color:var(--brand-400); background:var(--brand-50); }
.imp-drop > i{ font-size:42px; color:var(--brand-400); display:block; margin-bottom:8px; }
.imp-drop b{ display:block; font-size:15px; } .imp-drop small{ color:var(--ink-muted); font-size:12px; }
.imp-drop.has-file{ border-color:var(--brand-500); background:var(--brand-50); }
.imp-drop.has-file > i{ color:var(--brand-600); }
.imp-result .imp-sum{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:10px; }
.imp-result .imp-stat{ flex:1; min-width:90px; text-align:center; padding:12px; border-radius:13px; font-size:12px; }
.imp-result .imp-stat b{ display:block; font-family:"Kanit"; font-size:26px; }
.imp-result .imp-errs{ max-height:160px; overflow-y:auto; background:#fef2f2; border:1px solid #fecaca; border-radius:12px; padding:10px 14px; font-size:12.5px; color:#b91c1c; }
.imp-result .imp-errs div{ padding:2px 0; }

/* ── Product image preview ─────────────────────────────────── */
.p-img-preview{ width:64px; height:64px; border-radius:14px; border:1px solid var(--line); background:var(--bg-soft); display:grid; place-items:center; overflow:hidden; flex:none; color:var(--ink-faint); }
.p-img-preview i{ font-size:24px; }
.p-img-preview img{ width:100%; height:100%; object-fit:cover; }

/* ── Navbar search trigger ─────────────────────────────────── */
.nav-search-trigger{ display:inline-flex; align-items:center; gap:9px; height:40px; padding:0 12px 0 14px; border-radius:12px; border:1px solid var(--line); background:var(--bg-soft); color:var(--ink-muted); font-family:inherit; font-size:13px; transition:.18s; }
.nav-search-trigger:hover{ border-color:var(--brand-300); color:var(--brand-700); background:#fff; box-shadow:var(--shadow-xs); }
.nav-search-trigger i{ font-size:15px; }
.nav-search-trigger span{ min-width:90px; text-align:left; }
.nav-search-trigger kbd{ font-size:10.5px; font-weight:700; padding:2px 6px; border-radius:6px; background:var(--surface); border:1px solid var(--line-strong); color:var(--ink-faint); }
@media(max-width:720px){ .nav-search-trigger span, .nav-search-trigger kbd{ display:none; } .nav-search-trigger{ padding:0; width:40px; justify-content:center; } }

/* ── Command Palette ───────────────────────────────────────── */
.cmdk{ position:fixed; inset:0; z-index:300; display:none; }
.cmdk.open{ display:block; }
.cmdk-backdrop{ position:absolute; inset:0; background:rgba(15,23,42,.45); backdrop-filter:blur(6px); opacity:0; transition:.22s; }
.cmdk.open .cmdk-backdrop{ opacity:1; }
.cmdk-box{ position:absolute; top:12vh; left:50%; transform:translateX(-50%) scale(.97); width:min(640px,calc(100vw - 28px)); max-height:72vh; display:flex; flex-direction:column; overflow:hidden; background:var(--surface-glass); backdrop-filter:blur(22px) saturate(160%); border:1px solid var(--line); border-radius:20px; box-shadow:var(--shadow-lg); opacity:0; transition:.24s var(--ease-spring); }
.cmdk.open .cmdk-box{ opacity:1; transform:translateX(-50%) scale(1); }
.cmdk-input{ display:flex; align-items:center; gap:12px; padding:16px 18px; border-bottom:1px solid var(--line); }
.cmdk-input > i{ font-size:20px; color:var(--brand-500); }
.cmdk-input input{ flex:1; border:none; background:transparent; font-family:inherit; font-size:16.5px; color:var(--ink); }
.cmdk-input input:focus{ outline:none; }
.cmdk-input kbd{ font-size:11px; font-weight:700; padding:3px 8px; border-radius:7px; background:var(--bg-soft); border:1px solid var(--line-strong); color:var(--ink-faint); }
.cmdk-spin{ width:16px; height:16px; border-radius:50%; border:2px solid var(--line-strong); border-top-color:var(--brand-500); animation:spin .7s linear infinite; display:none; }
.cmdk-spin.show{ display:block; }
.cmdk-results{ overflow-y:auto; padding:8px; flex:1; }
.cmdk-group-title{ font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); padding:10px 12px 5px; }
.cmdk-item{ display:flex; align-items:center; gap:13px; padding:11px 13px; border-radius:12px; cursor:pointer; transition:.12s; }
.cmdk-item .ic{ width:36px; height:36px; border-radius:10px; background:var(--brand-50); color:var(--brand-600); display:grid; place-items:center; font-size:17px; flex-shrink:0; }
.cmdk-item .tx{ flex:1; min-width:0; }
.cmdk-item .tx b{ display:block; font-size:14px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cmdk-item .tx span{ font-size:11.5px; color:var(--ink-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; }
.cmdk-item .go{ color:var(--ink-faint); font-size:13px; opacity:0; }
.cmdk-item.active{ background:linear-gradient(90deg,var(--brand-50),transparent); }
.cmdk-item.active .ic{ background:linear-gradient(135deg,var(--brand-400),var(--brand-600)); color:#fff; box-shadow:0 6px 14px rgba(16,185,129,.35); }
.cmdk-item.active .go{ opacity:1; color:var(--brand-600); }
.cmdk-empty{ text-align:center; padding:40px 20px; color:var(--ink-muted); }
.cmdk-empty i{ font-size:38px; color:var(--ink-faint); display:block; margin-bottom:10px; }
.cmdk-foot{ display:flex; align-items:center; gap:16px; padding:10px 16px; border-top:1px solid var(--line); font-size:11.5px; color:var(--ink-faint); }
.cmdk-foot kbd{ font-size:10px; padding:1px 5px; border-radius:5px; background:var(--bg-soft); border:1px solid var(--line-strong); margin-right:2px; }
.cmdk-foot .ml-auto{ margin-left:auto; font-weight:700; color:var(--brand-600); }
@media(max-width:540px){ .cmdk-box{ top:0; left:0; transform:none; width:100%; max-height:100vh; height:100dvh; border-radius:0; } .cmdk.open .cmdk-box{ transform:none; } }

/* ── Top navigation progress bar ───────────────────────────── */
#navProgress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:9999; background:linear-gradient(90deg,var(--brand-400),var(--brand-600)); box-shadow:0 0 10px var(--brand-400); transition:width .25s var(--ease),opacity .3s; opacity:0; }
#navProgress.go{ opacity:1; }

/* ── Page enter stagger ────────────────────────────────────── */
.page > section, .page > .card, .page-outlet > .hero, .kpi-grid > .kpi, .dash-row > .card, .dash-row-2 > .card{ animation:enterUp .5s var(--ease) both; }
.kpi-grid > .kpi:nth-child(2){ animation-delay:.05s; } .kpi-grid > .kpi:nth-child(3){ animation-delay:.1s; }
.kpi-grid > .kpi:nth-child(4){ animation-delay:.15s; } .kpi-grid > .kpi:nth-child(5){ animation-delay:.2s; } .kpi-grid > .kpi:nth-child(6){ animation-delay:.25s; }
@keyframes enterUp{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:translateY(0); } }
@media (prefers-reduced-motion:reduce){ .page > section,.page > .card,.kpi-grid > .kpi,.dash-row > .card,.dash-row-2 > .card{ animation:none; } }

/* ── Quantum Spinner ───────────────────────────────────────── */
.q-spinner{ position:fixed; inset:0; z-index:200; display:grid; place-items:center; background:rgba(15,23,42,.55); backdrop-filter:blur(6px); opacity:0; transition:.25s; }
.q-spinner.show{ opacity:1; }
.q-spinner-box{ text-align:center; color:#fff; }
.q-orbit{ width:74px; height:74px; margin:0 auto 18px; position:relative; }
.q-orbit span{ position:absolute; inset:0; border-radius:50%; border:3px solid transparent; }
.q-orbit span:nth-child(1){ border-top-color:var(--brand-300); animation:spin 1s linear infinite; }
.q-orbit span:nth-child(2){ border-right-color:var(--gold-400); inset:9px; animation:spin 1.4s linear infinite reverse; }
.q-orbit span:nth-child(3){ border-bottom-color:#fff; inset:18px; animation:spin .8s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.q-spinner-title{ font-family:"Kanit"; font-weight:600; font-size:17px; }
.q-spinner-stage{ font-size:13px; color:#bbf7d0; margin-top:5px; min-height:18px; }

/* ── Mobile bottom nav ─────────────────────────────────────── */
.m-bottom-nav{ display:none; }
.sidebar-backdrop{ display:none; }
@media(max-width:900px){
  :root{ --sidebar-w:0px; }
  .sidebar{ position:fixed; left:0; top:0; transform:translateX(-100%); transition:transform .3s var(--ease); width:264px; z-index:120; }
  .sidebar.mobile-open{ transform:translateX(0); }
  .sidebar-backdrop{ display:block; position:fixed; inset:0; z-index:110; background:rgba(15,23,42,.55); backdrop-filter:blur(3px); opacity:0; visibility:hidden; transition:.3s var(--ease); }
  .sidebar-backdrop.show{ opacity:1; visibility:visible; }
  .nav-toggle{ display:flex; }
  .nav-search{ display:none; }
  .nav-page-text p{ display:none; }
}
@media(max-width:900px){
  .m-bottom-nav{ position:fixed; bottom:0; left:0; right:0; z-index:50; display:flex; justify-content:space-around; align-items:center;
    background:rgba(255,255,255,.96); backdrop-filter:blur(20px); border-top:1px solid var(--line);
    padding:6px 0 calc(6px + env(safe-area-inset-bottom)); }
  .m-nav-item{ display:flex; flex-direction:column; align-items:center; gap:2px; padding:6px 10px; min-width:58px; min-height:44px; color:var(--ink-muted); font-size:10.5px; position:relative; }
  .m-nav-item i{ font-size:20px; }
  .m-nav-item.is-active{ color:var(--brand-700); }
  .m-nav-item.is-active::before{ content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:24px; height:3px; background:var(--gold-400); border-radius:0 0 4px 4px; }
  .m-nav-fab{ margin-top:-24px; }
  .m-nav-fab .fab{ width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,var(--brand-400),var(--brand-600)); color:#fff; display:grid; place-items:center; font-size:24px; box-shadow:0 8px 20px rgba(16,185,129,.5); border:4px solid #fff; }
  .nav-pill.online span:not(.dot), .nav-clock{ display:none; }
}
@media(max-width:900px){ .main{ padding-bottom:0; } .page{ padding-bottom:96px; } }

@media print{
  .sidebar,.navbar,.app-footer,.sd-no-print,.toolbar,.m-bottom-nav{ display:none !important; }
  .main{ display:block; } .page{ padding:0; max-width:100%; }
  body{ background:#fff; }
  .card{ box-shadow:none; border:1px solid #ddd; break-inside:avoid; }
}

/* ── Product modal: wholesale & pack box ── */
.pwp-box{ border:1px dashed var(--line-strong,#cbd5e1); border-radius:14px; padding:10px 14px; background:linear-gradient(180deg,#fbfdfe,#f6faf8); }
.pwp-box > summary{ cursor:pointer; font-family:"Kanit"; font-weight:600; font-size:13.5px; color:var(--brand-700); display:flex; align-items:center; gap:8px; list-style:none; user-select:none; }
.pwp-box > summary::-webkit-details-marker{ display:none; }
.pwp-box > summary::after{ content:"\F282"; font-family:"bootstrap-icons"; margin-left:auto; transition:transform .2s var(--ease); color:var(--ink-faint); }
.pwp-box[open] > summary::after{ transform:rotate(180deg); }
.pwp-box[open] > summary{ margin-bottom:10px; }
.pwp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px 12px; }
@media(max-width:640px){ .pwp-grid{ grid-template-columns:1fr; } }
:root[data-mode="dark"] .pwp-box{ background:var(--surface); border-color:var(--line); }

/* ── Shift close: cash denomination counter ── */
.cash-denom{ border:1px solid var(--line); border-radius:14px; padding:10px 14px; background:var(--bg-soft); }
.cash-denom > summary{ cursor:pointer; font-family:"Kanit"; font-weight:600; font-size:13.5px; color:var(--brand-700); list-style:none; display:flex; align-items:center; gap:8px; }
.cash-denom > summary::-webkit-details-marker{ display:none; }
.cash-denom > summary::after{ content:"\F282"; font-family:"bootstrap-icons"; margin-left:auto; color:var(--ink-faint); transition:transform .2s var(--ease); }
.cash-denom[open] > summary::after{ transform:rotate(180deg); }
.denom-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:7px 14px; margin-top:12px; }
@media(max-width:540px){ .denom-grid{ grid-template-columns:1fr; } }
.denom-row{ display:flex; align-items:center; gap:8px; }
.denom-face{ font-family:"Kanit"; font-weight:600; min-width:52px; color:var(--ink); }
.denom-row[data-type="coin"] .denom-face{ color:var(--gold-600); }
.denom-x{ color:var(--ink-faint); }
.denom-count{ width:64px; text-align:center; padding:6px 4px !important; }
.denom-sub{ margin-left:auto; font-variant-numeric:tabular-nums; color:var(--ink-soft); font-size:12.5px; min-width:54px; text-align:right; }
.denom-total{ margin-top:10px; padding-top:9px; border-top:1px dashed var(--line); text-align:right; font-size:13.5px; }
.denom-total b{ font-family:"Kanit"; color:var(--brand-700); font-size:16px; }
:root[data-mode="dark"] .cash-denom{ background:var(--surface); }

/* ── Favorite (สินค้าขายบ่อย) star toggle ── */
.btn-icon.is-fav{ color:var(--gold-500); }
.btn-icon.is-fav i{ filter:drop-shadow(0 1px 3px rgba(245,158,11,.4)); }

/* ── Happy Hour: day-of-week picker chips ── */
.dow-chip{ cursor:pointer; user-select:none; }
.dow-chip span{ display:grid; place-items:center; min-width:42px; height:38px; padding:0 6px; border-radius:11px;
  border:1.5px solid var(--line); background:#fff; font-family:"Kanit"; font-weight:600; font-size:13px; color:var(--ink-soft); transition:.15s var(--ease); }
.dow-chip:hover span{ border-color:var(--brand-300); }
.dow-chip.on span{ background:linear-gradient(135deg,var(--brand-500),var(--brand-700)); color:#fff; border-color:transparent; box-shadow:0 4px 12px -4px rgba(16,185,129,.5); }
:root[data-mode="dark"] .dow-chip span{ background:var(--surface); }
