/* --------- Theme tokens --------- */
:root {
  --bg: #0b0b0f;
  --panel: #131318;
  --muted: #a1a1aa;
  --text: #e7e7ea;
  --line: #22222a;
  --brand: #ff7a1a;      /* orange accent */
  --brand-2: #ffd399;
  --good: #19c37d;
  --warn: #f5a524;
  --bad: #ef4444;
  --shadow: 0 8px 20px rgba(0,0,0,.35);
  --radius: 12px;
}

html[data-theme="light"] {
  --bg: #f8fafc;
  --panel: #ffffff;
  --muted: #5b6171;
  --text: #0b1020;
  --line: #e5e7eb;
  --shadow: 0 8px 20px rgba(2,6,23,.08);
}

/* --------- Base --------- */
* { box-sizing: border-box; }
body {
  margin: 0;
  background: radial-gradient(1200px 600px at 10% -10%, rgba(255,122,26,.15), transparent),
              var(--bg);
  color: var(--text);
  font: 14.5px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Inter, "Helvetica Neue", Arial, sans-serif;
}

/* Layout shell */
.app-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 100dvh;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100dvh;
  background: var(--panel);
  border-right: 1px solid var(--line);
  padding: 18px 14px;
  overflow-y: auto;
  transition: transform .2s ease;
}

.sidebar.open { transform: translateX(0); }

.brand {
  display: flex; align-items: center; gap: 14px;
  margin: 8px 10px 22px;
}
.brand-logo {
  width: 68px; height: 68px;
  padding: 6px;
  border-radius: 50%;
  object-fit: contain;
  background: #060606;
  box-shadow: 0 14px 32px rgba(224, 27, 36, .32);
}
.brand-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.brand-title {
  letter-spacing: .08em;
  font-weight: 800;
  font-size: 22px;
  text-transform: uppercase;
}
.brand-tagline {
  font-size: 11px;
  letter-spacing: .34em;
  font-weight: 600;
  color: color-mix(in oklab, var(--muted), white 28%);
}

.auth-brand-copy {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.brand-tagline--auth {
  font-size: 12px;
  letter-spacing: .28em;
  font-weight: 600;
  color: color-mix(in oklab, var(--muted), white 35%);
  text-transform: uppercase;
}

.nav { display: grid; gap: 6px; margin-top: 10px; }
.nav-link {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: var(--radius);
  color: var(--text); text-decoration: none;
  border: 1px solid transparent;
}
.nav-link:hover { background: color-mix(in oklab, var(--panel), white 4%); border-color: var(--line); }
.nav-link.is-active {
  background: color-mix(in oklab, var(--brand) 18%, var(--panel));
  border-color: color-mix(in oklab, var(--brand) 35%, var(--line));
}

.icon { width: 18px; text-align: center; opacity: .9; }

/* Main column */
.main { display: grid; grid-template-rows: auto 1fr; min-width: 0; }

.topbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  background: color-mix(in oklab, var(--panel), black 4%);
  position: sticky; top: 0; z-index: 5;
}

.only-mobile { display: none; }

.topbar-right { display: flex; align-items: center; gap: 12px; }

.user-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 10px; border-radius: 999px;
  background: color-mix(in oklab, var(--panel), white 3%);
  border: 1px solid var(--line);
}
.avatar { width: 22px; height: 22px; display: grid; place-items: center; }
.user-name { font-weight: 600; letter-spacing: .01em; }

/* Buttons */
.btn-primary, .btn-ghost {
  appearance: none; border: 1px solid transparent; cursor: pointer;
  padding: 8px 12px; border-radius: 10px; font-weight: 600;
}
.btn-primary {
  background: linear-gradient(135deg, var(--brand), #ff9e3a);
  color: #1d1308; border-color: transparent;
  box-shadow: 0 6px 18px rgba(255,122,26,.25);
}
.btn-primary:hover { filter: brightness(1.05); }
.btn-ghost {
  background: transparent; color: var(--text); border-color: var(--line);
}
.btn-ghost:hover { background: color-mix(in oklab, var(--panel), white 4%); }

/* Page scaffolding */
.content { padding: 18px; }
.page-header {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 14px;
}
.page-title { font-size: 24px; letter-spacing: .02em; margin: 0; }

/* Cards */
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}


