/* =============================================================
   CoreIQ Office — Desktop admin app
   Builds on tokens.css + styles.css.
   1440×900 design; denser, mouse-first.
   ============================================================= */

html, body { height: 100%; margin: 0; }
body {
  background: var(--bg-subtle);
  overflow: hidden;
  font-size: 14px;
}

/* -------------------------------------------------------------
   Sign-in
   ------------------------------------------------------------- */
.signin-stage {
  position: fixed;
  inset: 0;
  background: var(--structure-bg);
  background-image:
    radial-gradient(ellipse at top left, rgba(13,148,136,0.10), transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(124,58,237,0.06), transparent 50%);
  display: grid;
  place-items: center;
  color: var(--structure-fg);
}
.signin-card {
  width: 420px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 20px;
  padding: 36px 40px;
  backdrop-filter: blur(20px);
}
.signin-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 26px;
}
.signin-brand-mark {
  width: 48px; height: 48px;
  background: var(--teal-500);
  color: var(--navy-950);
  border-radius: 12px;
  display: grid; place-items: center;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.04em;
}
.signin-brand-text {
  display: flex; flex-direction: column;
  line-height: 1.2;
}
.signin-brand-name {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.signin-brand-sub {
  font-size: 11px;
  color: var(--structure-fg-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.signin-title {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
  color: #fff;
}
.signin-sub {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  margin: 0 0 24px;
}
.signin-form { display: flex; flex-direction: column; gap: 14px; }
.signin-form .field-label { color: rgba(255,255,255,0.78); font-size: 12px; letter-spacing: 0.02em; }
.signin-form .input {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  color: #fff;
  height: 44px;
}
.signin-form .input::placeholder { color: rgba(255,255,255,0.4); }
.signin-form .input:focus {
  background: rgba(255,255,255,0.10);
  border-color: var(--teal-500);
  box-shadow: 0 0 0 3px rgba(45,193,180,0.18);
}
.signin-cta {
  margin-top: 10px;
  height: 46px;
  font-size: 15px;
}
.signin-foot {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex; justify-content: space-between;
  font-size: 12px; color: rgba(255,255,255,0.5);
}
.signin-foot a { color: var(--teal-300); text-decoration: none; }
.signin-error {
  font-size: 12px;
  padding: 8px 12px;
  background: rgba(239,68,68,0.12);
  border: 1px solid rgba(239,68,68,0.32);
  color: #fca5a5;
  border-radius: 8px;
}

/* -------------------------------------------------------------
   Shell — sidebar + topbar + main
   ------------------------------------------------------------- */
.office-shell {
  position: fixed;
  inset: 0;
  display: grid;
  grid-template-columns: 240px 1fr;
  background: var(--bg);
}

/* Sidebar */
.off-side {
  background: var(--structure-bg);
  color: var(--structure-fg);
  display: flex;
  flex-direction: column;
  padding: 16px 10px;
  gap: 1px;
  overflow-y: auto;
  border-right: 1px solid var(--structure-border);
}
.off-side-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 8px 16px;
  border-bottom: 1px solid var(--structure-border);
  margin-bottom: 10px;
}
.off-side-brand-mark {
  width: 30px; height: 30px;
  background: var(--teal-500);
  color: var(--navy-950);
  border-radius: 8px;
  display: grid; place-items: center;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.04em;
}
.off-side-brand-meta { display: flex; flex-direction: column; line-height: 1.15; }
.off-side-brand-name {
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
}
.off-side-brand-store {
  font-size: 10px;
  color: var(--structure-fg-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}

.off-side-section {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--structure-fg-muted);
  font-weight: 500;
  padding: 12px 10px 4px;
}

.off-nav {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.off-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 7px;
  color: var(--structure-fg);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  font-family: inherit;
  transition: background var(--dur-fast) var(--ease-out);
}
.off-nav-item:hover { background: rgba(255,255,255,0.06); }
.off-nav-item--active {
  background: var(--teal-700);
  color: #fff;
}
.off-nav-item--active:hover { background: var(--teal-700); }
.off-nav-item svg { width: 15px; height: 15px; flex-shrink: 0; }
.off-nav-badge {
  margin-left: auto;
  font-size: 10px;
  font-weight: 500;
  background: rgba(255,255,255,0.12);
  color: var(--structure-fg);
  padding: 1px 6px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
  min-width: 18px; text-align: center;
}
.off-nav-item--active .off-nav-badge {
  background: rgba(0,0,0,0.22);
  color: #fff;
}

.off-side-foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--structure-border);
}
.off-side-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  border-radius: 7px;
  cursor: pointer;
}
.off-side-user:hover { background: rgba(255,255,255,0.06); }
.off-side-user-av {
  width: 28px; height: 28px;
  border-radius: 999px;
  background: var(--teal-700);
  color: #fff;
  display: grid; place-items: center;
  font-size: 10px;
  font-weight: 600;
  flex-shrink: 0;
}
.off-side-user-meta {
  flex: 1;
  display: flex; flex-direction: column;
  line-height: 1.2;
  min-width: 0;
}
.off-side-user-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--structure-fg);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.off-side-user-role {
  font-size: 10px;
  color: var(--structure-fg-muted);
}

/* Main column */
.off-main {
  display: grid;
  grid-template-rows: 56px 1fr;
  overflow: hidden;
  min-width: 0;
}

