/* ============================================================
   admin.css — Административная панель ShinLite
   Mobile-first. Переиспользует токены /css/variables.css.
   ============================================================ */

*,
*::before,
*::after {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

:focus-visible { outline: 2px solid var(--clr-accent); outline-offset: 2px; }
:focus:not(:focus-visible) { outline: none; }

/* ---- Плавный переход при смене темы ---- */
html.color-transition *,
html.color-transition *::before,
html.color-transition *::after {
  transition:
    background-color 250ms ease,
    color 250ms ease,
    border-color 250ms ease,
    box-shadow 250ms ease !important;
}

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-primary);
  color: var(--clr-text-primary);
  background: var(--clr-bg-primary);
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ---- Утилиты ---- */
.is-hidden { display: none !important; }
.spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--clr-border);
  border-top-color: var(--clr-accent);
  border-radius: var(--r-full);
  animation: spin .7s linear infinite;
  margin: var(--sp-8) auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

.muted { color: var(--clr-text-muted); }
.error-banner {
  background: var(--clr-danger-bg);
  border: 1px solid var(--clr-danger-border);
  color: var(--clr-danger-text);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
}

/* ============================================================
   LOGIN
   ============================================================ */
.login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--sp-4);
  background: var(--gradient-hero);
}
.login-card {
  width: 100%;
  max-width: 400px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-2xl);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-8) var(--sp-6);
}
.login-card__brand {
  text-align: center;
  margin-bottom: var(--sp-6);
}
.login-card__logo {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: var(--fs-2xl);
  color: var(--clr-accent);
  letter-spacing: -0.02em;
}
.login-card__sub {
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
  margin-top: var(--sp-1);
}

.field { margin-bottom: var(--sp-4); }
.field label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-2);
  color: var(--clr-text-secondary);
}
.field input[type="text"],
.field input[type="password"] {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast);
}
.field input:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}
.field--check {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.field--check label { margin: 0; cursor: pointer; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  border: 1px solid transparent;
  border-radius: var(--r-md);
  transition: background var(--t-fast), transform var(--t-fast);
}
.btn:active { transform: translateY(1px); }
.btn--primary {
  background: var(--clr-accent);
  color: var(--clr-text-inverse);
  width: 100%;
}
.btn--primary:hover { background: var(--clr-accent-hover); }
.btn--primary:disabled { opacity: .6; cursor: not-allowed; }
.btn--ghost {
  background: transparent;
  border-color: var(--clr-border);
  color: var(--clr-text-secondary);
}
.btn--ghost:hover { border-color: var(--clr-border-hover); }
.btn--sm { padding: var(--sp-2) var(--sp-3); font-size: var(--fs-sm); }

/* ============================================================
   APP SHELL (sidebar + main)
   ============================================================ */
.shell { min-height: 100vh; }

.topbar {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  height: 60px;
  padding: 0 var(--sp-4);
  background: var(--clr-bg-secondary);
  border-bottom: 1px solid var(--clr-border);
}
.topbar__burger {
  display: inline-flex;
  background: transparent;
  border: none;
  font-size: var(--fs-xl);
  color: var(--clr-text-primary);
  padding: var(--sp-2);
  line-height: 1;
}
.topbar__title {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
}
.topbar__spacer { flex: 1; }
.topbar__user {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.topbar__user b { color: var(--clr-text-primary); }

.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 240px;
  background: var(--clr-bg-secondary);
  border-right: 1px solid var(--clr-border);
  transform: translateX(-100%);
  transition: transform var(--t-normal);
  z-index: var(--z-modal);
  display: flex;
  flex-direction: column;
  padding: var(--sp-4);
}
.sidebar.is-open { transform: translateX(0); }
.sidebar__brand {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: var(--fs-xl);
  color: var(--clr-accent);
  padding: var(--sp-2) var(--sp-2) var(--sp-6);
  letter-spacing: -0.02em;
}
.sidebar__brand span { color: var(--clr-text-muted); font-weight: var(--fw-medium); font-size: var(--fs-xs); display: block; }
.nav { display: flex; flex-direction: column; gap: var(--sp-1); }
.nav a {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  border-radius: var(--r-md);
  color: var(--clr-text-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  transition: background var(--t-fast), color var(--t-fast);
}
.nav a:hover { background: var(--clr-bg-elevated); color: var(--clr-text-primary); }
.nav a.is-active { background: var(--clr-accent-glow); color: var(--clr-accent); }
.nav a .ico { width: 20px; text-align: center; }
.nav__tag {
  margin-left: auto;
  font-size: 10px;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-full);
  padding: 1px 6px;
}
.sidebar__foot { margin-top: auto; padding-top: var(--sp-4); }

.scrim {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-normal);
  z-index: var(--z-overlay);
}
.scrim.is-open { opacity: 1; pointer-events: auto; }

.main {
  padding: var(--sp-5) var(--sp-4);
  max-width: var(--max-width);
  margin: 0 auto;
}
.page-head {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.page-head h1 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: 0;
}

/* ============================================================
   DASHBOARD — stat cards
   ============================================================ */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}
@media (min-width: 768px) {
  .stats-grid { grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
}
.stat-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.stat-card__label {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-2);
}
.stat-card__value {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-bold);
  line-height: 1;
}
.stat-card--accent .stat-card__value  { color: var(--clr-accent); }
.stat-card--success .stat-card__value { color: var(--clr-success-dark); }
.stat-card--info .stat-card__value    { color: var(--clr-info-text); }
.stat-card--warn .stat-card__value    { color: var(--clr-warning-text); }

/* ============================================================
   TABLES / LISTS
   ============================================================ */
.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.toolbar select,
.toolbar input {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  font-size: var(--fs-sm);
}

.card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.table-wrap { overflow-x: auto; }
table.data {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  min-width: 600px;
}
table.data th {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-secondary);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  border-bottom: 1px solid var(--clr-border);
}
table.data td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
  vertical-align: middle;
}
table.data tr:last-child td { border-bottom: none; }
table.data tbody tr { transition: background var(--t-fast); }
table.data tbody tr:hover { background: var(--clr-bg-elevated); cursor: pointer; }
.num { text-align: right; font-variant-numeric: tabular-nums; }
.mono { font-variant-numeric: tabular-nums; }

/* ---- Status badges ---- */
.badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  border: 1px solid transparent;
}
.badge.st-new        { background: var(--clr-info-bg);    color: var(--clr-info-text);    border-color: var(--clr-info-border); }
.badge.st-processing { background: var(--clr-warning-bg); color: var(--clr-warning-text); border-color: var(--clr-warning-border); }
.badge.st-delivered  { background: var(--clr-success-bg); color: var(--clr-success-text); border-color: var(--clr-success-border); }
.badge.st-cancelled  { background: var(--clr-danger-bg);  color: var(--clr-danger-text);  border-color: var(--clr-danger-border); }
.badge.in-stock      { background: var(--clr-success-bg); color: var(--clr-success-text); border-color: var(--clr-success-border); }
.badge.out-stock     { background: var(--clr-danger-bg);  color: var(--clr-danger-text);  border-color: var(--clr-danger-border); }
.badge--delivery     { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; font-size: 11px; }
.badge--pickup       { background: #f0fdf4; color: #15803d; border-color: #bbf7d0; font-size: 11px; }

.pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
}

/* ============================================================
   MODAL (order detail)
   ============================================================ */
.modal-scrim {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  display: grid;
  place-items: center;
  padding: var(--sp-4);
  z-index: var(--z-modal);
}
.modal {
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--clr-bg-card);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-xl);
  padding: var(--sp-6);
}
.modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.modal__head h2 { margin: 0; font-size: var(--fs-xl); font-family: var(--font-display); }
.modal__close {
  background: transparent;
  border: none;
  font-size: var(--fs-xl);
  color: var(--clr-text-muted);
  line-height: 1;
}
.kv { display: grid; grid-template-columns: 130px 1fr; gap: var(--sp-2) var(--sp-3); font-size: var(--fs-sm); margin-bottom: var(--sp-4); }
.kv dt { color: var(--clr-text-muted); }
.kv dd { margin: 0; }

.items-list { border-top: 1px solid var(--clr-border); margin-top: var(--sp-2); }
.items-list .row {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
.items-list .row .name { flex: 1; }
.total-row {
  display: flex;
  justify-content: space-between;
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  padding-top: var(--sp-3);
}

.status-changer {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
}
.status-changer select {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
}

/* ---- Empty state ---- */
.empty {
  text-align: center;
  padding: var(--sp-12) var(--sp-4);
  color: var(--clr-text-muted);
}
.empty .ico { font-size: var(--fs-4xl); margin-bottom: var(--sp-3); }

/* ---- Stub section ---- */
.stub {
  text-align: center;
  padding: var(--sp-16) var(--sp-4);
  background: var(--clr-bg-card);
  border: 1px dashed var(--clr-border-hover);
  border-radius: var(--r-lg);
  color: var(--clr-text-muted);
}
.stub .ico { font-size: var(--fs-5xl); margin-bottom: var(--sp-4); }
.stub h2 { color: var(--clr-text-secondary); margin: 0 0 var(--sp-2); }

/* ============================================================
   LOGIN — password show/hide
   ============================================================ */
.password-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.password-wrap input {
  width: 100%;
  padding-right: var(--sp-10) !important;
}
.password-toggle {
  position: absolute;
  right: var(--sp-3);
  background: transparent;
  border: none;
  font-size: var(--fs-md);
  color: var(--clr-text-muted);
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
.password-toggle:hover { color: var(--clr-text-secondary); }

/* ============================================================
   SETTINGS FORM
   ============================================================ */
.settings-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.settings-section {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-6);
  box-shadow: var(--shadow-sm);
}
.settings-section__title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  margin: 0 0 var(--sp-4);
  color: var(--clr-text-primary);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--clr-border);
}
.settings-section__hint {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin: calc(-1 * var(--sp-2)) 0 var(--sp-4);
}

.settings-grid {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .settings-grid { grid-template-columns: repeat(2, 1fr); }
}
.settings-grid--narrow {
  grid-template-columns: 1fr !important;
  max-width: 340px;
}

.field input[type="email"],
.field input[type="tel"],
.field input[type="number"] {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast);
}
.field input[type="email"]:focus,
.field input[type="tel"]:focus,
.field input[type="number"]:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}
.field__hint {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
}

.settings-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}
.btn--save { width: auto; }

.settings-msg {
  font-size: var(--fs-sm);
}
.settings-msg--ok { color: var(--clr-success-dark); }
.settings-msg--err { color: var(--clr-danger-text); }

/* ============================================================
   DASHBOARD — stat card link
   ============================================================ */
.stat-card__link {
  display: inline-block;
  margin-top: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-info-text);
  text-decoration: none;
}
.stat-card__link:hover { text-decoration: underline; }

.stat-card__badge {
  display: inline-block;
  margin-top: var(--sp-2);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: var(--r-full);
  background: var(--clr-warning-bg);
  color: var(--clr-warning-text);
  border: 1px solid var(--clr-warning-border);
}
.stat-card__badge--urgent {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}

/* ============================================================
   BLOCK SCREEN (экран блокировки при превышении попыток входа)
   ============================================================ */
