/* ============================================================
   BDKazak — Дизайн-система (Modern SaaS / Linear)
   Шрифт: Inter (подключается в base.html через Google Fonts).
   Базис: Bootstrap 5 (переопределяем переменные/классы).
   Префикс собственных утилит — bdk-.
   ============================================================ */


/* ============================================
   1. ДИЗАЙН-ТОКЕНЫ (CSS custom properties)
   ============================================ */
:root {
  /* Нейтральные */
  --bdk-bg: #f7f8fa;
  --bdk-surface: #ffffff;
  --bdk-border: #e5e7eb;
  --bdk-border-strong: #d1d5db;
  --bdk-text: #111827;
  --bdk-text-muted: #6b7280;
  --bdk-text-dim: #9ca3af;

  /* Брендовые */
  --bdk-primary: #1f5f8b;
  --bdk-primary-hover: #16466a;
  --bdk-primary-bg: #eaf2f8;
  --bdk-accent: #d6a85b;
  --bdk-accent-hover: #b88842;
  --bdk-accent-bg: #fdf6ea;

  /* Семантика */
  --bdk-success: #059669;
  --bdk-success-bg: #ecfdf5;
  --bdk-warning: #d97706;
  --bdk-warning-bg: #fffbeb;
  --bdk-danger: #dc2626;
  --bdk-danger-bg: #fef2f2;
  --bdk-info: #0891b2;
  --bdk-info-bg: #ecfeff;

  /* Радиусы */
  --bdk-radius-sm: 6px;
  --bdk-radius: 10px;
  --bdk-radius-lg: 14px;
  --bdk-radius-pill: 999px;

  /* Тени */
  --bdk-shadow-sm: 0 1px 2px rgba(16, 24, 40, 0.05);
  --bdk-shadow:    0 1px 3px rgba(16, 24, 40, 0.08), 0 1px 2px rgba(16, 24, 40, 0.06);
  --bdk-shadow-md: 0 4px 12px rgba(16, 24, 40, 0.08), 0 2px 4px rgba(16, 24, 40, 0.04);
  --bdk-shadow-lg: 0 8px 24px rgba(16, 24, 40, 0.10), 0 4px 8px rgba(16, 24, 40, 0.04);

  /* Переходы */
  --bdk-transition: 0.15s ease;
  --bdk-transition-slow: 0.3s ease;

  /* Z-index */
  --bdk-z-navbar: 50;
  --bdk-z-dropdown: 100;
  --bdk-z-modal: 1050;
  --bdk-z-toast: 1100;

  /* Bootstrap-переопределения через CSS-переменные */
  --bs-primary: var(--bdk-primary);
  --bs-primary-rgb: 31, 95, 139;
  --bs-link-color: var(--bdk-primary);
  --bs-link-hover-color: var(--bdk-primary-hover);
  --bs-link-color-rgb: 31, 95, 139;
  --bs-border-color: var(--bdk-border);
  --bs-body-color: var(--bdk-text);
  --bs-body-bg: var(--bdk-bg);
  --bs-secondary-color: var(--bdk-text-muted);
  --bs-tertiary-bg: var(--bdk-bg);
}


/* ============================================
   2. БАЗОВЫЕ СТИЛИ И ТИПОГРАФИКА
   ============================================ */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Подсказка браузеру про светлую тему — фиксит нативные скроллбары
     и input-controls в Windows dark mode. */
  color-scheme: light;
}

/* Скрытая визуально, но видимая для screen reader подпись
   (Bootstrap 5 даёт .visually-hidden, но дублируем для надёжности
   и используем под привычным именем .sr-only). */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Skip-link для клавиатурной навигации: ссылка появляется только
   при фокусе, ведёт сразу к <main>. */
.bdk-skip-link {
  position: absolute;
  left: 8px;
  top: -40px;
  z-index: 9999;
  background: var(--bdk-primary);
  color: #fff;
  padding: 8px 14px;
  border-radius: var(--bdk-radius-sm);
  font-size: 13.5px;
  text-decoration: none;
}
.bdk-skip-link:focus,
.bdk-skip-link:focus-visible {
  top: 8px;
  color: #fff;
  outline: none;
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}

/* Якоря под sticky-топбаром: при переходе по hash не упирается под шапку. */
:target {
  scroll-margin-top: 80px;
}

/* Анимации/переходы выключаются для пользователей с пометкой
   prefers-reduced-motion (системная настройка «уменьшить движение»). */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  background: var(--bdk-bg);
  color: var(--bdk-text);
  font-size: 14px;
  line-height: 1.5;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  letter-spacing: -0.01em;
  font-weight: 600;
  color: var(--bdk-text);
}
h1, .h1 { font-size: 24px; }
h2, .h2 { font-size: 20px; }
h3, .h3 { font-size: 16px; }
h4, .h4 { font-size: 15px; }
h5, .h5 { font-size: 14px; }
h6, .h6 { font-size: 13px; }

a { color: var(--bdk-primary); text-decoration: none; }
a:hover { color: var(--bdk-primary-hover); }

.text-muted, .text-secondary { color: var(--bdk-text-muted) !important; }
.text-bdk-muted { color: var(--bdk-text-muted) !important; }
.text-bdk-dim { color: var(--bdk-text-dim) !important; }
.small, small { font-size: 12.5px; }

::selection { background: var(--bdk-primary-bg); color: var(--bdk-primary-hover); }


/* ============================================
   3. ТОПБАР (.bdk-topbar)
   ============================================ */
.bdk-topbar {
  background: var(--bdk-surface);
  border-bottom: 1px solid var(--bdk-border);
  height: 60px;
  position: sticky;
  top: 0;
  z-index: var(--bdk-z-navbar);
}
.bdk-topbar-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 20px;
}
.bdk-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 16px;
  color: var(--bdk-text);
  text-decoration: none;
  flex-shrink: 0;
}
.bdk-brand:hover { color: var(--bdk-text); }
.bdk-brand-logo {
  width: 32px;
  height: 32px;
  background: linear-gradient(135deg, var(--bdk-primary), var(--bdk-primary-hover));
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: -0.02em;
}

.bdk-nav-links {
  display: flex;
  gap: 2px;
  flex: 1;
  align-items: center;
  min-width: 0;
}
.bdk-nav-link {
  padding: 8px 12px;
  border-radius: var(--bdk-radius-sm);
  color: var(--bdk-text-muted);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  white-space: nowrap;
  transition: background-color var(--bdk-transition), color var(--bdk-transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.bdk-nav-link:hover { background: var(--bdk-bg); color: var(--bdk-text); }
.bdk-nav-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
  color: var(--bdk-text);
}
.bdk-nav-link.active {
  background: var(--bdk-primary-bg);
  color: var(--bdk-primary);
  font-weight: 600;
}

.bdk-search-box {
  position: relative;
  width: 320px;
  max-width: 100%;
}
.bdk-search-box input {
  width: 100%;
  height: 36px;
  padding: 0 12px 0 36px;
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm);
  background: var(--bdk-bg);
  color: var(--bdk-text);
  font-size: 13.5px;
  font-family: inherit;
  transition: background-color var(--bdk-transition), border-color var(--bdk-transition), box-shadow var(--bdk-transition);
}
.bdk-search-box input::placeholder { color: var(--bdk-text-dim); }
.bdk-search-box input:focus {
  outline: none;
  border-color: var(--bdk-primary);
  background: var(--bdk-surface);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}