.card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.card-head-actions {
  margin-left: auto;
  display: flex;
  text-align-last: end;
}
.form-field .form-label {
  display: block;
  margin-bottom: 6px;
}

.expense-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.expense-title .badge.info {
  color: #042238;
  background: color-mix(in oklab, var(--brand) 20%, transparent);
  border-color: color-mix(in oklab, var(--brand) 35%, var(--line));
}

/* Table */
.table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  overflow: hidden;
}
.table thead th {
  text-align: left; font-weight: 700; font-size: 12px; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted);
  background: color-mix(in oklab, var(--panel), white 2%);
  border-bottom: 1px solid var(--line);
  padding: 12px 14px;
}
.table tbody td {
  padding: 14px; border-bottom: 1px solid var(--line);
}
.table thead th.right,
.table tbody td.right,
.table thead th.amount-col,
.table tbody td.amount-col {
  text-align: right;
}

.table thead th.amount-col,
.table tbody td.amount-col {
  width: 16%;
  padding-right: 18px;
}
.table tbody tr:hover { background: color-mix(in oklab, var(--panel), white 3%); }


.toggle-paid {
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; color: var(--muted); font-size: 12px;
}
.toggle-paid input[type="checkbox"] {
  width: 18px; height: 18px; cursor: pointer;
}
.detail-card.calculator-card {
  gap: 16px;
}
.calculator-head {
  display: grid;
  gap: 4px;
}
.calculator-head h4 {
  margin: 0;
  font-size: 14px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.calc-display {
  background: color-mix(in oklab, var(--panel), white 8%);
  border-radius: calc(var(--radius) - 4px);
  border: 1px solid color-mix(in oklab, var(--line), white 12%);
  padding: 12px 14px;
  display: grid;
  gap: 6px;
  min-height: 70px;
}
.calc-expression {
  font-size: 12px;
  letter-spacing: .05em;
  color: color-mix(in oklab, var(--muted), white 30%);
  text-align: right;
}
.calc-result {
  font-size: 26px;
  font-weight: 600;
  text-align: right;
}
.calc-keypad {
  display: grid;
  grid-template-columns: repeat(4, minmax(60px, 1fr));
  gap: 10px;
}
.calc-btn {
  border: 1px solid color-mix(in oklab, var(--line), white 8%);
  border-radius: calc(var(--radius) - 6px);
  padding: 12px;
  font-size: 16px;
  font-weight: 600;
  background: color-mix(in oklab, var(--panel), white 4%);
  color: var(--text);
  cursor: pointer;
  transition: background .15s ease, transform .05s ease;
}
.calc-btn:hover {
  background: color-mix(in oklab, var(--panel), white 8%);
}
.calc-btn:active {
  transform: translateY(1px);
}
.calc-btn--op {
  background: linear-gradient(135deg, color-mix(in oklab, var(--brand), white 10%), var(--brand));
  color: #1d1308;
  border: none;
}
.calc-btn--util {
  color: color-mix(in oklab, var(--muted), white 20%);
}
.calc-btn--equal {
  background: linear-gradient(135deg, var(--good), color-mix(in oklab, var(--good), white 20%));
  color: #032412;
  border: none;
}
.calc-btn--wide {
  grid-column: span 2;
}
/* Badges */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px; font-weight: 700; font-size: 12px;
  border: 1px solid transparent;
}
.badge.good  { color: #052e1f; background: color-mix(in oklab, var(--good) 30%, transparent); border-color: color-mix(in oklab, var(--good) 55%, var(--line)); }
.badge.warn  { color: #3b2703; background: color-mix(in oklab, var(--warn) 30%, transparent); border-color: color-mix(in oklab, var(--warn) 55%, var(--line)); }
.badge.bad   { color: #3b0a0a; background: color-mix(in oklab, var(--bad) 28%, transparent);  border-color: color-mix(in oklab, var(--bad) 55%, var(--line)); }

/* Toolbar */
.toolbar {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px;
}
.input, .select {
  height: 36px; padding: 0 10px; border-radius: 10px;
  border: 1px solid var(--line); background: color-mix(in oklab, var(--panel), white 2%);
  color: var(--text);
}
.input:focus, .select:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 30%, transparent); }

/* Alerts & messages */
.alert { padding: 10px 12px; border-radius: 10px; margin-bottom: 10px; border: 1px solid var(--line); }
.alert.success { background: color-mix(in oklab, var(--good) 22%, transparent); }
.alert.warning { background: color-mix(in oklab, var(--warn) 22%, transparent); }
.alert.error   { background: color-mix(in oklab, var(--bad)  22%, transparent); }

/* Responsive */
@media (max-width: 960px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; left: 0; top: 0; width: 82%; max-width: 320px; transform: translateX(-100%);
    box-shadow: var(--shadow); z-index: 10;
  }
  .sidebar.open { transform: translateX(0); }
  .only-mobile { display: inline-flex; }
  .content { padding: 14px; }
}


