/* ==========================================================================
   ChatAudit · Design System
   Единая система цветов, типографики и компонентов.
   Работает в светлой и тёмной теме через prefers-color-scheme.
   ========================================================================== */

/* ── Токены: светлая тема (по умолчанию) ─────────────────────────────────── */
:root {
  /* Фоны */
  --bg-page:        #f7f7f5;
  --bg-panel:       #ffffff;
  --bg-subtle:      #f1efe8;
  --bg-hover:       #ebe9e0;

  /* Текст */
  --text-primary:   #1a1a18;
  --text-secondary: #5f5e5a;
  --text-tertiary:  #888780;
  --text-muted:     #b4b2a9;

  /* Границы */
  --border:         rgba(26, 26, 24, 0.08);
  --border-strong:  rgba(26, 26, 24, 0.15);

  /* Семантические — успех (зелёный, основной акцент процесса) */
  --success-bg:     #eaf3de;
  --success-fg:     #3b6d11;
  --success-border: #97c459;
  /* Soft-варианты success-fg для полупрозрачных фонов (замена color-mix) */
  --success-fg-soft18: rgba(59, 109, 17, 0.18);
  --success-fg-soft35: rgba(59, 109, 17, 0.35);
  --success-bg-soft45: rgba(92, 210, 141, 0.45);
  --success-border-soft60: rgba(76, 175, 80, 0.6);

  /* Предупреждение (жёлтый/оранжевый — идёт работа, внимание) */
  --warning-bg:     #faeeda;
  --warning-fg:     #854f0b;
  --warning-border: #ef9f27;

  /* Опасность/плохое (красный — потери, критические проблемы) */
  --danger-bg:      #fcebeb;
  --danger-fg:      #a32d2d;
  --danger-border:  #e24b4a;

  /* Информация (синий — нейтральное выделение, справочное) */
  --info-bg:        #e6f1fb;
  --info-fg:        #185fa5;
  --info-border:    #85b7eb;

  /* Форма — кнопки, поля ввода */
  --input-bg:       #ffffff;
  --input-border:   rgba(26, 26, 24, 0.15);
  --input-focus:    #3b6d11;

  /* Геометрия */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
}

/* ── Токены: тёмная тема ─────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-page:        #0a0a0c;
    --bg-panel:       #141417;
    --bg-subtle:      #1c1c20;
    --bg-hover:       #242429;

    --text-primary:   #e8e6e0;
    --text-secondary: #a8a6a0;
    --text-tertiary:  #6e6c66;
    --text-muted:     #4a4844;

    --border:         rgba(232, 230, 224, 0.08);
    --border-strong:  rgba(232, 230, 224, 0.15);

    --success-bg:     #1a3a1a;
    --success-fg:     #97c459;
    --success-border: #3b6d11;
    /* Soft-варианты для тёмной темы */
    --success-fg-soft18: rgba(151, 196, 89, 0.18);
    --success-fg-soft35: rgba(151, 196, 89, 0.35);
    --success-bg-soft45: rgba(26, 58, 26, 0.45);
    --success-border-soft60: rgba(59, 109, 17, 0.6);

    --warning-bg:     #3a2a10;
    --warning-fg:     #ef9f27;
    --warning-border: #854f0b;

    --danger-bg:      #3a1010;
    --danger-fg:      #e24b4a;
    --danger-border:  #791f1f;

    --info-bg:        #0f2a45;
    --info-fg:        #85b7eb;
    --info-border:    #185fa5;

    --input-bg:       #1c1c20;
    --input-border:   rgba(232, 230, 224, 0.15);
    --input-focus:    #97c459;
  }
}

/* ── Сброс и база ────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg-page);
  color: var(--text-primary);
  height: 100vh;
  display: flex;
  flex-direction: column;
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-weight: 500; color: var(--text-primary); }
h1 { font-size: 22px; }
h2 { font-size: 18px; }
h3 { font-size: 15px; }

a { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--success-fg); }

/* ── Шапка ───────────────────────────────────────────────────────────────── */
.header {
  display: flex;
  align-items: center;
  gap: 14px;
  height: 52px;
  padding: 0 20px;
  background: var(--bg-panel);
  border-bottom: 0.5px solid var(--border);
  flex-shrink: 0;
}
.header h1 { font-size: 15px; font-weight: 500; letter-spacing: -0.01em; }
.header span { font-size: 12px; color: var(--text-tertiary); }
.header-input { display: flex; gap: 8px; margin-left: auto; align-items: center; }
.header input[type=text] {
  width: 320px; height: 32px; padding: 0 12px;
  border: 0.5px solid var(--input-border);
  border-radius: var(--radius-md);
  background: var(--input-bg);
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
  transition: border-color 0.15s;
}
.header input[type=text]:focus { border-color: var(--input-focus); }
.header input[type=text]::placeholder { color: var(--text-tertiary); }

/* ── Кнопки ──────────────────────────────────────────────────────────────── */
.btn {
  padding: 0 14px;
  height: 32px;
  border-radius: var(--radius-md);
  border: 0.5px solid var(--input-border);
  background: transparent;
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 400;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn:hover:not(:disabled) { background: var(--bg-hover); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

.btn-primary {
  background: var(--success-fg);
  border-color: var(--success-fg);
  color: #ffffff;
  font-weight: 500;
}
.btn-primary:hover:not(:disabled) { background: var(--success-border); border-color: var(--success-border); color: var(--success-fg); }

.btn-secondary { /* альтернативный стиль — как .btn по умолчанию */ }

/* ── Основной layout ─────────────────────────────────────────────────────── */
.app {
  display: flex;
  flex: 1;
  overflow: hidden;
  padding: 10px;
  gap: 10px;
  background: var(--bg-page);
}

/* ── Сайдбар ─────────────────────────────────────────────────────────────── */
.sidebar {
  width: 240px;
  flex-shrink: 0;
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.sidebar-header { padding: 14px 16px 10px; }
.sidebar-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
}

.ops-list { flex: 1; overflow-y: auto; padding: 4px 0; }
.ops-list::-webkit-scrollbar { width: 4px; }
.ops-list::-webkit-scrollbar-track { background: transparent; }
.ops-list::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }

/* Пункт шага */
.op-item {
  display: flex;
  align-items: center;
  padding: 9px 16px;
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: background 0.1s;
  position: relative;
}
.op-item:hover { background: var(--bg-subtle); }
.op-item.active {
  background: var(--bg-subtle);
  border-left-color: var(--success-fg);
}
.op-item.active .op-label { color: var(--text-primary); font-weight: 500; }
.op-label {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
  flex: 1;
}
.op-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-right: 10px;
  background: var(--border-strong);
}
.op-dot.running { background: var(--warning-fg); animation: pulse 1.4s infinite; }
.op-dot.done    { background: var(--success-fg); }
.op-dot.error   { background: var(--danger-fg); }
.op-item.op-running .op-label { color: var(--text-primary); }
.op-item.op-error   .op-label { color: var(--danger-fg); }
.op-item.op-done    .op-label { color: var(--text-secondary); }

@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

/* Панель действий внизу сайдбара */
.action-panel {
  padding: 12px 14px;
  border-top: 0.5px solid var(--border);
  display: none;
  flex-direction: column;
  gap: 8px;
}

.action-btns { display: flex; flex-direction: column; gap: 6px; }
.action-btns .btn {
  width: 100%;
  justify-content: flex-start;
  height: 32px;
  font-size: 12px;
}