/* Topbar */
.off-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.off-topbar-store {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px 6px 6px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font: inherit;
  font-size: 13px;
  background: var(--bg-subtle);
  cursor: pointer;
  color: var(--text);
}
.off-topbar-store:hover { background: var(--surface); border-color: var(--text-subtle); }
.off-topbar-store-av {
  width: 24px; height: 24px;
  border-radius: 6px;
  background: var(--navy-800);
  color: var(--teal-300);
  display: grid; place-items: center;
  font-size: 10px;
  font-weight: 600;
}
.off-topbar-store-meta {
  display: flex; flex-direction: column;
  line-height: 1.2;
  text-align: left;
}
.off-topbar-store-name {
  font-size: 13px;
  font-weight: 500;
}
.off-topbar-store-sub {
  font-size: 10px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.off-topbar-search {
  flex: 1;
  max-width: 420px;
  position: relative;
}
.off-topbar-search .input {
  height: 34px;
  background: var(--bg-subtle);
  border-color: transparent;
  padding-left: 32px;
  font-size: 13px;
}
.off-topbar-search .input:focus { background: var(--surface); border-color: var(--brand); }
.off-topbar-search-ic {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  width: 14px; height: 14px;
  color: var(--text-subtle);
}
.off-topbar-search .kbd {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-subtle);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 2px 5px;
}

.off-topbar-meta {
  margin-left: auto;
  display: flex; align-items: center; gap: 10px;
}
.off-topbar-btn {
  background: transparent;
  border: 1px solid var(--border);
  width: 34px; height: 34px;
  border-radius: 7px;
  display: grid; place-items: center;
  color: var(--text-muted);
  cursor: pointer;
}
.off-topbar-btn:hover { background: var(--bg-subtle); color: var(--text); }
.off-topbar-btn svg { width: 14px; height: 14px; }

.off-topbar-divider { width: 1px; height: 24px; background: var(--border); }

/* -------------------------------------------------------------
   Screen
   ------------------------------------------------------------- */
.off-screen {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
  min-width: 0;
}
.off-screen-header {
  padding: 16px 24px 12px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.off-screen-header-meta {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
}
.off-screen-eyebrow {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  color: var(--text-subtle);
}
.off-screen-title {
  margin: 0;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.off-screen-actions { display: flex; align-items: center; gap: 8px; }
.off-screen-body {
  flex: 1;
  overflow-y: auto;
  padding: 18px 24px 24px;
  min-height: 0;
  background: var(--bg-subtle);
}

/* Sub-tabs within a section */
.off-subtabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  padding: 0 24px;
  margin: -1px 0 0;
}
.off-subtab {
  padding: 11px 14px;
  background: transparent;
  border: none;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.off-subtab:hover { color: var(--text); }
.off-subtab--active {
  color: var(--text);
  border-bottom-color: var(--brand);
}

/* -------------------------------------------------------------
   Standard table layout used across all data-grids in Office
   ------------------------------------------------------------- */
.off-table {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  font-size: 13px;
}
.off-table-toolbar {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-subtle);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.off-table-toolbar-sep {
  width: 1px; height: 22px; background: var(--border);
}
.off-grid {
  display: grid;
}
.off-grid-header {
  background: var(--bg-subtle);
  border-bottom: 1px solid var(--border);
}
.off-grid-cell, .off-grid-headcell {
  padding: 9px 12px;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
  align-self: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.off-grid-headcell {
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 500;
  background: var(--bg-subtle);
  border-bottom: 1px solid var(--border);
  user-select: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
}
.off-grid-headcell:hover { color: var(--text); }
.off-grid-headcell svg.sort-arrow {
  width: 10px; height: 10px;
  opacity: 0.6;
}
.off-grid-row {
  display: contents;
}
.off-grid-row > .off-grid-cell { cursor: pointer; }
.off-grid-row:hover > .off-grid-cell { background: var(--bg-subtle); }

.off-cell-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: inherit;
}
.off-cell-mono {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
}
.off-cell-strong { font-weight: 500; color: var(--text); }

/* Inline editable cell */
.off-cell-edit input,
.off-cell-edit select {
  width: 100%;
  border: 1px solid transparent;
  background: transparent;
  font: inherit;
  font-size: 13px;
  padding: 4px 6px;
  border-radius: 4px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.off-cell-edit input:hover,
.off-cell-edit select:hover { background: var(--bg-subtle); border-color: var(--border-subtle); }
.off-cell-edit input:focus,
.off-cell-edit select:focus {
  background: var(--surface);
  border-color: var(--brand);
  box-shadow: var(--ring);
  outline: none;
}
.off-cell-edit--dirty input { background: var(--hold-bg) !important; border-color: var(--hold) !important; }

/* Bulk action bar */
.off-bulk-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--navy-900);
  color: #fff;
  border-radius: 10px;
  margin-bottom: 12px;
}
.off-bulk-bar-count {
  background: var(--teal-500);
  color: var(--navy-950);
  border-radius: 999px;
  padding: 2px 10px;
  font-size: 12px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.off-bulk-bar-actions {
  margin-left: auto;
  display: flex; gap: 6px;
}

/* -------------------------------------------------------------
   KPI cards
   ------------------------------------------------------------- */
.off-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.off-kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.off-kpi-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  font-weight: 500;
}
.off-kpi-value {
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.off-kpi-delta {
  font-size: 12px;
  color: var(--text-muted);
  display: flex; align-items: center; gap: 4px;
  font-variant-numeric: tabular-nums;
}
.off-kpi-delta--up   { color: var(--paid-text); }
.off-kpi-delta--down { color: var(--void-text); }
.off-kpi-spark {
  margin-top: 4px;
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 28px;
}
.off-kpi-spark span {
  flex: 1;
  background: var(--brand-bg-strong);
  border-radius: 1px;
  min-height: 2px;
}
.off-kpi-spark span.peak { background: var(--brand); }

/* -------------------------------------------------------------
   Cards (used everywhere)
   ------------------------------------------------------------- */
.off-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.off-card-title {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
}
.off-card-meta {
  font-size: 12px;
  color: var(--text-muted);
}
.off-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* -------------------------------------------------------------
   Dashboard layout
   ------------------------------------------------------------- */
.dash-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 14px;
}
.dash-stores-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.dash-store-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: all var(--dur-fast) var(--ease-out);
}
.dash-store-card:hover {
  border-color: var(--text-subtle);
  box-shadow: var(--shadow-sm);
}
.dash-store-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
}
.dash-store-card-name {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0;
}
.dash-store-card-sub {
  font-size: 12px;
  color: var(--text-subtle);
  font-family: var(--font-mono);
}
.dash-store-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 12px;
  margin-top: 6px;
}
.dash-store-stat {
  display: flex; flex-direction: column;
}
.dash-store-stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  font-weight: 500;
}
.dash-store-stat-value {
  font-size: 16px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.dash-chart {
  height: 220px;
  display: flex;
  align-items: flex-end;
  gap: 5px;
  margin-top: 16px;
}
.dash-chart-stack {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0;
  height: 100%;
}
.dash-chart-stack span {
  width: 100%;
  min-height: 2px;
}
.dash-chart-legend {
  display: flex;
  gap: 16px;
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 10px;
}
.dash-chart-legend-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 2px;
  margin-right: 6px;
  vertical-align: -1px;
}