.bdk-search-box .bi-search {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bdk-text-dim);
  pointer-events: none;
}

.bdk-nav-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.bdk-icon-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--bdk-radius-sm);
  border: none;
  background: transparent;
  color: var(--bdk-text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: background-color var(--bdk-transition), color var(--bdk-transition);
  text-decoration: none;
}
.bdk-icon-btn:hover { background: var(--bdk-bg); color: var(--bdk-text); }
.bdk-icon-btn:focus-visible {
  outline: none;
  background: var(--bdk-bg);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}
.bdk-icon-btn .bi { font-size: 16px; }
.bdk-icon-btn .badge {
  position: absolute;
  top: 4px;
  right: 4px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 5px;
  border-radius: 10px;
  background: var(--bdk-danger);
  color: #fff;
  border: 2px solid var(--bdk-surface);
  line-height: 1;
}

.bdk-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bdk-accent), var(--bdk-accent-hover));
  color: #fff;
  font-weight: 600;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  border: none;
  letter-spacing: 0.02em;
}
.bdk-avatar:hover { color: #fff; opacity: 0.92; }

/* dropdown профиля и колокольчика в нашем стиле */
.bdk-topbar .dropdown-menu {
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  box-shadow: var(--bdk-shadow-lg);
  padding: 6px;
  font-size: 13.5px;
}
.bdk-topbar .dropdown-item {
  border-radius: var(--bdk-radius-sm);
  padding: 8px 10px;
}
.bdk-topbar .dropdown-item:active {
  background: var(--bdk-primary);
  color: #fff;
}


/* ============================================
   4. КНОПКИ
   ============================================ */
.btn {
  font-size: 13.5px;
  font-weight: 500;
  border-radius: var(--bdk-radius-sm);
  padding: 8px 14px;
  transition: background-color var(--bdk-transition), border-color var(--bdk-transition), color var(--bdk-transition), box-shadow var(--bdk-transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn-sm { padding: 6px 10px; font-size: 12.5px; }
.btn-lg { padding: 11px 18px; font-size: 14.5px; }

.btn-primary,
.btn-primary:focus {
  background-color: var(--bdk-primary);
  border-color: var(--bdk-primary);
  color: #fff;
}
.btn-primary:hover,
.btn-primary:active {
  background-color: var(--bdk-primary-hover) !important;
  border-color: var(--bdk-primary-hover) !important;
}
.btn-primary:focus-visible {
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}

.btn-outline-primary {
  color: var(--bdk-primary);
  border-color: var(--bdk-border-strong);
  background: var(--bdk-surface);
}
.btn-outline-primary:hover,
.btn-outline-primary:active {
  background-color: var(--bdk-primary);
  border-color: var(--bdk-primary);
  color: #fff;
}

.btn-secondary {
  background-color: var(--bdk-surface);
  border-color: var(--bdk-border);
  color: var(--bdk-text);
}
.btn-secondary:hover,
.btn-secondary:active {
  background-color: var(--bdk-bg) !important;
  border-color: var(--bdk-border-strong) !important;
  color: var(--bdk-text) !important;
}

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

.btn-link {
  color: var(--bdk-primary);
  text-decoration: none;
  padding: 6px 8px;
}
.btn-link:hover { color: var(--bdk-primary-hover); text-decoration: underline; }


/* ============================================
   5. КАРТОЧКИ (Bootstrap .card + .bdk-panel)
   ============================================ */
.card {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  box-shadow: none;
}
.card .card-header {
  background: transparent;
  border-bottom: 1px solid var(--bdk-border);
  padding: 14px 18px;
  font-weight: 600;
  font-size: 14px;
}
.card .card-body { padding: 18px; }
.card.shadow-sm { box-shadow: var(--bdk-shadow-sm); }

/* Обёртка для страницы логина / экранов авторизации.
   Не используем bootstrap .row/.col — внутри .bdk-content без .container
   row схлопывался до ~60 px из-за конфликта flex-расчётов. */
.bdk-auth-wrap {
  max-width: 420px;
  margin: 0 auto;
  padding: 24px 0;
}
@media (max-width: 540px) {
  .bdk-auth-wrap { padding: 8px 0; }
}

/* Универсальная панель в стиле дашборда */
.bdk-panel {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  overflow: hidden;
}
.bdk-panel-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--bdk-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.bdk-panel-title {
  font-size: 15px;
  font-weight: 600;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--bdk-text);
}
.bdk-panel-title .bi { color: var(--bdk-text-muted); }
.bdk-panel-title .bdk-count {
  font-size: 12px;
  font-weight: 500;
  padding: 2px 8px;
  background: var(--bdk-bg);
  color: var(--bdk-text-muted);
  border-radius: 10px;
}
.bdk-panel-action {
  font-size: 13px;
  color: var(--bdk-primary);
  text-decoration: none;
  font-weight: 500;
}
.bdk-panel-action:hover { text-decoration: underline; color: var(--bdk-primary-hover); }
.bdk-panel-body { padding: 8px 0; }
.bdk-panel-body.padded { padding: 16px 20px; }


/* ============================================
   6. МЕТРИКИ ДАШБОРДА (.bdk-metric-card)
   ============================================ */
.bdk-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.bdk-metric-card {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  padding: 18px 20px;
  transition: border-color var(--bdk-transition), box-shadow var(--bdk-transition), transform var(--bdk-transition);
  text-decoration: none;
  color: inherit;
  display: block;
}
.bdk-metric-card:focus-visible {
  outline: none;
  border-color: var(--bdk-primary);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}
.bdk-metric-card:hover {
  border-color: var(--bdk-primary);
  box-shadow: var(--bdk-shadow);
  transform: translateY(-1px);
  color: inherit;
}
.bdk-metric-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.bdk-metric-label {
  font-size: 12.5px;
  color: var(--bdk-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.bdk-metric-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}
.bdk-metric-icon.blue  { background: var(--bdk-primary-bg); color: var(--bdk-primary); }
.bdk-metric-icon.gold  { background: var(--bdk-accent-bg);  color: var(--bdk-accent); }
.bdk-metric-icon.green { background: var(--bdk-success-bg); color: var(--bdk-success); }
.bdk-metric-icon.amber { background: var(--bdk-warning-bg); color: var(--bdk-warning); }
.bdk-metric-icon.red   { background: var(--bdk-danger-bg);  color: var(--bdk-danger); }
.bdk-metric-icon.cyan  { background: var(--bdk-info-bg);    color: var(--bdk-info); }
.bdk-metric-value {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 2px;
  line-height: 1.15;
  font-variant-numeric: tabular-nums;
}
.bdk-metric-trend {
  font-size: 12px;
  color: var(--bdk-text-muted);
  display: flex;
  align-items: center;
  gap: 4px;
}
.bdk-metric-trend.positive { color: var(--bdk-success); }
.bdk-metric-trend.negative { color: var(--bdk-danger); }


/* ============================================
   6b. ПЛИТКИ КАТАЛОГА (.bdk-catalog-tile)
   Быстрые пресеты на главной: Здания/Гостиницы/ТРЦ-БЦ/ГАБ/Склады/
   Общепит/Бизнес/Земли. 4×2 на десктопе, 2×4 на планшете, 1 кол на
   узком мобильном.
   ============================================ */
.bdk-catalog-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.bdk-catalog-tile {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  padding: 14px 16px;
  text-decoration: none;
  color: inherit;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: border-color var(--bdk-transition),
              box-shadow var(--bdk-transition),
              transform var(--bdk-transition);
}
.bdk-catalog-tile:hover,
.bdk-catalog-tile:focus-visible {
  border-color: var(--bdk-primary);
  box-shadow: var(--bdk-shadow);
  transform: translateY(-1px);
  color: inherit;
  outline: none;
}
.bdk-catalog-tile-body { min-width: 0; flex: 1 1 auto; }
.bdk-catalog-tile-label {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.15;
  margin-bottom: 2px;
}
.bdk-catalog-tile-count {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  color: var(--bdk-text-muted);
}
.bdk-catalog-tile-hint {
  font-size: 11.5px;
  color: var(--bdk-text-muted);
  margin-top: 1px;
}


/* ============================================
   7. ХЕДЕР СТРАНИЦЫ + ТАБЫ + ФИЛЬТР-БАР
   ============================================ */
.bdk-page-header {
  margin-bottom: 16px;
}
.bdk-page-header-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 20px;
}
.bdk-page-title h1 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.bdk-page-subtitle {
  color: var(--bdk-text-muted);
  font-size: 13.5px;
  margin: 0;
}
.bdk-page-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Табы-категории */
.bdk-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--bdk-border);
  margin-bottom: -1px;
  flex-wrap: wrap;
}
.bdk-tab {
  padding: 10px 14px;
  color: var(--bdk-text-muted);
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color var(--bdk-transition), border-color var(--bdk-transition);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.bdk-tab:hover { color: var(--bdk-text); }
.bdk-tab:focus-visible {
  outline: none;
  color: var(--bdk-text);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
  border-radius: var(--bdk-radius-sm);
}
.bdk-tab.active {
  color: var(--bdk-primary);
  border-bottom-color: var(--bdk-primary);
  font-weight: 600;
}
.bdk-tab .bdk-count {
  background: var(--bdk-bg);
  color: var(--bdk-text-muted);
  font-size: 11.5px;
  padding: 1px 7px;
  border-radius: 10px;
  font-weight: 500;
}
.bdk-tab.active .bdk-count {
  background: var(--bdk-primary-bg);
  color: var(--bdk-primary);
}

/* Фильтр-бар с чипами */
.bdk-filter-bar {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  padding: 12px 16px;
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.bdk-filter-search {
  position: relative;
  flex: 1;
  min-width: 200px;
}
.bdk-filter-search .bi-search {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bdk-text-dim);
  pointer-events: none;
}
.bdk-filter-search input {
  width: 100%;
  height: 32px;
  padding: 0 12px 0 32px;
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm);
  background: var(--bdk-surface);
  color: var(--bdk-text);
  font-size: 13px;
  font-family: inherit;
}
.bdk-filter-search input:focus {
  outline: none;
  border-color: var(--bdk-primary);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}