/* Login spotlight animation */
.ims-anim {
  margin-top: 16px;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--brand) 20%, var(--line));
  background: transparent; /* inside card, avoid double background */
  box-shadow: none;
}
.ims-anim__svg { display:block; width: 100%; max-width: 520px; height: auto; }


/* Auth layout */
.auth-body {
  position: relative;
  min-height: 100dvh;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 72px 24px;
  background: radial-gradient(1400px 640px at 12% -12%, rgba(255,122,26,.16), transparent),
              radial-gradient(900px 520px at 90% 18%, rgba(38,38,64,.55), transparent),
              var(--bg);
}

.auth-body > * { z-index: 1; }

.auth-backdrop {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(420px 420px at 82% 84%, rgba(255,122,26,.24), transparent),
              radial-gradient(900px 520px at 10% 100%, rgba(62,46,22,.4), transparent);
  opacity: .45;
  z-index: 0;
}

.auth-wrapper {
  position: relative;
  display: grid;
  width: min(1040px, 100%);
  grid-template-columns: minmax(320px, 420px) minmax(320px, 1fr);
  gap: 48px;
  align-items: stretch;
}

.auth-panel {
  padding: 40px 36px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--panel), white 4%), color-mix(in oklab, var(--panel), black 6%));
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 14%);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  display: grid;
  gap: 24px;
}

.auth-header {
  display: flex;
  align-items: center;
  gap: 22px;
}

.auth-header .brand-logo {
  width: 84px;
  height: 84px;
  padding: 10px;
  background: #050505;
  border-radius: 50%;
  box-shadow: 0 12px 30px rgba(224, 27, 36, .3);
}

.brand-logo--auth {
  width: 84px;
  height: 84px;
}

.auth-header h1 {
  margin: 4px 0 0;
  font-size: 28px;
  letter-spacing: .02em;
}

.eyebrow {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 11px;
  color: var(--muted);
}

.auth-copy {
  margin: 0;
  color: color-mix(in oklab, var(--text), white 8%);
  line-height: 1.6;
}

.auth-form {
  display: grid;
  gap: 18px;
}

.form-field {\n  display: grid;\n  gap: 8px;\n  flex: 0 0 calc(50% - 18px);\n  max-width: calc(50% - 18px);\n  min-width: 280px;\n  justify-items: start;\n  text-align: left;\n}\n\n

.form-field label {
  font-weight: 600;
  letter-spacing: .04em;
}

.auth-form .input {
  width: 100%;
  background: color-mix(in oklab, var(--panel), white 3%);
  border-color: color-mix(in oklab, var(--line), var(--brand) 10%);
  padding-inline: 12px;
}

.auth-form .input:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 35%, transparent);
}

.field-error {
  color: var(--bad);
  font-size: 12px;
}

.btn-primary.full,
.btn-ghost.full {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-primary.full {
  padding-block: 12px;
  font-size: 15px;
}

.auth-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  font-size: 13px;
}

.auth-footer .link {
  color: var(--brand-2);
  font-weight: 600;
  text-decoration: none;
}

.auth-footer .link:hover {
  text-decoration: underline;
}

.auth-spotlight {
  align-self: stretch;
  display: grid;
  align-content: center;
  justify-items: center;
}

.spotlight-card {
  padding: 36px;
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--brand) 25%, var(--line));
  background: linear-gradient(145deg, color-mix(in oklab, var(--panel), var(--brand) 10%), rgba(19,19,24,.82));
  box-shadow: var(--shadow);
  max-width: 420px;
}

.spotlight-card h2 {
  margin: 0 0 12px;
  font-size: 24px;
}

.spotlight-card p {
  margin: 0;
  color: color-mix(in oklab, var(--text), white 12%);
  line-height: 1.6;
}