.block-screen {
  display: none;
  min-height: 100vh;
  place-items: center;
  padding: var(--sp-4);
  background: var(--gradient-hero);
  position: fixed;
  inset: 0;
  z-index: 200;
}
.block-screen__card {
  width: 100%;
  max-width: 400px;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-danger-border);
  border-radius: var(--r-2xl);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
}
.block-screen__icon {
  display: flex;
  justify-content: center;
  margin-bottom: var(--sp-5);
  color: var(--clr-danger-text);
}
.block-screen__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin: 0 0 var(--sp-3);
}
.block-screen__reason {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin: 0 0 var(--sp-6);
  line-height: 1.5;
}
.block-screen__timer-wrap {
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-6);
  display: inline-block;
  min-width: 160px;
}
.block-screen__timer-label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-2);
}
.block-screen__timer {
  font-size: 2.25rem;
  font-weight: var(--fw-bold);
  color: var(--clr-danger-text);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* ============================================================
   SECURITY INFO (информационный блок защиты входа)
   ============================================================ */
.security-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.security-info__row {
  display: flex;
  gap: var(--sp-4);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.security-info__label {
  flex: 0 0 220px;
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
}
.security-info__value {
  color: var(--clr-text-primary);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
  align-items: center;
}
.ban-badge {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border: 1px solid var(--clr-danger-border);
  border-radius: var(--r-sm);
  padding: 2px var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  white-space: nowrap;
}

/* ============================================================
   BADGE (universal)
   ============================================================ */
.badge {
  display: inline-block;
  padding: 2px var(--sp-2);
  border-radius: var(--r-sm);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  border: 1px solid transparent;
}
.badge--ok {
  background: var(--clr-success-bg, #f0fdf4);
  color: var(--clr-success-dark, #15803d);
  border-color: var(--clr-success-border, #bbf7d0);
}
.badge--warn {
  background: var(--clr-warning-bg, #fffbeb);
  color: var(--clr-warning-dark, #b45309);
  border-color: var(--clr-warning-border, #fde68a);
}
.badge--err {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}

/* ============================================================
   DESKTOP TOPBAR NAVIGATION (replaces sidebar at ≥1024px)
   ============================================================ */
.topbar__brand--desktop {
  display: none;
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: var(--fs-lg);
  color: var(--clr-accent);
  letter-spacing: -0.02em;
  margin-right: var(--sp-4);
  white-space: nowrap;
}
.topbar__title--mobile {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
}
.topbar__nav {
  display: none;
  align-items: center;
  gap: var(--sp-1);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex-shrink: 1;
  min-width: 0;
}
.topbar__nav::-webkit-scrollbar { display: none; }
.topbar__nav-link {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  transition: all var(--t-normal);
  white-space: nowrap;
  border: 1px solid transparent;
}
.topbar__nav-link:hover {
  background: var(--clr-bg-elevated);
  color: var(--clr-text-primary);
  border-color: var(--clr-border);
}
.topbar__nav-link.is-active {
  background: var(--clr-accent);
  color: white;
  border-color: var(--clr-accent);
  font-weight: var(--fw-semibold);
}
.topbar__user-name {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
}

/* Desktop topbar nav kicks in at 900px so laptops on 125–150% display
   scaling (effective width 900–1023px) still get the full horizontal nav
   instead of the burger. */
@media (min-width: 900px) {
  .topbar__burger         { display: none !important; }
  .topbar__title--mobile  { display: none !important; }
  .topbar__brand--desktop { display: block !important; }
  .topbar__nav            { display: flex !important; }
  .sidebar                { display: none !important; }
  .scrim                  { display: none !important; }
  .shell                  { padding-left: 0; }
  .topbar { padding-left: var(--sp-6); padding-right: var(--sp-6); }
  .main   { padding: var(--sp-8) var(--sp-6); max-width: 1440px; margin: 0 auto; }
}

/* ============================================================
   SETTINGS TABS
   ============================================================ */
.tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--clr-border);
  margin-bottom: var(--sp-6);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.tabs::-webkit-scrollbar { display: none; }

.tab-btn {
  flex-shrink: 0;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.tab-btn:hover { color: var(--clr-text-primary); }
.tab-btn.is-active {
  color: var(--clr-accent);
  border-bottom-color: var(--clr-accent);
}
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

/* ============================================================
   STATUS CHIP (read-only inline indicator)
   ============================================================ */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  border: 1px solid transparent;
  white-space: nowrap;
}
.chip::before {
  content: '';
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
}
.chip--ok {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}
.chip--ok::before  { background: var(--clr-success-dark, #16a34a); }
.chip--err {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}
.chip--err::before { background: var(--clr-danger-text); }

/* ============================================================
   SYSTEM STATUS ROWS
   ============================================================ */
.sysrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
.sysrow:last-child { border-bottom: none; }
.sysrow__label { color: var(--clr-text-muted); }

/* ============================================================
   INLINE SAVE ROW + RESPONSIVE TABLE COLUMNS
   ============================================================ */
.inline-save-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
}
@media (max-width: 767px) {
  .col--desktop { display: none; }
  .settings-section { padding: var(--sp-4); }
}

/* ============================================================
   DANGER / WARN / SUCCESS BUTTONS
   ============================================================ */
.btn--danger {
  background: var(--clr-danger-text);
  color: var(--clr-text-inverse);
  border-color: transparent;
  width: auto;
}
.btn--danger:hover { background: #b91c1c; }
.btn--danger:disabled { opacity: 0.6; cursor: not-allowed; }

.btn--warn {
  background: var(--clr-warning-bg);
  color: var(--clr-warning-dark, #b45309);
  border-color: var(--clr-warning-border);
  width: auto;
}
.btn--warn:hover { background: var(--clr-warning-border); color: #92400e; }
.btn--warn:disabled { opacity: 0.6; cursor: not-allowed; }

.btn--success {
  background: var(--clr-success-bg);
  color: var(--clr-success-dark, #15803d);
  border-color: var(--clr-success-border);
  width: auto;
}
.btn--success:hover { background: var(--clr-success-border); color: #166534; }
.btn--success:disabled { opacity: 0.6; cursor: not-allowed; }

/* Read-only input — looks like a field but non-editable */
.field input[readonly] {
  background: var(--clr-bg-elevated);
  color: var(--clr-text-secondary);
  cursor: default;
  border-color: var(--clr-border);
}
.field input[readonly]:focus {
  border-color: var(--clr-border);
  box-shadow: none;
}

/* ============================================================
   WARNING BANNER
   ============================================================ */
.warning-banner {
  background: var(--clr-warning-bg);
  border: 1px solid var(--clr-warning-border);
  color: var(--clr-warning-text);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  line-height: 1.5;
}

/* ============================================================
   MODAL BODY / FOOT
   ============================================================ */
.modal__body { margin-bottom: var(--sp-5); }
.modal__foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
}
.modal__foot .btn--primary,
.modal__foot .btn--danger,
.modal__foot .btn--ghost { width: auto; }

/* Confirm modal */
.confirm-modal { max-width: 420px; }
.confirm-modal__msg { margin: 0; color: var(--clr-text-primary); line-height: 1.5; }
.confirm-modal__email {
  margin-top: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: var(--clr-bg-secondary);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
}

/* ============================================================
   FIELD — SELECT
   ============================================================ */
.field select {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  font-family: inherit;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast);
  cursor: pointer;
}
.field select:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}

/* ============================================================
   PAGE HEAD — right-side actions
   ============================================================ */
.page-head__actions { margin-left: auto; width: auto; }

/* ============================================================
   FORM SECTIONS (inside modals)
   ============================================================ */
.form-section { margin-bottom: var(--sp-5); }
.form-section:last-child { margin-bottom: 0; }
.form-section__label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-3);
}

/* ============================================================
   ROLE PICKER CARDS (in modals)
   ============================================================ */
.role-picker {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
}
.role-option {
  padding: var(--sp-4) var(--sp-3);
  border: 2px solid var(--clr-border);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: border-color var(--t-fast), background var(--t-fast);
  text-align: center;
  user-select: none;
}
.role-option:hover:not(.is-selected) {
  border-color: var(--clr-border-hover);
  background: var(--clr-bg-elevated);
}
.role-option__icon { font-size: 1.75rem; display: block; margin-bottom: var(--sp-2); }
.role-option__title {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
}
.role-option__desc {
  font-size: 11px;
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  line-height: 1.4;
}
.role-option[data-role="manager"].is-selected {
  border-color: var(--clr-success);
  background: var(--clr-success-bg);
}
.role-option[data-role="superadmin"].is-selected {
  border-color: var(--clr-blue);
  background: var(--clr-blue-glow);
}

/* ============================================================
   ROLE TAGS (in cards)
   ============================================================ */
.role-tag {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--sp-3);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  border: 1px solid transparent;
  letter-spacing: 0.01em;
}
.role-tag--superadmin {
  background: var(--clr-info-bg);
  color: var(--clr-info-text);
  border-color: var(--clr-info-border);
}
.role-tag--manager {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}

/* ============================================================
   PERSON GRID + CARDS
   ============================================================ */
.person-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .person-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1280px) {
  .person-grid { grid-template-columns: repeat(3, 1fr); }
}

.person-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  transition: box-shadow var(--t-fast), border-color var(--t-fast);
}
.person-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-hover);
}
.person-card--blocked { opacity: 0.65; }

.person-card__head {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
}

/* Avatar with initials */
.person-avatar {
  width: 52px;
  height: 52px;
  border-radius: var(--r-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-text-inverse);
  flex-shrink: 0;
  letter-spacing: 0.02em;
}
.person-avatar--superadmin {
  background: var(--gradient-blue);
  box-shadow: 0 2px 8px var(--clr-blue-glow);
}
.person-avatar--manager {
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  box-shadow: 0 2px 8px rgba(5, 150, 105, 0.25);
}
.person-avatar--blocked {
  background: linear-gradient(135deg, #9ca3af 0%, #6b7280 100%);
}

.person-card__info { flex: 1; min-width: 0; }
.person-card__name {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  line-height: 1.3;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.person-card__username {
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
  margin-top: 2px;
}
.person-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}

.person-card__meta {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  display: flex;
  flex-direction: column;
  gap: 4px;
  line-height: 1.5;
}
.person-card__meta-row {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
}
.person-card__meta-label {
  flex-shrink: 0;
  font-weight: var(--fw-medium);
}

.person-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
  margin-top: auto;
}

/* Mobile (<640px): 2 колонки, delete справа */
@media (max-width: 639px) {
  .person-card__actions .btn--sm:not(.js-delete) {
    flex: 1 1 calc(50% - var(--sp-1));
    max-width: calc(50% - var(--sp-1));
    justify-content: center;
    padding: var(--sp-2) var(--sp-3);
    font-size: var(--fs-xs);
  }
}

/* Desktop (≥640px): всё в одну строку, delete справа */
@media (min-width: 640px) {
  .person-card__actions { flex-wrap: nowrap; }
}

/* Delete — компактная, прижата вправо */
.person-card__actions .js-delete {
  margin-left: auto;
  flex: none;
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  line-height: 1.3;
  white-space: nowrap;
  align-self: flex-end;
}

/* Password display (в модалке) */
.pwd-display {
  display: block;
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  font-family: 'Courier New', monospace;
  font-size: var(--fs-base);
  letter-spacing: 0.05em;
  word-break: break-all;
  color: var(--clr-text-primary);
  flex: 1;
}

/* ============================================================
   COMPACT DESKTOP NAV  (1024 – 1279 px)
   ============================================================ */
@media (min-width: 900px) and (max-width: 1279px) {
  .topbar__nav-link { padding: 4px 8px; font-size: 12px; }
  .topbar__brand--desktop { font-size: var(--fs-md); margin-right: var(--sp-2); }
  .topbar__user-name { font-size: 11px; }
}
/* Below 1100px the full user name crowds the 8-item superadmin nav — drop it,
   the Выйти button stays. */
@media (min-width: 900px) and (max-width: 1099px) {
  .topbar__user-name { display: none; }
  .topbar__brand--desktop { margin-right: var(--sp-3); }
}

/* ============================================================
   DASHBOARD — QUICK ACTIONS
   ============================================================ */
.dash-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.dash-action {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  text-decoration: none;
  transition: box-shadow var(--t-fast), border-color var(--t-fast), color var(--t-fast);
  cursor: pointer;
}
.dash-action:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}
.dash-action--accent {
  background: var(--clr-accent-glow);
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}
.dash-action__icon { font-size: var(--fs-xl); flex-shrink: 0; }
.dash-action__badge {
  margin-left: auto;
  background: var(--clr-danger);
  color: #fff;
  font-size: 11px;
  font-weight: var(--fw-bold);
  padding: 1px 7px;
  border-radius: var(--r-full);
  flex-shrink: 0;
}
.dash-action__count {
  margin-left: auto;
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
}

/* ============================================================
   DASHBOARD — MAIN GRID
   ============================================================ */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-top: var(--sp-5);
}
@media (min-width: 1024px) {
  .dash-grid { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   DASHBOARD — SECTION CARDS
   ============================================================ */
.dash-section {
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  margin-bottom: var(--sp-4);
}
.dash-section:last-child { margin-bottom: 0; }

.dash-section__title {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--clr-text-muted);
  margin: 0 0 var(--sp-4);
}
.dash-section__more {
  display: inline-block;
  margin-top: var(--sp-3);
  font-size: var(--fs-xs);
  color: var(--clr-accent);
  text-decoration: none;
}
.dash-section__more:hover { text-decoration: underline; }

/* ---- KPI metrics ---- */
.dash-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: var(--sp-3);
}
.dash-kpi__val {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  color: var(--clr-text-primary);
  line-height: 1;
}
.dash-kpi__val--accent { color: var(--clr-accent); }
.dash-kpi__label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
}

/* ---- Stat card value shrink for long numbers ---- */
.stat-card__value--sm { font-size: var(--fs-xl); }
@media (min-width: 640px) { .stat-card__value--sm { font-size: var(--fs-2xl); } }

/* ============================================================
   DASHBOARD — SYSTEM STATUS CHIPS
   ============================================================ */
.status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.status-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: 4px 10px;
  border-radius: var(--r-full);
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-secondary);
}
.status-chip::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--clr-text-muted);
  flex-shrink: 0;
}
.status-chip--ok  { background: #f0fdf4; border-color: #bbf7d0; color: #166534; }
.status-chip--ok::before  { background: #22c55e; }
.status-chip--warn{ background: #fffbeb; border-color: #fde68a; color: #92400e; }
.status-chip--warn::before{ background: #f59e0b; }
.status-chip--err { background: #fef2f2; border-color: #fecaca; color: #991b1b; }
.status-chip--err::before { background: #ef4444; }

[data-theme="dark"] .status-chip--ok  { background: rgba(34,197,94,.15);  border-color: rgba(34,197,94,.35);  color: #86efac; }
[data-theme="dark"] .status-chip--ok::before  { background: #22c55e; }
[data-theme="dark"] .status-chip--warn{ background: rgba(245,158,11,.15); border-color: rgba(245,158,11,.35); color: #fcd34d; }
[data-theme="dark"] .status-chip--warn::before{ background: #f59e0b; }
[data-theme="dark"] .status-chip--err { background: rgba(239,68,68,.15);  border-color: rgba(239,68,68,.35);  color: #fca5a5; }
[data-theme="dark"] .status-chip--err::before { background: #ef4444; }

/* ============================================================
   DASHBOARD — SECURITY EVENT LIST
   ============================================================ */
.event-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.event-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--clr-border);
}
.event-item:last-child { border-bottom: none; }
.event-item__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
  flex-shrink: 0;
  margin-top: 4px;
}
.event-item__dot--fail { background: var(--clr-danger); }
.event-item__body { flex: 1; min-width: 0; }
.event-item__who  { font-size: var(--fs-xs); font-weight: var(--fw-medium); color: var(--clr-text-primary); }
.event-item__when { font-size: 11px; color: var(--clr-text-muted); margin-top: 1px; }
.event-item__empty{ font-size: var(--fs-xs); color: var(--clr-text-muted); padding: var(--sp-2) 0; }

/* ============================================================
   DASHBOARD — BLOCKS (SUPERADMIN)
   ============================================================ */
.dash-blocks {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-top: var(--sp-5);
}
@media (min-width: 1280px) {
  .dash-blocks > :first-child { grid-column: 1 / -1; }
  .dash-blocks { grid-template-columns: 1fr 1fr; }
}

.dash-block {
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.dash-block__header {
  padding: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-bg-elevated);
}

.dash-block__title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin: 0;
}

.dash-block__content {
  padding: var(--sp-4);
  flex: 1;
  overflow: auto;
}

/* ============================================================
   DASHBOARD — ORDER LIST
   ============================================================ */
.order-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.order-item {
  display: grid;
  grid-template-columns: 120px 1fr 120px;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  text-decoration: none;
  transition: background var(--t-fast), color var(--t-fast), padding var(--t-fast);
  cursor: pointer;
}

.order-item:last-child { border-bottom: none; }

.order-item:hover {
  background: var(--clr-bg-elevated);
  color: var(--clr-accent);
  padding-left: var(--sp-2);
  padding-right: var(--sp-2);
  margin-left: calc(var(--sp-2) * -1);
  margin-right: calc(var(--sp-2) * -1);
}

.order-item__id {
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  font-size: var(--fs-xs);
  font-family: 'Courier New', monospace;
}

.order-item__status {
  color: var(--clr-text-muted);
  font-size: 11px;
  text-transform: uppercase;
}

.order-item--new .order-item__status {
  color: var(--clr-warn);
  font-weight: var(--fw-semibold);
}

.order-item--processing .order-item__status {
  color: var(--clr-info);
  font-weight: var(--fw-semibold);
}

.order-item__amount {
  text-align: right;
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}

/* ============================================================
   NEW DASHBOARD DESIGN (Manager & SuperAdmin)
   ============================================================ */

/* KPI STRIP: 4 крупные карточки с ключевыми метриками */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
@media (min-width: 640px) {
  .kpi-strip { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1024px) {
  .kpi-strip { gap: var(--sp-5); margin-bottom: var(--sp-8); }
}

.kpi-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: all var(--t-normal);
  position: relative;
}
.kpi-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-hover);
  transform: translateY(-2px);
}

.kpi-card__icon {
  font-size: 1.75rem;
  line-height: 1;
}

.kpi-card__body {
  flex: 1;
}

.kpi-card__label {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-2);
}

.kpi-card__value {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  color: var(--clr-text-primary);
  line-height: 1;
  font-family: var(--font-display);
}

.kpi-card__value--sm {
  font-size: var(--fs-xl);
}
@media (min-width: 640px) {
  .kpi-card__value--sm { font-size: var(--fs-2xl); }
}

.kpi-card__action {
  margin-top: var(--sp-2);
  color: var(--clr-accent);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  transition: color var(--t-fast);
}
.kpi-card__action:hover {
  color: var(--clr-accent-hover);
}

/* KPI Card color modifiers */
.kpi-card--urgent {
  border-left: 4px solid var(--clr-warning);
  background: linear-gradient(135deg, rgba(193,18,31,0.05) 0%, transparent 100%);
}
.kpi-card--urgent .kpi-card__value {
  color: var(--clr-accent);
}

.kpi-card--processing {
  border-left: 4px solid var(--clr-info);
}
.kpi-card--processing .kpi-card__value {
  color: var(--clr-blue);
}

.kpi-card--accent {
  border-left: 4px solid var(--clr-accent);
}
.kpi-card--accent .kpi-card__value {
  color: var(--clr-accent);
}

.kpi-card--success {
  border-left: 4px solid var(--clr-success);
}
.kpi-card--success .kpi-card__value {
  color: var(--clr-success);
}

.kpi-card--info {
  border-left: 4px solid var(--clr-blue);
}
.kpi-card--info .kpi-card__value {
  color: var(--clr-blue);
}

/* ──────────────────────────────────────────────────────────────
   ORDERS FEED: Вертикальные карточки заказов
   ────────────────────────────────────────────────────────────── */

.orders-feed {
  margin-bottom: var(--sp-6);
}
@media (min-width: 1024px) {
  .orders-feed { margin-bottom: var(--sp-8); }
}

.section-header {
  margin-bottom: var(--sp-4);
}
.section-header h2 {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin: 0;
  font-family: var(--font-display);
}

.order-cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
}
@media (min-width: 640px) {
  .order-cards-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .order-cards-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
}

.order-cards-grid--compact {
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .order-cards-grid--compact { grid-template-columns: 1fr; }
}

.order-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  transition: all var(--t-normal);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  position: relative;
}
.order-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--clr-border);
  transition: background var(--t-normal);
}
.order-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-hover);
  transform: translateY(-2px);
}