/* Чипы */
.bdk-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm);
  font-size: 12.5px;
  color: var(--bdk-text);
  cursor: pointer;
  transition: background-color var(--bdk-transition), border-color var(--bdk-transition), color var(--bdk-transition);
  text-decoration: none;
  font-weight: 500;
  white-space: nowrap;
}
.bdk-chip:hover {
  border-color: var(--bdk-border-strong);
  color: var(--bdk-text);
}
.bdk-chip:focus-visible {
  outline: none;
  border-color: var(--bdk-primary);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}
.bdk-chip.active {
  background: var(--bdk-primary-bg);
  border-color: var(--bdk-primary);
  color: var(--bdk-primary);
}
.bdk-chip .bi { font-size: 11px; }
.bdk-chip .bdk-chip-remove {
  color: var(--bdk-text-dim);
  margin-left: 2px;
  cursor: pointer;
  text-decoration: none;
}
.bdk-chip.active .bdk-chip-remove { color: var(--bdk-primary); }
.bdk-chip-remove:hover { color: var(--bdk-danger); }

/* Чип «понятого фильтра», распознанного YandexGPT.
   Используется в /search/ рядом со списком обычных чипов от регексп-парсера.
   Визуально отличается приглушённым iOS-синим цветом и иконкой ✨ (bi-stars). */
.badge.bdk-chip-gpt {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(0, 122, 255, 0.08);
  color: var(--ios-accent, #007aff);
  border: 1px solid rgba(0, 122, 255, 0.2);
  font-weight: 500;
  font-size: 12px;
  padding: 5px 9px;
  border-radius: 999px;
}
.badge.bdk-chip-gpt .bi {
  font-size: 11px;
  opacity: 0.9;
}

/* Переключатель view (сетка/список/карта) */
.bdk-view-toggle {
  display: inline-flex;
  background: var(--bdk-bg);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm);
  padding: 2px;
  margin-left: auto;
}
.bdk-view-toggle button,
.bdk-view-toggle a {
  border: none;
  background: transparent;
  width: 30px;
  height: 26px;
  border-radius: 4px;
  color: var(--bdk-text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.bdk-view-toggle button:hover,
.bdk-view-toggle a:hover { color: var(--bdk-text); }
.bdk-view-toggle button.active,
.bdk-view-toggle a.active {
  background: var(--bdk-surface);
  color: var(--bdk-text);
  box-shadow: var(--bdk-shadow-sm);
}


/* ============================================
   8. КАРТОЧКИ ОБЪЕКТОВ (.bdk-object-card)
   ============================================ */
.bdk-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}
.bdk-object-card {
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
  display: flex;
  flex-direction: column;
  position: relative;
  text-decoration: none;
  color: inherit;
}
.bdk-object-card:hover {
  border-color: var(--bdk-primary);
  box-shadow: var(--bdk-shadow-lg);
  transform: translateY(-2px);
  color: inherit;
}
.bdk-object-card-image {
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, #e5e7eb 0%, #d1d5db 100%);
  position: relative;
  overflow: hidden;
  display: block;
}
.bdk-object-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--bdk-transition-slow);
}
.bdk-object-card:hover .bdk-object-card-image img {
  transform: scale(1.04);
}
.bdk-object-card-image-empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bdk-text-dim);
  font-size: 32px;
}

