/* ═══════════════════════════════════════════════════════════════
   Home Extras — Page-help, Tabs visibility, Kanban wizard, chips
   Извлечено из checklist_operational.css строки 4445–4680
   ═══════════════════════════════════════════════════════════════ */

        /* ===== PAGE HELP ICON (?) В ШАПКЕ + TOOLTIP =====
           Справа от #pageHeaderTitle. Data-help подгружается на каждое
           переключение вкладки из tabTitles[name].help. Сам tooltip рендерится
           JS-ом на уровне body (position:fixed) — чтобы не обрезался
           родителями с overflow. */
        .page-help {
            width: 26px;
            height: 26px;
            min-width: 26px;
            border-radius: 50%;
            background: var(--color-primary-10);
            color: var(--color-primary);
            border: 1.5px solid var(--color-primary-50);
            display: inline-grid;
            place-items: center;
            font-size: var(--text-md);
            font-weight: 700;
            line-height: 1;
            text-align: center;
            cursor: help;
            flex-shrink: 0;
            user-select: none;
            font-family: var(--font-sans);
            transition: background 0.15s, color 0.15s, transform 0.15s, border-color 0.15s;
            /* Лёгкий сдвиг вниз через асимметричный padding — компенсация
               верхнего bearing глифа "?" (визуально кажется приподнятым). */
            padding: 4px 0 0 0;
            box-sizing: border-box;
            vertical-align: middle;
        }
        /* Inline SVG в HTML внутри .page-help — flex-родитель центрирует
           SVG идеально,
без зависимости от font metrics. Цвет иконки
           берётся из currentColor (color родителя). */
        .page-help svg { display: block; }
        .page-help:hover,
.page-help:focus-visible {
            background: var(--color-primary);
            color: #fff;
            border-color: var(--color-primary);
            outline: none;
            transform: scale(1.1);
            box-shadow: 0 2px 8px rgba(62, 60, 89, 0.35);
        }

        /* Floating tooltip — рендерится JS-ом (используется и для .page-help, и для legacy .side-help) */
        .side-tooltip {
            position: fixed;
            background: var(--color-nav-bg);
            color: rgba(255, 255, 255, 0.95);
            padding: 8px 12px;
            border-radius: var(--radius-lg);
            max-width: 320px;
            font-size: var(--text-sm);
            font-weight: 400;
            line-height: 1.45;
            box-shadow: var(--shadow-xl);
            z-index: 9999;
            pointer-events: none;
            opacity: 0;
            transform: translateY(-4px);
            transition: opacity 0.12s ease, transform 0.12s ease;
        }
        .side-tooltip.visible {
            opacity: 1;
            transform: translateY(0);
        }
        /* Стрелка — сверху по центру,
направлена вверх (tooltip под иконкой "?") */
        .side-tooltip::before {
            content: '';
            position: absolute;
            top: -5px;
            left: var(--arrow-left, 14px);
            width: 10px;
            height: 10px;
            background: var(--color-nav-bg);
            transform: rotate(45deg);
            border-radius: 2px;
        }
        /* Если tooltip не поместился снизу — JS ставит data-placement="top",
стрелка снизу */
        .side-tooltip[data-placement="top"]::before {
            top: auto;
            bottom: -5px;
        }

        /* Mobile: при открытом drawer-сайдбаре tooltip справа тоже работает */
        @media (max-width: 768px) {
            .side-tooltip { max-width: 240px; font-size: var(--text-xs); padding: 8px 12px; }
        }

        /* ===== TAB VISIBILITY SETTINGS ===== */
        .side-link--user-hidden,