.order-card--new::before { background: var(--clr-warning); }
.order-card--processing::before { background: var(--clr-info); }
.order-card--delivered::before { background: var(--clr-success); }

.order-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}

.order-card__id {
  font-family: 'Courier New', monospace;
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-text-primary);
}

.order-card__status {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
}

.order-card--new .order-card__status {
  background: rgba(193, 18, 31, 0.1);
  color: var(--clr-accent);
}
.order-card--processing .order-card__status {
  background: var(--clr-blue-glow);
  color: var(--clr-blue);
}

.order-card__body {
  flex: 1;
  margin-bottom: var(--sp-2);
}

.order-card__amount {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: 1.2;
}

.order-card__date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-2);
}

.order-card__footer {
  border-top: 1px solid var(--clr-border);
  padding-top: var(--sp-3);
}

.order-card__cta {
  font-size: var(--fs-sm);
  color: var(--clr-accent);
  font-weight: var(--fw-semibold);
  transition: color var(--t-fast);
}
.order-card:hover .order-card__cta {
  color: var(--clr-accent-hover);
}

/* ──────────────────────────────────────────────────────────────
   DASHBOARD GRID: 3-column layout for SuperAdmin
   ────────────────────────────────────────────────────────────── */

.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
  margin-bottom: var(--sp-6);
}
@media (min-width: 1024px) {
  .dashboard-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); margin-bottom: var(--sp-8); }
}

.dashboard-section {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

/* ──────────────────────────────────────────────────────────────
   SYSTEM STATUS: 2x2 grid of status indicators
   ────────────────────────────────────────────────────────────── */

.system-status-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}

.status-item {
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  transition: all var(--t-normal);
}
.status-item:hover {
  border-color: var(--clr-border-hover);
}

.status-item__indicator {
  width: 10px;
  height: 10px;
  border-radius: var(--r-full);
  flex-shrink: 0;
  background: var(--clr-text-muted);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

.status-item--ok .status-item__indicator {
  background: var(--clr-success);
  box-shadow: 0 0 8px rgba(34, 197, 94, 0.3);
}

.status-item--error .status-item__indicator {
  background: var(--clr-danger);
  box-shadow: 0 0 8px rgba(239, 68, 68, 0.3);
  animation: pulse-error 2s infinite;
}

@keyframes pulse-error {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

.status-item__label {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  font-weight: var(--fw-medium);
}

/* System metrics */
.system-metrics {
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
}

.metric-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--clr-border);
}
.metric-row:last-child {
  border-bottom: none;
}

.metric-label {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
}

.metric-value {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
}

/* ──────────────────────────────────────────────────────────────
   SECURITY FEED: Event list with indicators
   ────────────────────────────────────────────────────────────── */

.security-feed {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.feed-title {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--fw-semibold);
  margin: 0 0 var(--sp-3) 0;
}

.security-events {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.security-event {
  display: flex;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--clr-border);
  transition: background var(--t-fast);
}
.security-event:last-child {
  border-bottom: none;
}
.security-event:hover {
  background: var(--clr-bg-elevated);
  margin: 0 calc(var(--sp-2) * -1);
  padding: var(--sp-2);
  border-radius: var(--r-sm);
}

.security-event__indicator {
  width: 8px;
  height: 8px;
  border-radius: var(--r-full);
  flex-shrink: 0;
  margin-top: 6px;
  background: var(--clr-text-muted);
}

.security-event__indicator--ok {
  background: var(--clr-success);
  box-shadow: 0 0 6px rgba(34, 197, 94, 0.4);
}

.security-event__indicator--fail {
  background: var(--clr-danger);
  box-shadow: 0 0 6px rgba(239, 68, 68, 0.4);
}

.security-event__indicator--blocked {
  background: var(--clr-warning);
  box-shadow: 0 0 6px rgba(193, 18, 31, 0.4);
}

.security-event__content {
  flex: 1;
  min-width: 0;
}

.security-event__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  word-break: break-word;
}

.security-event__detail {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: 2px;
}

.security-event__ip {
  font-size: 11px;
  color: var(--clr-text-muted);
  font-family: 'Courier New', monospace;
  margin-top: 2px;
  opacity: 0.7;
}

.security-event--blocked .security-event__title {
  color: var(--clr-accent);
}

/* ──────────────────────────────────────────────────────────────
   QUICK ACTIONS: Grid of large action buttons
   ────────────────────────────────────────────────────────────── */

.quick-actions {
  margin-top: var(--sp-8);
}

.action-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .action-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
}
@media (min-width: 1024px) {
  .action-grid { grid-template-columns: repeat(4, 1fr); }
}

.action-button {
  background: var(--clr-bg-card);
  border: 2px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5) var(--sp-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  text-decoration: none;
  color: inherit;
  transition: all var(--t-normal);
  cursor: pointer;
  position: relative;
  min-height: 140px;
}
.action-button:hover {
  border-color: var(--clr-accent);
  background: linear-gradient(135deg, rgba(193,18,31,0.03) 0%, transparent 100%);
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}

.action-button__icon {
  font-size: 2.5rem;
  line-height: 1;
  display: block;
}

.action-button__label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  text-align: center;
  color: var(--clr-text-primary);
  line-height: 1.3;
}

.action-button__badge {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  background: var(--clr-danger);
  color: white;
  border-radius: var(--r-full);
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: var(--fw-bold);
  box-shadow: var(--shadow-md);
}

.action-button__count {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
  border-radius: var(--r-full);
  padding: 2px 8px;
  font-size: 11px;
  font-weight: var(--fw-semibold);
}

.action-button--urgent {
  border-color: var(--clr-accent);
  background: linear-gradient(135deg, rgba(193,18,31,0.08) 0%, transparent 100%);
}
.action-button--urgent:hover {
  box-shadow: 0 0 24px rgba(193, 18, 31, 0.15);
}

/* Empty state */
.empty-state {
  text-align: center;
  padding: var(--sp-8);
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
}

/* ============================================================
   MANAGER DASHBOARD — переработанный (mgr-*)
   SuperAdmin продолжает использовать kpi-card / order-card / action-button.
   ============================================================ */

/* --- Блок "Требует внимания" --- */
.mgr-alert {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.mgr-alert__item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  text-decoration: none;
  border: 1px solid transparent;
  transition: filter var(--t-fast);
}
.mgr-alert__item:hover { filter: brightness(0.93); }
.mgr-alert__item--warn {
  background: var(--clr-warning-bg);
  color: var(--clr-warning-text);
  border-color: var(--clr-warning-border);
}
.mgr-alert__item--info {
  background: var(--clr-info-bg);
  color: var(--clr-info-text);
  border-color: var(--clr-info-border);
}
.mgr-alert__dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  background: var(--clr-warning);
}
.mgr-alert__dot--info { background: var(--clr-blue); }
.mgr-alert__arrow { margin-left: var(--sp-1); opacity: 0.7; }

/* --- KPI карточки (компактные) --- */
.mgr-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
@media (min-width: 640px) {
  .mgr-kpis { grid-template-columns: repeat(4, 1fr); }
}

.mgr-kpi {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-left-width: 4px;
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
a.mgr-kpi:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-hover, #d1d5db);
}
.mgr-kpi--urgent { border-left-color: var(--clr-warning); }
.mgr-kpi--info   { border-left-color: var(--clr-info); }
.mgr-kpi--accent { border-left-color: var(--clr-accent); }
.mgr-kpi--success{ border-left-color: var(--clr-success); }

.mgr-kpi__val {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  line-height: 1;
  font-family: var(--font-display);
  color: var(--clr-text-primary);
}
.mgr-kpi--urgent .mgr-kpi__val { color: var(--clr-accent); }
.mgr-kpi--info   .mgr-kpi__val { color: var(--clr-blue); }
.mgr-kpi--success .mgr-kpi__val { color: var(--clr-success-dark); }

.mgr-kpi__val--sm { font-size: var(--fs-lg); }
@media (min-width: 640px) { .mgr-kpi__val--sm { font-size: var(--fs-xl); } }

.mgr-kpi__label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: var(--fw-medium);
}

/* --- Секция "Последние заказы" --- */
.mgr-section {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.mgr-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--clr-border);
}
.mgr-section__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin: 0;
  font-family: var(--font-display);
}
.mgr-section__more {
  font-size: var(--fs-sm);
  color: var(--clr-accent);
  font-weight: var(--fw-semibold);
}
.mgr-section__more:hover { text-decoration: underline; }

/* --- Компактный список заказов --- */
.mgr-orders { display: flex; flex-direction: column; }

.mgr-order {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-1);
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
  text-decoration: none;
  color: inherit;
  border-radius: var(--r-sm);
  transition: background var(--t-fast);
}
.mgr-order:last-child { border-bottom: none; }
.mgr-order:hover { background: var(--clr-bg-elevated); }

@media (min-width: 480px) {
  .mgr-order { grid-template-columns: auto 1fr auto auto; }
}

.mgr-order__id {
  font-family: 'Courier New', monospace;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  white-space: nowrap;
}
.mgr-order__status {
  font-size: 11px;
  font-weight: var(--fw-semibold);
  padding: 2px 8px;
  border-radius: var(--r-full);
  white-space: nowrap;
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
  justify-self: start;
}
.mgr-order--new .mgr-order__status {
  background: var(--clr-warning-bg);
  color: var(--clr-warning-text);
  border-color: var(--clr-warning-border);
}
.mgr-order--processing .mgr-order__status {
  background: var(--clr-info-bg);
  color: var(--clr-info-text);
  border-color: var(--clr-info-border);
}
.mgr-order--delivered .mgr-order__status {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}
.mgr-order--cancelled .mgr-order__status {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}
.mgr-order__amount {
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  white-space: nowrap;
  text-align: right;
}
.mgr-order__date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  white-space: nowrap;
  text-align: right;
  display: none;
}
@media (min-width: 480px) { .mgr-order__date { display: block; } }

.mgr-empty {
  padding: var(--sp-5);
  text-align: center;
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
}

/* --- Быстрые ссылки (2 в ряд mobile, 4 в ряд desktop) --- */
.mgr-links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-2);
}
@media (min-width: 640px) {
  .mgr-links { grid-template-columns: repeat(4, 1fr); gap: var(--sp-3); }
}

.mgr-link {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  text-decoration: none;
  transition: all var(--t-fast);
  position: relative;
  min-width: 0;
}
.mgr-link:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
  background: var(--clr-accent-glow);
}
.mgr-link--urgent {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
  background: var(--clr-accent-glow);
}
.mgr-link__ico { font-size: var(--fs-base); flex-shrink: 0; }
.mgr-link__label {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mgr-link__badge {
  background: var(--clr-danger);
  color: #fff;
  border-radius: var(--r-full);
  padding: 1px 6px;
  font-size: 11px;
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}

/* ============================================================
   SUPERADMIN DASHBOARD (sa-*)
   ============================================================ */

/* --- Строка здоровья системы --- */
.sa-health {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: space-between;
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.sa-health__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.sa-health__meta {
  display: flex;
  gap: var(--sp-4);
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
}
.sa-health__meta strong { color: var(--clr-text-secondary); }

/* Status chips */
.sa-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  padding: 3px 10px;
  border-radius: var(--r-full);
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
}
.sa-chip__dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: var(--clr-text-muted);
}
.sa-chip--ok {
  background: var(--clr-success-bg);
  border-color: var(--clr-success-border);
  color: var(--clr-success-text);
}
.sa-chip--ok .sa-chip__dot { background: var(--clr-success); }
.sa-chip--warn {
  background: var(--clr-warning-bg);
  border-color: var(--clr-warning-border);
  color: var(--clr-warning-text);
}
.sa-chip--warn .sa-chip__dot { background: var(--clr-warning); }
.sa-chip--err {
  background: var(--clr-danger-bg);
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
}
.sa-chip--err .sa-chip__dot {
  background: var(--clr-danger);
  animation: sa-pulse 1.5s ease-in-out infinite;
}
@keyframes sa-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* --- KPI: 5 карточек в ряд на ПК --- */
.sa-kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
@media (min-width: 640px) {
  .sa-kpis { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 900px) {
  .sa-kpis { grid-template-columns: repeat(5, 1fr); }
}

/* Neutral KPI (Клиенты) */
.mgr-kpi--neutral { border-left-color: var(--clr-border-hover, #d1d5db); }
.mgr-kpi--neutral .mgr-kpi__val { color: var(--clr-text-secondary); }

/* --- Двухколоночный layout: Заказы + Безопасность --- */
.sa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
@media (min-width: 900px) {
  .sa-grid { grid-template-columns: 1fr 1fr; }
}

/* --- Секция безопасности --- */
.sa-sec { display: flex; flex-direction: column; }

.sa-sec__group-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-2);
}
.sa-sec__sep {
  border-top: 1px solid var(--clr-border);
  margin: var(--sp-3) 0;
}
.sa-sec__empty {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  padding: var(--sp-2) 0;
}

/* --- Компактный список входов --- */
.sa-logins, .sa-blocks { display: flex; flex-direction: column; }

.sa-login {
  display: grid;
  grid-template-columns: 10px 1fr auto auto;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
.sa-login:last-child { border-bottom: none; }
.sa-login__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--clr-success);
  justify-self: center; flex-shrink: 0;
}
.sa-login--err .sa-login__dot { background: var(--clr-danger); }
.sa-login__who {
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-width: 0;
}
.sa-login__type {
  color: var(--clr-text-muted);
  white-space: nowrap;
}
.sa-login--err .sa-login__type { color: var(--clr-danger-text); }
.sa-login__when { color: var(--clr-text-muted); white-space: nowrap; }

