/* Эталон Outreach Dashboard — canon redesign v4
   Шрифты подключены через <link> в index.html: Unbounded + Inter + JetBrains Mono.
   Палитра: paper #F4F2EE + ink #15171A + ember #FF5A1F (один акцент).
   Старые имена (--primary, --bg, --text…) сохранены как compat-mapping
   на канонические токены — существующие правила работают без правки. */

:root {
    /* ====== CANON tokens — Эталон design system ====== */

    /* Core palette */
    --c-paper:      #F4F2EE;     /* warm off-white canvas */
    --c-paper-2:    #ECE9E2;
    --c-snow:       #FFFFFF;
    --c-ink:        #15171A;     /* primary text + dark sections */
    --c-ink-2:      #2A2D33;
    --c-graphite:   #4A4D54;
    --c-smoke:      #6E7178;
    --c-fog:        #A8ABB2;
    --c-mist:       #DCDDE0;     /* hairlines, dividers */

    /* Accent — ember (single accent across the platform) */
    --c-ember:      #FF5A1F;
    --c-ember-soft: #FFE3D3;
    --c-ember-deep: #C53D0F;

    /* Semantic */
    --c-good:       #2ECF6F;
    --c-good-soft:  #D9F5E5;
    --c-warn:       #FF9D2E;
    --c-warn-soft:  #FFF1DC;
    --c-bad:        #FF4B4B;
    --c-bad-soft:   #FFE1E1;

    /* Type families */
    --ff-display: "Unbounded", "Manrope", system-ui, sans-serif;
    --ff-body:    "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --ff-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
    --fw-r: 400; --fw-m: 500; --fw-sb: 600; --fw-b: 700; --fw-eb: 800;

    /* Spacing — 4px grid */
    --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px; --sp-5: 24px;
    --sp-6: 32px; --sp-7: 48px; --sp-8: 64px; --sp-9: 96px; --sp-10: 128px;

    /* Radius */
    --r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-xl: 28px; --r-pill: 999px;

    /* Shadows — ink-tinted, not pure black */
    --sh-sm: 0 1px 2px rgba(21,23,26,0.06), 0 4px 12px rgba(21,23,26,0.04);
    --sh-md: 0 8px 24px rgba(21,23,26,0.08);
    --sh-lg: 0 24px 60px rgba(21,23,26,0.12);

    /* Motion */
    --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --dur-1: 160ms; --dur-2: 240ms; --dur-3: 380ms;

    /* Layout */
    --sidebar-width: 240px;
    --header-height: 60px;

    /* ====== COMPAT MAPPING — старые имена → канонические токены ====== */
    --primary:           var(--c-ember);
    --primary-dark:      var(--c-ember-deep);
    --primary-light:     var(--c-ember-soft);
    --primary-soft:      var(--c-ember-soft);

    --brand-blue:        var(--c-ember);
    --brand-lavender:    var(--c-mist);

    --bg:                var(--c-paper);
    --bg-card:           var(--c-snow);
    --bg-sidebar:        var(--c-ink);            /* CANON: тёмный sidebar */
    --bg-sidebar-hover:  rgba(255, 255, 255, 0.06);
    --bg-sidebar-active: rgba(255, 90, 31, 0.16); /* ember tint */

    --text:              var(--c-ink);
    --text-secondary:    var(--c-smoke);
    --text-muted:        var(--c-fog);
    --text-sidebar:      var(--c-fog);
    --text-sidebar-active: var(--c-ember);

    --border:            var(--c-mist);
    --border-light:      var(--c-mist);
    --border-focus:      var(--c-ember);

    --success:           var(--c-good);
    --success-bg:        var(--c-good-soft);
    --danger:            var(--c-bad);
    --danger-bg:         var(--c-bad-soft);
    --warning:           var(--c-warn);
    --warning-bg:        var(--c-warn-soft);
    --info-bg:           var(--c-ember-soft);
    --purple:            var(--c-graphite);        /* "purple" не в каноне — graphite */
    --purple-bg:         rgba(74, 77, 84, 0.08);

    --radius:            var(--r-md);
    --radius-sm:         var(--r-sm);
    --radius-xs:         var(--r-sm);
    --shadow:            var(--sh-sm);
    --shadow-md:         var(--sh-md);
    --shadow-lg:         var(--sh-lg);

    --transition:        var(--dur-1) var(--ease-out);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
button, input, textarea, select { font-family: inherit; }
html { overflow-x: hidden; background: var(--c-paper); -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scrollbar-gutter: stable; overscroll-behavior-x: none; }
/* Гасим горизонтальный rubber-band (macOS): при сильном свайпе вбок не вылезает
   белое пространство по краям. */
body { overscroll-behavior-x: none; }
/* overscroll-behavior:contain — ТОЛЬКО для реально прокручиваемых внутренних
   областей (модалка с overflow-y:auto, card-body с inline overflow). `.table-wrap`
   тут быть НЕ должен: у него overflow:hidden, и contain делал его scroll-boundary,
   который съедал колесо над таблицей → страница не скроллилась нигде, кроме самой
   полосы прокрутки. Убрано — скролл колесом работает над любой зоной страницы. */
.card-body[style*="overflow"], .dossier-modal .modal-body { overscroll-behavior: contain; }

/* Scroll-lock фона при открытой модалке (см. MutationObserver в app.js).
   overscroll-behavior на html — чтобы докрут внутри модалки не «пробивал» в фон (#2). */
body.modal-open { overflow: hidden; }
.modal-overlay, .modal { overscroll-behavior: contain; }

/* ── #13: iOS-safe scroll-lock ──────────────────────────────────────────────
   body.modal-open{overflow:hidden} не работает на iOS Safari: страница скроллится под
   модалкой. Фикс: position:fixed фиксирует тело, top:-scrollY сохраняет позицию, JS
   восстанавливает её при закрытии (scrollTo в scrollUnlock — см. app.js).

   .main и .content НЕ нужно лочить отдельно: они не overflow:auto/scroll (только
   overflow-x:hidden), скролл страницы — это body/html. Лочить нужно именно body.

   Если в будущем появится внутренний скролл-контейнер (например .content с
   overflow-y:auto) — добавить:
     body.scroll-locked .content { overflow-y: hidden; }
   ─────────────────────────────────────────────────────────────────────────── */
body.scroll-locked {
    position: fixed;
    top: var(--scroll-lock-y, 0);
    left: 0;
    right: 0;
    width: 100%;
    /* overflow-y:scroll держит ширину страницы стабильной — нет прыжка при
       появлении/скрытии скроллбара (актуально для Windows/Linux с полосой). */
    overflow-y: scroll;
}

body {
    font-family: var(--ff-body);
    font-size: 15px;
    line-height: 1.5;
    background: var(--c-paper);
    color: var(--c-ink);
    min-height: 100vh;
    display: flex;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    max-width: 100vw;
    font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--ff-display);
    font-weight: var(--fw-b);
    color: var(--c-ink);
    letter-spacing: -0.02em;
    line-height: 1.15;
    text-wrap: balance;
}

::selection { background: var(--c-ember); color: var(--c-snow); }
:focus-visible { outline: 2px solid var(--c-ink); outline-offset: 2px; border-radius: var(--r-sm); }

/* ============================================
   EYEBROW + PAGE-HERO — универсальный header pattern
   ============================================ */

.eyebrow {
    font-family: var(--ff-mono);
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: 0.04em;
    color: var(--c-smoke);
    text-transform: lowercase;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 14px;
}
.eyebrow::before { content: "/ "; opacity: 0.5; }
.eyebrow--ember { color: var(--c-ember-deep); }

.page-hero {
    margin-bottom: 32px;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--c-mist);
}
.page-hero__title {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: clamp(32px, 4.4vw, 56px);
    line-height: 1.02;
    letter-spacing: -0.03em;
    color: var(--c-ink);
    text-wrap: balance;
    margin: 0;
}
.page-hero__lead {
    font-family: var(--ff-body);
    font-size: 18px;
    line-height: 1.45;
    color: var(--c-graphite);
    margin-top: 16px;
    max-width: 60ch;
}

/* Compat: старые .page-header h1 наследуют display-стиль до миграции в Phase 4 */
.page-header h1 {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    letter-spacing: -0.025em;
}

/* ============================================
   LOGIN — Эталон canon
   ============================================ */

.login-screen {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(520px, 1fr);
    background: var(--c-paper);
    overflow: hidden;
}

/* LEFT — тёмная editorial-сцена */
.login-stage {
    background: var(--c-ink);
    color: var(--c-snow);
    padding: clamp(32px, 4.5vw, 64px) clamp(36px, 5vw, 80px);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 48px;
    position: relative;
    overflow: hidden;
    min-height: 100vh;
}
.login-stage::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 78% 18%, rgba(255, 90, 31, 0.42) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 8% 92%, rgba(255, 90, 31, 0.18) 0%, transparent 55%);
    pointer-events: none;
}
.login-stage::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
    background-size: 64px 64px;
    pointer-events: none;
    -webkit-mask-image: radial-gradient(ellipse 100% 80% at 50% 50%, black 30%, transparent 75%);
    mask-image: radial-gradient(ellipse 100% 80% at 50% 50%, black 30%, transparent 75%);
}
.login-stage > * { position: relative; z-index: 1; }

.login-stage-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.login-stage-top .brand-mark { color: var(--c-snow); font-size: 24px; }
.login-stage-counter {
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    color: var(--c-fog);
}
.login-stage-body { display: flex; flex-direction: column; gap: 24px; max-width: 720px; }
.login-stage-eyebrow {
    font-family: var(--ff-mono);
    font-size: 13px;
    line-height: 1.4;
    letter-spacing: 0.04em;
    color: var(--c-ember);
    text-transform: lowercase;
}
.login-stage-eyebrow::before { content: "/ "; opacity: 0.6; }
.login-stage-title {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: clamp(44px, 6.2vw, 92px);
    line-height: 1.0;
    letter-spacing: -0.035em;
    color: var(--c-snow);
    text-wrap: balance;
    margin: 0;
}
.login-stage-title .h-mark {
    background: var(--c-ember);
    color: var(--c-snow);
    font-style: normal;
    padding: 0 0.12em;
    border-radius: 8px;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}
.login-stage-lead {
    font-family: var(--ff-body);
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.72);
    max-width: 520px;
    margin-top: 8px;
}
.login-stage-foot {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    flex-wrap: wrap;
}
.login-stage-meta {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    font-family: var(--ff-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--c-fog);
    text-transform: lowercase;
}
.login-stage-meta span { white-space: nowrap; }
.login-stage-year { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--c-fog); }

/* RIGHT — чистая paper-форма */
.login-form-pane {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 40px;
    background: var(--c-paper);
}
.login-card {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    width: 480px;
    max-width: 100%;
    flex: 0 0 480px;
    text-align: left;
    display: flex;
    flex-direction: column;
}
.login-card-eyebrow {
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    color: var(--c-smoke);
    text-transform: lowercase;
    margin-bottom: 20px;
}
.login-card h2 {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: 48px;
    line-height: 1.0;
    letter-spacing: -0.035em;
    color: var(--c-ink);
    margin-bottom: 12px;
}
.login-subtitle {
    font-family: var(--ff-body);
    font-size: 15px;
    line-height: 1.5;
    color: var(--c-smoke);
    margin-bottom: 36px;
}
.login-form { display: flex; flex-direction: column; gap: 16px; }
.login-field { display: flex; flex-direction: column; gap: 6px; }
.login-field-label {
    font-family: var(--ff-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--c-smoke);
    text-transform: lowercase;
    padding-left: 2px;
}
.login-form input {
    padding: 14px 18px;
    border: none;
    border-radius: var(--r-pill);
    font-size: 16px;
    font-family: var(--ff-body);
    background: var(--c-snow);
    color: var(--c-ink);
    outline: none;
    width: 100%;
    box-shadow: inset 0 0 0 1px rgba(21, 23, 26, 0.06);
    transition: box-shadow var(--dur-1) var(--ease-out);
}
.login-form input::placeholder { color: var(--c-fog); }
.login-form input:focus { box-shadow: inset 0 0 0 2px var(--c-ember); }

/* Убираем голубую заливку Chrome autofill (как на платформе) */
.login-form input:-webkit-autofill,
.login-form input:-webkit-autofill:hover,
.login-form input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px var(--c-snow) inset, inset 0 0 0 1px rgba(21, 23, 26, 0.06) !important;
    -webkit-text-fill-color: var(--c-ink) !important;
    transition: background-color 9999s ease-in-out 0s;
}
.login-form input:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 30px var(--c-snow) inset, inset 0 0 0 2px var(--c-ember) !important;
}

.login-btn {
    padding: 16px !important;
    font-size: 15px !important;
    font-weight: var(--fw-sb) !important;
    height: auto !important;
    border-radius: var(--r-pill) !important;
    justify-content: center;
    margin-top: 12px;
    background: var(--c-ember) !important;
    color: var(--c-snow) !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(255, 90, 31, 0.25) !important;
    transition: background var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out) !important;
}
@media (hover: hover) {
    .login-btn:hover {
        background: var(--c-ember-deep) !important;
        box-shadow: 0 6px 16px rgba(255, 90, 31, 0.35) !important;
        transform: translateY(-1px);
    }
}

