/* Импульс CRM — design tokens */
:root {
  --accent-h: 160;
  --accent: oklch(0.68 0.16 var(--accent-h));
  --accent-2: oklch(0.62 0.17 var(--accent-h));
  --accent-soft: oklch(0.95 0.04 var(--accent-h));
  --accent-text: oklch(0.34 0.10 var(--accent-h));
  --accent-fg: var(--accent);
  --on-accent: #ffffff;

  --bg: oklch(0.985 0.005 250);
  --bg-2: oklch(0.97 0.006 250);
  --surface: #ffffff;
  --surface-2: oklch(0.98 0.005 250);
  --border: oklch(0.92 0.008 250);
  --border-2: oklch(0.88 0.01 250);
  --text: oklch(0.22 0.02 260);
  --text-2: oklch(0.45 0.02 260);
  --text-3: oklch(0.62 0.02 260);
  /* Алиасы для legacy-обращений в JSX (var(--text-1)/var(--bg-1)).
     Ссылаются на тематические токены — значение пересчитывается под каждую
     тему (airy/dark) автоматически, отдельных переопределений не требуют. */
  --text-1: var(--text);
  --bg-1: var(--surface);
  --shadow-sm: 0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.04);
  --shadow-md: 0 4px 6px -1px rgba(15,23,42,0.06), 0 2px 4px -2px rgba(15,23,42,0.04);
  --shadow-lg: 0 12px 24px -8px rgba(15,23,42,0.10), 0 6px 12px -6px rgba(15,23,42,0.06);

  --success: oklch(0.62 0.14 160);
  --success-soft: oklch(0.95 0.05 160);
  --warn: oklch(0.74 0.16 60);
  --warning: oklch(0.74 0.16 60);
  --warn-soft: oklch(0.96 0.05 70);
  --danger: oklch(0.62 0.21 25);
  --danger-soft: oklch(0.96 0.04 25);
  --info: oklch(0.66 0.14 230);
  --info-soft: oklch(0.96 0.04 230);
  --purple: oklch(0.62 0.18 300);
  --purple-soft: oklch(0.96 0.04 300);

  /* Фон колонки «сегодня» в расписании. В тёмной теме — прозрачный
     (подсвечивается только шапка дня). */
  --today-col-bg: oklch(0.99 0.01 150);

  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 22px;

  --sidebar-w: 248px;
  --topbar-h: 64px;

  --font: "Geist", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Inter", "Helvetica Neue", "Segoe UI", system-ui, sans-serif;
  --font-mono: "Geist Mono", "JetBrains Mono", "SF Mono", ui-monospace, Menlo, monospace;
}

/* ── Тема "airy" (бумажная) ─────────────────────────────────────────────
 * Импульс CRM v0.2: тёплая бумага, ink-текст, лайм-акцент бренда Импульс.
 * Дизайн-референс: lk-crm-v0-1/project/crm-styles.css (.app.airy)
 * Включается через [data-theme="airy"] из twiks-панели. */
[data-theme="airy"] {
  --bg: #F2EFE8;
  --bg-2: #EBE7DC;
  --surface: #FFFFFF;
  --surface-2: #F7F4EB;
  --border: #E0DCD0;
  --border-2: #D2CDC0;
  --text: #0B0B0A;
  --text-2: #2A2A26;
  --text-3: #525049;

  --accent-h: 75;
  --accent: #D4F250;
  --accent-2: #C6E739;
  --accent-soft: #F0F8C2;
  --accent-text: #1B2A05;
  --accent-fg: #4f6d0c;
  --on-accent: #1B2A05;

  --success: #1F8A5B;
  --success-soft: #E4F4EC;
  --warn: #C77A14;
  --warning: #C77A14;
  --warn-soft: #F8EAD3;
  --danger: #D14A2F;
  --danger-soft: #FBE5DE;
  --info: #5B8DEF;
  --info-soft: #E1ECFC;
  --purple: #9B6BFF;
  --purple-soft: #ECE2FF;

  --shadow-sm: 0 1px 2px rgba(11,11,10,0.04), 0 1px 3px rgba(11,11,10,0.04);
  --shadow-md: 0 4px 6px -1px rgba(11,11,10,0.06), 0 2px 4px -2px rgba(11,11,10,0.04);
  --shadow-lg: 0 12px 24px -8px rgba(11,11,10,0.10), 0 6px 12px -6px rgba(11,11,10,0.06);
}
/* Airy: цифры на mono — фирменная фишка макета. */
[data-theme="airy"] .money,
[data-theme="airy"] .num,
[data-theme="airy"] .mono { font-family: var(--font-mono); letter-spacing: -0.01em; }
/* Airy: softer shadows и border-radius чуть крупнее — добавляет «бумажности». */
[data-theme="airy"] .card { border-radius: 16px; }
[data-theme="airy"] .btn-primary {
  background: var(--accent);
  box-shadow: 0 2px 8px -2px rgba(212, 242, 80, 0.45);
}
[data-theme="airy"] .btn-primary:hover { background: var(--accent-2); box-shadow: 0 4px 14px -2px rgba(212, 242, 80, 0.55); }
[data-theme="airy"] .nav-item.active {
  background: var(--accent);
  box-shadow: 0 4px 12px -4px rgba(212, 242, 80, 0.55);
}
[data-theme="airy"] .brand-mark { background: var(--accent); box-shadow: 0 4px 12px -4px rgba(212, 242, 80, 0.4); }

/* ── Тема "dark" (тёплая) ───────────────────────────────────────────────
 * Палитра проекта N8N_MOVE_IT (ZG Board, V2): тёплый угольный фон,
 * кремовый текст, терракотовый акцент. */