/* --- Компактный список блокировок --- */
.sa-block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
.sa-block:last-child { border-bottom: none; }
.sa-block__key {
  font-weight: var(--fw-semibold);
  color: var(--clr-accent);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1; min-width: 0;
}
.sa-block__detail { color: var(--clr-text-muted); white-space: nowrap; }

/* ============================================================
   ORDERS — список карточками (ord-*)
   Каждый заказ = карточка (а не строка таблицы БД). Цветной левый
   кант кодирует статус, как у KPI-карточек Dashboard.
   ============================================================ */
.ord-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
}
@media (min-width: 640px)  { .ord-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); } }
@media (min-width: 1280px) { .ord-grid { grid-template-columns: repeat(3, 1fr); } }

.ord-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-left-width: 4px;
  border-left-color: var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-4);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--t-fast), transform var(--t-fast);
  cursor: pointer;
}
.ord-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.ord-card--new        { border-left-color: var(--clr-warning); }
.ord-card--processing { border-left-color: var(--clr-info); }
.ord-card--delivered  { border-left-color: var(--clr-success); }
.ord-card--cancelled  { border-left-color: var(--clr-danger); }

.ord-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
}
.ord-card__badges {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  flex-wrap: wrap;
  justify-content: flex-end;
}
.ord-card__num {
  font-family: 'Courier New', monospace;
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-accent);
  border: none;
  background: none;
  padding: 0;
  cursor: pointer;
  position: relative;
  transition: opacity var(--t-fast);
}
.ord-card__num:hover {
  opacity: 0.8;
}

.ord-card__facts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2) var(--sp-3);
  margin: 0;
}
.ord-card__fact dt {
  font-size: 11px;
  color: var(--clr-text-disabled, #999);
  text-transform: none;
  letter-spacing: 0;
  font-weight: var(--fw-medium);
}
.ord-card__fact dd {
  margin: 2px 0 0;
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ord-card__items {
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--clr-border);
}

.ord-card__item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding-bottom: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
}

.ord-card__item:last-child {
  padding-bottom: 0;
}

.ord-card__item-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.ord-card__item-qty {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  opacity: 0.7;
}

.ord-card__item--more {
  padding-top: var(--sp-2);
  margin-top: var(--sp-2);
  border-top: 1px solid var(--clr-border);
  color: var(--clr-text-muted);
  font-style: italic;
  cursor: default;
  padding-bottom: 0;
}

.ord-card__total {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-top: var(--sp-2);
  margin-top: var(--sp-2);
  border-top: 1px solid var(--clr-border);
}
.ord-card__total span { font-size: var(--fs-sm); color: var(--clr-text-muted); }
.ord-card__total strong {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  font-family: var(--font-display);
  color: var(--clr-text-primary);
}

.ord-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}

/* ============================================================
 * CATALOG
 * ============================================================ */

.catalog-toolbar {
  display: flex;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
  flex-wrap: wrap;
}

.catalog-search {
  flex: 1;
  min-width: 250px;
  padding: 0.75rem 1rem;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: 1rem;
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast), background var(--t-fast);
}

.catalog-search:focus {
  outline: none;
  border-color: var(--clr-accent);
  background: var(--clr-bg-card);
}

.catalog-filter {
  min-width: 180px;
  padding: 0.75rem 1rem;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: 1rem;
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  cursor: pointer;
}

.catalog-filter:focus {
  outline: none;
  border-color: var(--clr-accent);
}

/* Сетка товаров */
.cat-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}

@media (min-width: 640px) {
  .cat-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-4);
  }
}

@media (min-width: 1024px) {
  .cat-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Карточка товара */
.cat-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: all var(--t-fast);
  position: relative;
  overflow: hidden;
}

.cat-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.cat-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-2);
}

.cat-card__name {
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-text-primary);
  flex: 1;
  min-width: 0;
}

.cat-card__type {
  font-size: 11px;
  color: var(--clr-text-disabled, #999);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}

.cat-card__body {
  flex: 1;
}

.cat-card__model {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  margin-bottom: var(--sp-1);
  line-height: 1.4;
}

.cat-card__sku {
  font-size: 11px;
  color: var(--clr-text-disabled, #999);
  font-family: 'Courier New', monospace;
  word-break: break-word;
}

.cat-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--sp-2);
  border-top: 1px solid var(--clr-border);
}

.cat-card__price {
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-accent);
  font-family: var(--font-display);
}

.cat-card__stock {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
}

.cat-card__status {
  display: flex;
  gap: var(--sp-1);
}

.cat-card__status .badge {
  font-size: 11px;
  padding: 0.25rem 0.5rem;
}

/* ============================================================
 * PRODUCT DETAIL
 * ============================================================ */

.prod-detail {
  max-width: 1000px;
  margin: 0 auto;
}

.prod-detail__back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: var(--sp-4);
  padding: 0.5rem 1rem;
  color: var(--clr-accent);
  text-decoration: none;
  border-radius: var(--r-md);
  transition: all var(--t-fast);
}

.prod-detail__back:hover {
  background: var(--clr-bg-secondary);
}

.prod-detail__head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-4);
  align-items: start;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
}

@media (max-width: 640px) {
  .prod-detail__head {
    grid-template-columns: 1fr;
    gap: var(--sp-3);
  }
}

.prod-detail__head-main {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.prod-detail__name {
  font-size: 2rem;
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin: 0;
  line-height: 1.2;
}

.prod-detail__type {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.prod-detail__head-price {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  align-items: flex-start;
}

.prod-detail__price {
  font-size: 1.75rem;
  font-weight: var(--fw-bold);
  font-family: var(--font-display);
  color: var(--clr-accent);
}

.prod-detail__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}

@media (min-width: 768px) {
  .prod-detail__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.prod-panel {
  padding: var(--sp-3);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
}

.prod-panel__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--sp-3) 0;
  color: var(--clr-text-primary);
}

.prod-kv {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-2) var(--sp-3);
  margin: 0;
}

.prod-kv dt {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
}

.prod-kv dd {
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  margin: 0;
  word-break: break-word;
}

.prod-image {
  max-width: 100%;
  height: auto;
  border-radius: var(--r-md);
}

.prod-description {
  font-size: var(--fs-sm);
  line-height: 1.6;
  color: var(--clr-text-primary);
  white-space: pre-wrap;
  word-break: break-word;
}

.prod-detail__actions {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}

/* Телефон-ссылка на карточке — быстрый звонок клиенту в один тап */
.ord-card__phone { color: var(--clr-text-primary); text-decoration: none; }
.ord-card__phone:hover { color: var(--clr-accent); text-decoration: underline; }

/* Пометка терминального заказа в строке действий (вместо кнопок) */
.ord-card__done {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
}
.ord-card__done--delivered { color: var(--clr-success-dark); }
.ord-card__done--cancelled { color: var(--clr-danger-text); }

/* ---- Кнопки действий (списка и страницы заказа) ---- */
.ord-act {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  cursor: pointer;
  transition: filter var(--t-fast), background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.ord-act:disabled { opacity: 0.55; cursor: default; }
.ord-act--primary {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: #fff;
}
.ord-act--primary:hover:not(:disabled) { filter: brightness(0.93); }
.ord-act--ghost {
  background: var(--clr-accent-glow);
  border-color: var(--clr-border-accent);
  color: var(--clr-accent);
}
.ord-act--ghost:hover:not(:disabled) {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: #fff;
}
.ord-act--success {
  background: var(--clr-success);
  border-color: var(--clr-success);
  color: #fff;
}
.ord-act--success:hover:not(:disabled) { filter: brightness(0.93); }
.ord-act--danger {
  background: var(--clr-danger-bg);
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
}
.ord-act--danger:hover:not(:disabled) { filter: brightness(0.96); }
.ord-act--open {
  margin-left: auto;
  background: transparent;
  border-color: transparent;
  color: var(--clr-accent);
}
.ord-act--open:hover { text-decoration: underline; }

/* ============================================================
   ORDER STATUS CARD — блок управления статусом
   ============================================================ */
.ord-status-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-4);
  box-shadow: var(--shadow-md);
}
.ord-status-card__now {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding-bottom: var(--sp-3);
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
}
.ord-status-card__next-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-2);
}
.ord-status-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.ord-status-card__msg {
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
  min-height: 1em;
}
.ord-status-card__msg--ok  { color: var(--clr-success-dark); font-weight: var(--fw-semibold); }
.ord-status-card__msg--err { color: var(--clr-danger-text); font-weight: var(--fw-semibold); }

/* ============================================================
   ORDER DETAIL — страница /orders/{id}
   ============================================================ */
.ord-detail { max-width: 920px; }

/* Внутри страницы заказа — более контрастные тексты */
.ord-detail {
  --clr-text-muted: #475569;
  --clr-text-secondary: #1f2937;
}
[data-theme="dark"] .ord-detail {
  --clr-text-muted: #b8c3d9;
  --clr-text-secondary: #dce1ec;
}

.ord-detail__back {
  display: inline-block;
  margin-bottom: var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  text-decoration: none;
}
.ord-detail__back:hover { color: var(--clr-accent); }

.ord-detail__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
}
.ord-detail__head-right {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.ord-detail__num {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  color: var(--clr-text-primary);
}
.ord-detail__sub {
  margin-top: var(--sp-1);
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
}
.ord-detail__age {
  display: inline-block;
  margin-left: var(--sp-2);
  padding: 1px var(--sp-2);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  vertical-align: middle;
}

.ord-detail__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}
@media (min-width: 720px) { .ord-detail__grid { grid-template-columns: 1fr 1fr; } }

.ord-panel {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.ord-detail__grid .ord-panel { margin-bottom: 0; }
.ord-panel__title {
  margin: 0 0 var(--sp-3);
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}
.ord-panel__text { font-size: var(--fs-sm); color: var(--clr-text-primary); line-height: 1.5; }

.ord-kv {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--sp-2) var(--sp-3);
  margin: 0;
  font-size: var(--fs-sm);
}
.ord-kv dt { color: var(--clr-text-muted); }
.ord-kv dd { margin: 0; color: var(--clr-text-primary); word-break: break-word; }
.ord-kv a { color: var(--clr-accent); text-decoration: none; }
.ord-kv a:hover { text-decoration: underline; }
.ord-kv__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin: 0;
}
.ord-kv__comment { margin: 0; font-style: italic; color: var(--clr-text-secondary); word-break: break-word; }
.ord-copy-btn {
  padding: 1px var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  background: none;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.ord-copy-btn:hover { border-color: var(--clr-border-hover); color: var(--clr-text-secondary); }
.ord-call-btn {
  padding: 1px var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--clr-accent);
  background: none;
  border: 1px solid var(--clr-accent);
  border-radius: var(--r-sm);
  text-decoration: none;
  white-space: nowrap;
  transition: background var(--t-fast), color var(--t-fast);
}
.ord-call-btn:hover { background: var(--clr-accent); color: var(--clr-text-inverse); }