.login-error {
    color: var(--c-bad);
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.02em;
    min-height: 20px;
    margin-top: 14px;
}


/* ============================================
   SIDEBAR — Эталон canon (тёмный)
   ============================================ */

.sidebar {
    width: var(--sidebar-width);
    background: var(--c-ink);
    height: 100vh;
    position: fixed;
    left: 0; top: 0;
    display: flex;
    flex-direction: column;
    z-index: 100;
    border-right: none;
}

.sidebar-logo {
    padding: 24px 20px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: calc(var(--header-height) + 12px);
}
.sidebar-logo img { height: 40px; width: auto; max-width: 100%; object-fit: contain; }

/* Бренд-словознак (как на платформе агентства — текст, не PNG, для точных пропорций) */
.brand-mark {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    letter-spacing: -0.03em;
    line-height: 1;
    display: inline-flex;
    align-items: baseline;
}
.brand-dot { color: var(--c-ember); }
.sidebar-logo .brand-mark { color: var(--c-snow); font-size: 28px; }

.sidebar-nav { flex: 1; padding: 8px 12px; overflow-y: auto; }

.nav-section {
    padding: 18px 10px 6px;
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-m);
    letter-spacing: 0.08em;
    color: var(--c-smoke);
    text-transform: lowercase;
}
.nav-section::before { content: "/ "; opacity: 0.5; }

.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    color: var(--c-fog);
    cursor: pointer;
    transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
    font-family: var(--ff-body);
    font-size: 14px;
    font-weight: var(--fw-m);
    border-radius: var(--r-sm);
    margin: 1px 0;
    text-decoration: none;
    position: relative;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
}

@media (hover: hover) {
    .nav-item:hover { background: rgba(255, 255, 255, 0.06); color: var(--c-snow); }
    .nav-item:hover svg { color: var(--c-snow); }
}
.nav-item.active {
    background: rgba(255, 90, 31, 0.16);
    color: var(--c-ember);
    font-weight: var(--fw-sb);
}
.nav-item.active svg { color: var(--c-ember); }
.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; color: currentColor; }

.sidebar-footer {
    padding: 20px 14px 16px;
    text-align: center;
    position: relative;
}
.sidebar-footer::before {
    content: '';
    position: absolute;
    top: 0; left: 16px; right: 16px; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.10), transparent);
}

.sidebar-user {
    font-family: var(--ff-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    color: var(--c-fog);
    text-align: center;
    margin-bottom: 10px;
    display: block;
}
.sidebar-user::before { content: "/ "; opacity: 0.5; }

.btn-logout {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px;
    background: rgba(255, 255, 255, 0.04);
    border: none;
    border-radius: var(--r-md);
    color: var(--c-fog);
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    font-weight: var(--fw-m);
    text-transform: lowercase;
    cursor: pointer;
    transition: all var(--dur-1) var(--ease-out);
}
@media (hover: hover) {
    .btn-logout:hover {
        color: var(--c-ember);
        background: rgba(255, 90, 31, 0.14);
    }
}

/* ============================================
   MAIN & HEADER — Эталон canon
   ============================================ */

.app-shell { display: flex; width: 100%; min-height: 100vh; }

.main { margin-left: var(--sidebar-width); flex: 1; min-height: 100vh; overflow-x: hidden; }

.header {
    height: var(--header-height);
    background: var(--c-paper);
    border-bottom: 1px solid var(--c-mist);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    position: sticky;
    top: 0;
    z-index: 50;
}

.header-title {
    font-family: var(--ff-display);
    font-size: 18px;
    font-weight: var(--fw-b);
    letter-spacing: -0.02em;
    color: var(--c-ink);
}
.hamburger {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    margin-right: 8px;
    color: var(--c-ink);
}
.content { padding: 24px 28px; overflow: visible; }

/* ============================================
   PAGE HEADER (legacy — compat для страниц до Phase 4 миграции)
   ============================================ */

.page-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 32px;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--c-mist);
    flex-wrap: wrap;
    gap: 16px;
}

.page-header > div:first-child {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.page-header h1,
.page-header .page-hero__title {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: clamp(28px, 3.5vw, 44px);
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--c-ink);
    margin: 0;
    text-wrap: balance;
}

.page-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px;
    color: var(--c-smoke);
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
}

.spinner {
    width: 28px; height: 28px;
    border: 3px solid var(--c-mist);
    border-top-color: var(--c-ember);
    border-radius: 50%;
    animation: spin 0.7s linear infinite;
    margin-right: 10px;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* Инлайновый SVG-спиннер в кнопках (мгновенный отклик — _btnSpin) */
.spin-icon {
    display: inline-block;
    vertical-align: middle;
    animation: spin 0.7s linear infinite;
    flex: 0 0 auto;
}

/* Маленький инлайновый спиннер для прогресса внутри текста (auth-ожидание и т.п.) */
.spinner-sm {
    width: 14px; height: 14px;
    border-width: 2px;
    margin-right: 0;
    flex: 0 0 auto;
}

/* ============================================
   STAT CARDS — Эталон canon
   ============================================ */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 28px;
}

.stats-grid-2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }

/* Воронка — ВСЕГДА одна строка (не перенос на 2-ю), любое число карточек.
   grid-auto-flow:column + minmax(0,1fr) → колонки ужимаются под ширину, не переносятся. */
.stats-grid--row {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
}
.stats-grid--row .stat-card { padding: 16px 16px 14px; gap: 8px; }
.stats-grid--row .stat-value { font-size: clamp(20px, 2.4vw, 34px); }
@media (max-width: 760px) {
    /* узкий экран: одна строка сохраняется, но даём горизонтальный скролл вместо клиппинга */
    .stats-grid--row { grid-auto-columns: minmax(116px, 1fr); overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; }
}

.stat-card {
    background: var(--c-snow);
    border-radius: var(--r-lg);
    padding: 24px 24px 22px;
    border: none;
    box-shadow: var(--sh-sm);
    transition: transform var(--dur-1) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
    display: flex;
    flex-direction: column;
    gap: 12px;
}
@media (hover: hover) {
    .stat-card:hover {
        transform: translateY(-1px);
        box-shadow: var(--sh-md);
    }
}

.stat-label {
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-m);
    letter-spacing: 0.08em;
    color: var(--c-smoke);
    text-transform: lowercase;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}
.stat-label::before { content: "/ "; opacity: 0.5; }

.stat-value {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: clamp(32px, 3.5vw, 44px);
    line-height: 0.98;
    letter-spacing: -0.03em;
    color: var(--c-ink);
}
.stat-sub {
    font-family: var(--ff-mono);
    font-size: 12px;
    color: var(--c-smoke);
    letter-spacing: 0.02em;
    margin-left: 8px;
    font-weight: var(--fw-m);
}

/* Варианты (compat-имена из старого Finance) */
.stat-card-blue {
    background: var(--c-ink);
}
.stat-card-blue .stat-label,
.stat-card-blue .stat-sub { color: var(--c-fog); }
.stat-card-blue .stat-value { color: var(--c-ember); }

.stat-card-green {
    background: var(--c-good-soft);
}
.stat-card-green .stat-value { color: #1B7A3E; }

.stat-card-purple {
    background: var(--c-ember-soft);
}
.stat-card-purple .stat-value { color: var(--c-ember-deep); }

.stat-card-red {
    background: var(--c-bad-soft);
}
.stat-card-red .stat-value { color: #B42318; }

.stat-big {
    font-family: var(--ff-display);
    font-weight: var(--fw-eb);
    font-size: clamp(56px, 6vw, 96px);
    line-height: 0.95;
    letter-spacing: -0.035em;
    color: var(--c-ember);
    margin-bottom: 8px;
}

/* ============================================
   CARDS
   ============================================ */

.card {
    background: var(--c-snow);
    border-radius: var(--r-lg);
    border: none;
    box-shadow: var(--sh-sm);
    overflow: hidden;
}

.card-header {
    padding: 18px 22px 14px;
    font-family: var(--ff-display);
    font-size: 16px;
    font-weight: var(--fw-b);
    letter-spacing: -0.01em;
    color: var(--c-ink);
    border-bottom: 1px solid var(--c-mist);
}

.card-body { padding: 22px; }

/* Таблица как прямой ребёнок карточки — flush к краям, без «плавающего» thead-обрубка */
.card-body:has(> table) { padding: 0; }
.card-body:has(> table) > table { border-radius: 0 0 var(--r-lg) var(--r-lg); overflow: hidden; }

/* Карточка кампании (#11) — без коробок-метрик и лишних разделителей */
.campaign-card { margin-bottom: 12px; }
.campaign-card__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: 18px 22px;
    flex-wrap: wrap;
}
.campaign-card__id { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.campaign-card__name {
    font-family: var(--ff-display);
    font-size: 16px;
    font-weight: var(--fw-b);
    letter-spacing: -0.01em;
    cursor: pointer;
    color: var(--c-ink);
}
.campaign-card__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.campaign-card__metrics { display: flex; gap: 32px; padding: 0 22px 20px; flex-wrap: wrap; }
.cmetric { display: flex; flex-direction: column; gap: 2px; }
.cmetric__val { font-family: var(--ff-display); font-size: 22px; font-weight: var(--fw-b); color: var(--c-ink); line-height: 1; }
.cmetric__label { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--c-smoke); text-transform: lowercase; }

/* Деструктивный ghost — нейтральный, без красного (не по дизайн-системе) */
.btn-ghost-danger { background: transparent; border-color: transparent; color: var(--c-smoke); }
@media (hover: hover) { .btn-ghost-danger:hover { background: var(--c-paper-2); border-color: transparent; color: var(--c-ink); } }

/* ============================================
   SCROLLBARS — тонкие скруглённые, не обрубки (#15/#20)
   ============================================ */

/* Светлая тема (контент, модалки, таблицы) */
* { scrollbar-width: thin; scrollbar-color: var(--c-fog) transparent; }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: var(--c-fog);
    border-radius: var(--r-pill);
    border: 2px solid transparent;
    background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--c-smoke); background-clip: padding-box; }
::-webkit-scrollbar-corner { background: transparent; }

/* Скролл внутри скруглённых модалок не должен вылазить за радиус углов.
   `.modal` скроллится целиком (border-radius:--r-xl), а нативный трек идёт от края
   до края → на верхнем/нижнем скруглении скроллбар визуально торчит за попап.
   Отодвигаем трек на радиус сверху/снизу — скроллбар живёт в ПРЯМОЙ части края.
   То же для модалок, скроллящих через .modal-body. */
.modal::-webkit-scrollbar-track,
.modal-body::-webkit-scrollbar-track {
    margin: var(--r-xl) 0;
}

/* Тёмный сайдбар — приглушённый thumb под ink-фон */
.sidebar, .sidebar-nav { scrollbar-color: rgba(255,255,255,0.18) transparent; }
.sidebar ::-webkit-scrollbar-thumb,
.sidebar-nav::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.18);
    border-radius: var(--r-pill);
    border: 2px solid transparent;
    background-clip: padding-box;
}
.sidebar ::-webkit-scrollbar-thumb:hover,
.sidebar-nav::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.3); background-clip: padding-box; }

/* ============================================
   FUNNEL
   ============================================ */

.funnel-row { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.funnel-label {
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.04em;
    width: 130px;
    flex-shrink: 0;
    color: var(--c-smoke);
    text-transform: lowercase;
}
.funnel-bar-wrap { flex: 1; background: var(--c-mist); border-radius: var(--r-pill); height: 8px; overflow: hidden; }
.funnel-bar { height: 100%; border-radius: var(--r-pill); transition: width 0.5s var(--ease-out); }
.funnel-count {
    font-family: var(--ff-mono);
    font-size: 13px;
    font-weight: var(--fw-sb);
    width: 40px;
    text-align: right;
    color: var(--c-ink);
}

/* ============================================
   TABLES — Эталон canon
   ============================================ */

.table-wrap {
    background: var(--c-snow);
    border-radius: var(--r-lg);
    border: none;
    box-shadow: var(--sh-sm);
    overflow: hidden;
    margin-bottom: 28px;
}

.table-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 18px 22px;
    border-bottom: 1px solid var(--c-mist);
    flex-wrap: wrap;
}

/* Контекстная плашка выбора — отдельный ряд-продолжение тулбара (#10).
   Полноширинный ряд внутри .table-wrap: ember-tinted фон = состояние «выбрано»,
   единственная разделительная линия снизу (как border-bottom у .table-toolbar),
   БЕЗ собственного border/border-radius/margin — иначе двойные линии и щель
   между тулбаром и таблицей. Левый ember-акцент маркирует активный выбор. */