/* ── Правая панель контента ──────────────────────────────────────────────── */
.content {
  flex: 1;
  overflow-y: auto;
  padding: 24px 28px;
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
}
.content::-webkit-scrollbar { width: 6px; }
.content::-webkit-scrollbar-track { background: transparent; }
.content::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 3px; }

.content-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 200px;
  color: var(--text-tertiary);
  font-size: 14px;
}

/* ── Связка "поэтому → ..." на каждом шаге ───────────────────────────────── */
.connector {
  font-size: 12px;
  color: var(--text-secondary);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 18px;
  line-height: 1.5;
}
.connector svg { flex-shrink: 0; color: var(--text-tertiary); margin-top: 1px; }

/* ── Заголовок блока контента ────────────────────────────────────────────── */
.content-block { margin-bottom: 20px; }
.content-block-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 12px;
}

/* ── Карточки (универсальные) ────────────────────────────────────────────── */
.card {
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}

/* ── Иконки Lucide ───────────────────────────────────────────────────────── */
.lu { width: 14px; height: 14px; stroke-width: 1.6; flex-shrink: 0; }
.lu-16 { width: 16px; height: 16px; stroke-width: 1.6; flex-shrink: 0; }
.lu-20 { width: 20px; height: 20px; stroke-width: 1.6; flex-shrink: 0; }

/* ── Спиннер загрузки (новый — без символа внутри) ───────────────────────── */
.spinner {
  display: inline-block;
  width: 13px; height: 13px;
  border: 1.5px solid var(--border-strong);
  border-top-color: var(--text-secondary);
  border-radius: 50%;
  animation: spinner-rotate 0.8s linear infinite;
  vertical-align: -2px;
}
@keyframes spinner-rotate { to { transform: rotate(360deg); } }

/* ── Пилюля/бейдж ────────────────────────────────────────────────────────── */
.pill {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--radius-md);
  font-size: 11px;
  font-weight: 400;
  line-height: 1.6;
}
.pill-success { background: var(--success-bg); color: var(--success-fg); }
.pill-danger  { background: var(--danger-bg);  color: var(--danger-fg); }
.pill-warning { background: var(--warning-bg); color: var(--warning-fg); }
.pill-info    { background: var(--info-bg);    color: var(--info-fg); }
.pill-neutral { background: var(--bg-subtle);  color: var(--text-secondary); }

/* ── Шаг 1 · О бизнесе ───────────────────────────────────────────────────── */
.summary-text {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-primary);
  margin-bottom: 16px;
}

.loading-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 0;
  font-size: 13px;
  color: var(--text-secondary);
}

.tech-details {
  margin-top: 6px;
}
.tech-details > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: var(--bg-subtle);
  font-size: 12px;
  color: var(--text-secondary);
  user-select: none;
  transition: background 0.1s;
}
.tech-details > summary:hover { background: var(--bg-hover); }
.tech-details > summary::-webkit-details-marker { display: none; }
.tech-summary-icon {
  color: var(--text-tertiary);
  transition: transform 0.15s;
  display: inline-flex;
}
.tech-details[open] .tech-summary-icon { transform: rotate(180deg); }
.tech-summary-count {
  margin-left: auto;
  color: var(--text-tertiary);
  font-size: 11px;
}

.tech-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 2px 20px;
  padding: 12px 12px 6px;
  background: var(--bg-subtle);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  margin-top: -6px;
}
.tech-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  padding: 5px 0;
  font-size: 12px;
  border-bottom: 0.5px solid var(--border);
}
.tech-item:last-child { border-bottom: none; }
.tech-label { color: var(--text-tertiary); }
.tech-value { color: var(--text-primary); font-weight: 500; }
.tech-value-success { color: var(--success-fg); }
.tech-value-warning { color: var(--warning-fg); }
.tech-value-danger  { color: var(--danger-fg); }

/* ── Шаг 2 · Целевая аудитория ───────────────────────────────────────────── */
.segments-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}
.segment-card {
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.segment-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}
.segment-meta {
  font-size: 11px;
  color: var(--info-fg);
}
.segment-desc {
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-secondary);
}
.segment-needs {
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-primary);
  padding: 6px 10px;
  background: var(--bg-subtle);
  border-radius: var(--radius-sm);
  margin-top: 2px;
}
.segment-needs::before {
  content: "Ищет: ";
  color: var(--text-tertiary);
  font-weight: 500;
}

/* ── Шаг 3 · Активность аудитории (Вордстат) ─────────────────────────────── */
.wd-source {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-bottom: 16px;
}

.wd-chart {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  height: 110px;
  margin-bottom: 16px;
  padding: 0 4px;
}
.wd-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.wd-pct {
  font-size: 11px;
  color: var(--text-tertiary);
  line-height: 1;
}
.wd-pct-peak {
  color: var(--text-primary);
  font-weight: 500;
}
.wd-bar {
  width: 100%;
  max-width: 40px;
  background: var(--text-muted);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  min-height: 4px;
  transition: background 0.15s;
}
.wd-bar-peak {
  background: var(--info-fg);
}
.wd-day {
  font-size: 11px;
  color: var(--text-secondary);
  line-height: 1;
}
.wd-day-peak {
  color: var(--text-primary);
  font-weight: 500;
}

.wd-insight {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: var(--success-bg);
  border-radius: var(--radius-md);
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-primary);
  margin-bottom: 16px;
}
.wd-insight svg { margin-top: 2px; }
.wd-insight-bold {
  font-weight: 500;
  color: var(--text-primary);
}

.wd-queries-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 8px;
}
.wd-queries {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* Info-row — универсальная строка с иконкой (для пустых состояний и т.п.) */
.info-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
  font-size: 13px;
  color: var(--text-secondary);
}

/* ── Шаг 4 · Расписание проверок ─────────────────────────────────────────── */

/* Подсказка «можно за день» — лёгкая ненавязчивая плашка между заголовком
   и сеткой. Отвечает на возможный вопрос пользователя «а почему расписание
   на неделю, я хочу быстрее?» — сразу даём ответ что можно за день. */
.sch-quickhint {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  padding: 10px 14px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-left: 3px solid var(--info-fg, #5b8def);
  border-radius: 8px;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.sch-quickhint svg {
  flex-shrink: 0;
  color: var(--info-fg, #5b8def);
}

/* Шапка: «Начало» + date-picker + счётчик */
.sch-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  position: relative;
}
.sch-head-label {
  font-size: 12px;
  color: var(--text-tertiary);
}
.sch-date-picker {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--bg-subtle);
  border: 0.5px solid var(--input-border);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--text-primary);
  cursor: pointer;
  user-select: none;
  font-variant-numeric: tabular-nums;
  transition: background 0.1s;
}
.sch-date-picker:hover { background: var(--bg-hover); }
.sch-date-picker svg { color: var(--text-tertiary); }
.sch-date-picker-locked {
  cursor: default;
  background: transparent;
  border-color: transparent;
  padding-left: 0;
  color: var(--text-secondary);
}
.sch-date-picker-locked:hover { background: transparent; }
.sch-counter {
  margin-left: auto;
  font-size: 12px;
  color: var(--text-tertiary);
}
.sch-counter b {
  color: var(--text-primary);
  font-weight: 500;
}