[data-theme="dark"] {
  --bg: #1F1E1C;
  --bg-2: #262522;
  --surface: #2D2C29;
  --surface-2: #252421;
  --border: rgba(245,235,215,0.08);
  --border-2: rgba(245,235,215,0.16);
  --text: #F5EBD7;
  --text-2: #B8AC95;
  --text-3: #857B69;

  --accent-h: 18;
  --accent: #D97757;
  --accent-2: #E08768;
  --accent-soft: rgba(217,119,87,0.18);
  --accent-text: #E8A98E;
  --accent-fg: var(--accent);
  --on-accent: #ffffff;

  --success: #7BAE7C;
  --success-soft: rgba(123,174,124,0.18);
  --warn: #E0A05A;
  --warning: #E0A05A;
  --warn-soft: rgba(224,160,90,0.18);
  --danger: #D4756F;
  --danger-soft: rgba(212,117,111,0.18);
  --info: #7B9DC9;
  --info-soft: rgba(123,157,201,0.18);
  --purple: #A99BD4;
  --purple-soft: rgba(169,155,212,0.18);

  /* «Сегодня» в расписании — лёгкая тёплая подсветка колонки (намного слабее,
     чем на светлой теме) + терракотовая шапка дня. */
  --today-col-bg: rgba(245,235,215,0.05);

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.35);
  --shadow-md: 0 4px 10px rgba(0,0,0,0.45);
  --shadow-lg: 0 18px 40px -10px rgba(0,0,0,0.65);
}
/* Dark: акцентная кнопка — ровная терракотовая заливка (без свечения). */
[data-theme="dark"] .btn-primary { box-shadow: 0 2px 8px -2px rgba(0,0,0,0.5); }
[data-theme="dark"] .btn-primary:hover { box-shadow: 0 4px 14px -2px rgba(0,0,0,0.6); }
[data-theme="dark"] .nav-item.active { box-shadow: 0 4px 12px -6px rgba(0,0,0,0.6); }
[data-theme="dark"] .brand-mark { box-shadow: 0 4px 12px -4px rgba(0,0,0,0.5); }

/* ─────────────────────────────────────────────────────────────────────
 * Отчёт «Выручка» (rev-*) — наглядный дашборд по макету Claude Design,
 * цвета через токены тем (airy/default/dark), не хардкод. ──────────── */
.rev { display: flex; flex-direction: column; gap: 12px; max-width: 1040px; margin: 0 auto; width: 100%;
  --rev-track: var(--bg-2);
  --rev-shadow: 0 1px 2px rgba(0,0,0,.04), 0 10px 26px -18px rgba(0,0,0,.20); }
.rev-card { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 20px; box-shadow: var(--rev-shadow); }
.rev-card-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.rev-card-title { margin: 0; font-size: 15px; font-weight: 600; letter-spacing: -.01em; }
.rev-sub { font-size: 11.5px; color: var(--text-3); margin: -6px 0 12px; }
.rev-mono { font-family: var(--font-mono); }

.rev-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.rev-kpi { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 18px 20px; box-shadow: var(--rev-shadow); }
.rev-kpi:first-child { background: linear-gradient(180deg, var(--accent-soft), var(--surface)); }
.rev-kpi-label { font-size: 11.5px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: .04em; }
.rev-kpi-value { font-size: 29px; font-weight: 700; letter-spacing: -.02em; margin: 8px 0 4px; line-height: 1; font-variant-numeric: tabular-nums; }
.rev-kpi-sub { font-size: 12.5px; color: var(--text-2); }

.rev-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rev-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.rev-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; align-items: start; }

.rev-donut-row { display: flex; align-items: center; gap: 18px; margin-top: 6px; }
.rev-legend { list-style: none; margin: 0; padding: 0; flex: 1; display: flex; flex-direction: column; gap: 11px; min-width: 0; }
.rev-legend li { display: grid; grid-template-columns: 12px 1fr auto; grid-template-areas: "dot name val" "dot pct val"; column-gap: 8px; align-items: center; }
.rev-lg-dot { grid-area: dot; width: 9px; height: 9px; border-radius: 3px; align-self: center; }
.rev-lg-name { grid-area: name; font-size: 13px; font-weight: 500; }
.rev-lg-val { grid-area: val; font-size: 13px; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; }
.rev-lg-pct { grid-area: pct; font-size: 11px; color: var(--text-3); font-family: var(--font-mono); }

.rev-dir-head { display: flex; align-items: center; gap: 8px; }
.rev-dir-dot { width: 10px; height: 10px; border-radius: 3px; }
.rev-dir-name { font-size: 14px; font-weight: 600; flex: 1; }
.rev-dir-share { font-family: var(--font-mono); font-size: 12px; color: var(--text-2); font-weight: 500; }
.rev-dir-sum { font-size: 23px; font-weight: 700; letter-spacing: -.02em; margin: 12px 0 2px; font-variant-numeric: tabular-nums; }
.rev-dir-count { font-size: 12px; color: var(--text-3); margin-bottom: 12px; }
.rev-bar-track { height: 7px; background: var(--rev-track); border-radius: 4px; overflow: hidden; margin-bottom: 14px; }
.rev-bar-fill { height: 100%; border-radius: 4px; }
.rev-ch { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.rev-ch li { display: grid; grid-template-columns: 124px 1fr auto; align-items: center; gap: 8px; }
.rev-ch-name { font-size: 11.5px; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rev-ch-bar { height: 6px; background: var(--rev-track); border-radius: 3px; overflow: hidden; }
.rev-ch-bar i { display: block; height: 100%; border-radius: 3px; }
.rev-ch-val { font-size: 11.5px; font-weight: 600; font-variant-numeric: tabular-nums; }

.rev-days { display: flex; flex-direction: column; gap: 6px; max-height: 360px; overflow-y: auto; margin: 4px -4px 0; padding: 0 4px; }
.rev-day { display: grid; grid-template-columns: 78px 1fr 96px; align-items: center; gap: 10px; }
.rev-day-label { font-size: 11.5px; color: var(--text-2); display: flex; gap: 5px; align-items: baseline; }
.rev-day-label i { font-style: normal; font-size: 9.5px; color: var(--text-3); font-family: var(--font-mono); }
.rev-day-bar { height: 12px; background: var(--rev-track); border-radius: 3px; overflow: hidden; }
.rev-day-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-2), var(--accent)); border-radius: 3px; }
.rev-day-val { font-size: 11.5px; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; color: var(--text-2); }

