/* ── RESET & VARIABLES ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary:    #1e3a5f;
  --primary-dark: #152d4a;
  --primary-light: #e8f0fb;
  --accent:     #059669;
  --accent-dark: #047857;
  --red:        #c0392b;
  --red-dark:   #8e1c11;
  --red-light:  #e74c3c;
  --sidebar-bg: #ffffff;
  --sidebar-w:  260px;
  --topbar-h:   58px;
  --body-bg:    #f8fafc;
  --card-bg:    #ffffff;
  --text:       #1e293b;
  --muted:      #64748b;
  --border:     #e2e8f0;
  --radius:     8px;
  --shadow:     0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --shadow-md:  0 4px 12px rgba(0,0,0,.10);
  --tr:         .2s ease;
  --blue-bg:#dbeafe; --blue-fg:#2563eb;
  --teal-bg:#d1fae5; --teal-fg:#059669;
  --orange-bg:#ffedd5; --orange-fg:#ea580c;
  --yellow-bg:#fef9c3; --yellow-fg:#ca8a04;
  --pink-bg:#fce7f3;  --pink-fg:#db2777;
  --red-card-bg:#fee2e2; --red-card-fg:#dc2626;
}

html, body {
  height: 100%;
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  font-size: 14px; color: var(--text); background: var(--body-bg);
}
a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font: inherit; }
ul { list-style: none; }
.hidden { display: none !important; }

/* ── LAYOUT ── */
.layout { display: flex; height: 100vh; overflow: hidden; }

/* ══════════════════════════════════
   SIDEBAR  — white / navy
══════════════════════════════════ */
.sidebar {
  width: var(--sidebar-w); flex-shrink: 0;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow-y: auto; overflow-x: hidden;
  transition: width var(--tr);
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
  box-shadow: 2px 0 8px rgba(0,0,0,.04);
}
.sidebar.collapsed { width: 64px; }
.sidebar.collapsed .sidebar-brand span:last-child,
.sidebar.collapsed .nav-link > span,
.sidebar.collapsed .arrow,
.sidebar.collapsed .sub-menu { display: none; }
.sidebar.collapsed .sidebar-brand { justify-content: center; }
.sidebar.collapsed .nav-link { justify-content: center; padding: 12px 0; }

/* Brand strip */
.sidebar-brand {
  background: var(--primary);
  color: #fff;
  display: flex; align-items: center; gap: 10px;
  padding: 0 18px; height: var(--topbar-h);
  font-weight: 800; font-size: 15px; letter-spacing: .6px;
  flex-shrink: 0;
}
.brand-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 6px rgba(5,150,105,.5);
  flex-shrink: 0;
}

/* Nav */
.sidebar-nav { padding: 10px 0; flex: 1; }

.nav-link {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 16px; border-radius: 8px; margin: 2px 8px;
  color: var(--muted); font-size: 13.5px;
  transition: background var(--tr), color var(--tr);
  white-space: nowrap;
}
.nav-link:hover { background: var(--primary-light); color: var(--primary); }

.nav-item.active > .nav-link {
  background: var(--primary-light);
  color: var(--primary);
  font-weight: 700;
  border-left: 3px solid var(--accent);
  padding-left: 13px;
}

.nav-icon { font-size: 15px; width: 18px; text-align: center; flex-shrink: 0; }
.arrow { margin-left: auto; font-size: 11px; color: var(--border); transition: transform var(--tr); }
.nav-item.open > .nav-link .arrow { transform: rotate(-90deg); }

/* Sub-menu */
.sub-menu { display: none; padding: 2px 0 4px 42px; }
.nav-item.open > .sub-menu { display: block; }
.sub-menu li a {
  display: block; padding: 7px 12px; font-size: 13px;
  color: var(--muted); border-radius: 6px;
  transition: background var(--tr), color var(--tr);
}
.sub-menu li a:hover { background: var(--primary-light); color: var(--primary); }

/* ── MAIN AREA ── */
.main-area { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

/* ══════════════════════════════════
   TOP BAR  — white / clean
══════════════════════════════════ */
.topbar {
  background: #fff;
  height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 22px; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.topbar-left, .topbar-right { display: flex; align-items: center; gap: 6px; }

.icon-btn {
  color: var(--muted);
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; transition: background var(--tr);
}
.icon-btn:hover { background: var(--primary-light); color: var(--primary); }

.pos-pill {
  width: auto; padding: 0 14px; gap: 6px;
  font-weight: 700; font-size: 13px;
  border: 1.5px solid var(--border); border-radius: 8px;
  color: var(--primary);
}

.topbar-date { display: flex; align-items: center; gap: 7px; color: var(--muted); font-size: 13px; padding: 0 6px; }

.notif-btn { position: relative; }
.badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--accent); color: #fff;
  font-size: 9px; font-weight: 800;
  width: 14px; height: 14px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}

.user-chip {
  display: flex; align-items: center; gap: 8px;
  color: var(--text); padding: 4px 12px 4px 4px;
  border-radius: 20px; cursor: pointer;
  border: 1px solid var(--border);
  transition: background var(--tr);
}
.user-chip:hover { background: var(--primary-light); }
.avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--primary);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px;
}