/* Сетка недели */
.sch-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 16px;
  position: relative;
}
.sch-col {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: relative;
  min-width: 0;
}
.sch-day-label {
  font-size: 11px;
  text-align: center;
  padding: 6px 2px 7px;
  border-bottom: 0.5px solid var(--border);
  color: var(--text-tertiary);
  line-height: 1.3;
  font-variant-numeric: tabular-nums;
}
.sch-day-label-peak {
  color: var(--text-primary);
  font-weight: 500;
}
.sch-day-label-past {
  color: var(--text-muted);
}
.sch-day-dow {
  display: inline-block;
}
.sch-day-date {
  font-size: 10px;
  opacity: 0.75;
  margin-top: 1px;
}
.sch-day-peak-mark {
  margin-left: 4px;
  font-size: 9px;
  color: var(--success-fg);
  font-weight: 400;
  letter-spacing: 0.03em;
  vertical-align: 1px;
}

/* Слот времени */
.sch-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 4px;
  background: var(--info-bg);
  color: var(--info-fg);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  font-variant-numeric: tabular-nums;
  transition: background 0.1s;
  min-height: 26px;
}
.sch-slot:hover {
  background: var(--info-border);
  color: var(--text-primary);
}
.sch-slot-overdue {
  background: var(--danger-bg);
  color: var(--danger-fg);
}
.sch-slot-overdue:hover {
  background: var(--danger-border);
  color: #fff;
}

/* Played-слот: галочка + время + оценка, цвет по оценке.
   Клик открывает отчёт, редактирование заблокировано. */
.sch-slot-played {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  padding: 5px 6px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  cursor: pointer;
  min-height: 26px;
  font-variant-numeric: tabular-nums;
  border: 0.5px solid transparent;
  transition: background 0.1s, border-color 0.1s;
}
.sch-slot-played-time {
  color: var(--text-tertiary);
  font-size: 10px;
}
.sch-slot-played-score {
  font-weight: 500;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.sch-slot-played-check {
  flex-shrink: 0;
  display: inline-flex;
}

.sch-slot-played-good  { background: var(--success-bg); border-color: var(--success-border); }
.sch-slot-played-good  .sch-slot-played-score,
.sch-slot-played-good  .sch-slot-played-check { color: var(--success-fg); }
.sch-slot-played-good:hover  { background: var(--success-border); }

.sch-slot-played-med   { background: var(--warning-bg); border-color: var(--warning-border); }
.sch-slot-played-med   .sch-slot-played-score,
.sch-slot-played-med   .sch-slot-played-check { color: var(--warning-fg); }
.sch-slot-played-med:hover   { background: var(--warning-border); }

.sch-slot-played-low   { background: var(--danger-bg); border-color: var(--danger-border); }
.sch-slot-played-low   .sch-slot-played-score,
.sch-slot-played-low   .sch-slot-played-check { color: var(--danger-fg); }
.sch-slot-played-low:hover   { background: var(--danger-border); }

.sch-slot-played-na    { background: var(--bg-panel-alt); border-color: var(--border); }
.sch-slot-played-na    .sch-slot-played-score,
.sch-slot-played-na    .sch-slot-played-check { color: var(--text-tertiary); }
.sch-slot-played-na:hover    { background: var(--border); }

/* Легенда под сеткой — показывается если есть played-слоты */
.sch-legend {
  display: flex;
  gap: 14px;
  font-size: 11px;
  color: var(--text-tertiary);
  margin: -8px 0 12px;
  flex-wrap: wrap;
}
.sch-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.sch-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  border: 0.5px solid;
  display: inline-block;
}

/* Кнопка добавления */
.sch-add {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 4px;
  border: 0.5px dashed var(--input-border);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  cursor: pointer;
  min-height: 26px;
  transition: border-color 0.1s, color 0.1s;
}
.sch-add:hover {
  border-color: var(--success-fg);
  color: var(--success-fg);
}

/* Подвал расписания */
.sch-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--text-tertiary);
  flex-wrap: wrap;
}
.sch-hint {
  flex: 1;
}