@media (max-width: 960px) {
  .auth-body {
    align-items: flex-start;
    padding: 56px 18px 40px;
  }
  .auth-wrapper {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .auth-panel {
    padding: 32px 24px;
  }
  .auth-spotlight {
    order: -1;
    justify-items: center;
  }
  .spotlight-card {
    max-width: 520px;
    text-align: center;
  }
}

@media (max-width: 540px) {
  .auth-panel {
    padding: 28px 20px;
  }
  .auth-header {
    flex-direction: column;
    align-items: flex-start;
  }
}
/* Inventory enhancements */
.inventory-toolbar {
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.inventory-toolbar form {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.inventory-toolbar__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.column-manager {
  position: relative;
  display: flex;
  align-items: center;
}

.column-manager > .btn-ghost {
  align-self: stretch;
  display: inline-flex;
  align-items: center;
}

.column-panel {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: min(520px, 90vw);
  background: color-mix(in oklab, var(--panel), var(--brand) 6%);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 25%);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: 0 22px 60px rgba(0, 0, 0, .35);
  z-index: 12;
}

.column-panel__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.column-panel__header h3 {
  margin: 0;
  font-size: 17px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.column-panel__hint {
  margin: 4px 0 0;
  color: color-mix(in oklab, var(--muted), white 20%);
  font-size: 13px;
}

.column-panel__close {
  appearance: none;
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 10%);
  background: transparent;
  color: var(--text);
  border-radius: 999px;
  padding: 6px 14px;
  font-size: 12px;
  cursor: pointer;
}

.column-panel__close:hover {
  background: color-mix(in oklab, var(--panel), white 6%);
}

.column-panel__grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
  max-height: 320px;
  overflow-y: auto;
  padding-right: 6px;
}

.column-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: calc(var(--radius) - 6px);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 15%);
  background: color-mix(in oklab, var(--panel), white 8%);
  font-size: 13px;
}

.column-option input {
  width: 16px;
  height: 16px;
  accent-color: var(--brand);
}

.inventory-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.metric-card {
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 20%);
  background: linear-gradient(145deg, color-mix(in oklab, var(--panel), var(--brand) 16%), rgba(19, 19, 24, .78));
  padding: 18px 20px;
  box-shadow: var(--shadow);
  display: grid;
  gap: 6px;
}

.metric-label {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 30%);
}

.metric-value {
  font-size: 28px;
  font-weight: 700;
}

.metric-subtext {
  font-size: 13px;
  color: color-mix(in oklab, var(--muted), white 18%);
}

.inventory-table-card {
  overflow-x: auto;
}

.inventory-table th,
.inventory-table td {
  vertical-align: top;
}

.inventory-table td.right,
.inventory-table th.right {
  text-align: right;
}

.inventory-table td {
  white-space: nowrap;
}

.inventory-table td[data-column="name"],
.inventory-table td[data-column="supplier"],
.inventory-table td[data-column="location"],
.inventory-table td[data-column="tags"],
.inventory-table td[data-column="price_effective_from"],
.inventory-table td[data-column="last_counted_at"],
.inventory-table td[data-column="lot_number"],
.inventory-table td[data-column="expiry_date"],
.inventory-table td[data-column="status"] {
  white-space: normal;
}

.tag-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--brand), var(--panel) 40%);
  color: #fff5eb;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.inventory-pagination {
  justify-content: flex-end;
  margin-top: 18px;
  gap: 12px;
}

.is-col-hidden {
  display: none !important;
}

@media (max-width: 960px) {
  .inventory-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .inventory-toolbar__actions {
    justify-content: flex-start;
  }
  .column-panel {
    position: fixed;
    top: 80px;
    right: 16px;
    left: 16px;
    width: auto;
    max-height: calc(100vh - 120px);
    overflow: auto;
  }
}

@media (max-width: 720px) {
  .inventory-overview {
    grid-template-columns: 1fr;
  }
  .inventory-table td,
  .inventory-table th {
    white-space: normal;
  }
}

.dashboard-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.metric-value .metric-divider {
  margin: 0 6px;
  font-size: 20px;
  color: color-mix(in oklab, var(--muted), white 35%);
}

@media (max-width: 720px) {
  .dashboard-kpis {
    grid-template-columns: 1fr;
  }
}