.alert-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
}
.alert-row:last-child { border-bottom: none; }
.alert-row-icon {
  width: 28px; height: 28px;
  border-radius: 7px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.alert-row-icon svg { width: 13px; height: 13px; }
.alert-row-icon--s8       { background: var(--sched-bg); color: var(--sched); }
.alert-row-icon--stock    { background: var(--hold-bg);  color: var(--hold-text); }
.alert-row-icon--expiry   { background: var(--hold-bg);  color: var(--hold-text); }
.alert-row-icon--transfer { background: var(--brand-bg); color: var(--brand); }
.alert-row-icon--void     { background: var(--void-bg);  color: var(--void); }
.alert-row-icon--system   { background: var(--bg-muted); color: var(--text-muted); }

/* -------------------------------------------------------------
   Drawer (right-side panel for store-switcher, etc.)
   ------------------------------------------------------------- */
.off-drawer {
  position: absolute;
  top: 56px; right: 0; bottom: 0;
  width: 360px;
  background: var(--surface);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  z-index: 60;
}
.off-drawer-head {
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.off-drawer-body {
  flex: 1; overflow-y: auto;
}
.off-drawer-row {
  padding: 12px 18px;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid var(--border-subtle);
  cursor: pointer;
}
.off-drawer-row:hover { background: var(--bg-subtle); }
.off-drawer-row--active { background: var(--brand-bg); }
.off-drawer-row--active:hover { background: var(--brand-bg-strong); }

/* -------------------------------------------------------------
   Label designer
   ------------------------------------------------------------- */
.label-designer {
  display: grid;
  grid-template-columns: 260px 1fr 280px;
  gap: 14px;
  height: 100%;
  min-height: 0;
}
.label-pane {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}
.label-pane-head {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  font-weight: 500;
}
.label-pane-body {
  flex: 1;
  overflow-y: auto;
  padding: 10px 14px;
}

.label-element {
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: grab;
  background: var(--bg);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
}
.label-element:hover { border-color: var(--text-subtle); }
.label-element-icon {
  width: 28px; height: 28px;
  background: var(--bg-muted);
  border-radius: 6px;
  display: grid; place-items: center;
  color: var(--text-muted);
}

.label-stage {
  flex: 1;
  display: grid; place-items: center;
  background:
    linear-gradient(45deg, var(--bg-muted) 25%, transparent 25%) 0 0 / 16px 16px,
    linear-gradient(-45deg, var(--bg-muted) 25%, transparent 25%) 0 0 / 16px 16px,
    linear-gradient(45deg, transparent 75%, var(--bg-muted) 75%) 0 0 / 16px 16px,
    linear-gradient(-45deg, transparent 75%, var(--bg-muted) 75%) 0 0 / 16px 16px;
  background-color: var(--bg-subtle);
  padding: 28px;
  overflow: auto;
  min-height: 0;
}

.label-canvas {
  background: #fff;
  position: relative;
  box-shadow: var(--shadow-lg);
  /* dimensions set via inline style */
}

.label-canvas-el {
  position: absolute;
  border: 1px dashed transparent;
  padding: 2px 4px;
  cursor: move;
  user-select: none;
}
.label-canvas-el:hover { border-color: var(--brand); }
.label-canvas-el--selected { border-color: var(--brand); border-style: solid; }
.label-canvas-el--text { color: #000; font-family: var(--font-sans); }
.label-canvas-el--barcode {
  background: repeating-linear-gradient(to right, #000 0, #000 2px, #fff 2px, #fff 3px, #000 3px, #000 5px, #fff 5px, #fff 6px, #000 6px, #000 7px, #fff 7px, #fff 9px);
  color: #000;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 8px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 2px;
}

.label-prop-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.label-prop-row:last-child { border-bottom: none; }
.label-prop-label {
  font-size: 11px;
  color: var(--text-subtle);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 500;
}
.label-prop-row .input { height: 32px; padding: 0 10px; font-size: 13px; }

/* Stocktake counting */
.count-screen {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 14px;
  height: 100%;
  min-height: 0;
}
.count-item-row {
  display: grid;
  grid-template-columns: 40px 1fr 90px 80px 110px 110px 80px;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-subtle);
  align-items: center;
  font-size: 13px;
}
.count-item-row:last-child { border-bottom: none; }
.count-item-row--counted { background: var(--paid-bg); }
.count-item-row--variance { background: var(--hold-bg); }
.count-item-row--header {
  background: var(--bg-subtle);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 500;
  padding: 10px 16px;
}

.count-input {
  height: 32px;
  width: 84px;
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  background: var(--surface);
  font: inherit;
  font-size: 14px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--text);
}
.count-input:focus { outline: none; border-color: var(--brand); box-shadow: var(--ring); }

/* Settings vertical nav */
.settings-grid {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 20px;
  height: 100%;
}
.settings-nav {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px;
  display: flex; flex-direction: column;
  gap: 1px;
  height: max-content;
}
.settings-nav button {
  padding: 9px 11px;
  border: none;
  background: transparent;
  font: inherit;
  font-size: 13px;
  text-align: left;
  border-radius: 6px;
  color: var(--text-muted);
  cursor: pointer;
  font-weight: 500;
}
.settings-nav button:hover { color: var(--text); background: var(--bg-subtle); }
.settings-nav button.active {
  background: var(--brand-bg);
  color: var(--brand);
}
.settings-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 26px;
  overflow-y: auto;
}
.settings-row {
  display: grid;
  grid-template-columns: 1fr 320px;
  padding: 14px 0;
  gap: 24px;
  border-bottom: 1px solid var(--border-subtle);
  align-items: center;
}
.settings-row:last-child { border-bottom: none; }
.settings-row-title { font-weight: 500; font-size: 14px; }
.settings-row-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* Filter chip row */
.off-filters {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.off-filter {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 28px;
}
.off-filter:hover { color: var(--text); }
.off-filter--active {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
}
.off-filter-count {
  background: var(--bg-muted);
  color: var(--text-muted);
  padding: 0 6px;
  border-radius: 999px;
  font-size: 10px;
  font-variant-numeric: tabular-nums;
}
.off-filter--active .off-filter-count {
  background: rgba(255,255,255,0.18);
  color: var(--bg);
}

/* Empty states inside Office */
.off-empty {
  text-align: center;
  padding: 48px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

/* Wizard for New stock line */
.wiz-step-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.wiz-step-number {
  width: 28px; height: 28px;
  border-radius: 999px;
  background: var(--brand);
  color: var(--brand-fg);
  display: grid; place-items: center;
  font-weight: 600;
  font-size: 12px;
  flex-shrink: 0;
}
.wiz-step-title {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
}

/* Schema designer */
.schema-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
  height: 100%;
  min-height: 0;
}
.schema-pool {
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.schema-pool-head {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-subtle);
  font-weight: 500;
  background: var(--bg-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.schema-pool-body {
  flex: 1; overflow-y: auto;
  padding: 8px;
  display: flex; flex-direction: column; gap: 4px;
}
.schema-field-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 7px;
  font-size: 13px;
  background: var(--bg-subtle);
  cursor: grab;
}
.schema-field-pill:hover { background: var(--bg); border-color: var(--text-subtle); }
.schema-field-pill--selected {
  background: var(--brand-bg);
  border-color: var(--brand-border);
  color: var(--brand);
}
.schema-field-pill-type {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 2px 5px;
  border-radius: 3px;
  background: var(--bg);
  color: var(--text-muted);
  margin-left: auto;
}

/* Misc utilities */
.off-mono { font-family: var(--font-mono); font-size: 12px; }
.off-num  { font-variant-numeric: tabular-nums; }
.off-muted { color: var(--text-muted); }
.off-row { display: flex; align-items: center; gap: 8px; }
.off-spacer { flex: 1; }


/* ===============================================================
   CATEGORY RAIL — left-side hierarchical category filter
   =============================================================== */
.cat-rail {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 6px;
  position: sticky;
  top: 0;
  max-height: calc(100vh - 240px);
  overflow-y: auto;
  font-size: 13px;
}
.cat-rail-header {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 8px 10px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-subtle);
  font-weight: 600;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: 4px;
}
.cat-rail-header svg { color: var(--brand); }
.cat-rail-count {
  margin-left: auto;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
  color: var(--text-muted);
}
.cat-rail-tree { display: flex; flex-direction: column; }

.cat-rail-row {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 8px;
  border-radius: 6px;
  border: 0;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  width: 100%;
  font: inherit;
  font-size: 13px;
  position: relative;
}
.cat-rail-row:hover { background: var(--bg-subtle); }
.cat-rail-row.is-selected {
  background: var(--brand-bg);
  color: var(--brand);
  font-weight: 500;
}
.cat-rail-row.is-selected .cat-rail-num { color: var(--brand); }

.cat-rail-row--all {
  margin: 2px 0 6px;
  font-weight: 500;
  border: 1px solid var(--border-subtle);
}
.cat-rail-row--dept {
  margin-top: 4px;
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 7px 8px;
}
.cat-rail-row--cat { padding: 5px 8px 5px 6px; }
.cat-rail-row--sub {
  padding: 5px 8px 5px 6px;
  color: var(--text-muted);
  font-size: 12.5px;
}
.cat-rail-row--sub:hover { color: var(--text); }

.cat-rail-twist {
  background: transparent;
  border: 0;
  width: 16px; height: 16px;
  display: grid; place-items: center;
  cursor: pointer;
  color: var(--text-subtle);
  padding: 0;
  border-radius: 3px;
  flex-shrink: 0;
}
.cat-rail-twist:hover { background: var(--bg-muted); color: var(--text); }
.cat-rail-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cat-rail-label--btn {
  background: transparent;
  border: 0;
  font: inherit;
  cursor: pointer;
  color: inherit;
  text-align: left;
  padding: 0;
}
.cat-rail-num {
  font-variant-numeric: tabular-nums;
  font-size: 11.5px;
  color: var(--text-subtle);
  font-weight: 500;
  flex-shrink: 0;
}
.cat-rail-pip {
  width: 6px; height: 6px;
  border-radius: 99px;
  background: var(--hold-text, #c08200);
  flex-shrink: 0;
}
.cat-rail-children {
  padding-left: 18px;
  border-left: 1px solid var(--border-subtle);
  margin-left: 8px;
  display: flex; flex-direction: column; gap: 1px;
}
.cat-rail-children--sub {
  padding-left: 14px;
}

/* Category add buttons — header "+", inline "+" on rows, footer button */
.cat-rail-add {
  margin-left: 4px;
  background: var(--brand-bg);
  border: 1px solid var(--brand-border);
  color: var(--brand);
  width: 20px; height: 20px;
  border-radius: 5px;
  display: grid; place-items: center;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}
.cat-rail-add:hover { background: var(--brand); color: #fff; }
.cat-rail-inline-add {
  background: transparent;
  border: 0;
  color: var(--text-subtle);
  width: 18px; height: 18px;
  border-radius: 4px;
  display: grid; place-items: center;
  cursor: pointer;
  padding: 0;
  opacity: 0;
  transition: opacity 80ms;
  flex-shrink: 0;
}
.cat-rail-row:hover .cat-rail-inline-add { opacity: 1; }
.cat-rail-inline-add:hover { background: var(--brand-bg); color: var(--brand); }
.cat-rail-footer-add {
  margin-top: 8px;
  padding: 8px 10px;
  background: transparent;
  border: 1px dashed var(--border-strong);
  border-radius: 7px;
  color: var(--text-muted);
  font: inherit;
  font-size: 12.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  justify-content: center;
}
.cat-rail-footer-add:hover {
  border-color: var(--brand);
  background: var(--brand-bg);
  color: var(--brand);
}

/* Level picker in the New Category modal */
.newcat-level {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.newcat-level-opt {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  transition: border-color .12s, background .12s;
}
.newcat-level-opt:hover { border-color: var(--text-subtle); }
.newcat-level-opt.is-selected {
  border-color: var(--brand);
  background: var(--brand-bg);
  box-shadow: var(--ring, 0 0 0 3px rgba(20, 110, 90, 0.12));
}
.newcat-level-title {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.newcat-level-opt.is-selected .newcat-level-title { color: var(--brand); }
.newcat-level-hint {
  font-size: 11px;
  color: var(--text-subtle);
  margin-top: 2px;
}

/* ===============================================================
   TREE BREADCRUMB — current selection above the table
   =============================================================== */
.tree-crumb {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 14px;
  background: var(--brand-bg);
  border-bottom: 1px solid var(--border);
  font-size: 12.5px;
  flex-wrap: wrap;
}
.tree-crumb-root,
.tree-crumb-link {
  background: transparent;
  border: 0;
  color: var(--brand);
  font: inherit;
  cursor: pointer;
  padding: 0;
  text-decoration: underline dotted;
  text-underline-offset: 3px;
}
.tree-crumb-root:hover,
.tree-crumb-link:hover { color: var(--text); }
.tree-crumb-sep { color: var(--text-subtle); }
.tree-crumb-current {
  color: var(--text);
  font-weight: 600;
}
.tree-crumb-clear {
  margin-left: auto;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-muted);
  border-radius: 999px;
  padding: 3px 10px;
  font: inherit;
  font-size: 11.5px;
  display: inline-flex; align-items: center; gap: 4px;
  cursor: pointer;
}
.tree-crumb-clear:hover { color: var(--text); border-color: var(--text-subtle); }

/* ===============================================================
   STOCK TREE VIEW — 3-level hierarchical rollup of inventory
   =============================================================== */
.stk-tree { display: flex; flex-direction: column; }
.stk-tree-dept + .stk-tree-dept { border-top: 1px solid var(--border); }

.stk-tree-head {
  display: grid;
  grid-template-columns: 18px 1fr auto auto auto auto;
  align-items: center;
  gap: 16px;
  padding: 12px 16px;
  cursor: pointer;
  user-select: none;
  background: var(--surface);
  border-bottom: 1px solid var(--border-subtle);
}
.stk-tree-head:hover { background: var(--bg-subtle); }

.stk-tree-head--dept {
  background: linear-gradient(to bottom, var(--bg-subtle), var(--surface));
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.stk-tree-head--dept .stk-tree-head-title {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.012em;
}
.stk-tree-head-desc {
  font-size: 11.5px;
  color: var(--text-subtle);
  margin-top: 1px;
}

.stk-tree-head--cat {
  padding: 9px 16px 9px 36px;
  background: var(--bg-subtle);
}
.stk-tree-head-title--cat {
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
}

.stk-tree-head--sub {
  padding: 7px 16px 7px 56px;
  background: var(--surface);
  border-bottom: 1px dashed var(--border-subtle);
}
.stk-tree-head-title--sub {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.stk-tree-head--sub:hover .stk-tree-head-title--sub { color: var(--text); }

.stk-tree-twist { color: var(--text-subtle); flex-shrink: 0; }
.stk-tree-head:hover .stk-tree-twist { color: var(--text); }

.stk-tree-sku-count {
  font-size: 11px;
  color: var(--text-subtle);
  font-variant-numeric: tabular-nums;
}

.tree-stat {
  text-align: right;
  min-width: 70px;
}
.tree-stat-label {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-subtle);
  font-weight: 500;
  margin-bottom: 1px;
}
.tree-stat-value {
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--text);
}
.tree-stat-value.is-strong { font-weight: 600; }
.tree-stat-value.is-warn   { color: var(--hold-text); }

.stk-tree-head--sub .tree-stat-label { font-size: 9px; }
.stk-tree-head--sub .tree-stat-value { font-size: 12px; font-weight: 500; }

.stk-tree-rows {
  position: relative;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  border-left: 3px solid var(--brand-bg-strong, var(--border));
  margin-left: 56px;
}
.stk-tree-rows .off-grid-cell {
  border-bottom: 1px solid var(--border-subtle);
}


/* ===============================================================
   PRODUCT DETAIL — full SKU view, opens from Stock overview row
   =============================================================== */
.pd-header {
  align-items: flex-start;
  padding-top: 18px;
  padding-bottom: 18px;
}
.pd-back {
  background: transparent;
  border: 0;
  padding: 0;
  font: inherit;
  font-size: 11.5px;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  margin-bottom: 6px;
}
.pd-back:hover { color: var(--text); }
.pd-title-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}
.pd-title {
  font-size: 22px !important;
  letter-spacing: -0.02em;
  margin: 0;
}
.pd-strength {
  font-size: 16px;
  color: var(--text-muted);
  font-weight: 500;
}
.pd-pack {
  font-size: 13px;
  color: var(--text-subtle);
  padding: 2px 8px;
  background: var(--bg-muted);
  border-radius: 99px;
  white-space: nowrap;
}
.pd-meta-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  flex-wrap: wrap;
  font-size: 12px;
}
.pd-sku {
  font-family: var(--font-mono);
  color: var(--text-subtle);
  font-size: 12px;
}
.pd-dot { color: var(--text-subtle); }
.pd-crumb {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
}
.pd-crumb-link {
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 12px;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  text-decoration: underline dotted;
  text-underline-offset: 3px;
}
.pd-crumb-link:hover { color: var(--brand); }
.pd-crumb-sep { color: var(--text-subtle); }
.pd-crumb-current {
  color: var(--text);
  font-weight: 500;
}

/* Chips for flags / status */
.pd-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  background: var(--bg-muted);
  color: var(--text-muted);
  border: 1px solid var(--border-subtle);
  letter-spacing: 0.005em;
  white-space: nowrap;
}
.pd-chip--compact { padding: 2px 7px; font-size: 10.5px; }
.pd-chip--brand { background: var(--brand-bg); color: var(--brand); border-color: var(--brand-border); }
.pd-chip--paid  { background: var(--paid-bg);  color: var(--paid-text); border-color: transparent; }
.pd-chip--hold  { background: var(--hold-bg);  color: var(--hold-text); border-color: transparent; }
.pd-chip--void  { background: var(--void-bg);  color: var(--void);      border-color: transparent; }

/* 2-column body layout */
.pd-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 16px;
  align-items: flex-start;
}
.pd-main { display: flex; flex-direction: column; gap: 14px; min-width: 0; }
.pd-side { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 0; }

.pd-card { padding: 0; }
.pd-card > .off-card-title { padding: 16px 18px 0; }
.pd-card-head {
  padding: 16px 18px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.pd-card-head .off-card-title { padding: 0; }
.pd-card-sub {
  font-size: 11.5px;
  color: var(--text-subtle);
  margin-top: 2px;
}

/* Sidebar cards need padding back (they don't use the off-grid pattern) */
.pd-side .pd-card { padding: 18px; }
.pd-side .pd-card > .off-card-title { padding: 0; }

.pd-empty {
  padding: 28px 18px;
  text-align: center;
  font-size: 13px;
  color: var(--text-muted);
}

/* Stock bar within the per-store table */
.pd-bar {
  display: flex;
  flex-direction: column;
  gap: 3px;
  width: 100%;
}
.pd-bar-track {
  position: relative;
  height: 6px;
  background: var(--bg-muted);
  border-radius: 99px;
  overflow: hidden;
}
.pd-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--brand);
  border-radius: 99px;
  transition: width .2s;
}
.pd-bar-fill.is-low { background: var(--hold-text); }
.pd-bar-min {
  position: absolute;
  top: -2px;
  bottom: -2px;
  width: 1.5px;
  background: var(--text-subtle);
  transform: translateX(-50%);
}
.pd-bar-legend {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  font-variant-numeric: tabular-nums;
  color: var(--text-subtle);
}
.pd-bar-legend .off-muted {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Pricing / supplier row list */
.pd-rule-list { display: flex; flex-direction: column; gap: 1px; }
.pd-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
}
.pd-row:last-child { border-bottom: 0; }
.pd-row-label { color: var(--text-muted); }
.pd-row-value {
  font-variant-numeric: tabular-nums;
  color: var(--text);
  font-weight: 500;
}
.pd-row-value.is-strong { font-weight: 600; font-size: 14px; }
.pd-row-value.is-mono { font-family: var(--font-mono); font-size: 12px; font-weight: 400; }
.pd-row-value.is-warn { color: var(--hold-text); }
.pd-row-value.is-good { color: var(--paid-text); }