.ord-lines-head {
  display: none;
}
@media (min-width: 540px) {
  .ord-lines-head {
    display: grid;
    grid-template-columns: 1fr 70px 100px 100px;
    gap: var(--sp-3);
    padding-bottom: var(--sp-2);
    border-bottom: 2px solid var(--clr-border);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    color: var(--clr-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0;
  }
  .ord-lines-head span:not(:first-child) { text-align: right; }
}

.ord-lines { display: flex; flex-direction: column; }
.ord-line {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
@media (min-width: 540px) {
  .ord-line { grid-template-columns: 1fr 70px 100px 100px; }
}
.ord-line:first-child { padding-top: 0; }
.ord-line__name { color: var(--clr-text-primary); }
.ord-item-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: var(--fw-bold);
  padding: 1px 6px;
  border-radius: var(--r-sm);
  margin-right: var(--sp-2);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  vertical-align: middle;
  line-height: normal;
}
.ord-item-badge--tire {
  background: #d1fae5;
  color: #065f46;
}
.ord-item-badge--wheel {
  background: #fef3c7;
  color: #92400e;
}
[data-theme="dark"] .ord-item-badge--tire {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}
[data-theme="dark"] .ord-item-badge--wheel {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
}
.ord-line__qty { white-space: nowrap; text-align: right; }
.ord-line__price { display: none; white-space: nowrap; text-align: right; }
@media (min-width: 540px) { .ord-line__price { display: block; } }
.ord-line__sum { white-space: nowrap; font-weight: var(--fw-semibold); text-align: right; }

.ord-total {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-top: var(--sp-3);
  margin-top: var(--sp-1);
}
.ord-total span { font-size: var(--fs-sm); color: var(--clr-text-muted); }
.ord-total strong {
  font-size: var(--fs-xl);
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  color: var(--clr-text-primary);
}

/* ---- Прогресс-бар статуса ---- */
.ord-progress {
  display: flex;
  align-items: center;
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-4);
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-sm);
  overflow-x: auto;
  gap: 0;
}
.ord-progress__step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  min-width: 72px;
}
.ord-progress__icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: var(--fw-bold);
  border: 2px solid var(--clr-border);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-muted);
  line-height: 1;
}
.ord-progress__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  text-align: center;
  white-space: nowrap;
}
.ord-progress__step--done .ord-progress__icon { background: var(--clr-success); border-color: var(--clr-success); color: #fff; }
.ord-progress__step--done .ord-progress__label { color: var(--clr-success-text); }
.ord-progress__step--active .ord-progress__icon { background: var(--clr-info); border-color: var(--clr-info); color: #fff; }
.ord-progress__step--active .ord-progress__label { color: var(--clr-text-primary); font-weight: var(--fw-semibold); }
.ord-progress__step--skip .ord-progress__icon { background: var(--clr-danger); border-color: var(--clr-danger); color: #fff; }
.ord-progress__step--skip .ord-progress__label { color: var(--clr-danger-text); }
.ord-progress__line {
  flex: 1;
  height: 2px;
  background: var(--clr-success);
  min-width: 16px;
}
.ord-progress__line--muted { background: var(--clr-border); }
.ord-progress__cancelled-badge {
  margin-left: var(--sp-3);
  padding: 3px var(--sp-3);
  background: var(--clr-danger-bg);
  border: 1px solid var(--clr-danger-border);
  color: var(--clr-danger-text);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ---- Блок получения (доставка / самовывоз) ---- */
.ord-delivery {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding-top: var(--sp-1);
}
.ord-delivery__icon {
  font-size: var(--fs-xl);
  color: var(--clr-text-muted);
  flex-shrink: 0;
  width: 24px;
  text-align: center;
  line-height: 1.2;
}
.ord-delivery__label { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--clr-text-primary); }
.ord-delivery__sub { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: 2px; }
.ord-delivery__sub--warn { color: var(--clr-danger-text, #991b1b); }
.ord-delivery__text { flex: 1; }

.ord-controls { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.ord-controls__msg { margin-top: var(--sp-3); font-size: var(--fs-sm); color: var(--clr-text-muted); min-height: 1em; }
.ord-controls__msg--ok  { color: var(--clr-success-dark); font-weight: var(--fw-semibold); }
.ord-controls__msg--err { color: var(--clr-danger-text); font-weight: var(--fw-semibold); }

/* Финальный баннер терминального заказа (вместо кнопок управления) */
.ord-done {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-lg);
  border: 1px solid transparent;
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
}
.ord-done__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  border-radius: 50%;
  font-size: var(--fs-sm);
  flex-shrink: 0;
}
.ord-done--delivered {
  background: var(--clr-success-bg);
  border-color: var(--clr-success-border);
  color: var(--clr-success-text);
}
.ord-done--delivered .ord-done__icon { background: var(--clr-success); color: #fff; }
.ord-done--cancelled {
  background: var(--clr-danger-bg);
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
}
.ord-done--cancelled .ord-done__icon { background: var(--clr-danger); color: #fff; }

/* ---- Таймлайн истории статусов ---- */
.ord-tl { list-style: none; margin: 0; padding: 0; }
.ord-tl__item {
  position: relative;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: var(--sp-3);
  padding: 0 0 var(--sp-4) 0;
}
.ord-tl__item:last-child { padding-bottom: 0; }
/* вертикальная линия между точками */
.ord-tl__item::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 16px;
  bottom: 0;
  width: 2px;
  background: var(--clr-border);
}
.ord-tl__item:last-child::before { display: none; }
.ord-tl__dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  margin-top: 2px;
  background: var(--clr-text-muted);
  border: 2px solid var(--clr-bg-card);
  box-shadow: 0 0 0 1px var(--clr-border);
  z-index: 1;
}
.ord-tl__item--new .ord-tl__dot        { background: var(--clr-warning); }
.ord-tl__item--processing .ord-tl__dot { background: var(--clr-info); }
.ord-tl__item--delivered .ord-tl__dot  { background: var(--clr-success); }
.ord-tl__item--cancelled .ord-tl__dot  { background: var(--clr-danger); }
.ord-tl__date { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-bottom: 2px; font-variant-numeric: tabular-nums; }
.ord-tl__title { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--clr-text-primary); }
.ord-tl__who { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: 2px; }
.ord-tl__meta { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: 2px; }

.ord-empty { font-size: var(--fs-sm); color: var(--clr-text-muted); padding: var(--sp-2) 0; }

/* ---- Cancellation reason (shown in "done" block for cancelled orders) ---- */
.ord-cancel-reason {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-danger-bg);
  border: 1px solid var(--clr-danger-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
}
.ord-cancel-reason__label {
  font-weight: var(--fw-semibold);
  color: var(--clr-danger-text);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ord-cancel-reason__text { color: var(--clr-text-primary); line-height: 1.5; }

/* ---- Danger Zone ---- */
.ord-danger-zone {
  border-color: var(--clr-danger-border) !important;
  background: var(--clr-danger-bg);
}
.ord-danger-zone__head { margin-bottom: var(--sp-4); }
.ord-danger-zone__title { color: var(--clr-danger-text) !important; }
.ord-danger-zone__desc {
  margin: var(--sp-1) 0 0;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
}
.ord-danger-zone__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.ord-danger-zone__info { flex: 1; min-width: 0; }
.ord-danger-zone__info strong { display: block; font-size: var(--fs-base); }
.ord-danger-zone__hint {
  margin: var(--sp-1) 0 0;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: 1.4;
}
.ord-danger-zone__err {
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
}

/* ---- Cancel reason modal ---- */
.cancel-reason-modal { max-width: 480px; }
.cancel-reason-modal__email {
  margin-top: var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: var(--clr-bg-secondary);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: 1.4;
}
.cancel-reason-modal__field { margin-top: var(--sp-4); }
.cancel-reason-modal__label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}
.cancel-reason-modal__optional {
  font-weight: var(--fw-normal);
  color: var(--clr-text-muted);
}
.cancel-reason-modal__textarea {
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-family: inherit;
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  background: var(--clr-bg-primary);
  resize: vertical;
  min-height: 72px;
  line-height: 1.5;
}
.cancel-reason-modal__textarea:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(var(--clr-accent-rgb, 99 102 241), 0.15);
}

/* ============================================================
   USERS SECTION — stats banner, search, client cards
   ============================================================ */

/* Stats banner */
.usr-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
@media (min-width: 640px) {
  .usr-stats { grid-template-columns: repeat(4, 1fr); }
}

.usr-stats__item {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  text-align: center;
}

.usr-stats__val {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  font-family: var(--font-display);
  color: var(--clr-text-primary);
  line-height: 1.1;
}

.usr-stats__lbl {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: var(--sp-1);
  font-weight: var(--fw-medium);
}

/* Controls row: search + sort */
.usr-controls {
  display: flex;
  align-items: flex-end;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
}

.usr-search-box {
  flex: 1;
  min-width: 250px;
}

.usr-search {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  border: 2px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-md);
  font-family: inherit;
  color: var(--clr-text-primary);
  background: var(--clr-bg-card);
  outline: none;
  transition: all var(--t-fast);
  line-height: 1.5;
}
.usr-search::placeholder {
  color: var(--clr-text-muted);
}
.usr-search:focus {
  border-color: var(--clr-info);
  box-shadow: 0 0 0 3px rgba(59,130,246,.15);
  background: var(--clr-bg-elevated);
}

.usr-sort-box {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.usr-sort__label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  white-space: nowrap;
}

.usr-sort {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-family: inherit;
  color: var(--clr-text-primary);
  background: var(--clr-bg-card);
  cursor: pointer;
  outline: none;
  transition: border-color var(--t-fast);
}
.usr-sort:focus {
  border-color: var(--clr-info);
}
.usr-sort option {
  background: var(--clr-bg-card);
  color: var(--clr-text-primary);
}

.usr-results-count {
  font-size: var(--fs-sm);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Client card grid */
.usr-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}
@media (min-width: 540px) {
  .usr-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px) {
  .usr-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1280px) {
  .usr-grid { grid-template-columns: repeat(4, 1fr); }
}

/* Client card */
.usr-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  cursor: pointer;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.usr-card:hover {
  border-color: var(--clr-info);
  box-shadow: var(--shadow-md);
}

.usr-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-2);
}

.usr-card__name {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
  color: var(--clr-text-primary);
  line-height: 1.3;
  word-break: break-word;
}

.usr-card__badge {
  flex-shrink: 0;
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  padding: 2px var(--sp-2);
  white-space: nowrap;
}

.usr-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.usr-card__row {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
}

.usr-card__ic {
  font-size: var(--fs-xs);
  flex-shrink: 0;
  opacity: .7;
}

.usr-card__phone {
  color: var(--clr-text-primary);
  font-size: var(--fs-sm);
}

.usr-card__email {
  font-size: var(--fs-sm);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.usr-card__dates {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: var(--fs-xs);
  margin-top: var(--sp-1);
}

.usr-card__foot {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.usr-card__total {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
}

.usr-card__actions {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.usr-act {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: 4px var(--sp-2);
  border-radius: var(--r-sm);
  cursor: pointer;
  font-family: inherit;
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-elevated);
  color: var(--clr-text-secondary);
  transition: all var(--t-fast);
}
.usr-act:hover {
  border-color: var(--clr-info);
  color: var(--clr-info);
}

.usr-act--open {
  color: var(--clr-info);
  border-color: var(--clr-info);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  padding: 4px var(--sp-2);
}
.usr-act--open:hover {
  background: var(--clr-info);
  color: #fff;
}

/* ============================================================
   USER DETAIL PAGE
   ============================================================ */

.usr-detail {
  max-width: 800px;
}

.usr-detail__head {
  margin-bottom: var(--sp-5);
}

.usr-detail__name {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  font-family: var(--font-display);
  color: var(--clr-text-primary);
  line-height: 1.2;
  margin-bottom: var(--sp-2);
}

.usr-detail__phone {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-md);
}

.usr-detail__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
@media (min-width: 540px) {
  .usr-detail__stats { grid-template-columns: repeat(4, 1fr); }
}

.usr-detail__stat {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  text-align: center;
}

.usr-detail__stat-val {
  font-size: var(--fs-md);
  font-weight: var(--fw-extrabold);
  font-family: var(--font-display);
  color: var(--clr-text-primary);
  line-height: 1.2;
  word-break: break-all;
}

.usr-detail__stat-lbl {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: var(--sp-1);
  font-weight: var(--fw-medium);
}

/* Client orders list */
.usr-ord-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.usr-ord-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto auto;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.usr-ord-row:hover {
  border-color: var(--clr-info);
  background: var(--clr-bg-card);
}

.usr-ord-row__num {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  min-width: 90px;
}

.usr-ord-row__status {
  /* badge inline */
}

.usr-ord-row__date {
  font-size: var(--fs-xs);
  white-space: nowrap;
}

.usr-ord-row__total {
  font-size: var(--fs-sm);
  text-align: right;
  white-space: nowrap;
}

.usr-ord-row__arrow {
  font-size: var(--fs-sm);
}

@media (max-width: 539px) {
  .usr-ord-row {
    grid-template-columns: 1fr auto auto;
    grid-template-rows: auto auto;
  }
  .usr-ord-row__num  { grid-column: 1; }
  .usr-ord-row__status { grid-column: 2; }
  .usr-ord-row__arrow  { grid-column: 3; }
  .usr-ord-row__date   { grid-column: 1; grid-row: 2; }
  .usr-ord-row__total  { grid-column: 2; grid-row: 2; }
}

/* ---- Show-more button (orders history & activity) ---- */
.btn-show-more {
  display: block;
  width: 100%;
  margin-top: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: none;
  border: 1px dashed var(--clr-border);
  border-radius: var(--r-md);
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast);
  text-align: center;
}
.btn-show-more:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}

/* usr-card__badge with text (orders count) */
.usr-card__badge {
  min-width: unset;
}

/* ============================================================
   SMOOTH TRANSITIONS
   ============================================================ */

.usr-grid {
  animation: fadeIn 0.3s ease-in;
}

.pager {
  animation: slideUp 0.3s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================================
   CLIENT STATUS & VISUAL EMPHASIS
   ============================================================ */

.usr-card__status-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  margin-bottom: 2px;
}

.usr-card--vip {
  border: 2px solid #d4af37;
  background: linear-gradient(135deg, rgba(212,175,55,.05) 0%, transparent 100%);
}
.usr-card--vip .usr-card__status-label {
  color: #b8860b;
}

.usr-card--постоянный {
  border-left: 4px solid var(--clr-info);
}
.usr-card--постоянный .usr-card__status-label {
  color: var(--clr-info);
}

.usr-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-2);
}

.usr-card__head > div {
  flex: 1;
}

.usr-card__badge {
  flex-shrink: 0;
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  padding: 4px var(--sp-3);
  white-space: nowrap;
  text-align: center;
  min-width: 45px;
}

/* ============================================================
   CLIENT DETAIL: STATUS & ACTIVITY
   ============================================================ */

.usr-detail__status {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  padding: 6px var(--sp-3);
  border-radius: var(--r-full);
  margin-bottom: var(--sp-2);
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-secondary);
}

.usr-detail__status--vip {
  background: linear-gradient(135deg, rgba(212,175,55,.1) 0%, transparent 100%);
  border-color: #d4af37;
  color: #b8860b;
}

.usr-detail__status--repeat {
  background: linear-gradient(135deg, rgba(59,130,246,.1) 0%, transparent 100%);
  border-color: var(--clr-info);
  color: var(--clr-info);
}

.usr-detail__status--new {
  background: linear-gradient(135deg, rgba(34,197,94,.1) 0%, transparent 100%);
  border-color: var(--clr-success);
  color: var(--clr-success);
}

/* ---- Active orders block ---- */
.usr-active-orders {
  border-color: var(--clr-warning-border);
  background: linear-gradient(135deg, var(--clr-warning-bg) 0%, var(--clr-bg-card) 60%);
}

.usr-active-orders__title {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--clr-warning-text);
}

.usr-active-orders__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  background: var(--clr-bg-card);
  color: #92400e;
  border: 1px solid var(--clr-warning-border);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  font-family: var(--font-primary);
}

.usr-active-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.usr-active-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.usr-active-card:hover {
  border-color: var(--clr-warning-border);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.usr-active-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}

.usr-active-card__num {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  font-family: 'Courier New', monospace;
  color: var(--clr-accent);
  text-decoration: none;
}
.usr-active-card__num:hover { text-decoration: underline; }

.usr-active-card__badges {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  flex-wrap: wrap;
}

.usr-active-card__meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-2) var(--sp-4);
  margin-bottom: var(--sp-3);
  font-size: var(--fs-sm);
}
@media (min-width: 540px) {
  .usr-active-card__meta { grid-template-columns: repeat(3, 1fr); }
}

.usr-active-card__meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.usr-active-card__meta-item--wide {
  grid-column: 1 / -1;
}

.usr-active-card__meta-label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: var(--fw-medium);
}

.usr-active-card__total {
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
}

.usr-active-card__actions {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--clr-border);
}

/* Activity timeline */
.usr-activity {
  list-style: none;
  padding: 0;
  margin: 0;
  position: relative;
}

.usr-activity::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--clr-border);
}

.usr-activity__item {
  margin-bottom: var(--sp-4);
  padding-left: var(--sp-8);
  position: relative;
}

.usr-activity__date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
  margin-bottom: 4px;
}

.usr-activity__marker {
  position: absolute;
  left: 6px;
  top: 2px;
  width: 20px;
  height: 20px;
  border-radius: var(--r-full);
  background: var(--clr-bg-card);
  border: 3px solid var(--clr-border-hover);
}
.usr-activity__marker--created {
  border-color: var(--clr-accent);
}
.usr-activity__marker--status {
  border-color: var(--clr-info);
}

.usr-activity__content {
  background: var(--clr-bg-elevated);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
}

/* Тип события (иконка + метка) */
.usr-activity__type {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--sp-1);
}

/* Описание (переход статусов или название события) */
.usr-activity__desc {
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  font-weight: var(--fw-medium);
}

/* Ссылка на заказ */
.usr-activity__order-link {
  display: inline-block;
  margin-top: 6px;
  font-size: var(--fs-xs);
  font-family: 'Courier New', monospace;
  font-weight: var(--fw-semibold);
  color: var(--clr-accent);
  padding: 2px 8px;
  background: var(--clr-accent-glow);
  border-radius: var(--r-sm);
  text-decoration: none;
  transition: opacity var(--t-fast);
}
.usr-activity__order-link:hover { opacity: 0.75; }

/* ============================================================
   TOPBAR v2 — компактная шапка
   ============================================================ */

/* Мобильный заголовок страницы — truncate при нехватке места */
.topbar__title--mobile {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 1;
  min-width: 0;
}

/* Бейдж роли (всегда виден) */
.topbar__role {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  border: 1px solid transparent;
  line-height: 1.2;
  flex-shrink: 0;
}
.topbar__role--superadmin {
  background: var(--clr-info-bg);
  color: var(--clr-info-text);
  border-color: var(--clr-info-border);
}
.topbar__role--manager {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}