.rev-split { display: flex; height: 14px; border-radius: 5px; overflow: hidden; margin: 2px 0 16px; background: var(--rev-track); }
.rev-mlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.rev-mlist li { display: grid; grid-template-columns: 12px 1fr auto auto; align-items: center; gap: 10px; }
.rev-m-dot { width: 10px; height: 10px; border-radius: 3px; }
.rev-m-name { font-size: 13px; font-weight: 500; }
.rev-m-pct { font-family: var(--font-mono); font-size: 13px; font-weight: 600; }
.rev-m-val { font-size: 12.5px; color: var(--text-3); text-align: right; min-width: 92px; font-variant-numeric: tabular-nums; }

.rev-fiscal { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border); }
.rev-fiscal-head { font-size: 12px; font-weight: 600; color: var(--text-2); margin-bottom: 10px; }
.rev-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.rev-pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; padding: 4px 9px; border-radius: 7px; }
.rev-pill b { font-variant-numeric: tabular-nums; }

@media (max-width: 880px) {
  .rev-kpis, .rev-2, .rev-3, .rev-bottom { grid-template-columns: 1fr; }
}

* { box-sizing: border-box; }
html, body, #root { height: 100%; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea, select { font-family: inherit; font-size: inherit; color: inherit; }

/* Layout */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
  background: var(--bg);
}

/* Sidebar */
.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  z-index: 10;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  height: var(--topbar-h);
}
.brand-mark {
  width: 32px; height: 32px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  display: grid; place-items: center;
  color: var(--on-accent); font-weight: 800;
  box-shadow: 0 4px 12px -4px var(--accent);
  position: relative;
  overflow: hidden;
}
.brand-mark::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,0.25) 50%, transparent 60%);
}
.brand-name {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.01em;
}
.brand-sub {
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.02em;
}
.nav { padding: 10px 10px; flex: 1; overflow-y: auto; }
.nav-section {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-3);
  padding: 14px 12px 6px;
  font-weight: 600;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  border-radius: 9px;
  color: var(--text-2);
  font-weight: 500;
  cursor: pointer;
  transition: all .15s ease;
  position: relative;
  width: 100%;
  text-align: left;
}
.nav-item:hover { background: var(--bg-2); color: var(--text); }
.nav-item.active {
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  color: var(--on-accent);
  box-shadow: 0 6px 14px -6px var(--accent);
}
.nav-item.active .nav-icon { color: var(--on-accent); }
.nav-icon {
  width: 18px; height: 18px;
  display: inline-grid; place-items: center;
  flex-shrink: 0;
}
.nav-badge {
  margin-left: auto;
  background: var(--accent-soft);
  color: var(--accent-text);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 999px;
  font-weight: 600;
}
.nav-item.active .nav-badge {
  background: rgba(0,0,0,0.18);
  color: var(--on-accent);
}

.sidebar-footer {
  padding: 12px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
}
.user-chip {
  display: flex; align-items: center; gap: 10px;
  flex: 1;
  padding: 6px 8px;
  border-radius: 9px;
  cursor: pointer;
}
.user-chip:hover { background: var(--bg-2); }

/* Topbar */
.topbar {
  height: var(--topbar-h);
  position: sticky; top: 0;
  background: color-mix(in oklch, var(--surface) 85%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px;
  padding: 0 24px;
  z-index: 9;
}
.search-bar {
  flex: 1;
  max-width: 520px;
  position: relative;
}
.search-input {
  width: 100%;
  padding: 10px 14px 10px 38px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 13px;
  outline: none;
  transition: all .15s ease;
}
.search-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
  background: var(--surface);
}
.search-icon {
  position: absolute; left: 12px; top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  pointer-events: none;
}
.kbd {
  position: absolute; right: 10px; top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-3);
}
.icon-btn {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 10px;
  color: var(--text-2);
  position: relative;
  transition: all .15s ease;
}
.icon-btn:hover { background: var(--bg-2); color: var(--text); }
.icon-btn .dot {
  position: absolute; top: 8px; right: 8px;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--danger);
  border: 2px solid var(--surface);
}
.icon-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}
.icon-btn:disabled:hover { background: transparent; color: var(--text-2); }

/* Main */
.main {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.page {
  padding: 24px 28px 60px;
  max-width: 1600px;
  width: 100%;
}
.page-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.page-title {
  font-size: 26px; font-weight: 700; letter-spacing: -0.02em;
  margin: 0;
}
.page-subtitle {
  font-size: 13px; color: var(--text-2);
  margin-top: 4px;
}

/* Cards */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.card-pad { padding: 18px 20px; }
.card-title {
  font-size: 15px; font-weight: 600; margin: 0;
  display: flex; align-items: center; gap: 8px;
}
.card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.card-head .right { display: flex; align-items: center; gap: 8px; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: 10px;
  font-size: 13px; font-weight: 500;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  transition: all .15s ease;
  white-space: nowrap;
}
.btn:not(.btn-primary):hover { background: var(--bg-2); border-color: var(--border-2); }
.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: var(--on-accent);
  border-color: transparent;
  box-shadow: 0 4px 12px -4px var(--accent);
}
.btn-primary:hover {
  filter: brightness(1.06);
  box-shadow: 0 6px 18px -4px var(--accent);
  transform: translateY(-1px);
}
.btn-ghost { border: none; background: transparent; }
.btn-ghost:hover { background: var(--bg-2); }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-icon {
  width: 32px;
  height: 32px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-size: 16px;
  line-height: 1;
}