.selection-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 12px 22px;
    background: var(--c-ember-soft);
    border-bottom: 1px solid var(--c-mist);
    box-shadow: inset 3px 0 0 0 var(--c-ember);
}
.selection-bar[hidden] { display: none; }
.selection-bar__count {
    font-size: 13px; color: var(--c-ember-deep);
    display: inline-flex; align-items: center; gap: 8px;
}
.selection-bar__count strong {
    font-family: var(--ff-mono); font-weight: var(--fw-b);
    background: var(--c-ember); color: var(--c-snow);
    padding: 2px 10px; border-radius: var(--r-pill);
    font-size: 12px; line-height: 1.5;
}
.selection-bar__actions { display: flex; gap: 8px; flex-wrap: wrap; }
/* Кнопка «Удалить выбранных» на ember-soft баре: чистая сплошная ink-пилюля
   (нейтральная, чётко читается на персике, без сырой оранжевой обводки),
   hover → залитый rust (ember-deep) как сигнал деструктивного действия. */
/* .btn.sel-del-btn — двойной класс, чтобы перебить базовый .btn (идёт позже в файле). */
.btn.sel-del-btn {
    background: var(--c-ink);
    color: var(--c-snow);
    border-color: var(--c-ink);
    box-shadow: 0 1px 2px rgba(21, 23, 26, 0.10);
}
@media (hover: hover) {
    .btn.sel-del-btn:hover {
        background: var(--c-ember-deep);
        border-color: var(--c-ember-deep);
        color: var(--c-snow);
        transform: translateY(-1px);
        box-shadow: 0 4px 12px rgba(197, 61, 15, 0.30);
    }
}
.btn.sel-del-btn:active { transform: translateY(0); }

.search-input {
    padding: 10px 16px;
    border: 1px solid var(--c-mist);
    border-radius: var(--r-pill);
    font-size: 14px;
    font-family: var(--ff-body);
    color: var(--c-ink);
    background: var(--c-snow);
    outline: none;
    min-width: 220px;
    height: 40px;
    transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
}
.search-input:focus { border-color: var(--c-ember); box-shadow: 0 0 0 3px rgba(255, 90, 31, 0.15); }

table { width: 100%; border-collapse: collapse; font-size: 14px; }

thead { background: var(--c-paper); position: sticky; top: 0; z-index: 2; }

/* В модалках thead НЕ липкий — иначе серый прямоугольный обрубок плавает и режется о скругление модалки (#12) */
.modal thead, .modal-body thead { position: static; }
.modal table, .modal-body table { border-radius: var(--r-md); overflow: hidden; }

th {
    padding: 12px 18px;
    text-align: left;
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-m);
    letter-spacing: 0.08em;
    color: var(--c-smoke);
    text-transform: lowercase;
    white-space: nowrap;
    border-bottom: 1px solid var(--c-mist);
    background: var(--c-paper);
}

td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--c-mist);
    font-family: var(--ff-body);
    color: var(--c-ink);
}
tr:last-child td { border-bottom: none; }
tbody tr { transition: background var(--dur-1) var(--ease-out); }
@media (hover: hover) {
    tbody tr:hover { background: rgba(21, 23, 26, 0.03); }
}

