/* ════════════════════════════════════════════════════════════════════
   AmigoVet · Закупівлі — Design System v2 (2026)
   "Ops, clean & confident": cool-neutral data ground, deep indigo shell,
   one brand accent, disciplined semantic status scale, dense but legible.
   Single source of truth — tokens drive everything.
   ════════════════════════════════════════════════════════════════════ */

:root {
  color-scheme: light;

  /* ── Layout ── */
  --sidebar-w: 236px;

  /* ── Spacing scale ── */
  --s1: 4px;  --s2: 8px;  --s3: 12px; --s4: 16px;
  --s5: 20px; --s6: 24px; --s7: 32px; --s8: 40px;

  /* ── Radius ── */
  --r-xs: 5px; --r-sm: 7px; --r: 10px; --r-lg: 14px; --r-pill: 999px;

  /* ── Type scale (floor 12px for persistent text) ── */
  --fs-2xs: 11px;   /* numeric chips / dense badges only */
  --fs-xs: 12px;    /* meta, labels */
  --fs-sm: 13px;
  --fs-base: 14px;  /* tables / body default */
  --fs-md: 15px;
  --fs-lg: 17px;
  --fs-xl: 20px;
  --fs-2xl: 24px;   /* page title */
  --fs-3xl: 30px;   /* stat values */
  --lh: 1.5;
  --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'SF Mono', 'JetBrains Mono', 'Consolas', 'Menlo', monospace;

  /* ── Neutral ramp (cool, faint blue tint) ── */
  --gray-50:  #f6f7f9;
  --gray-100: #eef1f5;
  --gray-150: #e6eaf0;
  --gray-200: #dde2ea;
  --gray-300: #c6cdd9;
  --gray-400: #9aa3b2;   /* non-text only (icons, dividers) */
  --gray-500: #6b7280;   /* tertiary text — ~4.6:1 on white */
  --gray-600: #565e6d;
  --gray-700: #3b4252;   /* secondary text */
  --gray-800: #272d3a;
  --gray-900: #161a23;   /* primary ink */

  --bg:        #f4f6f9;
  --surface:   #ffffff;
  --surface-2: #f8fafc;
  --border:    #e3e8ef;
  --border-strong: #d0d7e2;
  --ink:    var(--gray-900);
  --ink-2:  var(--gray-700);
  --ink-3:  var(--gray-500);

  /* ── Brand: indigo-violet ── */
  --brand:        #5a4af0;
  --brand-strong: #4838d6;
  --brand-soft:   #6b5cf5;
  --brand-tint:   #eeebfe;
  --brand-tint-2: #e2ddfd;
  --brand-ink:    #3a2db3;

  /* legacy alias kept so old templates still resolve */
  --blue: var(--brand);

  /* ── Sidebar shell (deep indigo-charcoal) ── */
  --side-bg:      #1b1d2e;
  --side-bg-2:    #23263b;
  --side-ink:     #a7adc4;
  --side-ink-dim: #8b90ab;
  --side-active:  #2c2f49;
  --side-border:  #2c2f44;

  /* ── Semantic colors: {solid, tint, ink-on-tint} ── */
  --success: #16a34a; --success-tint: #e7f6ec; --success-ink: #0f7a37;
  --warning: #d97706; --warning-tint: #fdf0dd; --warning-ink: #9a5808;
  --danger:  #dc2626; --danger-tint:  #fdeaea; --danger-ink:  #b21c1c;
  --info:    #2563eb; --info-tint:    #e6effe; --info-ink:    #1a4fc4;
  --teal:    #0d9488; --teal-tint:    #def5f2; --teal-ink:    #0a6b62;
  --orange:  #ea580c; --orange-tint:  #fdeadf; --orange-ink:  #b6420a;
  --purple:  #9333ea; --purple-tint:  #f4e8fd; --purple-ink:  #7423c0;
  --indigo:  var(--brand); --indigo-tint: var(--brand-tint); --indigo-ink: var(--brand-ink);

  /* green legacy aliases used in templates */
  --green: var(--success);
  --yellow: var(--warning);
  --red: var(--danger);

  /* ── Shadows ── */
  --shadow-xs: 0 1px 2px rgba(22,26,35,.06);
  --shadow-sm: 0 1px 3px rgba(22,26,35,.07), 0 1px 2px rgba(22,26,35,.04);
  --shadow:    0 4px 14px -4px rgba(22,26,35,.12), 0 2px 6px -3px rgba(22,26,35,.08);
  --shadow-lg: 0 18px 44px -12px rgba(27,29,46,.28);
  --ring: 0 0 0 3px rgba(90,74,240,.22);

  /* ── z-index scale (coordinated with Bootstrap 1020-1090) ── */
  --z-overlay: 1030;
  --z-sidebar: 1035;
  --z-hamburger: 1040;
  --z-dropdown: 1000;
  --z-sticky: 1010;
  --z-toast: 1085;
  --z-tooltip: 1090;

  --transition: 140ms cubic-bezier(.4,.2,.2,1);
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  line-height: var(--lh);
  background: var(--bg);
  color: var(--ink);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--brand-tint-2); color: var(--brand-ink); }