.bdk-card-badges {
  position: absolute;
  top: 10px;
  left: 10px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  max-width: calc(100% - 60px);
  z-index: 2;
}
.bdk-card-badge {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--bdk-text);
  box-shadow: var(--bdk-shadow-sm);
  white-space: nowrap;
}
.bdk-card-badge.sale     { background: var(--bdk-accent);  color: #fff; }
.bdk-card-badge.exclusive{ background: var(--bdk-primary); color: #fff; }
.bdk-card-badge.rent     { background: var(--bdk-info);    color: #fff; }
.bdk-card-badge.business { background: var(--bdk-success); color: #fff; }

.bdk-card-checkbox {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 26px;
  height: 26px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  border: 1px solid var(--bdk-border-strong);
  border-radius: var(--bdk-radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: border-color var(--bdk-transition), background-color var(--bdk-transition);
  padding: 0;
  margin: 0;
}
.bdk-card-checkbox input {
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  width: 18px;
  height: 18px;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  border: 1.5px solid var(--bdk-border-strong);
  background: #fff;
}
.bdk-card-checkbox input:checked {
  background: var(--bdk-primary);
  border-color: var(--bdk-primary);
}
.bdk-card-checkbox input:checked::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 1px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.bdk-card-checkbox:hover input { border-color: var(--bdk-primary); }

.bdk-photo-count {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  color: #fff;
  padding: 4px 8px;
  border-radius: var(--bdk-radius-sm);
  font-size: 11.5px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  z-index: 2;
}

.bdk-object-card-body {
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.bdk-object-card-title {
  font-size: 14.5px;
  font-weight: 600;
  margin: 0 0 4px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  color: var(--bdk-text);
}
.bdk-object-card-title a {
  color: inherit;
  text-decoration: none;
}
.bdk-object-card-address {
  font-size: 12.5px;
  color: var(--bdk-text-muted);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bdk-object-card-attrs {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--bdk-border);
  flex-wrap: wrap;
}
.bdk-attr {
  font-size: 12.5px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--bdk-text);
}
.bdk-attr .bi {
  color: var(--bdk-text-muted);
  font-size: 13px;
}
.bdk-attr strong { font-weight: 600; }

.bdk-object-card-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: auto;
  gap: 8px;
}
.bdk-price {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--bdk-text);
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
}
.bdk-price.muted {
  font-size: 13px;
  font-weight: 500;
  color: var(--bdk-text-muted);
}
.bdk-price-per {
  font-size: 11.5px;
  color: var(--bdk-text-muted);
  margin-top: 2px;
}
.bdk-object-tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-top: 8px;
}


/* ============================================
   9. ТЕГИ И БЕЙДЖИ (.bdk-tag)
   ============================================ */
.bdk-tag {
  font-size: 10.5px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--bdk-bg);
  color: var(--bdk-text-muted);
  display: inline-block;
  text-decoration: none;
  border: 1px solid transparent;
  line-height: 1.4;
}
.bdk-tag.hot       { background: var(--bdk-danger-bg);  color: var(--bdk-danger); }
.bdk-tag.exclusive { background: var(--bdk-primary-bg); color: var(--bdk-primary); }
.bdk-tag.sea       { background: var(--bdk-info-bg);    color: var(--bdk-info); }
.bdk-tag.business  { background: var(--bdk-accent-bg);  color: var(--bdk-accent); }
.bdk-tag.success   { background: var(--bdk-success-bg); color: var(--bdk-success); }

/* Bootstrap-бейджи в нашей палитре */
.badge {
  font-weight: 500;
  font-size: 11.5px;
  padding: 4px 8px;
  border-radius: 10px;
}


/* ============================================
   10. ФОРМЫ (поля, селекты, чекбоксы)
   ============================================ */
.form-control,
.form-select {
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm);
  background-color: var(--bdk-surface);
  color: var(--bdk-text);
  font-size: 13.5px;
  font-family: inherit;
  padding: 8px 12px;
  transition: border-color var(--bdk-transition), box-shadow var(--bdk-transition);
}
.form-control:focus,
.form-select:focus {
  border-color: var(--bdk-primary);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
  outline: none;
}
.form-control::placeholder { color: var(--bdk-text-dim); }
.form-control-sm, .form-select-sm { padding: 6px 10px; font-size: 12.5px; }
.form-control-lg, .form-select-lg { padding: 11px 14px; font-size: 14.5px; }

.form-label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--bdk-text);
  margin-bottom: 4px;
}
.form-text { color: var(--bdk-text-muted); font-size: 12px; }

.form-check-input {
  border: 1.5px solid var(--bdk-border-strong);
  border-radius: 4px;
  width: 16px;
  height: 16px;
}
.form-check-input:checked {
  background-color: var(--bdk-primary);
  border-color: var(--bdk-primary);
}
.form-check-input:focus {
  border-color: var(--bdk-primary);
  box-shadow: 0 0 0 3px var(--bdk-primary-bg);
}
.form-check-label { font-size: 13.5px; }


/* ============================================
   11. ТАБЛИЦЫ
   ============================================ */
.table {
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--bdk-border);
  font-size: 13.5px;
  color: var(--bdk-text);
  /* Цифры в колонках «Площадь / Цена / ₽-м²» должны быть моноширинными,
     иначе ряды чисел дёргаются по ширине от строки к строке. */
  font-variant-numeric: tabular-nums;
}
.table > :not(caption) > * > * {
  padding: 10px 12px;
  background-color: transparent;
}
.table > thead {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--bdk-text-muted);
}
.table > thead > tr > th {
  border-bottom: 1px solid var(--bdk-border);
  background: var(--bdk-bg);
}
.table-hover > tbody > tr:hover { background-color: var(--bdk-bg); }


/* ============================================
   12. ПАГИНАЦИЯ
   ============================================ */
.pagination {
  gap: 4px;
}
.page-item .page-link,
.page-link {
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius-sm) !important;
  color: var(--bdk-text);
  background: var(--bdk-surface);
  font-size: 13px;
  font-weight: 500;
  padding: 6px 12px;
  min-width: 32px;
  text-align: center;
}
.page-link:hover {
  background: var(--bdk-bg);
  color: var(--bdk-text);
  border-color: var(--bdk-border-strong);
}
.page-item.active .page-link {
  background: var(--bdk-primary);
  border-color: var(--bdk-primary);
  color: #fff;
}
.page-item.disabled .page-link {
  color: var(--bdk-text-dim);
  background: var(--bdk-surface);
  border-color: var(--bdk-border);
}


/* ============================================
   13. ЛЕНТА АКТИВНОСТИ + ТОП-ОБЪЕКТЫ
   ============================================ */
.bdk-activity-item {
  padding: 12px 20px;
  display: flex;
  gap: 12px;
  border-bottom: 1px solid var(--bdk-border);
}
.bdk-activity-item:last-child { border-bottom: none; }
.bdk-activity-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--bdk-bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 12px;
  color: var(--bdk-text-muted);
}
.bdk-activity-icon.comment { background: var(--bdk-primary-bg); color: var(--bdk-primary); }
.bdk-activity-icon.price   { background: var(--bdk-accent-bg);  color: var(--bdk-accent); }
.bdk-activity-content {
  flex: 1;
  font-size: 13px;
  min-width: 0;
}
.bdk-activity-content strong { font-weight: 600; }
.bdk-activity-time {
  color: var(--bdk-text-muted);
  font-size: 12px;
  margin-top: 2px;
}