/* Supplier card */
.pd-supplier {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pd-supplier-av {
  width: 36px; height: 36px;
  background: var(--brand-bg);
  color: var(--brand);
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.pd-supplier-name {
  font-weight: 600;
  font-size: 13.5px;
  letter-spacing: -0.005em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pd-supplier-meta { font-size: 11.5px; color: var(--text-subtle); margin-top: 2px; }

/* 30-day demand sparkline */
.pd-spark {
  width: 100%;
  height: 64px;
  display: block;
}
.pd-spark-line {
  fill: none;
  stroke: var(--brand);
  stroke-width: 1.6;
  vector-effect: non-scaling-stroke;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.pd-spark-area {
  fill: var(--brand-bg);
  opacity: 0.55;
}
.pd-spark-peak {
  fill: var(--brand);
}
.pd-spark-foot {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--border-subtle);
}
.pd-spark-foot-label {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-subtle);
  font-weight: 500;
  margin-bottom: 2px;
}
.pd-spark-foot-value {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
  font-variant-numeric: tabular-nums;
}

/* Movements timeline */
.pd-timeline {
  padding: 8px 18px 16px;
}
.pd-mv {
  display: grid;
  grid-template-columns: 22px 90px 1fr;
  align-items: flex-start;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border-subtle);
}
.pd-mv:last-child { border-bottom: 0; }
.pd-mv-bullet {
  width: 22px; height: 22px;
  border-radius: 99px;
  display: grid;
  place-items: center;
  background: var(--bg-muted);
  color: var(--text-muted);
  margin-top: 1px;
}
.pd-mv-bullet--sale     { background: var(--paid-bg); color: var(--paid-text); }
.pd-mv-bullet--receive  { background: var(--brand-bg); color: var(--brand); }
.pd-mv-bullet--transfer { background: var(--bg-muted); color: var(--text-muted); }
.pd-mv-bullet--adjust   { background: var(--hold-bg);  color: var(--hold-text); }
.pd-mv-bullet--stocktake{ background: var(--bg-muted); color: var(--text-subtle); }
.pd-mv-when {
  font-size: 11.5px;
  color: var(--text-subtle);
  font-variant-numeric: tabular-nums;
  padding-top: 2px;
}
.pd-mv-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.pd-mv-kind {
  font-size: 13px;
  font-weight: 500;
}
.pd-mv-qty {
  font-size: 12.5px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  padding: 1px 7px;
  border-radius: 4px;
}
.pd-mv-qty.is-out { background: var(--void-bg); color: var(--void); }
.pd-mv-qty.is-in  { background: var(--paid-bg); color: var(--paid-text); }
.pd-mv-note {
  font-size: 11.5px;
  color: var(--text-muted);
  margin-top: 2px;
}

.pd-onhand { font-size: 14px; }

/* ===== Adjust stock modal ===== */
.pd-modal-back {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 35, 0.45);
  display: grid;
  place-items: center;
  z-index: 60;
  backdrop-filter: blur(2px);
}
.pd-modal {
  background: var(--surface);
  border-radius: 12px;
  box-shadow: var(--shadow-lg, 0 12px 40px rgba(0,0,0,0.18));
  width: 440px;
  max-width: 90vw;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.pd-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.pd-modal-body {
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.pd-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  background: var(--bg-subtle);
}
.pd-qty {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pd-qty-btn {
  width: 36px; height: 36px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  cursor: pointer;
  display: grid;
  place-items: center;
  color: var(--text-muted);
}
.pd-qty-btn:hover { background: var(--bg-subtle); color: var(--text); }
.pd-qty input { flex: 1; height: 44px; }


/* ===============================================================
   STOCK LINE EDITOR — tabbed comprehensive form
   =============================================================== */
.sle-screen {}
.sle-header { align-items: flex-start; padding-bottom: 14px; }
.sle-title {
  font-size: 22px !important;
  letter-spacing: -0.02em;
  margin: 0 !important;
}
.sle-subtitle {
  display: flex; align-items: center; gap: 10px;
  margin-top: 4px;
  font-size: 12.5px;
  color: var(--text-muted);
}
.sle-dot { color: var(--text-subtle); }
.sle-sku { font-family: var(--font-mono); font-size: 11.5px; color: var(--text-subtle); }
.sle-dirty {
  display: inline-flex; align-items: center;
  background: var(--hold-bg);
  color: var(--hold-text);
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  margin-left: 4px;
}

/* Tab strip */
.sle-tabs {
  display: flex;
  gap: 2px;
  padding: 0 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  flex-shrink: 0;
}
.sle-tab {
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  padding: 12px 14px;
  font: inherit;
  font-size: 13px;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
  margin-bottom: -1px;
  transition: color .12s, border-color .12s;
}
.sle-tab:hover:not(:disabled) { color: var(--text); }
.sle-tab.is-active {
  color: var(--brand);
  border-bottom-color: var(--brand);
  font-weight: 500;
}
.sle-tab:disabled { opacity: 0.4; cursor: not-allowed; }

/* Body grid */
.sle-body { background: var(--bg-subtle); }
.sle-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: flex-start;
}
.sle-grid--single { grid-template-columns: 1fr; }
.sle-col { display: flex; flex-direction: column; gap: 14px; min-width: 0; }

.sle-card { padding: 0; overflow: hidden; }
.sle-card-head {
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border-subtle);
}
.sle-card-head .off-card-title { padding: 0; }
.sle-card-sub {
  font-size: 11.5px;
  color: var(--text-subtle);
  margin-top: 2px;
}