/* ── Пикер времени (timepicker) ──────────────────────────────────────────── */
.tp {
  position: absolute;
  z-index: 100;
  background: var(--bg-panel);
  border: 0.5px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 6px;
  width: 150px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35);
}
.tp-cols {
  display: flex;
  gap: 4px;
  margin-bottom: 6px;
}
.tp-col {
  flex: 1;
  max-height: 140px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.tp-col::-webkit-scrollbar { width: 3px; }
.tp-col::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }
.tp-divider {
  width: 1px;
  background: var(--border);
  margin: 4px 0;
  flex-shrink: 0;
}
.tp-item {
  padding: 5px 0;
  text-align: center;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 4px;
  font-variant-numeric: tabular-nums;
  user-select: none;
}
.tp-item:hover {
  background: var(--bg-subtle);
  color: var(--text-primary);
}
.tp-item.active {
  background: var(--info-bg);
  color: var(--info-fg);
  font-weight: 500;
}
.tp-item.disabled {
  color: var(--text-muted);
  cursor: not-allowed;
}
.tp-item.disabled:hover {
  background: transparent;
  color: var(--text-muted);
}
.tp-hint {
  font-size: 10px;
  color: var(--danger-fg);
  padding: 4px 2px;
  display: none;
}
.tp-actions {
  display: flex;
  gap: 4px;
  align-items: stretch;
}
.tp-save {
  flex: 1;
  padding: 6px;
  text-align: center;
  background: var(--success-bg);
  color: var(--success-fg);
  font-size: 11px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 500;
  border: none;
  user-select: none;
  transition: background 0.1s;
}
.tp-save:hover { background: var(--success-border); color: #fff; }
.tp-delete {
  padding: 6px 8px;
  background: var(--danger-bg);
  color: var(--danger-fg);
  font-size: 11px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.1s;
}
.tp-delete:hover { background: var(--danger-border); color: #fff; }
.tp-cancel {
  padding: 6px 10px;
  background: transparent;
  color: var(--text-tertiary);
  border: 0.5px solid var(--input-border);
  font-size: 11px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.1s, color 0.1s;
}
.tp-cancel:hover {
  background: var(--bg-subtle);
  color: var(--text-primary);
}

/* ── Календарь выбора даты ───────────────────────────────────────────────── */
.cal {
  background: var(--bg-panel);
  border: 0.5px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 12px;
  width: 240px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35);
}
.cal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.cal-nav {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: 0.5px solid var(--input-border);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
  padding: 0;
}
.cal-nav:hover {
  background: var(--bg-subtle);
  color: var(--text-primary);
}
.cal-month {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.cal-dow {
  font-size: 10px;
  color: var(--text-tertiary);
  text-align: center;
  padding: 4px 0;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* Перекрываем старый стиль .cal-day из styles.css */
.cal-day {
  font-size: 12px;
  text-align: center;
  padding: 6px 2px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  transition: background 0.1s, color 0.1s;
}
.cal-day:hover {
  background: var(--bg-subtle);
  color: var(--text-primary);
}
.cal-day.cal-other {
  color: var(--text-muted);
  opacity: 0.4;
  cursor: default;
  pointer-events: none;
}
.cal-day.cal-today {
  color: var(--success-fg);
  font-weight: 500;
}
.cal-day.cal-selected {
  background: var(--success-bg);
  color: var(--success-fg);
  font-weight: 500;
}
.cal-day.cal-selected:hover {
  background: var(--success-border);
  color: #fff;
}

/* Перекрываем .pcol-item (в старом коде) — это тоже пикер */
.pcol-item {
  padding: 5px 0;
  text-align: center;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  border-radius: 4px;
  font-variant-numeric: tabular-nums;
  user-select: none;
}
.pcol-item:hover {
  background: var(--bg-subtle);
  color: var(--text-primary);
}
.pcol-item.pac {
  background: var(--info-bg);
  color: var(--info-fg);
  font-weight: 500;
}
.pcol-item.pbl {
  color: var(--text-muted);
  cursor: not-allowed;
}
.pcol-item.pbl:hover {
  background: transparent;
  color: var(--text-muted);
}

/* Overdue-badge в sidebar */
.overdue-badge {
  margin-left: 6px;
  background: var(--danger-fg);
  color: #fff;
  border-radius: 10px;
  font-size: 10px;
  padding: 1px 6px;
  font-weight: 500;
}

/* Статусы сохранения расписания */
.schedule-error {
  color: var(--danger-fg);
  font-size: 12px;
  margin-top: 8px;
}

/* Баннер со ссылкой для восстановления сессии. */
.restore-link-banner {
  background: var(--info-bg);
  border: 0.5px solid var(--info-border);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  margin: 0 0 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.restore-link-banner-text {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
}
.restore-link-banner-row {
  display: flex;
  gap: 6px;
  align-items: center;
}
.restore-link-input {
  flex: 1;
  font-size: 12px;
  padding: 6px 8px;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  color: var(--text-primary);
  font-family: var(--font-mono, monospace);
  min-width: 0;
}
.restore-link-input:focus {
  outline: none;
  border-color: var(--info-fg);
}

/* Индикатор статуса сохранения расписания. */
.sch-save-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  min-height: 20px;
}
.sch-save-status-idle {
  color: var(--text-tertiary);
}
.sch-save-status-saving {
  color: var(--text-tertiary);
}
.sch-save-status-saved {
  color: var(--success-fg);
}
.sch-save-status-error {
  color: var(--danger-fg);
}

/* ── Шаг 5 · Фокус-группа ────────────────────────────────────────────────── */
.fg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.persona-card,
.persona-card-anim {
  display: flex;
  gap: 10px;
  padding: 12px 14px;
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s, opacity .35s ease, transform .35s ease;
  width: auto;
  align-items: flex-start;
}
.persona-card:hover,
.persona-card-anim:hover {
  background: var(--bg-hover);
  border-color: var(--border-strong);
}
.persona-card-anim {
  opacity: 0;
  transform: translateY(10px);
}
.persona-card-anim.show {
  opacity: 1;
  transform: translateY(0);
}

.persona-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 500;
  flex-shrink: 0;
}
.persona-avatar-info    { background: var(--info-bg);    color: var(--info-fg); }
.persona-avatar-success { background: var(--success-bg); color: var(--success-fg); }
.persona-avatar-warning { background: var(--warning-bg); color: var(--warning-fg); }
.persona-avatar-purple  { background: rgba(127, 119, 221, 0.15);   color: #AFA9EC; }
.persona-avatar-pink    { background: rgba(212, 83, 126, 0.15);    color: #ED93B1; }

.persona-info {
  flex: 1;
  min-width: 0;
}
.persona-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.persona-meta {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-bottom: 6px;
}
.persona-desc {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.persona-contacts {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 0.5px solid var(--border);
}
.persona-contact {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}
.persona-contact span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

/* Отыгравшая карточка — read-only, клик открывает отчёт */
.persona-card-played {
  background: var(--bg-subtle);
  opacity: 0.95;
}
.persona-card-played:hover {
  background: var(--bg-hover);
  border-color: var(--border-strong);
}
.persona-played-marker {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--success-fg);
  margin-top: 4px;
}
.persona-score {
  flex-shrink: 0;
  align-self: center;
  font-size: 20px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  padding-left: 10px;
}

/* Иконка слева от инпута телефона/email в редакторе */
.fg-input-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  flex-shrink: 0;
  color: var(--text-tertiary);
}

/* Редактор персонажа (add + edit) */
.persona-editor {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 14px;
  background: var(--bg-panel);
  border: 0.5px solid var(--border-strong);
  border-radius: var(--radius-md);
}

.fg-input {
  padding: 6px 10px;
  background: var(--input-bg);
  border: 0.5px solid var(--input-border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 12px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.12s;
}
.fg-input:focus { border-color: var(--input-focus); }
.fg-input::placeholder { color: var(--text-tertiary); }

.fg-input-row {
  display: flex;
  gap: 4px;
}
.fg-input-age {
  width: 72px;
  flex-shrink: 0;
}

.fg-textarea {
  resize: none;
  line-height: 1.5;
  min-height: 64px;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.fg-textarea::-webkit-scrollbar { width: 4px; }
.fg-textarea::-webkit-scrollbar-track { background: transparent; }
.fg-textarea::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }

.fg-actions {
  display: flex;
  gap: 4px;
  margin-top: 2px;
}

.fg-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

.fg-add-btn {
  font-size: 12px;
}

/* Плашка согласия */
.fg-consent {
  margin-top: 16px;
  padding: 12px 14px;
  background: var(--warning-bg);
  border: 0.5px solid var(--warning-border);
  border-radius: var(--radius-md);
}
.fg-consent-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 12px;
  color: var(--text-primary);
  line-height: 1.5;
  cursor: pointer;
  user-select: none;
}
.fg-consent-checkbox {
  margin: 0;
  margin-top: 2px;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: var(--warning-fg);
}
.fg-consent-link {
  color: var(--info-fg);
  text-decoration: underline;
  text-decoration-color: transparent;
  transition: text-decoration-color 0.1s;
}
.fg-consent-link:hover {
  text-decoration-color: var(--info-fg);
}

/* Дисэйбл кнопок через класс (добавляется applyConsentState) */
.btn:disabled,
.btn-disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

/* ── Активный аудит: «Идёт аудит...» с анимированными точками ───────────── */
/* Кнопка btn-now в момент когда аудит реально работает (стрим стримит).
   Визуально показываем что что-то происходит — пульсирующая опасити плюс
   три анимированные точки после текста. Не блокируем клик через
   pointer-events (кнопка disabled через атрибут, см. .btn:disabled выше). */
.btn-running {
  opacity: 0.7;
  background: var(--success-bg-soft45);
  border-color: var(--success-border-soft60);
  animation: btn-running-pulse 1.8s ease-in-out infinite;
}
.btn-running::after {
  content: '';
  display: inline-block;
  width: 14px;
  margin-left: 4px;
  text-align: left;
  animation: btn-running-dots 1.4s steps(4, end) infinite;
}
@keyframes btn-running-pulse {
  0%, 100% { opacity: 0.85; }
  50%      { opacity: 0.55; }
}
@keyframes btn-running-dots {
  0%   { content: ''; }
  25%  { content: '.'; }
  50%  { content: '..'; }
  75%  { content: '...'; }
  100% { content: ''; }
}

/* ── Шкала скорости ответа в отчёте ─────────────────────────────────────── */
/* Визуальный блок где средний/максимальный ответ оператора подсвечивается
   на шкале с 5 диапазонами по нашей методике (см. 08-methodology.js).
   SVG-bar — масштабируется по ширине, маркер позиционируется по avgIdx. */
.speed-scale-block {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 16px 18px 14px;
  margin: 12px 0;
}
.speed-scale-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}
.speed-scale-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.speed-scale-sub {
  font-size: 12px;
  color: var(--text-secondary);
}
.speed-scale-svg {
  display: block;
  width: 100%;
  height: 70px;
  margin: 4px 0 8px;
}
.speed-scale-verdict {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}
.speed-scale-pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.speed-scale-note {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.4;
}
.speed-scale-extra {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.speed-scale-extra b {
  color: var(--text-primary);
}
.speed-scale-source {
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px dashed var(--border-subtle);
  font-size: 11px;
  color: var(--text-tertiary, var(--text-secondary));
  opacity: 0.75;
}

/* ── Каналы коммуникации (юр. квалификация) ─────────────────────────────── */
/* Блок появляется в отчёте если виджет чата предлагает мессенджеры/соцсети
   (telegram, whatsapp, instagram и т.п.). Для каждого канала с правовым
   риском показываем нейтральную справку без рекомендаций «куда переходить». */
.rep-channels {
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 16px 18px 14px;
  margin: 12px 0;
}
.rep-channels-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.rep-channels-rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ch-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 13px;
  line-height: 1.5;
}
.ch-row-ok {
  color: var(--text-secondary);
  font-size: 12px;
  align-items: center;
}
.ch-dot {
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 6px;
}
.ch-dot-danger { background: var(--danger-fg); }
.ch-dot-warn   { background: #e6c366; }
.ch-dot-info   { background: var(--info-fg, #5b8def); }
.ch-body {
  flex: 1;
  min-width: 0;
}
.ch-head {
  color: var(--text-primary);
  margin-bottom: 2px;
}
.ch-text {
  color: var(--text-secondary);
}
.ch-sources {
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-tertiary);
  font-style: italic;
}
.ch-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 500;
}
.ch-pill-ok {
  background: var(--success-fg-soft18);
  color: var(--success-fg);
  border: 1px solid var(--success-fg-soft35);
}
.ch-row-note {
  font-size: 12px;
  color: var(--text-secondary);
}
.rep-channels-source {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed var(--border-subtle);
  font-size: 11px;
  color: var(--text-tertiary, var(--text-secondary));
  opacity: 0.85;
  line-height: 1.5;
}

/* ── Отчёт по диалогу ────────────────────────────────────────────────────── */
.rep {
  font-size: 13px;
}

/* Шапка отчёта */
.rep-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 0.5px solid var(--border);
}
.rep-ava {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 500;
  flex-shrink: 0;
}
.rep-id {
  flex: 1;
  min-width: 0;
}
.rep-name {
  font-size: 15px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.rep-meta {
  font-size: 11px;
  color: var(--text-tertiary);
}
.rep-score {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  padding-left: 16px;
  border-left: 0.5px solid var(--border);
}
.rep-score-val {
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.rep-score-good { color: var(--success-fg); }
.rep-score-med  { color: var(--warning-fg); }
.rep-score-low  { color: var(--danger-fg); }
.rep-score-na   { color: var(--text-tertiary); }
.rep-score-lbl {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 3px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Задача персонажа — блок под шапкой с синим левым акцентом.
   Контекст: что клиент пытался выяснить/возразить. */
.rep-task {
  margin: 16px 0 16px;
  padding: 12px 16px;
  background: var(--bg-subtle);
  border-left: 3px solid var(--info-fg);
  border-radius: 4px;
}
.rep-task-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.rep-task-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  font-weight: 500;
}
.rep-task-tag {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 3px;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.rep-task-tag-info {
  background: var(--info-bg);
  color: var(--info-fg);
}
.rep-task-tag-objection {
  background: var(--warning-bg);
  color: var(--warning-fg);
}
.rep-task-body {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-primary);
}

/* Секция */
.rep-sec {
  margin-bottom: 20px;
}
.rep-sec:last-child {
  margin-bottom: 0;
}
.rep-sec-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 10px;
}

/* Метрики — сетка auto-fit */
.rep-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 6px;
}
.rep-stat {
  background: var(--bg-subtle);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
}
.rep-stat-val {
  font-size: 16px;
  font-weight: 500;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}
.rep-stat-lbl {
  font-size: 10px;
  color: var(--text-tertiary);
  line-height: 1.3;
  margin-top: 2px;
}

/* Критерии — круговой индикатор + название + пояснение в одной строке */
.rep-crit-list {
  display: flex;
  flex-direction: column;
}
.rep-crit-row {
  display: grid;
  grid-template-columns: 36px 1fr;
  align-items: start;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 0.5px solid var(--border);
}
.rep-crit-row:last-child { border-bottom: 0; }
.rep-donut {
  width: 36px;
  height: 36px;
  position: relative;
  flex-shrink: 0;
}
.rep-donut svg {
  width: 36px;
  height: 36px;
  transform: rotate(-90deg);
}
.rep-donut-track {
  fill: none;
  stroke: var(--bg-subtle);
  stroke-width: 3;
}
.rep-donut-fill {
  fill: none;
  stroke-width: 3;
  stroke-linecap: round;
  transition: stroke-dasharray 0.3s ease;
}
.rep-donut-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.rep-crit-good .rep-donut-fill { stroke: var(--success-fg); }
.rep-crit-good .rep-donut-num  { color: var(--success-fg); }
.rep-crit-med  .rep-donut-fill { stroke: var(--warning-fg); }
.rep-crit-med  .rep-donut-num  { color: var(--warning-fg); }
.rep-crit-low  .rep-donut-fill { stroke: var(--danger-fg); }
.rep-crit-low  .rep-donut-num  { color: var(--danger-fg); }
.rep-crit-na   .rep-donut-fill { stroke: var(--text-muted); }
.rep-crit-na   .rep-donut-num  { color: var(--text-tertiary); }

.rep-crit-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.rep-crit-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-primary);
}
.rep-crit-desc {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* Главная плашка вердикта — заголовок проблемы + статус лида справа.
   Три варианта: verdict-lost (красный), -risk (жёлтый), -won (зелёный). */
.rep-verdict {
  border-radius: var(--radius-md);
  padding: 16px 20px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
  border: 0.5px solid;
  margin-bottom: 24px;
}
.rep-verdict.verdict-lost {
  background: var(--danger-bg);
  border-color: var(--danger-border);
}
.rep-verdict.verdict-lost .rep-verdict-title { color: var(--danger-fg); }
.rep-verdict.verdict-lost .rep-verdict-badge {
  background: var(--danger-border);
  color: #fff;
}
.rep-verdict.verdict-risk {
  background: var(--warning-bg);
  border-color: var(--warning-border);
}
.rep-verdict.verdict-risk .rep-verdict-title { color: var(--warning-fg); }
.rep-verdict.verdict-risk .rep-verdict-badge {
  background: var(--warning-border);
  color: var(--warning-fg);
}
.rep-verdict.verdict-won {
  background: var(--success-bg);
  border-color: var(--success-border);
}
.rep-verdict.verdict-won .rep-verdict-title { color: var(--success-fg); }
.rep-verdict.verdict-won .rep-verdict-badge {
  background: var(--success-border);
  color: #fff;
}
.rep-verdict-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.rep-verdict-title {
  font-size: 14px;
  font-weight: 500;
}
.rep-verdict-text {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.55;
}
.rep-verdict-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Рекомендации — нумерованный список */
.rep-reco-list {
  margin: 0;
  padding-left: 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rep-reco-list li {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-primary);
  padding-left: 4px;
}
.rep-reco-list li::marker {
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}
.rep-reco-single {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-primary);
}