.bdk-top-object {
  padding: 10px 20px;
  display: flex;
  gap: 12px;
  align-items: center;
  border-bottom: 1px solid var(--bdk-border);
  text-decoration: none;
  color: inherit;
  transition: background var(--bdk-transition);
}
.bdk-top-object:hover { background: var(--bdk-bg); color: inherit; }
.bdk-top-object:last-child { border-bottom: none; }
.bdk-top-object-num {
  width: 24px;
  height: 24px;
  background: var(--bdk-bg);
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--bdk-text-muted);
  flex-shrink: 0;
}
.bdk-top-object-title {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bdk-top-object-price {
  font-size: 13px;
  font-weight: 600;
  color: var(--bdk-primary);
  white-space: nowrap;
}


/* ============================================
   14. СПИСОК ЗАДАЧ НА ДАШБОРДЕ
   ============================================ */
.bdk-task-list { list-style: none; padding: 0; margin: 0; }
.bdk-task-item {
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--bdk-border);
  transition: background var(--bdk-transition);
}
.bdk-task-item:hover { background: var(--bdk-bg); }
.bdk-task-item:last-child { border-bottom: none; }
.bdk-task-content { flex: 1; min-width: 0; }
.bdk-task-title {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--bdk-text);
  margin-bottom: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bdk-task-meta {
  font-size: 12px;
  color: var(--bdk-text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.bdk-task-meta .bi { font-size: 11px; }
.bdk-task-overdue {
  color: var(--bdk-danger);
  font-weight: 500;
}
.bdk-priority-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}
.bdk-priority-dot.urgent { background: var(--bdk-danger); }
.bdk-priority-dot.high   { background: var(--bdk-warning); }
.bdk-priority-dot.normal { background: var(--bdk-primary); }
.bdk-priority-dot.low    { background: var(--bdk-text-dim); }


/* ============================================
   14a. РАБОЧИЙ СТОЛ ЗАДАЧ (workbench, Этап 6)
   iOS-эстетика: воздух, тонкие разделители, 44px тач-таргеты.
   ============================================ */
/* Сводка digest — три карточки-счётчика. */
.bdk-wb-summary {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}
.bdk-wb-stat {
  flex: 1 1 0;
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: 12px;
  padding: 12px 10px;
  text-align: center;
  box-shadow: var(--bdk-shadow);
}
.bdk-wb-stat-num {
  display: block;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.5px;
  color: var(--bdk-text);
}
.bdk-wb-stat-label {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  color: var(--bdk-text-muted);
}
.bdk-wb-stat.danger .bdk-wb-stat-num { color: var(--bdk-danger); }

/* Сводка-счётчики как ссылки (виджет дашборда «Мои задачи»). */
.bdk-wb-summary-compact { margin-bottom: 14px; }
a.bdk-wb-stat { text-decoration: none; }
a.bdk-wb-stat:hover { border-color: var(--bdk-primary); }
a.bdk-wb-stat:hover .bdk-wb-stat-label { color: var(--bdk-primary); }

/* Группа задач внутри панели. */
.bdk-wb-group + .bdk-wb-group { border-top: 1px solid var(--bdk-border); }
.bdk-wb-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px 6px;
}
.bdk-wb-group-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--bdk-text-muted);
}
.bdk-wb-group-title .bi { font-size: 13px; }
.bdk-wb-group-title.danger { color: var(--bdk-danger); }
.bdk-wb-empty {
  margin: 0;
  padding: 8px 20px 14px;
  font-size: 13px;
  color: var(--bdk-text-dim);
}

/* Кликабельный заголовок задачи. */
.bdk-task-title-link { text-decoration: none; }
.bdk-task-title-link:hover .bdk-task-title { color: var(--bdk-primary); }
.bdk-task-link-obj {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
}

/* Быстрое действие — круглая кнопка 44×44 (HIG). */
.bdk-task-actions { flex-shrink: 0; }
.bdk-task-action-btn {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1.5px solid var(--bdk-border);
  background: var(--bdk-surface);
  color: var(--bdk-text-muted);
  font-size: 18px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background var(--bdk-transition), color var(--bdk-transition), border-color var(--bdk-transition);
}
.bdk-task-action-btn.complete:hover,
.bdk-task-action-btn.complete:focus-visible {
  border-color: var(--bdk-success, #16a34a);
  color: var(--bdk-success, #16a34a);
  background: rgba(22, 163, 74, 0.08);
}
.bdk-task-action-btn.reopen:hover,
.bdk-task-action-btn.reopen:focus-visible {
  border-color: var(--bdk-warning);
  color: var(--bdk-warning);
  background: rgba(217, 119, 6, 0.08);
}

/* Заголовок отфильтрованного по дню вида. */
.bdk-wb-filtered-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

/* Фильтры рабочего стола (iOS-чипы). Каждая строка — подпись + ряд чипов,
   ряд переносится (flex-wrap), поэтому на 375px нет горизонтального скролла. */
.bdk-task-filters {
  margin-bottom: 16px;
  padding: 12px 14px;
  background: var(--bdk-surface);
  border: 1px solid var(--bdk-border);
  border-radius: 12px;
  box-shadow: var(--bdk-shadow);
}
.bdk-filter-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.bdk-filter-row + .bdk-filter-row { margin-top: 10px; }
.bdk-filter-label {
  flex: 0 0 84px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--bdk-text-muted);
}
.bdk-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1 1 auto;
}
.bdk-filter-reset-row { margin-top: 12px; }
.bdk-chip-reset { color: var(--bdk-danger); }
.bdk-chip-reset:hover { border-color: var(--bdk-danger); color: var(--bdk-danger); }

@media (max-width: 480px) {
  /* Подпись над чипами, а не сбоку — экономит ширину. */
  .bdk-filter-row { flex-direction: column; gap: 6px; }
  .bdk-filter-label { flex-basis: auto; }
}

/* Поля формы создания внутри iOS-sheet. */
.bdk-ios-sheet .bdk-field { margin-bottom: 14px; }
.bdk-ios-sheet .bdk-field:last-child { margin-bottom: 0; }
.bdk-ios-sheet .bdk-field .form-label {
  display: block;
  margin-bottom: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ios-text-secondary, #3c3c43);
}
.bdk-ios-sheet .bdk-field .form-control,
.bdk-ios-sheet .bdk-field .form-select {
  min-height: 44px;
  border-radius: 10px;
  border: 1px solid var(--bdk-border);
  font-size: 16px; /* >=16px — iOS не зумит при фокусе */
}
.bdk-field-error {
  margin-top: 4px;
  font-size: 12.5px;
  color: var(--bdk-danger);
}