/* Form grid */
.sle-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  padding: 16px 18px;
}
.sle-field { min-width: 0; }
.sle-field--full { grid-column: 1 / -1; }
.sle-hint {
  font-weight: 400;
  font-size: 10.5px;
  color: var(--text-subtle);
  margin-left: 8px;
  text-transform: none;
  letter-spacing: 0;
}
.sle-emph { font-weight: 600; font-size: 14px; }

.sle-crumb {
  padding: 10px 18px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  background: var(--bg-subtle);
  color: var(--text);
  border-top: 1px dashed var(--border-subtle);
}
.sle-crumb span {
  color: var(--text-subtle);
  margin: 0 4px;
}

.sle-derived {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted);
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: 7px;
}
.sle-derived strong { color: var(--text); }

/* Toggle list */
.sle-toggles {
  display: flex;
  flex-direction: column;
  padding: 6px 0;
}
.sle-toggle {
  display: grid;
  grid-template-columns: 32px 1fr;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 18px;
  cursor: pointer;
  border-bottom: 1px solid var(--border-subtle);
}
.sle-toggle:last-child { border-bottom: 0; }
.sle-toggle:hover { background: var(--bg-subtle); }
.sle-toggle input { display: none; }
.sle-toggle-pill {
  width: 30px;
  height: 18px;
  background: var(--bg-muted);
  border-radius: 99px;
  position: relative;
  transition: background .15s;
  margin-top: 2px;
}
.sle-toggle-pill span {
  position: absolute;
  top: 2px; left: 2px;
  width: 14px; height: 14px;
  border-radius: 99px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,.18);
  transition: left .15s;
}
.sle-toggle.is-on .sle-toggle-pill { background: var(--brand); }
.sle-toggle.is-on .sle-toggle-pill span { left: 14px; }
.sle-toggle--void.is-on  .sle-toggle-pill { background: var(--void); }
.sle-toggle--hold.is-on  .sle-toggle-pill { background: var(--hold-text); }
.sle-toggle--brand.is-on .sle-toggle-pill { background: var(--brand); }
.sle-toggle-label {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.sle-toggle-hint {
  font-size: 11px;
  color: var(--text-subtle);
  margin-top: 1px;
}

/* Margin summary */
.sle-margin-summary {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border-subtle);
}
.sle-stat {
  background: var(--bg-subtle);
  border-radius: 8px;
  padding: 10px 12px;
}
.sle-stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-subtle);
  font-weight: 600;
  margin-bottom: 2px;
}
.sle-stat-value {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.012em;
  font-variant-numeric: tabular-nums;
}
.sle-stat-value.is-warn { color: var(--hold-text); }
.sle-stat-value.is-good { color: var(--paid-text); }