a { color: var(--brand); text-decoration-color: color-mix(in srgb, var(--brand) 35%, transparent); text-underline-offset: 2px; }
a:hover { color: var(--brand-strong); }

/* ════════ Global focus ring (a11y) ════════ */
:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  border-radius: var(--r-xs);
}
*:focus:not(:focus-visible) { outline: none; }

/* skip link */
.skip-link {
  position: fixed; top: -60px; left: 12px; z-index: var(--z-tooltip);
  background: var(--surface); color: var(--ink);
  padding: 10px 16px; border-radius: var(--r-sm); box-shadow: var(--shadow);
  transition: top var(--transition);
}
.skip-link:focus { top: 12px; }

/* ════════════════════════ SIDEBAR ════════════════════════ */
.sidebar {
  position: fixed; top: 0; left: 0;
  width: var(--sidebar-w); height: 100vh;
  background: linear-gradient(180deg, var(--side-bg-2) 0%, var(--side-bg) 100%);
  color: var(--side-ink);
  overflow-y: auto;
  z-index: var(--z-sidebar);
  transition: transform .26s cubic-bezier(.4,.2,.2,1);
  border-right: 1px solid var(--side-border);
  scrollbar-width: thin; scrollbar-color: var(--side-active) transparent;
}
.sidebar::-webkit-scrollbar { width: 7px; }
.sidebar::-webkit-scrollbar-thumb { background: var(--side-active); border-radius: 99px; }

.sidebar .brand {
  display: flex; align-items: center; gap: 11px;
  padding: 20px 20px 18px;
  border-bottom: 1px solid var(--side-border);
}
.sidebar .brand .brand-mark {
  width: 38px; height: 38px; flex-shrink: 0;
  border-radius: 9px; overflow: hidden;
  box-shadow: 0 2px 8px -2px rgba(0,0,0,.35);
}
.sidebar .brand .brand-mark img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sidebar .brand h5 { color: #fff; margin: 0; font-size: 16px; font-weight: 700; letter-spacing: -.01em; line-height: 1.1; }
.sidebar .brand small { font-size: 11.5px; color: var(--side-ink-dim); letter-spacing: .02em; }

.sidebar nav {
  display: flex; flex-direction: column;
  min-height: calc(100vh - 73px);
  padding: 10px 10px 16px;
  gap: 1px;
}
.sidebar nav a {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 12px;
  color: var(--side-ink);
  text-decoration: none;
  font-size: var(--fs-sm); font-weight: 500;
  border-radius: var(--r-sm);
  transition: background var(--transition), color var(--transition);
  position: relative;
}
.sidebar nav a:hover { background: var(--side-active); color: #eef0f8; }
.sidebar nav a.active {
  background: var(--side-active);
  color: #fff; font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.sidebar nav a.active::before {
  content: ""; position: absolute; left: -10px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 18px; border-radius: 0 3px 3px 0; background: var(--brand-soft);
}
.sidebar nav a i { font-size: 17px; width: 22px; text-align: center; flex-shrink: 0; opacity: .9; }
.sidebar nav a.active i { opacity: 1; color: var(--brand-soft); }
.sidebar nav a:focus-visible { outline: 2px solid var(--brand-soft); outline-offset: -2px; }
.sidebar nav .nav-logout { margin-top: auto; color: var(--side-ink-dim); }
.sidebar nav .nav-logout:hover { color: #fde2e2; background: rgba(220,38,38,.16); }

/* ════════════════════════ MAIN ════════════════════════ */
.main-content {
  margin-left: var(--sidebar-w);
  padding: var(--s7) var(--s7) var(--s8);
  min-height: 100vh;
  max-width: 1480px;
}

/* ════════════════════════ HAMBURGER ════════════════════════ */
.hamburger {
  display: none;
  position: fixed; top: 12px; left: 12px; z-index: var(--z-hamburger);
  background: var(--side-bg); color: #fff; border: 1px solid var(--side-border);
  border-radius: var(--r-sm); width: 42px; height: 42px;
  font-size: 20px; cursor: pointer; line-height: 1;
  box-shadow: var(--shadow-sm);
}
.sidebar-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(15,18,30,.5); backdrop-filter: blur(2px);
  z-index: var(--z-overlay);
}

/* ════════════════════════ PAGE HEADER ════════════════════════ */
.page-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s3) var(--s4); flex-wrap: wrap;
  margin-bottom: var(--s5);
}
.page-header h1 {
  font-size: var(--fs-2xl); font-weight: 750; margin: 0;
  color: var(--ink); letter-spacing: -.02em; line-height: 1.15;
  display: flex; align-items: center; gap: var(--s2);
  text-wrap: balance;
}
.page-header h1 .count-note { font-size: var(--fs-sm); font-weight: 500; color: var(--ink-3); }
.page-header .header-actions { display: flex; align-items: center; gap: var(--s2); flex-wrap: wrap; }
.page-subtitle { color: var(--ink-3); font-size: var(--fs-sm); margin: -8px 0 var(--s5); }