.stagger-row {
    opacity: 0;
    transform: translateY(12px);
    filter: blur(3px);
    animation: rowFadeIn 0.3s ease forwards;
}
@keyframes rowFadeIn {
    to { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* Появление новой/изменившейся карточки группы без перезагрузки страницы */
.card-appear {
    animation: cardAppear 0.38s var(--ease-out) both;
}
@keyframes cardAppear {
    from { opacity: 0; transform: translateY(14px) scale(0.97); filter: blur(4px); }
    to   { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

.table-empty {
    text-align: center;
    padding: 56px 24px;
    color: var(--c-graphite);
    font-family: var(--ff-mono);
    font-size: 13px;
    letter-spacing: 0.04em;
}
.table-empty::before { content: "/ пусто"; display: block; color: var(--c-smoke); margin-bottom: 4px; }

/* ============================================
   BADGES / STATUS PILLS — Эталон canon
   ============================================ */

.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    border-radius: var(--r-pill);
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-m);
    letter-spacing: 0.04em;
    text-transform: lowercase;
    white-space: nowrap;
}

/* Lead status pills — outreach_leads.status */
.badge-new          { background: var(--c-mist); color: var(--c-graphite); }
.badge-enriched     { background: var(--c-ember-soft); color: var(--c-ember-deep); }
.badge-in_campaign  { background: var(--c-warn-soft); color: #93370D; }
.badge-responded    { background: var(--c-ember-soft); color: var(--c-ember-deep); }
.badge-qualified    { background: var(--c-good-soft); color: #1B7A3E; }
.badge-disqualified { background: var(--c-bad-soft); color: #B42318; }

/* Лид, которому уже отправлено сообщение — неактивный (дедуп аутрича) */
/* «Сообщение отправлено» — максимально тихий индикатор: один приглушённый значок-самолётик
   рядом со статусом (без текста, без цвета, без плашки). Статус-бейдж — единственный акцент;
   строка contacted-лида и так приглушена (.lead-row-contacted opacity). Tooltip — на hover. */
.lead-sent-flag {
    display: inline-flex;
    align-items: center;
    color: var(--c-fog, #9A9DA3);
    flex: 0 0 auto;
}
.lead-sent-flag svg { display: block; }
.lead-row-contacted { opacity: 0.55; }
.lead-row-contacted:hover { opacity: 0.8; }

/* Dialog status pills — outreach_dialogs.status */
.badge-pending_reply  { background: var(--c-warn-soft); color: #93370D; }
.badge-interested     { background: var(--c-good-soft); color: #1B7A3E; }
.badge-call_scheduled { background: var(--c-ink); color: var(--c-snow); }
.badge-rejected       { background: var(--c-bad-soft); color: #B42318; }
.badge-warning        { background: var(--c-warn-soft); color: #93370D; }

/* Channel badges (где есть телега/инст/email) */
.badge-email     { background: var(--c-mist); color: var(--c-graphite); }
.badge-telegram  { background: var(--c-ember-soft); color: var(--c-ember-deep); }
.badge-instagram { background: var(--c-good-soft); color: #1B7A3E; }
.badge-max       { background: rgba(27,107,255,.12); color: #1B6BFF; }

/* Strategy hypothesis priority pills (strategy.js: badge-priority-{1,2,3}) */
.badge-priority-1 { background: var(--c-bad-soft); color: #B42318; }
.badge-priority-2 { background: var(--c-warn-soft); color: #93370D; }
.badge-priority-3 { background: var(--c-mist); color: var(--c-graphite); }

/* ============================================
   BUTTONS — Finance style (pill shape)
   ============================================ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 20px;
    border-radius: var(--r-pill);
    font-size: 14px;
    font-weight: var(--fw-sb);
    font-family: var(--ff-body);
    cursor: pointer;
    border: 1px solid var(--c-mist);
    background: var(--c-snow);
    color: var(--c-ink);
    transition: background var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out);
    height: 40px;
    white-space: nowrap;
}
@media (hover: hover) {
    .btn:hover {
        background: var(--c-paper-2);
        border-color: var(--c-fog);
        transform: translateY(-1px);
    }
}
/* Все кнопки семейства .btn реагируют одинаково: подскок на hover, возврат на клик (#1). */
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: 0.5; cursor: default; transform: none; }

.btn-primary {
    background: var(--c-ember);
    color: var(--c-snow);
    border-color: transparent;
    padding: 10px 22px;
    box-shadow: 0 2px 8px rgba(255, 90, 31, 0.25);
}
@media (hover: hover) {
    .btn-primary:hover {
        background: var(--c-ember-deep);
        box-shadow: 0 6px 16px rgba(255, 90, 31, 0.35);
        transform: translateY(-1px);
    }
}
.btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(255, 90, 31, 0.2);
}

.btn-outline {
    background: transparent;
    color: var(--c-ink);
    border: 1px solid var(--c-mist);
}
@media (hover: hover) {
    .btn-outline:hover {
        background: var(--c-paper);
        border-color: var(--c-fog);
        transform: translateY(-1px);
    }
}

.btn-success {
    background: var(--c-good);
    color: var(--c-snow);
    border-color: transparent;
    box-shadow: 0 2px 8px rgba(46, 207, 111, 0.25);
}
@media (hover: hover) {
    .btn-success:hover {
        /* явно затемняем зелёный — иначе .btn:hover (выше по специфичности) красит фон
           в серый c-paper-2 → «grey-ghost» с раздутым глоу (#13). Убираем глоу, лёгкое потемнение. */
        background: #27B863;
        border-color: transparent;
        box-shadow: 0 3px 10px rgba(46, 207, 111, 0.28);
        transform: translateY(-1px);
    }
}
.btn-success:active { background: #21A657; box-shadow: 0 2px 6px rgba(46, 207, 111, 0.22); }

/* ============================================
   INFO-TIP — значок (i) с поп-апом по наведению (#10, переиспользуем для #18/#20)
   ============================================ */
.info-tip {
    display: inline-flex; align-items: center; justify-content: center;
    width: 15px; height: 15px; margin-left: 5px;
    border-radius: 50%; border: 1px solid var(--c-fog);
    color: var(--c-graphite); background: var(--c-snow);
    font: 600 10px/1 var(--ff-body); cursor: help; position: relative;
    vertical-align: middle; user-select: none;
}
.info-tip:hover { border-color: var(--c-ember); color: var(--c-ember); }
.info-tip__pop {
    position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(4px);
    width: max-content; max-width: min(280px, calc(100vw - 24px)); white-space: normal; text-align: left;
    background: var(--c-ink); color: var(--c-snow); font: 400 12px/1.45 var(--ff-body);
    padding: 9px 11px; border-radius: var(--r-sm); box-shadow: var(--sh-md);
    opacity: 0; pointer-events: none; transition: opacity var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out);
    z-index: 100001;
    /* #9: max-height + внутренний скролл — тултип не обрезается снизу вьюпортом или
       родителем с overflow. 200px хватает для самых длинных пояснений на Аккаунтах
       (~130px контента). Скроллбар тонкий (webkit) / стандартный на остальных. */
    max-height: 200px;
    overflow-y: auto;
    /* тонкий скроллбар внутри тёмного поп-апа */
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.3) transparent;
}
.info-tip__pop::-webkit-scrollbar { width: 4px; }
.info-tip__pop::-webkit-scrollbar-track { background: transparent; }
.info-tip__pop::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.3); border-radius: 2px; }
.info-tip__pop::after {
    content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
    border: 5px solid transparent; border-top-color: var(--c-ink);
}
.info-tip:hover .info-tip__pop, .info-tip:focus .info-tip__pop {
    opacity: 1; transform: translateX(-50%) translateY(0);
}
/* у правого края экрана — прижать поп-ап влево, чтобы не уезжал за вьюпорт */
.info-tip__pop--right { left: auto; right: -8px; transform: translateY(4px); }
.info-tip:hover .info-tip__pop--right, .info-tip:focus .info-tip__pop--right { transform: translateY(0); }
.info-tip__pop--right::after { left: auto; right: 12px; transform: none; }
/* открытие ВНИЗ (#A5): когда сверху не помещается / клипится родителем с overflow */
.info-tip__pop--down { bottom: auto; top: calc(100% + 8px); transform: translateX(-50%) translateY(-4px); }
.info-tip__pop--down::after { top: auto; bottom: 100%; border-top-color: transparent; border-bottom-color: var(--c-ink); }
.info-tip:hover .info-tip__pop--down, .info-tip:focus .info-tip__pop--down { transform: translateX(-50%) translateY(0); }
/* мобила: значок живёт в правой колонке модалки → --right тянет поп влево; узкий
   экран не вмещает 280px без клипа слева. Капаем ширину, чтобы поп помещался. */
@media (max-width: 640px) {
  .info-tip__pop { max-width: min(220px, calc(100vw - 40px)); }
  /* тултип в правом углу flex-заголовка: прижать влево чтобы не уезжал за viewport */
  .info-tip__pop--mobile-right { left: auto; right: -8px; transform: translateY(-4px); }
  .info-tip__pop--mobile-right::after { left: auto; right: 12px; transform: none; }
  .info-tip:hover .info-tip__pop--mobile-right,
  .info-tip:focus .info-tip__pop--mobile-right { transform: translateY(0); }
  /* комбо down+mobile-right: открывается вниз, прижат к правому краю */
  .info-tip__pop--down.info-tip__pop--mobile-right { top: calc(100% + 8px); bottom: auto; transform: translateY(-4px); }
  .info-tip:hover .info-tip__pop--down.info-tip__pop--mobile-right,
  .info-tip:focus .info-tip__pop--down.info-tip__pop--mobile-right { transform: translateY(0); }
  .info-tip__pop--down.info-tip__pop--mobile-right::after { top: auto; bottom: 100%; border-top-color: transparent; border-bottom-color: var(--c-ink); left: auto; right: 12px; transform: none; }
}

/* ============================================
   INFO-TIP PORTAL (#3) — синглтон в body, position:fixed
   Не клипится overflow родительской карточки.
   JS выставляет left/top через getBoundingClientRect().
   Стрелки: --down (триггер сверху → поп под ним),
            без --down (триггер снизу → поп над ним).
   ============================================ */
.info-tip__pop--portal {
    /* Переопределяем позиционирование: JS ставит left/top напрямую */
    position: fixed !important;
    /* Убираем transform'ы inherited от .info-tip__pop (они для in-place режима) */
    transform: none !important;
    bottom: auto !important;
    left: auto;
    top: auto;
    /* Стрелка по умолчанию СНИЗУ поп-апа (поп над триггером) */
}
/* Поп НАД триггером → стрелка снизу (border-top-color) */
.info-tip__pop--portal:not(.info-tip__pop--down)::after {
    top: 100%; left: 50%; transform: translateX(-50%);
    border-top-color: var(--c-ink);
    border-bottom-color: transparent;
}
/* Поп ПОД триггером (--down) → стрелка сверху (border-bottom-color) */
.info-tip__pop--portal.info-tip__pop--down::after {
    top: auto; bottom: 100%; left: 50%; transform: translateX(-50%);
    border-top-color: transparent;
    border-bottom-color: var(--c-ink);
}
/* Анимация открытия уже через opacity transition (inline style) */
@media (max-width: 640px) {
    .info-tip__pop--portal { max-width: min(220px, calc(100vw - 16px)) !important; }
}

/* ============================================
   READY-CHECK — кружок ✓/✗ готовности (#5), вместо сырого emoji
   ============================================ */
.ready-check {
    display: inline-flex; align-items: center; justify-content: center;
    flex: 0 0 22px; width: 22px; height: 22px; border-radius: 50%;
}
.ready-check svg { width: 13px; height: 13px; }
.ready-check--ok  { background: var(--c-good-soft); color: var(--c-good); }
.ready-check--no  { background: var(--c-bad-soft);  color: var(--c-bad); }
.ready-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; font-size: 14px; }
.ready-row + .ready-row { border-top: 1px solid var(--c-mist); }

/* ============================================
   CAMP-LEADS — секция таблицы лидов внутри поп-апа кампании (#7),
   чтобы таблица не «висела в пустоте», а читалась частью модалки
   ============================================ */
.camp-section-label { font: var(--fw-sb) 13px/1 var(--ff-body); color: var(--c-graphite); margin-bottom: 8px; }
.camp-leads {
    border: 1px solid var(--c-mist); border-radius: var(--r-md); overflow: hidden;
    background: var(--c-paper);
}
.camp-leads__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px; background: var(--c-paper-2);
    border-bottom: 1px solid var(--c-mist);
    font: var(--fw-sb) 13px/1 var(--ff-body); color: var(--c-ink);
}
.camp-leads__body { max-height: 46vh; overflow-y: auto; overflow-x: auto; overscroll-behavior: contain; background: var(--c-snow); }
.camp-leads__body table { margin: 0; }
.camp-leads__body td { word-break: break-word; } /* длинное имя компании без пробелов не растягивает модалку */
.camp-leads__body thead th { position: sticky; top: 0; background: var(--c-snow); z-index: 1; }

/* Кнопка удаления группы парсинга (правый верхний угол карточки группы) */
.group-del-btn {
    position: absolute; top: 10px; right: 10px;
    width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px; border: 1px solid transparent; background: transparent;
    color: var(--c-smoke); cursor: pointer; opacity: 0; transition: opacity var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.group-del-btn svg { width: 15px; height: 15px; }
.lead-group-card:hover .group-del-btn { opacity: 1; }
.group-del-btn:hover { background: var(--c-bad-soft); color: var(--c-bad); border-color: transparent; }
@media (hover: none) { .group-del-btn { opacity: 1; } } /* на тач-устройствах кнопка видна всегда */

/* Деструктивный — ghost-стиль (#1/#2): прозрачный фон + ink-текст + тонкая граница,
   на hover заливается тёмным. Не давит на глаз рядом с ember-primary и не конкурирует
   с ним по весу. Красный остаётся только для статус-бейджей (--c-bad), не для кнопок. */
.btn-danger {
    background: transparent;
    color: var(--c-ink);
    border-color: var(--c-mist);
}
@media (hover: hover) {
    .btn-danger:hover {
        background: var(--c-ink-2);
        color: var(--c-snow);
        border-color: var(--c-ink-2);
        transform: translateY(-1px);
    }
}
.btn-danger:active { transform: translateY(0); }

.btn-sm { padding: 6px 14px; font-size: 12px; height: 32px; }
.btn-icon { width: 40px; padding: 0; justify-content: center; }
.btn-group { display: flex; gap: 8px; flex-wrap: wrap; }

/* Диалоги — компактная группа action-иконок (#2 редизайн: один pill-контейнер
   вместо 4 разрозненных обводок; нейтральные по умолчанию, семантика на hover) */
.row-actions {
    display: inline-flex; align-items: center; gap: 2px;
    padding: 3px; background: var(--c-paper-2);
    border-radius: var(--r-pill);
}
.row-actions .ra-btn {
    width: 30px; height: 30px; padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    border: none; background: transparent; border-radius: var(--r-pill);
    color: var(--c-smoke); cursor: pointer;
    transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out);
}
.row-actions .ra-btn svg { width: 16px; height: 16px; display: block; }
.row-actions .ra-btn:active { transform: scale(0.9); }
@media (hover: hover) {
    .row-actions .ra-btn:hover { background: var(--c-snow); color: var(--c-ink); box-shadow: var(--sh-sm); }
    .row-actions .ra-btn--good:hover { color: var(--c-good); }
    .row-actions .ra-btn--bad:hover  { color: var(--c-bad); }
}
.row-actions.is-busy { opacity: 0.45; pointer-events: none; }
/* Кнопка с иконкой + подписью */
.row-actions .ra-btn--labeled { width: auto; padding: 0 8px; gap: 5px; }
.row-actions .ra-btn--labeled .ra-label { font-size: 11px; font-weight: 500; white-space: nowrap; }
/* Разделитель между основным действием и деструктивными */
.row-actions .ra-sep { width: 1px; height: 18px; background: var(--c-mist); margin: 0 2px; flex-shrink: 0; }
/* Семантические hover-цвета */
@media (hover: hover) {
    .row-actions .ra-btn--archive:hover,
    .row-actions .ra-btn--unarchive:hover { color: var(--c-smoke); }
    .row-actions .ra-btn--del:hover     { color: var(--danger,#e53e3e); }
}

/* ============================================
   MODAL — Эталон canon
   ============================================ */

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(18, 20, 23, 0.78);
    backdrop-filter: blur(16px) saturate(0.6);
    -webkit-backdrop-filter: blur(16px) saturate(0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--dur-2) var(--ease-out);
    padding: 24px 16px;
}

.modal-overlay.show, .modal-overlay.active {
    opacity: 1;
    pointer-events: all;
}

.modal {
    background: var(--c-snow);
    border-radius: var(--r-xl);
    padding: 32px 32px 16px;
    width: 100%;
    max-width: 560px;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    scrollbar-gutter: stable;
    box-shadow: var(--sh-lg);
    transform: translateY(8px) scale(0.98);
    transition: transform var(--dur-2) var(--ease-out);
    margin: auto;
}

.modal-overlay.show .modal, .modal-overlay.active .modal {
    transform: translateY(0) scale(1);
}

.modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 22px;
    gap: 12px;
}

.modal-header span,
.modal-header h2 {
    font-family: var(--ff-display);
    font-size: 22px;
    font-weight: var(--fw-b);
    letter-spacing: -0.02em;
    color: var(--c-ink);
    margin: 0;
}

.modal-close {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 22px;
    color: var(--c-graphite);
    padding: 4px 8px;
    line-height: 1;
    border-radius: var(--r-sm);
    transition: background var(--dur-1) var(--ease-out);
}
@media (hover: hover) {
    .modal-close:hover { background: var(--c-mist); color: var(--c-ink); }
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid var(--c-mist);
}

/* ============================================
   FORMS — Эталон canon
   ============================================ */

.form-group { margin-bottom: 14px; }
.form-label {
    display: block;
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-m);
    letter-spacing: 0.06em;
    color: var(--c-smoke);
    text-transform: lowercase;
    margin-bottom: 6px;
}
.form-label::before { content: "/ "; opacity: 0.5; }

.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: 11px 16px;
    border: 1px solid var(--c-mist);
    border-radius: var(--r-pill);
    font-size: 14px;
    font-family: var(--ff-body);
    color: var(--c-ink);
    background: var(--c-snow);
    outline: none;
    transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
    height: 42px;
    box-sizing: border-box;
}

.form-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236E7178' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 42px;
}

.form-textarea {
    min-height: 80px;
    height: auto;
    resize: vertical;
    padding: 12px 16px;
    border-radius: var(--r-md);
}

.form-input:focus, .form-select:focus, .form-textarea:focus {
    border-color: var(--c-ember);
    box-shadow: 0 0 0 3px rgba(255, 90, 31, 0.15);
}

/* ── #14a: плашка «Лид не состоит ни в одной кампании» ───────────────────
   #madd-campaign-err рендерится inline-стилями из calls.js; перебиваем здесь
   только spacing/тон (без override background/border — они уже по DS в JS).
   margin-top: даёт воздух между label/предыдущим полем и notice.
   Уведомление оформлено как предупреждение (warn-soft), не просто серый блок:
   левая accent-полоска + тёплый фон сигнализируют «нет данных / нужно действие». */
#madd-campaign-err {
    margin-top: 8px !important;
    background: var(--c-warn-soft) !important;
    border-color: var(--c-warn) !important;
    border-left: 3px solid var(--c-warn) !important;
    color: var(--c-ink) !important;
    /* чуть компактнее padding слева, чтобы текст не прижимался к accent-полоске */
    padding-left: 12px !important;
    border-radius: var(--r-sm) !important;
}

/* Автоподсказка переменных шаблона ({{...}}) — всплывает у каретки.
   Шире, чтобы описание умещалось в ОДНУ строку (см. .var-ac-item grid + nowrap). */
.var-autocomplete {
    position: fixed;
    z-index: 1100;
    min-width: 360px;
    max-width: 560px;
    background: var(--c-snow);
    border: 1px solid var(--c-mist);
    border-radius: var(--r-md);
    box-shadow: var(--sh-lg);
    padding: 4px;
}
/* grid: переменная слева (auto), описание справа (1fr, nowrap) — одна строка */
.var-ac-item {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 16px;
    padding: 8px 10px;
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: background .12s var(--ease-out);
}
/* hover/active — единый эмбер-софт фон (как у активного пункта) */
.var-ac-item:hover,
.var-ac-item.active { background: var(--c-ember-soft); }
.var-ac-key {
    font-family: var(--ff-mono);
    font-size: 13px;
    font-weight: var(--fw-sb);
    color: var(--c-ember-deep);
    white-space: nowrap;
}
.var-ac-hint {
    font-size: 12px;
    color: var(--c-smoke);
    white-space: nowrap;          /* описание в одну строку (десктоп) */
    text-align: right;
    overflow: hidden;
    text-overflow: ellipsis;
}
/* На узком экране popup сужается по вьюпорту: grid `auto 1fr` при длинном ключе
   ({{icebreaker}}) схлопывал описание в колонку по букве → СТЕКАЕМ вертикально
   (ключ сверху, описание снизу слева, перенос разрешён). */
@media (max-width: 480px) {
    .var-autocomplete { min-width: 0; max-width: calc(100vw - 16px); }
    .var-ac-item { grid-template-columns: 1fr; gap: 2px; }
    .var-ac-hint { white-space: normal; text-align: left; }
}

/* Прогресс-бар ротации icebreaker (светлая модалка — свой трек, не тёмный jm-bar) */
.ib-progress { margin-top: 10px; }
.ib-progress__head {
    display: flex; justify-content: space-between; align-items: baseline;
    font-size: 12px; color: var(--c-smoke); margin-bottom: 6px;
}
.ib-progress__pct { font-family: var(--ff-mono); white-space: nowrap; }
.ib-bar { height: 8px; background: var(--c-paper-2); border-radius: var(--r-pill); overflow: hidden; }
.ib-bar__fill { height: 100%; width: 0; background: var(--c-ember); border-radius: var(--r-pill); transition: width .4s var(--ease-out); }
.ib-bar--indet .ib-bar__fill { width: 40%; animation: ibIndet 1.1s ease-in-out infinite; }
@keyframes ibIndet { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }

/* ============================================
   IMPORT TABS
   ============================================ */

.import-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 18px;
    background: var(--c-paper-2);
    border-radius: var(--r-pill);
    padding: 4px;
}

.import-tab {
    flex: 1;
    padding: 9px 14px;
    border: none;
    background: transparent;
    border-radius: var(--r-pill);
    font-family: var(--ff-body);
    font-size: 13px;
    font-weight: var(--fw-m);
    color: var(--c-graphite);
    cursor: pointer;
    transition: all var(--dur-1) var(--ease-out);
}
@media (hover: hover) {
    .import-tab:hover { color: var(--c-ink); }
}

.import-tab.active {
    background: var(--c-snow);
    color: var(--c-ink);
    font-weight: var(--fw-sb);
    box-shadow: var(--sh-sm);
}

/* ============================================
   FILE PICKER — кастомная зона выбора файла (#3)
   нативный input спрятан, клик/перетаскивание — через дизайн-токены
   ============================================ */

.file-hidden-input {
    position: absolute;
    width: 1px; height: 1px;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
}

.file-dropzone {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 24px 20px;
    border: 1.5px dashed var(--c-mist);
    border-radius: var(--r-lg);
    background: var(--c-paper);
    color: var(--c-smoke);
    cursor: pointer;
    text-align: center;
    transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
}
@media (hover: hover) {
    .file-dropzone:hover { border-color: var(--c-fog); background: var(--c-paper-2); }
}
.file-dropzone.is-dragover {
    border-color: var(--c-ember);
    background: var(--c-ember-soft);
    color: var(--c-ember-deep);
}
.file-dropzone svg { color: var(--c-fog); }
.file-dropzone__name {
    font-family: var(--ff-mono);
    font-size: 12px;
    letter-spacing: 0.02em;
    color: var(--c-smoke);
}
.file-dropzone__name.is-selected { color: var(--c-ink); font-weight: var(--fw-sb); }
.file-dropzone__hint {
    font-size: 11px;
    color: var(--c-fog);
}

/* ============================================
   ANIMATED SELECT — replaces native <select>
   ============================================ */

.asel {
    position: relative;
    display: inline-block;
}

.asel__trigger {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border: 1px solid var(--c-mist);
    border-radius: var(--r-pill);
    font-size: 14px;
    font-family: var(--ff-body);
    background: var(--c-snow);
    color: var(--c-ink);
    cursor: pointer;
    height: 40px;
    white-space: nowrap;
    transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
    user-select: none;
}
@media (hover: hover) {
    .asel__trigger:hover { border-color: var(--c-fog); }
}

.asel.open .asel__trigger {
    border-color: var(--c-ember);
    box-shadow: 0 0 0 3px rgba(255, 90, 31, 0.15);
}

/* Полноширинный вариант (импорт лидов — «тип базы»): селект во всю ширину формы,
   как соседнее поле ссылки. Действует только на .asel со style width:100%. */
.asel[style*="100%"] { display: block; }
/* Full-width вариант (поля форм/модалок): chevron не должен липнуть к скруглённому
   правому краю pill-поля — даём ему воздух справа (баг «галочка прижата к краю»). */
.asel[style*="100%"] .asel__trigger { width: 100%; height: 42px; justify-content: space-between; padding-right: 18px; }
/* Длинный текст опции (напр. «Сначала выберите площадку») не должен распирать/вылезать за
   поле — обрезаем многоточием. min-width:0 обязателен, иначе flex-элемент не ужимается. */
.asel__label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.asel[style*="100%"] .asel__label { flex: 1 1 auto; }

.asel__chevron {
    width: 14px;
    height: 14px;
    transition: transform var(--dur-1) var(--ease-out);
    flex-shrink: 0;
    color: var(--c-smoke);
}

.asel.open .asel__chevron {
    transform: rotate(180deg);
}

.asel__dropdown {
    position: fixed;
    z-index: 100000;
    min-width: 100%;
    width: max-content;
    max-width: 340px; /* #9 — длинные опции (follow-up) не расползаются на пол-экрана */
    background: var(--c-snow);
    border: 1px solid var(--c-mist);
    border-radius: var(--r-md);
    box-shadow: var(--sh-lg);
    /* длинный список должен прокручиваться внутри, а не уезжать за экран (#1) */
    max-height: min(320px, 60vh);
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain; /* безопасно: элемент реально прокручиваемый */
    opacity: 0;
    transform: translateY(-8px) scale(0.96);
    pointer-events: none;
    transition: opacity var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out);
}

.asel.open .asel__dropdown,
.asel__dropdown.open {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

.asel__option {
    display: block;
    width: 100%;
    padding: 10px 16px;
    font-size: 14px;
    font-family: var(--ff-body);
    color: var(--c-ink);
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--c-mist);
    cursor: pointer;
    text-align: left;
    white-space: normal; /* #9 — длинная опция переносится, не растягивает дропдаун по ширине */
    opacity: 0;
    transform: translateX(-16px);
}

.asel__option:last-child { border-bottom: none; }
@media (hover: hover) {
    .asel__option:hover { background: var(--c-paper); }
}

.asel__option.selected {
    color: var(--c-ember);
    font-weight: var(--fw-sb);
}

/* Пустое состояние / подсказка внутри дропдауна (disabled-опция) —
   не кнопка, не выбирается: приглушённый текст с иконкой-намёком. */
.asel__note {
    display: block;
    padding: 12px 16px;
    font-size: 13px;
    line-height: 1.4;
    font-family: var(--ff-body);
    color: var(--c-smoke);
    background: var(--c-paper-2, var(--c-paper));
    cursor: default;
    white-space: normal;
}

/* ============================================
   TOAST — Эталон canon (dark + colored left-border)
   ============================================ */

.toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.toast {
    padding: 14px 20px;
    border-radius: var(--r-md);
    font-family: var(--ff-body);
    font-size: 14px;
    font-weight: var(--fw-m);
    color: var(--c-snow);
    background: var(--c-ink);
    box-shadow: var(--sh-md);
    max-width: 360px;
    border-left: 3px solid var(--c-ember);
    word-break: break-word; overflow-wrap: anywhere;  /* длинный текст/URL не вылазит за рамки */
    /* мгновенное появление: стартуем сдвинутым+прозрачным, .show включает плавный заезд */
    transform: translateX(120%);
    opacity: 0;
    transition: transform .2s var(--ease-out), opacity .2s var(--ease-out);
    will-change: transform, opacity;
}
.toast.show { transform: translateX(0); opacity: 1; }
.toast.hide { transform: translateX(120%); opacity: 0; }

.toast-info { border-left-color: var(--c-ember); }
.toast-success { border-left-color: var(--c-good); }
.toast-error { border-left-color: var(--c-bad); }
.toast-warn, .toast-warning { border-left-color: var(--c-warn); }

/* ============================================
   JOB PROGRESS WIDGET (фоновые задачи: парсинг/импорт/обогащение)
   Фиксированный справа сверху, под тостами; live-ползунок прогресса.
   ============================================ */
#jm-widget {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1990;             /* под тостами (2000), чтобы транзиентные тосты были поверх */
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 300px;
    max-width: calc(100vw - 32px);
    pointer-events: none;      /* виджет информационный — не перехватывает клики по странице */
}
.jm-card {
    pointer-events: auto;
    background: var(--c-ink);
    color: var(--c-snow);
    border-radius: var(--r-md);
    padding: 12px 14px;
    box-shadow: var(--sh-md);
    border-left: 3px solid var(--c-ember);
    animation: jmIn .25s var(--ease-out);
}
@keyframes jmIn { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: none; } }
.jm-card__row { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.jm-card__title { font-family: var(--ff-display); font-weight: var(--fw-b); font-size: 13px; }
.jm-card__pct { font-family: var(--ff-mono); font-size: 11px; color: var(--c-fog); white-space: nowrap; }
.jm-card__sub { font-size: 11px; color: var(--c-fog); margin-top: 3px; word-break: break-word; overflow-wrap: anywhere; }
.jm-bar { height: 6px; background: rgba(255,255,255,0.15); border-radius: var(--r-pill); overflow: hidden; margin-top: 9px; }
.jm-bar__fill { height: 100%; background: var(--c-ember); border-radius: var(--r-pill); transition: width .4s var(--ease-out); }
.jm-bar--indet { position: relative; }
.jm-bar--indet .jm-bar__fill { width: 40%; animation: jmIndet 1.1s ease-in-out infinite; }
@keyframes jmIndet { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }
@media (max-width: 480px) {
    #jm-widget { top: 12px; right: 12px; left: 12px; width: auto; }
}

/* ============================================
   OPTIMISTIC MUTATIONS — fade+collapse при удалении/изменении
   ============================================ */
.optimistic-removing {
    overflow: hidden !important;
    pointer-events: none;
    animation: optimisticCollapse .32s var(--ease-out) forwards;
}
@keyframes optimisticCollapse {
    0%   { opacity: 1; transform: translateX(0) scale(1); }
    35%  { opacity: 0; transform: translateX(28px) scale(.98); }
    100% { opacity: 0; transform: translateX(28px) scale(.98);
           max-height: 0; margin-top: 0; margin-bottom: 0;
           padding-top: 0; padding-bottom: 0; border-width: 0; }
}
.optimistic-flash {
    animation: optimisticFlash .5s var(--ease-out);
}
@keyframes optimisticFlash {
    0%   { background-color: var(--c-good-soft); }
    100% { background-color: transparent; }
}

/* ============================================
   EMPTY STATE
   ============================================ */

.empty-state {
    text-align: center;
    padding: 56px 24px;
    color: var(--c-graphite);
    font-family: var(--ff-body);
}
.empty-state::before {
    content: "/ пусто";
    display: block;
    font-family: var(--ff-mono);
    font-size: 11px;
    letter-spacing: 0.06em;
    color: var(--c-smoke);
    text-transform: lowercase;
    margin-bottom: 12px;
}
.empty-state p { font-size: 15px; margin-bottom: 8px; }
.text-muted { color: var(--c-smoke); font-size: 13px; }

/* ============================================
   DOSSIER — Lead detail full page
   ============================================ */

.dossier-modal {
    max-width: 760px !important;
    max-height: calc(100vh - 48px);
}

.dossier-modal .modal-body {
    max-height: calc(100vh - 150px);
    overflow-y: auto;
    padding: 8px 28px 28px;
    background: var(--c-snow);
}

/* Тулбар действий — чистая строка с нижней линией, без серой коробки.
   Первичное действие (ember) выделено, остальные — тихие ghost. */
.dossier-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    /* flex-start, не center: «Обогатить» обёрнут в колонку с подсказкой снизу («Соберёт: …»),
       при align-items:center эта 2-строчная колонка центрируется и её кнопка уезжает выше
       соседних 1-строчных кнопок. top-align ставит ВСЕ кнопки на один уровень, подсказка
       висит ниже. */
    align-items: flex-start;
    margin: 4px 0 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--c-mist);
    background: transparent;
}
/* delete-кнопка прижата вправо — выравниваем её по верху ряда (как остальные кнопки) */
.dossier-actions .dossier-del { align-self: flex-start; }
.dossier-actions .btn,
.dossier-actions .badge { flex: 0 0 auto; }
.dossier-actions .dossier-del {
    margin-left: auto;
    width: 34px; height: 34px; padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--c-smoke); border-color: transparent; background: transparent;
}
@media (hover: hover) {
    .dossier-actions .dossier-del:hover { color: var(--c-bad); background: var(--c-bad-soft); border-color: transparent; }
}