/* Avatar */
.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 600;
  font-size: 13px;
  color: white;
  flex-shrink: 0;
  background: linear-gradient(135deg, hsl(var(--av-h, 200) 75% 60%), hsl(var(--av-h, 200) 65% 45%));
  letter-spacing: -0.01em;
  box-shadow: inset 0 -1px 2px rgba(0,0,0,0.2), 0 1px 2px rgba(0,0,0,0.1);
}
.avatar.sm { width: 28px; height: 28px; font-size: 11px; }
.avatar.lg { width: 56px; height: 56px; font-size: 18px; }
.avatar.xl { width: 88px; height: 88px; font-size: 28px; border-radius: 50%; }

/* Аватарка с загруженным фото: убираем градиент и тень-инсет, чтобы фото
   не подсвечивалось снизу. */
.avatar.has-photo {
  background: var(--bg-2);
  box-shadow: 0 1px 2px rgba(0,0,0,0.12);
  overflow: hidden;
  position: relative;
  transition: transform .22s ease, box-shadow .22s ease, z-index 0s linear .22s;
  transform-origin: top left;
}
.avatar.has-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}
.avatar.clickable { cursor: zoom-in; }
.avatar.clickable.expanded { cursor: zoom-out; }

/* Плавное растяжение прямо в карточке — выезжает за пределы своего контейнера,
   чтобы не ломать сетку. Размер итоговой увеличенной аватарки = scale × базовый. */
.avatar.has-photo.expanded {
  transform: scale(var(--av-expand-scale, 2.6));
  box-shadow: 0 18px 42px rgba(0,0,0,0.30), 0 0 0 2px var(--accent);
  z-index: 9999;
  transition: transform .22s ease, box-shadow .22s ease;
}

/* Подсветка строки клиента, к которой мы вернулись из карточки. */
@keyframes rowFlash {
  0%   { background-color: color-mix(in oklch, var(--accent) 25%, transparent); }
  100% { background-color: transparent; }
}
.client-row.row-flash > td { animation: rowFlash 1.4s ease-out; }