/* Cost ladder */
.sle-ladder {
  padding: 12px 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sle-ladder-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
  color: var(--text-muted);
}
.sle-ladder-row:last-child { border-bottom: 0; }
.sle-ladder-row.is-emph {
  color: var(--text);
  font-weight: 600;
}
.sle-ladder-row.is-muted {
  color: var(--text-subtle);
  font-size: 12px;
}
.sle-ladder-value {
  font-variant-numeric: tabular-nums;
}

/* PDE / supplier / barcode editable rows */
.sle-empty-row {
  grid-column: 1 / -1;
  padding: 24px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
}
.sle-default-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted);
  cursor: pointer;
}
.sle-default-radio input { margin: 0; }
.sle-default-radio input:checked + span { color: var(--brand); font-weight: 500; }

/* Movements pills */
.sle-mv-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 500;
  background: var(--bg-muted);
  color: var(--text-muted);
}
.sle-mv-pill--sale       { background: var(--paid-bg);  color: var(--paid-text); }
.sle-mv-pill--receipt    { background: var(--brand-bg); color: var(--brand); }
.sle-mv-pill--transfer   { background: var(--bg-muted); color: var(--text-muted); }
.sle-mv-pill--adjustment { background: var(--hold-bg);  color: var(--hold-text); }
.sle-mv-pill--stocktake  { background: var(--bg-muted); color: var(--text-subtle); }