/* Horizontal KPI layout for Inventory and Dashboard cards */
.inventory-overview .metric-card,
.dashboard-kpis .metric-card,
.detail-kpis .metric-card {
  display: grid;
  grid-template-columns: 1fr auto !important;
  grid-template-rows: auto auto !important;
  align-items: center;
  gap: 4px 12px;
}
.inventory-overview .metric-card .metric-label,
.dashboard-kpis .metric-card .metric-label,
.detail-kpis .metric-card .metric-label {
  grid-column: 1; grid-row: 1;
}
.inventory-overview .metric-card .metric-subtext,
.dashboard-kpis .metric-card .metric-subtext,
.detail-kpis .metric-card .metric-subtext {
  grid-column: 1; grid-row: 2;
}
.inventory-overview .metric-card .metric-value,
.dashboard-kpis .metric-card .metric-value,
.detail-kpis .metric-card .metric-value {
  grid-column: 2 !important; grid-row: 1 / span 2 !important;
  align-self: center;
  justify-self: end;
}

.dashboard-operations {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.operations-card {
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 20%);
  background: linear-gradient(160deg, color-mix(in oklab, var(--panel), var(--brand) 10%), rgba(10, 8, 12, .85));
  box-shadow: var(--shadow);
  padding: 18px 20px;
  display: grid;
  gap: 12px;
}

.operations-card__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.operations-card__header h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.operations-card__meta {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 40%);
}

.operations-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.operations-list__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  border-radius: calc(var(--radius) - 4px);
  background: color-mix(in oklab, var(--panel), white 4%);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 12%);
}

.operations-list__item--empty {
  justify-content: center;
  color: color-mix(in oklab, var(--muted), white 25%);
}

.operations-list__title {
  font-weight: 600;
  display: block;
}

.operations-list__subtitle {
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 30%);
}

.operations-list__meta {
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 45%);
  white-space: nowrap;
}

@media (max-width: 720px) {
  .dashboard-operations {
    grid-template-columns: 1fr;
  }
}


.dashboard-fulfillment {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-bottom: 24px;
}

.fulfillment-card {
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 18%);
  background: linear-gradient(150deg, color-mix(in oklab, var(--panel), var(--brand) 12%), rgba(8, 6, 10, .9));
  box-shadow: var(--shadow);
  padding: 20px 22px;
  display: grid;
  gap: 14px;
}

.fulfillment-card__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.fulfillment-card__header h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.fulfillment-card__meta {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 40%);
}

.fulfillment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.fulfillment-metric {
  padding: 14px;
  border-radius: calc(var(--radius) - 4px);
  background: color-mix(in oklab, var(--panel), white 5%);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 18%);
  display: grid;
  gap: 6px;
}

.fulfillment-metric--accent {
  background: linear-gradient(135deg, var(--brand), color-mix(in oklab, var(--brand), white 20%));
  color: #160a03;
}

.fulfillment-metric--accent .fulfillment-label {
  color: rgba(22, 10, 3, .7);
}

.fulfillment-label {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 35%);
}

.fulfillment-value {
  font-size: 26px;
  font-weight: 700;
}

.fulfillment-helper {
  margin: 0;
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 35%);
}

@media (max-width: 720px) {
  .dashboard-fulfillment {
    grid-template-columns: 1fr;
  }
}


.dashboard-quality {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-bottom: 24px;
}


.dashboard-trends {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-bottom: 24px;
}

.trend-card {
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 18%);
  background: linear-gradient(150deg, color-mix(in oklab, var(--panel), var(--brand) 10%), rgba(10, 8, 12, .88));
  box-shadow: var(--shadow);
  padding: 20px 22px;
  display: grid;
  gap: 14px;
}

.trend-card__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.trend-card__header h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.trend-card__meta {
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 40%);
}

.trend-chart {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(60px, 1fr));
  gap: 10px;
  align-items: end;
}

.trend-chart__item {
  display: grid;
  gap: 6px;
  justify-items: center;
}

.trend-chart__bar {
  width: 100%;
  height: calc(var(--value) * 1.2px + 24px);
  border-radius: 8px 8px 4px 4px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--brand), white 25%), var(--brand));
  box-shadow: 0 6px 14px rgba(255, 122, 26, .25);
}