/* Секция — мягкая белая карточка с лёгкой тенью, без жирной рамки/серого бара. */
.dossier-section {
    margin-bottom: 16px;
    background: var(--c-snow);
    border: 1px solid var(--c-mist);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-sm);
    overflow: hidden;
}

/* Заголовок секции — редакторский: mono-капс лейбл, тонкая линия снизу. */
.dossier-section-title {
    font-family: var(--ff-mono);
    font-size: 11px;
    font-weight: var(--fw-sb);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 15px 20px 13px;
    background: transparent;
    border-bottom: 1px solid var(--c-mist);
    color: var(--c-smoke);
}

/* Профиль — 2 колонки label/value с воздухом, БЕЗ табличных дивайдеров. */
.dossier-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 28px;
    row-gap: 2px;
    padding: 10px 20px 6px;
    background: transparent;
}

.dossier-field {
    padding: 11px 0;
    background: transparent;
}

.dossier-field-label {
    font-family: var(--ff-mono);
    font-size: 10.5px;
    font-weight: var(--fw-sb);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--c-fog);
    margin-bottom: 5px;
}

.dossier-field-value {
    font-size: 15px;
    line-height: 1.4;
    color: var(--c-ink);
    font-weight: var(--fw-m);
}

/* Контакты — отдельный padded-блок под grid'ом, отступы выровнены с ячейками
   grid (16px), сверху разделитель. Раньше блок был без горизонтального padding'а
   → заголовок «Контакты» прибивался к левому краю секции, не совпадал с grid. */
.dossier-contacts {
    padding: 16px 20px 18px;
    border-top: 1px solid var(--c-mist);
}

.dossier-contact {
    padding: 12px 14px;
    background: var(--c-snow);
    border: 1px solid var(--c-mist);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    margin-bottom: 8px;
    font-size: 14px;
    overflow-wrap: anywhere;
}
.dossier-contact:last-child { margin-bottom: 0; }

.dossier-contact-details {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 4px;
    font-size: 13px;
    color: var(--text-secondary);
    overflow-wrap: anywhere;
}

/* Длинные URL/слова (ссылки из bio, посты) не должны вылазить за границу секции. */
.dossier-field-value,
.dossier-research-block,
.dossier-post { overflow-wrap: anywhere; word-break: break-word; }

.dossier-research-block {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-light);
    font-size: 14px;
    line-height: 1.5;
}

.dossier-research-block:last-child { border-bottom: none; }