/* Мобильная адаптация 375px: компактнее счётчики, без горизонтального скролла. */
@media (max-width: 480px) {
  .bdk-wb-summary { gap: 8px; }
  .bdk-wb-stat { padding: 10px 6px; }
  .bdk-wb-stat-num { font-size: 22px; }
  .bdk-wb-stat-label { font-size: 11px; }
  .bdk-task-item { padding: 12px 14px; }
  .bdk-wb-group-head { padding: 12px 14px 6px; }
  .bdk-wb-empty { padding: 8px 14px 14px; }
}


/* ============================================
   15. КАРТА — ПЛЕЙСХОЛДЕР
   ============================================ */
.bdk-map-placeholder {
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, #eaf2f8 0%, #d6e6f0 100%);
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--bdk-text-muted);
  position: relative;
  overflow: hidden;
  text-align: center;
  padding: 16px;
}
.bdk-map-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(31, 95, 139, 0.15) 0, transparent 60px),
    radial-gradient(circle at 70% 60%, rgba(31, 95, 139, 0.12) 0, transparent 50px),
    radial-gradient(circle at 45% 75%, rgba(31, 95, 139, 0.18) 0, transparent 40px);
}
.bdk-map-placeholder .bi {
  font-size: 32px;
  margin-bottom: 8px;
  color: var(--bdk-primary);
  z-index: 1;
}
.bdk-map-placeholder > span {
  font-size: 13px;
  z-index: 1;
}


/* ============================================
   16. БРЕНДОВЫЕ УТИЛИТЫ
   ============================================ */
.bg-bdk-primary { background-color: var(--bdk-primary) !important; }
.bg-bdk-surface { background-color: var(--bdk-surface) !important; }
.bg-bdk-bg      { background-color: var(--bdk-bg) !important; }
.text-bdk-primary { color: var(--bdk-primary) !important; }
.text-bdk-accent  { color: var(--bdk-accent) !important; }
.border-bdk { border-color: var(--bdk-border) !important; }
.rounded-bdk { border-radius: var(--bdk-radius) !important; }
.rounded-bdk-sm { border-radius: var(--bdk-radius-sm) !important; }
.shadow-bdk { box-shadow: var(--bdk-shadow) !important; }
.shadow-bdk-lg { box-shadow: var(--bdk-shadow-lg) !important; }


/* ============================================
   17. ПУСТЫЕ СОСТОЯНИЯ (.bdk-empty)
   ============================================ */
.bdk-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--bdk-text-muted);
  background: var(--bdk-surface);
  border: 1px dashed var(--bdk-border-strong);
  border-radius: var(--bdk-radius);
}
.bdk-empty .bi {
  font-size: 40px;
  color: var(--bdk-text-dim);
  margin-bottom: 12px;
  display: block;
}
.bdk-empty-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--bdk-text);
  margin-bottom: 4px;
}
.bdk-empty-text {
  font-size: 13.5px;
  margin-bottom: 16px;
}


/* ============================================
   18. АЛЕРТЫ И УВЕДОМЛЕНИЯ
   ============================================ */
.alert {
  border: 1px solid var(--bdk-border);
  border-radius: var(--bdk-radius);
  font-size: 13.5px;
  padding: 12px 16px;
}
.alert-success { background: var(--bdk-success-bg); border-color: var(--bdk-success); color: var(--bdk-success); }
.alert-warning { background: var(--bdk-warning-bg); border-color: var(--bdk-warning); color: var(--bdk-warning); }
.alert-danger  { background: var(--bdk-danger-bg);  border-color: var(--bdk-danger);  color: var(--bdk-danger); }
.alert-info    { background: var(--bdk-info-bg);    border-color: var(--bdk-info);    color: var(--bdk-info); }


/* ============================================
   19. ОБЁРТКА КОНТЕНТА
   ============================================ */
.bdk-content {
  max-width: 1400px;
  margin: 0 auto;
  padding: 28px 24px 56px;
}
/* Старые шаблоны оборачивали контент в <div class="container py-4">. Внутри
   нашего .bdk-content такой враппер не нужен — обнуляем его paddings и
   max-width, чтобы не было «двойного контейнера». */
.bdk-content > .container,
.bdk-content > .container-fluid,
.bdk-content .container.py-4,
.bdk-content .container-fluid.py-4 {
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: none !important;
  width: 100%;
}
@media (max-width: 768px) {
  .bdk-content { padding: 20px 16px 48px; }
}


/* ============================================
   20. МОБИЛЬНАЯ АДАПТАЦИЯ
   ============================================ */
/* Антипереполнение по горизонтали: на узких экранах любые широкие
   элементы (длинные кадастровые номера, фотогаллереи) не должны
   вызывать горизонтальный скролл всего документа. */
html, body { overflow-x: hidden; }

/* На iOS Safari «vh» зашит на максимальную высоту viewport (с раскрытым
   address bar). Когда строка адреса сворачивается — внизу остаётся
   пустая полоса. «dvh» — динамический viewport, учитывает текущее
   состояние UI браузера. Переключаем .min-vh-100 (используется на body)
   через @supports, чтобы старые браузеры остались на 100vh. */
@supports (height: 100dvh) {
  .min-vh-100 { min-height: 100dvh !important; }
}