/* Контекст — справочная информация под рекомендациями */
.rep-context {
  padding: 14px 18px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rep-context-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  font-size: 12px;
}
.rep-context-lbl {
  color: var(--text-tertiary);
}
.rep-context-val {
  color: var(--text-secondary);
  line-height: 1.5;
}

/* Техническая статистика — свёрнутый блок в конце отчёта */
.rep-stats-wrap {
  margin-top: 12px;
  margin-bottom: 8px;
}
.rep-stats-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border: 0.5px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text-tertiary);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
}
.rep-stats-toggle:hover {
  background: var(--bg-hover);
  color: var(--text-secondary);
}
.rep-stats-toggle svg {
  transition: transform 0.15s ease;
}
.rep-stats-body {
  padding-top: 10px;
}

/* 152-ФЗ чеклист */
.rep-pd-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  margin-bottom: 8px;
}
.rep-pd-ok      { background: var(--success-bg); border: 0.5px solid var(--success-border); }
.rep-pd-partial { background: var(--warning-bg); border: 0.5px solid var(--warning-border); }
.rep-pd-fail    { background: var(--danger-bg);  border: 0.5px solid var(--danger-border); }
.rep-pd-na      { background: var(--bg-subtle);  border: 0.5px solid var(--border); }

.rep-pd-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.rep-pd-dot-ok      { background: var(--success-fg); }
.rep-pd-dot-partial { background: var(--warning-fg); }
.rep-pd-dot-fail    { background: var(--danger-fg); }
.rep-pd-dot-na      { background: var(--text-tertiary); }