.trend-chart__label {
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 40%);
}

.trend-chart__value {
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 35%);
}

.trend-chart__empty {
  grid-column: 1 / -1;
  text-align: center;
  color: color-mix(in oklab, var(--muted), white 30%);
}

@media (max-width: 720px) {
  .dashboard-trends {
    grid-template-columns: 1fr;
  }
}



.form-card {
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 18%);
  background: linear-gradient(150deg, color-mix(in oklab, var(--panel), rgba(255,122,26,.08)), rgba(6,6,10,.92));
  box-shadow: var(--shadow);
  padding: 26px 28px;
  display: grid;
  gap: 18px;
}

.form-card--wide {
  max-width: 980px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.form-field {\n  display: grid;\n  gap: 8px;\n  flex: 0 0 calc(50% - 18px);\n  max-width: calc(50% - 18px);\n  min-width: 280px;\n  justify-items: start;\n  text-align: left;\n}\n\n

.form-field label {
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 45%);
}

.form-field .required {
  color: var(--brand);
  margin-left: 4px;
}

.form-input,
.form-select,
.form-textarea,
.form-multiselect {
  width: 100%;
  border-radius: calc(var(--radius) - 6px);
  border: 1px solid color-mix(in oklab, var(--line), var(--brand) 20%);
  background: color-mix(in oklab, var(--panel), white 5%);
  color: var(--text);
  padding: 10px 12px;
  font-size: 14px;
}

.form-select,
.form-multiselect {
  padding-right: 36px;
}

.form-textarea {
  min-height: 100px;
  resize: vertical;
}

/* Improve visibility of date/time picker icons on dark theme */
input[type="date"],
input[type="datetime-local"],
input[type="time"] {
  position: relative;
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 18px 18px;
  padding-right: 36px; /* space for icon */
}

/* Brighten native picker icon in WebKit/Chromium */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(1) sepia(1) saturate(3) hue-rotate(0deg) brightness(1.9) contrast(1.25);
  -webkit-filter: invert(1) sepia(1) saturate(3) hue-rotate(0deg) brightness(1.9) contrast(1.25);
  opacity: .98;
  cursor: pointer;
}

input[type="date"]:hover::-webkit-calendar-picker-indicator,
input[type="datetime-local"]:hover::-webkit-calendar-picker-indicator,
input[type="time"]:hover::-webkit-calendar-picker-indicator {
  filter: invert(1) sepia(1) saturate(3.5) hue-rotate(0deg) brightness(2.1) contrast(1.3);
  -webkit-filter: invert(1) sepia(1) saturate(3.5) hue-rotate(0deg) brightness(2.1) contrast(1.3);
}

/* Fallback icon (e.g., Firefox) using a light brand-tinted SVG */
input[type="date"],
input[type="datetime-local"] {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffd399' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2' ry='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>");
}

input[type="time"] {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffd399' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><polyline points='12 6 12 12 16 14'/></svg>");
}

/* Fallback focus ring for date/time inputs */
input[type="date"]:focus,
input[type="datetime-local"]:focus,
input[type="time"]:focus {
  outline: none;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 30%, transparent);
  border-color: var(--brand);
}

.form-field.has-error .form-input,
.form-field.has-error .form-select,
.form-field.has-error .form-textarea,
.form-field.has-error .form-multiselect {
  border-color: var(--bad);
  box-shadow: 0 0 0 2px rgba(239, 68, 68, .20);
}

.field-error {
  color: var(--bad);
  font-size: 12px;
}

.form-errors {
  border-radius: calc(var(--radius) - 6px);
  border: 1px solid var(--bad);
  background: rgba(239, 68, 68, .15);
  color: var(--bad);
  padding: 12px 16px;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

@media (max-width: 640px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}
.form-section {
  display: grid;
  gap: 14px;
}

.form-section__title {
  margin: 0;
  font-size: 16px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--muted), white 45%);
}

\n

.form-grid--two {\n  display: grid;\n  grid-template-columns: repeat(2, minmax(260px, 1fr));\n  gap: 18px;\n  align-items: start;\n}\n\n\n\n

.span-2 {
  grid-column: span 2;
}

.form-field--checkbox {\n  display: inline-flex;\n  align-items: center;\n  gap: 12px;\n  flex: 0 0 calc(50% - 18px);\n  max-width: calc(50% - 18px);\n  min-width: 280px;\n}\n\n