/* Имя пользователя в топбаре (только десктоп) */
.topbar__uname {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  white-space: nowrap;
  display: none;
}

/* Кнопка выхода — иконка на мобиле, иконка+текст на десктопе */
.topbar__logout {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: transparent;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
  white-space: nowrap;
  font-family: inherit;
  flex-shrink: 0;
  line-height: 1;
}
.topbar__logout:hover {
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
  background: var(--clr-danger-bg);
}
.topbar__logout-label {
  display: none;
}

/* ---- Десктоп: раскрыть имя + текст кнопки ---- */
@media (min-width: 900px) {
  .topbar__uname        { display: block; }
  .topbar__logout-label { display: inline; }
}
/* Компактный диапазон — только кнопка без имени */
@media (min-width: 900px) and (max-width: 1099px) {
  .topbar__uname { display: none !important; }
}

/* ============================================================
   МОБИЛЬ: убрать дублирующий H1 (уже есть в topbar__title)
   ============================================================ */
@media (max-width: 899px) {
  .page-head h1 {
    display: none;
  }
  /* Если в page-head только h1 — убрать нижний отступ */
  .page-head:not(:has(> *:not(h1))) {
    margin-bottom: 0;
  }
  /* Чуть меньше padding у main на мобиле — контент начинается выше */
  .main {
    padding-top: var(--sp-3);
  }
}

/* ============================================================
   SIDEBAR v2 — шапка с брендом и кнопкой закрытия
   ============================================================ */
.sidebar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) var(--sp-2) var(--sp-4);
}
.sidebar__brand-text {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: var(--fs-xl);
  color: var(--clr-accent);
  letter-spacing: -0.02em;
}
.sidebar__close {
  background: transparent;
  border: none;
  font-size: var(--fs-md);
  color: var(--clr-text-muted);
  cursor: pointer;
  padding: var(--sp-1) var(--sp-2);
  line-height: 1;
  border-radius: var(--r-sm);
  transition: color var(--t-fast), background var(--t-fast);
}
.sidebar__close:hover {
  color: var(--clr-text-primary);
  background: var(--clr-bg-elevated);
}

/* ---- Секция пользователя ---- */
.sidebar__user {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
  background: var(--clr-bg-elevated);
  border-radius: var(--r-lg);
  border: 1px solid var(--clr-border);
}
.sidebar__avatar {
  width: 38px;
  height: 38px;
  border-radius: var(--r-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  color: #fff;
  flex-shrink: 0;
  letter-spacing: 0.02em;
}
.sidebar__avatar--superadmin { background: var(--gradient-blue); }
.sidebar__avatar--manager    { background: linear-gradient(135deg, #059669 0%, #047857 100%); }

.sidebar__user-info { min-width: 0; }
.sidebar__user-name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sidebar__user-role {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: 2px;
}

/* ---- Группировка навигации (superadmin) ---- */
.nav__group {
  margin-bottom: var(--sp-2);
}
.nav__group:last-child {
  margin-bottom: 0;
}
.nav__group-label {
  font-size: 10px;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--clr-text-muted);
  padding: 0 var(--sp-3);
  margin-bottom: 2px;
}

/* Активный пункт — левый акцентный кант */
.nav a.is-active {
  border-left: 3px solid var(--clr-accent);
  padding-left: calc(var(--sp-3) - 3px);
}

/* ---- Кнопка выхода в сайдбаре ---- */
.sidebar__logout {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  background: transparent;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
  font-family: inherit;
}
.sidebar__logout:hover {
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
  background: var(--clr-danger-bg);
}

/* ============================================================
   DIAGNOSTICS BANNER & MODAL
   ============================================================ */

/* Баннер-сводка на дашборде */
.diag-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-lg);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-4);
  border: 1px solid transparent;
  text-align: left;
  font-family: inherit;
  cursor: default;
  transition: filter var(--t-fast);
}

/* Состояние «всё хорошо» */
.diag-banner--ok {
  background: var(--clr-success-bg, #f0fdf4);
  color: var(--clr-success-dark, #15803d);
  border-color: var(--clr-success-border, #bbf7d0);
}

/* Предупреждение (warning-severity issues) */
.diag-banner--warn {
  background: var(--clr-warning-bg, #fffbeb);
  color: var(--clr-warning-dark, #b45309);
  border-color: var(--clr-warning-border, #fde68a);
  cursor: pointer;
}
.diag-banner--warn:hover { filter: brightness(0.95); }

/* Информационное (только info-severity issues) */
.diag-banner--info {
  background: var(--clr-info-bg, #eff6ff);
  color: var(--clr-info-text, #1d4ed8);
  border-color: var(--clr-info-border, #bfdbfe);
  cursor: pointer;
}
.diag-banner--info:hover { filter: brightness(0.95); }

.diag-banner__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: currentColor;
}
.diag-banner__dot--ok { background: var(--clr-success-dark, #15803d); }

.diag-banner__arrow {
  margin-left: auto;
  opacity: 0.7;
}

/* Карточки проблем внутри модального окна */
.diag-modal { max-width: 600px; }

.diag-modal__body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: 0;
}

.diag-card {
  border-radius: var(--r-md);
  border: 1px solid transparent;
  padding: var(--sp-3) var(--sp-4);
}

.diag-card--warning {
  background: var(--clr-warning-bg, #fffbeb);
  border-color: var(--clr-warning-border, #fde68a);
}

.diag-card--info {
  background: var(--clr-info-bg, #eff6ff);
  border-color: var(--clr-info-border, #bfdbfe);
}

.diag-card__head {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-1);
}

.diag-card__icon {
  font-size: var(--fs-base);
  flex-shrink: 0;
}

.diag-card__number {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
}

.diag-card__msg {
  margin: 0 0 var(--sp-3) 0;
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  line-height: 1.4;
}

/* ============================================================
   ORDERS TOOLBAR — поиск + фильтр статуса
   ============================================================ */
.ord-toolbar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

/* Обёртка поиска — относительный контейнер для кнопки ✕ */
.ord-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.ord-search {
  width: 100%;
  padding: var(--sp-3) var(--sp-10) var(--sp-3) var(--sp-4);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  font-size: var(--fs-base);
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
  /* Убираем дефолтный крестик браузера — у нас свой */
  appearance: none;
}
.ord-search::-webkit-search-cancel-button { display: none; }
.ord-search:focus {
  outline: none;
  border-color: var(--clr-accent);
  background: var(--clr-bg-card);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--clr-accent) 12%, transparent);
}
.ord-search::placeholder { color: var(--clr-text-muted); }

/* Кнопка очистки внутри поля */
.ord-search-clear {
  position: absolute;
  right: var(--sp-3);
  top: 50%;
  transform: translateY(-50%);
  padding: var(--sp-1) var(--sp-2);
  border: none;
  background: transparent;
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
  cursor: pointer;
  line-height: 1;
  border-radius: var(--r-sm);
  transition: color var(--t-fast), background var(--t-fast);
}
.ord-search-clear:hover {
  color: var(--clr-text-primary);
  background: var(--clr-bg-elevated);
}

/* Вторая строка тулбара: фильтр + кнопка обновить */
.ord-toolbar-row2 {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
}
.ord-status-filter {
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  font-size: var(--fs-sm);
  flex: 1;
}

/* Desktop: строка 1 = поиск, строка 2 = фильтр + кнопка в ряд */
@media (min-width: 640px) {
  .ord-toolbar {
    flex-direction: column;
    gap: var(--sp-2);
  }
  .ord-search {
    font-size: var(--fs-base);
  }
  .ord-status-filter {
    flex: 0 0 auto;
    min-width: 180px;
  }
}

/* Мобиль: поиск прилипает вверху при прокрутке */
@media (max-width: 639px) {
  .ord-toolbar {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--clr-bg-primary);
    padding: var(--sp-2) 0 var(--sp-1);
    margin-bottom: var(--sp-3);
    border-bottom: 1px solid var(--clr-border);
  }
  .ord-search {
    font-size: 1rem;
  }
}

/* Пустое состояние при поиске */
.ord-not-found {
  text-align: center;
  padding: var(--sp-10) var(--sp-4);
}
.ord-not-found strong {
  display: block;
  font-size: var(--fs-lg);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}
.ord-not-found__hint {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  max-width: 360px;
  margin: 0 auto;
  line-height: 1.5;
}

/* ============================================================
   THEME TOGGLE — переключатель светлой/тёмной темы
   ============================================================ */

/* ---- Сайдбар (мобиль) ---- */
.sidebar__theme-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  background: transparent;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  cursor: pointer;
  font-family: inherit;
  margin-bottom: var(--sp-2);
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}
.sidebar__theme-btn:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
  background: var(--clr-accent-glow);
}

/* ---- Топбар (десктоп) ---- */
.topbar__theme-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  color: var(--clr-text-secondary);
  cursor: pointer;
  flex-shrink: 0;
  font-family: inherit;
  transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}
.topbar__theme-btn:hover {
  border-color: var(--clr-border-hover);
  color: var(--clr-text-primary);
  background: var(--clr-bg-elevated);
}
@media (min-width: 900px) {
  .topbar__theme-btn { display: inline-flex; }
}

/* ============================================================
   DARK THEME — исправление hardcoded цветов
   ============================================================ */

/* Person card avatars — ярче на тёмном фоне */
[data-theme="dark"] .person-avatar--manager {
  background: linear-gradient(135deg, #34d399 0%, #059669 100%);
  box-shadow: 0 2px 12px rgba(52, 211, 153, 0.35);
}
[data-theme="dark"] .person-avatar--blocked {
  background: linear-gradient(135deg, #6b7280 0%, #4b5563 100%);
}
[data-theme="dark"] .person-avatar--superadmin {
  box-shadow: 0 2px 12px rgba(59, 130, 246, 0.35);
}

/* Buttons — hover'ы с хардкодными светлыми цветами */
[data-theme="dark"] .btn--danger {
  background: #dc2626;
  color: #fff;
  border-color: transparent;
}
[data-theme="dark"] .btn--danger:hover { background: #b91c1c; }

[data-theme="dark"] .btn--warn {
  background: rgba(251, 191, 36, 0.18);
  color: var(--clr-warning);
  border-color: rgba(251, 191, 36, 0.35);
}
[data-theme="dark"] .btn--warn:hover {
  background: rgba(251, 191, 36, 0.28);
  color: #fde68a;
}

[data-theme="dark"] .btn--success {
  background: rgba(52, 211, 153, 0.18);
  color: var(--clr-success);
  border-color: rgba(52, 211, 153, 0.35);
}
[data-theme="dark"] .btn--success:hover {
  background: rgba(52, 211, 153, 0.28);
  color: #a7f3d0;
}

/* Ghost button — более заметная рамка и hover-фон */
[data-theme="dark"] .btn--ghost {
  border-color: rgba(255, 255, 255, 0.18);
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .btn--ghost:hover {
  border-color: rgba(255, 255, 255, 0.30);
  background: rgba(255, 255, 255, 0.05);
  color: var(--clr-text-primary);
}

/* Primary — чуть ярче */
[data-theme="dark"] .btn--primary { box-shadow: 0 1px 8px rgba(232, 32, 47, 0.35); }
[data-theme="dark"] .btn--primary:hover { box-shadow: 0 2px 12px rgba(232, 32, 47, 0.5); }

/* Blocked card — чуть более читаем в тёмном, т.к. контраст ниже */
[data-theme="dark"] .person-card--blocked { opacity: 0.5; }

/* Role picker — более явная подсветка в тёмном */
[data-theme="dark"] .role-option:hover:not(.is-selected) {
  background: rgba(255, 255, 255, 0.04);
}
[data-theme="dark"] .role-option[data-role="manager"].is-selected {
  border-color: var(--clr-success);
  background: rgba(52, 211, 153, 0.12);
}
[data-theme="dark"] .role-option[data-role="superadmin"].is-selected {
  border-color: var(--clr-info);
  background: rgba(96, 165, 250, 0.12);
}

/* Warning banner inside modals — тёмный фон */
[data-theme="dark"] .warning-banner {
  background: rgba(251, 191, 36, 0.08);
  border-color: rgba(251, 191, 36, 0.2);
  color: var(--clr-warning-text);
}

/* Delivery / pickup badges */
[data-theme="dark"] .badge--delivery {
  background: rgba(59, 130, 246, 0.15);
  color: #93c5fd;
  border-color: rgba(59, 130, 246, 0.3);
}
[data-theme="dark"] .badge--pickup {
  background: rgba(52, 211, 153, 0.15);
  color: #6ee7b7;
  border-color: rgba(52, 211, 153, 0.3);
}

/* VIP клиент — золотой акцент адаптирован под тёмный фон */
[data-theme="dark"] .usr-card--vip {
  border-color: #d4b44a;
  background: linear-gradient(135deg, rgba(212, 180, 74, 0.10) 0%, transparent 100%);
}
[data-theme="dark"] .usr-card--vip .usr-card__status-label {
  color: #d4b44a;
}
[data-theme="dark"] .usr-detail__status--vip {
  border-color: #d4b44a;
  color: #d4b44a;
  background: linear-gradient(135deg, rgba(212, 180, 74, 0.12) 0%, transparent 100%);
}

/* ============================================================
   SECURITY PAGE (полностью переработанный раздел)
   ============================================================ */

.sec {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

/* ── Security status banner ── */
.sec-status {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--r-xl);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  border: 1px solid transparent;
  line-height: 1.5;
}
.sec-status__icon { font-size: var(--fs-lg); flex-shrink: 0; }
.sec-status--ok {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}
.sec-status--warn, .sec-status--info {
  background: var(--clr-warning-bg);
  color: var(--clr-warning-text);
  border-color: var(--clr-warning-border);
}
.sec-status--danger {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}

/* ── Summary cards ── */
.sec-summary {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}
@media (min-width: 640px) {
  .sec-summary { grid-template-columns: repeat(4, 1fr); }
}

.sec-summary-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  transition: box-shadow var(--t-fast), border-color var(--t-fast);
}

.sec-summary-card--clickable {
  cursor: pointer;
}
.sec-summary-card--clickable:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-border-hover);
}

.sec-summary-card__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--clr-text-muted);
}

.sec-summary-card__value {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  font-family: var(--font-display);
  color: var(--clr-text-primary);
  line-height: 1;
}

.sec-summary-card__date {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  line-height: 1.2;
}

.sec-summary-card__time {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  line-height: 1.2;
}

.sec-summary-card__sub {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  line-height: 1.4;
}

.sec-summary-card--warn .sec-summary-card__value {
  color: var(--clr-danger-text);
}

/* ── Section wrapper ── */
.sec-section {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-xl);
  padding: var(--sp-5) var(--sp-6);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}
@media (max-width: 639px) {
  .sec-section { padding: var(--sp-4); }
  .sec-summary-card { padding: var(--sp-4); }
}

.sec-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
  flex-wrap: wrap;
}

.sec-section__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin: 0;
}

.sec-section__desc {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  margin: 0 0 var(--sp-5);
  line-height: 1.5;
  max-width: 560px;
}

/* ── Session cards ── */
.sec-sessions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.sec-session-card {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.sec-session-card:hover {
  border-color: var(--clr-border-hover);
  box-shadow: var(--shadow-sm);
}
.sec-session-card--current {
  border-color: var(--clr-blue);
  background: var(--clr-blue-glow);
}

.sec-session-card__icon {
  font-size: var(--fs-2xl);
  flex-shrink: 0;
  width: 40px;
  text-align: center;
  line-height: 1;
}

.sec-session-card__body {
  flex: 1;
  min-width: 0;
}

.sec-session-card__device {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin-bottom: 2px;
  word-break: break-word;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.sec-session-card__line {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  margin-bottom: 1px;
}

.sec-session-card__meta {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  flex-wrap: wrap;
}

.sec-session-card__ip {
  font-family: 'Courier New', monospace;
  font-size: 11px;
}

.sec-session-card__rel {
  color: var(--clr-text-secondary);
  font-size: 11px;
  font-weight: var(--fw-medium);
}

.sec-session-card__sep {
  color: var(--clr-text-muted);
  opacity: 0.5;
}

.sec-session-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  background: var(--clr-blue-glow);
  color: var(--clr-blue);
  border: 1px solid var(--clr-blue);
}

.sec-session-card__actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}
@media (max-width: 480px) {
  .sec-session-card {
    flex-wrap: wrap;
  }
  .sec-session-card__actions {
    width: 100%;
    justify-content: flex-end;
    padding-top: var(--sp-2);
    border-top: 1px solid var(--clr-border);
  }
}

/* ── Login timeline ── */
.sec-timeline {
  display: flex;
  flex-direction: column;
}

.sec-event {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  position: relative;
}
.sec-event::before {
  content: '';
  position: absolute;
  left: 13px;
  top: 36px;
  bottom: 0;
  width: 2px;
  background: var(--clr-border);
}
.sec-event:last-child::before { display: none; }

.sec-event__icon {
  width: 28px;
  height: 28px;
  border-radius: var(--r-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: #fff;
  z-index: 1;
  flex-shrink: 0;
}
.sec-event__icon--ok {
  background: var(--clr-success);
  box-shadow: 0 0 6px rgba(34, 197, 94, 0.4);
}
.sec-event__icon--fail {
  background: var(--clr-danger-text);
  box-shadow: 0 0 6px rgba(239, 68, 68, 0.4);
}

.sec-event__body { min-width: 0; }

.sec-event__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}
.sec-event__title--fail { color: var(--clr-danger-text); }

.sec-event__reason {
  font-size: var(--fs-xs);
  color: var(--clr-danger-text);
  margin-top: 1px;
}

.sec-event__meta {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  flex-wrap: wrap;
}

.sec-event__date {
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
}

.sec-event__time {
  color: var(--clr-text-muted);
}

.sec-event__sep-dot {
  color: var(--clr-text-muted);
  opacity: 0.5;
}

.sec-event__ip {
  font-family: 'Courier New', monospace;
  font-size: 11px;
  color: var(--clr-text-secondary);
  opacity: 0.8;
}

.sec-timeline__empty {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  padding: var(--sp-3) 0;
}

/* ── Blocks ── */
.sec-blocks {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.sec-block-card {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
}

.sec-block-card__icon {
  font-size: var(--fs-xl);
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-danger-bg);
  border-radius: var(--r-full);
  color: var(--clr-danger-text);
}

.sec-block-card__body { flex: 1; min-width: 0; }

.sec-block-card__key {
  font-family: 'Courier New', monospace;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  word-break: break-all;
}

.sec-block-card__meta {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

.sec-blocks__empty {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  padding: var(--sp-3) 0;
}

/* ── Session TTL settings ── */
.sec-settings-row {
  display: flex;
  align-items: flex-end;
  gap: var(--sp-4);
  flex-wrap: wrap;
}

.sec-settings-field {
  max-width: 200px;
}

.sec-settings-field input {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast);
}
.sec-settings-field input:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}

.sec-settings-field__label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  margin-bottom: var(--sp-2);
}