.dossier-research-label {
    font-family: var(--ff-mono);
    font-size: 10.5px;
    font-weight: var(--fw-sb);
    color: var(--c-fog);
    margin-bottom: 7px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dossier-icebreaker {
    background: var(--primary-soft);
    border-left: 3px solid var(--primary);
}

.dossier-empty {
    padding: 24px 16px;
    text-align: center;
    color: var(--text-secondary);
    font-size: 14px;
}

/* Collapsible raw data */
.dossier-collapsible .dossier-collapsible-body {
    display: none;
}

.dossier-collapsible.open .dossier-collapsible-body {
    display: block;
}

.dossier-toggle {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    user-select: none;
}@media (hover: hover) {


.dossier-toggle:hover {
    background: var(--bg-sidebar-hover);
}
}

.dossier-chevron {
    transition: transform 0.2s ease;
}

.dossier-collapsible.open .dossier-chevron {
    transform: rotate(180deg);
}

.dossier-post {
    padding: 8px 0;
    border-bottom: 1px solid var(--border-light);
    font-size: 13px;
    line-height: 1.5;
    color: var(--text);
}

.dossier-post:last-child { border-bottom: none; }

.dossier-post-num {
    display: inline-block;
    background: var(--primary-light);
    color: var(--primary);
    font-size: 11px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: var(--r-sm);
    margin-right: 6px;
}

/* Message in dossier */
.dossier-message {
    border-bottom: 1px solid var(--border-light);
    padding: 16px;
}

.dossier-message:last-child { border-bottom: none; }

.dossier-message-header {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 10px;
}

.dossier-message-icebreaker {
    background: var(--primary-soft);
    border-radius: var(--radius-xs);
    padding: 8px 12px;
    font-size: 13px;
    color: var(--primary-dark);
    margin-bottom: 10px;
}

.dossier-msg-textarea {
    width: 100%;
    font-size: 14px;
    line-height: 1.5;
    min-height: 100px;
}

.dossier-message-actions {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    justify-content: flex-end;
}

/* ============================================
   STRATEGY — Hypotheses & AI recommendations
   ============================================ */

.strategy-hypothesis {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-light);
}

.strategy-hypothesis:last-child { border-bottom: none; }

.strategy-hyp-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}

.strategy-hyp-body {
    margin-bottom: 10px;
}

.strategy-hyp-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.badge-priority-high {
    background: var(--danger-bg);
    color: var(--danger);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: var(--r-pill);
}

.badge-priority-medium {
    background: var(--warning-bg);
    color: var(--warning);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: var(--r-pill);
}

/* ============================================
   TEMPLATES
   ============================================ */

.template-item {
    border-bottom: 1px solid var(--border-light);
    padding: 14px 20px;
}

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

.template-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.template-body {
    background: var(--bg);
    border-radius: var(--radius-xs);
    padding: 10px 12px;
}

.badge-priority-low {
    background: var(--info-bg);
    color: var(--primary);
    font-size: 11px;
    padding: 2px 8px;
    border-radius: var(--r-pill);
}

/* ============================================
   SIDEBAR OVERLAY (mobile)
   ============================================ */

.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(21, 23, 26, 0.55);
    z-index: 99;
}


/* #8 — все чекбоксы/радио в фирменном ember-цвете вместо browser-default синего.
   accent-color: iOS 15.4+, Chrome 93+, Firefox 92+. На focus — soft ember-ring. */
input[type="radio"],
input[type="checkbox"] {
    accent-color: var(--c-ember);
}
input[type="radio"]:focus-visible,
input[type="checkbox"]:focus-visible {
    outline: 2px solid var(--c-ember-soft);
    outline-offset: 2px;
}

/* Чекбоксы/радио в попапах — изначальный нативный вид (accent-color ember выше).
   Проработанный кастом-вариант — в работе, раскатываем после согласования. */

/* Тумблер-переключатель — ВСЕ чекбоксы в попапах (.modal-overlay), утверждён Артёмом 2026-06-22.
   Радио (input[type=radio]) НЕ трогаем — остаются нативными. В таблицах (массовый выбор лидов/
   сообщений) и на страницах (Настройки, сравнение кампаний) чекбоксы тоже нативные (вне .modal-overlay). */
.modal-overlay input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 40px;
    height: 23px;
    border-radius: 999px;
    background: var(--c-mist);
    position: relative;
    cursor: pointer;
    flex: 0 0 auto;
    vertical-align: middle;
    transition: background .18s ease;
}
.modal-overlay input[type="checkbox"]::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: 19px;
    height: 19px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 3px rgba(16, 24, 40, .3);
    transition: left .18s ease;
}
.modal-overlay input[type="checkbox"]:checked {
    background: var(--c-ember);
}
.modal-overlay input[type="checkbox"]:checked::after {
    left: 19px;
}

/* ============================================
   UPDATE BANNER — «Доступно обновление» (новый деплой при открытой вкладке)
   ============================================ */
.update-banner {
    position: fixed;
    right: 20px;
    bottom: 20px;
    z-index: 9000;
    display: flex;
    align-items: center;
    gap: 14px;
    max-width: calc(100vw - 40px);
    padding: 14px 16px;
    background: var(--c-ink);
    color: var(--c-snow);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-lg);
    transform: translateY(140%);
    opacity: 0;
    transition: transform 0.35s var(--ease-out, cubic-bezier(0.16,1,0.3,1)), opacity 0.35s ease;
}
.update-banner.show { transform: translateY(0); opacity: 1; }

.update-banner__icon {
    flex: 0 0 auto;
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--r-md);
    background: rgba(255,90,31,0.18);
    color: var(--c-ember);
}
.update-banner__text { min-width: 0; }
.update-banner__title { font-weight: 700; font-size: 15px; line-height: 1.2; }
.update-banner__sub { font-size: 13px; color: rgba(255,255,255,0.6); margin-top: 2px; line-height: 1.3; }

