/* ================================================================
   COMPONENTS — cards, forms, badges, tables, chat, timeline, etc.
   Colours are driven by design tokens (see css/theme.css).
   ================================================================ */

/* ── FILTERS ─────────────────────────────────────────────────── */
.fbar{display:flex;align-items:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.fico{position:relative;width:34px;height:34px;border-radius:8px;border:1.5px solid var(--c-border-2);display:flex;align-items:center;justify-content:center;background:transparent;flex-shrink:0;cursor:pointer;transition:border-color .18s,background .18s;color:var(--c-ink)}
.fico:hover{border-color:var(--c-brand);background:rgba(77,179,77,.07)}
.fico.has-active{border-color:var(--c-brand);background:rgba(77,179,77,.1)}
.fico.has-active::after{content:'';position:absolute;top:4px;right:4px;width:7px;height:7px;border-radius:50%;background:var(--c-brand);border:1.5px solid var(--c-bg)}
.fsel{appearance:none;background:var(--c-field);border:1.5px solid var(--c-border);border-radius:8px;padding:6px 28px 6px 10px;font-size:13px;color:var(--c-ink);cursor:pointer;min-width:120px;font-family:'Open Sans',sans-serif}
.fsel:focus{outline:none;border-color:var(--c-brand)}
.fmore-btn{display:inline-flex;align-items:center;gap:5px;border:1.5px solid var(--c-border);border-radius:8px;background:var(--c-field);font-family:'Open Sans',sans-serif;font-size:13px;font-weight:500;color:var(--c-text-2);padding:5px 12px;cursor:pointer;white-space:nowrap;transition:border-color .18s,color .18s,background .18s;height:34px;box-sizing:border-box}
.fmore-btn:hover:not(:disabled){border-color:var(--c-brand);color:var(--c-brand)}
.fmore-btn.active{background:rgba(77,179,77,.1);border-color:var(--c-brand);color:var(--c-brand);font-weight:600}
.fmore-btn:disabled{opacity:.35;cursor:not-allowed}
.fmore-btn .fmore-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--c-brand);color:#fff;font-size:10px;font-weight:700;border-radius:9px;min-width:16px;height:16px;padding:0 4px;line-height:1}

/* ── Searchable ССП filter (combobox с поиском) ──────────────────
   Триггер повторяет стиль .fsel; выпадающая панель — поиск + полный
   список ССП (DATA_ORG.ssps), фильтрация локально по DOM. Тема-зависим
   (CSS-переменные), поэтому корректно работает в светлой и тёмной теме. */
.ssp-filter{position:relative;display:inline-flex}
.ssp-trigger{display:inline-flex;align-items:center;min-width:170px;max-width:240px;text-align:left;position:relative}
.ssp-trigger::after{content:'▾';position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--c-text-2);pointer-events:none}
.ssp-trigger-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}
.ssp-drop{display:none;position:absolute;top:calc(100% + 4px);left:0;z-index:200;width:280px;max-width:82vw;background:var(--c-white);border:1.5px solid var(--c-border);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.18);padding:8px;box-sizing:border-box}
.ssp-drop.open{display:block}
.ssp-search{width:100%;box-sizing:border-box;padding:7px 10px;border:1.5px solid var(--c-border);border-radius:8px;font-size:13px;font-family:'Open Sans',sans-serif;color:var(--c-ink);background:var(--c-field);outline:none;margin-bottom:6px}
.ssp-search:focus{border-color:var(--c-brand)}
.ssp-list{max-height:260px;overflow-y:auto;overscroll-behavior:contain}
.ssp-opt{padding:7px 10px;font-size:13px;color:var(--c-ink);border-radius:7px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .12s}
.ssp-opt:hover{background:var(--c-surface)}
.ssp-opt.sel{background:rgba(77,179,77,.14);font-weight:600}
.ssp-empty{display:none;padding:10px 8px;font-size:12px;color:var(--c-text-2);text-align:center}