.sec-settings-field__hint {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
}

.sec-settings-msg {
  font-size: var(--fs-sm);
  min-height: 1.2em;
}
.sec-settings-msg--ok { color: var(--clr-success-dark); }
.sec-settings-msg--err { color: var(--clr-danger-text); }

/* ── Revoke others button area ── */
.sec-sessions-foot {
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
  display: flex;
  justify-content: flex-end;
}

/* ── Toast notification ── */
.sec-toast {
  position: fixed;
  bottom: var(--sp-6);
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--clr-success-dark, #15803d);
  color: #fff;
  padding: var(--sp-3) var(--sp-6);
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-modal, 1000);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  white-space: nowrap;
}
.sec-toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ============================================================
   DARK THEME — security page overrides
   ============================================================ */
[data-theme="dark"] .sec-session-card--current {
  background: rgba(96, 165, 250, 0.10);
}
[data-theme="dark"] .sec-session-card__meta {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-event__meta {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-event__time {
  color: var(--clr-text-muted);
}
[data-theme="dark"] .sec-event__ip {
  opacity: 0.9;
}
[data-theme="dark"] .sec-summary-card__sub {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-summary-card__time {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-block-card__meta {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-session-card__line {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-section__desc {
  color: var(--clr-text-secondary);
}
[data-theme="dark"] .sec-toast {
  background: #15803d;
}

/* ============================================================
   EVENTS FEED — unified audit log
   ============================================================ */

.ev-page {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

/* ── Stats bar ──────────────────────────────────────────────── */
.ev-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}
@media (min-width: 640px) {
  .ev-stats { grid-template-columns: repeat(4, 1fr); }
}

.ev-stat {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  box-shadow: var(--shadow-sm);
}
.ev-stat--alert {
  background: var(--clr-danger-bg);
  border-color: var(--clr-danger-border);
}
.ev-stat__value {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: 1;
}
.ev-stat__value--accent { color: var(--clr-accent); }
.ev-stat__value--info    { color: var(--clr-info-text); }
.ev-stat__value--danger  { color: var(--clr-danger-text); }
.ev-stat__label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: var(--fw-medium);
}

/* ── Toolbar ────────────────────────────────────────────────── */
.ev-toolbar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
@media (min-width: 768px) {
  .ev-toolbar {
    flex-direction: row;
    align-items: center;
    gap: var(--sp-4);
  }
}

/* Filter pills */
.ev-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  flex-shrink: 0;
}

.ev-pill {
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-full);
  border: 1px solid var(--clr-border);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: all var(--t-fast);
  white-space: nowrap;
}
.ev-pill:hover {
  border-color: var(--clr-border-hover);
  color: var(--clr-text-primary);
  background: var(--clr-bg-elevated);
}
.ev-pill--active {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: #fff;
}
.ev-pill--active:hover {
  background: var(--clr-accent-hover);
  border-color: var(--clr-accent-hover);
  color: #fff;
}

/* Search */
.ev-search-wrap {
  position: relative;
  flex: 1;
  min-width: 200px;
}
.ev-search {
  width: 100%;
  padding: var(--sp-2) var(--sp-4);
  padding-right: var(--sp-10);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-full);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  font-size: var(--fs-sm);
  font-family: inherit;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.ev-search:focus {
  outline: none;
  border-color: var(--clr-accent);
  background: var(--clr-bg-card);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}
.ev-search::placeholder { color: var(--clr-text-muted); }
.ev-search-clear {
  position: absolute;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  font-size: var(--fs-lg);
  color: var(--clr-text-muted);
  cursor: pointer;
  padding: var(--sp-1);
  line-height: 1;
}
.ev-search-clear:hover { color: var(--clr-text-primary); }

/* ── Feed ───────────────────────────────────────────────────── */
.ev-feed {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

/* ── Event card ─────────────────────────────────────────────── */
.ev-card {
  display: flex;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-left-width: 4px;
  border-left-color: var(--clr-border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: box-shadow var(--t-fast), transform var(--t-fast), border-color var(--t-fast);
}
.ev-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.ev-card:focus-visible {
  outline: 2px solid var(--clr-accent);
  outline-offset: 2px;
}

/* Severity border colors */
.ev-card--success { border-left-color: var(--clr-success); }
.ev-card--warning { border-left-color: var(--clr-warning); }
.ev-card--error   { border-left-color: var(--clr-danger); }
.ev-card--info    { border-left-color: var(--clr-info-text); }

.ev-card__indicator {
  flex-shrink: 0;
  padding-top: 3px;
}

.ev-dot {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--clr-text-muted);
  flex-shrink: 0;
}
.ev-dot--success { background: var(--clr-success); box-shadow: 0 0 6px rgba(34, 197, 94, 0.4); }
.ev-dot--warning { background: var(--clr-warning); box-shadow: 0 0 6px rgba(245, 158, 11, 0.4); }
.ev-dot--error   { background: var(--clr-danger);  box-shadow: 0 0 6px rgba(239, 68, 68, 0.4); }
.ev-dot--info    { background: var(--clr-info-text); box-shadow: 0 0 6px rgba(59, 130, 246, 0.4); }

.ev-card__body {
  flex: 1;
  min-width: 0;
}

.ev-card__top {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  margin-bottom: var(--sp-2);
}
@media (min-width: 540px) {
  .ev-card__top {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.ev-card__title-row {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.ev-category-tag {
  display: inline-block;
  padding: 1px 8px;
  border-radius: var(--r-sm);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid transparent;
  line-height: 1.5;
}
.ev-category-tag--security {
  background: var(--clr-warning-bg);
  color: var(--clr-warning-text);
  border-color: var(--clr-warning-border);
}
.ev-category-tag--orders {
  background: var(--clr-info-bg);
  color: var(--clr-info-text);
  border-color: var(--clr-info-border);
}
.ev-category-tag--admins {
  background: var(--clr-success-bg);
  color: var(--clr-success-text);
  border-color: var(--clr-success-border);
}
.ev-category-tag--system {
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
  border-color: var(--clr-border);
}
.ev-category-tag--error {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border-color: var(--clr-danger-border);
}

.ev-card__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  line-height: 1.4;
}

.ev-card__date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

.ev-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-1);
}

.ev-card__meta-item {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  padding: 1px 8px;
  background: var(--clr-bg-secondary);
  border-radius: var(--r-sm);
  border: 1px solid var(--clr-border);
}
.ev-card__meta-admin {
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
}
.ev-card__meta-ip {
  font-family: 'Courier New', monospace;
  font-size: 11px;
}
.ev-card__meta-entity[data-link] {
  color: var(--clr-info-text);
  text-decoration: none;
  cursor: pointer;
  transition: color var(--t-fast), background var(--t-fast);
}
.ev-card__meta-entity[data-link]:hover {
  color: var(--clr-accent);
  background: var(--clr-accent-glow);
  border-color: var(--clr-accent);
}

.ev-card__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: 1.4;
  margin-top: var(--sp-1);
}

/* Status change pill */
.ev-card__change {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
  padding: var(--sp-1) var(--sp-2);
  background: var(--clr-bg-secondary);
  border-radius: var(--r-md);
  border: 1px solid var(--clr-border);
  font-size: var(--fs-xs);
  flex-wrap: wrap;
}
.ev-card__change-old {
  color: var(--clr-text-muted);
  text-decoration: line-through;
}
.ev-card__change-arrow {
  color: var(--clr-text-muted);
  font-weight: var(--fw-bold);
}
.ev-card__change-new {
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}

/* ── Empty state ────────────────────────────────────────────── */
.ev-empty {
  text-align: center;
  padding: var(--sp-12) var(--sp-4);
  color: var(--clr-text-muted);
}
.ev-empty__ico {
  font-size: 2.5rem;
  margin-bottom: var(--sp-3);
  opacity: 0.5;
}
.ev-empty__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-secondary);
  margin-bottom: var(--sp-1);
}
.ev-empty__hint {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
}

/* ── Load more ──────────────────────────────────────────────── */
.ev-more {
  text-align: center;
  padding: var(--sp-4) 0;
}
.ev-more .btn { min-width: 200px; }

/* ── Detail modal ───────────────────────────────────────────── */
.ev-detail {
  max-width: 560px;
}
.ev-detail__body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.ev-detail__row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--sp-2) var(--sp-3);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
@media (max-width: 480px) {
  .ev-detail__row {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.ev-detail__label {
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
}
.ev-detail__value {
  color: var(--clr-text-primary);
  word-break: break-word;
}
.ev-detail__value code {
  font-family: 'Courier New', monospace;
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
}

/* ============================================================
   DARK THEME overrides for event feed
   ============================================================ */
[data-theme="dark"] .ev-stat--alert {
  background: rgba(239, 68, 68, 0.15);
  border-color: rgba(239, 68, 68, 0.3);
}
[data-theme="dark"] .ev-card__meta-item {
  background: var(--clr-bg-elevated);
}
[data-theme="dark"] .ev-card__change {
  background: var(--clr-bg-elevated);
}
[data-theme="dark"] .ev-category-tag--system {
  background: var(--clr-bg-elevated);
  color: var(--clr-text-muted);
  border-color: var(--clr-border);
}


/* ============================================================
   SETTINGS REDESIGN — 2026-06-25
   ============================================================ */

/* ── Settings layout ──────────────────────────────────────── */
.settings-page { max-width: 940px; }

.settings-card {
  background: var(--clr-bg-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-6);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-5);
  transition: box-shadow var(--t-fast);
}

/* ── Card header ──────────────────────────────────────────── */
.settings-card__header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--clr-border);
}
.settings-card__icon {
  width: 40px; height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-lg);
  background: var(--clr-accent-glow);
  font-size: 1.15rem;
  flex-shrink: 0;
  margin-top: 2px;
}
.settings-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin: 0 0 var(--sp-1);
  line-height: 1.3;
}
.settings-card__subtitle {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin: 0;
  line-height: 1.5;
}

/* ── Save row ─────────────────────────────────────────────── */
.sett-save-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--clr-border);
}

/* ── Field improvements ───────────────────────────────────── */
.settings-card .field { margin-bottom: 0; }
.settings-card label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  margin-bottom: var(--sp-2);
}
.settings-card input[type="text"],
.settings-card input[type="email"],
.settings-card input[type="tel"],
.settings-card input[type="number"],
.settings-card select {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-base);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  color: var(--clr-text-primary);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  font-family: inherit;
  box-sizing: border-box;
}
.settings-card input:focus,
.settings-card select:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}
.settings-card select { appearance: auto; }

