/* QTL Journal v2 — Kaspi-style Mini App */

:root {
    --bg: var(--tg-theme-bg-color, #f5f5f5);
    --text: var(--tg-theme-text-color, #202124);
    --hint: var(--tg-theme-hint-color, #5f6368);
    --link: var(--tg-theme-link-color, #1a73e8);
    --btn: var(--tg-theme-button-color, #1a73e8);
    --btn-text: var(--tg-theme-button-text-color, #ffffff);
    --card: var(--tg-theme-section-bg-color, #ffffff);
    --card-alt: var(--tg-theme-secondary-bg-color, #f0f0f0);
    --subtitle: var(--tg-theme-subtitle-text-color, #5f6368);
    --danger: var(--tg-theme-destructive-text-color, #d93025);
    --success: #188038;
    --warn: #f59e0b;
    --text-sec: var(--tg-theme-subtitle-text-color, #444);
    --radius: 12px;
    --radius-sm: 8px;
    --nav-h: 56px;
}

* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html {
    overflow: hidden;
    height: 100%;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro', 'Segoe UI', Roboto, sans-serif;
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    line-height: 1.45;
    padding-bottom: calc(var(--nav-h) + 12px);
    -webkit-font-smoothing: antialiased;
    height: 100%;
    overflow-y: auto;
    overscroll-behavior: none;
    -webkit-overflow-scrolling: touch;
}

/* -- Lucide icons ---------------------------------------------------------- */
[data-lucide] { display: inline-block; vertical-align: middle; }
.ic { width: 16px; height: 16px; stroke-width: 2; }

/* -- Виджет-счётчик -------------------------------------------------------- */
.widget {
    display: flex;
    gap: 8px;
    padding: 0;
}
.widget:empty { display: none; }
.widget-item {
    flex: 1;
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius-sm);
    padding: 10px 8px;
    text-align: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.widget-num {
    font-size: 20px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.widget-label {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 2px;
}
.widget-warn .widget-num { color: var(--danger); }

/* -- Нижняя навигация ------------------------------------------------------ */
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: var(--nav-h);
    background: var(--card);
    display: flex;
    border-top: 1px solid var(--card-alt);
    z-index: 100;
    padding-bottom: env(safe-area-inset-bottom, 0);
}
.nav-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    background: none;
    border: none;
    color: var(--text-sec);
    font-size: 11px;
    font-family: inherit;
    cursor: pointer;
    transition: color 0.15s;
}
.nav-item [data-lucide] { width: 22px; height: 22px; stroke-width: 1.8; }
.nav-item.active { color: var(--btn); }
.nav-item:active { opacity: 0.7; }

/* -- Контент --------------------------------------------------------------- */
.content-wrapper {
    position: relative;
    overflow: hidden;
}
.content {
    padding: 0 0 8px;
}
.content-incoming {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}

/* Карусель — анимация завершения свайпа */
.content-wrapper.snapping .content,
.content-wrapper.snapping .content-incoming {
    transition: transform 0.3s ease;
}

/* -- Под-вкладки (Активные | Завершённые | Архив) -------------------------- */
.sub-tabs {
    display: flex;
    gap: 6px;
    padding: 8px 16px;
    overflow-x: auto;
}
.sub-tabs::-webkit-scrollbar { display: none; }
.sub-tab {
    padding: 6px 14px;
    border-radius: 20px;
    background: var(--card);
    color: var(--text);
    font-size: 13px;
    white-space: nowrap;
    border: none;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s;
}
.sub-tab.active {
    background: var(--btn);
    color: var(--btn-text);
}

/* -- Карточки -------------------------------------------------------------- */
.cards { padding: 0 12px; }

.card {
    /* Telegram-специфичный secondary bg — автоматически контрастирует
       с основным фоном и на светлой, и на тёмной теме. Фолбэк var(--card). */
    background: var(--tg-theme-secondary-bg-color, var(--card));
    border-radius: var(--radius);
    padding: 10px 12px;
    margin-bottom: 6px;
    cursor: pointer;
    transition: transform 0.1s;
    position: relative;
    overflow: hidden;
    /* Полный полупрозрачный бордер — виден на любой теме.
       rgba серый с прозрачностью 0.18 работает универсально. */
    border: 1px solid rgba(128, 128, 128, 0.18);
    border-left: 3px solid rgba(128, 128, 128, 0.18);
    /* Двухслойная тень для объёма на светлой теме + читаемость на тёмной */
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08),
                0 1px 3px rgba(0, 0, 0, 0.12);
}
.card:active { transform: scale(0.98); }
.card-active-border    { border-left-color: var(--btn); }
.card-hot-border       { border-left-color: var(--danger); }
.card-won-border       { border-left-color: var(--success); }
.card-lost-border      { border-left-color: var(--danger); }
.card-submitted-border { border-left-color: #ea580c; }
.card-skipped-border   { border-left-color: var(--hint); }

.card-title {
    font-weight: 600;
    font-size: 13px;
    line-height: 1.25;
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.card-lot-num { font-weight: 400; font-size: 11px; color: var(--hint); }
.card-row-dim { color: var(--hint); }

/* Шапка компактной карточки — название + индикаторы + бейдж в одной flex-строке.
   flex-start alignment чтобы title (2 строки) и badge (1 строка) не прыгали. */
.card-head-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 4px;
}
/* Индикаторы (расчёт / задачи) — мелкие иконки рядом с бейджем справа вверху */
.card-indicators {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    margin-right: 2px;
}
.card-indicators .card-calc-icon,
.card-indicators .card-task-icon {
    margin: 0;
    opacity: 0.9;
}

/* Primary-строка: сумма + таймер на одной линии.
   На узких экранах таймер переносится под сумму (flex-wrap). */
.card-primary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px 10px;
    margin-bottom: 4px;
}
.card-primary-row .card-amount { margin-bottom: 0; }
.card-timer-inline { display: inline-flex; align-items: center; flex-shrink: 0; }

/* Meta-строка: №объявление · метод · организатор.
   Жёстко в одну строку. Обрезается через text-overflow: ellipsis. */
.card-meta-row {
    font-size: 11px;
    color: var(--text-sec);
    line-height: 1.4;
    margin-bottom: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.card-meta-announce { font-weight: 500; color: var(--text); }
.card-meta-org { /* внутри card-meta-row который сам ellipsis — просто inline */ }

/* Цветной префикс статуса в таймере (перед датой/дедлайном) */
.card-timer-status { font-weight: 600; }
.card-timer-status.ps-danger  { color: var(--danger, #d14343); }
.card-timer-status.ps-warning { color: var(--warning, #e07b00); }
.card-timer-status.ps-success { color: var(--success, #0f9d58); }
.card-timer-status.ps-neutral { color: var(--text-sec); }

/* Card-timer-done получает цвет через ps-* класс — переопределяем default серый */
.card-timer-done.ps-danger  { color: var(--danger, #d14343); }
.card-timer-done.ps-warning { color: var(--warning, #e07b00); }
.card-timer-done.ps-success { color: var(--success, #0f9d58); }

/* Статус портала в скобках — цветовая разметка для сканирования */
.card-portal-status { font-weight: 500; }
.card-portal-status.ps-danger  { color: var(--danger, #d14343); }
.card-portal-status.ps-warning { color: var(--warning, #e07b00); }
.card-portal-status.ps-success { color: var(--success, #0f9d58); }
.card-portal-status.ps-neutral { color: var(--hint); }

.card-amount {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 14px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    margin-bottom: 4px;
}
.card-amount [data-lucide] { width: 13px; height: 13px; color: var(--success); flex-shrink: 0; }

.card-row {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    color: var(--text);
    margin-bottom: 3px;
    line-height: 1.4;
}
.card-row [data-lucide] { width: 13px; height: 13px; flex-shrink: 0; margin-top: 1px; }

.card-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.5;
}
/* WCAG AA (4.5:1+) — затемнённые тексты и усиленные фоны.
   Цвет бейджа совпадает с цветом левого бордера карточки (визуальная связь). */
.badge-hot           { background: rgba(220,38,38,0.15);  color: #991b1b; }
.badge-warn          { background: rgba(37,99,235,0.15);  color: #1e40af; }
/* added/participating → одинаковый синий «В работе» */
.badge-active        { background: rgba(37,99,235,0.15);  color: #1e40af; }
.badge-participating { background: rgba(37,99,235,0.15);  color: #1e40af; }
/* submitted → оранжевый (согласовано с бордером #ea580c) */
.badge-submitted     { background: rgba(234,88,12,0.15);  color: #9a3412; }
.badge-won           { background: rgba(4,120,87,0.2);    color: #064e3b; font-weight: 700; }
.badge-lost          { background: rgba(185,28,28,0.15);  color: #7f1d1d; }
.badge-skipped       { background: rgba(107,114,128,0.18); color: #4b5563; }

/* Тёмная тема — светлый текст + более яркий фон для контраста */
@media (prefers-color-scheme: dark) {
    .badge-warn         { background: rgba(96,165,250,0.25);  color: #93c5fd; }
    .badge-active       { background: rgba(96,165,250,0.25);  color: #93c5fd; }
    .badge-participating{ background: rgba(96,165,250,0.25);  color: #93c5fd; }
    .badge-submitted    { background: rgba(251,146,60,0.25);  color: #fdba74; }
    .badge-won          { background: rgba(52,211,153,0.3);   color: #a7f3d0; }
    .badge-lost         { background: rgba(248,113,113,0.22); color: #fca5a5; }
    .badge-skipped      { background: rgba(148,163,184,0.22); color: #cbd5e1; }
    .badge-hot          { background: rgba(248,113,113,0.25); color: #fca5a5; }
}

.card-timer {
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    color: var(--text);
}
/* Legacy — оставлено для старого кода. Новый — card-timer-red/yellow. */
.card-timer-hot {
    color: var(--danger);
    font-weight: 600;
    animation: pulse-red 1.4s ease-in-out infinite;
}
.card-timer-red {
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    color: var(--danger);
    font-weight: 700;
    animation: pulse-red 1.4s ease-in-out infinite;
}
.card-timer-yellow {
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    color: #b45309;
    font-weight: 600;
    animation: pulse-yellow 1.8s ease-in-out infinite;
}
.card-timer-expired {
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    color: var(--text-sec);
    font-weight: 500;
}
.card-timer-done {
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    color: var(--text-sec);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
@keyframes pulse-red { 0%,100% { opacity: 1; } 50% { opacity: 0.45; } }
@keyframes pulse-yellow { 0%,100% { opacity: 1; } 50% { opacity: 0.55; } }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }

.card-source {
    position: absolute;
    top: 10px;
    right: 12px;
    font-size: 10px;
    color: var(--text-sec);
}

/* Описание лота */
.card-desc {
    font-size: 11px;
    color: var(--text-sec);
    line-height: 1.3;
    margin-bottom: 6px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

/* Нижняя строка: задачи слева, В архив справа */
.card-bottom-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-top: 4px;
}
/* Группа иконок (калькулятор + лампочка) прижата влево, архив остаётся справа */
.card-icons-left {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-right: auto;
}
.card-bottom-row .card-task-icon,
.card-bottom-row .card-calc-icon { margin: 0; }

.card-archive {
    padding: 4px 10px;
    border-radius: 12px;
    background: var(--card-alt);
    color: var(--text);
    border: 1px solid var(--hint);
    font-size: 11px;
    font-family: inherit;
    cursor: pointer;
    transition: opacity 0.15s;
}
.card-archive:active { opacity: 1; color: var(--danger); }

.card-restore {
    padding: 4px 10px;
    border-radius: 12px;
    background: rgba(16,185,129,0.12);
    color: var(--success);
    border: none;
    font-size: 11px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
}
.card-restore:active { opacity: 0.7; }

/* Индикатор задач — стиль Google Tasks */
.card-task-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #f59e0b;
    opacity: 0.85;
}
.card-task-icon [data-lucide] { width: 16px; height: 16px; }
.card-calc-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--btn);
    opacity: 0.85;
    margin-left: 4px;
}
.card-calc-icon [data-lucide] { width: 16px; height: 16px; }
.card-bottom-row .card-calc-icon { margin-right: 0; }

/* Бейдж статуса — нажимается */
.card-badge-tap { cursor: pointer; }
.card-badge-tap:active { opacity: 0.7; }

/* Попап выбора статуса */
.status-picker {
    background: var(--card);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.18);
    padding: 4px;
    min-width: 150px;
    animation: picker-in 0.15s ease;
}
@keyframes picker-in { from { opacity: 0; transform: scale(0.95) translateY(-4px); } to { opacity: 1; transform: none; } }
.status-picker-item {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 10px 12px;
    border: none;
    background: none;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    cursor: pointer;
    border-radius: 8px;
}
.status-picker-item:active { background: var(--card-alt); }
.status-picker-item.active { background: var(--card-alt); color: var(--btn); font-weight: 600; }

/* Разделитель между статусами и действиями (В архив / Вернуть) */
.status-picker-sep {
    height: 1px;
    background: rgba(128, 128, 128, 0.2);
    margin: 4px 8px;
}
/* В архив — красноватый акцент, чтобы визуально отличать от смены статуса */
.status-picker-item.status-picker-archive {
    color: var(--danger);
}
.status-picker-item.status-picker-archive:active {
    background: rgba(220, 38, 38, 0.08);
}
/* Вернуть из архива — акцентный синий (позитивное действие) */
.status-picker-item.status-picker-restore {
    color: var(--btn);
    font-weight: 500;
}
.status-picker-item.status-picker-restore:active {
    background: rgba(37, 99, 235, 0.08);
}

/* Кнопка сортировки в sub-tabs */
.sort-btn {
    margin-left: auto;
    padding: 6px 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* -- Статус-иконки --------------------------------------------------------- */
.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}
.dot-active { background: var(--btn); }
.dot-won { background: var(--success); }
.dot-lost { background: var(--danger); }
.dot-done { background: var(--hint); }

/* -- FAB ------------------------------------------------------------------- */
.fab {
    position: fixed;
    bottom: calc(var(--nav-h) + 16px);
    left: 16px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    z-index: 50;
    display: none;  /* по умолчанию скрыт; показывается только на табе Лоты */
    align-items: center;
    justify-content: center;
}
body.tab-lots .fab { display: flex; }
.fab [data-lucide] { width: 18px; height: 18px; stroke-width: 2.5; }
.fab:active { transform: scale(0.92); }

/* -- Проверка контрагента -------------------------------------------------- */
.check-screen { padding: 16px; }

.search-box {
    position: relative;
    margin-bottom: 16px;
}
.search-input {
    width: 100%;
    padding: 14px 16px 14px 44px;
    border-radius: var(--radius);
    border: 1.5px solid var(--hint);
    background: var(--card);
    filter: brightness(1.15);
    color: var(--text);
    font-size: 16px;
    font-family: inherit;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.search-input:focus { outline: none; border-color: var(--btn); }
.search-input::placeholder { color: var(--hint); }
.search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--hint);
}
.search-icon [data-lucide] { width: 20px; height: 20px; }

.recent-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.recent-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.recent-item:active { opacity: 0.7; }
.recent-item [data-lucide] { width: 20px; height: 20px; color: var(--text-sec); flex-shrink: 0; }
.recent-name { font-size: 14px; font-weight: 500; }
.recent-bin { font-size: 12px; color: var(--text-sec); }
.recent-more {
    padding: 10px;
    text-align: center;
    font-size: 13px;
    color: var(--link);
    cursor: pointer;
    border-radius: var(--radius);
}
.recent-more:active { background: var(--card-alt); }

/* -- Карточка проверки (результат) ----------------------------------------- */
.profile-card {
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15), 0 0 1px rgba(0,0,0,0.2);
}
.profile-name {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 4px;
}
.profile-type {
    font-size: 12px;
    color: var(--text-sec);
    margin-bottom: 12px;
}
.profile-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 13px;
    border-bottom: 1px solid var(--card-alt);
}
.profile-row:last-child { border-bottom: none; }
.profile-label { color: var(--text-sec); }
.profile-value { font-weight: 500; text-align: right; }

.stats-row {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
}
.stat-box {
    flex: 1;
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius-sm);
    padding: 12px;
    text-align: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.stat-num {
    font-size: 18px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.stat-label {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 2px;
}
.stat-danger .stat-num { color: var(--danger); }
.stat-success .stat-num { color: var(--success); }

.alert-box {
    background: var(--card);
    filter: brightness(1.15);
    border-left: 3px solid var(--danger);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    margin-bottom: 8px;
    font-size: 13px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.alert-box-title {
    font-weight: 600;
    color: var(--danger);
    margin-bottom: 4px;
}

.contract-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.contract-item:active { opacity: 0.7; }
.contract-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.contract-info { flex: 1; min-width: 0; }
.contract-name {
    font-size: 13px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.contract-meta { font-size: 11px; color: var(--text-sec); }
.contract-amount { font-size: 13px; font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; }
.contract-link {
    font-size: 12px;
    color: var(--link);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

/* -- Компания -------------------------------------------------------------- */
.company-screen { padding: 16px; }

/* === Company v2 === */
.company-screen-v2 { padding: 12px 16px 80px; }

/* === КАБИНЕТ v3 (Free + Pro) === */
.cabinet-screen { padding: 12px 16px 80px; }

/* Hero */
.cabinet-hero {
    position: relative;
    background: linear-gradient(135deg, #1a73e8 0%, #4285f4 50%, #6366f1 100%);
    color: #ffffff;
    border-radius: 18px;
    padding: 22px 18px 20px;
    margin-bottom: 16px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(26,115,232,0.25);
}
.cabinet-hero-bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 100% 0%, rgba(255,255,255,0.18), transparent 50%),
        radial-gradient(circle at 0% 100%, rgba(99,102,241,0.4), transparent 50%);
    pointer-events: none;
}
.cabinet-hero-content { position: relative; z-index: 1; }
.cabinet-hero-greeting {
    font-size: 13px;
    opacity: 0.85;
    margin-bottom: 4px;
    font-weight: 500;
}
.cabinet-hero-title {
    font-size: 20px;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 6px;
    word-break: break-word;
}
.cabinet-hero-meta {
    font-size: 12px;
    opacity: 0.85;
    font-variant-numeric: tabular-nums;
}
.cabinet-hero-chip {
    display: inline-block;
    font-size: 7px;
    font-weight: 800;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 6px;
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);
    color: #fff;
    margin-bottom: 4px;
    align-self: flex-start;
    line-height: 1.2;
    box-shadow: 0 1px 4px rgba(99,102,241,0.4);
}
.cabinet-hero-epigraph {
    margin-top: 8px;
}
.cabinet-hero-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.3) 50%, transparent 100%);
    margin: 0 0 6px 0;
}
.cabinet-hero-quote {
    font-size: 11px;
    line-height: 1.35;
    font-style: italic;
    opacity: 0.85;
    font-weight: 400;
}
@media (prefers-color-scheme: dark) {
    .cabinet-hero {
        background: linear-gradient(135deg, #1e3a8a 0%, #1e40af 50%, #3730a3 100%);
        box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    }
}

/* Section */
.cab-section {
    background: var(--card);
    border-radius: 14px;
    padding: 14px 14px;
    margin-bottom: 12px;
    border: 1px solid var(--border, rgba(0,0,0,0.06));
}
.cab-section-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Stat cards (Моя неделя) */
.cab-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.cab-stats-grid-3 { grid-template-columns: 1fr 1fr 1fr; gap: 6px; }
.cab-stats-grid-3 .cab-stat-card { padding: 10px 8px; }
.cab-stats-grid-3 .cab-stat-value { font-size: 19px; }
.cab-stats-grid-3 .cab-stat-label { font-size: 10px; }
.cab-stat-card {
    background: var(--card-alt);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 10px;
    padding: 12px;
    text-align: left;
    transition: background 0.15s;
    position: relative;
}
.cab-stat-badge {
    position: absolute;
    top: 4px;
    right: 6px;
    font-size: 8px;
    color: var(--text-sec);
    opacity: 0.6;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.cab-stat-icon {
    color: var(--btn);
    margin-bottom: 6px;
}
.cab-stat-icon [data-lucide] { width: 18px; height: 18px; }
.cab-stat-value {
    font-size: 22px;
    font-weight: 800;
    color: var(--text);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.cab-stat-label {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 4px;
}

/* Task rows */
.cab-task-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    cursor: pointer;
    border-bottom: 1px solid var(--card-alt);
}
.cab-task-row:last-child { border-bottom: none; }
.cab-task-row:active { opacity: 0.7; }
.cab-task-icon {
    color: var(--btn);
    flex-shrink: 0;
    margin-top: 2px;
}
.cab-task-overdue .cab-task-icon { color: var(--danger); }
.cab-task-overdue .cab-task-title { color: var(--danger); }
.cab-task-body { flex: 1; min-width: 0; }
.cab-task-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.35;
    word-break: break-word;
}
.cab-task-meta {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 2px;
    word-break: break-word;
}

/* Recent lots */
.cab-recent-row {
    padding: 10px 0;
    cursor: pointer;
    border-bottom: 1px solid var(--card-alt);
}
.cab-recent-row:last-child { border-bottom: none; }
.cab-recent-row:active { opacity: 0.7; }
.cab-recent-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.35;
    word-break: break-word;
    margin-bottom: 2px;
}
.cab-recent-meta {
    font-size: 11px;
    color: var(--text-sec);
    font-variant-numeric: tabular-nums;
}

/* Task lot meta (название лота под задачей) */
.cab-task-lot {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 3px;
    display: flex;
    align-items: center;
    gap: 4px;
    word-break: break-word;
}
.cab-task-lot [data-lucide] { width: 11px; height: 11px; flex-shrink: 0; }

/* Show more button */
.cab-show-more {
    text-align: center;
    padding: 10px;
    margin-top: 6px;
    font-size: 12px;
    color: var(--btn);
    cursor: pointer;
    border-top: 1px solid var(--card-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}
.cab-show-more:active { opacity: 0.6; }

/* News rows */
.cab-news-row {
    padding: 10px 0;
    cursor: pointer;
    border-bottom: 1px solid var(--card-alt);
}
.cab-news-row:last-child { border-bottom: none; }
.cab-news-row:active { opacity: 0.7; }
.cab-news-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--text);
    line-height: 1.4;
    margin-bottom: 3px;
}
.cab-news-meta {
    font-size: 11px;
    color: var(--text-sec);
}

/* Pro benefits page */
.pro-benefits { padding: 4px 4px 20px; }
.pro-benefits-hero {
    text-align: center;
    padding: 20px 16px 24px;
    background: linear-gradient(135deg, rgba(168,85,247,0.10), rgba(99,102,241,0.10));
    border-radius: 14px;
    margin-bottom: 16px;
}
.pro-benefits-icon { color: #a855f7; margin-bottom: 8px; display: inline-block; }
.pro-benefits-icon [data-lucide] { width: 32px; height: 32px; }
.pro-benefits-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 6px;
}
.pro-benefits-sub {
    font-size: 13px;
    color: var(--text-sec);
    line-height: 1.4;
}
.pro-benefits-list { display: flex; flex-direction: column; gap: 12px; }
.pro-benefits-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 12px;
    background: var(--card-alt);
    border-radius: 10px;
}
.pro-benefits-item-icon { color: #a855f7; flex-shrink: 0; margin-top: 2px; }
.pro-benefits-item-icon [data-lucide] { width: 20px; height: 20px; }
.pro-benefits-item-body { flex: 1; min-width: 0; }
.pro-benefits-item-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
}
.pro-benefits-item-desc {
    font-size: 12px;
    color: var(--text-sec);
    line-height: 1.4;
}
.pro-benefits-soon {
    display: inline-block;
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 6px;
    border-radius: 6px;
    background: rgba(168,85,247,0.15);
    color: #a855f7;
    margin-left: 6px;
    vertical-align: middle;
}
.pro-benefits-item-soon .pro-benefits-item-icon { opacity: 0.55; }
.pro-benefits-item-soon .pro-benefits-item-title { opacity: 0.85; }
.pro-benefits-item-soon .pro-benefits-item-desc { opacity: 0.7; }

.pro-benefits-about {
    margin-top: 24px;
    padding: 16px 14px;
    background: var(--card-alt);
    border-radius: 12px;
}
.pro-benefits-about-title {
    font-size: 15px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 10px;
}
.pro-benefits-about p {
    font-size: 13px;
    color: var(--text-sec);
    line-height: 1.5;
    margin: 0 0 10px;
}
.pro-benefits-about p:last-child { margin-bottom: 0; }
.pro-benefits-about a {
    color: var(--btn);
    text-decoration: underline;
}
@media (prefers-color-scheme: dark) {
    .pro-benefits-soon {
        background: rgba(168,85,247,0.22);
        color: #c4b5fd;
    }
}

/* News article overlay */
.news-article { padding: 4px 4px 24px; }
.news-article-loading {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-sec);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.news-article-img {
    width: 100%;
    border-radius: 12px;
    margin-bottom: 14px;
    display: block;
}
.news-article-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--text);
    line-height: 1.3;
    margin-bottom: 8px;
}
.news-article-meta {
    font-size: 12px;
    color: var(--text-sec);
    margin-bottom: 16px;
}
.news-article-body p {
    font-size: 15px;
    color: var(--text);
    line-height: 1.55;
    margin: 0 0 12px;
}

/* News placeholder */
.cab-news-placeholder {
    font-size: 12px;
    color: var(--text-sec);
    padding: 10px 12px;
    background: var(--card-alt);
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Pro badge — ненавязчивый */
.cab-pro-badge {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.06));
    border-radius: 16px;
    padding: 16px 14px;
    margin-top: 16px;
    cursor: pointer;
    position: relative;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.cab-pro-badge-icon {
    color: #7c3aed;
    flex-shrink: 0;
    background: rgba(168,85,247,0.15);
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cab-pro-badge-text { flex: 1; min-width: 0; padding-right: 24px; }
.cab-pro-badge-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
}
.cab-pro-badge-desc {
    font-size: 11px;
    color: var(--text-sec);
    line-height: 1.4;
}
.cab-pro-badge-close {
    position: absolute;
    top: 8px;
    right: 8px;
    background: transparent;
    border: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    color: var(--text-sec);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.cab-pro-badge-close:active { background: var(--card-alt); }
@media (prefers-color-scheme: dark) {
    .cab-pro-badge {
        background: linear-gradient(135deg, rgba(168,85,247,0.12), rgba(99,102,241,0.12));
        border-color: rgba(168,85,247,0.3);
    }
}

/* Hero блок — приветствие + прогресс профиля */
.comp-hero {
    background: linear-gradient(135deg, var(--btn), #3b82f6);
    color: var(--btn-text);
    border-radius: 16px;
    padding: 18px 16px;
    margin-bottom: 16px;
    box-shadow: 0 6px 16px rgba(26,115,232,0.20);
    overflow: hidden;
    position: relative;
}
.comp-hero::before {
    content: "";
    position: absolute;
    right: -30px;
    top: -30px;
    width: 140px;
    height: 140px;
    background: radial-gradient(circle, rgba(255,255,255,0.18), transparent 70%);
    pointer-events: none;
}
.comp-hero-inner { position: relative; z-index: 1; }
.comp-hero-name {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 4px;
    word-break: break-word;
}
.comp-hero-name .text-hint { color: rgba(255,255,255,0.8); font-weight: 500; }
.comp-hero-meta {
    font-size: 12px;
    opacity: 0.9;
    font-variant-numeric: tabular-nums;
    margin-bottom: 10px;
}
.comp-hero-progress {
    height: 4px;
    background: rgba(255,255,255,0.25);
    border-radius: 2px;
    margin-top: 10px;
    overflow: hidden;
}
.comp-hero-progress-bar {
    height: 100%;
    background: #ffffff;
    border-radius: 2px;
    transition: width 0.3s ease;
}
.comp-hero-progress-label {
    font-size: 11px;
    opacity: 0.95;
    margin-top: 6px;
}
.comp-hero-progress-label a {
    color: #ffffff;
    font-weight: 600;
    text-decoration: underline;
    cursor: pointer;
}
.comp-hero-actions {
    margin-top: 6px;
}
.btn-ghost {
    background: rgba(255,255,255,0.2);
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.4);
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-family: inherit;
}
.btn-ghost:active { opacity: 0.85; }

/* Тёмная ghost-кнопка для форм (например, поиск по БИН) */
.btn-ghost-dark {
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    padding: 0 14px;
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    min-width: 44px;
    font-family: inherit;
}
.btn-ghost-dark:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-ghost-dark:active { opacity: 0.85; }
.btn-ghost-dark [data-lucide] { width: 16px; height: 16px; }

/* Segmented mini (договоры / заявки) */
.segmented-mini {
    display: flex;
    gap: 4px;
    background: var(--card-alt);
    padding: 3px;
    border-radius: 8px;
    margin-bottom: 12px;
}
.seg-mini {
    flex: 1;
    background: transparent;
    border: none;
    padding: 7px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-sec);
    cursor: pointer;
    font-family: inherit;
}
.seg-mini.active {
    background: var(--card);
    color: var(--text);
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

/* Карточка истории */
.hist-card {
    background: var(--card);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 8px;
    cursor: pointer;
    border: 1px solid var(--border, rgba(0,0,0,0.06));
    transition: background 0.15s;
}
.hist-card:active { background: var(--card-alt); }
.hist-card-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.35;
    margin-bottom: 4px;
    word-break: break-word;
}
.hist-card-amount {
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
    font-variant-numeric: tabular-nums;
    margin-bottom: 6px;
}
.hist-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    color: var(--text-sec);
}
.hist-card-customer {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.hist-status {
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 600;
    background: var(--card-alt);
    color: var(--text-sec);
}
.hist-status-done { background: rgba(34,197,94,0.15); color: #15803d; }
.hist-status-active { background: rgba(26,115,232,0.15); color: var(--btn); }
.hist-status-canceled { background: rgba(220,38,38,0.15); color: #991b1b; }
.hist-badge {
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 10px;
    font-weight: 600;
    background: var(--card-alt);
    color: var(--text-sec);
}
.hist-badge-win { background: rgba(34,197,94,0.15); color: #15803d; }

/* Tiles документов */
.docs-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.doc-tile {
    background: var(--card);
    border-radius: 14px;
    padding: 16px 12px;
    text-align: center;
    cursor: pointer;
    border: 1px solid var(--border, rgba(0,0,0,0.06));
    transition: transform 0.15s, box-shadow 0.15s;
}
.doc-tile:active {
    transform: scale(0.97);
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.doc-tile-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}
.doc-tile-icon [data-lucide] { width: 28px; height: 28px; }
.doc-icon-zkp { background: rgba(26,115,232,0.12); color: var(--btn); }
.doc-icon-kp { background: rgba(34,197,94,0.12); color: #15803d; }
.doc-icon-req { background: rgba(168,85,247,0.12); color: #7e22ce; }
.doc-icon-complaint { background: rgba(249,115,22,0.12); color: #c2410c; }
.doc-tile-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
}
.doc-tile-desc {
    font-size: 11px;
    color: var(--text-sec);
    line-height: 1.3;
}

/* Элементы выбора лота в ЗКП */
.zkp-lot-item {
    background: var(--card);
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 8px;
    cursor: pointer;
    border: 1px solid var(--border, rgba(0,0,0,0.06));
}
.zkp-lot-item:active { background: var(--card-alt); }
.zkp-lot-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}
.zkp-lot-meta {
    font-size: 11px;
    color: var(--text-sec);
}

/* Для настройки профиля компании в "Ещё" */
.profile-lang-fields { animation: fadeIn 0.2s ease; }
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@media (prefers-color-scheme: dark) {
    .comp-hero {
        background: linear-gradient(135deg, #1e3a8a, #1e40af);
        box-shadow: 0 6px 16px rgba(0,0,0,0.35);
    }
    .hist-card, .zkp-lot-item, .doc-tile {
        border-color: rgba(255,255,255,0.08);
    }
}

.header-preview {
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 12px;
    position: relative;
    min-height: 100px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15), 0 0 1px rgba(0,0,0,0.2);
}
.header-preview-img {
    width: 100%;
    max-height: 120px;
    object-fit: contain;
    border-radius: 6px;
}
.header-placeholder {
    text-align: center;
    color: var(--text-sec);
    padding: 24px;
}
.header-edit-btn {
    position: absolute;
    bottom: 8px;
    right: 8px;
    padding: 6px 12px;
    border-radius: 16px;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
}

.form-section {
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15), 0 0 1px rgba(0,0,0,0.2);
}
.form-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.form-field {
    margin-bottom: 12px;
}
.form-label {
    display: block;
    font-size: 12px;
    color: var(--text-sec);
    margin-bottom: 4px;
}
.form-input {
    width: 100%;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1.5px solid var(--hint);
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
}
.form-input:focus { outline: none; border-color: var(--btn); }

.tax-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.tax-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    background: var(--bg);
    border-radius: 8px;
    cursor: pointer;
    border: 2px solid transparent;
    font-size: 14px;
}
.tax-option.active {
    border-color: var(--btn);
    background: var(--card-alt);
}
.tax-radio {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid var(--hint);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.tax-option.active .tax-radio {
    border-color: var(--btn);
}
.tax-option.active .tax-radio::after {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--btn);
}

.btn-primary {
    width: 100%;
    padding: 14px;
    border-radius: var(--radius);
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    font-size: 15px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
}
.btn-primary:active { opacity: 0.85; }

.btn-secondary {
    width: 100%;
    padding: 14px;
    border-radius: var(--radius);
    background: var(--card);
    color: var(--text);
    border: 1.5px solid var(--hint);
    font-size: 15px;
    font-family: inherit;
    cursor: pointer;
}

.btn-danger {
    width: 100%;
    padding: 12px;
    border-radius: 8px;
    background: none;
    color: var(--danger);
    border: 1px solid var(--danger);
    font-size: 14px;
    font-family: inherit;
    cursor: pointer;
    margin-top: 8px;
}

/* -- Шапка (редактор шаблонов) --------------------------------------------- */
.template-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 12px;
}
.template-item {
    background: var(--bg);
    border-radius: 8px;
    padding: 12px;
    text-align: center;
    cursor: pointer;
    border: 2px solid transparent;
    font-size: 12px;
    color: var(--text-sec);
}
.template-item.active {
    border-color: var(--btn);
    color: var(--btn);
}
.template-preview {
    height: 48px;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.upload-area {
    border: 2px dashed var(--hint);
    border-radius: var(--radius);
    padding: 24px;
    text-align: center;
    color: var(--text-sec);
    cursor: pointer;
    transition: border-color 0.15s;
}
.upload-area:hover { border-color: var(--btn); }
.upload-area [data-lucide] { width: 32px; height: 32px; margin-bottom: 8px; }

/* -- Калькулятор ----------------------------------------------------------- */
.calc-screen { padding: 16px; }
.calc-inputs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 16px;
}
.calc-field label {
    display: block;
    font-size: 11px;
    color: var(--text-sec);
    margin-bottom: 2px;
}
.calc-field input {
    width: 100%;
    padding: 10px;
    border-radius: 8px;
    border: 1.5px solid var(--hint);
    background: var(--card);
    color: var(--text);
    font-size: 15px;
    font-family: inherit;
    font-variant-numeric: tabular-nums;
}
.calc-field input:focus { outline: none; border-color: var(--btn); }

.calc-results {
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius);
    padding: 14px 16px;
    margin-bottom: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.calc-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 13px;
    font-variant-numeric: tabular-nums;
}
.calc-row span:last-child { font-weight: 500; font-variant-numeric: tabular-nums; }
.calc-big { font-size: 15px; font-weight: 700; }
.calc-divider { height: 1px; background: var(--hint); opacity: 0.3; margin: 6px 0; }
.calc-warn { color: var(--danger); }
.calc-profit span:last-child { color: var(--success); }
.calc-loss span:last-child { color: var(--danger); }

.calc-buttons { display: flex; gap: 8px; }
.calc-buttons button { flex: 1; }
.calc-autosave {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 12px;
    opacity: 0.65;
    transition: opacity 0.3s ease, color 0.3s ease;
}
.calc-autosave.calc-autosave-pulse {
    opacity: 1;
    color: #22c55e;
}

/* -- Новая структура калькулятора (секции) -------------------------------- */
.calc-section {
    background: var(--card);
    border-radius: var(--radius);
    padding: 12px 14px;
    margin-bottom: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.calc-section-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.calc-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.calc-grid > * { min-width: 0; }
.calc-grid .calc-field input,
.calc-grid .calc-field select {
    width: 100%;
    padding: 10px;
    border-radius: 8px;
    border: 1.5px solid var(--hint);
    background: var(--card);
    color: var(--text);
    font-size: 15px;
    font-family: inherit;
    font-variant-numeric: tabular-nums;
}
.calc-grid .calc-field input:disabled {
    opacity: 0.7;
    background: transparent;
    border-color: transparent;
    padding-left: 4px;
}
.calc-budget-line {
    font-size: 13px;
    color: var(--text);
    margin-top: 8px;
    font-variant-numeric: tabular-nums;
}
.calc-muted { color: var(--text-sec); font-size: 11px; }
.calc-tax-hint {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 6px;
    line-height: 1.4;
}
.calc-check {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--text);
    margin-top: 8px;
    cursor: pointer;
}
.calc-check input { width: 16px; height: 16px; }
.calc-tip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: var(--hint);
    color: var(--card);
    font-size: 9px;
    font-weight: 700;
    margin-left: 4px;
    cursor: pointer;
    opacity: 0.6;
    vertical-align: middle;
}
.calc-tip:active { opacity: 1; }

/* Popover для подсказок — всплывает рядом с (?) */
.calc-popover {
    position: fixed;
    z-index: 10000;
    background: #1f2937;
    color: #ffffff;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1.45;
    box-shadow: 0 6px 20px rgba(0,0,0,0.35);
    max-width: 280px;
    pointer-events: auto;
    animation: popover-in 0.15s ease-out;
}
@media (prefers-color-scheme: dark) {
    .calc-popover {
        background: #f3f4f6;
        color: #111827;
    }
}
@keyframes popover-in {
    from { opacity: 0; transform: translateY(4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Section toggle (заголовок секции = label с чекбоксом) */
.calc-section-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    margin: 0;
}
.calc-section-toggle input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--btn);
}
.calc-section-title-inline {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Сегмент-кнопки (ЕАЭС / Третьи страны) */
.calc-segment {
    display: flex;
    gap: 4px;
    background: var(--card-alt);
    padding: 3px;
    border-radius: 8px;
    margin-top: 4px;
}
.calc-seg-btn {
    flex: 1;
    background: transparent;
    border: none;
    padding: 8px 10px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--text-sec);
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s, color 0.15s;
}
.calc-seg-btn.active {
    background: var(--card);
    color: var(--text);
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}
.calc-details summary {
    cursor: pointer;
    font-size: 13px;
    padding: 4px 0;
    color: var(--text-sec);
}
.calc-details summary::marker { color: var(--text-sec); }

/* -- Результаты расчёта (новые) ------------------------------------------- */
.calc-row-bold { font-weight: 700; }
.calc-section-row {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    padding: 8px 0 4px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.calc-muted-row span { color: var(--text-sec); font-size: 11px; font-weight: 400; }

/* Главная цифра — чистая прибыль */
.calc-profit-main, .calc-loss-main {
    text-align: center;
    padding: 14px 12px;
    border-radius: 12px;
    margin: 12px 0 8px;
}
.calc-profit-main { background: rgba(34,197,94,0.12); }
.calc-loss-main { background: rgba(220,38,38,0.12); }
.calc-profit-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--text-sec);
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}
.calc-profit-value {
    font-size: 26px;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
    margin-bottom: 4px;
}
.calc-profit-main .calc-profit-value { color: var(--success); }
.calc-loss-main .calc-profit-value { color: var(--danger); }
.calc-profit-meta {
    font-size: 12px;
    color: var(--text-sec);
}
.calc-breakeven {
    font-size: 12px;
    color: var(--text-sec);
    background: var(--card-alt);
    padding: 10px 12px;
    border-radius: 8px;
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    line-height: 1.4;
}
.calc-breakeven b { color: var(--text); font-variant-numeric: tabular-nums; }

/* Тёмная тема — увеличить контраст блока прибыли */
@media (prefers-color-scheme: dark) {
    .calc-profit-main { background: rgba(110,231,183,0.15); }
    .calc-loss-main { background: rgba(252,165,165,0.15); }
    .calc-profit-main .calc-profit-value { color: #6ee7b7; }
    .calc-loss-main .calc-profit-value { color: #fca5a5; }
}

/* -- Оверлей (детальные экраны) -------------------------------------------- */
.overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--bg);
    z-index: 90;
    overflow-y: auto;
    overscroll-behavior: none;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 24px;
    animation: overlay-in 0.3s ease;
}
@keyframes overlay-in {
    from { transform: translateY(40%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
.overlay.closing {
    animation: overlay-out 0.25s ease forwards;
}
@keyframes overlay-out {
    from { transform: translateY(0); opacity: 1; }
    to { transform: translateY(40%); opacity: 0; }
}
.overlay-content { padding: 16px; }

.section-card {
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15), 0 0 1px rgba(0,0,0,0.2);
    word-break: break-word;
    overflow-wrap: break-word;
}
.section-card code {
    word-break: break-all;
    white-space: normal;
}
.section-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
}

/* -- Ещё (настройки) ------------------------------------------------------- */
.settings-screen { padding: 16px; }
.settings-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    min-height: 56px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
    cursor: pointer;
    font-size: 14px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.settings-item:active { opacity: 0.7; }
.settings-item [data-lucide] { width: 20px; height: 20px; color: var(--text-sec); }
.settings-item-text { flex: 1; }
.settings-item-hint { font-size: 12px; color: var(--text-sec); }
.settings-chevron { color: var(--text-sec); }
.settings-chevron [data-lucide] { width: 16px; height: 16px; }

/* -- Wheel Picker (барабан-крутилка для напоминаний) ---------------------- */
.drum::-webkit-scrollbar { display: none; }
.drum { -ms-overflow-style: none; scrollbar-width: none; }

/* -- Ещё v2: секции, тариф-карточка, язык, опасная зона ------------------- */
.more-section-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-sec);
    margin: 18px 4px 8px;
}
.more-section-title:first-child { margin-top: 4px; }

.more-tariff-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    border-radius: 14px;
    margin-bottom: 6px;
    cursor: pointer;
    box-shadow: 0 2px 10px rgba(0,0,0,0.12);
}
.more-tariff-card:active { opacity: 0.85; }
.more-tariff-card.is-pro {
    background: linear-gradient(135deg, #1a73e8 0%, #4285f4 60%, #6366f1 100%);
    color: #fff;
    border: none;
}
.more-tariff-card.is-pro .more-tariff-desc,
.more-tariff-card.is-pro .more-tariff-chev { color: rgba(255,255,255,0.85); }
.more-tariff-icon {
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 10px;
    background: rgba(99,102,241,0.12);
    color: #6366f1;
    flex-shrink: 0;
}
.more-tariff-card.is-pro .more-tariff-icon {
    background: rgba(255,255,255,0.18);
    color: #fff;
}
.more-tariff-body { flex: 1; min-width: 0; }
.more-tariff-title { font-size: 15px; font-weight: 700; }
.more-tariff-desc { font-size: 12px; color: var(--text-sec); margin-top: 2px; }
.more-tariff-chev { color: var(--text-sec); }

/* Standalone tariff chip — над всеми группами */
.tariff-chip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    margin: 4px 0 8px;
    background: var(--card);
    filter: brightness(1.18);
    border: 1px solid rgba(99,102,241,0.25);
    border-radius: 999px;
    cursor: pointer;
    font-size: 13px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.tariff-chip:active { opacity: 0.85; }
.tariff-chip-left {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #6366f1;
    font-weight: 800;
    letter-spacing: 0.03em;
}
.tariff-chip-label { font-size: 13px; }
.tariff-chip-right {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-sec);
    font-size: 12px;
}
.tariff-chip.is-pro {
    background: linear-gradient(135deg, #1a73e8 0%, #4285f4 60%, #6366f1 100%);
    border-color: transparent;
    color: #fff;
}
.tariff-chip.is-pro .tariff-chip-left,
.tariff-chip.is-pro .tariff-chip-right { color: #fff; }
.tariff-chip.is-pro .tariff-chip-right { opacity: 0.9; }

/* Language picker */
.lang-picker { display: flex; flex-direction: column; gap: 8px; }
.lang-option {
    display: flex;
    align-items: center;
    padding: 16px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    border-radius: 12px;
    cursor: pointer;
}
.lang-option:active { opacity: 0.85; }
.lang-option.selected {
    border-color: #6366f1;
    background: rgba(99,102,241,0.08);
}
.lang-option-name { flex: 1; font-size: 15px; font-weight: 600; }
.lang-option-check { color: #6366f1; }

/* Danger zone */
.account-danger-card {
    background: rgba(239,68,68,0.06);
    border: 1px solid rgba(239,68,68,0.25);
    border-radius: 14px;
    padding: 16px;
    margin-top: 8px;
}
.account-danger-title {
    font-size: 14px;
    font-weight: 700;
    color: #dc2626;
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
}
.account-danger-desc {
    font-size: 12px;
    color: var(--text-sec);
    line-height: 1.5;
    margin-bottom: 14px;
}
.btn-danger-outline {
    width: 100%;
    padding: 12px;
    background: transparent;
    color: #dc2626;
    border: 1px solid rgba(220,38,38,0.4);
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.btn-danger-outline:active { opacity: 0.75; }

/* -- Hero row с карандашом -------------------------------------------------- */
.cabinet-hero-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}
.cabinet-hero-row .cabinet-hero-title {
    flex: 1;
    margin-bottom: 0;
    min-width: 0;
}
.cabinet-hero-edit {
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.16);
    border: 1px solid rgba(255,255,255,0.22);
    border-radius: 8px;
    color: inherit;
    cursor: pointer;
    flex-shrink: 0;
}
.cabinet-hero-edit:active { opacity: 0.75; }
.cabinet-hero-meta-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.cabinet-hero-meta-row .cabinet-hero-meta { flex: 1; }
.cabinet-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    background: rgba(255,255,255,0.2);
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.06em;
}

/* Free hero — нейтральный фон, без градиента */
.cabinet-hero--free {
    background: var(--card);
    filter: brightness(1.15);
    color: var(--text, inherit);
    box-shadow: 0 2px 12px rgba(0,0,0,0.12);
    border: 1px solid var(--border, rgba(0,0,0,0.06));
}
.cabinet-hero--free .cabinet-hero-bg { display: none; }
.cabinet-hero--free .cabinet-hero-edit {
    background: rgba(99,102,241,0.1);
    border-color: rgba(99,102,241,0.25);
    color: #6366f1;
}
.cabinet-hero--free .cabinet-hero-meta { opacity: 1; color: var(--text-sec); }

/* -- FAQ -------------------------------------------------------------------- */
.faq-screen { padding: 4px 2px 20px; }
.faq-group-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-sec);
    margin: 18px 4px 8px;
}
.faq-item {
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.06));
    border-radius: 12px;
    padding: 14px 14px;
    margin-bottom: 6px;
    cursor: pointer;
}
.faq-item:active { opacity: 0.85; }
.faq-item.is-open {
    border-color: rgba(99,102,241,0.35);
    background: rgba(99,102,241,0.05);
}
.faq-q {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
}
.faq-q > span { flex: 1; }
.faq-q [data-lucide] { color: var(--text-sec); flex-shrink: 0; }
.faq-a {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border, rgba(0,0,0,0.08));
    font-size: 13px;
    color: var(--text-sec);
    line-height: 1.5;
    white-space: pre-line;
}

/* -- Feedback --------------------------------------------------------------- */
.feedback-cats {
    display: flex;
    gap: 8px;
    margin-bottom: 14px;
}
.feedback-cat {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 8px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text, inherit);
    cursor: pointer;
}
.feedback-cat:active { opacity: 0.8; }
.feedback-cat.selected {
    background: rgba(99,102,241,0.12);
    border-color: #6366f1;
    color: #6366f1;
}
.feedback-cat [data-lucide] { color: currentColor; }
.feedback-result {
    margin-top: 12px;
    font-size: 13px;
    color: var(--text-sec);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 20px;
}
.feedback-result.is-success { color: #16a34a; }
.feedback-result.is-success [data-lucide] { color: #16a34a; }
textarea.form-input {
    resize: vertical;
    min-height: 100px;
    font-family: inherit;
}

/* -- About ------------------------------------------------------------------ */
.about-screen { padding: 8px 2px 20px; text-align: center; }
.about-logo {
    width: 72px; height: 72px;
    margin: 10px auto 12px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #6366f1, #4285f4);
    color: #fff;
    border-radius: 18px;
    box-shadow: 0 8px 24px rgba(99,102,241,0.3);
}
.about-name { font-size: 22px; font-weight: 800; }
.about-version {
    font-size: 12px;
    color: var(--text-sec);
    margin-top: 4px;
    cursor: pointer;
    user-select: none;
}
.about-links {
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    text-align: left;
}
.about-link-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    border-radius: 12px;
    font-size: 14px;
    cursor: pointer;
}
.about-link-row > span { flex: 1; }
.about-link-row [data-lucide]:last-child { color: var(--text-sec); }
.about-link-row:active { opacity: 0.85; }
.about-footer {
    margin-top: 22px;
    font-size: 11px;
    color: var(--text-sec);
}

/* -- Referral --------------------------------------------------------------- */
.ref-screen { padding: 4px 2px 20px; }
.ref-hero {
    text-align: center;
    padding: 18px 12px 20px;
    background: linear-gradient(135deg, rgba(99,102,241,0.08), rgba(66,133,244,0.08));
    border-radius: 16px;
    margin-bottom: 16px;
    border: 1px solid rgba(99,102,241,0.18);
}
.ref-hero-icon {
    width: 56px; height: 56px;
    margin: 0 auto 10px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #6366f1, #4285f4);
    color: #fff;
    border-radius: 14px;
}
.ref-hero-title { font-size: 17px; font-weight: 800; margin-bottom: 6px; }
.ref-hero-sub { font-size: 13px; color: var(--text-sec); line-height: 1.45; }

.ref-stats {
    display: flex;
    gap: 10px;
}
.ref-stat {
    flex: 1;
    text-align: center;
    padding: 16px 8px;
    background: var(--card);
    filter: brightness(1.15);
    border: 1px solid var(--border, rgba(0,0,0,0.06));
    border-radius: 12px;
}
.ref-stat-num {
    font-size: 24px;
    font-weight: 800;
    color: #6366f1;
    font-variant-numeric: tabular-nums;
}
.ref-stat-label {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 2px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.btn-secondary {
    width: 100%;
    padding: 12px;
    background: var(--card);
    filter: brightness(1.2);
    color: var(--text, inherit);
    border: 1px solid var(--border, rgba(0,0,0,0.08));
    border-radius: 12px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.btn-secondary:active { opacity: 0.8; }

/* Кнопка калькулятора — акцентная обводка + иконка.
   Цвет идентичен индикатору сохранённого расчёта (card-calc-icon → var(--btn)).
   Это визуально связывает кнопку с маркером что расчёт был сделан. */
.btn-secondary.btn-calc {
    color: var(--btn);
    border: 1px solid var(--btn);
    background: var(--card);
    filter: none;
}
.btn-secondary.btn-calc [data-lucide] {
    color: var(--btn);
    stroke: currentColor;
}
.btn-secondary.btn-calc:active { opacity: 0.75; }

/* -- Заметки --------------------------------------------------------------- */
.note-item {
    padding: 8px 0;
    border-bottom: 1px solid var(--card-alt);
    font-size: 13px;
}
.note-item:last-child { border-bottom: none; }
.note-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}
.note-time { font-size: 11px; color: var(--text-sec); flex: 1; }
.note-edit { font-size: 11px; cursor: pointer; color: var(--link); }
.note-del { font-size: 16px; cursor: pointer; color: var(--text-sec); line-height: 1; }
.note-del:active { color: var(--danger); }

.note-input-wrap {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}
.note-input {
    flex: 1;
    padding: 10px;
    border-radius: 8px;
    border: 1.5px solid var(--hint);
    background: var(--bg);
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    resize: none;
    min-height: 40px;
}
.note-send {
    padding: 10px 14px;
    border-radius: 8px;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    font-size: 14px;
    cursor: pointer;
}

/* -- Скелетоны ------------------------------------------------------------- */
.skeleton {
    background: linear-gradient(90deg, var(--card-alt) 25%, var(--card) 50%, var(--card-alt) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 8px;
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

.skeleton-card {
    background: var(--card);
    border-radius: var(--radius);
    padding: 16px;
    margin-bottom: 8px;
}
.skeleton-line {
    height: 14px;
    margin-bottom: 8px;
    border-radius: 6px;
}
.skeleton-line:last-child { margin-bottom: 0; }
.skeleton-short { width: 60%; }
.skeleton-medium { width: 80%; }

/* -- Пустое состояние ------------------------------------------------------ */
.empty {
    text-align: center;
    padding: 48px 20px;
    color: var(--text-sec);
}
.empty [data-lucide] { width: 48px; height: 48px; margin-bottom: 12px; }
.empty-text { font-size: 15px; font-weight: 600; line-height: 1.4; color: var(--text); }
.legal-text { font-size: 13px; line-height: 1.55; color: var(--text); }
.legal-text p { margin: 8px 0; }
.legal-text ul { margin: 6px 0 8px 18px; padding: 0; }
.legal-text li { margin: 3px 0; }
.legal-text b { color: var(--text); }

.variant-list {
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    margin-top: 8px;
}
.variant-card {
    background: var(--bg-card);
    border: none;
    border-radius: 0;
    padding: 14px 12px;
    margin-bottom: 0;
    cursor: pointer;
    transition: background 0.15s;
    border-bottom: 1px solid var(--border);
}
.variant-card:last-child { border-bottom: none; }
.variant-card:active { background: var(--bg-hover); }
.variant-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 4px; }
.variant-name { font-size: 14px; font-weight: 700; color: var(--text); line-height: 1.35; flex: 1; word-break: break-word; }
.variant-badges { display: flex; gap: 4px; flex-shrink: 0; }
.variant-badge { font-size: 10px; padding: 2px 7px; border-radius: 6px; font-weight: 600; white-space: nowrap; }
.variant-tag { background: rgba(34,139,230,0.15); color: var(--accent); }
.variant-history { background: rgba(120,120,120,0.18); color: var(--text-sec); }
.variant-desc { font-size: 12px; color: var(--text-sec); line-height: 1.4; margin: 4px 0; word-break: break-word; }
.variant-price { font-size: 14px; color: var(--text); margin: 6px 0 4px; }
.variant-method { font-size: 12px; color: var(--text-sec); margin-bottom: 4px; }
.variant-org { font-size: 12px; color: var(--text-sec); margin-bottom: 4px; word-break: break-word; }
.variant-ids { font-size: 11px; color: var(--text-sec); margin-top: 4px; }
.variant-ids code { background: var(--bg-hover); padding: 1px 5px; border-radius: 4px; font-size: 11px; }
.empty-hint { font-size: 13px; color: var(--text-sec); margin-top: 6px; max-width: 260px; margin-left: auto; margin-right: auto; line-height: 1.5; }
.empty-cta {
    margin-top: 20px;
    padding: 12px 20px;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    border-radius: var(--radius);
    font-size: 14px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: transform 0.1s;
}
.empty-cta:active { transform: scale(0.96); }
.empty-cta [data-lucide] { width: 16px; height: 16px; margin-bottom: 0; }

/* -- Напоминание ----------------------------------------------------------- */
.remind-row { display: flex; gap: 8px; margin-bottom: 8px; }
.remind-btn {
    flex: 1; padding: 10px; border-radius: 8px;
    background: var(--card-alt); color: var(--text);
    border: none; font-size: 13px; font-family: inherit; cursor: pointer;
}

/* -- Свайп-подсказки ------------------------------------------------------- */
.swipe-hint {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    color: white;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s;
}
.swipe-left {
    right: 0;
    background: var(--hint);
}
.swipe-right {
    left: 0;
    background: var(--btn);
}

/* -- Участники (competitor rows) ------------------------------------------- */
.comp-row {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    background: var(--card);
    filter: brightness(1.15);
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.comp-rank { font-size: 16px; width: 28px; text-align: center; flex-shrink: 0; }
.comp-info { flex: 1; margin-left: 8px; }
.comp-name { font-size: 13px; font-weight: 600; }
.comp-detail { font-size: 11px; color: var(--text-sec); }
.comp-me { background: var(--btn); border-radius: var(--radius-sm); }
.comp-me .comp-name, .comp-me .comp-detail { color: var(--btn-text); }

/* -- Утилиты --------------------------------------------------------------- */
.mt-8 { margin-top: 8px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mb-8 { margin-bottom: 8px; }
.mb-12 { margin-bottom: 12px; }
.text-center { text-align: center; }
.text-danger { color: var(--danger); }
.text-success { color: var(--success); }
.text-hint { color: var(--hint); }
.text-sm { font-size: 12px; }
.fw-600 { font-weight: 600; }
.hidden { display: none !important; }

/* -- Загрузка -------------------------------------------------------------- */
/* -- Overlay open: скрыть навигацию ---------------------------------------- */
body.overlay-open .bottom-nav { display: none; }
body.overlay-open { padding-bottom: 16px; }
body.overlay-open .fab { display: none; }

.loading {
    text-align: center;
    padding: 40px;
    color: var(--text-sec);
}

/* -- Задачи (Google Tasks стиль) ------------------------------------------- */
.task-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--card-alt);
}
.task-item:last-child { border-bottom: none; }

.task-check {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--hint);
    flex-shrink: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    margin-top: 1px;
}
.task-check:active { transform: scale(0.85); }
.task-check.checked {
    border-color: var(--btn);
    background: var(--btn);
}
.task-check.checked::after {
    content: '';
    width: 8px;
    height: 5px;
    border-left: 2px solid var(--btn-text);
    border-bottom: 2px solid var(--btn-text);
    transform: rotate(-45deg);
    margin-top: -1px;
}

.task-body { flex: 1; min-width: 0; }
.task-title {
    font-size: 14px;
    line-height: 1.4;
    cursor: pointer;
}
.task-title.done {
    text-decoration: line-through;
    color: var(--hint);
}
.task-due {
    font-size: 11px;
    color: var(--text-sec);
    margin-top: 2px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.task-due-hot { color: var(--danger); font-weight: 600; }
.task-due-add, .task-notes-add {
    font-size: 11px;
    color: var(--hint);
    margin-top: 2px;
    display: flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    padding: 2px 0;
    width: fit-content;
}
.task-due-add:active, .task-notes-add:active { opacity: 0.7; }
.task-title, .task-notes-preview, .task-due { cursor: pointer; }
.task-inline-edit {
    width: 100%;
    padding: 4px 6px;
    border: 1.5px solid var(--btn);
    border-radius: 6px;
    background: var(--card);
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    outline: none;
    resize: vertical;
}
.task-notes-preview {
    font-size: 12px;
    color: var(--text-sec);
    margin-top: 2px;
    white-space: pre-wrap;
    word-break: break-word;
    line-height: 1.4;
}

.task-subtask {
    padding-left: 32px;
}

.task-del {
    font-size: 18px;
    cursor: pointer;
    color: var(--text-sec);
    line-height: 1;
    padding: 4px;
    flex-shrink: 0;
}
.task-del:active { color: var(--danger); }

/* Блок добавления задачи — Google Tasks стиль */
.task-add-block {
    margin-top: 12px;
    border: 1.5px solid var(--hint);
    border-radius: 10px;
    padding: 10px 12px;
    background: var(--bg);
}
.task-add-title {
    width: 100%;
    padding: 6px 0;
    border: none;
    background: none;
    color: var(--text);
    font-size: 15px;
    font-weight: 500;
    font-family: inherit;
    outline: none;
}
.task-add-title::placeholder { color: var(--hint); }
.task-add-detail-wrap { margin-top: 4px; }
.task-add-detail {
    width: 100%;
    padding: 4px 0;
    border: none;
    background: none;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    outline: none;
    resize: none;
}
.task-add-detail::placeholder { color: var(--hint); }
.task-add-date-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    flex-wrap: wrap;
}
.task-chip {
    padding: 5px 12px;
    border-radius: 20px;
    border: 1.5px solid var(--hint);
    background: none;
    color: var(--text);
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
}
.task-chip:active { opacity: 0.7; }
.task-chip-icon {
    padding: 5px 8px;
    display: inline-flex;
    align-items: center;
}
.task-chip-icon [data-lucide] { width: 16px; height: 16px; }
.task-date-label {
    font-size: 12px;
    color: var(--btn);
    font-weight: 500;
}
.task-date-inline {
    padding: 6px 10px;
    border-radius: 8px;
    border: 1.5px solid var(--hint);
    background: var(--card);
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    width: auto;
    color-scheme: dark light;
}
.task-date-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
}
.task-date-clear, .task-date-save {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}
.task-date-clear { background: rgba(217,48,37,0.12); color: var(--danger); }
.task-date-save { background: rgba(16,185,129,0.15); color: var(--success); }
.task-date-clear:active, .task-date-save:active { opacity: 0.7; }
/* Тулбар: иконки + кнопка сохранить */
.task-add-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
    border-top: 1px solid var(--card-alt);
    padding-top: 8px;
}
.task-tool-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: none;
    color: var(--text-sec);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.task-tool-btn:active { background: var(--card-alt); }
.task-tool-btn [data-lucide] { width: 18px; height: 18px; }
.task-add-btn {
    width: 36px;
    height: 36px;
    padding: 0;
    margin-left: auto;
    border-radius: 50%;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 14px;
    cursor: pointer;
}
/* Лейбл выбранной даты над toolbar */
.task-selected-date {
    font-size: 12px;
    color: var(--btn);
    font-weight: 600;
    padding: 6px 10px;
    background: rgba(26,115,232,0.08);
    border-radius: 8px;
    margin-top: 6px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
/* Меню редактирования даты существующей задачи — отдельный блок под task-item */
.task-date-menu {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 4px 0 10px;
    padding: 8px 10px;
    background: var(--card-alt);
    border-radius: 10px;
    flex-wrap: wrap;
    width: 100%;
    box-sizing: border-box;
}
.task-date-menu .task-picker-input {
    flex: 1 1 140px;
    min-width: 0;
}
.task-date-menu .task-chip { flex-shrink: 0; }
.task-date-menu .task-picker-apply { flex-shrink: 0; }
.task-date-menu .task-del-btn { flex-shrink: 0; margin-left: auto; }
.task-del-btn {
    color: var(--danger);
    margin-left: auto;
}

/* Кнопка календаря с невидимым input поверх — нативный picker по одному тапу */
.task-cal-wrap {
    position: relative;
    display: inline-flex;
    width: 36px;
    height: 36px;
    overflow: visible;
}
.task-cal-wrap .task-tool-btn {
    position: relative;
    z-index: 1;
    pointer-events: none;
}
.task-cal-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    z-index: 2;
    cursor: pointer;
    border: none;
    background: transparent;
    width: 100%;
    height: 100%;
    font-size: 16px; /* чтобы iOS не зумил при фокусе */
    color: transparent;
    -webkit-appearance: none;
    appearance: none;
}
.task-cal-input::-webkit-date-and-time-value { text-align: left; }
.task-cal-input::-webkit-calendar-picker-indicator { opacity: 0; }

/* Inline picker для новой задачи (видимый) */
.task-picker-inline {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    padding: 8px;
    background: var(--card-alt);
    border-radius: 8px;
}
.task-picker-input {
    flex: 1;
    min-width: 0;
    padding: 8px 10px;
    border: 1.5px solid var(--hint);
    border-radius: 6px;
    background: var(--card);
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
}
.task-picker-input:focus { outline: none; border-color: var(--btn); }
.task-picker-input-sm {
    flex: 0 1 auto;
    min-width: 140px;
    padding: 6px 8px;
    font-size: 13px;
}
.task-picker-apply {
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    font-family: inherit;
}
.task-picker-apply [data-lucide] { width: 14px; height: 14px; }
.task-picker-cancel {
    background: transparent;
    color: var(--text-sec);
    border: 1px solid var(--hint);
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-family: inherit;
}

.completed-toggle {
    padding: 10px 0;
    font-size: 13px;
    color: var(--text-sec);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* -- Документы ------------------------------------------------------------ */
.doc-item-current .doc-name { color: #059669; }
.doc-item-current .doc-icon { color: #059669; }
.doc-item-outdated .doc-name { color: #9ca3af; text-decoration: line-through; text-decoration-thickness: 1px; }
.doc-item-outdated .doc-icon { color: #9ca3af; }
@media (prefers-color-scheme: dark) {
    .doc-item-current .doc-name { color: #34d399; }
    .doc-item-current .doc-icon { color: #34d399; }
    .doc-item-outdated .doc-name { color: #6b7280; }
    .doc-item-outdated .doc-icon { color: #6b7280; }
}

.doc-section-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 12px 0 6px;
    display: flex;
    align-items: center;
    gap: 5px;
    border-top: 1px solid var(--card-alt);
    margin-top: 6px;
}
.doc-section-title [data-lucide] { width: 12px; height: 12px; }
.doc-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--card-alt);
    font-size: 13px;
}
.doc-item:last-child { border-bottom: none; }
.doc-icon { color: var(--text-sec); flex-shrink: 0; }
.doc-icon [data-lucide] { width: 18px; height: 18px; }
.doc-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-dl {
    padding: 6px 12px;
    border-radius: 8px;
    background: var(--btn);
    color: var(--btn-text);
    border: none;
    font-size: 12px;
    cursor: pointer;
    white-space: nowrap;
}
.doc-dl:active { opacity: 0.7; }

/* -- Ссылки портала ------------------------------------------------------- */
.portal-links {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.portal-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    border-radius: 8px;
    background: var(--card-alt);
    color: var(--link);
    text-decoration: none;
    font-size: 13px;
}
.portal-link [data-lucide] { width: 14px; height: 14px; }

/* -- Product Tour (пошаговые подсказки) ----------------------------------- */
.tour-overlay {
    position: fixed;
    inset: 0;
    z-index: 9998;
    pointer-events: auto;
}
.tour-overlay-bg {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 9998;
}
.tour-hole {
    position: fixed;
    z-index: 9999;
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.6);
    pointer-events: none;
    transition: all 0.3s ease;
}
.tour-hole.round {
    border-radius: 50%;
}
.tour-hole:not(.round) {
    border-radius: 12px;
}
.tour-tooltip {
    position: fixed;
    z-index: 10000;
    background: var(--card, #fff);
    border-radius: 14px;
    padding: 16px 18px;
    max-width: 280px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.25);

}
.tour-tooltip-text {
    font-size: 14px;
    line-height: 1.5;
    color: var(--text);
    margin-bottom: 14px;
}
.tour-tooltip-btns {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}
.tour-btn-skip {
    background: none;
    border: none;
    color: var(--text-sec, #888);
    font-size: 13px;
    cursor: pointer;
    padding: 6px 0;
}
.tour-btn-next {
    background: var(--btn);
    color: var(--btn-text, #fff);
    border: none;
    border-radius: 10px;
    padding: 8px 20px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}
.tour-btn-next:active { opacity: 0.8; }
.tour-dots {
    display: flex;
    gap: 5px;
}
.tour-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--text-sec, #ccc);
}
.tour-dot.active {
    background: var(--btn);
    width: 16px;
    border-radius: 3px;
}