/* ── CARDS ───────────────────────────────────────────────────── */
.card{background:var(--c-surface);border-radius:16px;padding:20px}
.card-dark{background:var(--c-dark);border-radius:16px;padding:20px;color:#fff}
.card-mid{background:var(--c-surface);border-radius:16px;padding:20px}
.card-white{background:var(--c-white);border-radius:16px;padding:20px}

/* ── KANBAN «Стадия» (Все заявки) ────────────────────────────────
   9 колонок-стадий + «Отказано»: горизонтальная прокрутка через
   зеркальный скролл СВЕРХУ доски (mirror-scroll technique).
   Нативный скролл нижнего контейнера скрыт, JS синхронизирует
   scrollLeft обоих div-ов в обе стороны. */
.kb-board{display:flex;gap:12px;min-width:max-content;padding-bottom:10px}

/* Верхний зеркальный скролл — толщина 14px (~2× от дефолтных 8px) */
.kb-scroll-top{overflow-x:scroll;overflow-y:hidden;height:14px;margin-bottom:8px}
.kb-scroll-top::-webkit-scrollbar{height:14px}
.kb-scroll-top::-webkit-scrollbar-track{background:var(--c-mid);border-radius:7px}
.kb-scroll-top::-webkit-scrollbar-thumb{background:#627068;border-radius:7px;border:2px solid var(--c-mid)}
#kb-scroll-spacer{height:1px;display:block}

/* Нижний рабочий контейнер — scroll работает, полоса скрыта */
.kb-scroll-body{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:4px}
.kb-scroll-body::-webkit-scrollbar{display:none}
.kb-scroll-body{scrollbar-width:none;-ms-overflow-style:none}
.kb-col{flex:0 0 260px;width:260px;display:flex;flex-direction:column;background:var(--c-surface);border-radius:12px;max-height:calc(100vh - 300px);min-height:240px}
.kb-col-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px 9px;border-radius:12px 12px 0 0}
.kb-col-title{font-size:12.5px;font-weight:700;color:var(--c-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kb-col-cnt{flex-shrink:0;font-size:11px;font-weight:700;color:var(--c-text-2);background:rgba(var(--ovl),.08);border-radius:50px;min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}
.kb-col-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 8px 8px;display:flex;flex-direction:column;gap:7px;min-height:60px;overscroll-behavior:contain}
.kb-col-foot{flex-shrink:0;padding:9px 12px;border-top:1.5px solid var(--c-border);background:var(--c-white);border-radius:0 0 12px 12px}
.kb-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:10px;padding:9px 11px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}
.kb-card:hover{border-color:var(--c-ink);box-shadow:0 4px 14px rgba(35,43,47,.10);transform:translateY(-1px)}
.kb-card-top{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:5px}
.kb-card-id{font-size:10.5px;font-weight:600;color:var(--c-text-3)}
.kb-card-client{font-size:13px;font-weight:600;color:var(--c-ink);line-height:1.25;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.kb-card-amt{font-size:13px;font-weight:700;color:#4DB34D;margin-bottom:4px}
.kb-card-meta{font-size:10.5px;color:var(--c-text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kb-empty{font-size:11px;color:var(--c-text-3);text-align:center;padding:18px 6px}
@media(max-width:639px){.kb-col{flex-basis:220px;width:220px}}

/* ── METRICS ─────────────────────────────────────────────────── */
.mval{font-size:30px;font-weight:700;line-height:1.15}
.mval-lg{font-size:42px;font-weight:700;line-height:1.1}
.mlbl{font-size:12px;color:var(--c-text-2);margin-top:3px}
.mlbl-d{font-size:12px;color:var(--c-text-3);margin-top:3px}
.dpos{color:var(--c-brand);font-size:12px;font-weight:600}
.dneg{color:#e05050;font-size:12px;font-weight:600}

/* ── PROGRESS ────────────────────────────────────────────────── */
.pbar{height:5px;border-radius:3px;background:var(--c-track);overflow:hidden;margin-top:6px}
.pfill{height:100%;border-radius:3px}

/* ── NAVIGATION CARD (hover lift, no layout shift) ───────────── */
.nav-card{cursor:pointer;transition:transform .22s ease,box-shadow .22s ease}
.nav-card:hover{transform:scale(1.015);box-shadow:0 10px 30px rgba(35,43,47,.13)}
.card-dark.nav-card:hover{box-shadow:0 10px 30px rgba(0,0,0,.35)}
/* «Сделки на стадиях» (Пайплайн): более деликатный hover-зум на широкой
   карте — едва заметное увеличение вместо стандартного scale(1.015). */
.nav-card.nav-card-soft:hover{transform:scale(1.008)}
/* «Открыть доску» (текст + стрелка → один color, стрелка наследует):
   фирменный зелёный во всех темах; при hover карточки — чуть темнее. */
.stage-open-link{color:#4DB34D;font-size:11px}
.nav-card:hover .stage-open-link{color:#43a047}
html[data-theme="dark"] .stage-open-link{color:#4DB34D}
/* Строка стадии в виджете «Pipeline» (главная) — самостоятельный
   интерактивный элемент: лёгкий hover-зум (≈2%) + усиление фона и тень,
   курсор-pointer. Ненавязчиво, в духе .nav-card дизайн-системы. */
.pl-stage{background:rgba(var(--ovl),.08);border-radius:10px;padding:9px 12px;margin-bottom:6px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}
.pl-stage:last-child{margin-bottom:0}
.pl-stage:hover{transform:scale(1.02);background:rgba(var(--ovl),.14);box-shadow:0 4px 14px rgba(35,43,47,.10)}
/* Pipeline-контейнер (главная) — статичен; внутренние .pl-stage анимируются независимо */
.pipeline-card.nav-card:hover,.pipeline-card.nav-card.nav-card-soft:hover{transform:none;box-shadow:none}
.pipeline-card.nav-card:hover .stage-open-link{color:#4DB34D}
/* «Открыть доску» (только Pipeline на главной) — hover-анимация всей ссылки + сдвиг стрелки */
.pipeline-card .stage-open-link{cursor:pointer;transition:transform 200ms ease-out;transform-origin:right center}
.pipeline-card .stage-open-link:hover{transform:scale(1.05)}
.pipeline-card .stage-open-link span{transition:transform 200ms ease-out}
.pipeline-card .stage-open-link:hover span{transform:translateX(3px)}

/* ── DATA ROW ────────────────────────────────────────────────── */
.drow{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--c-border);gap:8px}
.drow:last-child{border-bottom:none}

/* ── MATRIX ──────────────────────────────────────────────────── */
/* grid: label(1fr) | divider(1px fixed) | value(auto) — divider is always same size */
.mrow{display:grid;grid-template-columns:1fr auto auto;align-items:center;column-gap:10px;padding:11px 16px;border-radius:10px;cursor:pointer;transition:all .18s;margin-bottom:6px;border:1.5px solid var(--c-border-soft)}
.mrow:hover{background:var(--c-hover-soft);border-color:var(--c-border-hover);box-shadow:0 2px 8px rgba(35,43,47,.07)}
.mrow.sel{background:var(--c-dark);color:#fff;border-color:var(--c-dark);box-shadow:0 3px 12px rgba(35,43,47,.18)}
.mdiv{width:1px;height:18px;background:var(--c-track);align-self:center}
.mrow.sel .mdiv{background:rgba(255,255,255,.25)}
.reward-val{font-size:50px;font-weight:700;color:var(--c-ink);line-height:1}
/* ── MATRIX rows inside dark card (Факторы риска) ─────────── */
.card-dark .mrow{color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.14)}
.card-dark .mrow:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.28)}
/* «Факторы риска» — active state = корпоративный PSB orange (token --c-cta).
   Оттенок ПРОИЗВОДИТСЯ из единого CTA-токена через color-mix (без нового hex
   и локальных override): тинт-заливка + сплошное оранжевое кольцо. Единый
   язык выделения карточки сохранён, сменён только accent-hue (зелёный→оранж). */
.card-dark .mrow.sel{background:color-mix(in srgb,var(--c-cta) 18%,transparent);color:#fff;border-color:var(--c-cta)}
.card-dark .mrow.sel .mdiv{background:color-mix(in srgb,var(--c-cta) 55%,transparent)}
.card-dark .mdiv{background:rgba(255,255,255,.2)}

/* ── INPUTS & BUTTONS ────────────────────────────────────────── */
.inp{width:100%;padding:13px 16px;border:1.5px solid var(--c-border);border-radius:10px;background:var(--c-field);font-size:14px;outline:none;transition:border-color .15s;font-family:'Open Sans',sans-serif;color:var(--c-ink)}
.inp:focus{border-color:var(--c-brand)}
.btn-p{width:100%;padding:13px;border-radius:10px;border:none;background:var(--c-dark);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;font-family:'Open Sans',sans-serif}
.btn-p:hover{background:var(--c-dark-2)}
.btn-s{width:100%;padding:13px;border-radius:10px;border:none;background:var(--c-surface);color:var(--c-ink);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;font-family:'Open Sans',sans-serif}
.btn-s:hover{background:var(--c-btn-s-hover)}
/* ── Primary CTA — единый оранжевый action «Направить заявку» ──────
   Главный CTA системы (token: --c-cta / cta.primary.orange). Геометрия
   совпадает с .btn-p (взаимозаменяемы по размеру), отличается только
   фирменным оранжевым и его состояниями. Применяется во ВСЕХ темах
   одинаково (light/dark/psb). Запрещены локальные override цвета. */
.btn-cta{width:100%;padding:13px;border-radius:10px;border:none;background:var(--c-cta);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .05s;font-family:'Open Sans',sans-serif}
.btn-cta:hover{background:var(--c-cta-hover)}
.btn-cta:active{background:var(--c-cta-active);transform:translateY(1px)}
.btn-cta:disabled,.btn-cta[disabled]{background:var(--c-cta-disabled);opacity:.6;cursor:not-allowed;transform:none}
.btn-sm{padding:8px 14px;border-radius:8px;border:1.5px solid var(--c-border);background:transparent;font-size:13px;cursor:pointer;font-family:'Open Sans',sans-serif;color:var(--c-ink);transition:all .15s;white-space:nowrap}
.btn-sm:hover{background:var(--c-surface)}
.btn-accent{background:var(--c-brand);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Open Sans',sans-serif;transition:background .15s}
.btn-accent:hover{background:var(--c-brand-d)}

/* ── TABS ────────────────────────────────────────────────────── */
.tbg{display:flex;gap:4px;border-bottom:1px solid var(--c-border);margin-bottom:20px}
.tbtn{padding:8px 16px;font-size:13px;border:none;background:transparent;cursor:pointer;color:var(--c-text-2);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:'Open Sans',sans-serif;font-weight:500}
.tbtn:hover{color:var(--c-ink)}
.tbtn.active{color:var(--c-ink);border-bottom-color:var(--c-ink)}
/* Disabled-вкладка (placeholder, напр. SLA): видима, но неактивна.
   cursor:not-allowed виден (pointer-events НЕ отключаем), hover нейтрализован,
   клик блокируется нативным [disabled] + отсутствием onclick. */
.tbtn:disabled,.tbtn-disabled{opacity:.4;cursor:not-allowed;color:var(--c-text-2)}
.tbtn:disabled:hover,.tbtn-disabled:hover{color:var(--c-text-2);border-bottom-color:transparent}
.pill-g{display:flex;background:var(--c-surface);border-radius:8px;padding:3px;gap:2px}
.pill{padding:5px 12px;border-radius:6px;font-size:12px;cursor:pointer;border:none;background:transparent;color:var(--c-text-pill);font-family:'Open Sans',sans-serif;transition:all .15s}
.pill.active{background:var(--c-dark);color:#fff}

/* ── SCROLLABLE TABS ─────────────────────────────────────────── */
.stabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.stabs::-webkit-scrollbar{display:none}
.stab{padding:7px 14px;border-radius:8px;font-size:12.5px;cursor:pointer;border:1.5px solid var(--c-border);background:transparent;color:var(--c-text-pill);font-family:'Open Sans',sans-serif;white-space:nowrap;transition:all .15s}
.stab.active{background:var(--c-dark);border-color:var(--c-dark);color:#fff}

/* ── FORM ────────────────────────────────────────────────────── */
.flbl{font-size:12px;font-weight:600;color:var(--c-text-2);margin-bottom:5px;display:block}
.fsel2{width:100%;padding:12px 14px;border:1.5px solid var(--c-border);border-radius:10px;background:var(--c-field);font-size:14px;outline:none;cursor:pointer;appearance:none;font-family:'Open Sans',sans-serif;color:var(--c-ink)}
.fsel2:focus{border-color:var(--c-brand)}
.step-ind{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.sdot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}
.sdot.done{background:var(--c-brand);color:#fff}
.sdot.cur{background:var(--c-dark);color:#fff}
.sdot.pend{background:var(--c-surface);color:var(--c-text-2)}
.sline{flex:1;height:2px;background:var(--c-border)}
.sline.done{background:var(--c-brand)}

/* ── STATUS BADGES ───────────────────────────────────────────── */
/* Pastel status chips keep fixed light fills + dark text in BOTH themes —
   colourful chips remain legible on a dark surface. Neutral chips are
   token-driven so they invert with the theme. */
.badge{display:inline-block;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-new{background:var(--c-bg);color:var(--c-ink);border:1px solid var(--c-border)}
.badge-work{background:#dbeafe;color:#1d4ed8}
.badge-offer{background:#fef9c3;color:#854d0e}
.badge-accept{background:#dcfce7;color:#166534}
.badge-review{background:#f3e8ff;color:#6b21a8}
.badge-approved{background:#d1fae5;color:#14532d}
.badge-signed{background:#3da860;color:#fff}
.badge-reject{background:#fee2e2;color:#991b1b}
.badge-deal{background:var(--c-brand);color:#fff}
.badge-closed{background:var(--c-surface);color:var(--c-text-2)}

/* ── SLA INDICATORS ──────────────────────────────────────────── */
.sla-ok{color:var(--c-brand);font-size:12px;font-weight:600}
.sla-warn{color:#f0b040;font-size:12px;font-weight:600}
.sla-over{color:#e05050;font-size:12px;font-weight:600}

/* ── PRIZES ──────────────────────────────────────────────────── */
.prize-lg{border-radius:16px;overflow:hidden;padding:28px;background:var(--c-dark);color:#fff;position:relative;min-height:180px}
.prize-sm{border-radius:16px;overflow:hidden;padding:24px;background:var(--c-surface);position:relative;min-height:140px}

/* ── TABLE ───────────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;color:var(--c-text-2);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--c-border)}
.tbl td{padding:11px 12px;font-size:13px;border-bottom:1px solid var(--c-surface-2);color:var(--c-ink)}
.tbl tr.clickable:hover td{background:var(--c-row-hover);cursor:pointer}
.tbl tr:last-child td{border-bottom:none}

/* Compact table variant — reduced row height (admin → Пользователи) */
.tbl-compact td{padding:6px 12px}

/* Dark-theme rating table — Партнёры → «Рейтинг партнёров» (зеркало MSBL
   «Рейтинг менеджеров» в тёмной теме). Оверрайды .tbl, scoped под .prt-rating
   внутри card-dark; светлые .tbl в остальных разделах не затрагиваются. */
.prt-rating .tbl th{color:#8a9888;border-bottom-color:rgba(255,255,255,.16)}
.prt-rating .tbl td{color:#fff;border-bottom-color:rgba(255,255,255,.07)}
.prt-rating .tbl tr.clickable:hover td{background:rgba(255,255,255,.05)}

/* ════════════════════════════════════════════════════════════════
   CloudMD · Раздел «Партнёры» — ОБЯЗАТЕЛЬНАЯ ТЁМНАЯ ТЕМА (section-wide).
   Эталон поверхности — виджет «Эффективность партнёров» (card-dark).
   Правило: любой ВИДЖЕТ (card) внутри `.partners-dark` всегда тёмный —
   не зависит от вкладки и типа виджета, не переопределяется локально.
   Новые виджеты, использующие `.card`, наследуют тёмную тему
   автоматически. «Хром» страницы (заголовок, период-переключатель
   `.stabs`, таб-бар, фильтр-строка `.fsel`) остаётся на светлом фоне
   страницы — поэтому scoped-оверрайды привязаны к `.card`, а не глобально.
   ════════════════════════════════════════════════════════════════ */
.partners-dark .card{background:var(--c-dark);color:#fff}
/* Таблицы внутри тёмных карточек раздела (Сделки, SLA, и будущие) */
.partners-dark .tbl th{color:#8a9888;border-bottom-color:rgba(255,255,255,.16)}
.partners-dark .tbl td{color:#fff;border-bottom-color:rgba(255,255,255,.07)}
.partners-dark .tbl tr.clickable:hover td{background:rgba(255,255,255,.05)}
/* Сегмент-кнопки разреза (.stab) ВНУТРИ карточек — тёмный вариант.
   Привязка к `.card`, чтобы НЕ затронуть период-переключатель на фоне страницы. */
.partners-dark .card .stab{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.72)}
.partners-dark .card .stab:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.partners-dark .card .stab.active{background:#4DB34D;border-color:#4DB34D;color:#fff}

/* Square icon-action button — uniform size, colour set inline per action */
.ico-act{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:1.5px solid var(--c-border);border-radius:8px;background:transparent;cursor:pointer;transition:all .15s;padding:0}
.ico-act:hover{background:var(--c-hover-accent);border-color:var(--c-border-ico)}
.ico-act svg{width:16px;height:16px;display:block}

/* ── SEARCH INPUT ────────────────────────────────────────────── */
.sinp{padding:8px 14px 8px 38px;border:1.5px solid var(--c-border);border-radius:8px;background:var(--c-field);font-size:13px;outline:none;font-family:'Open Sans',sans-serif;color:var(--c-ink);width:100%;min-width:0;box-sizing:border-box}
.sinp:focus{border-color:var(--c-brand)}
/* Wrapper around .sinp + absolutely-positioned search icon */
.sinp-wrap{position:relative;flex:1 1 320px;min-width:280px}
.sinp-wrap>span{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--c-text-3);pointer-events:none;display:flex}

/* ── CHAT ────────────────────────────────────────────────────── */
.chat-wrap{display:flex;flex-direction:column;gap:10px;max-height:280px;overflow-y:auto;padding:4px 0}
.chat-msg{max-width:72%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5}
.chat-msg.bank{background:var(--c-dark);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-msg.msbl{background:var(--c-surface);color:var(--c-ink);align-self:flex-start;border-bottom-left-radius:4px}
.chat-author{font-size:10px;opacity:.6;margin-bottom:3px;font-weight:600}
.chat-time{font-size:10px;opacity:.5;margin-top:4px;text-align:right}

/* ── DRAG & DROP UPLOAD ──────────────────────────────────────── */
.dropzone{border:2px dashed var(--c-border);border-radius:12px;padding:48px 24px;text-align:center;transition:all .2s;cursor:pointer}
.dropzone:hover,.dropzone.over{border-color:var(--c-brand);background:rgba(77,179,77,.05)}

/* ── TIMELINE ────────────────────────────────────────────────── */
.timeline-wrap{display:flex;align-items:flex-start;overflow-x:auto;padding-bottom:8px;margin-bottom:20px;-webkit-overflow-scrolling:touch}
.tl-item{display:flex;align-items:flex-start;flex:1;min-width:80px}
.tl-dot-wrap{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.tl-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.tl-dot.done{background:var(--c-brand);color:#fff}
.tl-dot.cur{background:var(--c-dark);color:#fff}
.tl-dot.pend{background:var(--c-surface);color:var(--c-text-2)}
.tl-label{font-size:11px;text-align:center;margin-top:5px;line-height:1.3;max-width:72px;color:var(--c-ink)}
.tl-sla{font-size:10px;text-align:center;margin-top:2px}
.tl-line{flex:1;height:2px;background:var(--c-border);margin-top:13px}
.tl-line.done{background:var(--c-brand)}

/* ── MODAL ───────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--c-white);border-radius:16px;padding:28px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto}

/* ── INN CHECK ───────────────────────────────────────────────── */
/* Light pastel fills; dark theme re-skins these to dark-tinted surfaces
   in theme.css so the (now-light) ink text stays legible. */
.inn-result{border-radius:12px;padding:14px 16px;margin-top:12px;display:flex;align-items:flex-start;gap:12px}
.inn-free{background:#dcfce7;border:1px solid #86efac}
.inn-busy{background:#fee2e2;border:1px solid #fca5a5}
/* Скоринг пройден = успех → зелёная тема (синий освобождён под MSBL-маркер) */
.inn-score-ok{background:#e7f5ea;border:1px solid #9bd3a6}
.inn-score-fail{background:#fef9c3;border:1px solid #fde047}

/* ── MAP ─────────────────────────────────────────────────────── */
.map-dot{cursor:pointer;transition:r .15s}
.map-dot:hover{r:9}
.leg-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0}

/* ── CHART CONTAINERS ────────────────────────────────────────── */
.chart-wrap{position:relative;width:100%}
.gauge-wrap{position:relative;display:flex;align-items:center;justify-content:center}

/* ── PRIZE CARDS ─────────────────────────────────────────────── */
.prize-card-img{object-fit:contain;display:block;transition:transform .22s ease}
.prize-card:hover .prize-card-img{transform:scale(1.07)}

/* ── ENGAGEMENT KPI PANELS (inner panels of dark-card) ────────── */
.eng-panel{background:rgba(255,255,255,.07);border:1px solid transparent;border-radius:12px;padding:14px 12px;display:flex;flex-direction:column;transition:background .18s ease,transform .22s ease,box-shadow .22s ease,border-color .18s ease}
.eng-panel:hover{background:rgba(255,255,255,.12);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.28);border-color:rgba(255,255,255,.15)}
@media(hover:none){.eng-panel:hover{background:rgba(255,255,255,.07);transform:none;box-shadow:none;border-color:transparent}}

/* ── THEME SWITCHER (light / dark / psb) ─────────────────────────
   Кнопка-триггер (.tnico) НЕ меняется. Меню — компактный «карман»-
   продолжение кнопки: ширина РАВНА кнопке (34px), фон — светло-серый,
   близкий к фону кнопки (var(--c-hover) = тот же оттенок, что .tnico:hover),
   слегка выделяется, но не контрастен (не белый / не чёрный / не яркий).
   Внутри — три квадратные мини-превью со скруглением (18px ≈ 82% прежних
   22px — «мини-превью темы», НЕ круги, НЕ полноценные кнопки), каждая
   показывает цвета темы тремя полосами.
   Полностью на токенах → корректно во всех трёх темах. */
.theme-tg-wrap{position:relative;display:inline-flex}
.theme-toggle.active{background:var(--c-hover);border-color:var(--c-border-hover)}
.theme-menu-catcher{position:fixed;inset:0;z-index:150;background:transparent}
/* «Карман» под кнопкой: ширина = превью 18 + padding 6×2 + border 1×2 = 32px,
   на 2px УЖЕ кнопки (34px) и центрирован под ней (translateX(-50%)) →
   читается как продолжение кнопки, а не отдельный блок. Высота — ровно под
   три превью, без «воздуха». Радиус близок к кнопке (8px), тень минимальная. */
.theme-menu{position:absolute;top:calc(100% + 5px);left:50%;transform:translateX(-50%);z-index:160;
  background:var(--c-hover);border:1px solid var(--c-border);border-radius:9px;
  box-shadow:0 4px 14px rgba(0,0,0,.14);padding:6px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  animation:themeMenuIn .17s ease;transform-origin:top center}
/* Мини-превью темы — квадрат со скруглением (rounded-rectangle, не круг) */
.theme-opt{position:relative;width:18px;height:18px;flex-shrink:0;padding:0;border:none;
  border-radius:5px;cursor:pointer;background:none;overflow:visible;
  transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}
.theme-opt:hover{transform:scale(1.1);filter:brightness(1.07);box-shadow:0 2px 8px rgba(0,0,0,.22)}
.theme-opt:focus-visible{outline:none;box-shadow:0 0 0 1.5px var(--c-hover),0 0 0 3px var(--c-brand)}
/* Активная тема: тонкая фирменная обводка + мягкое свечение + лёгкий scale.
   Внутренний зазор — цвета контейнера (var(--c-hover)) → сливается с фоном. */
.theme-opt.active{transform:scale(1.05);
  box-shadow:0 0 0 1.5px var(--c-hover),0 0 0 2.5px var(--c-brand),0 0 8px rgba(77,179,77,.5)}
.theme-opt.active:hover{transform:scale(1.09)}
/* Мини-превью заполняет квадрат: три вертикальные цветовые полосы темы */
.theme-opt .theme-sw{display:flex;width:100%;height:100%;border-radius:5px;overflow:hidden;
  border:1px solid var(--c-border-2);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.theme-opt .theme-sw i{flex:1;height:100%}
/* Базовый свотч (используется ТОЛЬКО триггером .tnico при теме ПСБ —
   кнопку не трогаем) */
.theme-sw{display:inline-flex;flex-shrink:0;border-radius:5px;overflow:hidden;
  border:1px solid var(--c-border-2);box-shadow:0 1px 2px rgba(0,0,0,.12)}
.theme-sw i{display:block;width:11px;height:18px}
.theme-toggle .theme-sw{border-radius:4px}
.theme-toggle .theme-sw i{width:6px;height:15px}