.rep-pd-verdict {
  font-size: 12px;
  font-weight: 500;
}
.rep-pd-verdict-ok      { color: var(--success-fg); }
.rep-pd-verdict-partial { color: var(--warning-fg); }
.rep-pd-verdict-fail    { color: var(--danger-fg); }
.rep-pd-verdict-na      { color: var(--text-secondary); }

/* Подсекции — форма ПД и запрос в чате */
.rep-pd-subsec {
  margin-bottom: 8px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  border: 0.5px solid var(--border);
}
.rep-pd-subsec-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}
.rep-pd-subsec-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
}
.rep-pd-subsec-detail {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 2px;
}
.rep-pd-subsec-com {
  font-size: 11px;
  color: var(--text-tertiary);
  margin-top: 4px;
  line-height: 1.4;
}
.rep-pd-method {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 8px;
  white-space: nowrap;
}
.rep-pd-method-ok {
  background: var(--success-bg);
  color: var(--success-fg);
  border: 0.5px solid var(--success-border);
}
.rep-pd-method-partial {
  background: var(--warning-bg);
  color: var(--warning-fg);
  border: 0.5px solid var(--warning-border);
}
.rep-pd-method-fail {
  background: var(--danger-bg);
  color: var(--danger-fg);
  border: 0.5px solid var(--danger-border);
}
.rep-pd-method-na {
  background: var(--bg-subtle);
  color: var(--text-tertiary);
  border: 0.5px solid var(--border);
}

.rep-pd-checks {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rep-pd-item {
  display: flex;
  gap: 8px;
  padding: 8px 10px;
  background: var(--bg-subtle);
  border-radius: var(--radius-sm);
}
.rep-pd-icon {
  flex-shrink: 0;
  margin-top: 1px;
  width: 13px;
  height: 13px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.rep-pd-icon-yes { color: var(--success-fg); }
.rep-pd-icon-no  { color: var(--danger-fg); }
.rep-pd-icon-na  { color: var(--text-tertiary); }
.rep-pd-txt { flex: 1; }
.rep-pd-txt-lbl {
  font-size: 11px;
  color: var(--text-secondary);
}
.rep-pd-txt-com {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 2px;
  line-height: 1.4;
}

/* Сворачиваемый диалог */
.rep-dialog {
  margin-top: 16px;
  border-top: 0.5px solid var(--border);
}
.rep-dialog-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 0;
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-tertiary);
  user-select: none;
}
.rep-dialog-toggle:hover {
  color: var(--text-secondary);
}
.rep-dialog-toggle svg {
  color: var(--text-tertiary);
  transition: transform 0.15s;
}
.rep-dialog-body {
  margin-top: 8px;
}

/* ── Активный диалог ─────────────────────────────────────────────────────── */

/* Шапка диалога (структура повторяет шапку отчёта) */
.dlg-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 0.5px solid var(--border);
}
.dlg-ava {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 500;
  flex-shrink: 0;
}
.dlg-id { flex: 1; min-width: 0; }
.dlg-name {
  font-size: 15px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.dlg-meta {
  font-size: 11px;
  color: var(--text-tertiary);
}
.dlg-index {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  padding-left: 16px;
  border-left: 0.5px solid var(--border);
}
.dlg-index-val {
  font-size: 16px;
  font-weight: 500;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}
.dlg-index-lbl {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 3px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Задача — connector-плашка */
.dlg-task {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 20px;
  line-height: 1.5;
}
.dlg-task svg {
  flex-shrink: 0;
  color: var(--text-tertiary);
  margin-top: 2px;
}
.dlg-task-type {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--info-fg);
  font-weight: 500;
  margin-bottom: 2px;
}
.dlg-task-desc {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* Sec-title в диалоге (чтобы не пересекался с .rep-sec-title) */
.dlg-sec-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 10px;
}

/* Лента сообщений — переопределяем .messages из styles.css мягче */
.dlg-messages {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 16px;
}

/* Переопределяем старые классы msg-* под новую тему */
.msg-wrap { display: flex; flex-direction: column; }
.msg-wrap.client { align-items: flex-end; }
.msg-wrap.operator { align-items: flex-start; }

.msg-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: var(--text-tertiary);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
}
.msg-time {
  font-size: 10px;
  color: var(--text-muted);
  margin-left: 4px;
  font-variant-numeric: tabular-nums;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}

/* Бейдж типа оператора */
.msg-op-type {
  display: inline-flex;
  align-items: center;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 9px;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}
.msg-op-type-bot {
  background: var(--success-bg);
  color: var(--success-fg);
}
.msg-op-type-human {
  background: var(--info-bg);
  color: var(--info-fg);
}

/* Пузыри */
.msg-bubble {
  max-width: 72%;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.55;
}
.msg-bubble.client {
  background: var(--info-bg);
  color: var(--info-fg);
  border-bottom-right-radius: 4px;
}
.msg-bubble.operator {
  background: var(--bg-subtle);
  color: var(--text-primary);
  border-bottom-left-radius: 4px;
}
/* Автосообщение виджета (бот-шаблон «Менеджер ответит» и т.п.) —
   приглушённый стиль чтобы визуально отличать от реальных ответов. */
.msg-bubble.operator-auto {
  background: var(--bg-subtle);
  color: var(--text-secondary);
  opacity: 0.78;
  border-left: 2px solid var(--warning-border);
}
/* Сообщение бота при открытии чата ДО реплики клиента —
   немного другой акцент, инициатива бизнеса. */
.msg-bubble.operator-pre {
  background: var(--bg-subtle);
  color: var(--text-primary);
  border-left: 2px solid var(--info-border, var(--border));
}
/* Маркер «· автосообщение» / «· до сообщения клиента» в подписи. */
.msg-op-marker {
  font-size: 11px;
  color: var(--text-tertiary);
  font-weight: 400;
}

/* Системное сообщение — тонкая центрированная плашка между репликами:
   «Принято согласие 152-ФЗ», «Форма ПД заполнена» и т.п. */
.msg-system {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: 10px auto;
  padding: 6px 12px;
  max-width: 80%;
  background: var(--bg-subtle);
  border: 0.5px dashed var(--border);
  border-radius: 8px;
  font-size: 11px;
  color: var(--text-secondary);
}
.msg-system svg {
  flex-shrink: 0;
  color: var(--success-fg);
}
.msg-system .msg-time {
  color: var(--text-tertiary);
  margin-left: 4px;
}