/* History rows */
.sle-history { padding: 6px 18px 16px; }
.sle-history-row {
  display: grid;
  grid-template-columns: 150px 1fr 120px;
  align-items: flex-start;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-subtle);
  font-size: 13px;
}
.sle-history-row:last-child { border-bottom: 0; }
.sle-history-when {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-subtle);
}
.sle-history-action { font-weight: 500; }
.sle-history-detail { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.sle-history-user { color: var(--text-muted); text-align: right; font-size: 12px; }

/* Notes */
.sle-textarea {
  margin: 0 18px 18px;
  width: calc(100% - 36px);
  font-family: var(--font-sans);
  font-size: 13px;
  resize: vertical;
  min-height: 100px;
  padding: 10px 12px;
}

/* Label preview */
.sle-label-preview {
  margin: 16px 18px;
  padding: 16px;
  background: #fff;
  border: 1px dashed var(--border-strong, var(--border));
  border-radius: 8px;
  color: #000;
  font-family: var(--font-sans);
}
.sle-label-name { font-size: 15px; font-weight: 600; letter-spacing: -0.012em; line-height: 1.2; }
.sle-label-sub { font-size: 12px; color: #555; margin-top: 2px; }
.sle-label-foot {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: 14px;
  gap: 14px;
}
.sle-label-barcode {
  flex: 1;
  height: 28px;
  background: repeating-linear-gradient(to right, #000 0, #000 2px, #fff 2px, #fff 3px, #000 3px, #000 5px, #fff 5px, #fff 6px);
}
.sle-label-price {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.sle-label-sku {
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: #555;
  text-align: center;
}