/* ════════════════════════ CARDS ════════════════════════ */
.card {
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  border-radius: var(--r-lg);
  background: var(--surface);
  overflow: clip;
}
.card-header {
  background: transparent;
  font-size: var(--fs-base); font-weight: 650;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  color: var(--ink); letter-spacing: -.01em;
  display: flex; align-items: center; gap: var(--s2);
}
.card-body { padding: 18px; }

/* ════════════════════════ TABLES ════════════════════════ */
.table { font-size: var(--fs-base); margin-bottom: 0; color: var(--ink); border-color: var(--border); }
.table thead th {
  font-weight: 650;
  color: var(--ink-2);
  font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .04em;
  white-space: nowrap;
  padding: 11px 16px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border-strong);
  position: sticky; top: 0; z-index: 1;
}
.table tbody td { vertical-align: middle; padding: 11px 16px; border-color: var(--border); }
.table tbody tr { transition: background var(--transition); }
.table-hover tbody tr:hover { background: var(--brand-tint); }
.table tbody tr[onclick], .table tbody tr.row-link { cursor: pointer; }
.table tbody tr:last-child td { border-bottom: 0; }
.num, .table .num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.table-dense thead th { padding: 8px 12px; }
.table-dense tbody td { padding: 7px 12px; }

/* primary cell (the load-bearing name column) */
.cell-title { font-size: var(--fs-base); font-weight: 600; color: var(--ink); line-height: 1.35; }
.cell-sub { font-size: var(--fs-xs); color: var(--ink-3); line-height: 1.3; }
.cell-truncate { max-width: 340px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: block; }

/* legacy: make .text-truncate-custom actually truncate, legibly */
.text-truncate-custom {
  font-size: var(--fs-sm); line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}

.table .total-row td {
  font-weight: 700; border-top: 2px solid var(--border-strong);
  font-size: var(--fs-base); background: var(--surface-2);
}

/* ════════════════════════ BUTTONS ════════════════════════ */
.btn {
  --bs-btn-focus-box-shadow: none;
  font-size: var(--fs-base); font-weight: 550;
  padding: 8px 16px; border-radius: var(--r-sm);
  transition: background var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition), transform var(--transition);
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  line-height: 1.2; white-space: nowrap;
}
.btn:active { transform: translateY(.5px); }
.btn:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }
.btn-sm { font-size: var(--fs-sm); padding: 6px 12px; border-radius: var(--r-xs); gap: 5px; }
.btn-xs { font-size: var(--fs-xs); padding: 4px 9px; border-radius: var(--r-xs); gap: 4px; }
.btn-lg { font-size: var(--fs-md); padding: 11px 22px; }
.btn:disabled, .btn.is-loading { opacity: .55; pointer-events: none; }