/* ── Единый Dialog API: window.uiConfirm/uiPrompt/uiAlert ─────────────────── */
.ui-dialog-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.45);
  backdrop-filter: blur(2px);
  z-index: 11000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: avatarLightboxFade .12s ease;
}
.ui-dialog {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.28);
  width: min(440px, 100%);
  overflow: hidden;
  animation: uiDialogPop .14s ease;
}
@keyframes uiDialogPop {
  from { transform: translateY(8px) scale(0.985); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
.ui-dialog-head {
  padding: 14px 18px 0;
  display: flex; align-items: center; gap: 12px;
}
.ui-dialog-icon {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ui-dialog-icon-danger   { background: color-mix(in oklch, var(--danger)  14%, transparent); color: var(--danger); }
.ui-dialog-icon-warning  { background: color-mix(in oklch, #f59e0b        14%, transparent); color: #d97706; }
.ui-dialog-icon-info     { background: color-mix(in oklch, var(--accent)  14%, transparent); color: var(--accent-fg); }
.ui-dialog-icon-success  { background: color-mix(in oklch, #16a34a        14%, transparent); color: #16a34a; }
.ui-dialog-icon-question { background: color-mix(in oklch, var(--accent)  14%, transparent); color: var(--accent-fg); }
.ui-dialog-title {
  font-size: 15px; font-weight: 600; color: var(--text);
  flex: 1;
}
.ui-dialog-danger .ui-dialog-title { color: var(--danger); }
.ui-dialog-body {
  padding: 10px 18px 6px;
  padding-left: 68px;   /* выровнен под иконкой 38+12+18 */
  font-size: 13px; color: var(--text-2); line-height: 1.45;
}
.ui-dialog-line { white-space: pre-wrap; word-wrap: break-word; }
.ui-dialog-input { margin-top: 10px; width: 100%; }
.ui-dialog-foot {
  padding: 12px 16px 14px;
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  border-top: 1px solid var(--border);
  margin-top: 10px;
  background: var(--bg-2);
}
.ui-dialog-remember {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-3);
  cursor: pointer; user-select: none;
}
.ui-dialog-remember input { cursor: pointer; }
.ui-dialog-buttons {
  display: flex; gap: 8px;
  margin-left: auto;
}
.btn.btn-danger {
  background: var(--danger);
  color: white;
  border-color: var(--danger);
}
.btn.btn-danger:hover { filter: brightness(0.93); }

/* Тосты — правый нижний угол, авто-исчезают, до 4 одновременно */
.ui-toast-stack {
  position: fixed;
  right: 20px; bottom: 20px;
  z-index: 11050;
  display: flex; flex-direction: column; gap: 8px;
  pointer-events: none;
}
.ui-toast {
  pointer-events: auto;
  min-width: 220px; max-width: 380px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px; line-height: 1.35;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 8px 24px rgba(0,0,0,0.14);
  animation: uiToastIn .18s ease;
}
.ui-toast-info    { border-left: 3px solid var(--accent); }
.ui-toast-success { border-left: 3px solid #16a34a; color: var(--text); }
.ui-toast-error   { border-left: 3px solid var(--danger); color: var(--text); }
@keyframes uiToastIn {
  from { transform: translateX(20px); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

/* Лайтбокс для аватара (prop lightbox у EntityAvatar). Используется для залов:
   круглый превью в карточке, по клику — полноразмерное прямоугольное фото. */
.avatar-lightbox {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.85);
  z-index: 10001;
  display: flex; align-items: center; justify-content: center;
  cursor: zoom-out;
  padding: 20px;
  animation: avatarLightboxFade .15s ease;
}
.avatar-lightbox img {
  max-width: 94vw;
  max-height: 92vh;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  object-fit: contain;
  cursor: default;
}
.avatar-lightbox-close {
  position: absolute; top: 18px; right: 18px;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  color: white;
  border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .15s;
}
.avatar-lightbox-close:hover { background: rgba(255,255,255,0.22); }
@keyframes avatarLightboxFade {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Badges/chips */
.chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px;
  font-size: 11px; font-weight: 500;
  border-radius: 999px;
  background: var(--bg-2);
  color: var(--text-2);
  border: 1px solid var(--border);
  white-space: nowrap;
}
.chip.green { background: oklch(0.94 0.06 160); color: oklch(0.32 0.10 160); border-color: oklch(0.86 0.08 160); }
.chip.blue  { background: oklch(0.94 0.04 230); color: oklch(0.32 0.10 230); border-color: oklch(0.85 0.06 230); }
.chip.orange{ background: oklch(0.94 0.06 50);  color: oklch(0.40 0.14 50);  border-color: oklch(0.86 0.10 50); }
.chip.red   { background: oklch(0.94 0.06 25);  color: oklch(0.40 0.16 25);  border-color: oklch(0.86 0.10 25); }
.chip.purple{ background: oklch(0.94 0.05 300); color: oklch(0.36 0.12 300); border-color: oklch(0.86 0.08 300); }
[data-theme="dark"] .chip { background: rgba(255,255,255,0.05); border-color: var(--border); color: var(--text-2); }
[data-theme="dark"] .chip.green { background: oklch(0.30 0.06 160); color: oklch(0.85 0.10 160); border-color: oklch(0.36 0.08 160); }
[data-theme="dark"] .chip.blue  { background: oklch(0.30 0.05 230); color: oklch(0.84 0.08 230); border-color: oklch(0.36 0.07 230); }
[data-theme="dark"] .chip.orange{ background: oklch(0.30 0.07 50);  color: oklch(0.85 0.12 50);  border-color: oklch(0.36 0.09 50); }
[data-theme="dark"] .chip.red   { background: oklch(0.30 0.08 25);  color: oklch(0.85 0.14 25);  border-color: oklch(0.36 0.10 25); }
[data-theme="dark"] .chip.purple{ background: oklch(0.30 0.06 300); color: oklch(0.84 0.10 300); border-color: oklch(0.36 0.08 300); }

.dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.status-active { background: var(--accent); }
.status-inactive { background: var(--text-3); }
.status-debt { background: var(--warn); }

/* Stat tile */
.stat {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px;
  position: relative;
  overflow: hidden;
}
.stat .label { font-size: 12px; color: var(--text-2); font-weight: 500; }
.stat .num { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin-top: 6px; }
.stat .delta { font-size: 12px; margin-top: 4px; display: inline-flex; align-items: center; gap: 4px; }
.stat .delta.up { color: oklch(0.55 0.16 160); }
.stat .delta.down { color: var(--danger); }
.stat .glyph {
  position: absolute; right: -8px; top: -8px;
  width: 70px; height: 70px;
  background: linear-gradient(135deg, var(--accent-soft), transparent);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--accent-fg);
  opacity: 0.6;
}

/* Tables */
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.table th {
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-3);
  font-weight: 600;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
  position: sticky; top: 0;
  /* z-index — иначе позиционированные ячейки тела (аватар .client-av-wrap)
     рисуются поверх липкой шапки при прокрутке. */
  z-index: 2;
}
.table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.table tbody tr { transition: background .12s ease; cursor: pointer; }
.table tbody tr:hover { background: var(--bg-2); }
.table tbody tr.selected { background: var(--accent-soft); }

/* Drawer */
.drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.4);
  backdrop-filter: blur(4px);
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}
.drawer-overlay.open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; right: 0; top: 0; height: 100vh;
  width: min(560px, 92vw);
  background: var(--surface);
  border-left: 1px solid var(--border);
  z-index: 101;
  transform: translateX(100%);
  transition: transform .25s cubic-bezier(.2,.8,.2,1);
  display: flex; flex-direction: column;
  box-shadow: -20px 0 40px -10px rgba(0,0,0,0.15);
}
.drawer.wide { width: min(720px, 96vw); }
.drawer.open { transform: translateX(0); }
.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.drawer-title { font-weight: 600; font-size: 15px; }
.drawer-body { flex: 1; overflow-y: auto; padding: 20px; }

/* Modal */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.45);
  backdrop-filter: blur(6px);
  display: grid; place-items: center;
  z-index: 200;
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal {
  background: var(--surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  width: min(540px, 92vw);
  max-height: min(85vh, calc(100vh - 32px));
  display: flex;
  flex-direction: column;
  transform: scale(0.96) translateY(8px);
  transition: transform .25s cubic-bezier(.2,.8,.2,1);
  overflow: hidden;
}
.modal > div:nth-child(2) {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--border-2) transparent;
}
.modal-overlay.open .modal { transform: scale(1) translateY(0); }

/* Стандартное тело и футер модалки — используются вместо inline padding,
   чтобы media-query ниже мог их перенастроить под FHD. */
.modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.modal-head > :first-child { min-width: 0; flex: 1; }
.modal-body {
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.modal-foot {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  background: var(--surface);
}

/* FHD-адаптация: на ноутбуках/мониторах с малой высотой
   уменьшаем вертикальные отступы у модалок и форм. */
@media (max-height: 900px) {
  .modal { max-height: calc(100vh - 16px); }
  .modal .card-head { padding: 12px 18px; }
  .modal-head { padding: 12px 18px; }
  .modal-body { padding: 12px 18px; gap: 9px; }
  .modal-foot { padding: 10px 18px; }
  .field { gap: 4px; }
  .field label { font-size: 11px; }
  .input, .select, .textarea { padding: 7px 11px; font-size: 12.5px; }
}

/* Form */
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12px; font-weight: 500; color: var(--text-2); }
.input, .select, .textarea {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--surface);
  font-size: 13px;
  outline: none;
  transition: all .15s ease;
}
.input:focus, .select:focus, .textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.toggle {
  width: 36px; height: 20px;
  background: var(--border-2);
  border-radius: 999px;
  position: relative;
  cursor: pointer;
  transition: background .15s ease;
}
.toggle::after {
  content:''; position: absolute;
  top: 2px; left: 2px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: left .15s ease;
}
.toggle.on { background: var(--accent); }
.toggle.on::after { left: 18px; }

/* Всплывающие подсказки по неочевидным функциям: элемент с data-tip → bubble.
   Позиционируется JS (initAppTips в utils.jsx) через position:fixed — не
   обрезается overflow:hidden контейнерами (карточки, модалки). Тёмный bubble
   читаем во всех темах, включая лаймовую. */
.app-tip {
  position: fixed; z-index: 4000; left: 0; top: 0; pointer-events: none;
  max-width: 280px; white-space: normal; text-align: left;
  background: rgba(17,20,26,0.96); color: #fff;
  font-size: 12px; line-height: 1.4; font-weight: 400;
  padding: 8px 11px; border-radius: 8px;
  box-shadow: 0 10px 30px -8px rgba(0,0,0,0.5);
  opacity: 0; transform: translateY(3px);
  transition: opacity .12s ease, transform .12s ease;
}
.app-tip.show { opacity: 1; transform: translateY(0); }

/* Skeleton */
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.skeleton {
  background: linear-gradient(90deg, var(--bg-2), var(--border), var(--bg-2));
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 8px;
}

/* Animations */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fadeUp .3s cubic-bezier(.2,.8,.2,1); }
.fade-up-stagger > * { animation: fadeUp .35s cubic-bezier(.2,.8,.2,1) backwards; }
.fade-up-stagger > *:nth-child(1) { animation-delay: 0ms; }
.fade-up-stagger > *:nth-child(2) { animation-delay: 40ms; }
.fade-up-stagger > *:nth-child(3) { animation-delay: 80ms; }
.fade-up-stagger > *:nth-child(4) { animation-delay: 120ms; }
.fade-up-stagger > *:nth-child(5) { animation-delay: 160ms; }
.fade-up-stagger > *:nth-child(6) { animation-delay: 200ms; }