.mobile-chip--user-hidden { display: none !important; }

        .side-link-settings {
            opacity: 0.75;
            font-size: var(--text-xs);
        }
        .side-link-settings:hover { opacity: 1; }

        .tabs-settings-modal {
            max-width: 460px;
            padding: 24px 32px;
        }
        .tabs-settings-title {
            font-size: var(--text-lg); font-weight: 600; color: var(--color-text);
            margin-bottom: 6px; letter-spacing: -0.015em;
        }
        .tabs-settings-hint {
            font-size: var(--text-sm); color: var(--color-text-secondary);
            margin-bottom: 18px; line-height: 1.5; letter-spacing: -0.005em;
        }
        .tabs-settings-list {
            display: flex; flex-direction: column; gap: 2px;
            max-height: 440px; overflow-y: auto;
            margin-bottom: 18px;
            padding: var(--space-2);
            background: var(--color-bg-subtle);
            border: 1px solid var(--color-border);
            border-radius: var(--radius-xl);
        }
        .tabs-settings-row {
            display: flex; align-items: center; gap: var(--space-3);
            padding: 8px 12px; border-radius: var(--radius-md);
            cursor: pointer; transition: background 0.12s ease;
        }
        .tabs-settings-row:hover { background: white; }
        .tabs-settings-row.is-locked {
            cursor: default; opacity: 0.7;
        }
        .tabs-settings-row.is-locked:hover { background: transparent; }
        .tabs-settings-row input[type="checkbox"] {
            width: 18px; height: 18px; cursor: pointer; accent-color: var(--color-primary);
            flex-shrink: 0;
        }
        .tabs-settings-row.is-locked input { cursor: not-allowed; }
        .tabs-settings-label {
            flex: 1;
            font-size: var(--text-base);
            color: var(--color-text);
            font-weight: 500;
            letter-spacing: -0.005em;
        }
        .tabs-settings-lock {
            font-size: var(--text-xs); color: var(--color-text-secondary);
            padding: 2px 8px; background: white;
            border: 1px solid var(--color-border);
            border-radius: var(--radius-pill); font-weight: 600;
            text-transform: uppercase; letter-spacing: 0.04em;
        }
        .tabs-settings-footer {
            display: flex; justify-content: space-between; align-items: center;
            gap: var(--space-2); flex-wrap: wrap;
        }
        .tabs-settings-actions { display: flex; gap: var(--space-2); }

        /* ===== KANBAN WIZARD ===== */
        .kb-wizard .kb-stepper {
            display: flex; align-items: center; gap: var(--space-2);
            margin: 4px 0 16px;
        }
        .kb-step-dot {
            display: flex; align-items: center; gap: var(--space-2);
            color: var(--color-gray-400); font-size: var(--text-xs); flex-shrink: 0;
        }
        .kb-step-dot span {
            display: flex; align-items: center; justify-content: center;
            width: 24px; height: 24px; border-radius: 50%;
            background: var(--color-gray-100); color: var(--color-gray-400); font-weight: 700; font-size: var(--text-xs);
            border: 1.5px solid var(--color-border);
        }
        .kb-step-dot label { font-weight: 500; cursor: default; }
        .kb-step-dot.is-active span { background: var(--color-primary); color: var(--color-surface); border-color: var(--color-primary); }
        .kb-step-dot.is-active label { color: var(--color-primary); font-weight: 600; }
        .kb-step-dot.is-done span {
            background: var(--color-success-50); color: var(--color-success); border-color: #c8e6c9;
        }
        .kb-step-line {
            flex: 1; height: 2px; background: var(--color-border); border-radius: var(--radius-pill);
        }
        .kb-step-pane { display: block; }
        .kb-step-hint {
            font-size: var(--text-xs); color: var(--color-text-secondary); margin-top: 4px;
        }
        .kb-roadmap-toggle {
            display: flex; align-items: center; gap: var(--space-2);
            padding: 8px 12px; margin-top: 6px;
            background: var(--color-bg-tint); border: 1px solid var(--color-border); border-radius: var(--radius-md);
            font-size: var(--text-sm); color: var(--color-text-strong); cursor: pointer;
        }
        .kb-roadmap-toggle input { margin: var(--space-0); cursor: pointer; }
        .kb-wizard-nav { display: flex; gap: var(--space-2); justify-content: flex-end; }

        /* ===== KANBAN LINKED ROADMAP CHIP ===== */
        .kb-card-linked {
            display: inline-flex; align-items: center; gap: var(--space-1);
            margin: 8px 0 0; padding: 4px 8px;
            background: #ecfdf5; color: #047857;
            border: 1px solid #a7f3d0; border-radius: var(--radius-pill);
            font-size: var(--text-xs); font-weight: 600;
            cursor: pointer; transition: background 0.15s, border-color 0.15s;
            max-width: 100%;
        }
        .kb-card-linked:hover { background: #d1fae5; border-color: #6ee7b7; }
        .kb-card-linked-ico { font-size: var(--text-xs); line-height: 1; }
        .kb-card-linked-text {
            white-space: normal; overflow: hidden; 
            max-width: 180px;
        }

        /* ===== KANBAN DUE DATE CHIP ===== */
        .kb-card-due {
            display: inline-flex; align-items: center; gap: var(--space-1);
            margin: 2px 0 0; padding: 1px 8px;
            background: #eff6ff; color: #0040DD;
            border: 1px solid #bfdbfe; border-radius: var(--radius-pill);
            font-size: var(--text-xs); font-weight: 600;
        }
        .kb-card-due.is-soon { background: #fef3c7; color: #92400e; border-color: #fde68a; }
        .kb-card-due.is-overdue { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
        .kb-card-due-ico { width: 13px; height: 13px; flex-shrink: 0; }

        /* Подсветка строки задачи в дорожной карте при переходе из канбана */
        @keyframes kbLinkedFlash {
            0%   { background: var(--color-warning-50); }
            60%  { background: #fef9c3; }
            100% { background: transparent; }
        }
        tr.kb-linked-flash > td { animation: kbLinkedFlash 2.2s ease-out; }
        .kb-card.kb-linked-flash {
            animation: kbLinkedFlash 2.2s ease-out;
            box-shadow: 0 0 0 3px var(--color-warning), 0 6px 18px rgba(15, 23, 42, 0.10);
        }