/* Ожидание ответа оператора */
.dlg-wait {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-subtle);
  border: 0.5px solid var(--border);
  border-radius: 12px;
  border-bottom-left-radius: 4px;
  max-width: 72%;
  color: var(--text-tertiary);
  font-size: 12px;
  align-self: flex-start;
}
.dlg-wait-dots {
  display: inline-flex;
  gap: 3px;
}
.dlg-wait-dots span {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--text-tertiary);
  animation: dlg-dot-pulse 1.4s infinite ease-in-out;
}
.dlg-wait-dots span:nth-child(2) { animation-delay: 0.2s; }
.dlg-wait-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes dlg-dot-pulse {
  0%, 80%, 100% { opacity: 0.3; }
  40% { opacity: 1; }
}
.dlg-wait-timer {
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}

/* Таймаут оператора */
.dlg-timeout {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  color: var(--danger-fg);
  font-size: 12px;
}

/* Подготовительные шаги */
.prep-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.prep-step {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  font-size: 13px;
}
.prep-step.running { color: var(--text-primary); }
.prep-step.done    { color: var(--text-secondary); }
.prep-step.error   { color: var(--danger-fg); }

/* Маленький спиннер для running-шагов */
.prep-step-icon {
  width: 11px;
  height: 11px;
  display: inline-flex;
  flex-shrink: 0;
}
.prep-step-running-icon {
  border: 1.2px solid var(--border-strong);
  border-top-color: var(--text-secondary);
  border-radius: 50%;
  animation: prep-spin 0.8s linear infinite;
}
@keyframes prep-spin { to { transform: rotate(360deg); } }

/* ── Чипы альтернативных каналов связи (рядом с «Чат открыт») ──────────── */
/* Показываются inline после статуса prep-step, разделителем — небольшой
   отступ. Каждый чип — компактная плашка с названием мессенджера. */
.msg-chips {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-left: 8px;
  vertical-align: middle;
}
.msg-chip {
  display: inline-flex;
  align-items: center;
  height: 18px;
  padding: 0 7px;
  border-radius: 9px;
  font-size: 11px;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.1px;
  color: var(--chip-color, var(--text-secondary));
  background: rgba(136, 136, 136, 0.12);
  border: 1px solid rgba(136, 136, 136, 0.28);
  text-decoration: none;
  transition: background 120ms ease, border-color 120ms ease;
  white-space: nowrap;
}
a.msg-chip:hover {
  background: rgba(136, 136, 136, 0.22);
  border-color: rgba(136, 136, 136, 0.5);
}

/* Форма контактов — блок "отправлена" */
.form-done {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-primary);
  flex-wrap: wrap;
}
.form-done.form-failed {
  color: var(--danger-fg);
}
.form-pd-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-tertiary);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: var(--bg-subtle);
  margin-left: auto;
}
.form-pd-badge.ok {
  color: var(--success-fg);
  background: var(--success-bg);
}

/* Отправленные контакты */
.form-contacts {
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  font-size: 12px;
}
.form-contacts-name {
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.form-contacts-row {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
}

/* ── Сводный отчёт ──────────────────────────────────────────────────────── */
.sum {
  font-size: 13px;
}

.sum-head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 0.5px solid var(--border);
}
.sum-title { flex: 1; min-width: 0; }
.sum-title-big {
  font-size: 15px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.sum-title-sub {
  font-size: 11px;
  color: var(--text-tertiary);
  line-height: 1.5;
}
.sum-title-cost {
  font-size: 11px;
  color: var(--text-tertiary);
  line-height: 1.5;
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
.sum-score-big {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  padding-left: 16px;
  border-left: 0.5px solid var(--border);
  flex-shrink: 0;
}
.sum-score-big-val {
  font-size: 28px;
  font-weight: 500;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.sum-score-big-lbl {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Разбивка лидов под главной плашкой сводного отчёта — три чипа */
.sum-lead-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.sum-lead-chip {
  font-size: 11px;
  padding: 3px 10px;
  border-radius: 4px;
  background: var(--bg-panel);
  font-variant-numeric: tabular-nums;
}
.sum-lead-won  { color: var(--success-fg); }
.sum-lead-risk { color: var(--warning-fg); }
.sum-lead-lost { color: var(--danger-fg); }

.sum-sec {
  margin-bottom: 22px;
}
.sum-sec:last-child {
  margin-bottom: 0;
}
.sum-sec-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 10px;
}

/* Топ-метрики */
.sum-top-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
}
.sum-top-stat {
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.sum-top-stat-val {
  font-size: 20px;
  font-weight: 500;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.15;
}
.sum-top-stat-good { color: var(--success-fg); }
.sum-top-stat-med  { color: var(--warning-fg); }
.sum-top-stat-low  { color: var(--danger-fg); }
.sum-top-stat-lbl {
  font-size: 10px;
  color: var(--text-tertiary);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Две колонки сильные/слабые */
.sum-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.sum-side-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.sum-side-good .sum-side-title { color: var(--success-fg); }
.sum-side-bad .sum-side-title  { color: var(--danger-fg); }
.sum-side-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sum-side-item {
  font-size: 12px;
  line-height: 1.5;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
}
.sum-side-good .sum-side-item {
  background: var(--success-bg);
  color: var(--success-fg);
}
.sum-side-bad .sum-side-item {
  background: var(--danger-bg);
  color: var(--danger-fg);
}

/* Рекомендации */
/* Итоговое заключение */
.sum-verdict {
  padding: 14px 16px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-primary);
}

/* Список диалогов в сводном отчёте — кликабельные ссылки на детали */
.sum-dlgs {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sum-dlg-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.1s;
}
.sum-dlg-item:hover {
  background: var(--bg-hover);
}
.sum-dlg-ava {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 500;
  flex-shrink: 0;
}
.sum-dlg-name {
  flex: 1;
  min-width: 0;
  font-size: 13px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sum-dlg-score {
  font-size: 14px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.sum-dlg-item svg {
  color: var(--text-muted);
  flex-shrink: 0;
}

/* Loading-строка для "Генерируем сводный отчёт..." */
.loading-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-secondary);
}

/* Hint о просроченных слотах */
.overdue-hint {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--danger-bg);
  border: 0.5px solid var(--danger-border);
  border-radius: var(--radius-sm);
  font-size: 12px;
  color: var(--danger-fg);
}
.overdue-hint-btn {
  margin-left: auto;
  font-size: 11px !important;
  padding: 4px 10px !important;
}

/* ── Модалка методологии ─────────────────────────────────────────────────── */
.mth {
  font-size: 13px;
  color: var(--text-primary);
}

.mth-sec-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin-bottom: 12px;
}

.mth-intro {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin-bottom: 24px;
  padding: 12px 14px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
}

/* Карточка критерия */
.mth-crit {
  margin-bottom: 22px;
  padding-bottom: 22px;
  border-bottom: 0.5px solid var(--border);
}
.mth-crit:last-of-type {
  border-bottom: 0;
  margin-bottom: 16px;
  padding-bottom: 16px;
}
.mth-crit-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.mth-crit-desc {
  font-size: 12px;
  color: var(--text-tertiary);
  line-height: 1.55;
  margin-bottom: 12px;
}

/* Шкала оценок критерия */
.mth-scale {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 10px;
}
.mth-scale-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 12px;
  padding: 6px 0;
  line-height: 1.5;
}
.mth-scale-range {
  flex-shrink: 0;
  width: 38px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.mth-scale-good    { color: var(--success-fg); }
.mth-scale-med     { color: var(--warning-fg); }
.mth-scale-med-low { color: var(--warning-fg); opacity: 0.75; }
.mth-scale-low     { color: var(--danger-fg); }
.mth-scale-time {
  flex-shrink: 0;
  width: 72px;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}
.mth-scale-note {
  flex: 1;
  color: var(--text-tertiary);
}

/* Источники */
.mth-sources {
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1.5;
}

/* Блок "Возможные потери лидов" */
.mth-loss {
  margin-top: 8px;
  padding: 20px 22px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
}
.mth-loss-head {
  margin-bottom: 20px;
}
.mth-loss-head-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  margin-bottom: 6px;
}
.mth-loss-head-desc {
  font-size: 12px;
  color: var(--text-tertiary);
  line-height: 1.6;
}
.mth-loss-formula-title {
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-tertiary);
  margin: 16px 0 8px;
}
.mth-loss-formula-title:first-of-type {
  margin-top: 0;
}
.mth-loss-formula {
  font-size: 12px;
  font-family: ui-monospace, 'SF Mono', Monaco, monospace;
  color: var(--text-secondary);
  padding: 10px 12px;
  background: var(--bg-panel);
  border-radius: var(--radius-sm);
  margin-bottom: 6px;
}
.mth-loss-desc {
  font-size: 12px;
  color: var(--text-tertiary);
  line-height: 1.6;
  margin-bottom: 14px;
}