/* Schedule */
.schedule-grid {
  display: grid;
  grid-template-columns: 64px repeat(7, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.schedule-cell {
  background: var(--surface);
  min-height: 70px;
  padding: 4px;
  position: relative;
}
.schedule-head {
  background: var(--surface-2);
  padding: 10px 8px;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
}
.schedule-time {
  background: var(--surface-2);
  padding: 8px 6px;
  font-size: 11px;
  color: var(--text-3);
  text-align: center;
  font-weight: 500;
}
.lesson {
  background: var(--surface);
  border-left: 3px solid var(--lesson-color, var(--accent));
  border-radius: 7px;
  padding: 6px 8px;
  font-size: 11px;
  cursor: grab;
  margin-bottom: 3px;
  transition: all .15s ease;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  border-left: 3px solid var(--lesson-color, var(--accent));
  /* Внутренний текст никогда не должен вылезать за карточку. Полное описание
     показывается через title (tooltip). */
  overflow: hidden;
}
.lesson:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.lesson .lname {
  font-weight: 600; font-size: 11px; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.lesson .lmeta {
  color: var(--text-3); font-size: 10px; margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.lesson.dragging { opacity: 0.4; }

/* Анимация появления кастомного tooltip занятия. fade + лёгкий подъезд снизу. */
@keyframes lesson-tt-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Kanban */
.kanban {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 8px;
}
.kanban-col {
  flex: 0 0 280px;
  background: var(--surface-2);
  border-radius: var(--radius);
  border: 1px solid var(--border);
}
.kanban-col-head {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.kanban-col-body {
  padding: 10px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 100px;
}
.kanban-col.drop-target { background: var(--accent-soft); }

/* Misc */
.row-flex { display: flex; align-items: center; gap: 10px; }
.muted { color: var(--text-3); }
.divider { height: 1px; background: var(--border); margin: 12px 0; }
.tabs {
  display: flex;
  gap: 2px;
  background: var(--surface-2);
  padding: 3px;
  border-radius: 10px;
  border: 1px solid var(--border);
  width: fit-content;
}
.tab {
  padding: 6px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-2);
  transition: all .15s ease;
}
.tab:hover { color: var(--text); }
.tab.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-sm);
}

/* Glass */
.glass {
  background: color-mix(in oklch, var(--surface) 75%, transparent);
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid color-mix(in oklch, var(--border) 80%, transparent);
}

/* Mini sparkline / chart placeholder */
.spark { display: block; width: 100%; height: 60px; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 10px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* Schedule weekly view list */
.weekly-cell {
  display: flex; flex-direction: column; gap: 4px;
  padding: 6px 4px;
  min-height: 80px;
}

/* Birthday card sparkles */
@keyframes pulse-soft {
  0%, 100% { opacity: 0.6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.1); }
}
.sparkle { animation: pulse-soft 2s ease-in-out infinite; }

/* Family tree */
.family-link {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: var(--bg-2);
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid var(--border);
  transition: all .15s ease;
}
.family-link:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
  transform: translateX(2px);
}

/* Email layout */
/* Wrapper: занимает всё свободное место и не даёт странице расти за пределы
   вьюпорта — иначе скролл уходит на body вместо списка писем. */
.page-mail {
  height: calc(100vh - var(--topbar-h));
  padding: 12px 16px 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  max-width: none;
}
.mail-layout {
  display: grid;
  grid-template-columns: 220px 420px 1fr;
  flex: 1;
  min-height: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
}
.mail-folders { border-right: 1px solid var(--border); padding: 12px; background: var(--surface-2); }
.mail-list   { border-right: 1px solid var(--border); display: flex; flex-direction: column; min-height: 0; }
.mail-view   { padding: 18px 22px; overflow-y: auto; min-height: 0; }
.mail-folder {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 13px; color: var(--text-2);
  cursor: pointer;
}
.mail-folder.active { background: var(--accent-soft); color: var(--accent-text); font-weight: 600; }
.mail-folder:hover:not(.active) { background: var(--bg-2); }

/* Строка письма: аватар (или чекбокс на hover) + 2 строки контента + дата.
   Высота ~62px — компактно но читаемо. */
.mail-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  column-gap: 10px;
  align-items: center;
  padding: 9px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
  position: relative;
  transition: background .12s;
}
.mail-item:hover { background: var(--bg-2); }
.mail-item.active { background: var(--accent-soft); }
.mail-item.selected { background: color-mix(in oklch, var(--accent) 14%, var(--surface)); }
.mail-item.selected:hover { background: color-mix(in oklch, var(--accent) 18%, var(--surface)); }