/* ── Social link fields ───────────────────────────────────── */
.social-links-grid {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
@media (min-width: 640px) {
  .social-links-grid { flex-direction: row; }
  .social-link-field { flex: 1; }
}

.social-link-field {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  background: var(--clr-bg-secondary);
  transition: border-color var(--t-fast);
}
.social-link-field:focus-within {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px var(--clr-accent-glow);
}
.social-link-field__icon {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}
.social-link-field__icon--tg { background: #229ED9; }
.social-link-field__icon--wa { background: #25D366; }

.social-link-field__content { flex: 1; min-width: 0; }
.social-link-field__label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-1);
}
.social-link-field__input {
  width: 100%;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  outline: none;
  box-shadow: none !important;
  box-sizing: border-box;
}
.social-link-field__input::placeholder { color: var(--clr-text-muted); }

/* ── Param list (Заказы) ──────────────────────────────────── */
.sett-param-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sett-param {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--clr-border);
}
.sett-param:last-child { border-bottom: none; }
.sett-param__info { flex: 1; }
.sett-param__label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-1);
}
.sett-param__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: 1.5;
}
.sett-param__control {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
  min-width: 160px;
}
.sett-param__control .field { margin-bottom: 0; }
.sett-param__unit {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  white-space: nowrap;
}
@media (max-width: 639px) {
  .sett-param {
    flex-direction: column;
    align-items: flex-start;
  }
  .sett-param__control { width: 100%; min-width: 0; }
}

/* ── Notification channels ────────────────────────────────── */
.notif-channels {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
@media (min-width: 768px) {
  .notif-channels { flex-direction: row; }
  .notif-channel { flex: 1; }
}

.notif-channel {
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--clr-bg-secondary);
  transition: box-shadow var(--t-fast);
}
.notif-channel:hover { box-shadow: var(--shadow-md); }

.notif-channel__header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-4) var(--sp-3);
}
.notif-channel__icon {
  width: 44px; height: 44px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.notif-channel__icon--smtp { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); }
.notif-channel__icon--tg   { background: linear-gradient(135deg, #229ED9 0%, #1a7fc4 100%); }

.notif-channel__meta { flex: 1; min-width: 0; }
.notif-channel__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}
.notif-channel__server {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.notif-channel__badge {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
}
.notif-channel__badge--ok {
  background: var(--clr-success-bg);
  color: var(--clr-success-dark);
  border: 1px solid var(--clr-success-border);
}
.notif-channel__badge--err {
  background: var(--clr-danger-bg);
  color: var(--clr-danger-text);
  border: 1px solid var(--clr-danger-border);
}
.notif-channel__badge-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.notif-channel__badge--ok .notif-channel__badge-dot { background: var(--clr-success-dark); }
.notif-channel__badge--err .notif-channel__badge-dot { background: var(--clr-danger-text); }

.notif-channel__body {
  padding: var(--sp-3) var(--sp-4) var(--sp-4);
  border-top: 1px solid var(--clr-border);
}
.notif-channel__stats {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.notif-channel__stat {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-xs);
}
.notif-channel__stat-label { color: var(--clr-text-muted); }
.notif-channel__stat-value { color: var(--clr-text-primary); font-weight: var(--fw-medium); }

.notif-channel__actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

/* Hint for unconfigured channels */
.notif-hint {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  margin-top: var(--sp-4);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  line-height: 1.6;
}
.notif-hint__icon { font-size: 1rem; flex-shrink: 0; margin-top: 2px; }
.notif-hint code {
  font-family: monospace;
  font-size: 0.85em;
  padding: 1px 4px;
  background: var(--clr-bg-primary);
  border-radius: 3px;
  color: var(--clr-accent);
}

/* ── Status banner ────────────────────────────────────────── */
.status-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-lg);
  border: 1px solid;
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-5);
}
.status-banner--ok {
  background: var(--clr-success-bg);
  border-color: var(--clr-success-border);
  color: var(--clr-success-dark);
}
.status-banner--warn {
  background: var(--clr-warning-bg);
  border-color: var(--clr-warning-border);
  color: var(--clr-warning-dark, #b45309);
}
.status-banner--err {
  background: var(--clr-danger-bg);
  border-color: var(--clr-danger-border);
  color: var(--clr-danger-text);
}
.status-banner__icon { font-size: 1.4rem; flex-shrink: 0; }
.status-banner__text { flex: 1; }
.status-banner__refresh {
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--fs-md);
  color: inherit;
  opacity: 0.7;
  background: transparent;
  border: 1px solid currentColor;
  border-radius: var(--r-md);
  cursor: pointer;
  transition: opacity var(--t-fast);
}
.status-banner__refresh:hover { opacity: 1; }

/* ── DB Stats Grid ────────────────────────────────────────── */
.db-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-3);
}
@media (min-width: 640px) {
  .db-stats-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 960px) {
  .db-stats-grid { grid-template-columns: repeat(6, 1fr); }
}

.db-stat {
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  padding: var(--sp-3) var(--sp-4);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.db-stat--ok { border-color: var(--clr-success-border); }
.db-stat--err { border-color: var(--clr-danger-border); }

.db-stat__indicator {
  display: flex;
  justify-content: center;
  margin-bottom: var(--sp-2);
}
.db-stat__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  display: inline-block;
}
.db-stat__dot--ok { background: var(--clr-success-dark); box-shadow: 0 0 6px var(--clr-success-dark); }
.db-stat__dot--err { background: var(--clr-danger-text); box-shadow: 0 0 6px var(--clr-danger-text); }

.db-stat__value {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: 1.2;
  word-break: break-all;
}
.db-stat__label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  line-height: 1.3;
}

/* ── Resource bars ────────────────────────────────────────── */
.resource-bars {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}
.resource-bar__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--sp-2);
}
.resource-bar__label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
}
.resource-bar__value {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}
.resource-bar__value--warn { color: var(--clr-warning-dark, #b45309); }
.resource-bar__track {
  height: 8px;
  background: var(--clr-bg-secondary);
  border-radius: var(--r-full);
  overflow: hidden;
  border: 1px solid var(--clr-border);
}
.resource-bar__fill {
  height: 100%;
  background: var(--clr-accent);
  border-radius: var(--r-full);
  transition: width 0.5s ease;
  min-width: 2px;
}
.resource-bar__fill--warn { background: var(--clr-warning-dark, #b45309); }

/* ── System action items ──────────────────────────────────── */
.sett-actions-group {
  border: 1px solid var(--clr-border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.sett-action-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-bg-secondary);
}
.sett-action-item:last-child { border-bottom: none; }
.sett-action-item__info { flex: 1; }
.sett-action-item__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-1);
}
.sett-action-item__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: 1.5;
}
.sett-action-item__btn {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-shrink: 0;
}
@media (max-width: 639px) {
  .sett-action-item {
    flex-direction: column;
    align-items: flex-start;
  }
  .sett-action-item__btn { width: 100%; }
}

/* ── App info grid ────────────────────────────────────────── */
.app-info-grid {
  display: flex;
  flex-direction: column;
}
.app-info-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: var(--fs-sm);
}
.app-info-row:last-child { border-bottom: none; }
.app-info-row__label { color: var(--clr-text-muted); }
.app-info-row__value {
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
}
.app-info-row__value--badge {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--sp-2);
  background: var(--clr-accent-glow);
  color: var(--clr-accent);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  font-family: monospace;
}
.app-info-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px var(--sp-2);
  border-radius: var(--r-full);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
}
.app-info-badge--ok {
  background: var(--clr-success-bg);
  color: var(--clr-success-dark);
}
.app-info-badge--off {
  background: var(--clr-bg-secondary);
  color: var(--clr-text-muted);
  border: 1px solid var(--clr-border);
}

/* ── Danger zone ──────────────────────────────────────────── */
.danger-zone {
  border: 2px solid var(--clr-danger-border, #fca5a5);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-top: var(--sp-6);
  background: var(--clr-bg-card);
}
.danger-zone__header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-6);
  background: var(--clr-danger-bg, #fef2f2);
  border-bottom: 1px solid var(--clr-danger-border, #fca5a5);
}
[data-theme="dark"] .danger-zone__header {
  background: rgba(239, 68, 68, 0.08);
}
.danger-zone__icon { font-size: 1.5rem; flex-shrink: 0; margin-top: 2px; }
.danger-zone__title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-danger-text, #dc2626);
  margin: 0 0 var(--sp-1);
}
.danger-zone__subtitle {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  margin: 0;
  line-height: 1.5;
}

.danger-actions {
  padding: var(--sp-4) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.danger-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--clr-border);
}
.danger-action:last-child { border-bottom: none; }
.danger-action__info { flex: 1; }
.danger-action__title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-1);
}
.danger-action__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: 1.5;
}
@media (max-width: 639px) {
  .danger-action {
    flex-direction: column;
    align-items: flex-start;
  }
  .danger-zone__header { padding: var(--sp-4); }
  .danger-actions { padding: var(--sp-3) var(--sp-4); }
  .danger-action .btn { width: 100%; justify-content: center; }
}
.danger-zone__footer {
  padding: var(--sp-3) var(--sp-6);
  border-top: 1px solid var(--clr-border);
  background: var(--clr-bg-secondary);
  min-height: 40px;
  display: flex;
  align-items: center;
}

/* ── Settings grid ────────────────────────────────────────── */
.settings-grid-2 {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .settings-grid-2 { grid-template-columns: 1fr 1fr; }
}

/* ── btn-row / btn-result ─────────────────────────────────── */
.btn-row { display: flex; align-items: center; gap: var(--sp-3); }
.btn-row .btn { width: auto; }
.btn-result {
  font-size: var(--fs-sm);
  padding: var(--sp-1) 0;
  transition: opacity var(--t-fast);
}
.btn-result--ok { color: var(--clr-success-dark); }
.btn-result--err { color: var(--clr-danger-text); }

/* ── Select field ─────────────────────────────────────────── */
.field--select { width: 100%; }

/* ── Toggle switch (used in other sections) ───────────────── */
.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
}
.toggle-row:last-child { border-bottom: none; }
.toggle-row__info { flex: 1; }
.toggle-row__label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
}
.toggle-row__desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
}
.toggle {
  position: relative;
  width: 44px; height: 24px;
  flex-shrink: 0;
  cursor: pointer;
}
.toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle__slider {
  position: absolute;
  inset: 0;
  background: var(--clr-border);
  border-radius: var(--r-full);
  transition: background var(--t-fast);
}
.toggle__slider::before {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  left: 3px; bottom: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--t-fast);
}
.toggle input:checked + .toggle__slider { background: var(--clr-accent); }
.toggle input:checked + .toggle__slider::before { transform: translateX(20px); }

/* ── Diagnostics (used in legacy tab) ────────────────────── */
.diag-status {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-lg);
  border: 1px solid;
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-5);
}
.diag-status--ok  { background: var(--clr-success-bg);  border-color: var(--clr-success-border);  color: var(--clr-success-dark); }
.diag-status--warn{ background: var(--clr-warning-bg);  border-color: var(--clr-warning-border);  color: var(--clr-warning-dark, #b45309); }
.diag-status--err { background: var(--clr-danger-bg);   border-color: var(--clr-danger-border);   color: var(--clr-danger-text); }
.diag-status__icon { font-size: 1.4rem; flex-shrink: 0; }

.diag-issue {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
  background: var(--clr-bg-secondary);
}
.diag-issue:last-child { margin-bottom: 0; }
.diag-issue__type { flex-shrink: 0; font-size: 1.1rem; }
.diag-issue__text { font-size: var(--fs-sm); color: var(--clr-text-primary); line-height: 1.5; }
.diag-issue__order { font-size: var(--fs-xs); color: var(--clr-text-muted); }

/* ── Empty state ──────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: var(--sp-8) var(--sp-4);
  color: var(--clr-text-muted);
}
.empty-state__icon { font-size: 2rem; margin-bottom: var(--sp-2); }
.empty-state__text { font-size: var(--fs-sm); }

/* ── Service dot ──────────────────────────────────────────── */
.service-dot {
  display: inline-block;
  width: 10px; height: 10px;
  border-radius: 50%;
  margin-right: var(--sp-2);
}
.service-dot--ok   { background: var(--clr-success-dark); }
.service-dot--warn { background: var(--clr-warning-dark, #b45309); }
.service-dot--err  { background: var(--clr-danger-text); }

/* ── Error log / health fallback ─────────────────────────── */
.error-log-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.error-log-item {
  font-size: var(--fs-xs);
  padding: var(--sp-2) var(--sp-3);
  background: var(--clr-danger-bg);
  border: 1px solid var(--clr-danger-border);
  border-radius: var(--r-md);
  color: var(--clr-danger-text);
  line-height: 1.4;
}

/* ============================================================
   COMPOSE EMAIL MODAL
   ============================================================ */
.compose-modal { max-width: 600px; }

.compose-modal__to {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--clr-bg-secondary);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  margin-bottom: var(--sp-4);
}
.compose-modal__to-label { color: var(--clr-text-muted); }
.compose-modal__to-addr {
  color: var(--clr-accent);
  text-decoration: none;
  font-weight: var(--fw-medium);
}
.compose-modal__to-addr:hover { text-decoration: underline; }

.compose-modal__field { margin-top: var(--sp-4); }

.compose-modal__label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}
.compose-modal__opt {
  font-weight: var(--fw-normal);
  color: var(--clr-text-muted);
}

.compose-modal__input,
.compose-modal__textarea {
  width: 100%;
  box-sizing: border-box;
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  font-family: inherit;
  font-size: var(--fs-sm);
  color: var(--clr-text-primary);
  background: var(--clr-bg-primary);
  line-height: 1.5;
}
.compose-modal__input:focus,
.compose-modal__textarea:focus {
  outline: none;
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(var(--clr-accent-rgb, 99 102 241), 0.15);
}
.compose-modal__textarea {
  resize: vertical;
  min-height: 160px;
}

.compose-modal__file-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border: 1px dashed var(--clr-border);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.compose-modal__file-btn:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}
.compose-modal__file-input {
  position: absolute;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
}

.compose-modal__files-list {
  list-style: none;
  margin: var(--sp-2) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.compose-modal__file-item {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  padding: var(--sp-1) var(--sp-2);
  background: var(--clr-bg-secondary);
  border-radius: var(--r-sm);
}

.compose-modal__err {
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--clr-danger-text, #dc2626);
  min-height: 20px;
}

/* ── CTA-блок «Написать клиенту» ── */
.ord-compose-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.ord-compose-cta__left {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 0;
}
.ord-compose-cta__icon {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  background: var(--clr-bg-secondary);
  border: 1px solid var(--clr-border);
  color: var(--clr-text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  user-select: none;
}
.ord-compose-cta__meta { min-width: 0; }
.ord-compose-cta__title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  line-height: 1.2;
}
.ord-compose-cta__addr {
  display: block;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 320px;
  transition: color var(--t-fast);
}
.ord-compose-cta__addr:hover { color: var(--clr-accent); }

.ord-compose-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  background: transparent;
  color: var(--clr-accent);
  font-family: inherit;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  border: 1px solid var(--clr-accent);
  border-radius: var(--r-md);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--t-fast), color var(--t-fast);
}
.ord-compose-cta__btn:hover {
  background: var(--clr-accent);
  color: #fff;
}
.ord-compose-cta__btn:active { filter: brightness(0.9); }

/* ── Toast ── */
.ord-toast {
  position: fixed;
  bottom: var(--sp-6);
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--clr-success-dark, #15803d);
  color: #fff;
  padding: var(--sp-3) var(--sp-6);
  border-radius: var(--r-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  box-shadow: var(--shadow-lg);
  z-index: calc(var(--z-modal, 1000) + 10);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  white-space: nowrap;
}
.ord-toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