@media (max-width: 992px) {
  .bdk-metrics { grid-template-columns: repeat(2, 1fr); }
  .bdk-catalog-tiles { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .bdk-nav-links { display: none; }
  .bdk-search-box { display: none; }
  .bdk-metrics { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .bdk-catalog-tiles { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .bdk-card-grid { grid-template-columns: 1fr; }
  .bdk-filter-bar { padding: 10px 12px; }
  .bdk-view-toggle { display: none; }
  .bdk-page-header-row { flex-direction: column; align-items: stretch; }
  .bdk-page-actions { justify-content: flex-start; flex-wrap: wrap; }
  h1, .h1 { font-size: 20px; }
  body { font-size: 13.5px; }
  /* Топбар: уменьшаем внешние отступы, чтобы поместить логотип, гамбургер
     и аватар на iPhone SE 375 px без отрезания. */
  .bdk-topbar-inner { padding: 0 12px; gap: 8px; }
  .bdk-content { padding: 16px 12px 40px; }
  /* Target-size ≥44 px для гамбургера и аватара (WCAG 2.5.5). */
  .bdk-icon-btn { width: 44px; height: 44px; }
  .bdk-avatar { width: 40px; height: 40px; font-size: 13px; }
  /* iOS не должен зумить страницу при фокусе на input — минимум 16 px.
     Распространяется и на формы внутри offcanvas, и на десктоп-десктоп
     поля при включённой эмуляции мобильного. */
  .form-control, .form-select, .form-control-sm, .form-select-sm,
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="number"], input[type="search"], input[type="password"],
  input[type="date"], input[type="datetime-local"], textarea, select {
    font-size: 16px !important;
  }
  /* Кнопки в формах — крупнее, чтобы пальцем не промахиваться.
     На мобильном минимум 44 px по HIG/WCAG 2.5.5, без исключений. */
  .btn { padding: 10px 14px; min-height: 44px; }
  .btn-sm { padding: 8px 12px; min-height: 44px; font-size: 13px; }
  /* Любая таблица в нашем дизайне на мобильном переключается в режим
     горизонтального скролла (через обёртку), либо сам элемент скроллит. */
  .table-responsive-md, .bdk-table-wrap, .bdk-table { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .table { font-size: 12.5px; }
  .table th, .table td { padding: 8px 10px; white-space: nowrap; }
  /* Pagination: компактнее, не вылезает за пределы. */
  .pagination { flex-wrap: wrap; gap: 4px; }
  /* Tabs: разрешаем перенос на 2 строки, и каждый tab — минимум 44 px высотой. */
  .bdk-tabs { flex-wrap: wrap; }
  .bdk-tabs a, .bdk-tabs .bdk-tab { min-height: 44px; }
  /* Корзина-подборок (basket-bar) — не должна заслонять контент. */
  .selection-basket-bar { font-size: 13px; padding: 10px 12px; }
  /* Sticky offcanvas-кнопки внутри форм-wizard — кнопки навигации шага. */
  .bdk-wizard-nav { flex-wrap: wrap; gap: 8px; }
  .bdk-wizard-nav .btn { flex: 1 1 100%; }
  /* Карта /map/: сайдбар разворачивается над картой, не рядом. */
  .bdk-map-page { flex-direction: column; }
  .bdk-map-page .bdk-map-sidebar { width: 100%; max-height: none; }
  .bdk-map-page .bdk-map-container { height: 60vh; min-height: 360px; }
  /* Любая карта Yandex (партиал _map_widget.html ставит класс .bdk-map) —
     ограничиваем высоту, иначе 720 px карты на iPhone съедают весь экран.
     Inline height имеет более высокую специфичность — нужен !important. */
  .bdk-map { height: 50vh !important; min-height: 280px; max-height: 480px; }
  /* Объект-карточка: фото фиксируем меньше, иначе с длинным adress'ом
     карточка вытягивается. */
  .bdk-object-card .bdk-object-cover { aspect-ratio: 16/10; }
  /* Hero-блок дашборда — крупный текст приветствия может быть выше. */
  .bdk-page-header { padding: 12px 14px; }
}
@media (max-width: 540px) {
  .bdk-metrics { grid-template-columns: 1fr; }
  .bdk-metric-value { font-size: 22px; }
  /* Кнопка-чип фильтров на bdk-filter-bar при малом ширине растёт
     до полной строки, чтобы текст и иконка не наезжали друг на друга. */
  .bdk-filter-bar .btn { width: 100%; justify-content: center; }
  .bdk-filter-bar .bdk-filter-search { width: 100%; }
  /* Карта /map/ — сайдбар с фильтрами разворачивается над картой. */
  .bdk-map-page .bdk-map-container { height: 50vh; min-height: 300px; }
}
/* Утилитарный класс для горизонтально-прокручиваемых таблиц на мобильном.
   Используется через <div class="bdk-table-wrap"><table>...</table></div>. */
.bdk-table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.bdk-table-wrap > .table { margin-bottom: 0; }
/* Сетка тач-целей не меньше 44×44 для всех чекбоксов/радио в формах
   (WCAG 2.5.5), на iPhone SE по умолчанию слишком мелкие. */
@media (max-width: 768px) {
  .form-check { padding-left: 1.75em; min-height: 28px; }
  .form-check-input { width: 1.2em; height: 1.2em; margin-left: -1.75em; margin-top: 0.2em; }
}


/* ============================================
   21. ПЕЧАТЬ (минимум — основная print-логика
        в presentation/* шаблонах, их не трогаем)
   ============================================ */
@media print {
  .bdk-topbar,
  .bdk-filter-bar,
  .bdk-view-toggle,
  .selection-basket-bar,
  footer {
    display: none !important;
  }
  body { background: #fff; }
  .bdk-content { max-width: none; padding: 0; }
}

/* ============================================
   22. ЕДИНАЯ ЛЕНТА АКТИВНОСТИ CRM (Activity Timeline v1)
   Используется на карточке сделки и в Contact 360.
   Стиль iOS: тонкие разделители, круглые иконки, чипы-сегменты.
   ============================================ */
.c360-tl-item {
  display: flex;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--ios-separator, rgba(60, 60, 67, 0.12));
}
.c360-tl-item:last-child { border-bottom: 0; }
.c360-tl-ico {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border-radius: 50%;
  background: #f0f0f3;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #3c3c43;
}

/* Чипы-фильтр ленты по типу события. Тач-таргет ≥ 32px по высоте, скруглённые. */
.bdk-tl-chip {
  appearance: none;
  border: 1px solid var(--ios-separator, rgba(60, 60, 67, 0.18));
  background: #f5f5f7;
  color: var(--ios-text-primary, #1c1c1e);
  font-size: 13px;
  line-height: 1;
  padding: 8px 14px;
  min-height: 34px;
  border-radius: var(--bdk-radius-pill, 999px);
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.bdk-tl-chip:hover { background: #ececf0; }
.bdk-tl-chip.is-active {
  background: var(--ios-accent, #007aff);
  border-color: var(--ios-accent, #007aff);
  color: #fff;
}
@media (prefers-reduced-motion: reduce) {
  .bdk-tl-chip { transition: none; }
}

/* ============================================================
   Dashboard v2 — KPI-ячейки и футер панели
   ============================================================ */

/* KPI-ячейка: компактный виджет с числом и подписью */
.bdk-kpi-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: var(--bdk-bg, #f7f8fa);
  border-radius: var(--bdk-radius, 10px);
  padding: 10px 8px;
  min-height: 64px;
  border: 1px solid var(--bdk-border, #e5e7eb);
  transition: background 0.15s;
}
.bdk-kpi-cell:is(a):hover {
  background: var(--bdk-primary-bg, #eaf2f8);
  border-color: var(--bdk-primary, #1f5f8b);
  text-decoration: none;
}
.bdk-kpi-cell.danger {
  background: var(--bdk-danger-bg, #fef2f2);
  border-color: var(--bdk-danger, #dc2626);
}
.bdk-kpi-cell.warning {
  background: var(--bdk-warning-bg, #fffbeb);
  border-color: var(--bdk-warning, #d97706);
}
.bdk-kpi-num {
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  color: var(--bdk-text, #111827);
}
.bdk-kpi-label {
  font-size: 11px;
  color: var(--bdk-text-muted, #6b7280);
  margin-top: 3px;
  line-height: 1.2;
}

/* Футер панели dashboard-v2 */
.bdk-panel-footer {
  border-top: 1px solid var(--bdk-border, #e5e7eb);
}

@media (prefers-reduced-motion: reduce) {
  .bdk-kpi-cell { transition: none; }
}

/* ============================================
   Lead Source Attribution v1 — бейдж источника
   ============================================ */
.bdk-source-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  background: rgba(0, 122, 255, 0.08);
  color: var(--ios-accent, #007aff);
  border: 1px solid rgba(0, 122, 255, 0.2);
  white-space: nowrap;
}

.bdk-source-badge .bi {
  font-size: 11px;
}

/* Таблица отчёта по источникам */
.bdk-source-bar {
  height: 8px;
  border-radius: 4px;
  background: var(--ios-accent, #007aff);
  display: inline-block;
  min-width: 4px;
}

.bdk-source-bar-bg {
  height: 8px;
  border-radius: 4px;
  background: rgba(0, 122, 255, 0.1);
  overflow: hidden;
}

.bdk-source-row-unset .bdk-source-badge {
  background: rgba(60, 60, 67, 0.08);
  color: #8a8a8e;
  border-color: rgba(60, 60, 67, 0.15);
}

/* ============================================
   Data Quality Center v1 — стили центра качества
   ============================================ */

/* Сегментированный переключатель (тип объекта) */
.bdk-segmented {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  background: rgba(118, 118, 128, 0.08);
  padding: 4px;
  border-radius: 12px;
  width: fit-content;
  max-width: 100%;
}
.bdk-seg-btn {
  padding: 6px 14px;
  border-radius: 9px;
  font-size: 14px;
  color: var(--ios-text-primary, #1c1c1e);
  text-decoration: none;
  white-space: nowrap;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  transition: background 0.15s, color 0.15s;
}
.bdk-seg-btn.active {
  background: #fff;
  color: var(--ios-accent, #007aff);
  font-weight: 600;
  box-shadow: 0 1px 4px rgba(0,0,0,0.10);
}

/* Чипы проблем */
.bdk-issue-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 13px;
  border: 1px solid var(--ios-separator, rgba(60,60,67,0.12));
  background: var(--bs-gray-100, #f8f9fa);
  color: var(--ios-text-primary, #1c1c1e);
  text-decoration: none;
  min-height: 32px;
  transition: background 0.15s, color 0.15s;
  cursor: pointer;
  white-space: nowrap;
}
.bdk-issue-chip--active {
  background: rgba(0, 122, 255, 0.10);
  color: var(--ios-accent, #007aff);
  border-color: rgba(0, 122, 255, 0.25);
  font-weight: 600;
}

/* Активная KPI-карточка */
.bdk-panel--active {
  border: 2px solid var(--ios-accent, #007aff) !important;
}

/* ============================================
   Search History Dropdown v1 — история поиска
   (feedback_feedback #28)
   ============================================ */

/* Обёртка поля поиска с позиционированием dropdown */
.bdk-search-wrap {
  position: relative;
}

/* Сам dropdown */
.bdk-search-history-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  min-width: 280px;
  background: var(--ios-bg-sheet, #ffffff);
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
  border: 1px solid var(--ios-separator, rgba(60, 60, 67, 0.12));
  z-index: 1050;
  overflow: hidden;
}

/* Заголовок dropdown */
.bdk-hist-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--ios-separator, rgba(60, 60, 67, 0.12));
}

.bdk-hist-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--ios-text-secondary, #6e6e73);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.bdk-hist-clear-btn {
  background: none;
  border: none;
  font-size: 13px;
  color: var(--ios-accent, #007aff);
  padding: 0;
  cursor: pointer;
  line-height: 1;
}
.bdk-hist-clear-btn:hover {
  color: #0056cc;
}

/* Список подсказок */
.bdk-hist-list {
  list-style: none;
  margin: 0;
  padding: 4px 0;
  max-height: 320px;
  overflow-y: auto;
}

.bdk-hist-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  min-height: 44px;  /* HIG touch target */
  cursor: pointer;
  transition: background 0.12s;
  border: none;
}
.bdk-hist-item:hover,
.bdk-hist-item--active {
  background: rgba(0, 122, 255, 0.07);
}

.bdk-hist-icon {
  color: var(--ios-text-secondary, #6e6e73);
  font-size: 14px;
  flex-shrink: 0;
}

.bdk-hist-query {
  flex: 1;
  font-size: 15px;
  color: var(--ios-text-primary, #1c1c1e);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bdk-hist-count {
  font-size: 12px;
  color: var(--ios-text-secondary, #6e6e73);
  flex-shrink: 0;
}

/* Анимация появления */
.bdk-hist-enter {
  transition: opacity 0.15s ease, transform 0.15s ease;
}
.bdk-hist-enter-start {
  opacity: 0;
  transform: translateY(-4px);
}
.bdk-hist-enter-end {
  opacity: 1;
  transform: translateY(0);
}
.bdk-hist-leave {
  transition: opacity 0.1s ease;
}
.bdk-hist-leave-start {
  opacity: 1;
}
.bdk-hist-leave-end {
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  .bdk-hist-enter,
  .bdk-hist-leave {
    transition: none;
  }
}

/* ============================================================
   Шахматка новостроек (.nb-chess-*)
   ============================================================ */

.nb-chess-grid {
  display: grid;
  /* Первая колонка — номера этажей, остальные — юниты */
  grid-template-columns: 2rem repeat(var(--nb-cols, 1), minmax(52px, 1fr));
  gap: 3px;
  min-width: max-content;
}

.nb-chess-floor-label {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--bdk-text-muted);
  min-height: 48px;
}

.nb-chess-cell {
  position: relative;
  min-width: 52px;
  min-height: 48px;
  border-radius: 8px;
  border: 1.5px solid transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  cursor: pointer;
  transition: transform 100ms ease, box-shadow 100ms ease;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.nb-chess-cell:hover { transform: scale(1.05); }
.nb-chess-cell:active { transform: scale(0.97); }

/* Статусы */
.nb-chess-open {
  background: #f0f6ff;
  border-color: #007aff;
  color: #007aff;
}
.nb-chess-booked {
  background: #fff8e1;
  border-color: #ff9500;
  color: #b06200;
}
.nb-chess-sold {
  background: #f5f5f5;
  border-color: #c7c7cc;
  color: #8e8e93;
}
.nb-chess-closed {
  background: #e5e5ea;
  border-color: #636366;
  color: #636366;
  opacity: 0.6;
}
.nb-chess-empty {
  background: transparent;
  border-color: transparent;
  cursor: default;
}

/* Режим выбора */
.nb-chess-select-mode:not(.nb-chess-empty) {
  cursor: pointer;
}
.nb-chess-selected {
  outline: 3px solid #007aff;
  outline-offset: 1px;
  box-shadow: 0 0 0 4px rgba(0,122,255,0.15);
}

/* Текст внутри ячейки */
.nb-chess-number {
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}
.nb-chess-price {
  font-size: 9px;
  font-weight: 500;
  line-height: 1;
  opacity: 0.85;
}
.nb-chess-type-icon {
  position: absolute;
  bottom: 2px;
  right: 3px;
  font-size: 9px;
  opacity: 0.7;
}

/* Точки легенды */
.nb-legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 3px;
  margin-right: 4px;
  border: 1.5px solid transparent;
}
.nb-chess-open-dot   { background: #f0f6ff; border-color: #007aff; }
.nb-chess-booked-dot { background: #fff8e1; border-color: #ff9500; }
.nb-chess-sold-dot   { background: #f5f5f5; border-color: #c7c7cc; }
.nb-chess-closed-dot { background: #e5e5ea; border-color: #636366; }
}