.update-banner__btn {
    flex: 0 0 auto;
    margin-left: 4px;
    padding: 10px 18px;
    background: var(--c-ember);
    color: #fff;
    border: none;
    border-radius: var(--r-pill);
    font-family: inherit;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.15s ease;
}
@media (hover: hover) { .update-banner__btn:hover { background: #e84e16; } }

.update-banner__close {
    flex: 0 0 auto;
    width: 24px; height: 24px;
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.5);
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
}
@media (hover: hover) { .update-banner__close:hover { color: #fff; } }

/* Mobile: баннер на всю ширину снизу; [иконка][текст] в строку, «Обновить» — на всю
   ширину отдельной строкой, крестик — в абсолютном верхнем-правом углу (длинный
   подзаголовок иначе выдавливает крестик за строку). */
@media (max-width: 560px) {
    .update-banner {
        left: 12px; right: 12px; bottom: 12px;
        max-width: none;
        flex-wrap: wrap;
        align-items: flex-start;
        row-gap: 12px;
        padding: 16px;
    }
    .update-banner__icon  { order: 1; }
    .update-banner__text  { order: 2; flex: 1 1 auto; padding-right: 26px; }
    .update-banner__btn   { order: 3; flex: 1 0 100%; margin-left: 0; padding: 12px; text-align: center; }
    .update-banner__close { position: absolute; top: 12px; right: 14px; }
}

@media (max-width: 520px) {
    .update-banner { left: 16px; right: 16px; bottom: 16px; flex-wrap: wrap; }
    .update-banner__text { flex: 1 1 auto; }
    .update-banner__btn { flex: 1 1 100%; margin-left: 0; order: 3; }
}

/* (budget-пилюля удалена 2026-06-25 — AI-долларового лимита больше нет, см. app.js) */
/* Mobile: off-canvas sidebar (HTML/JS уже разведены: hamburger + .sidebar-overlay +
   toggleSidebar → body.sidebar-open). Без этого блока на 375 сайдбар 240px давил контент
   в ~135px. Паттерн перенесён из dashboard-platform. */
@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
        z-index: 200;
        height: 100dvh;
        max-height: 100dvh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
        pointer-events: none;
        visibility: hidden;
        transition: transform .16s ease, visibility 0s linear .16s;
    }
    body.sidebar-open .sidebar {
        transform: translateX(0);
        box-shadow: var(--sh-lg, 0 24px 60px rgba(21,23,26,.18));
        pointer-events: auto;
        visibility: visible;
        transition: transform .16s ease, visibility 0s;
    }
    body.sidebar-open .sidebar-overlay { display: block; }
    .main { margin-left: 0; }
    .hamburger { display: inline-flex; align-items: center; }
    .content { padding: 16px; }

    /* Экран входа: на телефоне — одна колонка (форма), тёмная editorial-сцена скрыта.
       Иначе правая колонка min 520px вылезает за вьюпорт, а overflow:hidden обрезает форму. */
    .login-screen { grid-template-columns: 1fr; }
    .login-stage { display: none; }
    .login-form-pane { padding: 32px 20px; }
    .login-card { width: 100%; flex: 0 1 auto; }  /* flex:0 0 480px не сжимался → overflow на 375px */

    /* Таблицы данных (Лиды/Диалоги/Созвоны — 6-8 колонок) на узком экране скроллим
       горизонтально, а не обрезаем (.table-wrap по умолчанию overflow:hidden). */
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

@media (max-width: 640px) {
    .header { padding: 0 14px; }
    .header-title { font-size: 15px; }
}

/* ?-подсказки на неочевидных полях форм — DS-поповер (hover desktop + focus/tap mobile),
   НЕ нативный title. .hint-q ставится рядом с label, текст в data-tip. */
.hint-q { display:inline-flex; align-items:center; justify-content:center; width:16px; height:16px;
  margin-left:6px; border-radius:50%; background:var(--c-mist,#e6e3dd); color:var(--text-secondary,#777);
  font-size:11px; font-weight:700; cursor:help; position:relative; vertical-align:middle; outline:none;
  user-select:none; flex:0 0 auto; }
.hint-q:hover, .hint-q:focus { background:var(--c-ember,#FF5A1F); color:#fff; }
.hint-q::after { content:attr(data-tip); position:absolute; bottom:calc(100% + 8px); left:0;
  width:max-content; max-width:280px; background:#1d1d1f; color:#fff; font-size:12px; font-weight:400;
  line-height:1.45; padding:8px 11px; border-radius:8px; white-space:normal; text-align:left;
  opacity:0; visibility:hidden; transition:opacity .15s; z-index:1200; pointer-events:none;
  box-shadow:0 8px 24px rgba(0,0,0,.28); }
.hint-q:hover::after, .hint-q:focus::after { opacity:1; visibility:visible; }

/* ICP-форма (структурный целевой профиль) + гейт резолвера — Фаза 1 чистки базы 2026-06-23 */
.icp-form .icp-fields .form-group { margin-bottom: 12px; }
.icp-locked {
    background: var(--c-bad-soft);
    border: 1px solid var(--c-bad);
    color: #9a2020;
    border-radius: var(--r-md);
    padding: 12px 14px;
    font-size: 13px;
    line-height: 1.55;
}
.icp-locked strong { color: #7a1818; }

/* --- Айсбрейкер: режим-карточки (radio-cards) в модалке создания кампании --- */
/* Scoped to .ib-mode-card; used only in js/campaigns.js create-campaign modal. */
.ib-mode-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 4px;
}
.ib-mode-card {
    display: block;
    position: relative;
    cursor: pointer;
    border: 1.5px solid var(--c-mist);
    border-radius: var(--r-md, 12px);
    padding: 12px 14px;
    background: var(--c-snow);
    transition: border-color .15s ease, background .15s ease;
}
.ib-mode-card:hover { border-color: var(--c-ember); }
.ib-mode-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.ib-mode-card.is-active {
    border-color: var(--c-ember);
    background: var(--c-ember-soft);
}
.ib-mode-card__title {
    display: block;
    font-weight: 600;
    font-size: 13px;
    color: var(--c-ink);
}
.ib-mode-card__desc {
    display: block;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 3px;
    line-height: 1.4;
}
@media (max-width: 520px) {
    .ib-mode-cards { grid-template-columns: 1fr; }
}

/* ===== FIX #3 (2026-06-26): скелет блока «Готовность к запуску» в поп-апе кампании ===== */
/* Резервирует место под чек-лист сразу при открытии — убирает «короткий поп-ап → прыжок». */
.ready-skel {
    display: inline-block;
    border-radius: var(--r-sm);
    background: linear-gradient(90deg, var(--c-mist) 25%, #EEF1F4 37%, var(--c-mist) 63%);
    background-size: 400% 100%;
    animation: ready-skel-shimmer 1.4s ease-in-out infinite;
}
.ready-skel--dot  { width: 18px; height: 18px; border-radius: var(--r-pill); flex: 0 0 auto; }
.ready-skel--text { height: 12px; width: 62%; }
.ready-skel--btn  { height: 32px; width: 168px; border-radius: var(--r-md); }
.ready-row .ready-skel--text { width: 58%; }
.ready-row:nth-child(2) .ready-skel--text { width: 70%; }
.ready-row:nth-child(3) .ready-skel--text { width: 64%; }
.ready-row:nth-child(4) .ready-skel--text { width: 50%; }
@keyframes ready-skel-shimmer {
    0%   { background-position: 100% 50%; }
    100% { background-position: 0 50%; }
}
@media (prefers-reduced-motion: reduce) {
    .ready-skel { animation: none; }
}

/* ===== FIX #13 (2026-06-26): фильтр гипотез «Новые/Сохранённые» — приглушённый активный (не оранжевый) ===== */
.hyp-fbtn { background: #fff; border: 1px solid var(--c-mist); color: var(--c-graphite, #6b7280); font-weight: 600; }
.hyp-fbtn:hover { background: var(--c-paper-2); color: var(--c-ink); }
.hyp-fbtn.is-on { background: var(--c-ink); border-color: var(--c-ink); color: var(--c-snow, #fff); }

/* ===== #22 (2026-06-26): глобальный редизайн попапа диалога — чистая иерархия,
   мессенджер-пузыри (ink исходящие / snow входящие), composer, один action «архив».
   Созвон-кнопки убраны (созвон определяется автоматически — см. #23). ===== */
/* ============================================================
   ДИАЛОГИ — попап переписки. Редизайн «мессенджер-лента» (макет Claude Design,
   states S1–S13). Все токены из :root; ember+ink на тёплой бумаге, синего нет.
   Мета — НАД пузырём; пузыри ink(out)/snow(in); действия — абсолютные на пузыре.
   ВЕСЬ .dlg-* консолидирован здесь (правило no_layered_css).
   ============================================================ */

/* --- Мета-строка: бейджи канала / аккаунта / архива (S1, S11) --- */
.dlg-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 18px; }
.dlg-meta__contact { font-size: 13px; color: var(--c-graphite); }
/* Бейджи шапки диалога — вписаны в ember/ink, без чужих фирменных цветов (S11) */
.dlg-meta .badge {
    padding: 4px 12px; border-radius: var(--r-pill);
    font-family: var(--ff-mono); font-size: 11px; font-weight: 500; letter-spacing: .04em;
    line-height: 1.4; text-transform: none;
}
.dlg-meta .badge-telegram { background: var(--c-ember-soft); color: var(--c-ember-deep); }
.dlg-meta .badge-max { background: var(--c-paper-2); color: var(--c-ink-2); }
.dlg-meta .badge-instagram { background: var(--c-good-soft); color: #1B7A3E; }
.dlg-meta .badge-new { background: var(--c-paper-2); color: var(--c-graphite); }

/* --- Лента истории: тёплая канва без жёсткой серой коробки (S1) --- */
.dlg-history {
    height: min(56vh, 460px); overflow-y: auto;
    background: var(--c-paper); border-radius: var(--r-lg);
    padding: 20px 18px; overscroll-behavior: contain;
    display: flex; flex-direction: column; gap: 14px;
}

/* --- Строка сообщения: мета НАД пузырём (S1) --- */
.dlg-msg { display: flex; flex-direction: column; gap: 5px; }
.dlg-msg--out { align-items: flex-end; }
.dlg-msg--in { align-items: flex-start; }
.dlg-msg__meta {
    padding: 0 6px; font-family: var(--ff-body); font-weight: 500;
    font-size: 11px; line-height: 1; color: var(--c-fog);
}
.dlg-msg__when { font-family: var(--ff-mono); font-weight: 500; }
/* «(изменено)» — деликатная приписка в meta (S4) */
.dlg-msg__edited { margin-left: 6px; font-style: italic; font-family: var(--ff-mono); font-size: 10px; color: var(--c-fog); }

/* --- Пузырь (S1) --- */
.dlg-bubble {
    position: relative; max-width: 80%;
    padding: 10px 14px; border-radius: 18px;
    font-size: 14.5px; line-height: 1.45; word-break: break-word;
}
.dlg-msg--out .dlg-bubble { background: var(--c-ink); color: var(--c-snow); border-bottom-right-radius: 6px; }
.dlg-msg--in .dlg-bubble { background: var(--c-snow); color: var(--c-ink); border-bottom-left-radius: 6px; box-shadow: var(--sh-sm); }
.dlg-msg__text { white-space: pre-wrap; word-break: break-word; }
/* Медиа: фото/видео инлайн, файл-чип (S6) */
.dlg-bubble img, .dlg-bubble video { display: block; border-radius: var(--r-md); }

/* --- Action-кнопки над своим пузырём (S2) — абсолютные, fade-in по hover --- */
.dlg-bubble__actions {
    position: absolute; top: -13px; right: 8px;
    display: flex; gap: 4px;
    opacity: 0; pointer-events: none; transform: translateY(2px);
    transition: opacity .14s var(--ease-out), transform .14s var(--ease-out);
    z-index: 3;
}
.dlg-msg--out .dlg-bubble:hover .dlg-bubble__actions,
.dlg-bubble:focus-within .dlg-bubble__actions { opacity: 1; pointer-events: auto; transform: none; }
.dlg-act {
    width: 26px; height: 26px; flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center;
    padding: 0; border-radius: var(--r-sm); cursor: pointer;
    background: var(--c-snow); color: var(--c-smoke); border: 1px solid var(--c-mist);
    box-shadow: var(--sh-sm); transition: background .12s, color .12s, border-color .12s;
}
.dlg-act svg { width: 14px; height: 14px; display: block; }
.dlg-act:hover { background: var(--c-paper-2); color: var(--c-ink); border-color: var(--c-fog); }
.dlg-act:focus-visible { outline: 2px solid var(--c-ink); outline-offset: 1px; }
/* Удалить — деструктив, красный уже в покое-revealed (S2) */
.dlg-act--del { background: var(--c-bad-soft); color: var(--c-bad); border-color: var(--c-bad); }
.dlg-act--del:hover { background: var(--c-bad); color: var(--c-snow); border-color: var(--c-bad); }
.dlg-act:disabled { opacity: .5; cursor: default; pointer-events: none; }
/* «⋯» — раскрывает действия на тач (мобайл); на десктопе скрыта (там hover) */
.dlg-act--more { display: none; font: 700 16px/1 var(--ff-body); }

/* --- Инлайн-редактор в пузыре (S3): тёмный пузырь становится светлым --- */
.dlg-bubble--editing { padding: 10px; min-width: 240px; max-width: 92%; }
.dlg-msg--out .dlg-bubble--editing { background: var(--c-snow); color: var(--c-ink); border: 1px solid var(--c-mist); }
.dlg-edit__ta {
    width: 100%; min-height: 64px; resize: vertical;
    padding: 10px 12px; border: 1px solid var(--c-ember); border-radius: 10px;
    font-size: 14px; line-height: 1.45; color: var(--c-ink); background: var(--c-snow);
    outline: none; box-shadow: 0 0 0 3px rgba(255,90,31,.15);
}
.dlg-edit__actions { display: flex; gap: 8px; justify-content: flex-start; margin-top: 10px; flex-wrap: wrap; }

/* --- Удалённое сообщение (S5): приглушённый системный чип, текст скрыт --- */
.dlg-bubble--deleted {
    display: inline-flex; align-items: center; gap: 9px;
    background: var(--c-paper-2) !important; color: var(--c-smoke) !important;
    border: 1px dashed var(--c-mist) !important; box-shadow: none;
    border-radius: 14px; padding: 9px 13px; max-width: 80%;
}
.dlg-deleted__icon {
    flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center;
    width: 26px; height: 26px; border-radius: 50%; background: var(--c-mist); color: var(--c-smoke);
}
.dlg-deleted__icon svg { width: 14px; height: 14px; display: block; }
.dlg-deleted__body { display: inline-flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.dlg-deleted__note { font-size: 13px; font-style: italic; word-break: break-word; }
.dlg-deleted__date { font-size: 10px; margin-top: 2px; font-family: var(--ff-mono); color: var(--c-fog); }

/* --- Маркер ошибки отправки на пузыре (S7a) --- */
.dlg-msg--out .dlg-bubble--error { border: 1px solid var(--c-bad); box-shadow: 0 0 0 3px var(--c-bad-soft); }
.dlg-msg__error { display: inline-flex; align-items: center; gap: 6px; padding: 0 6px; }
.dlg-msg__error-txt { font: 500 11px var(--ff-mono); color: var(--c-bad); }
.dlg-msg__retry { font: 600 11px var(--ff-mono); color: var(--c-ember-deep); text-decoration: none; cursor: pointer; }

/* --- Загрузка: скелетон-лента (S9) --- */
.dlg-skel { display: flex; flex-direction: column; gap: 16px; }
.dlg-skel__row { display: flex; }
.dlg-skel__row--out { justify-content: flex-end; }
.dlg-skel__row--in { justify-content: flex-start; }
.dlg-skel__b {
    background: linear-gradient(90deg, var(--c-paper-2) 25%, #E3E0D8 37%, var(--c-paper-2) 63%);
    background-size: 340px 100%; animation: dlgShimmer 1.4s linear infinite;
}
.dlg-skel__row--out .dlg-skel__b { border-radius: 18px 18px 6px 18px; }
.dlg-skel__row--in .dlg-skel__b { border-radius: 18px 18px 18px 6px; }
@keyframes dlgShimmer { 0% { background-position: -340px 0; } 100% { background-position: 340px 0; } }

/* --- Пустой диалог / ошибка истории (S10 / S7b) --- */
.dlg-state {
    min-height: 230px; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 12px; padding: 32px; text-align: center;
}
.dlg-state__icon { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 50%; }
.dlg-state__icon svg { width: 24px; height: 24px; }
.dlg-state--empty .dlg-state__icon { background: var(--c-paper-2); color: var(--c-fog); }
.dlg-state--error .dlg-state__icon { background: var(--c-bad-soft); color: var(--c-bad); }
.dlg-state__title { font: 600 16px var(--ff-body); color: var(--c-ink); }
.dlg-state__hint { font: 400 13px var(--ff-body); color: var(--c-smoke); }

/* --- Композер (S8) --- */
.dlg-composer { position: sticky; bottom: 0; background: var(--c-snow); padding-top: 14px; margin-top: 14px; z-index: 2; }
.dlg-composer__input { width: 100%; min-height: 56px; resize: vertical; padding: 12px 16px; border: 1px solid var(--c-mist); border-radius: var(--r-md); font-size: 14px; line-height: 1.5; }
.dlg-composer__input:focus { border-color: var(--c-ember); outline: none; box-shadow: 0 0 0 3px rgba(255,90,31,.15); }
#dlg-file-chip:not(:empty) { margin-top: 8px; }
.dlg-composer__actions { display: flex; justify-content: flex-start; align-items: center; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
/* Кнопки композера/редактора — пилюли (макет) */
.dlg-composer__actions .btn, .dlg-edit__actions .btn { border-radius: var(--r-pill); }
.dlg-composer__sep { flex: 1 1 auto; }
/* «Убрать в архив» прижат вправо, приглушён ghost — не конкурирует с «Отправить» */
.dlg-composer__secondary { color: var(--c-smoke); border-color: var(--c-mist); }
.dlg-composer__secondary:hover { color: var(--c-ink); border-color: var(--c-fog); }
/* Композер в архиве (S8): приглушён + подсказка, отвечать нельзя (одна структура, состояние через класс) */
.dlg-composer--archived .dlg-composer__locked { opacity: .5; pointer-events: none; }
.dlg-composer--archived .dlg-composer__send,
.dlg-composer--archived .dlg-composer__attach,
.dlg-composer--archived .dlg-composer__sep { display: none; }
.dlg-composer--archived #dlg-archive-btn { background: var(--c-ember); border-color: var(--c-ember); color: var(--c-snow); }
.dlg-composer__archhint { display: none; align-items: center; gap: 6px; margin-top: 10px; font: 400 12px var(--ff-body); color: var(--c-smoke); }
.dlg-composer--archived .dlg-composer__archhint { display: inline-flex; }
.dlg-composer__archhint svg { width: 14px; height: 14px; flex: 0 0 auto; }

/* --- Mobile 375 (S13): действия по тапу «⋯» (нет hover), full-width --- */
@media (max-width: 480px) {
    .dlg-history { height: min(60vh, 440px); }
    .dlg-bubble { max-width: 86%; }
    /* тач: кнопки ВНУТРИ пузыря (top-right) — не вылезают за ленту/композер.
       Видна только «⋯»; тап раскрывает edit/delete. */
    .dlg-bubble__actions { position: absolute; top: 5px; right: 6px; transform: none; opacity: 1; pointer-events: auto; }
    .dlg-act--more { display: inline-flex; }
    .dlg-bubble__actions .dlg-act:not(.dlg-act--more) { display: none; }
    .dlg-bubble__actions.is-open .dlg-act--more { display: none; }
    .dlg-bubble__actions.is-open .dlg-act:not(.dlg-act--more) { display: inline-flex; }
    .dlg-bubble--editing { min-width: 0; }
    .dlg-bubble--deleted { max-width: 100%; }
    .dlg-composer__actions { gap: 6px; }
}

/* === SESSION-4 СООБЩЕНИЯ: regen / inline-edit / toast-stack === */

/* --- Sub-табы страницы «Сообщения» --- */
.msg-subtabs { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.msg-subtab { background: #fff; border: 1px solid var(--c-mist); color: var(--c-graphite); font-weight: var(--fw-sb); display: inline-flex; align-items: center; gap: 6px; }
.msg-subtab:hover { background: var(--c-paper-2); color: var(--c-ink); }
.msg-subtab.is-on { background: var(--c-ink); border-color: var(--c-ink); color: var(--c-snow); }
.msg-subtab__badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 18px; height: 18px; padding: 0 5px;
    border-radius: var(--r-pill);
    background: var(--c-ember); color: var(--c-snow);
    font-family: var(--ff-mono); font-size: 11px; font-weight: var(--fw-b); line-height: 1;
}
.msg-subtab.is-on .msg-subtab__badge { background: var(--c-ember); color: var(--c-snow); }

/* --- Тулбар вкладки --- */
.msg-toolbar { margin-bottom: 12px; display: flex; justify-content: space-between; align-items: center; gap: 8px; flex-wrap: wrap; }
.msg-toolbar__all { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; color: var(--c-graphite); }
.msg-toolbar__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.msg-review-count { font-size: 13px; color: var(--c-graphite); }

/* --- Карточка сообщения --- */
.msg-card { margin-bottom: 12px; }
.msg-card__head { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.msg-card__sel { display: flex; align-items: center; gap: 10px; cursor: pointer; min-width: 0; }
.msg-card__name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: var(--ff-display); }
.msg-card__subject { font-weight: 600; margin-bottom: 8px; }
.msg-card__ice { font-size: 13px; color: var(--c-ember-deep); margin-bottom: 8px; word-break: break-word; overflow-wrap: anywhere; }
.msg-card__text { font-size: 14px; white-space: pre-wrap; word-break: break-word; overflow-wrap: anywhere; }
.msg-card__reason {
    font-size: 12.5px; color: var(--c-graphite);
    background: var(--c-paper-2); border-left: 3px solid var(--c-ember);
    border-radius: var(--r-sm); padding: 8px 12px; margin-bottom: 10px;
    word-break: break-word; overflow-wrap: anywhere;
}
/* Ряд действий: ВСЕГДА выровнен по ЛЕВОМУ краю (правило проекта). */
.msg-card__actions {
    padding: 12px 22px; border-top: 1px solid var(--c-mist);
    display: flex; gap: 8px; justify-content: flex-start; flex-wrap: wrap;
}

/* --- Inline edit / regen панели внутри карточки --- */
.msg-edit, .msg-regen {
    padding: 16px 22px; border-top: 1px solid var(--c-mist);
    background: var(--c-paper);
    animation: msgPanelIn .2s var(--ease-out);
}
.msg-edit[hidden], .msg-regen[hidden] { display: none; }
.msg-regen .form-label { margin-bottom: 6px; }
/* Кнопки панелей — по ЛЕВОМУ краю (правило проекта). */
.msg-panel__actions { display: flex; gap: 8px; justify-content: flex-start; margin-top: 12px; flex-wrap: wrap; }
@keyframes msgPanelIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

/* --- Карточка «генерируется…» (pending) --- */
.msg-card--pending { opacity: .96; }
.msg-skeleton { display: flex; align-items: center; gap: 10px; color: var(--c-graphite); font-size: 13.5px; font-weight: var(--fw-sb); margin-bottom: 14px; }
.msg-skeleton__lines { display: flex; flex-direction: column; gap: 9px; }
.msg-skel-line { height: 11px; border-radius: var(--r-pill); background: linear-gradient(90deg, var(--c-paper-2) 0%, var(--c-mist) 50%, var(--c-paper-2) 100%); background-size: 200% 100%; animation: msgSkel 1.3s ease-in-out infinite; }
.msg-skel-line--short { width: 55%; }
@keyframes msgSkel { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* --- Прогресс-тосты перегенерации (расширение toast-стека) --- */
/* toast--closable: место под крестик справа сверху, чтобы текст не залезал на × */
.toast--closable { position: relative; display: flex; align-items: flex-start; gap: 10px; padding-right: 34px; }
.toast__msg { flex: 1 1 auto; min-width: 0; }
.toast__close {
    position: absolute; top: 8px; right: 10px;
    background: transparent; border: none; color: var(--c-fog);
    font-size: 18px; line-height: 1; cursor: pointer; padding: 2px 4px;
    border-radius: var(--r-sm);
}
.toast__close:hover { color: var(--c-snow); }

.toast-progress { display: block; padding-right: 34px; min-width: 280px; }
.toast__title { font-family: var(--ff-display); font-weight: var(--fw-b); font-size: 13.5px; margin-bottom: 9px; display: flex; align-items: center; gap: 8px; word-break: break-word; overflow-wrap: anywhere; padding-right: 4px; }
.toast__bar { height: 6px; background: rgba(255,255,255,0.18); border-radius: var(--r-pill); overflow: hidden; }
.toast__bar-fill { height: 100%; width: 4%; background: var(--c-ember); border-radius: var(--r-pill); transition: width .35s var(--ease-out); }
.toast-success .toast__bar-fill { background: var(--c-good); }
.toast-error .toast__bar-fill { background: var(--c-bad); }
.toast__bar--indet { position: relative; }
.toast__bar--indet .toast__bar-fill { width: 40%; animation: msgToastIndet 1.1s ease-in-out infinite; }
@keyframes msgToastIndet { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }
.toast__sub { font-size: 11px; color: var(--c-fog); margin-top: 7px; font-family: var(--ff-mono); }
.toast__spin {
    width: 13px; height: 13px; flex: 0 0 auto;
    border: 2px solid rgba(255,255,255,0.25); border-top-color: var(--c-snow);
    border-radius: 50%; animation: spin .7s linear infinite;
}

@media (max-width: 480px) {
    /* Тосты не перекрывают весь экран на mobile */
    .toast-container { left: 12px; right: 12px; top: 12px; }
    .toast, .toast-progress { max-width: none; min-width: 0; width: auto; }
    .msg-card__actions, .msg-panel__actions { gap: 6px; }
    .msg-edit, .msg-regen, .msg-card__actions { padding-left: 16px; padding-right: 16px; }
}

/* === /SESSION-4 СООБЩЕНИЯ === */

/* === SESSION-4 ДИАЛОГИ — консолидировано выше (редизайн «мессенджер-лента») === */


/* ============================================================
   SUPPORT WIDGET — FAB + попап поддержки (TG / MAX)
   Изолированная секция, токены Rapport. На всех экранах (login + app).
   ============================================================ */

.support-widget {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 100002;            /* выше модалок (макс. в проекте 100001) */
    font-family: var(--ff-body);
}

/* ---- FAB ---- */
.support-fab {
    position: relative;
    width: 60px;
    height: 60px;
    border-radius: var(--r-pill);
    border: none;
    background: var(--c-ink);
    color: var(--c-snow);
    cursor: pointer;
    display: grid;
    place-items: center;
    box-shadow: 0 10px 24px rgba(21,23,26,0.28), 0 2px 6px rgba(21,23,26,0.18);
    transition: transform var(--dur-2) var(--ease-out),
                box-shadow var(--dur-2) var(--ease-out),
                background var(--dur-1) var(--ease-out);
    -webkit-tap-highlight-color: transparent;
}
.support-fab:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 32px rgba(21,23,26,0.32), 0 3px 8px rgba(21,23,26,0.2);
    background: var(--c-ink-2);
}
.support-fab:active { transform: translateY(-1px); }
.support-fab:focus-visible {
    outline: 2px solid var(--c-ember);
    outline-offset: 3px;
}

/* ember-ободок при наведении — фирменный акцент */
.support-fab::after {
    content: "";
    position: absolute;
    inset: -3px;
    border-radius: inherit;
    border: 2px solid var(--c-ember);
    opacity: 0;
    transform: scale(0.9);
    transition: opacity var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out);
    pointer-events: none;
}
.support-fab:hover::after { opacity: 0.55; transform: scale(1); }

/* Иконки FAB: чат ↔ крестик с кросс-фейдом */
.support-fab__chat,
.support-fab__close {
    position: absolute;
    transition: opacity var(--dur-2) var(--ease-out),
                transform var(--dur-2) var(--ease-out);
}
.support-fab__chat  { opacity: 1; transform: rotate(0deg)  scale(1); }
.support-fab__close { opacity: 0; transform: rotate(-90deg) scale(0.6); }

.support-widget.is-open .support-fab__chat  { opacity: 0; transform: rotate(90deg)  scale(0.6); }
.support-widget.is-open .support-fab__close { opacity: 1; transform: rotate(0deg)   scale(1); }

/* ---- Попап ---- */
.support-popup {
    position: absolute;
    right: 0;
    bottom: 76px;              /* над FAB (60 + 16 зазор) */
    width: 320px;
    max-width: calc(100vw - 32px);
    background: var(--c-snow);
    border: 1px solid var(--c-mist);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-lg);
    padding: 18px 18px 16px;

    transform-origin: bottom right;
    opacity: 0;
    transform: translateY(8px) scale(0.96);
    pointer-events: none;
    transition: opacity var(--dur-2) var(--ease-out),
                transform var(--dur-2) var(--ease-out);
}
.support-widget.is-open .support-popup {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

/* Крестик попапа */
.support-popup__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 28px;
    height: 28px;
    border-radius: var(--r-sm);
    border: none;
    background: transparent;
    color: var(--c-fog);
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.support-popup__close:hover { background: var(--c-paper-2); color: var(--c-ink); }
.support-popup__close:focus-visible { outline: 2px solid var(--c-ink); outline-offset: 2px; }

/* Шапка попапа */
.support-popup__head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-right: 28px;       /* место под крестик */
    margin-bottom: 16px;
}
.support-avatar {
    position: relative;
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
}
.support-avatar img {
    width: 48px;
    height: 48px;
    border-radius: var(--r-pill);
    object-fit: cover;
    display: block;
    background: var(--c-paper-2);
}
.support-avatar__dot {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 13px;
    height: 13px;
    border-radius: var(--r-pill);
    background: var(--c-good);
    border: 2.5px solid var(--c-snow);
    box-shadow: 0 0 0 1px rgba(46,207,111,0.25);
}
.support-popup__heading { min-width: 0; }
.support-popup__title {
    font-family: var(--ff-display);
    font-size: 16px;
    font-weight: 600;
    line-height: 1.2;
    color: var(--c-ink);
    margin: 0 0 3px;
}
.support-popup__subtitle {
    font-size: 12.5px;
    line-height: 1.35;
    color: var(--c-smoke);
    margin: 0;
}

/* Ряды-карточки */
.support-popup__rows {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.support-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 12px;
    border: 1px solid var(--c-mist);
    border-radius: var(--r-md);
    background: var(--c-snow);
    text-decoration: none;
    transition: border-color var(--dur-1) var(--ease-out),
                background var(--dur-1) var(--ease-out),
                transform var(--dur-1) var(--ease-out),
                box-shadow var(--dur-1) var(--ease-out);
}
.support-row:hover {
    border-color: var(--c-ember);
    background: var(--c-ember-soft);
    box-shadow: 0 2px 8px rgba(255,90,31,0.12);
}
.support-row:active { transform: scale(0.99); }
.support-row:focus-visible { outline: 2px solid var(--c-ink); outline-offset: 2px; }

.support-row__icon {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    border-radius: var(--r-sm);
    display: grid;
    place-items: center;
}
.support-row__icon--tg  { background: #E7F2FB; color: #2AABEE; }
.support-row__icon--max { background: var(--c-ink); color: var(--c-snow); }

.support-row:hover .support-row__icon--tg  { background: #DCEEFB; }
.support-row:hover .support-row__icon--max { background: var(--c-ink-2); }

.support-row__text {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.support-row__name {
    font-size: 14px;
    font-weight: 600;
    color: var(--c-ink);
    line-height: 1.25;
}
.support-row__sub {
    font-size: 12px;
    color: var(--c-smoke);
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.support-row__chev {
    flex: 0 0 auto;
    color: var(--c-fog);
    transition: transform var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.support-row:hover .support-row__chev {
    color: var(--c-ember);
    transform: translateX(2px);
}

/* Приписка */
.support-popup__note {
    margin: 14px 0 0;
    padding-top: 13px;
    border-top: 1px solid var(--c-mist);
    font-size: 11.5px;
    line-height: 1.45;
    color: var(--c-smoke);
}

/* ---- Mobile ---- */
@media (max-width: 480px) {
    .support-widget {
        right: 16px;
        bottom: 16px;
    }
    .support-fab {
        width: 56px;
        height: 56px;
    }
    .support-popup {
        width: calc(100vw - 32px);
        bottom: 72px;
        padding: 16px 16px 14px;
    }
}

/* Уважение к prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .support-fab,
    .support-fab__chat,
    .support-fab__close,
    .support-popup,
    .support-row,
    .support-row__chev,
    .support-fab::after {
        transition: opacity var(--dur-1) linear !important;
    }
}

/* === /SUPPORT WIDGET === */