/* ── CONNECTION MODE BUTTONS ── */
.conn-mode-group {
  display: flex; align-items: center; gap: 2px;
  background: var(--body-bg); border-radius: 8px; padding: 3px;
  border: 1px solid var(--border);
}
.conn-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 10px; border: none; border-radius: 6px;
  font-size: 12px; font-weight: 600; cursor: pointer;
  color: var(--muted); background: transparent;
  transition: background .16s, color .16s; white-space: nowrap; line-height: 1; position: relative;
}
.conn-btn span { font-size: 11px; letter-spacing: .2px; }
.conn-btn:hover { background: #fff; color: var(--primary); }
.conn-online.conn-active  { background: #16a34a; color: #fff; box-shadow: 0 1px 5px rgba(22,163,74,.45); }
.conn-offline.conn-active { background: #dc2626; color: #fff; box-shadow: 0 1px 5px rgba(220,38,38,.45); }
.conn-sync.conn-sync-active { background: var(--primary); color: #fff; }
.conn-sync-badge {
  position: absolute; top: -4px; right: -4px;
  background: #f59e0b; color: #fff; font-size: 9px; font-weight: 800;
  min-width: 15px; height: 15px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; padding: 0 3px;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.conn-sync-badge.hidden { display: none; }
@keyframes conn-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.conn-sync-spinning i { animation: conn-spin .7s linear; }

/* ── PAGE CONTENT ── */
.page-content { flex: 1; overflow-y: auto; display: flex; flex-direction: column; }

/* ══════════════════════════════════
   DASHBOARD
══════════════════════════════════ */
.welcome-banner {
  background: linear-gradient(135deg, var(--primary) 0%, #2a5298 100%);
  padding: 26px 30px 22px;
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 14px;
}
.welcome-heading { color: #fff; font-size: 26px; font-weight: 800; }
.banner-filters { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

.filter-select {
  padding: 8px 14px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12); color: #fff;
  font-size: 13px; min-width: 180px; outline: none;
}
.filter-select option { color: #1a1a1a; background: #fff; }

#dash-date-bar {
  background: rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(255,255,255,.12);
  padding: 9px 30px;
}
#dash-date-bar .df-label { color: rgba(255,255,255,.85); }
#dash-date-bar .df-drop-btn {
  background: rgba(255,255,255,.12); color: rgba(255,255,255,.9);
  border-color: rgba(255,255,255,.3);
}
#dash-date-bar .df-drop-btn:hover,
#dash-date-bar .df-drop-btn.open {
  background: rgba(255,255,255,.22); color: #fff; border-color: rgba(255,255,255,.7);
}
#dash-date-bar .df-date-input {
  background: rgba(255,255,255,.15); color: #fff; border-color: rgba(255,255,255,.4);
}
#dash-date-bar .df-date-input:focus { border-color: #fff; box-shadow: none; }
#dash-date-bar .df-sep { color: rgba(255,255,255,.7); }
#dash-date-bar .df-go-btn { background: #fff; color: var(--primary); }
#dash-date-bar .df-go-btn:hover { background: var(--primary-light); }

.cards-section { background: linear-gradient(135deg, var(--primary) 0%, #2a5298 100%); padding: 0 30px 28px; }

.cards-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }

.card {
  background: #fff; border-radius: 12px;
  padding: 18px 20px;
  display: flex; align-items: center; gap: 16px;
  box-shadow: 0 4px 14px rgba(0,0,0,.1);
  transition: transform var(--tr), box-shadow var(--tr);
}
.card:hover { transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,.15); }

.card-icon-wrap {
  width: 50px; height: 50px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.card-icon-wrap.blue   { background: var(--blue-bg);     color: var(--blue-fg); }
.card-icon-wrap.teal   { background: var(--teal-bg);     color: var(--teal-fg); }
.card-icon-wrap.orange { background: var(--orange-bg);   color: var(--orange-fg); }
.card-icon-wrap.yellow { background: var(--yellow-bg);   color: var(--yellow-fg); }
.card-icon-wrap.pink   { background: var(--pink-bg);     color: var(--pink-fg); }
.card-icon-wrap.red    { background: var(--red-card-bg); color: var(--red-card-fg); }

.card-label { font-size: 12px; color: var(--muted); margin-bottom: 4px; display: flex; align-items: center; gap: 4px; }
.info-i { font-size: 11px; color: #93c5fd; }
.card-value { font-size: 19px; font-weight: 800; color: var(--text); }

.chart-section { padding: 24px 30px; flex: 1; background: var(--body-bg); }
.chart-card {
  background: #fff; border-radius: 14px;
  box-shadow: var(--shadow); padding: 22px 26px 26px;
}
.chart-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.chart-title-wrap { display: flex; align-items: center; gap: 10px; }
.chart-icon-circle {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--blue-bg); color: var(--blue-fg);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px;
}
.chart-header h3 { font-size: 16px; font-weight: 700; }
.chart-menu-btn { color: var(--muted); font-size: 16px; padding: 4px 8px; border-radius: 6px; }
.chart-menu-btn:hover { background: #f3f4f6; }
.chart-wrap { position: relative; height: 300px; }
.chart-toggle-group { display: flex; border: 1px solid #e2e8f0; border-radius: 8px; overflow: hidden; }
.chart-toggle-btn { padding: 5px 13px; font-size: 12px; font-weight: 600; color: #64748b; background: #fff; border: none; cursor: pointer; transition: background .15s, color .15s; }
.chart-toggle-btn:hover { background: #f1f5f9; color: #1e293b; }
.chart-toggle-btn.active { background: #2563eb; color: #fff; }

/* ══════════════════════════════════
   CASHIER HOME (POS-style)
══════════════════════════════════ */
.ch-wrap { display: flex; height: calc(100vh - 60px); overflow: hidden; background: #f1f5f9; }
.ch-left { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 18px; }
.ch-right { width: 340px; background: #fff; border-left: 1px solid #e2e8f0; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 6px; flex-shrink: 0; }

/* topbar */
.ch-topbar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.ch-search-wrap { flex: 1; position: relative; min-width: 220px; }
.ch-search-inp { width: 100%; padding: 11px 14px 11px 38px; border: 1.5px solid #e2e8f0; border-radius: 10px; font-size: 14px; background: #fff; outline: none; box-sizing: border-box; transition: border-color .15s; }
.ch-search-inp:focus { border-color: #2563eb; }
.ch-search-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: #9ca3af; font-size: 13px; }
.ch-search-ac { position: absolute; top: calc(100% + 4px); left: 0; right: 0; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,.12); z-index: 200; }
.ch-search-item { padding: 10px 14px; cursor: pointer; font-size: 13px; border-bottom: 1px solid #f3f4f6; }
.ch-search-item:last-child { border-bottom: none; }
.ch-search-item:hover { background: #f8fafc; }
.ch-topbar-meta { display: flex; flex-direction: column; align-items: flex-end; flex-shrink: 0; }
.ch-topbar-date { font-size: 12px; color: #6b7280; }
.ch-topbar-time { font-size: 17px; font-weight: 700; color: #111827; }

/* sections */
.ch-section { background: #fff; border-radius: 14px; padding: 18px 18px 16px; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.ch-section-title { font-size: 14px; font-weight: 700; color: #374151; margin-bottom: 14px; }

/* quick action tiles */
.ch-qa-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 700px) { .ch-qa-grid { grid-template-columns: repeat(2, 1fr); } }
.ch-qa-tile { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 16px 8px 12px; border-radius: 12px; border: 1.5px solid #f1f5f9; cursor: pointer; transition: border-color .15s, box-shadow .15s, transform .12s; background: #fafafa; }
.ch-qa-tile:hover { border-color: #bfdbfe; box-shadow: 0 4px 14px rgba(37,99,235,.10); transform: translateY(-2px); }
.ch-qa-icon { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 20px; }
.ch-qa-label { font-size: 12px; font-weight: 600; color: #374151; text-align: center; }

/* categories */
.ch-cat-row { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; flex-wrap: nowrap; }
.ch-cat-row::-webkit-scrollbar { height: 4px; } .ch-cat-row::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 4px; }
.ch-cat-pill { display: flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: 20px; border: 1.5px solid #e2e8f0; background: #fff; font-size: 12px; font-weight: 600; color: #374151; cursor: pointer; white-space: nowrap; transition: all .15s; flex-shrink: 0; }
.ch-cat-pill:hover { border-color: #93c5fd; color: #1d4ed8; }
.ch-cat-pill.active { background: #2563eb; color: #fff; border-color: #2563eb; }
.ch-cat-products { margin-top: 12px; }
.ch-prod-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; }
.ch-prod-card { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; padding: 10px; cursor: pointer; transition: border-color .15s; }
.ch-prod-card:hover { border-color: #93c5fd; }
.ch-prod-name { font-size: 11px; font-weight: 600; color: #1e293b; margin-bottom: 4px; line-height: 1.3; }
.ch-prod-price { font-size: 13px; font-weight: 700; color: #2563eb; }

/* right panel */
.ch-right-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 10px; }
.ch-right-title { font-size: 14px; font-weight: 700; color: #374151; margin-bottom: 10px; }
.ch-period-sel { border: 1.5px solid #e2e8f0; border-radius: 8px; padding: 5px 10px; font-size: 13px; color: #374151; cursor: pointer; outline: none; background: #fff; }
.ch-period-sel:focus { border-color: #2563eb; }
.ch-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.ch-stat-card { background: #f8fafc; border-radius: 12px; padding: 14px 12px; display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
.ch-stat-icon { width: 36px; height: 36px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 15px; }
.ch-stat-val { font-size: 16px; font-weight: 800; color: #111827; }
.ch-stat-label { font-size: 11px; font-weight: 600; color: #374151; }
.ch-stat-sub { font-size: 10px; color: #6b7280; }

/* transactions */
.ch-txn-list { display: flex; flex-direction: column; gap: 2px; }
.ch-txn-row { display: flex; align-items: center; gap: 10px; padding: 10px 8px; border-radius: 10px; transition: background .12s; cursor: default; }
.ch-txn-row:hover { background: #f8fafc; }
.ch-txn-icon { width: 34px; height: 34px; background: #dbeafe; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.ch-txn-info { flex: 1; min-width: 0; }
.ch-txn-ref { font-size: 12px; font-weight: 700; color: #1e293b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-txn-meta { font-size: 11px; color: #6b7280; }
.ch-txn-amt { font-size: 13px; font-weight: 700; color: #111827; }
.ch-pay-badge { font-size: 10px; font-weight: 600; padding: 2px 6px; border-radius: 4px; }
.ch-badge-paid { background: #dcfce7; color: #15803d; }
.ch-badge-due { background: #fee2e2; color: #b91c1c; }
.ch-badge-partial { background: #fef9c3; color: #a16207; }

/* ══════════════════════════════════
   DYNAMIC PAGES
══════════════════════════════════ */
#view-dynamic { padding: 24px 28px; flex: 1; }

.page-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px;
}
.page-title { font-size: 21px; font-weight: 800; color: var(--text); }

.btn-add {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--accent); color: #fff;
  padding: 9px 22px; border-radius: 8px;
  font-size: 13.5px; font-weight: 700;
  box-shadow: 0 3px 10px rgba(5,150,105,.25);
  transition: background var(--tr), box-shadow var(--tr);
}
.btn-add:hover { background: var(--accent-dark); box-shadow: 0 4px 14px rgba(5,150,105,.35); }

/* ══════════════════════════════════
   TABLE CARD
══════════════════════════════════ */
.table-card {
  background: #fff; border-radius: 14px;
  box-shadow: var(--shadow); overflow: hidden;
}

.table-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  flex-wrap: wrap; gap: 10px;
}
.table-toolbar-left { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

.show-entries { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); }
.show-entries select { padding: 4px 8px; border: 1px solid var(--border); border-radius: 6px; font-size: 13px; }

.export-btns { display: flex; gap: 6px; flex-wrap: wrap; }
.export-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 6px;
  border: 1px solid var(--border); font-size: 12px;
  color: var(--muted); background: #fff;
  transition: background var(--tr), color var(--tr);
}
.export-btn:hover { background: var(--primary-light); color: var(--primary); border-color: #bfdbfe; }
.col-vis-btn { gap: 6px; }
.col-vis-btn i { color: #6b7280; }
.col-vis-btn:hover i { color: var(--primary); }

/* ── DATE FILTER BAR ── */
.date-filter-bar {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
  padding: 10px 16px; border-bottom: 1px solid var(--border);
  background: var(--body-bg);
}

/* dropdown trigger */
.df-drop-wrap { position: relative; }
.df-drop-btn {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 7px 14px; border-radius: 8px;
  border: 1.5px solid var(--border); background: #fff;
  color: var(--text); font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all var(--tr); white-space: nowrap;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.df-drop-btn i.fa-calendar-days { color: var(--muted); font-size: 14px; }
.df-drop-btn:hover, .df-drop-btn.open { border-color: var(--primary); color: var(--primary); }
.df-drop-btn:hover i.fa-calendar-days,
.df-drop-btn.open  i.fa-calendar-days { color: var(--primary); }
.df-caret { font-size: 11px; color: var(--muted); transition: transform var(--tr); }
.df-drop-btn.open .df-caret { transform: rotate(180deg); color: var(--primary); }

/* dropdown menu */
.df-drop-menu {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 400;
  background: #fff; border-radius: 10px;
  border: 1px solid var(--border); border-top: 3px solid var(--primary);
  box-shadow: 0 8px 28px rgba(0,0,0,.13);
  min-width: 230px; padding: 4px 0; list-style: none;
}
.df-opt {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 16px; font-size: 13px; cursor: pointer;
  transition: background var(--tr), color var(--tr);
}
.df-opt:hover { background: var(--primary-light); color: var(--primary); }
.df-opt.active { color: var(--primary); font-weight: 700; }
.df-check { font-size: 11px; color: var(--primary); }

.df-range-wrap {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  width: 100%; padding: 8px 0 2px;
}
.df-range-wrap.hidden { display: none; }
.df-date-input {
  padding: 6px 10px; border: 1.5px solid var(--border);
  border-radius: 7px; font-size: 13px; color: var(--text);
  background: #fff; outline: none; transition: border-color var(--tr);
}
.df-date-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(30,58,95,.08); }
.df-sep { color: var(--muted); font-weight: 700; font-size: 14px; }
.df-go-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 14px; background: var(--primary); color: #fff;
  border-radius: 7px; font-size: 13px; font-weight: 700;
  transition: background var(--tr);
}
.df-go-btn:hover { background: var(--primary-dark); }

/* ── COLUMN VISIBILITY PANEL ── */
/* Generic column visibility panel (works on any table) */
.gcv-panel { min-width: 220px; }
.gcv-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px 7px; border-bottom: 1px solid var(--border);
  font-size: 13px; font-weight: 700; color: #1e293b;
}
.gcv-close {
  background: none; border: none; color: #9ca3af; font-size: 13px;
  cursor: pointer; padding: 2px 5px; border-radius: 5px; transition: var(--tr);
}
.gcv-close:hover { background: #f1f5f9; color: #1e293b; }

.col-vis-wrap { position: relative; }
.col-vis-panel {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 300;
  background: #fff; border-radius: 10px;
  border: 1px solid var(--border); border-top: 3px solid var(--primary);
  box-shadow: 0 8px 24px rgba(0,0,0,.13);
  padding: 6px 0; min-width: 210px;
  max-height: 340px; overflow-y: auto;
}
.col-vis-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; cursor: pointer; font-size: 13px; font-weight: 500;
  transition: background var(--tr), color var(--tr);
  user-select: none;
}
.col-vis-item:hover { background: var(--primary-light); color: var(--primary); }
.col-vis-item input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--accent);
  cursor: pointer; flex-shrink: 0;
}

.table-search input {
  padding: 7px 14px; border: 1px solid var(--border);
  border-radius: 8px; font-size: 13px; outline: none;
  width: 220px; transition: border-color var(--tr);
}
.table-search input:focus { border-color: var(--primary); }

/* Table */
.table-wrap { overflow-x: auto; }
.table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.data-table { width: 100%; border-collapse: collapse; min-width: 600px; }
.data-table th {
  background: var(--primary-light); padding: 11px 14px;
  text-align: left; font-size: 13px; font-weight: 700;
  color: var(--text); border-bottom: 2px solid var(--border);
  white-space: nowrap;
}
.data-table td {
  padding: 12px 14px; font-size: 13.5px;
  border-bottom: 1px solid var(--border);
  color: var(--text); vertical-align: middle;
}
.data-table tbody tr:hover { background: #f8fafc; }
.data-table tbody tr:last-child td { border-bottom: none; }
.sort-icon { font-size: 10px; color: #d1d5db; margin-left: 4px; }

/* Status badges */
.status-badge {
  display: inline-block; padding: 3px 10px;
  border-radius: 20px; font-size: 11.5px; font-weight: 700;
}
.status-active   { background: #d1fae5; color: #065f46; }
.status-inactive { background: #fee2e2; color: #991b1b; }
.status-paid     { background: #d1fae5; color: #065f46; }
.status-due      { background: #fef9c3; color: #92400e; }
.status-pending  { background: #e0f2fe; color: #0369a1; }
.status-completed{ background: #d1fae5; color: #065f46; }
.status-received { background: #d1fae5; color: #065f46; }

/* Action buttons */
.action-cell { white-space: nowrap; }
.actions { display: flex; gap: 5px; flex-wrap: wrap; }
.btn-action {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 6px;
  font-size: 12px; font-weight: 600; transition: opacity var(--tr);
}
.btn-action:hover { opacity: .82; }
.btn-edit       { background: #eff6ff; color: #2563eb; border: 1px solid #bfdbfe; }
.btn-view       { background: #ecfdf5; color: #059669; border: 1px solid #a7f3d0; }
.btn-delete     { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.btn-deactivate { background: #fff7ed; color: #ea580c; border: 1px solid #fed7aa; }
.btn-activate   { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }

.table-footer {
  padding: 12px 16px; font-size: 13px; color: var(--muted);
  border-top: 1px solid var(--border);
}

.empty-state { text-align: center; padding: 60px 20px; color: var(--muted); }
.empty-state i { font-size: 48px; margin-bottom: 14px; display: block; color: #94a3b8; }
.empty-state p { font-size: 15px; }

/* Placeholder page */
.placeholder-page {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; min-height: 60vh; text-align: center; color: var(--muted);
}
.placeholder-icon { font-size: 60px; margin-bottom: 16px; color: #94a3b8; }
.placeholder-page h2 { font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 8px; }

/* ══════════════════════════════════
   MODALS
══════════════════════════════════ */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000; padding: 20px;
}
.modal {
  background: #fff; border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0,0,0,.2);
  width: 100%; max-width: 540px; max-height: 90vh;
  display: flex; flex-direction: column; overflow: hidden;
}
.confirm-modal   { max-width: 400px; }
.quick-add-modal { max-width: 380px; }
.qa-form { display: flex; flex-direction: column; gap: 2px; }
.btn-qa-save {
  display: flex; align-items: center; gap: 6px;
  background: #16a34a; color: #fff;
  padding: 9px 20px; border-radius: 8px;
  font-size: 13.5px; font-weight: 700; cursor: pointer; border: none;
  transition: background .15s;
}
.btn-qa-save:hover { background: #15803d; }

/* Business Location multi-select */
.pf-loc-wrap {
  border: 1.5px solid var(--border); border-radius: 8px;
  overflow: hidden;
}
.pf-loc-list {
  display: flex; flex-direction: column; gap: 0;
  max-height: 130px; overflow-y: auto; padding: 6px 0;
}
.pf-loc-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 12px; cursor: pointer; font-size: 13px;
  transition: background .12s;
}
.pf-loc-item:hover { background: #f0fdf4; }
.pf-loc-item input[type=checkbox] { accent-color: #16a34a; width: 15px; height: 15px; }
.pf-loc-name { font-weight: 500; color: #1f2937; }
.btn-pf-loc-add {
  display: flex; align-items: center; gap: 6px;
  width: 100%; padding: 8px 12px;
  border-top: 1px dashed var(--border);
  background: #f8fafb; color: #16a34a;
  font-size: 12.5px; font-weight: 700; cursor: pointer;
  border-left: none; border-right: none; border-bottom: none;
  transition: background .12s;
}
.btn-pf-loc-add:hover { background: #f0fdf4; }
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
}
.modal-header h3 { font-size: 16px; font-weight: 800; display: flex; align-items: center; gap: 8px; }
.modal-close {
  color: var(--muted); font-size: 18px; width: 32px; height: 32px;
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
}
.modal-close:hover { background: var(--primary-light); color: var(--primary); }
.modal-body { padding: 20px 22px; overflow-y: auto; flex: 1; }
.modal-footer {
  display: flex; align-items: center; justify-content: flex-end;
  gap: 10px; padding: 16px 22px; border-top: 1px solid var(--border);
}

/* Forms */
.form-group { margin-bottom: 16px; }
.form-label { display: block; font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.required { color: var(--red); }
.form-input {
  width: 100%; padding: 9px 12px;
  border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 14px; color: var(--text); outline: none;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.form-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(30,58,95,.1); }
.form-input.input-error { border-color: var(--red); box-shadow: 0 0 0 3px rgba(192,57,43,.12); }
.form-textarea { resize: vertical; min-height: 80px; }

/* ── PRODUCT MODAL ── */
.modal-product { max-width: 920px !important; }
/* ── VIEW / PRINT MODAL ── */
.modal-view { max-width: min(1100px, 96vw) !important; max-height: 92vh; }
.modal-product .modal-body { padding: 20px 26px; }

/* 3-column grid */
.pform-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 20px;
}

/* info icon next to label */
.pf-info-icon { color: #3b82f6; font-size: 13px; margin-left: 4px; cursor: help; }

/* field + add-button row */
.pf-with-add { display: flex; align-items: center; gap: 8px; }
.pf-with-add .form-input { flex: 1; }
.btn-pf-add {
  flex-shrink: 0; width: 32px; height: 36px;
  border-radius: 50%; background: #2563eb; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; cursor: pointer; border: none;
  transition: background .15s;
}
.btn-pf-add:hover { background: #1d4ed8; }

/* currency input */
.pf-currency-wrap { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.pf-currency-wrap:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(30,58,95,.1); }
.pf-curr { padding: 0 10px; background: #f3f4f6; color: var(--muted); font-weight: 700; font-size: 14px; border-right: 1px solid var(--border); height: 100%; display: flex; align-items: center; white-space: nowrap; }
.pf-curr-input { border: none !important; box-shadow: none !important; border-radius: 0 !important; }

/* Manage Stock row */
.pf-manage-stock-row {
  display: flex; align-items: flex-start; gap: 30px;
  margin: 4px 0 20px; padding: 14px 16px;
  background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px;
}
.pf-manage-stock-left { flex: 1; }
.pf-check-label {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  font-weight: 700; font-size: 13.5px; color: var(--text);
}
.pf-check-label input[type=checkbox] { display: none; }
.pf-check-box {
  width: 20px; height: 20px; border-radius: 5px; border: 2px solid #3b82f6;
  background: #fff; flex-shrink: 0; position: relative; transition: background .15s;
}
.pf-check-label input:checked ~ .pf-check-box { background: #2563eb; border-color: #2563eb; }
.pf-check-label input:checked ~ .pf-check-box::after {
  content: ''; position: absolute; left: 4px; top: 1px;
  width: 8px; height: 12px; border: 2px solid #fff;
  border-top: none; border-left: none; transform: rotate(45deg);
}
.pf-check-hint { font-size: 12px; color: var(--muted); margin: 4px 0 0 30px; font-style: italic; }
.pf-alert-qty { flex: 1; margin-bottom: 0; }

/* Section divider */
.pf-section-title {
  font-size: 13px; font-weight: 800; color: var(--text);
  letter-spacing: .04em; text-transform: uppercase;
  border-bottom: 2px solid #f1f5f9; padding-bottom: 8px;
  margin: 4px 0 16px;
}

/* ── Variable Product — POS Variant Picker ── */
.pvp-list { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.pvp-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border: 1px solid #e2e8f0; border-radius: 10px;
  cursor: pointer; transition: background .15s, border-color .15s;
}
.pvp-row:hover { background: #eff6ff; border-color: #93c5fd; }
.pvp-info { display: flex; flex-direction: column; gap: 3px; }
.pvp-name { font-size: 15px; font-weight: 700; color: #1e293b; }
.pvp-conv { font-size: 12px; color: #6b7280; }
.pvp-right { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.pvp-price { font-size: 14px; font-weight: 700; color: #059669; }
.pvp-stock { font-size: 12px; color: #9ca3af; }
/* Variable product card badge */
.pos-prod-variable { border-color: #fbbf24 !important; }
.pos-prod-var-badge {
  font-size: 10px; color: #d97706; font-weight: 700; margin-top: 2px;
  display: flex; align-items: center; gap: 3px; justify-content: center;
}

/* ── Variable Product Variants ── */
.pf-var-hint {
  background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 8px;
  padding: 10px 14px; font-size: 12.5px; color: #1e40af; margin-bottom: 14px;
  display: flex; gap: 8px; align-items: flex-start; line-height: 1.5;
}
.pf-var-conv { width: 80px !important; }
.pf-var-conv-wrap { display: flex; align-items: center; gap: 4px; }
.pf-var-conv-lbl { font-size: 11px; color: #6b7280; white-space: nowrap; }
.pf-var-conv-unit-lbl { font-size: 11px; color: #6b7280; }
.pf-var-conv-warn { border-color: #ef4444 !important; background: #fff7f7 !important; box-shadow: 0 0 0 2px rgba(239,68,68,.25) !important; }
.pf-var-wrap { overflow-x: auto; margin-bottom: 20px; border: 1px solid #e2e8f0; border-radius: 8px; }
.pf-var-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.pf-var-table thead th {
  background: #1a7f4e; color: #fff; padding: 9px 10px; text-align: left;
  font-weight: 700; font-size: 12.5px; white-space: nowrap;
}
.pf-var-table thead th:last-child { width: 40px; }
.pf-var-table tbody td { padding: 7px 8px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.pf-var-table tbody tr:last-child td { border-bottom: none; }
.pf-var-inp {
  width: 100%; border: 1px solid #d1d5db; border-radius: 5px; padding: 6px 8px;
  font-size: 13px; color: #374151; background: #fff; outline: none; box-sizing: border-box;
}
.pf-var-inp:focus { border-color: #3b82f6; box-shadow: 0 0 0 2px rgba(59,130,246,.1); }
.pf-var-sel { background: #fff; cursor: pointer; }
.pf-var-stock { width: 80px; }
.pf-var-del-btn {
  background: none; border: none; color: #dc2626; cursor: pointer; font-size: 13px; padding: 4px 6px;
}
.pf-var-del-btn:hover { color: #b91c1c; }
.pf-var-add-btn {
  background: #059669; color: #fff; border: none; padding: 6px 14px;
  border-radius: 6px; font-size: 12.5px; font-weight: 600; cursor: pointer;
}
.pf-var-add-btn:hover { background: #047857; }

/* 1/3-width grid for single-item rows */
.pform-grid-third { display: grid; grid-template-columns: repeat(3,1fr); gap: 0 20px; }
.pform-grid-third > .form-group:nth-child(n+2) { visibility: hidden; }

/* ── Green pricing table ── */
.pf-price-table {
  display: flex;
  border: 1px solid #d1d5db; border-radius: 10px;
  overflow: hidden; margin-bottom: 20px;
}
.pf-pt-col { display: flex; flex-direction: column; }
.pf-pt-col:not(:last-child) { border-right: 1px solid #d1d5db; }
.pf-pt-col-purchase { flex: 2.2; }
.pf-pt-col-margin   { flex: 1.1; }
.pf-pt-col-sell     { flex: 1.4; }
.pf-pt-head {
  background: #4caf50; color: #fff;
  font-weight: 700; font-size: 12.5px;
  padding: 10px 14px; line-height: 1.35;
  white-space: nowrap;
}
.pf-pt-body { padding: 14px; flex: 1; }
.pf-pt-sub-row { display: flex; gap: 10px; }
.pf-pt-sub-field { flex: 1; min-width: 0; }
.pf-pt-sub-label { display: block; font-size: 12px; font-weight: 600; color: #374151; margin-bottom: 6px; }

/* image upload in pricing table */
.pf-file-input {
  display: block; width: 100%; font-size: 12px; margin-bottom: 8px;
  border: 1px solid #d1d5db; border-radius: 6px; padding: 5px;
  background: #f9fafb; cursor: pointer;
}
.pf-img-preview-wrap { margin-bottom: 6px; min-height: 36px; }
.pf-img-thumb-preview { width: 72px; height: 72px; object-fit: cover; border-radius: 6px; border: 1px solid #e5e7eb; }
.pf-img-hint { font-size: 11px; color: var(--muted); margin: 3px 0; }

/* ── 4 product save buttons ── */
.modal-footer .btn-save-group,
.modal-footer .btn-save-stock,
.modal-footer .btn-save-another,
.modal-footer .btn-save-prod {
  padding: 12px 18px; border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; border: none; color: #fff; transition: opacity .15s; white-space: nowrap;
}
.modal-footer .btn-save-group   { background: #d4a017; }
.modal-footer .btn-save-stock   { background: #3b4a6b; }
.modal-footer .btn-save-another { background: #e91e8c; }
.modal-footer .btn-save-prod    { background: #6c3bbd; }
.modal-footer .btn-save-group:hover   { opacity: .88; }
.modal-footer .btn-save-stock:hover   { opacity: .88; }
.modal-footer .btn-save-another:hover { opacity: .88; }
.modal-footer .btn-save-prod:hover    { opacity: .88; }

/* product modal footer wraps on smaller screens */
.modal-product .modal-footer {
  flex-wrap: wrap; gap: 8px; justify-content: flex-end;
}

.view-details { display: flex; flex-direction: column; gap: 12px; overflow-x: auto; }
.view-row, .vd-row { display: flex; gap: 12px; align-items: flex-start; padding: 4px 0; border-bottom: 1px solid #f1f5f9; font-size: 13px; }
.view-row:last-child, .vd-row:last-child { border-bottom: none; }
.vd-row span:first-child { font-weight: 600; min-width: 120px; color: #6b7280; flex-shrink: 0; }
.vd-row strong { color: #1e293b; }
.view-label { font-weight: 700; min-width: 140px; color: var(--muted); font-size: 13px; }
.view-value { color: var(--text); font-size: 14px; }

/* Buttons */
.btn-primary {
  display: flex; align-items: center; gap: 6px;
  background: var(--accent); color: #fff;
  padding: 9px 20px; border-radius: 8px;
  font-size: 13.5px; font-weight: 700;
  box-shadow: 0 2px 8px rgba(5,150,105,.25);
  transition: background var(--tr);
}
.btn-primary:hover { background: var(--accent-dark); }
.btn-cancel {
  padding: 9px 18px; border-radius: 8px;
  border: 1.5px solid var(--border);
  font-size: 13.5px; color: var(--muted);
  transition: background var(--tr);
}
.btn-cancel:hover { background: #f3f4f6; }
.btn-danger {
  display: flex; align-items: center; gap: 6px;
  background: #dc2626; color: #fff;
  padding: 9px 20px; border-radius: 8px;
  font-size: 13.5px; font-weight: 700;
}
.btn-danger:hover { background: #b91c1c; }

/* Toast */
.toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 2000;
  display: flex; align-items: center; gap: 10px;
  padding: 13px 20px; border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  font-size: 14px; font-weight: 700; color: #fff;
  transform: translateY(20px); opacity: 0; transition: all .3s ease;
}
.toast-visible { transform: translateY(0); opacity: 1; }
.toast-success { background: #059669; }
.toast-error   { background: #dc2626; }
.toast-info    { background: #2563eb; }

/* ══════════════════════════════════
   PRODUCTS PAGE
══════════════════════════════════ */
.prod-filter-card {
  background: #fff; border-radius: 14px;
  box-shadow: var(--shadow); margin-bottom: 16px; overflow: hidden;
}
.prod-filter-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 20px; cursor: pointer;
  border-bottom: 1px solid var(--border); user-select: none;
  transition: background var(--tr);
}
.prod-filter-header:hover { background: var(--primary-light); }
.pf-title { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14px; }
.pf-icon { color: var(--primary); font-size: 15px; }
#pf-chevron { color: var(--muted); font-size: 12px; transition: transform .25s; }
.prod-filter-body { padding: 20px 20px 18px; }
.pf-hidden { display: none; }

.pf-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px 24px; align-items: end; }
.pf-group { display: flex; flex-direction: column; gap: 6px; }
.pf-label { font-size: 13px; font-weight: 700; color: var(--text); }
.pf-select {
  padding: 8px 12px; border: 1.5px solid var(--border);
  border-radius: 8px; font-size: 13px; color: var(--text);
  background: #fff; outline: none; width: 100%;
  transition: border-color var(--tr);
}
.pf-select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(30,58,95,.08); }
.pf-check-group { display: flex; align-items: center; gap: 9px; padding-bottom: 8px; }
.pf-check-group input { width: 16px; height: 16px; accent-color: var(--accent); cursor: pointer; }
.pf-check-group label { font-size: 13px; font-weight: 700; color: var(--text); cursor: pointer; }

.prod-tabs {
  display: flex; border-bottom: 2px solid var(--border);
  margin-bottom: 16px; background: #fff;
  border-radius: 14px 14px 0 0; box-shadow: var(--shadow);
}
.prod-tab-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 13px 24px; font-size: 13.5px; font-weight: 700;
  color: var(--muted); border-bottom: 3px solid transparent;
  margin-bottom: -2px; transition: color var(--tr), border-color var(--tr);
}
.prod-tab-btn:hover { color: var(--primary); }
.prod-tab-btn.active { color: var(--primary); border-bottom-color: var(--accent); }

.prod-top-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 0; flex-wrap: wrap; gap: 10px;
}
.prod-top-btns { display: flex; gap: 10px; }

/* ── STATUS TOGGLE ── */
.sts-group { display: flex; gap: 6px; }
.sts-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 15px; border-radius: 20px;
  font-size: 13px; font-weight: 600;
  border: 1.5px solid var(--border); background: #fff; color: var(--muted);
  cursor: pointer; transition: all var(--tr); white-space: nowrap;
}
.sts-btn:hover { border-color: #9ca3af; color: var(--text); }
.sts-dot { font-size: 7px; }
.sts-btn.sts-active-on   { background: #16a34a; color: #fff; border-color: #16a34a; }
.sts-btn.sts-inactive-on { background: var(--red); color: #fff; border-color: var(--red); }
.sts-btn.sts-all-on      { background: #374151;    color: #fff; border-color: #374151; }
/* dashboard variant — on red banner */
#dash-sts-group .sts-btn {
  background: rgba(255,255,255,.12); color: rgba(255,255,255,.85);
  border-color: rgba(255,255,255,.3);
}
#dash-sts-group .sts-btn:hover { background: rgba(255,255,255,.22); color: #fff; }
#dash-sts-group .sts-btn.sts-active-on   { background: #16a34a; border-color: #16a34a; color: #fff; }
#dash-sts-group .sts-btn.sts-inactive-on { background: #fff;    border-color: #fff;    color: var(--red); }

.btn-dl-excel {
  display: inline-flex; align-items: center; gap: 7px;
  background: #1e3a8a; color: #fff;
  padding: 9px 20px; border-radius: 50px;
  font-size: 13.5px; font-weight: 700;
  transition: background var(--tr);
}
.btn-dl-excel:hover { background: #1d4ed8; }

.btn-del-oos {
  display: inline-flex; align-items: center; gap: 7px;
  background: #b91c1c; color: #fff;
  padding: 9px 18px; border-radius: 50px;
  font-size: 13.5px; font-weight: 700; cursor: pointer; border: none;
  transition: background var(--tr);
}
.btn-del-oos:hover { background: #991b1b; }

.btn-bulk-price {
  display: inline-flex; align-items: center; gap: 7px;
  background: #0d9488; color: #fff;
  padding: 9px 18px; border-radius: 50px;
  font-size: 13.5px; font-weight: 700; cursor: pointer; border: none;
  transition: background var(--tr);
}
.btn-bulk-price:hover { background: #0f766e; }

/* ── Bulk Price Edit Modal ── */
.bulk-price-modal { max-width: 860px; width: 100%; max-height: 92vh; }

/* Filter Bar */
.bpe-filter-bar {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
  padding: 12px 20px; border-bottom: 1px solid var(--border); background: #f8fafc;
}
.bpe-filter-group { display: flex; flex-direction: column; gap: 3px; }
.bpe-filter-label { font-size: 11px; font-weight: 700; color: #64748b; text-transform: uppercase; letter-spacing: .4px; }
.bpe-filter-select {
  padding: 7px 10px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13px; background: #fff; outline: none; cursor: pointer; min-width: 150px;
  transition: border-color .2s;
}
.bpe-filter-select:focus { border-color: #2563eb; }
.bpe-search-wrap { position: relative; flex: 1; min-width: 180px; }
.bpe-search-icon {
  position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
  color: #94a3b8; font-size: 13px; pointer-events: none;
}
.bpe-search-input {
  width: 100%; padding: 8px 12px 8px 32px;
  border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; outline: none; transition: border-color .2s;
}
.bpe-search-input:focus { border-color: #2563eb; }
.bpe-count {
  white-space: nowrap; font-size: 12.5px; font-weight: 600; align-self: flex-end;
  color: #64748b; background: #e2e8f0; padding: 5px 11px; border-radius: 20px;
}

/* Edit Mode Panel */
.bpe-edit-panel {
  border-bottom: 1px solid var(--border); background: #fff;
}
.bpe-mode-tabs {
  display: flex; border-bottom: 1px solid var(--border);
}
.bpe-mode-tab {
  flex: 1; padding: 10px 16px; font-size: 13px; font-weight: 700;
  background: #f8fafc; border: none; cursor: pointer; color: #64748b;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s, color .15s; border-bottom: 3px solid transparent;
}
.bpe-mode-tab:first-child { border-right: 1px solid var(--border); }
.bpe-tab-active { background: #fff; color: #2563eb; border-bottom-color: #2563eb !important; }
.bpe-ctrl-row {
  display: flex; align-items: flex-end; flex-wrap: wrap; gap: 18px;
  padding: 14px 20px;
}
.bpe-ctrl-group { display: flex; flex-direction: column; gap: 5px; }
.bpe-ctrl-label { font-size: 11.5px; font-weight: 700; color: #475569; text-transform: uppercase; letter-spacing: .4px; }
.bpe-radio-group { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.bpe-radio-lbl {
  display: flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 600; color: #334155; cursor: pointer;
}
.btn-bpe-apply {
  display: inline-flex; align-items: center; gap: 6px; margin-left: auto;
  background: #2563eb; color: #fff; border: none; cursor: pointer;
  padding: 9px 18px; border-radius: 8px; font-size: 13px; font-weight: 700;
  transition: background .15s; white-space: nowrap;
}
.btn-bpe-apply:hover { background: #1d4ed8; }

/* Product Table */
.bpe-body { padding: 0 !important; overflow-y: auto; max-height: 38vh; }
.bpe-table { border-collapse: collapse; width: 100%; }
.bpe-table thead th {
  background: #f1f5f9; position: sticky; top: 0; z-index: 1;
  font-size: 12.5px; font-weight: 700; color: #475569;
  padding: 11px 16px; border-bottom: 2px solid var(--border); text-align: left;
}
.bpe-table tbody tr:hover { background: #f8fafc; }
.bpe-table td { padding: 8px 16px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.bpe-name-cell { display: flex; flex-direction: column; gap: 2px; }
.bpe-prod-name { font-size: 13.5px; font-weight: 600; color: #1e293b; }
.bpe-sku-tag { font-size: 11.5px; color: #64748b; font-family: monospace; }
.bpe-input-wrap {
  display: flex; align-items: center;
  border: 1.5px solid var(--border); border-radius: 8px;
  overflow: hidden; max-width: 160px; transition: border-color .2s;
}
.bpe-input-wrap:focus-within { border-color: #2563eb; }
.bpe-currency {
  padding: 7px 9px; background: #f1f5f9;
  font-size: 13px; font-weight: 700; color: #475569;
  border-right: 1px solid var(--border); user-select: none;
}
.bpe-input {
  border: none; outline: none; padding: 7px 10px;
  font-size: 13.5px; font-weight: 600; color: #1e293b; width: 100%; background: #fff;
}
.bpe-input::-webkit-inner-spin-button,
.bpe-input::-webkit-outer-spin-button { opacity: 0.4; }

.bpe-row-skipped { background: #fff7ed !important; animation: bpe-flash .4s ease; }
.bpe-row-skipped .bpe-input[data-field="sellingPrice"] { border-color: #f97316 !important; color: #c2410c; }
@keyframes bpe-flash {
  0%,100% { background: #fff7ed; }
  50%      { background: #fed7aa; }
}
.bpe-skip-notice {
  display: flex; align-items: flex-start; gap: 10px;
  background: #fff7ed; border: 1.5px solid #fed7aa;
  border-left: 4px solid #f97316;
  padding: 12px 16px; font-size: 13px; color: #92400e;
  animation: slideDown .2s ease;
}
.bpe-skip-notice i { color: #f97316; margin-top: 2px; flex-shrink: 0; }
.bpe-skip-text { flex: 1; line-height: 1.5; }
.bpe-skip-names { font-style: italic; color: #b45309; }
.bpe-skip-close {
  background: none; border: none; cursor: pointer;
  color: #92400e; font-size: 14px; padding: 2px 4px;
  flex-shrink: 0; opacity: .7;
}
.bpe-skip-close:hover { opacity: 1; }

/* ── Expense Recurring ── */
.exp-recur-wrap { border: 1.5px solid var(--border); border-radius: 10px; overflow: hidden; margin-top: 4px; }
.exp-recur-header { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: #f8fafc; user-select: none; }
.exp-recur-header span { flex: 1; font-weight: 600; font-size: 14px; color: #374151; }
.exp-recur-icon { color: #6366f1; font-size: 15px; }
.exp-recur-panel { padding: 0 16px 16px; background: #fff; }
.exp-toggle-sw { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.exp-toggle-sw input { opacity: 0; width: 0; height: 0; }
.exp-toggle-sl { position: absolute; inset: 0; background: #cbd5e1; border-radius: 24px; transition: .25s; cursor: pointer; }
.exp-toggle-sl::before { content: ''; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: .25s; }
.exp-toggle-sw input:checked + .exp-toggle-sl { background: #6366f1; }
.exp-toggle-sw input:checked + .exp-toggle-sl::before { transform: translateX(20px); }
.exp-recur-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; background: #ede9fe; color: #6d28d9; border-radius: 20px; font-size: 11px; font-weight: 600; white-space: nowrap; text-transform: capitalize; }
.exp-due-ok  { display: inline-block; padding: 3px 9px; background: #dcfce7; color: #16a34a; border-radius: 8px; font-size: 12px; font-weight: 600; text-align: center; }
.exp-due-warn{ display: inline-block; padding: 3px 9px; background: #fef9c3; color: #b45309; border-radius: 8px; font-size: 12px; font-weight: 600; text-align: center; }
.exp-due-over{ display: inline-block; padding: 3px 9px; background: #fee2e2; color: #dc2626; border-radius: 8px; font-size: 12px; font-weight: 600; text-align: center; }

/* ── Report Summary Cards ── */
.rpt-summary-cards {
  display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 20px;
}
.rpt-card {
  display: flex; align-items: center; gap: 14px;
  background: #fff; border: 1.5px solid var(--border); border-radius: 14px;
  padding: 16px 20px; flex: 1; min-width: 180px;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.rpt-card-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.rpt-card-label { font-size: 12px; font-weight: 600; color: #64748b; margin-bottom: 4px; }
.rpt-card-val   { font-size: 18px; font-weight: 800; color: #1e293b; }

/* ── Stock Report Stats Panel ── */
.sr-stats-card { margin-top: 16px; }
.sr-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0; border-top: 3px solid #2563eb; }
.sr-stat-item { padding: 20px 28px; border-right: 1.5px solid var(--border); }
.sr-stat-item:last-child { border-right: none; }
.sr-stat-label { font-size: 13px; color: #6b7280; margin-bottom: 8px; font-weight: 500; }
.sr-stat-val { font-size: 24px; font-weight: 800; letter-spacing: -0.5px; }

/* ── Profit / Loss Report Tabs ── */
.pl-tabs-wrap { display:flex; flex-wrap:wrap; gap:4px; background:#fff; padding:8px 10px; border-radius:12px 12px 0 0; border:1.5px solid var(--border); border-bottom:none; margin-top:16px; }
.pl-tab-btn { padding:8px 16px; border:none; border-radius:8px; background:transparent; color:#6b7280; font-size:13px; font-weight:600; cursor:pointer; transition:all .2s; white-space:nowrap; display:flex; align-items:center; gap:6px; }
.pl-tab-btn:hover { background:#f1f5f9; color:#374151; }
.pl-tab-active { background:#2563eb !important; color:#fff !important; }
.pl-row { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding:13px 18px; border-bottom:1px solid #f1f5f9; }
.pl-row:last-child { border-bottom:none; }
.pl-row-label { font-size:14px; font-weight:600; color:#374151; line-height:1.4; }
.pl-row-val { font-size:14px; font-weight:700; color:#374151; white-space:nowrap; }

/* ── Bulk Action Bar ── */
.prod-bulk-bar {
  display: flex; align-items: center; gap: 16px;
  background: #1e293b; color: #fff;
  padding: 11px 18px; border-radius: 10px;
  margin-bottom: 10px; animation: slideDown .2s ease;
}
.prod-bulk-bar.hidden { display: none; }
.bulk-count-label { font-size: 13.5px; font-weight: 600; flex: 1; }
.bulk-count-label i { color: #60a5fa; margin-right: 6px; }
.btn-bulk-delete {
  display: inline-flex; align-items: center; gap: 7px;
  background: #dc2626; color: #fff;
  padding: 8px 18px; border-radius: 8px;
  font-size: 13px; font-weight: 700; cursor: pointer; border: none;
  transition: background .15s;
}
.btn-bulk-delete:hover { background: #b91c1c; }
@keyframes slideDown { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }

.prod-table th, .prod-table td { white-space: nowrap; }
.prod-img-thumb {
  width: 44px; height: 44px; border-radius: 8px;
  background: var(--primary-light); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
}
.prod-img-upload { cursor: pointer; transition: border-color var(--tr); }
.prod-img-upload:hover { border-color: var(--primary); }
.prod-img-icon { font-size: 17px; color: #94a3b8; }
.prod-img-preview {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: 7px; display: block;
}
.prod-img-overlay {
  position: absolute; inset: 0;
  background: rgba(30,58,95,.55);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity var(--tr); border-radius: 7px;
  color: #fff; font-size: 14px;
}
.prod-img-upload:hover .prod-img-overlay { opacity: 1; }
.prod-name { display: block; font-weight: 700; font-size: 13.5px; margin-bottom: 4px; }
.sku-cell  { font-size: 12.5px; font-weight: 700; color: var(--muted); white-space: nowrap; }
.bl-info-icon { color: #60a5fa; font-size: 11px; margin-left: 3px; }

/* product table: first row of a multi-location product */
tr.prod-loc-first td { border-top: 2px solid #d1d5db !important; }

/* continuation rows share a light background and no strong top border */
tr.prod-loc-cont td {
  background: #fafafa;
  border-top: 1px dashed #e5e7eb !important;
}

/* Stock Report */
.stock-report-table th small { font-size: 10px; font-weight: 500; color: #fff; opacity: .85; }
.num-cell { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.stock-totals-row td {
  background: var(--primary-light); border-top: 2px solid var(--primary) !important;
  font-size: 13px; padding: 10px 12px;
}
.stock-totals-row .num-cell { color: var(--primary); }
.profit-cell { color: #16a34a; font-weight: 600; }

/* ══════════════════════════════════
   PRODUCT HISTORY DROPDOWN
══════════════════════════════════ */
.hist-dropdown { position: relative; display: inline-block; }

.btn-hist-toggle {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 6px; font-size: 12px; font-weight: 600;
  border: 1px solid #d1d5db; background: #f9fafb; color: #374151; cursor: pointer;
  white-space: nowrap; transition: background .15s, border-color .15s;
}
.btn-hist-toggle:hover, .btn-hist-toggle.open {
  background: var(--primary-light); border-color: var(--primary); color: var(--primary);
}
.btn-hist-toggle .hist-chev { font-size: 10px; transition: transform .2s; }
.btn-hist-toggle.open .hist-chev { transform: rotate(180deg); }

.hist-menu {
  position: absolute; top: calc(100% + 4px); left: 0; z-index: 200;
  background: #fff; border: 1px solid #e5e7eb; border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,.1); min-width: 220px; padding: 6px 0;
}
.hist-menu.hidden { display: none; }

.hist-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 14px; gap: 12px;
}
.hist-item:not(:last-child) { border-bottom: 1px solid #f3f4f6; }

.hist-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: #6b7280; font-weight: 500; white-space: nowrap;
}
.hist-label .fas { color: var(--primary); font-size: 11px; width: 12px; text-align: center; }

.hist-val {
  font-size: 12.5px; font-weight: 700; color: #1f2937; white-space: nowrap;
}

/* ══════════════════════════════════
   ACTIONS DROPDOWN
══════════════════════════════════ */
.action-dropdown { position: relative; display: inline-block; }

.btn-actions-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 14px; border-radius: 6px;
  border: 1.5px solid var(--primary); color: var(--primary);
  font-size: 13px; font-weight: 700; background: #fff;
  transition: background var(--tr);
}
.btn-actions-toggle:hover { background: var(--primary-light); }
.btn-actions-toggle .fa-chevron-down { font-size: 10px; }

.dd-menu {
  position: absolute; top: calc(100% + 4px); left: 0;
  background: #fff; border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,.13);
  min-width: 190px; z-index: 600;
  display: none; padding: 6px 0;
  border-top: 3px solid var(--primary);
}
.action-dropdown.open .dd-menu { display: block; }
.dd-menu li a {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 16px; font-size: 13px; color: var(--text);
  transition: background var(--tr); white-space: nowrap;
}
.dd-menu li a:hover { background: var(--primary-light); color: var(--primary); }
.dd-menu li a i { width: 16px; text-align: center; color: var(--muted); font-size: 13px; }
.dd-menu li a:hover i { color: var(--primary); }
.dd-divider { height: 1px; background: var(--border); margin: 5px 0; }

/* ══════════════════════════════════
   IMPORT CONTACTS PAGE
══════════════════════════════════ */
.btn-download-tpl {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 20px; border-radius: 8px;
  background: #fff; color: var(--primary);
  border: 2px solid var(--primary); font-size: 13.5px; font-weight: 700;
  transition: background var(--tr), color var(--tr);
}
.btn-download-tpl:hover { background: var(--primary); color: #fff; }

.import-card {
  background: #fff; border-radius: 14px;
  box-shadow: var(--shadow); padding: 28px 30px;
  display: flex; flex-direction: column; gap: 22px;
}
.import-instructions {
  display: flex; align-items: flex-start; gap: 14px;
  background: var(--primary-light); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px 20px;
}
.instr-icon { color: var(--primary); font-size: 20px; flex-shrink: 0; margin-top: 2px; }
.import-instructions ol { list-style: decimal; padding-left: 18px; display: flex; flex-direction: column; gap: 5px; }
.import-instructions li { font-size: 13.5px; color: var(--text); line-height: 1.5; }

.upload-zone {
  border: 2.5px dashed var(--border); border-radius: 14px;
  padding: 50px 30px; text-align: center; cursor: pointer;
  background: #f8fafc; transition: border-color var(--tr), background var(--tr);
}
.upload-zone:hover, .upload-zone.drag-over { border-color: var(--primary); background: var(--primary-light); }
.upload-cloud-icon { font-size: 52px; color: #94a3b8; margin-bottom: 14px; transition: color var(--tr); }
.upload-zone:hover .upload-cloud-icon,
.upload-zone.drag-over .upload-cloud-icon { color: var(--primary); }
.upload-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.upload-sub { font-size: 13.5px; color: var(--muted); margin-bottom: 10px; }
.upload-link { color: var(--primary); font-weight: 700; text-decoration: underline; }
.upload-hint { font-size: 12px; color: #9ca3af; }

.file-info-box { background: var(--primary-light); border: 1px solid var(--border); border-radius: 10px; padding: 14px 18px; }
.file-info-inner { display: flex; align-items: center; gap: 14px; }
.fi-icon { font-size: 32px; color: var(--primary); flex-shrink: 0; }
.fi-meta { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.fi-name { font-size: 14px; font-weight: 700; color: var(--text); }
.fi-size { font-size: 12px; color: var(--muted); }
.fi-remove {
  width: 30px; height: 30px; border-radius: 50%;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 13px; transition: background var(--tr), color var(--tr);
}
.fi-remove:hover { background: var(--primary-light); color: var(--primary); }

.csv-preview-box { border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.preview-header-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; background: var(--primary-light); border-bottom: 1px solid var(--border);
}
.preview-label { font-size: 14px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 7px; }
.preview-count-badge { background: var(--primary); color: #fff; font-size: 12px; font-weight: 700; padding: 2px 10px; border-radius: 20px; }
.preview-note { font-size: 12px; color: var(--muted); margin-left: auto; }
.preview-scroll { overflow-x: auto; }
.empty-cell { color: #d1d5db; font-style: italic; }
.import-negative { background: #fee2e2 !important; color: #b91c1c !important; font-weight: 700; }
.import-neg-warn {
  display: flex; align-items: center; gap: 8px;
  margin: 10px 14px 4px; padding: 9px 14px;
  background: #fff7ed; border: 1px solid #fdba74; border-radius: 8px;
  color: #c2410c; font-size: .83rem; font-weight: 600;
}

.import-action-bar {
  display: flex; align-items: center; justify-content: flex-end; gap: 12px; padding-top: 4px;
}

/* ── Custom Scrollbars ── */

/* Scrollable areas */
.page-content,
.sidebar,
.modal-body,
.pam-body,
.api-body,
.bpe-body,
.as-suggest-box,
.as-prod-ac,
.notif-list,
.nt-list,
.bs-content,
.pos-prod-grid,
.pos-cart-items,
.table-wrap,
.table-responsive,
.as-items-wrap,
.preview-scroll,
.pf-var-wrap,
.view-details,
.dr-panel,
.pap-history,
.ep-table-wrap {
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 #f1f5f9;
}

/* Dark sidebar gets dark thumb */
.sidebar {
  scrollbar-color: rgba(255,255,255,.22) rgba(255,255,255,.05);
}

/* WebKit track */
.page-content::-webkit-scrollbar,
.modal-body::-webkit-scrollbar,
.pam-body::-webkit-scrollbar,
.api-body::-webkit-scrollbar,
.bpe-body::-webkit-scrollbar,
.as-suggest-box::-webkit-scrollbar,
.as-prod-ac::-webkit-scrollbar,
.notif-list::-webkit-scrollbar,
.nt-list::-webkit-scrollbar,
.bs-content::-webkit-scrollbar,
.pos-prod-grid::-webkit-scrollbar,
.pos-cart-items::-webkit-scrollbar,
.table-wrap::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar,
.as-items-wrap::-webkit-scrollbar,
.preview-scroll::-webkit-scrollbar,
.pf-var-wrap::-webkit-scrollbar,
.view-details::-webkit-scrollbar,
.pap-history::-webkit-scrollbar,
.ep-table-wrap::-webkit-scrollbar { width: 6px; height: 6px; }

.sidebar::-webkit-scrollbar { width: 5px; }

/* Track background */
.page-content::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track,
.pam-body::-webkit-scrollbar-track,
.api-body::-webkit-scrollbar-track,
.bpe-body::-webkit-scrollbar-track,
.as-suggest-box::-webkit-scrollbar-track,
.as-prod-ac::-webkit-scrollbar-track,
.notif-list::-webkit-scrollbar-track,
.nt-list::-webkit-scrollbar-track,
.bs-content::-webkit-scrollbar-track,
.pos-prod-grid::-webkit-scrollbar-track,
.pos-cart-items::-webkit-scrollbar-track,
.table-wrap::-webkit-scrollbar-track,
.table-responsive::-webkit-scrollbar-track,
.as-items-wrap::-webkit-scrollbar-track,
.preview-scroll::-webkit-scrollbar-track,
.pf-var-wrap::-webkit-scrollbar-track,
.view-details::-webkit-scrollbar-track,
.pap-history::-webkit-scrollbar-track,
.ep-table-wrap::-webkit-scrollbar-track {
  background: #f1f5f9;
  border-radius: 10px;
}

.sidebar::-webkit-scrollbar-track {
  background: rgba(255,255,255,.05);
  border-radius: 10px;
}

/* Thumb */
.page-content::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
.pam-body::-webkit-scrollbar-thumb,
.api-body::-webkit-scrollbar-thumb,
.bpe-body::-webkit-scrollbar-thumb,
.as-suggest-box::-webkit-scrollbar-thumb,
.as-prod-ac::-webkit-scrollbar-thumb,
.notif-list::-webkit-scrollbar-thumb,
.nt-list::-webkit-scrollbar-thumb,
.bs-content::-webkit-scrollbar-thumb,
.pos-prod-grid::-webkit-scrollbar-thumb,
.pos-cart-items::-webkit-scrollbar-thumb,
.table-wrap::-webkit-scrollbar-thumb,
.table-responsive::-webkit-scrollbar-thumb,
.as-items-wrap::-webkit-scrollbar-thumb,
.preview-scroll::-webkit-scrollbar-thumb,
.pf-var-wrap::-webkit-scrollbar-thumb,
.view-details::-webkit-scrollbar-thumb,
.pap-history::-webkit-scrollbar-thumb,
.ep-table-wrap::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 10px;
  border: 1px solid #f1f5f9;
  transition: background .2s;
}

.sidebar::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.22);
  border-radius: 10px;
}

/* Thumb hover */
.page-content::-webkit-scrollbar-thumb:hover,
.modal-body::-webkit-scrollbar-thumb:hover,
.pam-body::-webkit-scrollbar-thumb:hover,
.api-body::-webkit-scrollbar-thumb:hover,
.bpe-body::-webkit-scrollbar-thumb:hover,
.as-suggest-box::-webkit-scrollbar-thumb:hover,
.as-prod-ac::-webkit-scrollbar-thumb:hover,
.notif-list::-webkit-scrollbar-thumb:hover,
.nt-list::-webkit-scrollbar-thumb:hover,
.bs-content::-webkit-scrollbar-thumb:hover,
.pos-prod-grid::-webkit-scrollbar-thumb:hover,
.pos-cart-items::-webkit-scrollbar-thumb:hover,
.table-wrap::-webkit-scrollbar-thumb:hover,
.table-responsive::-webkit-scrollbar-thumb:hover,
.as-items-wrap::-webkit-scrollbar-thumb:hover,
.preview-scroll::-webkit-scrollbar-thumb:hover,
.pf-var-wrap::-webkit-scrollbar-thumb:hover,
.view-details::-webkit-scrollbar-thumb:hover,
.pap-history::-webkit-scrollbar-thumb:hover,
.ep-table-wrap::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

.sidebar::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.38); }

/* Corner piece */
::-webkit-scrollbar-corner { background: transparent; }

/* ── SKU Auto-generate ── */
.pf-sku-wrap { display: flex; gap: 6px; align-items: center; }
.pf-sku-wrap .form-input { flex: 1; min-width: 0; }
.btn-sku-regen {
  flex-shrink: 0; width: 34px; height: 34px;
  background: #f3f4f6; border: 1.5px solid var(--border);
  border-radius: 7px; cursor: pointer; color: #6b7280;
  font-size: 13px; display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.btn-sku-regen:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ── Opening Stock Modal ── */
.os-modal { max-width: 600px; }
.os-product-info, .pg-product-info {
  background: #f8fafc; border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px; margin-bottom: 14px; font-size: 13px;
}
.os-product-info span, .pg-product-info span { color: #6b7280; margin-right: 4px; }
.os-product-info strong, .pg-product-info strong { color: #111827; }

.os-table, .pg-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.os-table th, .pg-table th {
  background: #f3f4f6; padding: 9px 12px; text-align: left;
  font-weight: 600; color: #374151; border-bottom: 2px solid #e5e7eb;
  font-size: 12px; text-transform: uppercase; letter-spacing: .4px;
}
.os-table td, .pg-table td {
  padding: 8px 10px; border-bottom: 1px solid #f3f4f6; vertical-align: middle;
}
.os-table tr:last-child td, .pg-table tr:last-child td { border-bottom: none; }
.os-table tfoot td { font-weight: 700; background: #f8fafc; border-top: 2px solid #e5e7eb; }
.os-table input, .pg-table input {
  width: 100%; padding: 6px 9px; border: 1.5px solid #e5e7eb;
  border-radius: 6px; font-size: 13px; background: #fff; transition: border-color .15s;
  box-sizing: border-box;
}
.os-table input:focus, .pg-table input:focus { outline: none; border-color: var(--primary); }
.os-sub { color: #374151; }
.pg-disc-cell { color: #6b7280; font-size: 13px; }
.pg-hint { font-size: 12px; color: #6b7280; margin-bottom: 10px; }

.btn-os-save {
  display: flex; align-items: center; gap: 6px;
  background: #2563eb; color: #fff; padding: 9px 20px;
  border-radius: 8px; font-size: 13.5px; font-weight: 700;
  cursor: pointer; border: none; transition: background .15s;
}
.btn-os-save:hover { background: #1d4ed8; }

/* ── Price Group Modal ── */
.pg-modal { max-width: 580px; }
.pg-loc-header td {
  background: #eff6ff; color: #1d4ed8; font-weight: 700;
  font-size: 12px; padding: 8px 12px; letter-spacing: .3px;
  border-top: 2px solid #bfdbfe; border-bottom: 1px solid #dbeafe;
}
.pg-loc-header td i { margin-right: 5px; font-size: 11px; }
.pg-var-header td {
  background: #fffbeb; color: #92400e; font-weight: 600;
  font-size: 12px; padding: 6px 12px 6px 20px;
  border-top: 1px solid #fde68a; border-bottom: 1px solid #fde68a;
}
.pg-var-header td i { margin-right: 5px; }

.btn-pg-save {
  display: flex; align-items: center; gap: 6px;
  background: #d4a017; color: #fff; padding: 9px 20px;
  border-radius: 8px; font-size: 13.5px; font-weight: 700;
  cursor: pointer; border: none; transition: background .15s;
}
.btn-pg-save:hover { background: #b8860b; }

/* ── Purchases Page ── */
.pur-filter-card {
  background: #fff; border-radius: 12px; border: 1px solid var(--border);
  padding: 20px 24px; margin-bottom: 18px; box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.pur-filter-title { font-size: 15px; font-weight: 700; color: #1e293b; margin-bottom: 16px; }
.pur-filter-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px 20px; align-items: end;
}
.pur-filter-date { grid-column: span 2; }
.pur-filter-group { display: flex; flex-direction: column; gap: 5px; }
.pur-filter-label { font-size: 12.5px; font-weight: 600; color: #374151; }
.pur-filter-select {
  padding: 8px 10px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13px; background: #fff; color: #374151; cursor: pointer;
}
.pur-filter-select:focus { outline: none; border-color: var(--primary); }
.pur-date-row { display: flex; align-items: center; gap: 8px; }
.pur-date-input {
  flex: 1; padding: 8px 10px; border: 1.5px solid var(--border);
  border-radius: 8px; font-size: 13px; color: #374151;
}
.pur-date-input:focus { outline: none; border-color: var(--primary); }
.pur-date-sep { color: #9ca3af; font-size: 14px; }
.btn-apply-date { padding:7px 14px; background:#2563eb; color:#fff; border:none; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; white-space:nowrap; transition:background .2s; }
.btn-apply-date:hover { background:#1d4ed8; }

/* ── Date Range Picker ── */
.dr-picker { position:relative; }
.dr-picker-btn { display:flex; align-items:center; gap:8px; padding:8px 14px; background:#fff; border:1.5px solid #d1d5db; border-radius:8px; font-size:13px; font-weight:600; color:#374151; cursor:pointer; white-space:nowrap; width:100%; transition:border-color .2s; box-shadow:0 1px 3px rgba(0,0,0,.06); }
.dr-picker-btn:hover,.dr-picker-btn.dr-open { border-color:#2563eb; }
.dr-caret { margin-left:auto; font-size:10px; color:#9ca3af; transition:transform .2s; }
.dr-open .dr-caret { transform:rotate(180deg); }
.dr-panel { position:absolute; top:calc(100% + 4px); left:0; z-index:9999; background:#fff; border:1.5px solid #e5e7eb; border-radius:10px; box-shadow:0 8px 32px rgba(0,0,0,.14); min-width:210px; overflow:hidden; }
.dr-preset-item { display:block; width:100%; padding:9px 16px; background:none; border:none; text-align:left; font-size:13px; font-weight:500; color:#374151; cursor:pointer; transition:background .12s; }
.dr-preset-item:hover { background:#f1f5f9; color:#2563eb; }
.dr-preset-active { background:#eff6ff !important; color:#2563eb !important; font-weight:700 !important; }
.dr-custom-wrap { padding:10px 12px; border-top:1.5px solid #f1f5f9; background:#fafbfc; }
.dr-custom-title { font-size:11px; font-weight:700; color:#6b7280; text-transform:uppercase; letter-spacing:.5px; margin-bottom:6px; }
.dr-custom-row { display:flex; align-items:center; gap:4px; margin-bottom:8px; }
.dr-custom-inp { flex:1; min-width:0; padding:6px; border:1.5px solid #d1d5db; border-radius:6px; font-size:12px; color:#374151; }
.dr-custom-inp:focus { border-color:#2563eb; outline:none; }
.dr-sep { color:#9ca3af; font-size:12px; font-weight:600; }

.pur-table-card {
  background: #fff; border-radius: 12px; border: 1px solid var(--border);
  padding: 20px 24px; box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.pur-table-topbar {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px;
}
.pur-table-title { font-size: 16px; font-weight: 700; color: #1e293b; }

.btn-pur-add {
  display: inline-flex; align-items: center; gap: 8px;
  background: #4f46e5; color: #fff;
  padding: 10px 22px; border-radius: 50px;
  font-size: 14px; font-weight: 700; cursor: pointer; border: none;
  box-shadow: 0 4px 14px rgba(79,70,229,.35); transition: background .15s, box-shadow .15s;
}
.btn-pur-add:hover { background: #4338ca; box-shadow: 0 4px 18px rgba(79,70,229,.45); }

.btn-pur-actions {
  display: inline-flex; align-items: center; gap: 6px;
  background: #fff; color: #0e7490;
  border: 1.5px solid #0e7490; border-radius: 8px;
  padding: 6px 12px; font-size: 12.5px; font-weight: 700;
  cursor: pointer; transition: background .15s, color .15s; white-space: nowrap;
}
.btn-pur-actions:hover { background: #0e7490; color: #fff; }

.pur-status-badge {
  display: inline-block; padding: 3px 10px; border-radius: 20px;
  font-size: 11.5px; font-weight: 700; letter-spacing: .3px;
}
.pur-badge-received { background: #dcfce7; color: #15803d; }
.pur-badge-pending  { background: #fef9c3; color: #a16207; }
.pur-badge-ordered  { background: #dbeafe; color: #1d4ed8; }
.pur-badge-paid     { background: #dcfce7; color: #15803d; }
.pur-badge-due      { background: #fee2e2; color: #b91c1c; }
.pur-badge-partial  { background: #ffedd5; color: #c2410c; }

.pur-due-label { font-size: 11px; color: #6b7280; font-weight: 600; }

button.pur-pay-btn {
  border: none; cursor: pointer; line-height: 1;
  transition: filter .15s, transform .1s;
}
button.pur-pay-btn:hover  { filter: brightness(.92); transform: scale(1.04); }
button.pur-pay-btn:active { transform: scale(.97); }
.pur-time { font-size: 11px; color: #9ca3af; }
.empty-state-cell { text-align: center; padding: 40px; color: #9ca3af; font-size: 14px; }

/* ══════════════════════════════════
   ADD SALE PAGE
══════════════════════════════════ */
.as-page-wrap { display: flex; flex-direction: column; gap: 18px; padding: 20px 24px; }
.as-card { background: #fff; border-radius: 12px; border: 1px solid var(--border); padding: 22px 26px; box-shadow: 0 1px 4px rgba(0,0,0,.05); }

/* Location bar */
.as-loc-bar { display: inline-flex; align-items: center; gap: 10px; background: #fff; border-radius: 10px; border: 1px solid var(--border); padding: 9px 16px; }
.as-loc-icon { color: #374151; font-size: 16px; }
.as-loc-sel { border: none; background: transparent; font-size: 13.5px; font-weight: 600; color: #1e293b; outline: none; cursor: pointer; }
.as-info-btn { background: none; border: none; color: #06b6d4; font-size: 15px; cursor: pointer; padding: 0 2px; display: inline-flex; align-items: center; }
.as-info-btn:hover { color: #0891b2; }

/* Selling price row */
.as-price-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid #f1f5f9; }
.as-price-icon { width: 34px; height: 34px; background: #374151; border-radius: 6px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; flex-shrink: 0; }
.as-price-sel { border: 1.5px solid var(--border); border-radius: 8px; padding: 7px 12px; font-size: 13.5px; color: #1e293b; background: #fff; min-width: 200px; outline: none; cursor: pointer; }

/* 3-column main grid */
.as-main-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 28px; }
.as-col-fields { display: flex; flex-direction: column; gap: 14px; }

/* Field basics */
.as-field-group { display: flex; flex-direction: column; gap: 5px; }
.as-label { font-size: 13px; font-weight: 700; color: #374151; }
.as-req { color: #dc2626; margin-left: 2px; font-weight: 800; }

/* Required field — permanent left-border indicator */
.as-field-required > .as-input,
.as-field-required > .as-select,
.as-field-required > .as-textarea {
  border-left: 3px solid #fca5a5;
}
/* Error state — triggered on failed save */
.as-field-error > .as-label { color: #dc2626; }
.as-field-error > .as-input,
.as-field-error > .as-select,
.as-field-error > .as-textarea {
  border: 1.5px solid #ef4444 !important;
  border-left: 3px solid #ef4444 !important;
  background: #fff5f5 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15) !important;
}
.as-field-error-msg { font-size: 11px; color: #ef4444; margin-top: 2px; display: none; }
.as-field-error .as-field-error-msg { display: block; }
/* Products section error */
.as-prod-error .as-items-header > span { color: #dc2626; }
.as-prod-error .as-prod-search-wrap input {
  border: 1.5px solid #ef4444 !important;
  background: #fff5f5 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15) !important;
}
.as-input { width: 100%; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 13.5px; color: #1e293b; background: #fff; box-sizing: border-box; }
.as-input:focus { outline: none; border-color: #4f46e5; }
.as-select { width: 100%; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 13.5px; color: #1e293b; background: #fff; cursor: pointer; box-sizing: border-box; }
.as-select:focus { outline: none; border-color: #4f46e5; }
.as-textarea { width: 100%; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 13.5px; color: #1e293b; resize: vertical; font-family: inherit; box-sizing: border-box; }
.as-textarea:focus { outline: none; border-color: #4f46e5; }
.as-hint { font-size: 11.5px; color: #9ca3af; margin-top: 2px; line-height: 1.5; }

/* Input with left icon */
.as-ifield { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.as-ifield:focus-within { border-color: #4f46e5; }
.as-field-icon { width: 36px; background: #f1f5f9; border-right: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; color: #475569; font-size: 13px; align-self: stretch; flex-shrink: 0; }
.as-ifield .as-input, .as-ifield .as-select { border: none; border-radius: 0; flex: 1; }
.as-ifield .as-input:focus, .as-ifield .as-select:focus { outline: none; }

/* Date row */
.as-date-row { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; background: #f8fafc; }
.as-date-row:focus-within { border-color: #4f46e5; }
.as-date-row .as-field-icon { background: #f1f5f9; border-right: 1.5px solid var(--border); }

/* Customer row */
.as-cust-row { display: flex; align-items: center; gap: 6px; }
.as-cust-sel { flex: 1; }
.as-add-cust-btn { width: 34px; height: 34px; border-radius: 50%; background: #3b82f6; color: #fff; border: none; cursor: pointer; font-size: 16px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.as-add-cust-btn:hover { background: #2563eb; }

/* Address display */
.as-addr-block { margin-top: 10px; }
.as-addr-label { font-size: 12px; font-weight: 700; color: #374151; margin: 0 0 2px; }
.as-addr-val   { font-size: 13px; color: #4f46e5; margin: 0; }

/* Pay term row */
.as-payterm-row { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.as-payterm-row:focus-within { border-color: #4f46e5; }
.as-payterm-prefix { padding: 9px 12px; background: #f8fafc; color: #6b7280; font-size: 13px; border-right: 1.5px solid var(--border); white-space: nowrap; flex-shrink: 0; }

/* File browse */
.as-file-row { display: flex; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.as-browse-btn { display: flex; align-items: center; gap: 6px; padding: 9px 16px; background: #2563eb; color: #fff; font-size: 13px; font-weight: 600; cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.as-browse-btn:hover { background: #1d4ed8; }

/* Items table */
.as-items-wrap { border: 1.5px solid var(--border); border-radius: 10px; overflow-x: auto; overflow-y: visible; margin-bottom: 16px; }
.as-items-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.as-items-head th { background: #f8fafc; padding: 11px 12px; font-size: 12px; font-weight: 700; color: #374151; text-align: left; border-bottom: 1.5px solid var(--border); }
.as-items-table td { padding: 8px 12px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.as-items-table tbody tr:last-child td { border-bottom: none; }
.as-item-inp { width: 100%; padding: 5px 8px; border: 1.5px solid var(--border); border-radius: 6px; font-size: 13px; color: #1e293b; box-sizing: border-box; }
.as-item-inp:focus { outline: none; border-color: #4f46e5; }
.as-items-totals { display: flex; justify-content: flex-end; gap: 28px; padding: 10px 16px; background: #f8fafc; border-top: 1.5px solid var(--border); font-size: 13px; color: #374151; }
.as-items-totals strong { color: #1e293b; }
.as-del-btn { background: none; border: none; color: #9ca3af; cursor: pointer; font-size: 14px; padding: 4px 6px; border-radius: 4px; }
.as-del-btn:hover { color: #ef4444; background: #fef2f2; }

/* Product search autocomplete (Stock Transfer / Adjustment add forms) */
.as-suggest-box {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 400;
  background: #fff; border: 1.5px solid var(--border); border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.13); max-height: 240px; overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: #e5e7eb transparent;
}
.as-suggest-item {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 9px 12px; cursor: pointer; border-bottom: 1px solid #f1f5f9; font-size: 13px;
}
.as-suggest-item:hover { background: #f0f9ff; }
.as-suggest-item:last-child { border-bottom: none; }
.as-suggest-item.asi-added { background: #f0fdf4; border-left: 3px solid #16a34a; }
.as-suggest-item.asi-added:hover { background: #dcfce7; cursor: pointer; }
.asi-name { font-weight: 600; color: #1e293b; flex: 1; }
.asi-sku { font-size: 11px; color: #9ca3af; white-space: nowrap; }
.asi-price { font-size: 12px; color: #059669; font-weight: 600; white-space: nowrap; }
.asi-added-badge { font-size: 12px; color: #16a34a; font-weight: 700; white-space: nowrap; }
@keyframes icf-flash {
  0%   { background: #fef9c3; }
  40%  { background: #fde047; }
  100% { background: transparent; }
}
.icf-row-flash { animation: icf-flash 2s ease-out; }
.icf-row-search-hl { background: #fffbeb !important; box-shadow: inset 3px 0 0 #f59e0b; }

/* Product search */
.as-prod-search-bar { position: relative; display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 50px; background: #fff; padding: 0 8px 0 0; overflow: visible; }
.as-prod-search-bar:focus-within { border-color: #3b82f6; }
.as-search-icon { width: 42px; display: flex; align-items: center; justify-content: center; color: #6b7280; font-size: 15px; flex-shrink: 0; }
.as-search-inp { flex: 1; border: none; background: transparent; font-size: 14px; color: #1e293b; padding: 12px 0; outline: none; }
.as-search-inp::placeholder { color: #9ca3af; }
.as-add-prod-btn { width: 32px; height: 32px; border-radius: 50%; background: #3b82f6; color: #fff; border: none; cursor: pointer; font-size: 15px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.as-add-prod-btn:hover { background: #2563eb; }
.as-prod-ac { position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: #fff; border: 1.5px solid var(--border); border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,.13); z-index: 999; display: none; max-height: 240px; overflow-y: auto; }
.as-ac-item { display: flex; align-items: center; gap: 12px; padding: 10px 16px; cursor: pointer; border-bottom: 1px solid #f1f5f9; font-size: 13px; }
.as-ac-item:last-child { border-bottom: none; }
.as-ac-item:hover { background: #f0f9ff; }
.as-ac-empty { color: #9ca3af; cursor: default; font-style: italic; }
.as-ac-name  { flex: 1; font-weight: 600; color: #1e293b; }
.as-ac-sku   { font-size: 11px; color: #6b7280; }
.as-ac-price { font-size: 12px; color: #4f46e5; font-weight: 700; white-space: nowrap; }

/* Discount / Tax */
.as-disc-row { display: grid; grid-template-columns: 220px 200px 1fr; gap: 16px; align-items: end; margin-bottom: 4px; }
.as-calc-block { display: flex; flex-direction: column; gap: 4px; padding-bottom: 10px; }
.as-calc-label { font-size: 13px; font-weight: 700; color: #374151; }
.as-calc-val   { font-size: 14px; color: #374151; }
.as-gain-box   { background: #f8fafc; border: 1.5px solid #e2e8f0; border-radius: 10px; padding: 14px 18px; margin: 16px 0; }
.as-gain-title { font-size: 14px; font-weight: 700; color: #1e293b; margin: 0 0 12px; }
.as-gain-row   { display: grid; grid-template-columns: 200px 180px 1fr; gap: 16px; align-items: end; }
.as-gain-avail { font-size: 14px; color: #374151; margin: 0; padding: 8px 0; }
.as-tax-row    { display: flex; gap: 24px; align-items: flex-end; margin-top: 4px; }
.as-tax-row .as-field-group { width: 220px; }

/* Shipping */
.as-ship-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }
.as-ship-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; flex-wrap: wrap; gap: 12px; }
.as-add-exp-btn { display: inline-flex; align-items: center; gap: 8px; padding: 11px 22px; background: #4f46e5; color: #fff; border: none; border-radius: 8px; font-size: 13.5px; font-weight: 600; cursor: pointer; }
.as-add-exp-btn:hover { background: #4338ca; }
.as-total-payable { font-size: 15px; font-weight: 700; color: #1e293b; margin: 0; }
.as-total-payable strong { font-size: 18px; margin-left: 6px; }

/* Payment */
.as-pay-title    { font-size: 16px; font-weight: 700; color: #1e293b; margin: 0 0 6px; }
.as-advance-lbl  { font-size: 13px; color: #374151; margin: 0 0 16px; }
.as-advance-lbl strong { color: #4f46e5; }
.as-pay-grid     { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 14px; }
.as-divider      { border: none; border-top: 1px solid var(--border); margin: 16px 0; }
.as-change-block { }
.as-change-label { font-size: 13px; font-weight: 700; color: #374151; margin: 0 0 4px; }
.as-change-val   { font-size: 24px; font-weight: 800; color: #1e293b; margin: 0; }
.as-balance-row  { text-align: right; font-size: 14px; color: #374151; font-weight: 700; }
.as-balance-row strong { font-size: 16px; color: #1e293b; }

/* Bottom buttons */
.as-btn-bar        { display: flex; justify-content: center; gap: 16px; padding: 8px 0 16px; }
.as-btn-save       { padding: 13px 52px; background: #4f46e5; color: #fff; border: none; border-radius: 10px; font-size: 16px; font-weight: 700; cursor: pointer; }
.as-btn-save:hover { background: #4338ca; }
.as-btn-save-print       { padding: 13px 52px; background: #059669; color: #fff; border: none; border-radius: 10px; font-size: 16px; font-weight: 700; cursor: pointer; }
.as-btn-save-print:hover { background: #047857; }

/* ── Purchase Action Modals (View / Delete / Payment / Status) ── */
.pam-overlay {
  display: none; position: fixed; inset: 0; z-index: 1200;
  background: rgba(0,0,0,.46); align-items: center; justify-content: center;
}
.pam-overlay.pam-open { display: flex; }

.pam-modal {
  background: #fff; border-radius: 14px; width: 100%; max-width: min(960px, 96vw);
  box-shadow: 0 20px 60px rgba(0,0,0,.22); display: flex; flex-direction: column;
  max-height: 92vh; margin: 16px; overflow: hidden;
}

.pam-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px; border-bottom: 1.5px solid var(--border);
  background: #f8fafc; border-radius: 14px 14px 0 0;
}
.pam-title { font-size: 15px; font-weight: 700; color: #1e293b; }
.pam-close {
  background: none; border: none; font-size: 16px; color: #9ca3af;
  cursor: pointer; padding: 4px 8px; border-radius: 6px; transition: var(--tr);
}
.pam-close:hover { background: #e2e8f0; color: #1e293b; }

.pam-body { padding: 20px 22px; overflow-y: auto; flex: 1; display: flex; flex-direction: column; gap: 14px; }

.pam-footer {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 14px 22px; border-top: 1.5px solid var(--border); background: #f8fafc;
}

/* Info grid (view purchase/sale) */
.pam-info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px 16px; }
.pam-info-item { display: flex; flex-direction: column; gap: 3px; padding: 10px 12px; background: #f8fafc; border-radius: 8px; border: 1px solid var(--border); }
.pam-info-label { font-size: 11.5px; font-weight: 600; color: #6b7280; text-transform: uppercase; letter-spacing: .4px; }
.pam-info-val   { font-size: 13.5px; font-weight: 600; color: #1e293b; }
.pam-total { color: #059669; font-size: 15px; }
.pam-due   { color: #dc2626; font-size: 15px; }
.pam-notes { padding: 10px 14px; background: #fffbeb; border: 1.5px solid #fde68a; border-radius: 8px; font-size: 13px; color: #92400e; }

.pam-sect-label { font-size: 13px; font-weight: 700; color: #4f46e5; padding-bottom: 6px; border-bottom: 2px solid #e0e7ff; }

/* Items / payments table */
.pam-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.pam-table thead th { background: #059669; color: #fff; padding: 9px 10px; text-align: left; font-weight: 700; font-size: 12px; }
.pam-table tbody td { padding: 9px 10px; border-bottom: 1px solid #f1f5f9; color: #374151; }
.pam-table tbody tr:last-child td { border-bottom: none; }
.pam-table tbody tr:hover td { background: #f8fafc; }
.pam-sku { font-size: 11px; color: #9ca3af; }
.pam-pay-amt-cell { font-weight: 700; color: #059669; }
.pam-no-items { text-align: center; padding: 28px; color: #9ca3af; font-size: 14px; }

/* Confirm / delete */
.pam-confirm-msg { text-align: center; padding: 24px 16px; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.pam-warn-icon   { font-size: 2.4rem; color: #dc2626; }
.pam-notif-icon  { font-size: 2.4rem; color: #4f46e5; }
.pam-confirm-msg p { font-size: 14.5px; color: #1e293b; margin: 0; }
.pam-confirm-sub   { font-size: 12.5px; color: #6b7280 !important; }

/* Payment info summary */
.pam-pay-info { display: flex; flex-direction: column; gap: 6px; }
.pam-pay-info-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; background: #f8fafc; border-radius: 8px; font-size: 13.5px; color: #374151; }
.pam-pay-due-row { background: #fef9c3; border: 1.5px solid #fde68a; }
.pam-pay-due-row strong { color: #b45309; }

/* Payment history inside Add Payment modal */
.pap-history { margin: 14px 0 4px; border: 1.5px solid #e5e7eb; border-radius: 10px; overflow: hidden; }
.pap-history-title { padding: 8px 14px; background: #f1f5f9; font-size: 12.5px; font-weight: 700; color: #475569; border-bottom: 1.5px solid #e5e7eb; }
.pap-history-title i { margin-right: 6px; color: #6366f1; }
.pap-hist-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.pap-hist-table thead th { background: #f8fafc; padding: 7px 10px; text-align: left; font-weight: 700; color: #374151; border-bottom: 1px solid #e5e7eb; }
.pap-hist-table tbody td { padding: 7px 10px; border-bottom: 1px solid #f3f4f6; color: #374151; }
.pap-hist-table tbody tr:last-child td { border-bottom: none; }
.pap-hist-amt { font-weight: 700; color: #059669; }
.pap-hist-note { color: #6b7280; font-style: italic; }
.pap-hist-total { background: #f0fdf4; }
.pap-hist-total td { padding: 7px 10px; font-weight: 700; color: #15803d; border-top: 1.5px solid #bbf7d0; }
.pap-new-label { margin: 18px 0 10px; font-size: 13px; font-weight: 700; color: #4f46e5; display: flex; align-items: center; gap: 6px; }
.pap-new-label i { font-size: 13px; }

/* Form inside modal */
.pam-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px; }
.pam-field { display: flex; flex-direction: column; gap: 5px; }
.pam-field-full { grid-column: span 2; }
.pam-label { font-size: 12.5px; font-weight: 600; color: #374151; }
.pam-input {
  padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; width: 100%; transition: border-color var(--tr);
}
.pam-input:focus { outline: none; border-color: #4f46e5; }
.pam-select {
  padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; background: #fff; width: 100%; cursor: pointer;
  transition: border-color var(--tr);
}
.pam-select:focus { outline: none; border-color: #4f46e5; }
.pam-textarea {
  width: 100%; padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; resize: vertical; font-family: inherit;
  transition: border-color var(--tr);
}
.pam-textarea:focus { outline: none; border-color: #4f46e5; }
/* Edit Purchase — Items section */
.ep-items-section {
  margin-top: 20px; border-top: 1.5px solid var(--border); padding-top: 16px;
  display: flex; flex-direction: column; gap: 12px;
}
.ep-items-header { display: flex; align-items: center; justify-content: space-between; }
.ep-items-title { font-size: 14px; font-weight: 700; color: #1e293b; display: flex; align-items: center; gap: 8px; }
.ep-items-title i { color: #4f46e5; }
.ep-items-count { font-size: 12px; color: #6b7280; background: #f1f5f9; border-radius: 20px; padding: 2px 10px; }
.ep-table-wrap { overflow-x: auto; border-radius: 8px; border: 1.5px solid var(--border); }
.ep-items-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ep-items-table th {
  background: #f8fafc; padding: 9px 12px; font-size: 12px; font-weight: 600;
  color: #475569; text-transform: uppercase; letter-spacing: .4px; border-bottom: 1.5px solid var(--border);
}
.ep-items-table td { padding: 8px 12px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.ep-items-table tbody tr:last-child td { border-bottom: none; }
.ep-cell-input {
  width: 100%; padding: 5px 8px; border: 1.5px solid var(--border); border-radius: 6px;
  font-size: 13px; color: #1e293b; background: #fff;
}
.ep-cell-input:focus { outline: none; border-color: #4f46e5; }
.ep-del-btn {
  background: none; border: none; color: #ef4444; cursor: pointer;
  padding: 4px 6px; border-radius: 4px; font-size: 13px;
}
.ep-del-btn:hover { background: #fef2f2; }
.ep-add-row {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  padding: 10px 12px; background: #f8fafc; border-radius: 8px;
  border: 1.5px dashed #cbd5e1;
}
.ep-search-wrap { position: relative; flex: 1; min-width: 180px; }
.ep-add-prod { width: 100%; }
.ep-ac-box {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: #fff; border: 1.5px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.13); z-index: 1200;
  display: none; max-height: 230px; overflow-y: auto;
}
.ep-ac-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px; cursor: pointer; font-size: 13px;
  border-bottom: 1px solid #f1f5f9;
}
.ep-ac-item:last-child { border-bottom: none; }
.ep-ac-item:hover { background: #f0f9ff; }
.ep-ac-empty { color: #9ca3af; cursor: default; font-style: italic; }
.ep-ac-name  { flex: 1; font-weight: 600; color: #1e293b; }
.ep-ac-sku   { font-size: 11px; color: #6b7280; }
.ep-ac-price { font-size: 12px; color: #4f46e5; font-weight: 600; white-space: nowrap; }
.ep-add-qty  { width: 80px; flex-shrink: 0; }
.ep-add-cost { width: 110px; flex-shrink: 0; }
.ep-add-btn  { flex-shrink: 0; white-space: nowrap; }
.ep-total-row {
  text-align: right; font-size: 14px; color: #475569;
  padding: 6px 4px;
}
.ep-total-row strong { font-size: 16px; color: #1e293b; margin-left: 8px; }

/* Shared items table inside edit modals (ST, SA, Expenses) */
.pam-items-section {
  margin-top: 18px; border-top: 1.5px solid var(--border); padding-top: 14px;
  display: flex; flex-direction: column; gap: 10px;
}
.pam-items-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.pam-items-title { font-size: 13.5px; font-weight: 700; color: #1e293b; display: flex; align-items: center; gap: 7px; }
.pam-items-title i { color: #4f46e5; }
.pam-items-search {
  padding: 7px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13px; color: #1e293b; width: 260px; outline: none;
  transition: border-color var(--tr);
}
.pam-items-search:focus { border-color: #4f46e5; }
.pam-suggest-box {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: #fff; border: 1.5px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.13); z-index: 1300;
  max-height: 220px; overflow-y: auto;
}
.pam-suggest-box.hidden { display: none; }
.pam-suggest-item {
  display: flex; align-items: center; gap: 10px; padding: 9px 14px;
  cursor: pointer; font-size: 13px; border-bottom: 1px solid #f1f5f9;
}
.pam-suggest-item:last-child { border-bottom: none; }
.pam-suggest-item:hover { background: #f0f9ff; }
.psi-name  { flex: 1; font-weight: 600; color: #1e293b; }
.psi-sku   { font-size: 11px; color: #6b7280; }
.psi-price { font-size: 12px; color: #4f46e5; font-weight: 600; white-space: nowrap; }
.pam-items-table { width: 100%; border-collapse: collapse; font-size: 13px; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.pam-items-table th {
  background: #f8fafc; padding: 9px 10px; font-size: 11.5px; font-weight: 700;
  color: #475569; text-transform: uppercase; letter-spacing: .4px; border-bottom: 1.5px solid var(--border);
  text-align: left;
}
.pam-items-table td { padding: 7px 10px; border-bottom: 1px solid #f1f5f9; vertical-align: middle; }
.pam-items-table tbody tr:last-child td { border-bottom: none; }
.pam-items-table tbody tr:hover td { background: #f8fafc; }
.pam-inline-input {
  width: 70px; padding: 5px 7px; border: 1.5px solid var(--border); border-radius: 6px;
  font-size: 12.5px; color: #1e293b; text-align: center;
}
.pam-inline-input:focus { outline: none; border-color: #4f46e5; }
.pam-inline-desc { width: 180px; text-align: left; }
.pam-del-row {
  background: none; border: none; color: #ef4444; cursor: pointer;
  padding: 4px 7px; border-radius: 5px; font-size: 13px;
}
.pam-del-row:hover { background: #fef2f2; }
.pam-empty-row { text-align: center; color: #9ca3af; padding: 18px; font-style: italic; font-size: 12.5px; }
.pam-items-totals { display: flex; justify-content: flex-end; }
.pam-tot-row {
  display: flex; gap: 24px; align-items: center; padding: 8px 12px;
  background: #f0fdf4; border: 1.5px solid #bbf7d0; border-radius: 8px;
  font-size: 13px; color: #374151;
}
.pam-tot-row strong { color: #059669; }
.pam-add-row-btn {
  padding: 6px 14px; background: #4f46e5; color: #fff; border: none;
  border-radius: 7px; font-size: 12.5px; font-weight: 600; cursor: pointer;
  display: inline-flex; align-items: center; gap: 5px; transition: var(--tr);
}
.pam-add-row-btn:hover { background: #4338ca; }

.pam-money-wrap { display: flex; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.pam-money-pre { padding: 0 11px; background: #f1f5f9; color: #475569; font-size: 13px; font-weight: 600; border-right: 1.5px solid var(--border); display: flex; align-items: center; }
.pam-input-money { border: none; border-radius: 0; flex: 1; }
.pam-input-money:focus { outline: none; }

/* Buttons */
.pam-btn {
  padding: 9px 22px; border-radius: 8px; font-size: 13.5px; font-weight: 700;
  cursor: pointer; display: inline-flex; align-items: center; gap: 7px; transition: var(--tr);
}
.pam-btn-outline { border: 1.5px solid var(--border); background: #fff; color: #374151; }
.pam-btn-outline:hover { background: #f1f5f9; }
.pam-btn-primary { border: none; background: #4f46e5; color: #fff; }
.pam-btn-primary:hover { background: #3730a3; }
.pam-btn-danger  { border: none; background: #dc2626; color: #fff; }
.pam-btn-danger:hover  { background: #b91c1c; }

/* ── Purchase action modal extras ── */
.pam-pr-info {
  display: flex; gap: 20px; flex-wrap: wrap;
  padding: 10px 14px; background: #f8fafc;
  border: 1px solid var(--border); border-radius: 8px;
  font-size: 13px; color: #374151;
}
.pam-labels-info {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 12px; background: #eff6ff; border: 1.5px solid #bfdbfe;
  border-radius: 8px; font-size: 13px; color: #1d4ed8; margin-bottom: 14px;
}
.pam-label-ref { font-size: 12px; color: #6b7280; }
.pam-labels-grid {
  display: flex; flex-wrap: wrap; gap: 12px;
}
.pam-label-card {
  border: 1.5px solid #374151; border-radius: 8px;
  padding: 10px 12px; width: 148px; text-align: center;
  background: #fff;
}
.pam-lc-name  { font-size: 11.5px; font-weight: 700; color: #1e293b; margin-bottom: 3px; line-height: 1.3; }
.pam-lc-sku   { font-size: 10px; color: #6b7280; }
.pam-lc-bars  { display: flex; align-items: flex-end; justify-content: center; gap: 1.5px; margin: 6px auto; }
.pam-bar      { background: #1e293b; display: inline-block; border-radius: 1px; }
.pam-lc-price { font-size: 13px; font-weight: 800; color: #059669; margin-top: 5px; }

/* ── Purchase Import Modal ── */
.api-overlay {
  display: none; position: fixed; inset: 0; z-index: 1100;
  background: rgba(0,0,0,.45); align-items: center; justify-content: center;
}
.api-overlay.api-open { display: flex; }

.api-modal {
  background: #fff; border-radius: 14px; width: 100%; max-width: 600px;
  box-shadow: 0 20px 60px rgba(0,0,0,.22); display: flex; flex-direction: column;
  max-height: 90vh; margin: 16px;
}

.api-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1.5px solid var(--border);
}
.api-title { font-size: 16px; font-weight: 700; color: #1e293b; display: flex; align-items: center; gap: 9px; }
.api-close {
  background: none; border: none; font-size: 16px; color: #9ca3af;
  cursor: pointer; padding: 4px 7px; border-radius: 6px; transition: var(--tr);
}
.api-close:hover { background: #f1f5f9; color: #1e293b; }

.api-body { padding: 20px 22px; overflow-y: auto; display: flex; flex-direction: column; gap: 16px; }

.api-tip {
  display: flex; gap: 12px; padding: 12px 15px;
  background: #eff6ff; border: 1.5px solid #bfdbfe; border-radius: 10px;
}
.api-tip-icon { color: #2563eb; font-size: 15px; margin-top: 2px; flex-shrink: 0; }
.api-tip-list { margin: 0; padding-left: 18px; font-size: 13px; color: #374151; line-height: 1.8; }

.btn-api-tpl {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 18px; border-radius: 8px; border: 1.5px solid #4f46e5;
  background: #eef2ff; color: #4f46e5; font-size: 13.5px; font-weight: 700;
  cursor: pointer; transition: var(--tr); align-self: flex-start;
}
.btn-api-tpl:hover { background: #e0e7ff; }

.api-upload-zone {
  border: 2.5px dashed #94a3b8; border-radius: 12px; padding: 36px 20px;
  text-align: center; cursor: pointer; background: #f8fafc; transition: var(--tr);
}
.api-upload-zone:hover, .api-upload-zone.api-drag {
  border-color: #4f46e5; background: #eef2ff;
}
.api-upload-icon { font-size: 2.8rem; color: #94a3b8; margin-bottom: 10px; }
.api-upload-zone:hover .api-upload-icon, .api-upload-zone.api-drag .api-upload-icon { color: #4f46e5; }
.api-upload-title { font-size: 15px; font-weight: 700; color: #374151; margin-bottom: 5px; }
.api-upload-sub { font-size: 13px; color: #6b7280; }
.api-upload-link { color: #4f46e5; font-weight: 600; text-decoration: underline; }

.api-file-info { }
.api-fi-inner {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 15px; background: #f0fdf4;
  border: 1.5px solid #bbf7d0; border-radius: 10px;
}
.api-fi-icon { font-size: 1.8rem; color: #16a34a; }
.api-fi-meta { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.api-fi-name { font-size: 13.5px; font-weight: 700; color: #1e293b; }
.api-fi-size { font-size: 12px; color: #6b7280; }
.api-fi-remove {
  background: none; border: none; color: #dc2626; font-size: 15px;
  cursor: pointer; padding: 4px 8px; border-radius: 6px; transition: var(--tr);
}
.api-fi-remove:hover { background: #fee2e2; }

.api-prev-bar {
  display: flex; align-items: center; gap: 10px; margin-bottom: 8px;
}
.api-prev-label { font-size: 13.5px; font-weight: 700; color: #374151; }
.api-prev-badge {
  padding: 2px 9px; border-radius: 20px; background: #dbeafe; color: #1d4ed8;
  font-size: 12px; font-weight: 700;
}
.api-prev-note { font-size: 12px; color: #9ca3af; }
.api-prev-scroll { overflow-x: auto; border-radius: 8px; border: 1px solid var(--border); }
.api-prev-table { font-size: 12.5px; }

.api-footer {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 16px 22px; border-top: 1.5px solid var(--border);
}
.btn-api-cancel {
  padding: 9px 20px; border-radius: 8px; border: 1.5px solid var(--border);
  background: #fff; color: #374151; font-size: 13.5px; font-weight: 600;
  cursor: pointer; transition: var(--tr);
}
.btn-api-cancel:hover { background: #f1f5f9; }
.btn-api-import {
  padding: 9px 22px; border-radius: 8px; border: none;
  background: #4f46e5; color: #fff; font-size: 13.5px; font-weight: 700;
  cursor: pointer; display: inline-flex; align-items: center; gap: 7px;
  transition: var(--tr);
}
.btn-api-import:hover:not(:disabled) { background: #3730a3; }
.btn-api-import:disabled { background: #94a3b8; cursor: not-allowed; }

/* ── Add Purchase Page ── */
.ap-page-wrap { display: flex; flex-direction: column; gap: 20px; }

.ap-page-header {
  display: flex; align-items: center; gap: 14px; margin-bottom: 4px;
}
.ap-page-title { font-size: 20px; font-weight: 700; color: #1e293b; }
.btn-ap-back {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 15px; border-radius: 8px; border: 1.5px solid #4f46e5;
  background: #fff; color: #4f46e5; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: var(--tr);
}
.btn-ap-back:hover { background: #eef2ff; }

.ap-card {
  background: #fff; border-radius: 12px; border: 1px solid var(--border);
  padding: 22px 26px; box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.ap-card-title {
  font-size: 15px; font-weight: 700; color: #1e293b;
  margin-bottom: 18px; display: flex; align-items: center; gap: 8px;
}

/* Header grid */
.ap-header-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px 20px; align-items: start;
}
.ap-supplier-wrap { grid-column: span 1; }
.ap-attach-group  { grid-column: span 2; }

.ap-field-group { display: flex; flex-direction: column; gap: 5px; }
.ap-label { font-size: 12.5px; font-weight: 600; color: #374151; }
.ap-req   { color: #dc2626; }

.ap-input {
  padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; background: #fff; width: 100%;
  transition: border-color var(--tr);
}
.ap-input:focus { outline: none; border-color: #4f46e5; }

.ap-select {
  padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; background: #fff; width: 100%; cursor: pointer;
  transition: border-color var(--tr);
}
.ap-select:focus { outline: none; border-color: #4f46e5; }

.ap-supplier-row { display: flex; gap: 8px; align-items: center; }
.ap-supplier-addr { font-size: 12px; color: #6b7280; margin-top: 4px; min-height: 16px; }

.btn-ap-quick {
  padding: 7px 10px; border-radius: 7px; border: 1.5px solid #4f46e5;
  background: #4f46e5; color: #fff; cursor: pointer; font-size: 12px;
  flex-shrink: 0; transition: var(--tr);
}
.btn-ap-quick:hover { background: #3730a3; }

.ap-date-wrap { display: flex; align-items: center; gap: 10px; }
.ap-date-time { font-size: 12px; color: #6b7280; white-space: nowrap; }

.ap-attach-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 14px; border-radius: 8px; border: 1.5px dashed #94a3b8;
  background: #f8fafc; color: #475569; font-size: 13px; cursor: pointer;
  transition: var(--tr);
}
.ap-attach-btn:hover { border-color: #4f46e5; color: #4f46e5; }
.ap-attach-name { font-size: 12px; color: #9ca3af; margin-top: 4px; display: block; }

/* Product search */
.ap-product-topbar {
  display: flex; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap;
}
.btn-ap-import {
  padding: 8px 15px; border-radius: 8px; border: 1.5px solid #0891b2;
  background: #fff; color: #0891b2; font-size: 13px; font-weight: 600;
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
  transition: var(--tr);
}
.btn-ap-import:hover { background: #ecfeff; }

.ap-search-wrap { position: relative; flex: 1; min-width: 220px; }
.ap-search-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: #9ca3af; font-size: 13px; }
.ap-search-input {
  width: 100%; padding: 9px 12px 9px 34px; border: 1.5px solid var(--border);
  border-radius: 8px; font-size: 13.5px; color: #1e293b;
  transition: border-color var(--tr);
}
.ap-search-input:focus { outline: none; border-color: #4f46e5; }

.ap-autocomplete {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 200;
  background: #fff; border: 1.5px solid #e2e8f0; border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12); display: none; max-height: 260px; overflow-y: auto;
}
.ap-autocomplete.ap-ac-open { display: block; }
.ap-ac-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; cursor: pointer; transition: background var(--tr);
}
.ap-ac-item:hover { background: #f1f5f9; }
.ap-ac-empty { color: #9ca3af; cursor: default; }
.ap-ac-name  { flex: 1; font-size: 13.5px; font-weight: 600; color: #1e293b; }
.ap-ac-sku   { font-size: 11.5px; color: #6b7280; }
.ap-ac-price { font-size: 13px; font-weight: 700; color: #059669; }

.btn-ap-newprod {
  padding: 8px 15px; border-radius: 8px; border: 1.5px solid #059669;
  background: #ecfdf5; color: #059669; font-size: 13px; font-weight: 600;
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
  transition: var(--tr);
}
.btn-ap-newprod:hover { background: #d1fae5; }

/* Items table */
.ap-items-wrap { overflow: hidden; border-radius: 10px; border: 1.5px solid #d1fae5; }
.ap-items-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ap-items-head th {
  background: #059669; color: #fff; padding: 11px 10px; text-align: left;
  font-weight: 700; font-size: 12.5px; white-space: nowrap;
}
.ap-items-head th:first-child { border-radius: 0; }
.ap-th-num  { width: 40px; text-align: center; }
.ap-th-qty  { width: 100px; }
.ap-th-cost { width: 140px; }
.ap-th-disc { width: 80px; }
.ap-th-del  { width: 48px; }
.ap-items-table tbody tr { border-bottom: 1px solid #f0fdf4; }
.ap-items-table tbody tr:last-child { border-bottom: none; }
.ap-items-table tbody tr:hover { background: #f0fdf4; }
.ap-td-num  { text-align: center; color: #6b7280; font-size: 12px; }
.ap-td-ro   { color: #1e293b; font-weight: 600; padding: 10px; white-space: nowrap; }
.ap-items-table td { padding: 8px 10px; vertical-align: middle; }
.ap-item-name { font-weight: 600; color: #1e293b; }
.ap-item-sku  { font-size: 11px; color: #9ca3af; }
.ap-item-input {
  width: 100%; padding: 5px 8px; border: 1.5px solid var(--border); border-radius: 6px;
  font-size: 13px; text-align: right; transition: border-color var(--tr);
}
.ap-item-input:focus { outline: none; border-color: #059669; }

.btn-ap-del-item {
  padding: 5px 8px; border: none; background: #fee2e2; color: #dc2626;
  border-radius: 6px; cursor: pointer; font-size: 12px; transition: var(--tr);
}
.btn-ap-del-item:hover { background: #fca5a5; }

.ap-empty-row td {
  text-align: center; padding: 40px; color: #9ca3af; font-size: 14px; line-height: 2;
}

/* Items totals */
.ap-items-totals {
  margin-top: 14px; border-top: 2px solid #f1f5f9; padding-top: 12px;
  display: flex; flex-direction: column; gap: 6px; align-items: flex-end;
}
.ap-tot-row { display: flex; gap: 40px; font-size: 13.5px; color: #374151; }
.ap-tot-bold { font-weight: 700; font-size: 15px; color: #1e293b; }

/* Discount / Tax / Notes */
.ap-disc-tax-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; margin-bottom: 22px; }
.ap-sect { display: flex; flex-direction: column; gap: 12px; }
.ap-sect-label { font-size: 13.5px; font-weight: 700; color: #4f46e5; padding-bottom: 4px; border-bottom: 2px solid #e0e7ff; }
.ap-calc-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 10px; background: #f8fafc; border-radius: 8px; }
.ap-calc-label { font-size: 13px; color: #6b7280; font-weight: 600; }
.ap-calc-val { font-size: 13.5px; font-weight: 700; color: #1e293b; }
.ap-textarea {
  width: 100%; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; resize: vertical; font-family: inherit;
  transition: border-color var(--tr);
}
.ap-textarea:focus { outline: none; border-color: #4f46e5; }
.ap-sect-notes { grid-column: span 1; }

/* Shipping box */
.ap-shipping-box { border-top: 2px solid #f1f5f9; padding-top: 20px; }
.ap-ship-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; margin-top: 14px; align-items: end; }
.ap-money-wrap { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; }
.ap-money-prefix { padding: 0 10px; background: #f1f5f9; color: #475569; font-size: 13px; font-weight: 600; border-right: 1.5px solid var(--border); height: 100%; display: flex; align-items: center; white-space: nowrap; }
.ap-input-money { border: none; border-radius: 0; flex: 1; width: auto; }
.ap-input-money:focus { outline: none; }

.btn-ap-add-exp {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 8px; border: 1.5px dashed #94a3b8;
  background: #f8fafc; color: #475569; font-size: 13px; cursor: pointer;
  transition: var(--tr); width: 100%; justify-content: center;
}
.btn-ap-add-exp:hover { border-color: #4f46e5; color: #4f46e5; background: #eef2ff; }

.ap-purchase-total-row {
  display: flex; justify-content: flex-end; align-items: center; gap: 24px;
  margin-top: 18px; padding: 14px 18px; background: #f0fdf4;
  border-radius: 10px; border: 1.5px solid #bbf7d0;
}
.ap-ptot-label { font-size: 15px; font-weight: 700; color: #374151; }
.ap-ptot-val   { font-size: 18px; font-weight: 800; color: #059669; }

/* Payment card */
.ap-payment-card { }
.ap-payment-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; }
.ap-pay-info-row {
  grid-column: span 2; display: flex; align-items: center; gap: 14px;
  padding: 10px 14px; background: #f8fafc; border-radius: 8px; border: 1px solid #e2e8f0;
}
.ap-pay-info-label { font-size: 13px; font-weight: 600; color: #6b7280; }
.ap-pay-info-val   { font-size: 14px; font-weight: 700; color: #1e293b; }
.ap-pay-note-group { grid-column: span 2; }
.ap-pay-due-row {
  grid-column: span 2; display: flex; justify-content: flex-end; align-items: center; gap: 18px;
  padding: 10px 14px; background: #fef9c3; border-radius: 8px; border: 1.5px solid #fde68a;
}
.ap-pay-due-label { font-size: 13.5px; font-weight: 700; color: #92400e; }
.ap-pay-due-val   { font-size: 16px; font-weight: 800; color: #b45309; }

.ap-save-row { display: flex; justify-content: center; margin-top: 22px; }
.btn-ap-save {
  padding: 12px 48px; border-radius: 10px; border: none;
  background: #4f46e5; color: #fff; font-size: 15px; font-weight: 700;
  cursor: pointer; display: inline-flex; align-items: center; gap: 9px;
  box-shadow: 0 4px 14px rgba(79,70,229,.35); transition: var(--tr);
}
.btn-ap-save:hover { background: #3730a3; transform: translateY(-1px); }
.btn-ap-save:active { transform: translateY(0); }

/* ── Dashboard: Trending Items & Stock Alert ── */
/* Date range popup anchored to its select wrapper */
.trp-date-wrap { position: relative; }

.trend-range-popup {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 500;
  background: #fff; border: 1.5px solid #e2e8f0; border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.15); width: 280px;
  animation: trp-in .15s ease;
}
@keyframes trp-in { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }

.trp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 10px; border-bottom: 1px solid var(--border);
}
.trp-title { font-size: 14px; font-weight: 700; color: #1e293b; display: flex; align-items: center; gap: 8px; }
.trp-title i { color: #4f46e5; }
.trp-close {
  background: none; border: none; font-size: 14px; color: #9ca3af;
  cursor: pointer; padding: 3px 6px; border-radius: 5px; transition: var(--tr);
}
.trp-close:hover { background: #f1f5f9; color: #1e293b; }

.trp-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 12px; }
.trp-field { display: flex; flex-direction: column; gap: 5px; }
.trp-label { font-size: 12px; font-weight: 600; color: #6b7280; text-transform: uppercase; letter-spacing: .4px; }
.trp-input {
  padding: 9px 11px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 13.5px; color: #1e293b; width: 100%; transition: border-color var(--tr);
}
.trp-input:focus { outline: none; border-color: #4f46e5; }

.trp-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 10px 16px 14px; border-top: 1px solid var(--border);
}
.trp-btn {
  padding: 8px 18px; border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: var(--tr);
}
.trp-btn-clear { border: 1.5px solid var(--border); background: #fff; color: #6b7280; }
.trp-btn-clear:hover { background: #f1f5f9; }
.trp-btn-apply { border: none; background: #4f46e5; color: #fff; }
.trp-btn-apply:hover { background: #3730a3; }

.trend-view-more-row {
  display: flex; justify-content: center; padding: 14px 0 4px;
  border-top: 1px solid var(--border); margin-top: 10px;
}
.btn-trend-more {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 24px; border-radius: 20px;
  border: 1.5px solid var(--border); background: #f8fafc;
  color: #4f46e5; font-size: 13px; font-weight: 700;
  cursor: pointer; transition: var(--tr);
}
.btn-trend-more:hover { background: #eef2ff; border-color: #4f46e5; }

.dash-trend-header {
  flex-wrap: wrap; gap: 12px; align-items: flex-start;
}
.dash-trend-filters {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-left: auto;
}
.dash-filter-sel {
  padding: 7px 10px; border: 1.5px solid var(--border); border-radius: 8px;
  font-size: 12.5px; color: #374151; background: #fff; cursor: pointer;
  transition: border-color var(--tr); min-width: 120px;
}
.dash-filter-sel:focus { outline: none; border-color: #4f46e5; }

/* Stock Alert card */
.dash-stock-card {
  background: #fff; border-radius: 12px; border: 1px solid var(--border);
  padding: 20px 24px; box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.dash-sa-header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 4px;
}
.dash-sa-title-wrap {
  display: flex; align-items: center; gap: 10px;
}
.dash-sa-title { font-size: 16px; font-weight: 700; color: #1e293b; }
.dash-sa-info  { color: #60a5fa; cursor: pointer; font-size: 14px; }

/* Stock alert table cells */
.sa-stock-neg { color: #dc2626; font-weight: 700; }
.sa-stock-low { color: #d97706; font-weight: 700; }
.sa-sku       { font-size: 11px; color: #9ca3af; }

/* ── POS TERMINAL ── */
.pos-wrap {
  display: flex; height: calc(100vh - 56px); overflow: hidden;
  background: #f1f5f9; gap: 0;
}
/* LEFT */
.pos-left {
  flex: 0 0 62%; display: flex; flex-direction: column;
  background: #fff; border-right: 1px solid #e2e8f0; overflow: hidden;
}
/* TOP BAR */
.pos-topbar {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: #fff; border-bottom: 1px solid #e2e8f0; flex-wrap: wrap;
}
.pos-topbar-left  { display: flex; align-items: center; gap: 8px; flex: 1; }
.pos-topbar-icons { display: flex; gap: 4px; }
.pos-loc-label    { font-size: 13px; font-weight: 600; color: #374151; white-space: nowrap; }
.pos-loc-sel {
  border: 1px solid #d1d5db; border-radius: 6px; padding: 5px 8px;
  font-size: 13px; color: #374151; background: #fff; max-width: 140px;
}
.pos-datetime-btn {
  display: flex; align-items: center; gap: 6px;
  background: #4f46e5; color: #fff; border-radius: 6px;
  padding: 6px 12px; font-size: 12px; font-weight: 600; white-space: nowrap;
}
.pos-dt-icon { font-size: 11px; opacity: .8; }
.pos-icon-btn {
  width: 34px; height: 34px; border-radius: 6px; border: 1px solid #e2e8f0;
  background: #f8fafc; color: #374151; cursor: pointer; font-size: 13px;
  display: flex; align-items: center; justify-content: center; transition: background .15s;
}
.pos-icon-btn:hover  { background: #e0e7ff; color: #4f46e5; }
.pos-icon-red        { color: #dc2626; }
.pos-icon-red:hover  { background: #fee2e2; color: #dc2626; }
.pos-add-expense-btn {
  display: flex; align-items: center; gap: 6px;
  background: #fff; border: 1px solid #d1d5db; border-radius: 18px;
  padding: 6px 14px; font-size: 13px; font-weight: 600; color: #1e293b;
  cursor: pointer; white-space: nowrap;
}
.pos-add-expense-btn:hover { background: #f1f5f9; }

/* INPUTS ROW */
.pos-inputs-row {
  display: flex; gap: 8px; padding: 8px 12px; border-bottom: 1px solid #f1f5f9;
}
.pos-cust-wrap, .pos-prod-wrap {
  display: flex; align-items: center; gap: 6px; flex: 1;
  border: 1px solid #d1d5db; border-radius: 8px; padding: 4px 8px;
  background: #fff; position: relative;
}
.pos-prod-wrap { flex: 2; }
.pos-inp-icon  { color: #6b7280; font-size: 13px; flex-shrink: 0; }
.pos-cust-sel  { border: none; outline: none; background: transparent; flex: 1; font-size: 13px; color: #374151; }
.pos-prod-inp  { border: none; outline: none; background: transparent; flex: 1; font-size: 13px; color: #374151; }
.pos-prod-inp::placeholder { color: #9ca3af; }
.pos-inp-add-btn {
  width: 26px; height: 26px; border-radius: 50%; border: none;
  background: #2563eb; color: #fff; cursor: pointer; font-size: 12px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.pos-inp-add-btn:hover { background: #1d4ed8; }

/* PRODUCT AUTOCOMPLETE */
.pos-prod-ac {
  display: none; position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: #fff; border: 1px solid #d1d5db; border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12); z-index: 500; max-height: 220px; overflow-y: auto;
}
.pos-prod-ac.pos-ac-open { display: block; }
.pos-ac-item {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  cursor: pointer; font-size: 13px; border-bottom: 1px solid #f1f5f9;
}
.pos-ac-item:hover { background: #eff6ff; }
.pos-ac-name  { flex: 1; font-weight: 600; color: #1e293b; }
.pos-ac-sku   { color: #9ca3af; font-size: 11px; }
.pos-ac-price { color: #059669; font-weight: 700; }
.pos-ac-empty { padding: 12px; text-align: center; color: #9ca3af; font-size: 13px; }

/* META ROW */
.pos-meta-row {
  display: flex; gap: 8px; padding: 6px 12px; border-bottom: 1px solid #f1f5f9;
}
.pos-meta-item {
  display: flex; align-items: center; gap: 6px; flex: 1;
  border: 1px solid #e2e8f0; border-radius: 8px; padding: 6px 10px; background: #f8fafc;
}
.pos-meta-val  { font-size: 13px; color: #374151; flex: 1; }
.pos-date-inp  { border: none; background: transparent; font-size: 13px; color: #374151; flex: 1; outline: none; cursor: pointer; }
.pos-date-inp::-webkit-calendar-picker-indicator { opacity: .5; cursor: pointer; }
.pos-price-sel { border: none; background: transparent; font-size: 13px; color: #374151; flex: 1; outline: none; }
.pos-info-icon { color: #60a5fa; font-size: 12px; cursor: pointer; }

/* ITEMS TABLE */
.pos-items-wrap {
  flex: 1; overflow-y: auto; padding: 0;
}
.pos-items-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.pos-items-table thead th {
  background: #f8fafc; padding: 8px 12px; text-align: left;
  font-weight: 700; color: #374151; border-bottom: 2px solid #e2e8f0;
  position: sticky; top: 0;
}
.pos-items-table tbody td {
  padding: 8px 12px; border-bottom: 1px solid #f1f5f9; vertical-align: middle;
}
.pos-clear-btn {
  background: none; border: none; color: #dc2626; cursor: pointer; font-size: 16px;
}
.pos-empty-cell { text-align: center; color: #9ca3af; padding: 40px !important; font-size: 14px; }
.pos-item-name  { font-weight: 600; color: #1e293b; }
.pos-item-sku   { font-size: 11px; color: #9ca3af; }
.pos-item-price { font-size: 11px; color: #6b7280; margin-top: 2px; }
.pos-item-price-row { display: flex; align-items: center; gap: 2px; margin-top: 4px; }
.pos-item-price-lbl { font-size: 11px; color: #6b7280; }
.pos-item-price-inp {
  width: 66px; border: 1px solid #d1d5db; border-radius: 4px; padding: 2px 4px;
  font-size: 12px; text-align: right; background: #f8fafc; color: #1e293b;
}
.pos-item-price-inp:focus { outline: none; border-color: #3b82f6; background: #fff; }
.pos-item-pg-sel {
  margin-top: 4px; font-size: 11px; border: 1px solid #e2e8f0; border-radius: 4px;
  padding: 2px 4px; background: #f1f5f9; color: #374151; cursor: pointer; max-width: 140px;
}
.pos-item-pg-sel:focus { outline: none; border-color: #3b82f6; }
.pos-item-sub   { font-weight: 700; color: #1e293b; }
.pos-qty-ctrl   { display: flex; align-items: center; gap: 4px; }
.pos-qty-btn {
  width: 24px; height: 24px; border-radius: 4px; border: 1px solid #d1d5db;
  background: #f8fafc; cursor: pointer; font-size: 14px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.pos-qty-btn:hover { background: #dbeafe; border-color: #93c5fd; }
.pos-qty-inp {
  width: 52px; text-align: center; border: 1px solid #d1d5db; border-radius: 4px;
  padding: 3px 4px; font-size: 13px;
}
.pos-del-item-btn {
  background: none; border: none; color: #dc2626; cursor: pointer; font-size: 12px; padding: 4px;
}
.pos-del-item-btn:hover { color: #b91c1c; }

/* SUMMARY */
.pos-summary {
  display: flex; justify-content: space-between; padding: 10px 16px;
  border-top: 2px solid #e2e8f0; background: #f8fafc; gap: 16px; flex-wrap: wrap;
}
.pos-summary-left, .pos-summary-right { display: flex; flex-direction: column; gap: 4px; }
.pos-sum-row  { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.pos-sum-lbl  { font-weight: 700; color: #374151; }
.pos-sum-val  { color: #1e293b; font-weight: 600; }
.pos-gain-lbl { font-size: 13px; color: #6b7280; font-style: italic; }

/* ACTION BAR */
.pos-action-bar {
  display: flex; align-items: center; padding: 10px 12px; gap: 8px;
  background: #1e293b; border-top: 2px solid #0f172a;
}
.pos-action-left   { display: flex; gap: 6px; }
.pos-action-center { display: flex; gap: 8px; flex: 1; justify-content: center; }
.pos-action-right  { display: flex; align-items: center; gap: 10px; }
.pos-act-btn {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  background: #334155; border: none; border-radius: 8px;
  color: #fff; font-size: 11px; font-weight: 600;
  padding: 8px 12px; cursor: pointer; min-width: 60px; transition: background .15s;
}
.pos-act-btn:hover   { background: #475569; }
.pos-act-quot        { color: #fbbf24; }
.pos-act-suspend i   { color: #f87171; }
.pos-act-credit i    { color: #4ade80; }
.pos-act-card i      { color: #f87171; }
.pos-pay-multi-btn {
  display: flex; align-items: center; gap: 8px;
  background: #1e3a5f; color: #fff; border: none; border-radius: 8px;
  padding: 10px 20px; font-size: 14px; font-weight: 700; cursor: pointer;
}
.pos-pay-multi-btn:hover { background: #1e40af; }
.pos-cancel-btn {
  display: flex; align-items: center; gap: 8px;
  background: #dc2626; color: #fff; border: none; border-radius: 8px;
  padding: 10px 20px; font-size: 14px; font-weight: 700; cursor: pointer;
}
.pos-cancel-btn:hover { background: #b91c1c; }
.pos-payable-label { color: #94a3b8; font-size: 13px; font-weight: 600; line-height: 1.3; }
.pos-payable-val   { color: #4ade80; font-size: 2rem; font-weight: 900; line-height: 1; }

/* RIGHT PANEL */
.pos-right {
  flex: 1; display: flex; flex-direction: column; background: #f1f5f9; overflow: hidden;
}
.pos-tabs { display: flex; gap: 0; border-bottom: 1px solid #e2e8f0; }
.pos-tab-btn {
  flex: 1; padding: 12px; border: none; background: #e2e8f0;
  font-size: 14px; font-weight: 700; cursor: pointer; color: #374151;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s, color .15s;
}
.pos-tab-btn:hover     { background: #c7d2fe; }
.pos-tab-active        { background: #4f46e5 !important; color: #fff !important; }
.pos-tab-brand         { background: #ede9fe; }
.pos-tab-brand.pos-tab-active { background: #7c3aed !important; }
.pos-prod-grid {
  flex: 1; overflow-y: auto; padding: 10px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
  align-content: start;
}
.pos-prod-card {
  background: #fff; border-radius: 10px; border: 1px solid #e2e8f0;
  padding: 10px 6px; cursor: pointer; text-align: center;
  transition: box-shadow .15s, border-color .15s; user-select: none;
}
.pos-prod-card:hover  { box-shadow: 0 4px 16px rgba(79,70,229,.15); border-color: #a5b4fc; }
.pos-prod-card:active { transform: scale(.97); }
.pos-prod-img {
  width: 100%; aspect-ratio: 1; background: #f1f5f9; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: #cbd5e1; font-size: 24px; margin-bottom: 6px;
}
.pos-prod-img-photo { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; display: block; }
.pos-prod-name  { font-size: 11px; font-weight: 700; color: #1e293b; line-height: 1.3; }
.pos-prod-sku   { font-size: 10px; color: #6b7280; margin-top: 2px; }
.pos-prod-stock { font-size: 10px; color: #9ca3af; margin-top: 4px; }
.pos-grid-empty { text-align: center; padding: 40px 20px; color: #9ca3af; grid-column: 1/-1; font-size: 14px; }

/* Out-of-stock / max-reached card states */
.pos-prod-out   { opacity: .55; cursor: not-allowed; border-color: #fca5a5 !important; }
.pos-prod-out:hover { box-shadow: none !important; border-color: #fca5a5 !important; }
.pos-prod-maxed { border-color: #fcd34d !important; }
.pos-prod-maxed:hover { border-color: #f59e0b !important; box-shadow: 0 4px 12px rgba(245,158,11,.2) !important; }
.pos-stock-badge { display:inline-block; padding:1px 6px; border-radius:10px; font-size:10px; font-weight:700; margin-top:2px; }
.pos-stock-out  { background:#fee2e2; color:#dc2626; }
.pos-stock-max  { background:#fef3c7; color:#92400e; }

/* Online / Offline toggle + Sync */
.pos-mode-wrap   { display: flex; align-items: center; gap: 6px; }
.pos-mode-btn {
  display: flex; align-items: center; gap: 6px;
  border: none; border-radius: 20px; padding: 6px 14px;
  font-size: 13px; font-weight: 700; cursor: pointer; transition: background .2s, color .2s;
}
.pos-mode-online  { background: #dcfce7; color: #15803d; }
.pos-mode-online:hover  { background: #bbf7d0; }
.pos-mode-offline { background: #fee2e2; color: #b91c1c; }
.pos-mode-offline:hover { background: #fecaca; }
.pos-sync-btn {
  display: flex; align-items: center; gap: 5px; position: relative;
  background: #1e40af; color: #fff; border: none; border-radius: 20px;
  padding: 6px 14px; font-size: 13px; font-weight: 700; cursor: pointer;
  transition: background .2s;
}
.pos-sync-btn:hover { background: #1d4ed8; }
.pos-sync-badge {
  position: absolute; top: -6px; right: -6px;
  background: var(--accent); color: #fff; border-radius: 50%;
  width: 18px; height: 18px; font-size: 10px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
/* Mode indicator bar */
.pos-mode-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 16px; font-size: 12px; font-weight: 600;
}
.pos-modebar-online  { background: #f0fdf4; color: #15803d; border-bottom: 1px solid #bbf7d0; }
.pos-modebar-offline { background: #fff7ed; color: #c2410c; border-bottom: 1px solid #fed7aa; }

/* ── PRINT STYLES ── */
@media print {
  @page { size: 80mm auto; margin: 4mm; }

  /* Hide shell chrome */
  .sidebar, .top-nav, .page-header, .pur-filter-card, .as-form-card,
  .table-toolbar, .export-btns, .col-vis-wrap, .col-vis-panel,
  .action-dropdown, .btn-pur-actions, .dd-menu,
  .as-form-footer, .btn-cancel, .btn-primary,
  .pam-close, .pam-footer, .modal-footer, #modal-save-btn,
  #modal-overlay.hidden, #pur-act-overlay.hidden, #sl-act-overlay.hidden { display: none !important; }

  /* Show the current page's table */
  body, html { margin: 0; padding: 0; background: #fff; }
  #view-dynamic { display: block !important; width: 100% !important; padding: 0 !important; margin: 0 !important; }
  .pur-table-card, .table-responsive { box-shadow: none !important; border: none !important; padding: 0 !important; margin: 0 !important; }
  .pur-table-title { font-size: 11px; font-weight: 700; margin-bottom: 4px; display: block; }
  .table-footer { font-size: 10px; margin-top: 4px; }

  /* Table formatting for 80mm receipt width */
  .data-table { width: 100% !important; border-collapse: collapse; font-size: 9px; }
  .data-table th, .data-table td { padding: 3px 4px !important; border: 1px solid #999 !important; word-break: break-word; }
  .data-table th { background: #f3f4f6 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .data-table tr { page-break-inside: avoid; }

  /* Modal / overlay prints (receipts opened via print buttons in modals) */
  .modal-overlay, #pur-act-overlay, #sl-act-overlay {
    position: static !important; background: none !important; padding: 0 !important;
  }
  .modal, .pam-modal {
    box-shadow: none !important; max-width: 100% !important; max-height: none !important;
    margin: 0 !important; border-radius: 0 !important; width: 100% !important;
  }
  .modal-body, .pam-body { overflow: visible !important; max-height: none !important; }
}

/* ════════════════════════════════════════════════════════
   NOTIFICATION TEMPLATES
   ════════════════════════════════════════════════════════ */
.nt-layout {
  display: grid; grid-template-columns: 320px 1fr; gap: 20px;
  align-items: start; min-height: 0;
}
.nt-sidebar {
  background: #fff; border-radius: 12px; border: 1.5px solid var(--border);
  box-shadow: 0 2px 10px rgba(0,0,0,.06); display: flex; flex-direction: column;
  overflow: hidden;
}
.nt-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1.5px solid var(--border);
  background: #f8fafc; font-size: 14px; font-weight: 700; color: #1e293b;
}
.nt-add-btn {
  display: inline-flex; align-items: center; gap: 5px;
  background: #4f46e5; color: #fff; border: none; border-radius: 8px;
  padding: 6px 13px; font-size: 12.5px; font-weight: 700; cursor: pointer;
  transition: background .15s;
}
.nt-add-btn:hover { background: #4338ca; }
.nt-filter-row {
  display: flex; gap: 8px; padding: 10px 12px;
  border-bottom: 1px solid var(--border); background: #fafafa;
}
.nt-search {
  flex: 1; padding: 7px 10px; border: 1.5px solid var(--border);
  border-radius: 7px; font-size: 12.5px; color: #1e293b; outline: none;
}
.nt-search:focus { border-color: #4f46e5; }
.nt-type-filter {
  width: 90px; padding: 6px 8px; border: 1.5px solid var(--border);
  border-radius: 7px; font-size: 12px; color: #374151; background: #fff;
  cursor: pointer; outline: none;
}
.nt-list { overflow-y: auto; max-height: 600px; }
.nt-no-items { text-align: center; color: #9ca3af; padding: 28px; font-style: italic; font-size: 13px; }
.nt-list-item {
  padding: 12px 14px; cursor: pointer; border-bottom: 1px solid #f1f5f9;
  transition: background .12s;
}
.nt-list-item:last-child { border-bottom: none; }
.nt-list-item:hover { background: #f0f9ff; }
.nt-li-active { background: #eef2ff !important; border-left: 3px solid #4f46e5; }
.nt-li-top { display: flex; align-items: center; gap: 8px; }
.nt-li-icon { font-size: 13px; }
.nt-li-name { flex: 1; font-size: 13px; font-weight: 600; color: #1e293b; }
.nt-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.nt-dot-active   { background: #22c55e; }
.nt-dot-inactive { background: #d1d5db; }
.nt-li-sub { font-size: 11.5px; color: #6b7280; margin-top: 3px; padding-left: 21px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Preview panel */
.nt-preview-panel {
  background: #fff; border-radius: 12px; border: 1.5px solid var(--border);
  box-shadow: 0 2px 10px rgba(0,0,0,.06); min-height: 400px;
  display: flex; flex-direction: column;
}
.nt-preview-empty {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; color: #9ca3af; gap: 12px; padding: 60px;
}
.nt-empty-icon { font-size: 3rem; color: #c7d2fe; }
.nt-preview-empty p { font-size: 14px; }
.nt-preview-card { display: flex; flex-direction: column; gap: 14px; padding: 22px 24px; }
.nt-preview-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
}
.nt-preview-title-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.nt-preview-type-icon { font-size: 18px; }
.nt-preview-title { font-size: 18px; font-weight: 700; color: #1e293b; margin: 0; }
.nt-preview-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.nt-action-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 13px; border-radius: 8px; font-size: 12.5px; font-weight: 600;
  cursor: pointer; border: 1.5px solid; transition: background .14s;
}
.nt-btn-edit   { background: #eff6ff; color: #2563eb; border-color: #bfdbfe; }
.nt-btn-edit:hover { background: #dbeafe; }
.nt-btn-toggle { background: #f0fdf4; color: #166534; border-color: #bbf7d0; }
.nt-btn-toggle:hover { background: #dcfce7; }
.nt-btn-delete { background: #fef2f2; color: #dc2626; border-color: #fecaca; }
.nt-btn-delete:hover { background: #fee2e2; }
.nt-preview-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.nt-meta-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 20px; font-size: 12.5px; font-weight: 600;
}
.nt-preview-subject-row {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  background: #f8fafc; border-radius: 8px; border: 1.5px solid var(--border);
}
.nt-subject-label { font-size: 12px; font-weight: 700; color: #6b7280; white-space: nowrap; }
.nt-subject-val   { font-size: 13.5px; color: #1e293b; font-weight: 600; }
.nt-preview-body-label {
  font-size: 12px; font-weight: 700; color: #6b7280; text-transform: uppercase;
  letter-spacing: .5px; padding-bottom: 4px; border-bottom: 1.5px solid var(--border);
}
.nt-preview-body {
  font-size: 13.5px; color: #374151; line-height: 1.8; padding: 14px 16px;
  background: #f8fafc; border-radius: 10px; border: 1.5px solid var(--border);
  white-space: pre-wrap; font-family: inherit;
}
.nt-placeholder { background: #e0e7ff; color: #3730a3; border-radius: 5px; padding: 1px 6px; font-size: 12.5px; font-weight: 700; font-family: monospace; }
.nt-placeholder-legend {
  background: #f8fafc; border: 1.5px solid var(--border); border-radius: 10px;
  padding: 12px 14px; display: flex; flex-direction: column; gap: 8px;
}
.nt-legend-title { font-size: 12.5px; font-weight: 700; color: #4f46e5; display: flex; align-items: center; gap: 6px; }
.nt-legend-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.nt-legend-chip {
  background: #e0e7ff; color: #3730a3; border-radius: 5px; padding: 3px 9px;
  font-size: 11.5px; font-weight: 700; font-family: monospace; cursor: pointer;
  transition: background .14s; user-select: none;
}
.nt-legend-chip:hover { background: #c7d2fe; }

/* Placeholder chips in add/edit modal */
.nt-chips-wrap {
  display: flex; flex-wrap: wrap; gap: 5px; padding: 8px 10px;
  background: #f0f9ff; border: 1.5px solid #bae6fd; border-radius: 8px; margin-bottom: 6px;
}
.nt-chip {
  background: #e0e7ff; color: #3730a3; border-radius: 5px; padding: 2px 8px;
  font-size: 11px; font-weight: 700; font-family: monospace; cursor: pointer;
  transition: background .12s;
}
.nt-chip:hover { background: #c7d2fe; }

/* ════════════════════════════════════════════════════
   BUSINESS SETTINGS
   ════════════════════════════════════════════════════ */
.bset-layout { display: grid; grid-template-columns: 220px 1fr; gap: 20px; align-items: start; }
.bset-tabs { background:#fff; border-radius:12px; border:1.5px solid var(--border); box-shadow:0 2px 10px rgba(0,0,0,.06); overflow:hidden; position:sticky; top:20px; }
.bset-tabs-title { padding:14px 16px; font-size:13px; font-weight:700; color:#6b7280; text-transform:uppercase; letter-spacing:.5px; background:#f8fafc; border-bottom:1.5px solid var(--border); }
.bset-tab { display:flex; align-items:center; gap:9px; width:100%; padding:11px 16px; background:none; border:none; text-align:left; font-size:13px; color:#374151; cursor:pointer; border-left:3px solid transparent; transition:all .14s; }
.bset-tab:hover { background:#f0f9ff; color:#4f46e5; }
.bset-tab.bset-tab-active { background:#eef2ff; color:#4f46e5; font-weight:700; border-left-color:#4f46e5; }
.bset-tab i { width:16px; text-align:center; font-size:13px; }
.bset-panel { display:flex; flex-direction:column; gap:18px; }
.bset-section-card { background:#fff; border-radius:12px; border:1.5px solid var(--border); box-shadow:0 2px 10px rgba(0,0,0,.06); overflow:hidden; }
.bset-section-head { padding:14px 20px; border-bottom:1.5px solid var(--border); background:#f8fafc; }
.bset-section-title { font-size:14px; font-weight:700; color:#1e293b; }
.bset-section-desc { font-size:12px; color:#6b7280; margin-top:2px; }
.bset-section-body { padding:20px; display:grid; grid-template-columns:1fr 1fr; gap:14px 20px; }
.bset-section-body.bset-cols-1 { grid-template-columns:1fr; }
.bset-section-body.bset-cols-3 { grid-template-columns:repeat(3,1fr); }
.bset-field { display:flex; flex-direction:column; gap:5px; }
.bset-field-full { grid-column:span 2; }
.bset-label { font-size:12.5px; font-weight:600; color:#374151; }
.bset-input { padding:8px 11px; border:1.5px solid var(--border); border-radius:8px; font-size:13.5px; color:#1e293b; width:100%; transition:border-color .15s; }
.bset-input:focus { outline:none; border-color:#4f46e5; }
.bset-input[readonly] { background:#f8fafc; cursor:not-allowed; }
.bset-select { padding:8px 11px; border:1.5px solid var(--border); border-radius:8px; font-size:13.5px; color:#1e293b; background:#fff; width:100%; cursor:pointer; transition:border-color .15s; }
.bset-select:focus { outline:none; border-color:#4f46e5; }
.bset-textarea { width:100%; padding:8px 11px; border:1.5px solid var(--border); border-radius:8px; font-size:13.5px; color:#1e293b; resize:vertical; font-family:inherit; transition:border-color .15s; }
.bset-textarea:focus { outline:none; border-color:#4f46e5; }
.bset-toggle-row { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; background:#f8fafc; border-radius:8px; border:1.5px solid var(--border); }
.bset-toggle-label { font-size:13px; font-weight:600; color:#374151; }
.bset-toggle-sub { font-size:11.5px; color:#6b7280; margin-top:1px; }
.bset-save-wrap { display:flex; justify-content:flex-end; padding:4px 0; }
.bset-save-btn { padding:10px 28px; font-size:14px; }
/* Modules grid */
.bset-modules-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; padding:20px; }
.bset-module-card { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border:1.5px solid var(--border); border-radius:10px; background:#fafafa; gap:10px; }
.bset-module-card.bset-mod-active { background:#f0fdf4; border-color:#86efac; }
.bset-module-info { display:flex; align-items:center; gap:9px; }
.bset-module-icon { width:32px; height:32px; border-radius:8px; background:#e0e7ff; color:#4f46e5; display:flex; align-items:center; justify-content:center; font-size:14px; }
.bset-module-name { font-size:13px; font-weight:600; color:#1e293b; }
/* Test section */
.bset-test-section { padding:14px 20px; border-top:1.5px solid var(--border); display:flex; align-items:flex-end; gap:10px; background:#f8fafc; flex-wrap:wrap; }
.bset-test-label { font-size:12.5px; font-weight:600; color:#374151; display:block; margin-bottom:5px; }

/* Barcode preview */
.bc-preview-wrap { border:2px dashed #cbd5e1; border-radius:10px; padding:20px; background:#fafafa; display:flex; flex-direction:column; align-items:center; gap:6px; }
.bc-preview-label { background:#fff; border:1.5px solid #e2e8f0; border-radius:8px; padding:10px 18px; display:flex; flex-direction:column; align-items:center; gap:4px; min-width:180px; box-shadow:0 2px 6px rgba(0,0,0,.08); }
.bc-preview-biz  { font-size:9px; font-weight:700; color:#374151; letter-spacing:1px; text-transform:uppercase; }
.bc-preview-name { font-size:11px; font-weight:600; color:#1e293b; }
.bc-preview-bars { display:flex; gap:1.5px; height:32px; align-items:flex-end; margin:4px 0; }
.bc-preview-bar  { background:#1e293b; border-radius:1px; }
.bc-preview-code { font-size:8px; color:#374151; letter-spacing:2px; font-family:monospace; }
.bc-preview-price{ font-size:12px; font-weight:700; color:#059669; }
.bc-preview-sku  { font-size:9px; color:#6b7280; }
.bc-preview-hint { font-size:12px; color:#9ca3af; }

/* ── Calculator Popup ── */
.calc-popup {
  position: fixed;
  bottom: 80px;
  right: 24px;
  width: 268px;
  background: #1e293b;
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,.55);
  z-index: 99999;
  display: none;
  flex-direction: column;
  overflow: hidden;
  user-select: none;
}
.calc-popup.calc-open { display: flex; }
.calc-header {
  background: #0f172a;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: move;
  color: #94a3b8;
  font-size: 13px;
  font-weight: 600;
  gap: 8px;
}
.calc-header i { color: var(--accent); }
.calc-close {
  background: none;
  border: none;
  color: #64748b;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.calc-close:hover { color: #f1f5f9; background: rgba(255,255,255,.12); }
.calc-display {
  background: #0f172a;
  padding: 10px 16px 14px;
  text-align: right;
  border-bottom: 1px solid #1e293b;
  min-height: 72px;
}
.calc-expr {
  color: #475569;
  font-size: 12px;
  min-height: 16px;
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.calc-val {
  color: #f1f5f9;
  font-size: 32px;
  font-weight: 300;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: font-size .1s;
}
.calc-btns {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: #0f172a;
}
.calc-btn {
  background: #1e293b;
  color: #e2e8f0;
  font-size: 17px;
  font-weight: 400;
  padding: 17px 0;
  cursor: pointer;
  border: none;
  transition: background .1s;
  text-align: center;
}
.calc-btn:hover  { background: #263347; }
.calc-btn:active { background: #2f3f58; }
.calc-btn.calc-fn { background: #253040; color: #94a3b8; font-size: 14px; font-weight: 600; }
.calc-btn.calc-fn:hover { background: #2e3c50; }
.calc-btn.calc-op { background: #172554; color: #93c5fd; font-size: 19px; font-weight: 500; }
.calc-btn.calc-op:hover { background: #1e3a6e; }
.calc-btn.calc-op.calc-op-active { background: #f1f5f9; color: #172554; }
.calc-btn.calc-eq { background: var(--accent); color: #fff; font-size: 22px; font-weight: 600; }
.calc-btn.calc-eq:hover { background: var(--accent-dark); }
.calc-btn.calc-zero { grid-column: span 2; text-align: left; padding-left: 26px; }

/* ── Notification Panel ── */
.notif-panel {
  position: fixed;
  top: 62px;
  right: 14px;
  width: 360px;
  max-height: 500px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
  z-index: 99998;
  display: none;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid #e5e7eb;
}
.notif-panel.notif-open { display: flex; }
.notif-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  border-bottom: 1px solid #f3f4f6;
  flex-shrink: 0;
}
.notif-panel-title {
  font-weight: 700;
  font-size: 14px;
  color: #1e293b;
  display: flex;
  align-items: center;
  gap: 8px;
}
.notif-panel-title i { color: var(--primary); }
.notif-count-chip {
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 1px 7px;
  border-radius: 20px;
}
.notif-mark-all {
  background: none;
  border: none;
  color: #6b7280;
  font-size: 12px;
  cursor: pointer;
  padding: 4px 10px;
  border-radius: 6px;
  font-weight: 500;
  transition: background .15s, color .15s;
}
.notif-mark-all:hover { background: #f3f4f6; color: #374151; }
.notif-list { overflow-y: auto; flex: 1; }
.notif-item {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  padding: 11px 14px;
  cursor: pointer;
  border-bottom: 1px solid #f9fafb;
  transition: background .12s;
  position: relative;
}
.notif-item:hover { background: #f8fafc; }
.notif-item.notif-read { opacity: .5; }
.notif-dot {
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.notif-read .notif-dot { display: none; }
.notif-icon-wrap {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 14px;
  margin-left: 6px;
}
.notif-text { flex: 1; min-width: 0; }
.notif-title { font-size: 12px; font-weight: 700; color: #1e293b; margin-bottom: 2px; }
.notif-body  { font-size: 11.5px; color: #64748b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.notif-dismiss {
  background: none; border: none;
  color: #d1d5db; font-size: 13px; cursor: pointer;
  padding: 3px 5px; border-radius: 4px; flex-shrink: 0; line-height: 1;
  transition: color .12s, background .12s;
}
.notif-dismiss:hover { color: #6b7280; background: #f3f4f6; }
.notif-empty {
  text-align: center;
  padding: 44px 20px;
  color: #9ca3af;
}
.notif-empty i { font-size: 36px; color: #bbf7d0; margin-bottom: 10px; display: block; }
.notif-empty p { font-size: 13px; margin-top: 6px; font-weight: 500; }

/* ════════════════════════════════════════════════════════
   STOCK TAKING / INVENTORY COUNT
   ════════════════════════════════════════════════════════ */
.ic-items-section { margin-top:20px; display:flex; flex-direction:column; gap:14px; }
.ic-items-toolbar {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
  padding:12px 16px; background:#f8fafc; border-radius:10px; border:1.5px solid var(--border);
}
.ic-items-left  { display:flex; align-items:center; gap:12px; }
.ic-items-right { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ic-items-title { font-size:14px; font-weight:700; color:#1e293b; display:flex; align-items:center; gap:8px; }
.ic-period-note { font-size:11.5px; color:#4f46e5; background:#eef2ff; border-radius:20px; padding:3px 10px; font-style:italic; }
.ic-load-cat-wrap { display:flex; align-items:center; gap:0; border:1.5px solid var(--border); border-radius:8px; overflow:hidden; }
.ic-cat-select {
  padding:7px 10px; border:none; border-right:1.5px solid var(--border);
  font-size:12.5px; color:#374151; background:#f8fafc; cursor:pointer; outline:none;
  min-width:130px;
}
.ic-load-all-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; background:#4f46e5; color:#fff; border:none;
  font-size:12.5px; font-weight:700; cursor:pointer; transition:background .15s;
}
.ic-load-all-btn:hover { background:#4338ca; }
.ic-count-table th { font-size:11px; white-space:nowrap; }
.ic-phys-input {
  padding:5px 8px; border:1.5px solid var(--border); border-radius:7px;
  font-size:13px; text-align:center; color:#1e293b; width:90px;
}
.ic-phys-input:focus { outline:none; border-color:#4f46e5; }
.ic-var-badge { display:inline-block; padding:3px 9px; border-radius:20px; font-size:12px; font-weight:700; }
.ic-var-neg  { background:#fee2e2; color:#dc2626; }
.ic-var-pos  { background:#dcfce7; color:#16a34a; }
.ic-var-zero { background:#f1f5f9; color:#64748b; }
.ic-summary-bar {
  display:flex; align-items:center; border:1.5px solid var(--border);
  border-radius:10px; overflow:hidden;
}
.ic-sum-item {
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:10px 12px; border-right:1.5px solid var(--border); gap:3px;
}
.ic-sum-item:last-child { border-right:none; }
.ic-sum-item span { font-size:11px; color:#6b7280; text-transform:uppercase; letter-spacing:.4px; font-weight:600; }
.ic-sum-item strong { font-size:18px; font-weight:700; color:#1e293b; }
.ic-sum-total { flex:1.5; background:#f0fdf4; }

/* Inventory list — status badges */
.ic-status-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 12px; border-radius:20px; font-size:12px; font-weight:700;
}
.ic-status-open   { background:#dcfce7; color:#166534; border:1.5px solid #86efac; }
.ic-status-closed { background:#fee2e2; color:#991b1b; border:1.5px solid #fca5a5; }

/* Inventory list — inline action buttons */
.ic-inline-actions { display:flex; flex-wrap:wrap; gap:5px; }
.ic-act-btn {
  display:inline-flex; align-items:center; gap:4px;
  padding:5px 10px; border:none; border-radius:6px;
  font-size:11.5px; font-weight:700; cursor:pointer; transition:opacity .15s; white-space:nowrap;
}
.ic-act-btn:hover { opacity:.85; }
.ic-act-inventory  { background:#2563eb; color:#fff; }
.ic-act-report     { background:#0891b2; color:#fff; }
.ic-act-increased  { background:#059669; color:#fff; }
.ic-act-decreased  { background:#dc2626; color:#fff; }
.ic-act-close      { background:#7c3aed; color:#fff; }
.ic-act-reopen     { background:#16a34a; color:#fff; }
.ic-act-stock      { background:#d97706; color:#fff; }
.ic-act-delete     { background:#f1f5f9; color:#dc2626; border:1.5px solid #fecaca; }
.ic-list-table td  { vertical-align:middle; }

/* Already-added row highlight */
@keyframes ic-highlight-pulse {
  0%   { background:#fef9c3; }
  40%  { background:#fde047; }
  100% { background:transparent; }
}
.ic-row-highlight td { animation: ic-highlight-pulse 2s ease forwards; }

/* Autocomplete — already-added item */
.ic-suggest-added { background:#fffbeb !important; }
.ic-suggest-added:hover { background:#fef3c7 !important; }
.ic-already-tag {
  font-size:11px; font-weight:700; color:#d97706;
  background:#fef3c7; border-radius:12px; padding:2px 8px;
  white-space:nowrap; display:inline-flex; align-items:center; gap:4px;
}
.ic-oos-tag {
  font-size:11px; font-weight:700; color:#dc2626;
  background:#fee2e2; border-radius:12px; padding:2px 8px;
  white-space:nowrap; display:inline-flex; align-items:center; gap:4px;
}
.ic-oos-cell { display:inline-flex; align-items:center; gap:5px; }
.ic-oos-badge {
  font-size:10px; font-weight:700; color:#dc2626;
  background:#fee2e2; border-radius:10px; padding:1px 6px; white-space:nowrap;
}

/* ══════════════════════════════════════════════
   INVENTORY COUNT FORM (icf-)
   ══════════════════════════════════════════════ */
.icf-page { display:flex; flex-direction:column; gap:20px; }

/* Top bar */
.icf-top-bar {
  display:flex; align-items:flex-start; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
}
.icf-page-title {
  font-size:20px; font-weight:800; color:#0f172a; display:flex; align-items:center; gap:9px;
}
.icf-page-title i { color:#0d9488; }
.icf-page-sub { font-size:12.5px; color:#64748b; margin-top:3px; }
.icf-back-btn {
  display:inline-flex; align-items:center; gap:7px; padding:8px 16px;
  background:#f1f5f9; border:1.5px solid #cbd5e1; border-radius:8px;
  font-size:13px; font-weight:600; color:#475569; cursor:pointer; transition:background .12s;
}
.icf-back-btn:hover { background:#e2e8f0; }

/* Fields card */
.icf-fields-card {
  background:#fff; border-radius:14px; border:1.5px solid #e2e8f0;
  padding:20px 22px; box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.icf-fields-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.icf-field { display:flex; flex-direction:column; gap:5px; }
.icf-field-full { grid-column:1/-1; }
.icf-label {
  font-size:12px; font-weight:700; color:#475569;
  text-transform:uppercase; letter-spacing:.4px;
  display:flex; align-items:center; gap:5px;
}
.icf-label i { color:#0d9488; font-size:11px; }
.icf-input {
  padding:9px 12px; border:1.5px solid #cbd5e1; border-radius:9px;
  font-size:13.5px; color:#1e293b; outline:none; background:#f8fafc;
  transition:border-color .15s, box-shadow .15s;
}
.icf-input:focus { border-color:#0d9488; box-shadow:0 0 0 3px rgba(13,148,136,.12); background:#fff; }

/* Items card */
.icf-items-card {
  background:#fff; border-radius:14px; border:1.5px solid #e2e8f0;
  box-shadow:0 1px 4px rgba(0,0,0,.06); overflow:hidden;
}
.icf-items-topbar {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
  padding:14px 18px; background:#f8fafc; border-bottom:1.5px solid #f1f5f9;
}
.icf-items-title { font-size:14px; font-weight:700; color:#0f172a; display:flex; align-items:center; gap:7px; }
.icf-items-title i { color:#0d9488; }
.icf-period-badge {
  background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe;
  border-radius:8px; padding:5px 13px; font-size:12px; font-weight:600;
  display:inline-flex; align-items:center; gap:6px;
}
.icf-search-wrap { position:relative; }
.icf-search-ico { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:#94a3b8; pointer-events:none; font-size:13px; }
.icf-search-input {
  padding:8px 14px 8px 32px; border:1.5px solid #cbd5e1; border-radius:9px;
  font-size:13px; width:240px; outline:none; color:#1e293b;
}
.icf-search-input:focus { border-color:#0d9488; box-shadow:0 0 0 3px rgba(13,148,136,.1); }

/* Table */
.icf-table { width:100%; border-collapse:collapse; font-size:13px; }
.icf-thead-row { background:#f1f5f9; }
.icf-th {
  padding:10px 12px; text-align:left; font-size:11px; font-weight:700;
  color:#475569; text-transform:uppercase; letter-spacing:.5px;
  border-bottom:1.5px solid #e2e8f0; white-space:nowrap;
}
.icf-th-num { text-align:center; }
.icf-item-row { border-bottom:1px solid #f1f5f9; transition:background .1s; }
.icf-item-row:hover { background:#f8fafc; }
.icf-td { padding:10px 12px; vertical-align:middle; color:#334155; }
.icf-td-idx { font-weight:700; color:#94a3b8; width:36px; text-align:center; }
.icf-td-name { font-weight:600; color:#0f172a; max-width:180px; }
.icf-td-sku { }
.icf-td-num { text-align:center; }
.icf-td-note { min-width:130px; }
.icf-sku-tag {
  background:#eff6ff; color:#1d4ed8; border:1px solid #bfdbfe;
  border-radius:5px; padding:2px 8px; font-size:11.5px; font-weight:600;
  font-family:'Courier New',monospace;
}
.icf-stock-num { font-weight:700; color:#0f172a; }
.icf-sales-num { font-weight:700; color:#0369a1; }
.icf-zero { color:#9ca3af; }
.icf-exp-num { font-weight:600; color:#374151; }
.icf-oos { color:#dc2626; font-weight:700; display:inline-flex; align-items:center; gap:4px; }
.icf-oos-tag {
  font-size:10px; background:#fee2e2; color:#dc2626; border-radius:4px;
  padding:1px 5px; font-weight:700;
}
/* Variance cells */
.icf-var-pos { color:#16a34a; font-weight:800; font-size:13px; }
.icf-var-neg { color:#dc2626; font-weight:800; font-size:13px; }
.icf-var-zero { color:#94a3b8; font-weight:600; }
/* Inputs */
.icf-qty-input {
  width:80px; padding:6px 8px; border:1.5px solid #cbd5e1; border-radius:7px;
  font-size:13px; text-align:center; outline:none; color:#0f172a; font-weight:700;
}
.icf-qty-input:focus { border-color:#0d9488; box-shadow:0 0 0 2px rgba(13,148,136,.15); }
.icf-note-input {
  width:100%; padding:6px 8px; border:1.5px solid #e2e8f0; border-radius:7px;
  font-size:12px; outline:none; color:#374151; background:#f8fafc;
}
.icf-note-input:focus { border-color:#0d9488; background:#fff; }
.icf-del-btn {
  background:none; border:none; color:#cbd5e1; font-size:14px; cursor:pointer;
  padding:4px 7px; border-radius:6px; transition:color .12s, background .12s;
}
.icf-del-btn:hover { color:#dc2626; background:#fee2e2; }

/* Empty state */
.icf-empty {
  text-align:center; padding:40px 20px; color:#94a3b8;
  font-size:14px; font-weight:500; line-height:1.7;
}
.icf-empty i { font-size:2rem; display:block; margin-bottom:6px; }

/* Totals bar */
.icf-totals-bar {
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  padding:12px 18px; background:#f0fdf4; border-top:1.5px solid #bbf7d0;
  font-size:13px; color:#166534;
}
.icf-tot-label { font-weight:700; }
.icf-tot-item { font-size:12.5px; }

/* Action buttons row */
.icf-btn-row {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px; padding-bottom:8px;
}
.icf-btn-group-right { display:flex; gap:10px; flex-wrap:wrap; }
.icf-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border:none; border-radius:10px;
  font-size:13.5px; font-weight:700; cursor:pointer; letter-spacing:.1px;
  transition:opacity .15s, transform .1s;
}
.icf-btn:hover { opacity:.88; transform:translateY(-1px); }
.icf-btn-cancel {
  background:#f1f5f9; color:#475569; border:1.5px solid #cbd5e1;
}
.icf-btn-draft {
  background:linear-gradient(135deg,#7c3aed 0%,#6d28d9 100%);
  color:#fff; box-shadow:0 2px 8px rgba(124,58,237,.3);
}
.icf-btn-save {
  background:linear-gradient(135deg,#0d9488 0%,#0891b2 100%);
  color:#fff; box-shadow:0 2px 8px rgba(13,148,136,.3);
}
.icf-btn-update {
  background:linear-gradient(135deg,#1e3a5f 0%,#2a5298 100%);
  color:#fff; box-shadow:0 2px 8px rgba(30,58,95,.3);
}
.icf-btn-apply {
  background:linear-gradient(135deg,#059669 0%,#065f46 100%);
  color:#fff; box-shadow:0 2px 8px rgba(5,150,105,.3);
}

/* Category elements */
.icf-add-all-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border:1.5px solid #7c3aed; border-radius:8px;
  background:#faf5ff; color:#7c3aed; font-size:12.5px; font-weight:700;
  cursor:pointer; transition:background .12s, color .12s;
  white-space:nowrap;
}
.icf-add-all-btn:hover { background:#7c3aed; color:#fff; }
.icf-cat-badge {
  display:inline-block; background:#fef3c7; color:#92400e;
  border:1px solid #fcd34d; border-radius:5px;
  padding:2px 8px; font-size:11.5px; font-weight:600; white-space:nowrap;
}
.icf-cat-none { color:#cbd5e1; font-size:12px; }
.icf-cat-tag {
  display:inline-block; background:#fef3c7; color:#92400e;
  border:1px solid #fcd34d; border-radius:4px;
  padding:1px 6px; font-size:11px; font-weight:600;
}
.ilv2-cat-pill {
  display:inline-block; background:#fef3c7; color:#92400e;
  border:1px solid #fcd34d; border-radius:5px;
  padding:1px 7px; font-size:11px; font-weight:600;
  margin-left:6px; vertical-align:middle;
}

/* Footer save buttons */
.ic-footer-btns { justify-content:space-between; }
.ic-save-group  { display:flex; gap:10px; flex-wrap:wrap; }
.ic-btn-draft {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 20px; background:#f8fafc; color:#374151;
  border:1.5px solid var(--border); border-radius:9px;
  font-size:13.5px; font-weight:700; cursor:pointer; transition:all .15s;
}
.ic-btn-draft:hover { background:#e2e8f0; border-color:#94a3b8; }
.ic-btn-update {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 22px; background:#059669; color:#fff;
  border:none; border-radius:9px;
  font-size:13.5px; font-weight:700; cursor:pointer; transition:background .15s;
}
.ic-btn-update:hover { background:#047857; }
.ic-btn-save-exit {
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 22px; background:#2563eb; color:#fff;
  border:none; border-radius:9px;
  font-size:13.5px; font-weight:700; cursor:pointer; transition:background .15s;
}
.ic-btn-save-exit:hover { background:#1d4ed8; }

/* ══════════════════════════════════════════════
   INVENTORY LIST v2
   ══════════════════════════════════════════════ */

/* Header */
.ilv2-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
}
.ilv2-title {
  font-size: 22px; font-weight: 800; color: #0f172a; letter-spacing: -.3px;
  display: flex; align-items: center; gap: 10px;
}
.ilv2-title i { color: #0d9488; font-size: 20px; }
.ilv2-subtitle { font-size: 13px; color: #64748b; margin-top: 3px; }
.ilv2-add-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, #0d9488 0%, #0891b2 100%);
  color: #fff; border: none; border-radius: 10px;
  padding: 10px 20px; font-size: 13.5px; font-weight: 700;
  cursor: pointer; letter-spacing: .2px; box-shadow: 0 2px 8px rgba(13,148,136,.35);
  transition: opacity .15s, transform .1s;
}
.ilv2-add-btn:hover { opacity: .92; transform: translateY(-1px); }

/* Stat cards */
.ilv2-stats-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 20px;
}
.ilv2-stat-card {
  border-radius: 14px; padding: 16px 20px;
  display: flex; align-items: center; gap: 14px;
  box-shadow: 0 1px 4px rgba(0,0,0,.07);
}
.ilv2-stat-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.ilv2-stat-num { font-size: 26px; font-weight: 800; line-height: 1; }
.ilv2-stat-lbl { font-size: 12px; font-weight: 600; opacity: .7; margin-top: 3px; text-transform: uppercase; letter-spacing: .4px; }
.ilv2-stat-total  { background: #f0f9ff; color: #0369a1; }
.ilv2-stat-total  .ilv2-stat-icon { background: #bae6fd; color: #0369a1; }
.ilv2-stat-open   { background: #f0fdf4; color: #15803d; }
.ilv2-stat-open   .ilv2-stat-icon { background: #bbf7d0; color: #15803d; }
.ilv2-stat-closed { background: #fff7ed; color: #c2410c; }
.ilv2-stat-closed .ilv2-stat-icon { background: #fed7aa; color: #c2410c; }

/* Table card */
.ilv2-table-card {
  background: #fff; border-radius: 16px; border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 10px rgba(0,0,0,.06); overflow: hidden;
}

/* Toolbar */
.ilv2-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1.5px solid #f1f5f9; flex-wrap: wrap; gap: 10px;
  background: #f8fafc;
}
.ilv2-show-wrap { display: flex; align-items: center; gap: 8px; }
.ilv2-show-label { font-size: 13px; color: #475569; font-weight: 500; }
.ilv2-sel {
  padding: 6px 10px; border: 1.5px solid #cbd5e1; border-radius: 8px;
  font-size: 13px; color: #1e293b; outline: none; background: #fff; cursor: pointer;
}
.ilv2-sel:focus { border-color: #0d9488; }
.ilv2-search-wrap { position: relative; }
.ilv2-search-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: #94a3b8; font-size: 13px; pointer-events: none; }
.ilv2-search {
  padding: 8px 14px 8px 32px; border: 1.5px solid #cbd5e1; border-radius: 8px;
  font-size: 13px; width: 230px; outline: none; color: #1e293b; background: #fff;
}
.ilv2-search:focus { border-color: #0d9488; box-shadow: 0 0 0 3px rgba(13,148,136,.12); }

/* Table */
.ilv2-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ilv2-thead-row { background: #f1f5f9; }
.ilv2-th {
  padding: 11px 14px; text-align: left; font-size: 11.5px; font-weight: 700;
  color: #475569; text-transform: uppercase; letter-spacing: .5px;
  cursor: pointer; user-select: none; white-space: nowrap; border-bottom: 1.5px solid #e2e8f0;
}
.ilv2-th:hover { color: #0d9488; background: #e9f9f7; }
.ilv2-th-actions { cursor: default; }
.ilv2-th-actions:hover { color: #475569; background: #f1f5f9; }
.ilv2-sort-ico { font-size: 10px; color: #94a3b8; margin-left: 4px; }
.ilv2-row { border-bottom: 1px solid #f1f5f9; transition: background .1s; }
.ilv2-row:last-child { border-bottom: none; }
.ilv2-row:hover { background: #f8fafc; }
.ilv2-td { padding: 12px 14px; color: #334155; vertical-align: middle; }
.ilv2-td-id { font-weight: 700; color: #0f172a; font-size: 13.5px; }
.ilv2-td-ref { font-family: 'Courier New', monospace; font-size: 12.5px; color: #0369a1; font-weight: 600; }
.ilv2-td-actions { min-width: 320px; }

/* Branch tag */
.ilv2-branch-tag {
  display: inline-block; background: #eff6ff; color: #1d4ed8;
  border: 1px solid #bfdbfe; border-radius: 6px; padding: 3px 10px;
  font-size: 12px; font-weight: 600; white-space: nowrap;
}

/* Status badges */
.ilv2-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 700;
  white-space: nowrap;
}
.ilv2-badge-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.ilv2-badge-open   { background: #dcfce7; color: #15803d; }
.ilv2-badge-open   .ilv2-badge-dot { background: #16a34a; box-shadow: 0 0 0 2px #bbf7d0; }
.ilv2-badge-closed   { background: #f1f5f9; color: #475569; }
.ilv2-badge-closed   .ilv2-badge-dot { background: #94a3b8; }
.ilv2-badge-complete { background: #eff6ff; color: #1d4ed8; }
.ilv2-badge-complete .ilv2-badge-dot { background: #2563eb; box-shadow: 0 0 0 2px #bfdbfe; }

/* Action buttons */
.ilv2-actions-wrap { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }
.ilv2-action-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border: none; border-radius: 7px;
  font-size: 11.5px; font-weight: 700; cursor: pointer; white-space: nowrap;
  letter-spacing: .1px; transition: opacity .12s, transform .1s;
}
.ilv2-action-btn:hover { opacity: .85; transform: translateY(-1px); }
.ilv2-btn-indigo  { background: #4f46e5; color: #fff; }
.ilv2-btn-teal    { background: #0d9488; color: #fff; }
.ilv2-btn-emerald { background: #059669; color: #fff; }
.ilv2-btn-rose    { background: #e11d48; color: #fff; }
.ilv2-btn-close   { background: #dc2626; color: #fff; }
.ilv2-btn-slate   { background: #475569; color: #fff; }
.ilv2-btn-amber   { background: linear-gradient(135deg,#f59e0b 0%,#b45309 100%); color: #fff; }

/* Empty state */
.ilv2-empty { text-align: center; padding: 48px 20px; color: #94a3b8; font-size: 14px; font-weight: 500; }

/* Footer */
.ilv2-footer { padding: 11px 18px; font-size: 12.5px; color: #94a3b8; border-top: 1.5px solid #f1f5f9; background: #f8fafc; }

/* ── BUSINESS SETTINGS SIDEBAR LAYOUT ── */
.bs-layout { display: grid; grid-template-columns: 230px 1fr; background: #fff; border-radius: 12px; border: 1px solid var(--border); overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.bs-sidebar { border-right: 1.5px solid var(--border); display: flex; flex-direction: column; min-height: 600px; }
.bs-sidebar-head { padding: 14px 18px; background: #3b5bdb; color: #fff; font-size: 14.5px; font-weight: 700; text-align: center; letter-spacing: .3px; }
.bs-nav-item { padding: 12px 18px; font-size: 13px; font-weight: 700; color: #374151; cursor: pointer; border-bottom: 1px solid #f1f5f9; display: flex; align-items: center; justify-content: space-between; transition: background .1s, color .1s; }
.bs-nav-item:hover { background: #f0f9ff; color: #2563eb; }
.bs-nav-active { background: #eff6ff !important; color: #2563eb !important; border-left: 3px solid #2563eb; padding-left: 15px; }
.bs-nav-info { color: #06b6d4; font-size: 11px; flex-shrink: 0; }
.bs-content { padding: 26px 30px; overflow-y: auto; }
.bs-section-title { font-size: 15px; font-weight: 800; color: #1e293b; margin: 0 0 16px; padding-bottom: 11px; border-bottom: 2px solid #f1f5f9; }
.bs-save-bar { margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 10px; }

/* ── SETTINGS PAGES ── */
.sett-page { max-width: 920px; }
.sett-card { background: #fff; border-radius: 12px; border: 1px solid var(--border); box-shadow: 0 1px 4px rgba(0,0,0,.05); margin-bottom: 22px; overflow: hidden; }
.sett-card-head { padding: 15px 22px; border-bottom: 1px solid var(--border); background: #fafafa; display:flex;align-items:center; }
.sett-card-title { font-size: 14.5px; font-weight: 700; color: #1e293b; margin: 0; }
.sett-card-body { padding: 20px 22px; }
.sett-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sett-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.sett-full { grid-column: 1 / -1; }
.sett-footer { padding: 14px 22px; border-top: 1px solid var(--border); background: #fafafa; display: flex; justify-content: flex-end; gap: 10px; }
.sett-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 13px 0; border-bottom: 1px solid #f1f5f9; }
.sett-toggle-row:last-child { border-bottom: none; padding-bottom: 0; }
.sett-toggle-label { font-size: 13.5px; font-weight: 600; color: #374151; }
.sett-toggle-desc { font-size: 12px; color: #9ca3af; margin-top: 2px; }

/* ── ADD / EDIT ROLE PAGE ── */
.ar-page { max-width: 1100px; }
.ar-back-btn {
  background: #f1f5f9; color: #374151; border: 1px solid #e2e8f0;
  padding: 8px 16px; border-radius: 6px; font-size: 13px; font-weight: 600; cursor: pointer;
}
.ar-back-btn:hover { background: #e2e8f0; }
.ar-form-card {
  background: #fff; border-radius: 12px; border: 1px solid var(--border);
  padding: 28px 32px; margin-bottom: 22px;
}
.ar-field-row { margin-bottom: 22px; }
.ar-label { font-size: 14px; font-weight: 700; color: #1e293b; margin-bottom: 8px; display: block; }
.ar-name-inp {
  border: 1px solid #d1d5db; border-radius: 6px; padding: 9px 13px;
  font-size: 14px; width: 300px; display: block; outline: none; color: #374151;
}
.ar-name-inp:focus { border-color: #3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,.12); }
.ar-group {
  display: grid; grid-template-columns: 220px 1fr;
  padding: 20px 0; border-bottom: 1px solid #e9ecef; align-items: start; gap: 12px;
}
.ar-group:last-child { border-bottom: none; }
.ar-group-left { display: flex; flex-direction: column; gap: 10px; }
.ar-group-name { font-size: 15px; font-weight: 700; color: #2c3e6b; line-height: 1.4; }
.ar-group-info { color: #3b82f6; font-size: 12px; margin-left: 3px; }
.ar-select-all-wrap { display: flex; align-items: center; gap: 7px; }
.ar-sa-cb { width: 16px; height: 16px; cursor: pointer; accent-color: #3b82f6; flex-shrink: 0; }
.ar-sa-lbl { font-size: 13px; color: #374151; cursor: pointer; font-weight: 500; }
.ar-group-right { display: flex; flex-direction: column; gap: 10px; }
.ar-perm-item { display: flex; align-items: center; gap: 9px; }
.ar-cb {
  width: 16px; height: 16px; cursor: pointer; accent-color: #3b82f6;
  border-radius: 3px; flex-shrink: 0;
}
.ar-rb { width: 16px; height: 16px; cursor: pointer; accent-color: #3b82f6; flex-shrink: 0; }
.ar-perm-lbl { font-size: 13.5px; cursor: pointer; line-height: 1.4; }
.ar-perm-sep { border: none; border-top: 1px solid #e5e7eb; margin: 4px 0; }
.ar-save-btn {
  background: #4f46e5; color: #fff; border: none; padding: 13px 40px;
  border-radius: 8px; font-size: 15px; font-weight: 700; cursor: pointer;
}
.ar-save-btn:hover { background: #3730a3; }

/* POS mobile tab bar — hidden on desktop */
.pos-mob-tabs { display: none; }
.pos-mob-cart-badge { background: #2563eb; color: #fff; border-radius: 10px; font-size: 10px; font-weight: 700; padding: 1px 6px; min-width: 18px; text-align: center; display: none; }
.pos-mob-cart-badge:not(:empty) { display: inline-block; }

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media (max-width: 1100px) { .cards-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 900px)  { .pf-grid { grid-template-columns: repeat(2,1fr); } .ap-header-grid { grid-template-columns: repeat(2,1fr); } .ap-disc-tax-grid { grid-template-columns: 1fr 1fr; } }

/* ── Sidebar overlay backdrop ── */
#sidebar-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.45); z-index: 999;
}
#sidebar-overlay.active { display: block; }

/* ── MOBILE (≤ 768px) ── */
@media (max-width: 768px) {

  /* Sidebar: slide-in overlay */
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    z-index: 1000; width: var(--sidebar-w) !important;
    transform: translateX(-100%);
    transition: transform .25s ease;
  }
  .sidebar.mobile-open {
    transform: translateX(0);
    box-shadow: 4px 0 24px rgba(0,0,0,.3);
  }
  /* Undo desktop collapse on mobile */
  .sidebar.collapsed { transform: translateX(-100%); }
  .sidebar.collapsed .sidebar-brand span:last-child,
  .sidebar.collapsed .nav-link > span,
  .sidebar.collapsed .arrow { display: revert; }
  .sidebar.collapsed .sidebar-brand { justify-content: flex-start; }
  .sidebar.collapsed .nav-link { justify-content: flex-start; padding: 10px 16px; }

  /* Main area: full width */
  .layout { overflow: auto; }
  .main-area { width: 100%; min-width: 0; }

  /* Topbar: compact */
  .topbar { padding: 0 10px; }
  .topbar-right { gap: 3px; }
  .topbar-date { display: none; }
  #user-label { display: none; }
  .conn-mode-group { display: none; }
  .pos-pill { padding: 0 10px; font-size: 12px; }

  /* Page content */
  .page-content { overflow-y: auto; -webkit-overflow-scrolling: touch; }
  #view-dynamic { padding: 12px !important; }

  /* Dashboard */
  .welcome-banner { padding: 16px; flex-direction: column; align-items: flex-start; gap: 10px; }
  .welcome-heading { font-size: 18px; }
  .cards-section { padding: 0 12px 16px; }
  .cards-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
  .card { padding: 12px 10px; }
  .card-value { font-size: 14px !important; }
  .chart-section { padding: 12px; }
  .chart-wrap { height: 220px !important; }
  .chart-toggle-group { flex-wrap: wrap; gap: 2px; }
  .dash-trend-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .dash-trend-filters { flex-wrap: wrap; gap: 6px; }
  .dash-sa-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .export-btns { display: none; }
  .show-entries { font-size: 12px; }

  /* Modals: bottom sheet */
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal {
    max-width: 100% !important; width: 100% !important;
    border-radius: 18px 18px 0 0 !important;
    max-height: 92vh; margin: 0;
  }
  .modal-body { padding: 14px 16px; }
  .pam-form-grid { grid-template-columns: 1fr !important; }
  .pf-row { grid-template-columns: 1fr !important; }
  .pf-grid { grid-template-columns: 1fr !important; }
  .ap-header-grid { grid-template-columns: 1fr !important; }
  .ap-disc-tax-grid { grid-template-columns: 1fr !important; }
  .ap-ship-grid { grid-template-columns: 1fr !important; }
  .ap-payment-grid { grid-template-columns: 1fr !important; }

  /* POS Terminal: stacked with tab toggle */
  .pos-wrap { flex-direction: column; height: auto; min-height: calc(100dvh - 56px); overflow: visible; }
  .pos-mob-tabs {
    display: flex; flex-shrink: 0; background: #fff;
    border-bottom: 2px solid #e2e8f0; position: sticky; top: 0; z-index: 10;
  }
  .pos-mob-tab {
    flex: 1; padding: 13px 8px; font-size: 14px; font-weight: 700;
    color: #6b7280; background: none; border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 7px;
    border-bottom: 3px solid transparent; margin-bottom: -2px; transition: color .15s;
  }
  .pos-mob-tab.pos-mob-tab-active { color: #2563eb; border-bottom-color: #2563eb; }
  .pos-left { flex: none; height: auto; overflow: visible; }
  .pos-right { flex: none; height: calc(100dvh - 112px); display: flex; }
  .pos-wrap:not(.pos-mob-show-cart) .pos-right { display: none; }
  .pos-mob-show-cart .pos-left { display: none; }
  .pos-prod-grid { grid-template-columns: repeat(3, 1fr) !important; max-height: none !important; }
  .pos-items-wrap { flex: 1; overflow-y: auto; }
  .pos-topbar { flex-wrap: wrap; }
  .pos-topbar-icons { flex-wrap: wrap; }
  .pos-inputs-row { flex-direction: column; }
  .pos-meta-row { flex-wrap: wrap; }
  .pos-action-bar { flex-wrap: wrap; gap: 6px; }
  .pos-action-center { justify-content: flex-start; }
  .pos-payable-val { font-size: 1.5rem; }

  /* Cashier home: stacked */
  .ch-wrap { flex-direction: column; height: auto; }
  .ch-left { width: 100%; border-right: none; border-bottom: 1px solid #e2e8f0; max-height: none; overflow: visible; }
  .ch-right { width: 100%; padding: 14px; }
  .ch-stat-grid { grid-template-columns: 1fr 1fr; }
  .ch-qa-grid { grid-template-columns: repeat(3, 1fr); }

  /* Login overlays */
  #sb-login-overlay > div { padding: 28px 18px; margin: 16px; border-radius: 14px; }
  #staff-login-overlay > div { padding: 22px 16px; margin: 10px; border-radius: 14px; }
  #staff-user-list { grid-template-columns: repeat(2, 1fr) !important; }

  /* Tables */
  .data-table { font-size: 12px; }
  .data-table th, .data-table td { padding: 8px 6px; }
}

/* ── STAFF PICKER CARDS ── */
.staff-card {
  background: #f8fafc;
  border: 1.5px solid #e2e8f0;
  border-radius: 12px;
  padding: 14px 10px;
  text-align: center;
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .1s;
  user-select: none;
}
.staff-card:hover { background: #eff6ff; border-color: #93c5fd; transform: translateY(-1px); }
.staff-card.selected { background: #eff6ff; border-color: #2563eb; box-shadow: 0 0 0 2px #bfdbfe; }
.staff-avatar-circle {
  width: 48px; height: 48px;
  background: linear-gradient(135deg, #0d9488, #2563eb);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-size: 20px; font-weight: 700;
  margin-bottom: 8px;
}
.staff-card-name { font-size: 13px; font-weight: 700; color: #1e293b; margin-bottom: 2px; line-height: 1.3; }
.staff-card-role { font-size: 11px; color: #64748b; }

/* ── SMALL PHONES (≤ 480px) ── */
@media (max-width: 480px) {
  .cards-grid { grid-template-columns: 1fr !important; }
  .pos-prod-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ch-stat-grid { grid-template-columns: 1fr; }
  .ch-qa-grid { grid-template-columns: repeat(2, 1fr); }
  .welcome-heading { font-size: 16px; }
  .topbar { padding: 0 8px; }
}