.btn-primary { background: var(--brand); border-color: var(--brand); color: #fff; box-shadow: 0 1px 2px rgba(72,56,214,.25); }
.btn-primary:hover { background: var(--brand-strong); border-color: var(--brand-strong); color: #fff; box-shadow: 0 4px 12px -3px rgba(72,56,214,.5); }
.btn-primary:active { background: var(--brand-strong); }

.btn-dark { background: var(--gray-900); border-color: var(--gray-900); color: #fff; }
.btn-dark:hover { background: #000; border-color: #000; color: #fff; }

.btn-success { background: var(--success); border-color: var(--success); color: #fff; }
.btn-success:hover { background: var(--success-ink); border-color: var(--success-ink); color: #fff; }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-danger:hover { background: var(--danger-ink); border-color: var(--danger-ink); color: #fff; }
.btn-warning { background: var(--warning); border-color: var(--warning); color: #fff; }
.btn-warning:hover { background: var(--warning-ink); border-color: var(--warning-ink); color: #fff; }
.btn-info { background: var(--info); border-color: var(--info); color: #fff; }
.btn-info:hover { background: var(--info-ink); border-color: var(--info-ink); color: #fff; }

/* outlines — quiet, neutral by default */
.btn-outline-secondary { color: var(--ink-2); border-color: var(--border-strong); background: var(--surface); }
.btn-outline-secondary:hover { background: var(--gray-100); color: var(--ink); border-color: var(--gray-300); }
.btn-outline-primary { color: var(--brand); border-color: color-mix(in srgb, var(--brand) 45%, transparent); background: var(--surface); }
.btn-outline-primary:hover { background: var(--brand); color: #fff; border-color: var(--brand); }
.btn-outline-danger { color: var(--danger); border-color: color-mix(in srgb, var(--danger) 40%, transparent); background: var(--surface); }
.btn-outline-danger:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-outline-success { color: var(--success-ink); border-color: color-mix(in srgb, var(--success) 45%, transparent); background: var(--surface); }
.btn-outline-success:hover { background: var(--success); color: #fff; border-color: var(--success); }
.btn-outline-warning { color: var(--warning-ink); border-color: color-mix(in srgb, var(--warning) 50%, transparent); background: var(--surface); }
.btn-outline-warning:hover { background: var(--warning); color: #fff; border-color: var(--warning); }
.btn-outline-dark { color: var(--ink); border-color: var(--border-strong); background: var(--surface); }
.btn-outline-dark:hover { background: var(--gray-900); color: #fff; border-color: var(--gray-900); }

/* ghost / icon-only */
.btn-ghost { background: transparent; border-color: transparent; color: var(--ink-2); }
.btn-ghost:hover { background: var(--gray-100); color: var(--ink); }

/* ════════════════════════ BADGES & PILLS ════════════════════════ */
.badge {
  font-size: var(--fs-xs); font-weight: 600;
  padding: 4px 9px; border-radius: var(--r-xs);
  letter-spacing: 0; line-height: 1.3;
}

/* status pill — the canonical order/state indicator */
.status-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--fs-xs); font-weight: 600; line-height: 1.2;
  padding: 4px 10px 4px 8px; border-radius: var(--r-pill);
  white-space: nowrap; border: 1px solid transparent;
}
.status-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; flex-shrink: 0; }
.status-pill i { font-size: 12px; }
.status--draft     { background: var(--gray-100);   color: var(--gray-700);   border-color: var(--gray-200); }
.status--sent      { background: var(--info-tint);  color: var(--info-ink); }
.status--progress  { background: var(--brand-tint); color: var(--brand-ink); }
.status--processed { background: var(--teal-tint);  color: var(--teal-ink); }
.status--awaiting  { background: var(--warning-tint);color: var(--warning-ink); }
.status--received  { background: var(--success-tint);color: var(--success-ink); }
.status--cancelled { background: var(--gray-100);   color: var(--gray-500); text-decoration: line-through; text-decoration-thickness: 1px; }

/* generic soft pills */
.pill { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-xs); font-weight: 600; padding: 3px 9px; border-radius: var(--r-pill); border: 1px solid transparent; }
.pill-success { background: var(--success-tint); color: var(--success-ink); }
.pill-warning { background: var(--warning-tint); color: var(--warning-ink); }
.pill-danger  { background: var(--danger-tint);  color: var(--danger-ink); }
.pill-info    { background: var(--info-tint);    color: var(--info-ink); }
.pill-brand   { background: var(--brand-tint);   color: var(--brand-ink); }
.pill-muted   { background: var(--gray-100);     color: var(--gray-600); }
.pill-purple  { background: var(--purple-tint);   color: var(--purple-ink); }

/* bootstrap bg-* overrides → tinted, readable */
.badge.bg-warning, .bg-warning { background-color: var(--warning) !important; }
.badge.bg-success { background-color: var(--success) !important; }
.badge.bg-danger  { background-color: var(--danger) !important; }
.badge.bg-info    { background-color: var(--info) !important; color: #fff !important; }
.badge.bg-primary { background-color: var(--brand) !important; }
.badge.bg-secondary { background-color: var(--gray-500) !important; }
.bg-indigo  { background-color: var(--brand) !important; color: #fff; }
.bg-purple  { background-color: var(--purple) !important; color: #fff; }
.text-indigo { color: var(--brand) !important; }
.text-purple { color: var(--purple) !important; }

/* count chip (sidebar / header notification numbers) */
.count-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--fs-xs); font-weight: 650; padding: 5px 11px;
  border-radius: var(--r-pill); text-decoration: none; line-height: 1;
  border: 1px solid transparent; transition: all var(--transition);
}
.count-chip:hover { filter: brightness(.97); transform: translateY(-1px); }
.count-chip.warn  { background: var(--warning-tint); color: var(--warning-ink); border-color: color-mix(in srgb,var(--warning) 25%,transparent); }
.count-chip.info  { background: var(--info-tint);    color: var(--info-ink);    border-color: color-mix(in srgb,var(--info) 22%,transparent); }
.count-chip.danger{ background: var(--danger-tint);  color: var(--danger-ink);  border-color: color-mix(in srgb,var(--danger) 25%,transparent); }

/* ════════════════════════ STAT CARDS ════════════════════════ */
.stat-card { transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition); }
.stat-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); border-color: var(--border-strong); }
.stat-card a { text-decoration: none; color: inherit; display: block; }
.stat-card .stat-value { font-size: var(--fs-3xl); font-weight: 800; line-height: 1.1; letter-spacing: -.025em; font-variant-numeric: tabular-nums; }
.stat-card .stat-label { font-size: var(--fs-xs); color: var(--ink-3); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 5px; font-weight: 600; }

/* ════════════════════════ FORMS ════════════════════════ */
.form-control, .form-select {
  font-size: var(--fs-base); padding: 8px 12px;
  border-radius: var(--r-sm); border: 1px solid var(--border-strong);
  color: var(--ink); background-color: var(--surface);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-control::placeholder { color: var(--gray-400); }
.form-control:focus, .form-select:focus { border-color: var(--brand); box-shadow: var(--ring); }
.form-control-sm, .form-select-sm { font-size: var(--fs-sm); padding: 6px 10px; border-radius: var(--r-xs); }
/* keep room for the dropdown caret (our padding override removed Bootstrap's) */
.form-select { padding-right: 2.1rem; background-position: right .65rem center; }
.form-select-sm { padding-right: 1.9rem; background-position: right .55rem center; }
.form-label { font-size: var(--fs-xs); color: var(--ink-2); margin-bottom: 5px; font-weight: 600; }
.form-check-input:checked { background-color: var(--brand); border-color: var(--brand); }
.form-check-input:focus { border-color: var(--brand); box-shadow: var(--ring); }

/* styled file input (kills the raw "Choose file / No file chosen") */
input[type="file"].form-control { padding: 0; overflow: hidden; }
input[type="file"].form-control::file-selector-button {
  margin-right: 12px; padding: 8px 14px; border: 0;
  background: var(--gray-100); color: var(--ink-2);
  font-weight: 600; font-size: var(--fs-sm); cursor: pointer;
  border-right: 1px solid var(--border-strong);
  transition: background var(--transition);
}
input[type="file"].form-control:hover::file-selector-button { background: var(--gray-150); color: var(--ink); }

/* search input with leading icon */
.search-inline { position: relative; }
.search-inline > i { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); font-size: 13px; color: var(--gray-400); pointer-events: none; }
.search-inline > input { padding-left: 32px; }

/* compact numeric cell input (tables) */
.cell-input { width: 72px; text-align: center; font-variant-numeric: tabular-nums; }

/* filter / toolbar bar */
.filter-bar {
  display: flex; align-items: center; gap: var(--s2); flex-wrap: wrap;
  padding: 10px 12px; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); box-shadow: var(--shadow-xs);
}

/* segmented control (for status filter rows) */
.segmented { display: inline-flex; flex-wrap: wrap; gap: 4px; background: var(--gray-100); padding: 4px; border-radius: var(--r); }
.segmented a {
  font-size: var(--fs-sm); font-weight: 550; padding: 6px 12px; border-radius: var(--r-xs);
  color: var(--ink-2); text-decoration: none; transition: all var(--transition); white-space: nowrap;
  display: inline-flex; align-items: center; gap: 5px;
}
.segmented a:hover { background: var(--surface); color: var(--ink); }
.segmented a.active { background: var(--surface); color: var(--brand); box-shadow: var(--shadow-xs); font-weight: 650; }

/* ════════════════════════ MONO ════════════════════════ */
.mono { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--ink-2); }

/* ════════════════════════ ACTION ICONS ════════════════════════ */
.action-icon {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--gray-500); font-size: 16px; width: 30px; height: 30px;
  border-radius: var(--r-xs); transition: all var(--transition); text-decoration: none;
}
.action-icon:hover { color: var(--brand); background: var(--brand-tint); }
.action-icon:focus-visible { outline: 2px solid var(--brand); outline-offset: 1px; }

/* ════════════════════════ EMPTY STATE ════════════════════════ */
.empty-state { text-align: center; padding: 48px 24px; color: var(--ink-3); }
.empty-state .es-icon { font-size: 34px; color: var(--gray-300); margin-bottom: 12px; display: block; }
.empty-state .es-title { font-size: var(--fs-md); font-weight: 600; color: var(--ink-2); margin-bottom: 4px; }
.empty-state .es-text { font-size: var(--fs-sm); color: var(--ink-3); max-width: 380px; margin: 0 auto 14px; }
td .empty-state { padding: 36px 16px; }

/* ════════════════════════ SKELETON ════════════════════════ */
.skeleton { background: linear-gradient(90deg, var(--gray-100) 25%, var(--gray-150) 37%, var(--gray-100) 63%); background-size: 400% 100%; animation: shimmer 1.3s ease infinite; border-radius: var(--r-xs); }
@keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ════════════════════════ COPYABLE ════════════════════════ */
.copyable { cursor: pointer; position: relative; transition: background var(--transition); border-radius: 0 0 var(--r-lg) var(--r-lg); }
.copyable:hover { background: var(--brand-tint); }
.copyable:active { background: var(--brand-tint-2); }
.copyable:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.copy-toast {
  display: none; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--gray-900); color: #fff; font-size: var(--fs-base); font-weight: 600;
  padding: 10px 24px; border-radius: var(--r-sm); pointer-events: none; box-shadow: var(--shadow);
}
.copyable.copied .copy-toast { display: block; animation: toastFade 1.2s ease forwards; }
.copyable.copied pre { opacity: .25; }
@keyframes toastFade { 0%, 70% { opacity: 1; } 100% { opacity: 0; } }

/* ════════════════════════ SEARCH (legacy) ════════════════════════ */
.table-search { max-width: 320px; margin-bottom: 14px; }

/* ════════════════════════ FLASH / ALERTS ════════════════════════ */
.alert { font-size: var(--fs-base); border-radius: var(--r); border: 1px solid transparent; padding: 12px 16px; }
.alert-success { background: var(--success-tint); color: var(--success-ink); border-color: color-mix(in srgb,var(--success) 25%,transparent); }
.alert-danger  { background: var(--danger-tint);  color: var(--danger-ink);  border-color: color-mix(in srgb,var(--danger) 25%,transparent); }
.alert-warning { background: var(--warning-tint); color: var(--warning-ink); border-color: color-mix(in srgb,var(--warning) 25%,transparent); }
.alert-info    { background: var(--info-tint);    color: var(--info-ink);    border-color: color-mix(in srgb,var(--info) 22%,transparent); }
.flash-msg {
  position: fixed; top: 18px; right: 18px; left: auto; z-index: var(--z-toast);
  min-width: 280px; max-width: 420px;
  box-shadow: var(--shadow-lg);
  animation: flashIn .3s cubic-bezier(.2,.8,.2,1), flashFade 4s ease forwards;
}
@keyframes flashIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: none; } }
@keyframes flashFade { 0%, 80% { opacity: 1; } 100% { opacity: 0; transform: translateX(20px); } }

/* ════════════════════════ SPIN ════════════════════════ */
.spin { animation: spin .6s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ════════════════════════ CONTACT ICONS ════════════════════════ */
.contact-icons { display: inline-flex; align-items: center; gap: 2px; }
.contact-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: var(--r-xs); font-size: 15px;
  text-decoration: none !important; border: none; background: none; padding: 0;
  cursor: pointer; transition: background var(--transition);
}
.contact-icon:focus-visible { outline: 2px solid var(--brand); outline-offset: 1px; }
.contact-viber       { color: #7360f2; } .contact-viber:hover    { background: #ede9fe; }
.contact-telegram    { color: #229ed9; } .contact-telegram:hover { background: #e0f2fe; }
.contact-phone       { color: var(--success); } .contact-phone:hover { background: var(--success-tint); }
.contact-b2b         { color: var(--warning); } .contact-b2b:hover   { background: var(--warning-tint); }
.contact-email       { color: var(--danger); }  .contact-email:hover { background: var(--danger-tint); }
.contact-link        { color: var(--brand); }   .contact-link:hover  { background: var(--brand-tint); }
.contact-edit {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; font-size: 11px; color: var(--gray-400);
  opacity: 0; cursor: pointer; border-radius: var(--r-xs); border: 0; background: none;
  transition: opacity var(--transition), color var(--transition);
}
.contact-icons:hover .contact-edit { opacity: .55; }
.contact-edit:hover, .contact-edit:focus-visible { opacity: 1 !important; color: var(--ink-2); }

/* ════════════════════════ DRAG & DROP ════════════════════════ */
.drag-handle { cursor: grab; color: var(--gray-400); user-select: none; }
.drag-handle:hover { color: var(--ink-3); }
.drag-handle:active { cursor: grabbing; }
.sortable-ghost { background: var(--brand-tint) !important; opacity: .7; }

/* ════════════════════════ MODALS ════════════════════════ */
.modal-content { border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); }
.modal-header { border-bottom: 1px solid var(--border); }
.modal-footer { border-top: 1px solid var(--border); }

/* ════════════════════════ MISC UTIL ════════════════════════ */
.text-muted { color: var(--ink-3) !important; }
hr { border-color: var(--border); opacity: 1; }
.vr { background: var(--border-strong); opacity: 1; }
.pagination-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); margin-top: var(--s3); font-size: var(--fs-sm); color: var(--ink-3); }

/* ════════════════════════ MOBILE ════════════════════════ */
@media (max-width: 992px) {
  .main-content { max-width: none; }
}
@media (max-width: 768px) {
  .hamburger { display: flex; align-items: center; justify-content: center; }
  .sidebar { transform: translateX(-100%); box-shadow: var(--shadow-lg); }
  .sidebar.open { transform: translateX(0); }
  .sidebar-overlay.open { display: block; }
  .main-content { margin-left: 0; padding: 64px var(--s4) var(--s6); }
  .page-header h1 { font-size: var(--fs-xl); }
  .stat-card .stat-value { font-size: var(--fs-2xl); }
  .table { font-size: var(--fs-sm); }
  .table thead th, .table tbody td { padding: 9px 11px; }
  .table-search { max-width: 100%; }
  .card-header { padding: 12px 14px; }
  .cell-truncate { max-width: 200px; }
  /* bigger touch targets for inline numeric inputs on phones */
  .cell-input { min-height: 42px; width: 64px; }
  .form-control-sm, .form-select-sm { padding-top: 9px; padding-bottom: 9px; }
}

/* ════════════════════════ REDUCED MOTION ════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important; animation-iteration-count: 1 !important;
    transition-duration: .001ms !important; scroll-behavior: auto !important;
  }
  .sidebar { transition: none; }
}

/* ════════════════════════ PRINT ════════════════════════ */
@media print {
  .sidebar, .hamburger, .sidebar-overlay, .no-print { display: none !important; }
  .main-content { margin-left: 0; padding: 0; max-width: none; }
  .card { box-shadow: none; border-color: #ccc; }
}