/* Аватар-ячейка: и аватар, и чекбокс — один поверх другого. */
.mail-item .mi-av-cell {
  position: relative;
  width: 36px; height: 36px;
}
.mail-item .mi-av-cell .avatar {
  width: 36px; height: 36px;
  font-size: 13px;
  border-radius: 50%;
  transition: opacity .12s;
}
.mail-item .mi-av-cell .mi-checkbox {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  border-radius: 8px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  cursor: pointer;
  opacity: 0;
  transition: opacity .12s, border-color .12s, background .12s;
}
.mail-item .mi-av-cell .mi-checkbox:hover { border-color: var(--accent); }
.mail-item .mi-av-cell .mi-checkbox svg { width: 18px; height: 18px; opacity: 0; transition: opacity .12s; }

/* Hover на ряд → показать чекбокс, скрыть аватар. */
.mail-item:hover .mi-av-cell .avatar { opacity: 0; }
.mail-item:hover .mi-av-cell .mi-checkbox { opacity: 1; }

/* Если выделено — чекбокс активный, всегда видимый, с галкой. */
.mail-item.selected .mi-av-cell .avatar { opacity: 0; }
.mail-item.selected .mi-av-cell .mi-checkbox {
  opacity: 1;
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}
.mail-item.selected .mi-av-cell .mi-checkbox svg { opacity: 1; }

/* Контент письма */
.mail-item .mi-body { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.mail-item .mi-line1 {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-1);
  line-height: 1.2;
}
.mail-item .mi-from { flex: 1; min-width: 0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-weight: 500; }
.mail-item.unread .mi-from { font-weight: 700; }
.mail-item .mi-meta {
  display:flex; align-items:center; gap:5px;
  color: var(--text-3); font-size:11px; white-space:nowrap; flex-shrink: 0;
}
.mail-item .mi-line2 {
  display: flex; align-items: baseline; gap: 6px;
  font-size: 12px; line-height: 1.3; min-width: 0;
}
.mail-item .mi-subj {
  flex-shrink: 0; max-width: 60%;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  color: var(--text-2);
}
.mail-item.unread .mi-subj { font-weight: 600; color: var(--text-1); }
.mail-item .mi-snip { color: var(--text-3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; min-width: 0; flex: 1; }
.mail-item .mi-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: transparent;
  flex-shrink: 0;
}
.mail-item.unread .mi-dot { background: var(--accent); }

/* Мета-полоса над списком: счётчик писем + при выделении подсказка */
.mail-meta {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  height: 34px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  font-size: 11px; color: var(--text-3);
  overflow: hidden;
}
.mail-meta b { color: var(--accent-text); }

/* Bulk-bar (старый класс — оставлен на случай обратной совместимости) */
.mail-bulkbar {
  display:flex; align-items:center; gap:8px;
  padding: 6px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--accent-soft);
  font-size: 12px;
}
.mail-bulkbar .grow { flex:1; }
.mail-bulkbar .btn { height: 26px; padding: 0 10px; font-size: 12px; }

/* Drag-zone для compose */
.mail-dropzone {
  position: relative;
  border: 2px dashed var(--border);
  border-radius: 10px;
  padding: 12px;
  text-align: center;
  font-size: 12px;
  color: var(--text-3);
  transition: background .12s, border-color .12s;
  cursor: pointer;
}
.mail-dropzone.drag-over {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent-text);
}
.mail-dropzone input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer;
}