/* Таблица весов */
.mth-loss-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
  margin-bottom: 8px;
  font-variant-numeric: tabular-nums;
}
.mth-loss-table th,
.mth-loss-table td {
  padding: 7px 8px;
  border-bottom: 0.5px solid var(--border);
}
.mth-loss-table th {
  font-weight: 500;
  color: var(--text-tertiary);
  text-align: center;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.mth-loss-th-left {
  text-align: left !important;
}
.mth-th-good     { color: var(--success-fg) !important; }
.mth-th-med      { color: var(--warning-fg) !important; }
.mth-th-med-low  { color: var(--warning-fg) !important; opacity: 0.75; }
.mth-th-low      { color: var(--danger-fg) !important; }
.mth-th-crit     { color: var(--danger-fg) !important; }
.mth-loss-label {
  color: var(--text-primary);
  font-weight: 500;
}
.mth-loss-weight {
  text-align: center;
  color: var(--info-fg);
  font-weight: 500;
}
.mth-loss-cell {
  text-align: center;
  color: var(--text-secondary);
}
.mth-loss-none  { color: var(--text-muted); }
.mth-loss-low   { color: var(--text-secondary); }
.mth-loss-med   { color: var(--warning-fg); opacity: 0.75; }
.mth-loss-high  { color: var(--warning-fg); }
.mth-loss-crit  { color: var(--danger-fg); }
.mth-loss-table tr:last-child td {
  border-bottom: 0;
}

/* ── Модальное окно ──────────────────────────────────────────────────────── */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 1000;
  overflow-y: auto;
  padding: 40px 20px;
}
.modal-content {
  max-width: 720px;
  margin: 0 auto;
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
}
.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
}
.modal-title { font-size: 18px; font-weight: 500; color: var(--text-primary); }
.modal-subtitle { font-size: 12px; color: var(--text-tertiary); margin-top: 4px; }
.modal-close {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--bg-subtle);
  border: 0.5px solid var(--border);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  transition: background 0.12s, color 0.12s;
}
.modal-close:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

/* ── Двухступенчатая кнопка «Анализировать» ──────────────────────────────── */
/* Когда есть активное расписание, первый клик переводит кнопку в armed,
   показывается analyze-confirm-row. Второй клик запускает анализ. */
.btn-armed {
  background: var(--warning-bg) !important;
  border-color: var(--warning-border) !important;
  color: var(--warning-fg) !important;
}
.btn-armed:hover:not(:disabled) {
  background: var(--warning-border) !important;
}

/* Кнопка «Остановить групповой аудит» — пока групповой идёт, btn-group
   меняет вид на красноватую с иконкой stop. */
.btn-stop {
  background: var(--danger-bg) !important;
  border-color: var(--danger-border) !important;
  color: var(--danger-fg) !important;
}
.btn-stop:hover:not(:disabled) {
  background: var(--danger-border) !important;
}

.analyze-confirm-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 20px;
  margin: 0;
  background: var(--warning-bg);
  border: 0.5px solid var(--warning-border);
  border-radius: var(--radius-md);
  font-size: 12px;
  color: var(--warning-fg);
  animation: analyze-confirm-in 0.15s ease-out;
}
.analyze-confirm-icon {
  display: inline-flex;
  flex-shrink: 0;
  color: var(--warning-fg);
}
.analyze-confirm-text {
  flex: 1;
  line-height: 1.5;
}
.analyze-confirm-link {
  color: var(--warning-fg);
  font-family: var(--font-mono, monospace);
  font-size: 11px;
  text-decoration: underline;
}
.analyze-confirm-link:hover {
  opacity: 0.85;
}
.analyze-confirm-copy,
.analyze-confirm-cancel {
  background: transparent;
  border: 0.5px solid var(--warning-border);
  color: var(--warning-fg);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.1s;
}
.analyze-confirm-copy:hover,
.analyze-confirm-cancel:hover {
  background: rgba(255, 255, 255, 0.05);
}
@keyframes analyze-confirm-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Глобальный статусбар ────────────────────────────────────────────────
   Полоса под шапкой, показывает состояние идущего аудита (тестового или
   группового), накопительную стоимость API и таймер до ближайшего слота.
   Управляется через 14-statusbar.js. По умолчанию display:none — JS
   переключает на flex когда есть что показать.

   Состояния (классы):
     statusbar-running  — идёт аудит / расписание активно (зелёный)
     statusbar-active   — слот группового отыгрывается прямо сейчас (жёлтый)
     statusbar-stopped  — пользователь нажал Стоп, висит 3 сек (серый)
     statusbar-done     — все слоты отыграны (голубой)
*/
.statusbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 20px;
  font-size: 12px;
  line-height: 1.4;
  border-bottom: 0.5px solid var(--border);
  flex-shrink: 0;
}
.statusbar-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}
.statusbar-text { flex: 1; min-width: 0; }
.statusbar-text strong { font-weight: 500; }
.statusbar-muted { color: var(--text-tertiary); }
.statusbar-timer {
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.statusbar-cost {
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
  margin-left: 4px;
}

/* Состояния — фон и цвет текста через переменные темы */
.statusbar-running {
  background: var(--success-bg);
  color: var(--success-fg);
  border-bottom-color: var(--success-border);
}
.statusbar-active {
  background: var(--warning-bg);
  color: var(--warning-fg);
  border-bottom-color: var(--warning-border);
}
.statusbar-stopped {
  background: var(--bg-panel);
  color: var(--text-secondary);
}
.statusbar-done {
  background: var(--info-bg);
  color: var(--info-fg);
  border-bottom-color: var(--info-border);
}

/* Пульсирующая точка для running/active состояний — визуальный сигнал
   «что-то крутится прямо сейчас». */
.statusbar-pulse {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  animation: statusbar-pulse 1.4s ease-in-out infinite;
}
@keyframes statusbar-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(0.85); }
}