.form-label--checkbox {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.form-checkbox {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
}

.help-text {
  margin: 0;
  font-size: 12px;
  color: color-mix(in oklab, var(--muted), white 35%);
}


.span-3 {
  grid-column: span 3;
}

.equal-rows {
  align-items: start;
}

\n.form-row {\n  display: flex;\n  flex-wrap: wrap;\n  gap: 18px;\n  justify-content: space-between;\n}\n\n\n.col-span-2 {\n  flex: 0 0 100%;\n  max-width: 100%;\n}\n\n\n\n.form-field--checkbox {\n  display: inline-flex;\n  align-items: center;\n  gap: 12px;\n  flex: 0 0 calc(50% - 18px);\n  max-width: calc(50% - 18px);\n  min-width: 280px;\n}\n\n\n




.form-label-wrap {\n  display: inline-flex;\n  align-items: center;\n  gap: 8px;\n}\n\n.tooltip-icon {\n  display: inline-flex;\n  justify-content: center;\n  align-items: center;\n  width: 18px;\n  height: 18px;\n  border-radius: 50%;\n  font-size: 12px;\n  background: color-mix(in oklab, var(--brand), black 40%);\n  color: #120805;\n}\n\n.form-label-wrap[title] {\n  cursor: help;\n}\n
.form-card--narrow {
  max-width: 540px;
}

.form-action-field {
  display: flex;
  flex: 0 0 auto;
  align-items: flex-end;
  padding-bottom: 4px;
  min-width: 160px;
}

/* Utility: thirds layout for compact rows */
.form-field--third {
  flex: 0 0 calc(33.333% - 18px);
  max-width: calc(33.333% - 18px);
  min-width: 200px;
}

/* Generic right align helper (outside inventory table) */
.right { text-align: right; }

.btn-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: calc(var(--radius) - 6px);
  border: 1px solid color-mix(in oklab, var(--brand), var(--line) 20%);
  background: linear-gradient(135deg, color-mix(in oklab, var(--brand), white 15%), var(--brand));
  color: #160a03;
  font-weight: 600;
  text-decoration: none;
}

.btn-inline:hover {
  filter: brightness(1.05);
}
.detail-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 24px; }
.detail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 18px; }
.detail-grid.detail-grid--with-aside { grid-template-columns: minmax(0, 1.75fr) minmax(0, 1fr); align-items: start; }
@media (max-width: 960px) {
  .detail-grid.detail-grid--with-aside { grid-template-columns: minmax(0, 1fr); }
}
/* Extra vertical separation when stacking detail grids
   Fixes spacing between first grid (Identity/Controls/Audit) and
   the second grid (Recent Restocks/Adjustments) on the details page. */
.detail-grid + .detail-grid { margin-top: 24px; }
.detail-card { border: 1px solid color-mix(in oklab, var(--line), var(--brand) 18%); border-radius: var(--radius); background: linear-gradient(145deg, color-mix(in oklab, var(--panel), var(--brand) 10%), rgba(19,19,24,.86)); box-shadow: var(--shadow); padding: 16px 18px; display: grid; gap: 10px; }
.detail-card.col-2 { grid-column: span 2; }
.detail-title { margin: 0; font-size: 14px; letter-spacing: .14em; text-transform: uppercase; color: color-mix(in oklab, var(--muted), white 45%); }
.detail-card > .detail-title {
  font-size: 13px;
  line-height: 1.2;
  margin-bottom: 6px;
}
.kv { display: grid; gap: 8px; }
.kv > div { display: grid; grid-template-columns: 160px 1fr; gap: 12px; align-items: start; }
.kv dt { margin: 0; font-weight: 600; color: color-mix(in oklab, var(--muted), white 35%); }
.kv dd { margin: 0; }
.inventory-pagination { justify-content: space-between; align-items: center; }
.pager { display: inline-flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.pager .btn-ghost.is-disabled { opacity: .4; pointer-events: none; }
.pager .btn-ghost.is-active {
  background: linear-gradient(135deg, var(--brand), #ff9e3a);
  color: #1d1308;
  border-color: color-mix(in oklab, var(--brand) 60%, var(--line));
  box-shadow: 0 6px 16px rgba(255,122,26,.22);
  pointer-events: none;
}