/* Контекстное меню сообщений */
.mail-ctxmenu {
  position: fixed; z-index: 220;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 12px 28px rgba(0,0,0,.22);
  padding: 4px; min-width: 200px;
  font-size: 13px;
}
.mail-ctxmenu .item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 6px; cursor: pointer; color: var(--text-2);
}
.mail-ctxmenu .item:hover { background: var(--bg-2); }
.mail-ctxmenu .item.danger { color: var(--danger,#ef4444); }
.mail-ctxmenu .sep { height: 1px; background: var(--border); margin: 4px 0; }
.mail-ctxmenu .submenu-wrap { position: relative; }
.mail-ctxmenu .submenu {
  position: absolute; left: 100%; top: 0;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 12px 28px rgba(0,0,0,.22);
  padding: 4px; min-width: 200px; max-height: 320px; overflow-y: auto;
  margin-left: 4px;
}

/* Pass card */
.pass {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  padding: 22px;
  color: white;
  background: linear-gradient(135deg, var(--c), color-mix(in oklch, var(--c) 60%, black));
  min-height: 180px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.pass::before {
  content:''; position: absolute; inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(255,255,255,0.2), transparent 50%);
  pointer-events: none;
}
.pass-vis { font-size: 36px; font-weight: 700; letter-spacing: -0.03em; }
.pass-vis-sub { font-size: 12px; opacity: 0.8; font-weight: 500; }
.pass-price { font-size: 20px; font-weight: 600; }

/* Ring chart */
.ring {
  --p: 75;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: conic-gradient(var(--accent) calc(var(--p)*1%), var(--bg-2) 0);
  display: grid; place-items: center;
  position: relative;
}
.ring::before {
  content: '';
  position: absolute; inset: 6px;
  border-radius: 50%;
  background: var(--surface);
}
.ring-text {
  position: relative;
  font-size: 13px; font-weight: 700;
}

/* ── Sidebar collapsed mode ── */
.sidebar-collapsed { --sidebar-w: 64px; }
.sidebar-collapsed .brand-name,
.sidebar-collapsed .brand-sub,
.sidebar-collapsed .nav-section,
.sidebar-collapsed .nav-item > span:not(.nav-icon),
.sidebar-collapsed .nav-badge,
.sidebar-collapsed .sidebar-footer .user-chip { display: none; }
.sidebar-collapsed .nav-item { justify-content: center; padding: 9px; }
.sidebar-collapsed .nav-icon { width: 20px; height: 20px; }
.sidebar-collapsed .brand { justify-content: center; padding: 16px 8px; }
.sidebar-collapsed .sidebar-footer { justify-content: center; }
.sidebar-collapsed .sidebar-footer .icon-btn { margin: 0; }

/* ── Toast notifications ── */
.toast-stack { position: fixed; bottom: 24px; right: 24px; display: flex; flex-direction: column; gap: 10px; z-index: 9999; pointer-events: none; }
.toast {
  padding: 12px 18px; border-radius: 12px; font-size: 13px; font-weight: 500;
  box-shadow: var(--shadow-lg); border: 1px solid var(--border);
  background: var(--surface); color: var(--text);
  animation: fadeUp .25s ease;
  pointer-events: auto;
}
.toast.success { background: var(--success-soft); color: var(--success); border-color: var(--success); }
.toast.error { background: var(--danger-soft); color: var(--danger); border-color: var(--danger); }

/* ── Pass/Coach grids ── */
.passes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.coaches-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }

/* ── Светлые карточки залов и абонементов (минимализм) ── */
.halls-grid, .passes-grid-v2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.hall-card, .pass-card-v2 {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px 14px 18px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s, border-color .15s;
}
.hall-card::before, .pass-card-v2::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--card-color, var(--accent));
}
.hall-card:hover, .pass-card-v2:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(15,23,42,0.08);
  border-color: color-mix(in oklch, var(--card-color, var(--accent)) 40%, var(--border));
}
.hall-top, .pass-top-v2 {
  display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
}
.hall-avatar, .pass-avatar-v2 {
  width: 36px; height: 36px; border-radius: 10px;
  background: color-mix(in oklch, var(--card-color, var(--accent)) 14%, var(--surface));
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
/* В карточках залов аватар — круглый и крупнее (48×48), чтобы был как в
   остальных разделах. Перекрывает базовый .avatar.md (40×40, radius 12).
   ВАЖНО: класс .avatar.md лежит ниже в файле и имеет ту же specificity, что
   и `.hall-top .avatar`, поэтому без явного `.md` правило бы проиграло. */
.hall-top .avatar.md,
.hall-top .avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
}
.hall-top .hall-avatar {
  width: 100%; height: 100%;
  border-radius: 50%;
}
.hall-chip, .pass-chip-v2 {
  font-size: 10px; padding: 2px 8px; border-radius: 6px;
  background: color-mix(in oklch, var(--card-color, var(--accent)) 14%, var(--surface));
  font-weight: 600; text-transform: uppercase; letter-spacing: .04em;
  white-space: nowrap;
}
.hall-name, .pass-name-v2 {
  margin: 0 0 6px; font-size: 15px; font-weight: 600; line-height: 1.25;
}
.hall-meta, .pass-meta-v2 {
  font-size: 13px; color: var(--text-2); margin-bottom: 8px;
}
.hall-meta b, .pass-meta-v2 b { color: var(--text); font-weight: 600; }
.hall-desc, .pass-desc-v2 {
  font-size: 12px; color: var(--text-3); line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.pass-footer-v2 {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 10px; margin-top: 10px;
  border-top: 1px dashed var(--border);
}
.pass-price-v2 { font-size: 18px; font-weight: 700; }
.pass-perunit-v2 { font-size: 11px; color: var(--text-3); }
.pass-card-v2.inactive { opacity: 0.55; }

/* ── Debt visit highlight ── */
.visit-row-debt td { background: var(--warn-soft) !important; }
[data-theme="dark"] .visit-row-debt td { background: oklch(0.28 0.06 60) !important; }
[data-theme="airy"] .visit-row-debt td { background: var(--warn-soft) !important; }

/* ── Skeleton lines ── */
.skel { height: 14px; border-radius: 7px; display: inline-block; }
.skel-line { margin-bottom: 8px; }

/* ── MAX Messenger page ── */
.avatar.md { width: 40px; height: 40px; font-size: 14px; border-radius: 12px; }

.max-chat-item {
  display: flex; gap: 10px; align-items: flex-start;
  width: 100%; padding: 10px 12px;
  border: none; background: transparent; cursor: pointer;
  text-align: left; border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.max-chat-item:hover { background: var(--bg-2); }
.max-chat-item.active { background: var(--bg-3); }
.max-page { /* outer container */ }
.max-messages { display: flex; flex-direction: column; }

/* Кнопка-действие внутри пузыря сообщения (скачать, сохранить).
   Не должна давать «белой плашки» на акцентном фоне. */
.bubble-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 3px 6px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: inherit;
  font-size: 11px;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease;
}
.bubble-action:hover { background: rgba(255,255,255,0.16); border-color: rgba(255,255,255,0.22); }
/* На светлом фоне (входящие, серый surface-2) переворачиваем тинт. */
.theme-dark .bubble-action:hover,
.bubble-action.bubble-action-on-light:hover {
  background: rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.10);
}
