/* AUTO-GENERATED by scripts/build-css-bundles.js — do not edit directly */
/* Built: 2026-06-23T02:40:52.207Z */
/* Sources: 12 files */

/* === lib/ui/theme.css === */
/* ============================================================
   FOMO&TEMA · Design System — theme.css
   ------------------------------------------------------------
   Единый источник дизайн-токенов и переиспользуемых компонентов.
   Подключается на всех страницах ПОСЛЕ shell.css.

   Содержание:
     1. Дизайн-токены (dark/light, all accent colors)
     2. Типографика
     3. Компоненты: ft-btn, ft-input, ft-card
     4. Компоненты: ft-table
     5. Компоненты: ft-modal, ft-toast, ft-tooltip, ft-tabs, ft-dropdown
     6. Компоненты: ft-seg / ft-seg-btn (канонические, auth.js = совместимая копия)
     7. Утилитарные классы
   ============================================================ */

/* ─────────────────────────────────────────────────────────
   1. Дизайн-токены — Dark тема (по умолчанию)
   ───────────────────────────────────────────────────────── */
:root,
[data-theme="dark"] {
  /* Фон */
  --bg:  #0b0e11;
  --bg2: #161a1e;
  --bg3: #1e2329;

  /* Граница и текст */
  --border: #2a2e39;
  --text:   #d1d4dc;
  --muted:  #a6b0bd; /* WCAG AA contrast on --bg #0b0e11 ~5.5:1 (was #848e9c ~3.2:1) */
  --strong: #ffffff;

  /* Акцентные цвета — бренд-палитра см. memory/00_core/brand_palette.md */
  --green:        #0d9488;
  --green-hover:  #14b8a6;
  --green-dim:    rgba(13, 148, 136, 0.14);
  --green-border: rgba(13, 148, 136, 0.35);
  /* Text-grade зелёный для inline-текста (WCAG 2.1 AA контраст ≥4.5:1).
     На --bg #0b0e11 даёт ~7:1. В светлой теме переопределяется на тёмно-бирюзовый. */
  --green-text:   #14b8a6;
  /* Акцент-яркий (старый неон) — редкие индикаторы «Live», «Бесплатно», достижения.
     Не для основных кнопок и крупных областей — см. brand_palette.md §1. */
  --green-accent: #00ff88;

  --red:    #f6465d;
  --red-dim:    rgba(246, 70, 93, 0.12);
  --red-border: rgba(246, 70, 93, 0.25);

  --blue:        #0369a1;
  --blue-hover:  #0284c7;
  --blue-dim:    rgba(3, 105, 161, 0.14);
  --blue-border: rgba(3, 105, 161, 0.35);
  /* Text-grade синий для inline-текста (WCAG 2.1 AA контраст ≥4.5:1).
     В тёмной теме fill уже хорошо читается → синоним --blue. */
  --blue-text:   var(--blue);

  --purple: #a855f7;
  --purple-dim:    rgba(168, 85, 247, 0.10);
  --purple-border: rgba(168, 85, 247, 0.25);

  --yellow: #f7c948;
  --yellow-dim:    rgba(247, 201, 72, 0.10);
  --yellow-border: rgba(247, 201, 72, 0.25);

  /* Оранжевый-анонс — семантический «скоро событие» (делистинг, изменение фьючерса).
     Добавлено 2026-05-27, см. brand_palette.md §1 «Семейство системных цветов». */
  --orange-announce: #ff9966;
  --orange-announce-dim: rgba(255, 153, 102, 0.10);
  --orange-announce-border: rgba(255, 153, 102, 0.5);
  /* Text-grade жёлтый/амбер для inline-warning-текста (WCAG 2.1 AA ≥4.5:1).
     В тёмной теме fill читается хорошо → синоним --yellow.
     В светлой переопределяется на тёмно-янтарный. */
  --yellow-text: var(--yellow);

  --orange: #f97316;
  --orange-dim:    rgba(249, 115, 22, 0.10);
  --orange-border: rgba(249, 115, 22, 0.25);

  --cyan:   #06b6d4;
  --cyan-dim:    rgba(6, 182, 212, 0.10);
  --cyan-border: rgba(6, 182, 212, 0.25);

  /* Тени */
  --shadow-sm: 0 1px 4px rgba(0,0,0,.35);
  --shadow:    0 4px 16px rgba(0,0,0,.45);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.55);

  /* Компоненты */
  --input-bg:     var(--bg2);
  --input-border: var(--border);
  --card-bg:      var(--bg2);
  --card-border:  var(--border);

  /* Скроллбар */
  --scrollbar-thumb: var(--border);

  /* Контрастный текст на цветном фоне (для кнопок/чипов с акцентным background) */
  --on-bg:      var(--text);          /* текст на --bg */
  --on-card:    var(--text);          /* текст на --card-bg */
  --on-accent:  #ffffff;              /* текст на любом акцентном (зелёный/синий/...) — белый в dark */
  --on-green:   #ffffff;              /* dark: на бирюзовом #0d9488 белый текст читается (~5.5:1) */
  --on-red:     #ffffff;
  --on-yellow:  #000000;              /* yellow яркий → чёрный текст */
  --on-purple:  #ffffff;
  --on-orange:  #ffffff;
  --on-cyan:    #000000;
  --on-blue:    #ffffff;

  /* Backdrop'ы для модалок и оверлеев */
  --overlay-bg:        rgba(0, 0, 0, .45);
  --overlay-bg-strong: rgba(0, 0, 0, .70);
  --shadow-overlay:    0 0 0 100vmax rgba(0, 0, 0, .55);

  /* Brand & chart-палитра (статичная, не меняется по теме) */
  --chart-teal:     #26a69a;
  --chart-teal-dim: rgba(38, 166, 154, .12);
  --chart-red:      #ef5350;
  --chart-red-dim:  rgba(239, 83, 80, .12);
  --gh-green:       #2da44e;
  --gh-green-dim:   rgba(45, 164, 78, .12);
  --cyan-drift:     #00c8ff;
  --cyan-drift-dim: rgba(0, 200, 255, .12);

  /* Founder/премиум-акценты (статичные) */
  --gold:           #ffd24a;
  --gold-dark-text: #1a1200;
  --gold-glow:      rgba(255, 255, 255, .06);

  /* Грейдиент-стопы (статичные) */
  --grad-green-stop:   #00c6ff;
  --grad-purple-stop:  #ec4899;
  --light-surface-overlay: rgba(232, 236, 242, .7);

  /* Полупрозрачная white-подсветка для тёмной темы */
  --white-ghost-08:    rgba(255, 255, 255, .08);

  /* QR-canvas всегда белый (нативное требование) */
  --qr-bg:             #ffffff;
}

/* ─────────────────────────────────────────────────────────
   1. Дизайн-токены — Light тема
   ───────────────────────────────────────────────────────── */
[data-theme="light"] {
  --bg:  #e8ecf2;
  --bg2: #f6f8fb;
  --bg3: #dde2ea;

  --border: #b8c2d0;
  --text:   #0f1117;
  --muted:  #606878;
  --strong: #000000;

  --green:        #0d9488;
  --green-hover:  #14b8a6;
  --green-dim:    rgba(13, 148, 136, 0.10);
  --green-border: rgba(13, 148, 136, 0.35);
  /* Text-grade: тёмно-бирюзовый. #0f766e на --bg2 (#f6f8fb) ≈ 5.4:1 — WCAG 2.1 AA pass. */
  --green-text:   #0f766e;
  /* Акцент-яркий в light — приглушённая версия неона для редких индикаторов. */
  --green-accent: #00b86b;

  --red:    #c82b45;
  --red-dim:    rgba(200, 43, 69, 0.10);
  --red-border: rgba(200, 43, 69, 0.30);

  --blue:        #0369a1;
  --blue-hover:  #075985;
  --blue-dim:    rgba(3, 105, 161, 0.10);
  --blue-border: rgba(3, 105, 161, 0.35);
  /* Text-grade синий в light — `--blue` уже даёт нужный контраст:
     #0369a1 на --bg (#e8ecf2) → ~6:1 — WCAG AA pass. */
  --blue-text:   var(--blue);

  --purple: #7c3aed;
  --purple-dim:    rgba(124, 58, 237, 0.10);
  --purple-border: rgba(124, 58, 237, 0.30);

  --yellow: #d4a017;
  --yellow-dim:    rgba(212, 160, 23, 0.12);
  --yellow-border: rgba(212, 160, 23, 0.35);

  /* Светлая тема: тот же оттенок оранжевого — хорошо читается и на белом */
  --orange-announce: #e07b3f;
  --orange-announce-dim: rgba(224, 123, 63, 0.10);
  --orange-announce-border: rgba(224, 123, 63, 0.45);
  /* Text-grade: тёмный амбер. Контраст 5.44:1 на --bg (#e8ecf2), 6.04:1 на --bg2 (#f6f8fb).
     #8c6900 (исходный кандидат) на --bg давал лишь 4.28:1 — ниже AA, поэтому затемнили. */
  --yellow-text:   #7a5900;

  --orange: #c2550e;
  --orange-dim:    rgba(194, 85, 14, 0.10);
  --orange-border: rgba(194, 85, 14, 0.30);

  --cyan:   #0284a8;
  --cyan-dim:    rgba(2, 132, 168, 0.10);
  --cyan-border: rgba(2, 132, 168, 0.30);

  --shadow-sm: 0 1px 4px rgba(0,0,0,.10);
  --shadow:    0 4px 16px rgba(0,0,0,.15);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.20);

  --input-bg:     var(--bg2);
  --input-border: var(--border);
  --card-bg:      var(--bg2);
  --card-border:  var(--border);

  --scrollbar-thumb: var(--border);

  /* Контрастный текст на цветном фоне (для кнопок/чипов с акцентным background) */
  --on-bg:      var(--text);
  --on-card:    var(--text);
  --on-accent:  #ffffff;              /* light: на акцентном фоне белый чаще читается */
  --on-green:   #ffffff;
  --on-red:     #ffffff;
  --on-yellow:  #000000;              /* yellow в light — оставляем чёрный */
  --on-purple:  #ffffff;
  --on-orange:  #ffffff;
  --on-cyan:    #ffffff;
  --on-blue:    #ffffff;

  /* Backdrop'ы для модалок и оверлеев */
  --overlay-bg:        rgba(0, 0, 0, .35);
  --overlay-bg-strong: rgba(0, 0, 0, .55);
  --shadow-overlay:    0 0 0 100vmax rgba(0, 0, 0, .40);

  /* В light --ft-z-modal-stack/toast-priority наследуются из общего :root блока — не дублируем здесь */

  /* Brand & chart-палитра — версии для светлой темы */
  --chart-teal:     #1e8a82;
  --chart-teal-dim: rgba(30, 138, 130, .14);
  --chart-red:      #d73a3a;
  --chart-red-dim:  rgba(215, 58, 58, .14);
  --gh-green:       #1f7a3a;
  --gh-green-dim:   rgba(31, 122, 58, .14);
  --cyan-drift:     #0085b5;
  --cyan-drift-dim: rgba(0, 133, 181, .14);

  --gold:           #d4a017;
  --gold-dark-text: #1a1200;
  --gold-glow:      rgba(0, 0, 0, .06);

  --grad-green-stop:   #0085b5;
  --grad-purple-stop:  #c13484;
  --light-surface-overlay: rgba(232, 236, 242, .7);

  --white-ghost-08:    rgba(0, 0, 0, .06);
  --qr-bg:             #ffffff;
}

/* ─────────────────────────────────────────────────────────
   2. Типографика
   ───────────────────────────────────────────────────────── */
:root {
  --font-base:    'Lato', 'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Urbanist', var(--font-base);
  --font-mono:    'JetBrains Mono', 'Fira Mono', ui-monospace, monospace;

  --text-xs:   11px;
  --text-sm:   12px;
  --text-base: 13px;
  --text-md:   14px;
  --text-lg:   16px;
  --text-xl:   18px;
  --text-2xl:  24px;
  --text-3xl:  32px;
  --text-4xl:  42px;

  --lh-tight:  1.2;
  --lh-snug:   1.4;
  --lh-normal: 1.6;
  --lh-relaxed:1.75;

  --radius-sm: 4px;
  --radius:    6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  --transition: .15s ease;
  --transition-md: .22s ease;

  --ft-z-base: 1; --ft-z-dropdown: 10; --ft-z-sticky: 100; --ft-z-fixed: 200;
  --ft-z-overlay: 900; --ft-z-modal: 1000; --ft-z-popover: 1100; --ft-z-toast: 1200;
  /* HI-04: tooltip поднят до 9100 — выше --sh-z-modal (9000), ниже --sh-z-toast (9500).
     Tooltip должен перекрывать модалки, но не перекрывать системные тосты. */
  --ft-z-tooltip:        9100;
  --ft-z-modal-stack:    1400;        /* модалки поверх обычных */
  --ft-z-toast-priority: 1500;        /* toast приоритетный */
  --ft-z-ctx-menu:       1600;        /* поверх toast-priority (1500) */
}

/* ─────────────────────────────────────────────────────────
   3. Компонент: ft-btn
   Использование: <button class="ft-btn ft-btn-green">Текст</button>
   ───────────────────────────────────────────────────────── */
.ft-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 16px;
  height: 34px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--bg2);
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 600;
  font-family: var(--font-base);
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
  flex-shrink: 0;
}
.ft-btn:hover { background: var(--bg3); color: var(--text); }
/* A11Y (S92 v2.0 fix WCAG 2.1 SC 2.4.7 Focus Visible AA) */
.ft-btn:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }
.ft-btn:disabled { opacity: .45; pointer-events: none; }

.ft-btn-sm { height: 28px; padding: 0 12px; font-size: var(--text-xs); }
.ft-btn-lg { height: 40px; padding: 0 22px; font-size: var(--text-md); }
.ft-btn-xl { height: 48px; padding: 0 28px; font-size: var(--text-lg); font-weight: 700; }

/* Варианты */
.ft-btn-primary { background: var(--green); border-color: var(--green-text); color: #000; font-weight: 700; }
.ft-btn-primary:hover { filter: brightness(1.12); color: #000; }

.ft-btn-green { border-color: var(--green-border); color: var(--green-text); }
.ft-btn-green:hover { background: var(--green-dim); border-color: var(--green-text); color: var(--green-text); }

.ft-btn-blue { border-color: var(--blue-border); color: var(--blue); }
.ft-btn-blue:hover { background: var(--blue-dim); border-color: var(--blue); color: var(--blue); }

.ft-btn-red { border-color: var(--red-border); color: var(--red); }
.ft-btn-red:hover { background: var(--red-dim); border-color: var(--red); color: var(--red); }

.ft-btn-purple { border-color: var(--purple-border); color: var(--purple); }
.ft-btn-purple:hover { background: var(--purple-dim); border-color: var(--purple); color: var(--purple); }

.ft-btn-ghost { border-color: transparent; background: transparent; }
.ft-btn-ghost:hover { background: var(--bg3); border-color: var(--border); }

.ft-btn-icon { padding: 0; width: 34px; }
.ft-btn-icon.ft-btn-sm { width: 28px; }
.ft-btn-icon.ft-btn-lg { width: 40px; }

/* ─────────────────────────────────────────────────────────
   3b. Простой .btn — используется на страницах копитрейда
       (copytrade/, copytrade/master/, copytrade/subscriptions/)
   ───────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-base);
  cursor: pointer;
  border: 1px solid transparent;
  background: var(--bg2);
  color: var(--text);
  text-decoration: none;
  transition: background .15s, border-color .15s, color .15s, opacity .15s;
  white-space: nowrap;
  line-height: 1.2;
}
.btn:hover:not(:disabled) { background: var(--bg3); }
/* A11Y (S92 v2.0 fix WCAG 2.1 SC 2.4.7 Focus Visible AA) */
.btn:focus-visible { outline: 2px solid var(--blue, #4fc3f7); outline-offset: 2px; }
.btn:disabled { opacity: .4; cursor: default; pointer-events: none; }
.btn i { font-size: 12px; }

.btn-primary   { background: var(--accent, var(--green)); border-color: var(--accent, var(--green)); color: #fff; }
.btn-primary:hover:not(:disabled) { filter: brightness(1.1); background: var(--accent, var(--green)); color: #fff; }

.btn-secondary { background: var(--bg3); border-color: var(--border); color: var(--text); }
.btn-secondary:hover:not(:disabled) { border-color: var(--accent, var(--green)); color: var(--accent, var(--green)); background: var(--bg3); }

.btn-ghost     { background: transparent; border-color: var(--border); color: var(--text); }
.btn-ghost:hover:not(:disabled) { border-color: var(--accent, var(--green)); color: var(--accent, var(--green)); }

.btn-danger    { background: transparent; border-color: var(--red, #e55); color: var(--red, #e55); }
.btn-danger:hover:not(:disabled) { background: var(--red-dim, rgba(238,85,85,.1)); color: var(--red, #e55); }

.btn-sm        { padding: 5px 10px; font-size: 12px; }
.btn-lg        { padding: 10px 20px; font-size: 14px; }

/* ─────────────────────────────────────────────────────────
   4. Компонент: ft-input
   Использование: <input class="ft-input" ...>
   ───────────────────────────────────────────────────────── */
.ft-input {
  display: block;
  width: 100%;
  height: 34px;
  padding: 0 12px;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: var(--text-base);
  font-family: var(--font-base);
  transition: border-color var(--transition);
  outline: none;
  -webkit-appearance: none;
}
.ft-input::placeholder { color: var(--muted); opacity: .7; }
.ft-input:focus { border-color: var(--blue); }
/* A11Y (S92 v2.0 fix WCAG 2.1 SC 2.4.7 Focus Visible AA) — keyboard-only focus indicator */
.ft-input:focus-visible { border-color: var(--blue); outline: 2px solid var(--blue); outline-offset: 1px; box-shadow: 0 0 0 3px rgba(79,195,247,.25); }
.ft-input:disabled { opacity: .45; cursor: not-allowed; }

.ft-input-sm { height: 28px; padding: 0 10px; font-size: var(--text-xs); }
.ft-input-lg { height: 40px; padding: 0 14px; font-size: var(--text-md); }

.ft-textarea {
  display: block;
  width: 100%;
  padding: 10px 12px;
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: var(--text-base);
  font-family: var(--font-base);
  line-height: var(--lh-normal);
  resize: vertical;
  outline: none;
  transition: border-color var(--transition);
}
.ft-textarea:focus { border-color: var(--blue); }
.ft-textarea:focus-visible { border-color: var(--blue); outline: 2px solid var(--blue); outline-offset: 1px; box-shadow: 0 0 0 3px rgba(79,195,247,.25); }

.ft-select {
  display: block;
  height: 34px;
  padding: 0 32px 0 12px;
  background: var(--input-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23848e9c'/%3E%3C/svg%3E") no-repeat right 10px center;
  border: 1px solid var(--input-border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: var(--text-base);
  font-family: var(--font-base);
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color var(--transition);
}
.ft-select:focus { border-color: var(--blue); }
.ft-select:focus-visible { border-color: var(--blue); outline: 2px solid var(--blue); outline-offset: 1px; box-shadow: 0 0 0 3px rgba(79,195,247,.25); }

/* Input-group */
.ft-input-group { display: flex; }
.ft-input-group .ft-input { border-radius: 0; border-right: none; }
.ft-input-group .ft-input:first-child { border-radius: var(--radius) 0 0 var(--radius); }
.ft-input-group .ft-btn:last-child { border-radius: 0 var(--radius) var(--radius) 0; border-left: none; }

/* ─────────────────────────────────────────────────────────
   5. Компонент: ft-card
   Использование: <div class="ft-card"> ... </div>
   ───────────────────────────────────────────────────────── */
.ft-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-lg);
  padding: 20px;
  position: relative;
}
.ft-card-sm { padding: 14px 16px; border-radius: var(--radius-md); }
.ft-card-lg { padding: 28px 32px; }

.ft-card-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.ft-card-title {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--strong);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ft-card-sub { font-size: var(--text-sm); color: var(--muted); margin-top: 2px; }

/* ─────────────────────────────────────────────────────────
   6. Компонент: ft-table
   ───────────────────────────────────────────────────────── */
.ft-table-wrap { overflow-x: auto; }
.ft-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
  color: var(--text);
}
.ft-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.ft-table td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.ft-table tr:last-child td { border-bottom: none; }
.ft-table tr:hover td { background: var(--bg3); }
.ft-table.striped tr:nth-child(even) td { background: rgba(255,255,255,.02); }
[data-theme="light"] .ft-table.striped tr:nth-child(even) td { background: rgba(0,0,0,.02); }

/* ─────────────────────────────────────────────────────────
   7. Компонент: ft-tabs
   Использование:
     <div class="ft-tabs">
       <button class="ft-tab active">Tab 1</button>
       <button class="ft-tab">Tab 2</button>
     </div>
   ───────────────────────────────────────────────────────── */
.ft-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: none;
}
.ft-tabs::-webkit-scrollbar { display: none; }

.ft-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--muted);
  font-size: var(--text-base);
  font-weight: 600;
  font-family: var(--font-base);
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--transition), border-color var(--transition);
  margin-bottom: -1px;
}
.ft-tab:hover { color: var(--text); }
.ft-tab.active { color: var(--strong); border-bottom-color: var(--green-text); }
.ft-tab .ft-tab-badge {
  background: var(--red);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 1px 5px;
  border-radius: var(--radius-full);
  min-width: 16px;
  text-align: center;
}

/* ─────────────────────────────────────────────────────────
   8. Компонент: ft-dropdown
   Управление JS-классом .open
   ───────────────────────────────────────────────────────── */
.ft-dropdown-wrap { position: relative; display: inline-flex; }

.ft-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 180px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  z-index: var(--sh-z-dropdown, 1000);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  overflow: hidden;
}
.ft-dropdown-wrap.open .ft-dropdown,
.ft-dropdown.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ft-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  color: var(--text);
  font-size: var(--text-base);
  font-family: var(--font-base);
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  text-decoration: none;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
}
.ft-dropdown-item:hover { background: var(--bg3); color: var(--strong); }
.ft-dropdown-item.danger { color: var(--red); }
.ft-dropdown-item.danger:hover { background: var(--red-dim); }
.ft-dropdown-item i { width: 16px; text-align: center; color: var(--muted); font-size: var(--text-sm); }
.ft-dropdown-item:hover i { color: inherit; }
.ft-dropdown-sep { height: 1px; background: var(--border); margin: 4px 0; }
.ft-dropdown-label {
  padding: 6px 14px 4px;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
}

/* ─────────────────────────────────────────────────────────
   9. Компонент: ft-modal
   JS управляет атрибутом [open] на .ft-modal-overlay
   ───────────────────────────────────────────────────────── */
.ft-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .6);
  z-index: var(--sh-z-modal, 9000);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .22s, visibility .22s;
}
.ft-modal-overlay[open] {
  opacity: 1;
  visibility: visible;
}
.ft-modal-overlay[open] .ft-modal {
  transform: none;
}

.ft-modal {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-lg);
  transform: translateY(12px);
  transition: transform .22s;
  overflow: hidden;
}
.ft-modal-sm { max-width: 380px; }
.ft-modal-lg { max-width: 720px; }
.ft-modal-xl { max-width: 960px; }

.ft-modal-hd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.ft-modal-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--strong);
  flex: 1;
}
.ft-modal-x {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: var(--radius);
  border: none;
  background: none;
  color: var(--muted);
  font-size: 16px;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  flex-shrink: 0;
}
.ft-modal-x:hover { background: var(--bg3); color: var(--text); }

.ft-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}
.ft-modal-foot {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

/* ─────────────────────────────────────────────────────────
   10. Компонент: ft-toast
   Создаётся JS-компонентом FT.ui.toast(...)
   ───────────────────────────────────────────────────────── */
#ft-toast-container {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: flex;
  flex-direction: column-reverse;
  gap: 8px;
  z-index: var(--sh-z-toast, 9500);
  pointer-events: none;
}

.ft-toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  min-width: 240px;
  max-width: 360px;
  pointer-events: all;
  animation: ft-toast-in .2s ease;
}
.ft-toast.removing { animation: ft-toast-out .2s ease forwards; }

.ft-toast-icon { font-size: 15px; flex-shrink: 0; margin-top: 1px; }
.ft-toast-body { flex: 1; min-width: 0; }
.ft-toast-title { font-size: var(--text-base); font-weight: 600; color: var(--strong); }
.ft-toast-text { font-size: var(--text-sm); color: var(--muted); margin-top: 2px; line-height: 1.4; }
.ft-toast-x { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 14px; padding: 0; flex-shrink: 0; transition: color var(--transition); }
.ft-toast-x:hover { color: var(--text); }

.ft-toast.success { border-left: 3px solid var(--green); }
.ft-toast.success .ft-toast-icon { color: var(--green-text); }
.ft-toast.error { border-left: 3px solid var(--red); }
.ft-toast.error .ft-toast-icon { color: var(--red); }
.ft-toast.warning { border-left: 3px solid var(--yellow); }
.ft-toast.warning .ft-toast-icon { color: var(--yellow-text); }
.ft-toast.info { border-left: 3px solid var(--blue); }
.ft-toast.info .ft-toast-icon { color: var(--blue); }

@keyframes ft-toast-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes ft-toast-out {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(20px); }
}

/* ─────────────────────────────────────────────────────────
   11. Компонент: ft-tooltip (CSS-only через data-tip)
   Использование: <span data-ft-tip="Текст подсказки">...</span>
   ───────────────────────────────────────────────────────── */
[data-ft-tip] {
  position: relative;
  cursor: default;
}
[data-ft-tip]::after {
  content: attr(data-ft-tip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: var(--text-xs);
  font-weight: 400;
  white-space: nowrap;
  max-width: 240px;
  white-space: normal;
  text-align: left;
  line-height: var(--lh-snug);
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--transition), visibility var(--transition);
  z-index: var(--ft-z-tooltip, 9100);
}
[data-ft-tip]:hover::after { opacity: 1; visibility: visible; }
[data-ft-tip-right]::after { left: auto; right: 0; transform: none; }
[data-ft-tip-bottom]::after { top: calc(100% + 6px); bottom: auto; }

/* ─────────────────────────────────────────────────────────
   12. Компонент: ft-seg / ft-seg-btn
   КАНОНИЧЕСКИЕ стили (auth.js содержит идентичную копию для
   обратной совместимости — будет удалена в K3+)
   ───────────────────────────────────────────────────────── */
.ft-seg {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg2);
  flex-shrink: 0;
  height: 34px;
}
.ft-seg > .ft-seg-btn:first-child { border-radius: 7px 0 0 7px; }
.ft-seg > .ft-seg-btn:last-child,
.ft-seg > :last-child .ft-seg-btn { border-radius: 0 7px 7px 0; }

.ft-seg-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 14px;
  background: transparent;
  border: none;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition);
  font-family: var(--font-base);
  white-space: nowrap;
  position: relative;
  text-decoration: none;
}
.ft-seg-btn + .ft-seg-btn::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%; bottom: 20%;
  width: 1px;
  background: var(--border);
}
.ft-seg-btn i { font-size: 12px; transition: color var(--transition); }
.ft-seg-btn:hover { background: var(--bg3); color: var(--text); }

.ft-seg-btn.h-green:hover { color: var(--green-text); }
.ft-seg-btn.h-green:hover i { color: var(--green-text); }
.ft-seg-btn.h-blue:hover { color: var(--blue); }
.ft-seg-btn.h-blue:hover i { color: var(--blue); }
.ft-seg-btn.h-red:hover { color: var(--red); }
.ft-seg-btn.h-red:hover i { color: var(--red); }
.ft-seg-btn.h-purple:hover { color: var(--purple); }
.ft-seg-btn.h-purple:hover i { color: var(--purple); }
.ft-seg-btn.h-yellow:hover { color: var(--yellow-text); }
.ft-seg-btn.h-yellow:hover i { color: var(--yellow-text); }

.ft-seg-btn.icon-only { padding: 0 10px; }
.ft-seg-btn.active { color: var(--blue); background: var(--blue-dim); }
.ft-seg-btn.active i { color: var(--blue); }
.ft-seg-btn:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }

.ft-seg-acc-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px rgba(0,255,136,.4);
  flex-shrink: 0;
}

/* ─────────────────────────────────────────────────────────
   13. Компонент: ft-ctx-menu (глобальное контекстное меню)
   Создаётся и управляется FT.ui.ctxmenu(...)
   ───────────────────────────────────────────────────────── */
.ft-ctx-menu {
  position: fixed;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: calc(var(--sh-z-modal, 9000) - 1);
  min-width: 160px;
  overflow: hidden;
  animation: ft-ctx-in .12s ease;
}
@keyframes ft-ctx-in {
  from { opacity: 0; transform: scale(.96); }
  to   { opacity: 1; transform: scale(1); }
}
.ft-ctx-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 14px;
  background: none;
  border: none;
  color: var(--text);
  font-size: var(--text-base);
  font-family: var(--font-base);
  cursor: pointer;
  transition: background var(--transition);
  text-align: left;
}
.ft-ctx-item:hover { background: var(--bg3); }
.ft-ctx-item:focus-visible { outline: 2px solid var(--blue); outline-offset: -2px; }
.ft-ctx-item.danger { color: var(--red); }
.ft-ctx-item.danger:hover { background: var(--red-dim); }
.ft-ctx-item i { width: 16px; text-align: center; color: var(--muted); font-size: var(--text-sm); }
.ft-ctx-item:hover i { color: inherit; }
.ft-ctx-sep { height: 1px; background: var(--border); margin: 4px 0; }

/* ─────────────────────────────────────────────────────────
   14. Компонент: ft-badge / ft-tag
   ───────────────────────────────────────────────────────── */
.ft-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 700;
  background: var(--bg3);
  color: var(--muted);
  border: 1px solid var(--border);
}
.ft-badge-green { background: var(--green-dim); color: var(--green-text); border-color: var(--green-border); }
.ft-badge-red   { background: var(--red-dim);   color: var(--red);   border-color: var(--red-border); }
.ft-badge-blue  { background: var(--blue-dim);  color: var(--blue);  border-color: var(--blue-border); }
.ft-badge-yellow{ background: var(--yellow-dim);color: var(--yellow-text);border-color: var(--yellow-border); }
.ft-badge-purple{ background: var(--purple-dim);color: var(--purple);border-color: var(--purple-border); }

/* ─────────────────────────────────────────────────────────
   15. Утилиты
   ───────────────────────────────────────────────────────── */
/* Flex */
.ft-flex   { display: flex; }
.ft-flex-col { display: flex; flex-direction: column; }
.ft-center { display: flex; align-items: center; justify-content: center; }
.ft-between { display: flex; align-items: center; justify-content: space-between; }
.ft-gap-2  { gap: 4px; }
.ft-gap-4  { gap: 8px; }
.ft-gap-6  { gap: 12px; }
.ft-gap-8  { gap: 16px; }

/* Text */
.ft-text-muted  { color: var(--muted); }
.ft-text-strong { color: var(--strong); }
.ft-text-green  { color: var(--green-text); }
.ft-text-red    { color: var(--red); }
.ft-text-blue   { color: var(--blue); }
.ft-text-yellow { color: var(--yellow-text); }
.ft-text-sm     { font-size: var(--text-sm); }
.ft-text-xs     { font-size: var(--text-xs); }
.ft-fw-600      { font-weight: 600; }
.ft-fw-700      { font-weight: 700; }
.ft-truncate    { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Spacing */
.ft-mt-4  { margin-top: 8px; }
.ft-mt-6  { margin-top: 12px; }
.ft-mt-8  { margin-top: 16px; }
.ft-mb-4  { margin-bottom: 8px; }
.ft-mb-6  { margin-bottom: 12px; }
.ft-mb-8  { margin-bottom: 16px; }
.ft-p-4   { padding: 8px; }
.ft-p-6   { padding: 12px; }
.ft-p-8   { padding: 16px; }

/* Dividers */
.ft-sep { height: 1px; background: var(--border); margin: 12px 0; border: none; }
.ft-sep-v { width: 1px; background: var(--border); align-self: stretch; }

/* Loading spinner */
.ft-spin {
  width: 18px; height: 18px;
  border: 2px solid var(--border);
  border-top-color: var(--green-text);
  border-radius: 50%;
  animation: ft-spin .7s linear infinite;
  flex-shrink: 0;
}
.ft-spin-sm { width: 14px; height: 14px; }
.ft-spin-lg { width: 28px; height: 28px; border-width: 3px; }
@keyframes ft-spin { to { transform: rotate(360deg); } }

/* Empty state */
.ft-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
  color: var(--muted);
  gap: 10px;
}
.ft-empty i { font-size: 36px; opacity: .35; }
.ft-empty-title { font-size: var(--text-md); font-weight: 600; color: var(--text); }
.ft-empty-text { font-size: var(--text-sm); line-height: var(--lh-normal); }

/* Scrollbar */
.ft-scroll {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) transparent;
}
.ft-scroll::-webkit-scrollbar { width: 4px; height: 4px; }
.ft-scroll::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 2px;
}

/* Screen-reader only — WCAG 2.1 AA (1.3.1) */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Focus-visible ring — reusable helper (A11Y-02, Закон 15).
   Добавь class="focus-visible-ring" на любую кастомную кнопку
   для гарантированного outline при keyboard-навигации. */
.focus-visible-ring:focus-visible {
  outline: 2px solid var(--blue, #4fc3f7);
  outline-offset: 2px;
}

/* === lib/app-shell/shell.css === */
/* ============================================================
   FOMO&TEMA · App Shell — единый каркас платформы
   ------------------------------------------------------------
   Источник: memory/strategies/STRATEGY_ECOSYSTEM.md Часть 16.2
              memory/project/project_unified_cockpit.md раздел 2

   Grid layout: [topbar]
                [sidebar | main | right-panel]

   Темы: data-theme="dark"|"light"|"contrast"
   Акцент: data-accent="green"|"blue"|"purple"|"orange"|"cyan"
   Плотность: data-density="compact"|"normal"|"spacious"
   ============================================================ */

/* ─────────────────────────────────────────────────────────
   CSS-переменные: общие для всего App Shell
   ───────────────────────────────────────────────────────── */
:root {
  /* Layout */
  --sh-topbar-h: 52px;
  --sh-sidebar-w: 260px;
  --sh-sidebar-w-collapsed: 68px;
  --sh-right-w: 260px;
  --sh-right-w-collapsed: 0px;    /* панель полностью скрывается; видна только
                                     кнопка-язычок toggle, торчащая в main */
  --sh-transition: .28s cubic-bezier(.4, 0, .2, 1);
  --sh-radius: 8px;

  /* Типографика */
  --sh-font-base: 'Inter', 'Urbanist', system-ui, -apple-system, sans-serif;
  --sh-font-numeric: 'Inter Tight', 'JetBrains Mono', ui-monospace, monospace;

  /* Z-index шкала */
  --sh-z-topbar: 200;
  --sh-z-sidebar: 190;
  --sh-z-right-panel: 180;
  --sh-z-boundary: 201;
  --sh-z-dropdown: 1000;
  --sh-z-modal: 9000;
  --sh-z-toast: 9500;
}

/* Плотность интерфейса */
[data-density="compact"] {
  --sh-row-h: 28px;
  --sh-gap: 8px;
  --sh-pad: 10px;
}
[data-density="normal"],
:root:not([data-density]) {
  --sh-row-h: 36px;
  --sh-gap: 12px;
  --sh-pad: 14px;
}
[data-density="spacious"] {
  --sh-row-h: 44px;
  --sh-gap: 16px;
  --sh-pad: 18px;
}

/* Акценты (используют общую --accent из старой темы, если задана, иначе своё) */
:root:not([data-accent]) { --sh-accent: var(--green, #0d9488); }
[data-accent=green]    { --sh-accent: #0d9488; }
[data-accent="blue"]     { --sh-accent: #3b82f6; }
[data-accent="purple"]   { --sh-accent: #a855f7; }
[data-accent="orange"]   { --sh-accent: #f97316; }
[data-accent="cyan"]     { --sh-accent: #06b6d4; }

/* ─────────────────────────────────────────────────────────
   Shell root: grid-layout 12px rail, адаптив
   ───────────────────────────────────────────────────────── */
html, body { height: 100%; margin: 0; }
body.ft-shell {
  display: block; /* сбрасываем любой flex/grid от страничного CSS */
  font-family: var(--sh-font-base);
  background: var(--bg, #0a0a0a);
  color: var(--text, #e5e5e5);
  overflow: hidden; /* скроллы — внутри регионов */
}

.ft-shell-root {
  display: grid;
  height: 100vh;
  grid-template-columns: var(--sh-sidebar-w) 1fr var(--sh-right-w);
  grid-template-rows: var(--sh-topbar-h) 1fr;
  grid-template-areas:
    "topbar topbar topbar"
    "sidebar main  rightpanel";
  transition: grid-template-columns var(--sh-transition);
}
/* Подавить transition при инициализации — иначе правая панель анимируется при каждой загрузке */
.ft-shell-root[data-initializing] { transition: none !important; }
/* Pre-init: состояние панелей из localStorage до того как JS запустился.
   Атрибуты на <html> ставит инлайн-скрипт в <head> синхронно.
   HTML по умолчанию: data-right-collapsed="0" (открыто) — CSS-дефолт показывает 260px.
   Инлайн-скрипт ставит data-right-init="1" когда панель была закрыта, CSS скрывает её.
   После rAF JS убирает data-right-init — правила ниже перестают работать,
   управление передаётся data-right-collapsed на .ft-shell-root. */
html[data-side-init="1"] .ft-shell-root { grid-template-columns: 0px 1fr var(--sh-right-w); }
html[data-right-init="1"] .ft-shell-root { grid-template-columns: var(--sh-sidebar-w) 1fr 0px; }
html[data-side-init="1"][data-right-init="1"] .ft-shell-root { grid-template-columns: 0px 1fr 0px; }

.ft-shell-root[data-sidebar-collapsed="1"] {
  grid-template-columns: 0px 1fr var(--sh-right-w);
}
.ft-shell-root[data-right-collapsed="1"] {
  grid-template-columns: var(--sh-sidebar-w) 1fr var(--sh-right-w-collapsed);
}
.ft-shell-root[data-sidebar-collapsed="1"][data-right-collapsed="1"] {
  grid-template-columns: 0px 1fr var(--sh-right-w-collapsed);
}

.ft-shell-topbar  { grid-area: topbar;     z-index: var(--sh-z-topbar); }
.ft-shell-side    { grid-area: sidebar;    z-index: var(--sh-z-sidebar); }
.ft-shell-main    { grid-area: main;       overflow: auto; position: relative; }
.ft-shell-right   { grid-area: rightpanel; z-index: var(--sh-z-right-panel); }

/* ─────────────────────────────────────────────────────────
   Topbar
   ───────────────────────────────────────────────────────── */
.ft-shell-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 16px;
  background: var(--bg2, #141414);
  border-bottom: 1px solid var(--border, #2a2a2a);
  min-height: var(--sh-topbar-h);
}

/* ─────────────────────────────────────────────────────────
   Sidebar container
   ───────────────────────────────────────────────────────── */
.ft-shell-side {
  background: var(--bg2, #141414);
  border-right: 1px solid var(--border, #2a2a2a);
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Кнопка-граница «свернуть по центру» */
.ft-shell-sidebar-toggle {
  position: absolute;
  top: 50%;
  right: -12px;
  transform: translateY(-50%);
  width: 24px;
  height: 48px;
  background: var(--bg2, #141414);
  border: 1px solid var(--border, #2a2a2a);
  border-left: none;
  border-radius: 0 var(--sh-radius) var(--sh-radius) 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sh-accent, #0d9488);
  font-size: 11px;
  transition: background .15s, color .15s, right var(--sh-transition);
  z-index: var(--sh-z-boundary);
  padding: 0;
}
.ft-shell-sidebar-toggle { font-size: 13px; }
.ft-shell-sidebar-toggle:hover { background: var(--bg3, #1a1a1a); color: var(--sh-accent); }

/* ─────────────────────────────────────────────────────────
   Main content area
   ───────────────────────────────────────────────────────── */
.ft-shell-main {
  background: var(--bg, #0a0a0a);
  padding: var(--sh-pad, 14px);
}

/* Route container */
.ft-shell-route {
  min-height: calc(100% - 4px);
  display: block;
  opacity: 1;
  transition: opacity .18s ease;
}
.ft-shell-route[data-loading="1"] { opacity: .45; pointer-events: none; }

/* ─────────────────────────────────────────────────────────
   Right panel
   ───────────────────────────────────────────────────────── */
.ft-shell-right {
  background: var(--bg2, #141414);
  border-left: 1px solid var(--border, #2a2a2a);
  display: flex;
  flex-direction: column;
  /* overflow hidden — зеркально левому sidebar: кнопка toggle (-12px) тоже
     частично обрезается, чтобы выглядеть одинаковой полоской-язычком. */
  overflow: hidden;
  position: relative;
}
/* Свёрнутая правая панель — ширина 0, видна только кнопка-язычок toggle.
   Тело и табы скрыты, панель не занимает места в сетке; overflow:visible —
   чтобы абсолютная кнопка на left:-12px торчала в main-область. */
.ft-shell-root[data-right-collapsed="1"] .ft-shell-right {
  overflow: visible !important;
  border-left: none;
}
.ft-shell-root[data-right-collapsed="1"]:not([data-menu-mode="right-hover"]):not([data-menu-mode="swing"]) .ft-shell-right .ft-rp-tabs,
.ft-shell-root[data-right-collapsed="1"]:not([data-menu-mode="right-hover"]):not([data-menu-mode="swing"]) .ft-shell-right .ft-rp-body,
.ft-shell-root[data-right-collapsed="1"]:not([data-menu-mode="right-hover"]):not([data-menu-mode="swing"]) .ft-shell-right .ft-rp-header-text {
  display: none !important;
}

/* Свёрнутый левый sidebar — зеркало правой: ширина 0, виден только язычок
   toggle (right:-12px торчит в main). Контент полностью скрыт (без icon-bar).
   padding:0 — у .ft-shell-side базовый padding 14px 12px (от парного класса .ft-sb
   в sidebar.css; .ft-shell-side и .ft-sb — один элемент с двумя классами); при
   box-sizing:content-box горизонтальный padding 12+12 даёт видимую полосу 24px
   поверх 0-grid-колонки. Правая .ft-shell-right padding не имеет изначально,
   поэтому сворачивается чисто до 0. Обнуляем padding в collapsed — и левая
   ведёт себя симметрично правой (фикс «полоски» 2026-06-04). */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-shell-side {
  overflow: visible !important;
  border-right: none;
  padding: 0;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-shell-side > *:not(.ft-shell-sidebar-toggle) {
  display: none !important;
}

/* Кнопка свернуть правую панель */
.ft-shell-right-toggle {
  position: absolute;
  top: 50%;
  left: -12px;
  transform: translateY(-50%);
  width: 24px;
  height: 48px;
  background: var(--bg2, #141414);
  border: 1px solid var(--border, #2a2a2a);
  border-right: none;
  border-radius: var(--sh-radius) 0 0 var(--sh-radius);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sh-accent, #0d9488);
  font-size: 11px;
  transition: background .15s, color .15s;
  z-index: var(--sh-z-boundary);
  padding: 0;
}
.ft-shell-right-toggle { font-size: 13px; }
.ft-shell-right-toggle:hover { background: var(--bg3, #1a1a1a); color: var(--sh-accent); }

/* ─────────────────────────────────────────────────────────
   Адаптив
   ───────────────────────────────────────────────────────── */

/* 1024–1440 — правая панель по кнопке (не занимает сетку постоянно) */
@media (max-width: 1439px) {
  .ft-shell-root:not([data-right-collapsed="1"]) {
    grid-template-columns: var(--sh-sidebar-w) 1fr var(--sh-right-w);
  }
  .ft-shell-root[data-sidebar-collapsed="1"]:not([data-right-collapsed="1"]) {
    grid-template-columns: 0px 1fr var(--sh-right-w);
  }
}

/* 768–1024 — sidebar оверлеем (перекрываем все collapsed-состояния) */
@media (max-width: 1023px) {
  /* Sidebar всегда 0 в сетке — он показывается через position:fixed */
  .ft-shell-root,
  .ft-shell-root[data-sidebar-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="0"] {
    grid-template-columns: 0 1fr var(--sh-right-w);
  }
  .ft-shell-root[data-right-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="1"][data-right-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="0"][data-right-collapsed="1"] {
    grid-template-columns: 0 1fr 0;
  }
  .ft-shell-side {
    position: fixed;
    top: var(--sh-topbar-h);
    bottom: 0;
    left: 0;
    width: var(--sh-sidebar-w);
    transform: translateX(-100%);
    transition: transform var(--sh-transition);
    box-shadow: 0 0 24px rgba(0,0,0,.4);
  }
  .ft-shell-root[data-mobile-sidebar="1"] .ft-shell-side {
    transform: translateX(0);
  }
  /* Backdrop — затемнение позади открытого мобильного sidebar */
  .ft-shell-root[data-mobile-sidebar="1"]::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    z-index: calc(var(--sh-z-sidebar) - 1);
    cursor: pointer;
  }
  .ft-shell-sidebar-toggle { display: none; }
}

/* <768 — полная мобильная */
@media (max-width: 768px) {
  /* !important — единственный способ перебить высокоспецифичные base-правила для collapsed-комбинаций */
  .ft-shell-root,
  .ft-shell-root[data-sidebar-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="0"],
  .ft-shell-root[data-right-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="1"][data-right-collapsed="1"],
  .ft-shell-root[data-sidebar-collapsed="0"][data-right-collapsed="1"] {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-areas: "topbar" "main" !important;
  }
  /* Sidebar скрыт по умолчанию; показывается только как overlay */
  .ft-shell-side {
    display: none !important;
  }
  .ft-shell-root[data-mobile-sidebar="1"] .ft-shell-side {
    display: flex !important;
    position: fixed !important;
    top: var(--sh-topbar-h);
    bottom: 0;
    left: 0;
    width: var(--sh-sidebar-w);
    z-index: var(--sh-z-sidebar);
    transform: none !important;
  }
  .ft-shell-right { display: none !important; }
  .ft-shell-topbar { overflow-x: clip; min-width: 0; }
  .ft-shell-main { padding: 10px; overflow-x: hidden; min-width: 0; }
}

/* ─────────────────────────────────────────────────────────
   Scrollbars
   ───────────────────────────────────────────────────────── */
.ft-shell-side,
.ft-shell-right,
.ft-shell-main {
  scrollbar-width: thin;
  scrollbar-color: var(--border, #2a2a2a) transparent;
}
.ft-shell-side::-webkit-scrollbar,
.ft-shell-right::-webkit-scrollbar,
.ft-shell-main::-webkit-scrollbar { width: 6px; height: 6px; }
.ft-shell-side::-webkit-scrollbar-thumb,
.ft-shell-right::-webkit-scrollbar-thumb,
.ft-shell-main::-webkit-scrollbar-thumb {
  background: var(--border, #2a2a2a);
  border-radius: 3px;
}
.ft-shell-side::-webkit-scrollbar-thumb:hover,
.ft-shell-right::-webkit-scrollbar-thumb:hover,
.ft-shell-main::-webkit-scrollbar-thumb:hover { background: var(--sh-accent, #0d9488); }

/* ─────────────────────────────────────────────────────────
   Skeleton / loader
   ───────────────────────────────────────────────────────── */
.ft-shell-skeleton {
  padding: 32px;
  text-align: center;
  color: var(--sh-accent, #0d9488);
  font-size: 13px;
}
.ft-shell-skeleton::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--border, #2a2a2a);
  border-top-color: var(--sh-accent);
  border-radius: 50%;
  animation: ft-sh-spin .7s linear infinite;
  vertical-align: middle;
  margin-right: 10px;
}
@keyframes ft-sh-spin { to { transform: rotate(360deg); } }

/* ─────────────────────────────────────────────────────────
   FOUC: первичный рендер без shell
   ───────────────────────────────────────────────────────── */
.ft-shell-loading .ft-shell-root > * {
  visibility: hidden;
}
.ft-shell-loading::after {
  content: '';
  position: fixed; inset: 0;
  background: var(--bg, #0a0a0a);
  z-index: 999999;
  animation: ft-sh-fadeout .3s ease .5s forwards;
}
@keyframes ft-sh-fadeout { to { opacity: 0; visibility: hidden; } }

/* ─────────────────────────────────────────────────────────
   Menu modes (4 режима оформления меню — см. shell.js setMenuMode)
   data-menu-mode принимает значения: both | right-hover | left-hover | swing.
   - both         — без override, панели управляются data-{sidebar,right}-collapsed.
   - right-hover  — правое меню всегда узкая полоса; hover на полосу разворачивает её overlay-ом поверх main.
   - left-hover   — то же для левого.
   - swing        — оба меню узкие полосы; hover любого разворачивает только его (другое не трогается).
   Hover-overlay'ы НЕ двигают grid и не влияют на ширину main, чтобы контент не дёргался.
   ───────────────────────────────────────────────────────── */
@media (min-width: 1024px) {
  /* Тонкая полоса 6px для hover-режимов (есть куда навести, контент не виден).
     Реализация через position:fixed + transform: translateX — анимация плавная,
     grid не меняется при hover, поэтому top-bar и main не дёргаются. */
  .ft-shell-root[data-menu-mode="right-hover"],
  .ft-shell-root[data-menu-mode="left-hover"],
  .ft-shell-root[data-menu-mode="swing"] {
    --sh-hover-strip-w: 6px;
  }

  /* Grid: hover-режим форсирует ширину СВОЕЙ панели в полосу 6px,
     противоположная панель продолжает уважать data-{sidebar,right}-collapsed
     (чтобы юзер мог вручную её сворачивать toggle-кнопкой). */
  .ft-shell-root[data-menu-mode="right-hover"] {
    grid-template-columns: var(--sh-sidebar-w) 1fr var(--sh-hover-strip-w);
  }
  .ft-shell-root[data-menu-mode="right-hover"][data-sidebar-collapsed="1"] {
    grid-template-columns: 0px 1fr var(--sh-hover-strip-w);
  }
  .ft-shell-root[data-menu-mode="left-hover"] {
    grid-template-columns: var(--sh-hover-strip-w) 1fr var(--sh-right-w);
  }
  .ft-shell-root[data-menu-mode="left-hover"][data-right-collapsed="1"] {
    grid-template-columns: var(--sh-hover-strip-w) 1fr var(--sh-right-w-collapsed);
  }
  .ft-shell-root[data-menu-mode="swing"] {
    grid-template-columns: var(--sh-hover-strip-w) 1fr var(--sh-hover-strip-w);
  }

  /* Правая панель в hover-режимах: вытащена из grid в position:fixed,
     полная ширина, по дефолту сдвинута наружу (видно только 6px),
     hover возвращает её на место — плавно анимируется transform. */
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right {
    position: fixed;
    top: var(--sh-topbar-h);
    right: 0;
    bottom: 0;
    width: var(--sh-right-w);
    transform: translateX(calc(100% - var(--sh-hover-strip-w)));
    transition: transform .25s ease, box-shadow .2s ease;
    z-index: calc(var(--sh-z-right-panel) + 10);
    box-shadow: none;
    will-change: transform;
  }
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right:hover,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right:hover {
    transform: translateX(0);
    box-shadow: -8px 0 24px rgba(0,0,0,.45);
  }

  /* Левая панель — то же самое, наружу влево. */
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side {
    position: fixed;
    top: var(--sh-topbar-h);
    left: 0;
    bottom: 0;
    width: var(--sh-sidebar-w);
    transform: translateX(calc(-100% + var(--sh-hover-strip-w)));
    transition: transform .25s ease, box-shadow .2s ease;
    z-index: calc(var(--sh-z-sidebar) + 10);
    box-shadow: none;
    will-change: transform;
  }
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side:hover,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side:hover {
    transform: translateX(0);
    box-shadow: 8px 0 24px rgba(0,0,0,.45);
  }

  /* Тонкая полоса-подсказка по краю (узнаётся как «зона hover»).
     Левая граница для правой панели, правая — для левой. */
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right::before,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right::before {
    content: "";
    position: absolute;
    left: 0; top: 0;
    width: var(--sh-hover-strip-w);
    height: 100%;
    background: var(--bg2, #141414);
    border-left: 1px solid var(--border, #2a2a2a);
    pointer-events: none;
    transition: opacity .2s ease;
  }
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side::before,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side::before {
    content: "";
    position: absolute;
    right: 0; top: 0;
    width: var(--sh-hover-strip-w);
    height: 100%;
    background: var(--bg2, #141414);
    border-right: 1px solid var(--border, #2a2a2a);
    pointer-events: none;
    transition: opacity .2s ease;
  }
  /* При раскрытии (hover) полоска-подсказка исчезает */
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right:hover::before,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right:hover::before,
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side:hover::before,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side:hover::before {
    opacity: 0;
  }

  /* Индикатор «здесь меню»: три точки по центру полосы (вертикально).
     Реализовано через одну точку + box-shadow на 2 копии (выше и ниже). */
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right::after,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right::after {
    content: "";
    position: absolute;
    left: calc(var(--sh-hover-strip-w) / 2);
    top: 50%;
    width: 3px; height: 3px;
    border-radius: 50%;
    background: var(--sh-accent, #0d9488);
    transform: translate(-50%, -50%);
    box-shadow:
      0 -8px 0 var(--sh-accent, #0d9488),
      0  8px 0 var(--sh-accent, #0d9488);
    transition: background .15s, box-shadow .15s, opacity .2s ease;
    pointer-events: none;
  }
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side::after,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side::after {
    content: "";
    position: absolute;
    right: calc(var(--sh-hover-strip-w) / 2);
    top: 50%;
    width: 3px; height: 3px;
    border-radius: 50%;
    background: var(--sh-accent, #0d9488);
    transform: translate(50%, -50%);
    box-shadow:
      0 -8px 0 var(--sh-accent, #0d9488),
      0  8px 0 var(--sh-accent, #0d9488);
    transition: background .15s, box-shadow .15s, opacity .2s ease;
    pointer-events: none;
  }
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right:hover::after,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right:hover::after,
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-side:hover::after,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-side:hover::after {
    opacity: 0;
  }

  /* В hover-режимах прячем toggle-кнопки (они не нужны) */
  .ft-shell-root[data-menu-mode="right-hover"] .ft-shell-right-toggle,
  .ft-shell-root[data-menu-mode="left-hover"] .ft-shell-sidebar-toggle,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-right-toggle,
  .ft-shell-root[data-menu-mode="swing"] .ft-shell-sidebar-toggle {
    display: none;
  }
}


/* ─────────────────────────────────────────────────────────
   LFND-MOB-002 + WCAG 2.5.5 + topbar compact (2026-06-02)
   1) iOS no-zoom: font-size 16px на input/textarea/select при ≤768px
   2) Touch targets ≥44×44px: ft-tb-btn / modal-close / btn-sm / [class*="close-btn"]
   3) Mobile topbar ≤480px: AI/lang/theme показываем как icon-only вместо display:none
   Все правки изолированы в media query mobile — desktop не затронут.
   ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  /* 1) iOS Safari зумит при focus на input с font-size <16px — фиксируем минимум 16px */
  input, textarea, select { font-size: 16px !important; }

  /* 2) WCAG 2.5.5 — минимальная touch target 44×44px на mobile */
  .ft-tb-btn,
  .modal-close,
  .btn-sm,
  [class*="close-btn"] {
    min-width: 44px !important;
    min-height: 44px !important;
  }
}

/* 3) Mobile топбар ≤480px: возвращаем AI/lang/theme компактными иконками вместо display:none
      (donate и balance оставляем скрытыми — донат не критичен, балансу нужна цифра).
      Перебиваем существующий @media(max-width:480px) с display:none!important. */
@media (max-width: 480px) {
  #ft-tb-ai,
  #ft-tb-lang-wrap,
  #ft-tb-theme {
    display: inline-flex !important;
    min-width: 44px !important;
    min-height: 44px !important;
    padding: 0 !important;
  }
  /* В компактном виде прячем подписи рядом с иконкой если они есть */
  #ft-tb-ai .ft-tb-btn-label,
  #ft-tb-lang-wrap .ft-tb-btn-label,
  #ft-tb-theme .ft-tb-btn-label { display: none !important; }
}

/* === lib/ui/topbar.css === */
/* FOMO&TEMA · topbar component styles. Injected by topbar.js via <link>. */

.ft-tb { display:flex; align-items:center; gap:10px; width:100%; height:100%; position:relative; box-sizing:border-box; padding-right:30px }
.ft-tb-spacer { flex:1 }

/* hamburger — mobile only (<1024px) */
.ft-tb-menu { display:none; align-items:center; justify-content:center; width:36px; height:36px; background:transparent; border:1px solid var(--border,#2a2a2a); border-radius:6px; cursor:pointer; color:var(--text,#e5e5e5); font-size:16px; flex-shrink:0; transition:background .12s,border-color .12s }
.ft-tb-menu:hover { background:var(--bg3,#1a1a1a); border-color:var(--sh-accent) }
@media(max-width:1023px) { .ft-tb-menu { display:flex } }

/* search bar trigger */
.ft-tb-search { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:480px; max-width:calc(100% - 640px); display:flex; align-items:center; gap:8px; padding:7px 12px; background:var(--bg3,#1a1a1a); border:1px solid var(--border,#2a2a2a); border-radius:8px; color:var(--muted,#808080); font-size:13px; cursor:pointer; transition:border-color .15s,background .15s; z-index:1 }
@media(max-width:1439px) { .ft-tb-search { width:360px } }
@media(max-width:1023px) { .ft-tb-search { width:220px; max-width:calc(100% - 440px) } }
.ft-tb-search:hover { border-color:var(--sh-accent) }
.ft-tb-search i { opacity:.7 }
.ft-tb-search-placeholder { flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.ft-tb-search-kbd { font-family:var(--sh-font-numeric); font-size:11px; padding:2px 6px; background:var(--bg2,#141414); border:1px solid var(--border,#2a2a2a); border-radius:4px; opacity:.7 }

/* button */
.ft-tb-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; height:32px; min-width:32px; padding:0 10px; background:transparent; border:1px solid var(--border,#2a2a2a); color:var(--text,#e5e5e5); border-radius:6px; cursor:pointer; transition:background .12s,border-color .12s,color .12s; font-size:12.5px; white-space:nowrap; text-decoration:none }
.ft-tb-btn:hover { background:var(--bg3,#1a1a1a); border-color:var(--sh-accent); color:var(--strong,#fff) }
.ft-tb-btn:focus-visible { outline:2px solid var(--blue); outline-offset:2px }
.ft-tb-btn.primary { background:var(--sh-accent); color:#000; border-color:var(--sh-accent); font-weight:700 }
.ft-tb-btn.primary:hover { filter:brightness(1.1); color:#000 }
.ft-tb-btn[disabled] { opacity:.5; cursor:not-allowed }
.ft-tb-btn[disabled]:hover { background:transparent; border-color:var(--border,#2a2a2a) }
.ft-tb-btn i { font-size:14px }
.ft-tb-btn-label { font-size:12.5px }

/* notification badge */
.ft-tb-notif-wrap { position:relative }
.ft-tb-notif-badge { position:absolute; top:2px; right:2px; min-width:8px; height:8px; padding:0; background:var(--red,#f6465d); color:#fff; border-radius:999px; font-size:0; font-weight:700; display:flex; align-items:center; justify-content:center; pointer-events:none; line-height:1; box-shadow:0 0 0 2px var(--bg,#0b0e11) }
.ft-tb-notif-badge:not(:empty) { min-width:14px; height:14px; padding:0 4px; font-size:9px; top:-2px; right:-2px }
/* LD6 2026-06-17: бейдж сообщений зелёный (отличать от красного колокола уведомлений; мобила уже зелёная) */
.ft-tb-msg-badge { background:var(--green,#0d9488) }

/* balance */
.ft-tb-balance { font-family:var(--sh-font-numeric); font-weight:600 }

/* account dropdown */
.ft-tb-acc { position:relative }
.ft-tb-acc-avatar { width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg,var(--sh-accent),#4fc3f7); color:#000; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px }
.ft-tb-acc-avatar.admin { background:linear-gradient(135deg,#f7c948,#ff9b5a) }
.ft-tb-dd { position:absolute; top:calc(100% + 6px); right:0; min-width:240px; background:var(--bg2,#141414); border:1px solid var(--border,#2a2a2a); border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,.4); display:none; z-index:var(--sh-z-dropdown,1000); overflow:hidden }
.ft-tb-dd.open { display:block }
.ft-tb-dd-head { padding:10px 14px; border-bottom:1px solid var(--border,#2a2a2a); display:flex; gap:10px; align-items:center }
.ft-tb-dd-head .ft-tb-acc-avatar { width:32px; height:32px; font-size:13px; flex-shrink:0; align-self:flex-start; margin-top:2px }
.ft-tb-dd-name { font-size:13px; font-weight:600; color:var(--strong,#fff) }
.ft-tb-dd-handle { font-size:11px; color:var(--muted,#808080) }
/* S-tier-menu 2026-06-05: строка тарифа под @handle, вся строка — ссылка на /pricing/ */
.ft-tb-dd-tier { display:flex; align-items:center; gap:6px; margin-top:6px; padding:4px 6px; margin-left:-6px; border-radius:6px; text-decoration:none; transition:background .12s; cursor:pointer }
.ft-tb-dd-tier:hover { background:var(--bg3,#1a1a1a) }
.ft-tb-dd-tier-badge { display:inline-block; padding:2px 7px; border-radius:4px; font-size:10px; font-weight:700; letter-spacing:.4px; color:#fff; line-height:1.4; text-transform:uppercase }
.ft-tb-dd-tier-badge.ft-tier-free { background:var(--bg3,#2a2a2a); color:var(--muted,#808080); border:1px solid var(--border,#3a3a3a) }
.ft-tb-dd-tier-badge.ft-tier-starter { background:var(--green,#0d9488); color:#fff }
.ft-tb-dd-tier-badge.ft-tier-mid     { background:var(--green,#0d9488); color:#fff }
.ft-tb-dd-tier-badge.ft-tier-pro     { background:var(--blue,#0369a1); color:#fff }
.ft-tb-dd-tier-badge.ft-tier-expert  { background:var(--blue,#0369a1); color:#fff }
.ft-tb-dd-tier-date    { font-size:11px; color:var(--muted,#808080) }
.ft-tb-dd-tier-upgrade { font-size:11px; color:var(--green,#0d9488); font-weight:500 }
.ft-tb-dd-tier-upgrade i { color:var(--green,#0d9488) }
.ft-tb-dd-section { padding:6px 0 }
.ft-tb-dd-sep { height:1px; background:var(--border,#2a2a2a) }
.ft-tb-dd-item { display:flex; align-items:center; gap:10px; padding:8px 14px; font-size:13px; color:var(--text,#e5e5e5); text-decoration:none; cursor:pointer; background:transparent; border:none; width:100%; text-align:left; transition:background .12s }
.ft-tb-dd-item:hover { background:var(--bg3,#1a1a1a) }
.ft-tb-dd-item i { width:16px; text-align:center; color:var(--muted,#808080) }
.ft-tb-dd-logout { color:var(--red,#f6465d) }
.ft-tb-dd-logout i { color:var(--red,#f6465d) }
.ft-tb-dd-logout:hover { background:rgba(246,70,93,.1) }
.ft-tb-dd-menumode-toggle.open .ft-tb-dd-menumode-chev { transform:rotate(180deg) }
.ft-tb-dd-menumode-chev { transition:transform .15s }
.ft-tb-dd-menumode-sub { padding:4px 6px 8px 30px; display:flex; flex-direction:column; gap:2px; background:var(--bg,#0a0a0a) }
.ft-tb-dd-menumode-sub[hidden] { display:none }
.ft-tb-dd-menumode-row { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:6px; cursor:pointer; font-size:12.5px; color:var(--text,#e5e5e5); transition:background .12s }
.ft-tb-dd-menumode-row:hover { background:var(--bg3,#1a1a1a) }
.ft-tb-dd-menumode-row input[type="radio"] { accent-color:var(--sh-accent,#00ff88); margin:0; cursor:pointer }
.ft-tb-dd-menumode-row span { line-height:1.2 }
.ft-tb-dd-reset { color:var(--yellow,#f7c948) }
.ft-tb-dd-reset i { color:var(--yellow,#f7c948) }
.ft-tb-dd-reset:hover { background:rgba(247,201,72,.1) }

/* lang picker */
.ft-tb-lang-dd { position:absolute; top:calc(100% + 6px); right:0; min-width:120px; background:var(--bg2,#141414); border:1px solid var(--border,#2a2a2a); border-radius:8px; box-shadow:0 8px 24px rgba(0,0,0,.4); display:none; z-index:var(--sh-z-dropdown,1000); overflow:hidden }
.ft-tb-lang-dd.open { display:block }
.ft-tb-lang-item { display:flex; align-items:center; gap:10px; padding:8px 14px; font-size:13px; color:var(--text,#e5e5e5); cursor:pointer; background:transparent; border:none; width:100%; text-align:left; transition:background .12s }
.ft-tb-lang-item:hover { background:var(--bg3,#1a1a1a) }
.ft-tb-lang-item.active { color:var(--sh-accent) }

/* search modal */
.ft-tb-search-modal { position:fixed; top:20vh; left:50%; transform:translateX(-50%); width:620px; max-width:calc(100vw - 40px); background:var(--bg2,#141414); border:1px solid var(--border,#2a2a2a); border-radius:12px; box-shadow:0 16px 48px rgba(0,0,0,.7); z-index:var(--sh-z-modal,9000); display:none; overflow:hidden }
.ft-tb-search-modal.open { display:block }
.ft-tb-search-modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:calc(var(--sh-z-modal,9000) - 1); display:none }
.ft-tb-search-modal-backdrop.open { display:block }
.ft-tb-search-modal-top { display:flex; align-items:center; gap:10px; padding:0 16px; border-bottom:1px solid var(--border,#2a2a2a) }
.ft-tb-search-modal-top i { color:var(--muted,#808080); font-size:15px; flex-shrink:0 }
.ft-tb-search-modal-input { flex:1; padding:16px 0; background:transparent; border:none; color:var(--text,#e5e5e5); font-size:15px; outline:none }
.ft-tb-search-modal-clear { background:none; border:none; color:var(--muted,#808080); cursor:pointer; padding:6px; border-radius:4px; font-size:12px; display:none }
.ft-tb-search-modal-clear.visible { display:block }
.ft-tb-search-modal-body { max-height:420px; overflow-y:auto }
.ft-tb-sr-section { padding:8px 0 }
.ft-tb-sr-label { padding:4px 16px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--muted,#808080) }
.ft-tb-sr-item { display:flex; align-items:center; gap:12px; padding:10px 16px; cursor:pointer; transition:background .1s; text-decoration:none; color:var(--text,#e5e5e5) }
.ft-tb-sr-item:hover,.ft-tb-sr-item.active { background:var(--bg3,#1a1a1a) }
.ft-tb-sr-icon { width:30px; height:30px; border-radius:8px; background:var(--bg3,#1a1a1a); display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--muted,#808080); flex-shrink:0 }
.ft-tb-sr-icon.ticker { background:rgba(0,255,136,.08); color:#00ff88 }
.ft-tb-sr-icon.page { background:rgba(97,218,251,.08); color:#61dafb }
.ft-tb-sr-info { flex:1; min-width:0 }
.ft-tb-sr-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.ft-tb-sr-sub { font-size:11px; color:var(--muted,#808080) }
.ft-tb-sr-meta { font-size:12px; text-align:right; flex-shrink:0 }
.ft-tb-sr-pos { color:var(--green,#00ff88) }
.ft-tb-sr-neg { color:var(--red,#f6465d) }
.ft-tb-sr-empty { padding:32px 16px; text-align:center; font-size:13px; color:var(--muted,#808080) }
.ft-tb-sr-footer { border-top:1px solid var(--border,#2a2a2a); padding:8px 16px; display:flex; gap:16px; font-size:11px; color:var(--muted,#808080) }
.ft-tb-sr-footer kbd { background:var(--bg3,#1a1a1a); border:1px solid var(--border,#2a2a2a); border-radius:4px; padding:1px 5px; font-size:10px }

/* brand */
.ft-tb-brand { display:flex; align-items:center; gap:10px; flex-shrink:0; padding:2px 4px; text-decoration:none; color:var(--strong,#fff); font-family:"Urbanist",sans-serif; font-size:17px; font-weight:800; letter-spacing:.02em; white-space:nowrap }
.ft-tb-brand i { color:var(--sh-accent); font-size:18px }
.ft-tb-brand:hover { color:var(--strong,#fff) }
@media(max-width:768px) { .ft-tb-brand span { display:none } }

/* page history nav (Назад / ⌂ / Вперёд) — на месте старой кнопки Фидбэк */
.ft-tb-nav { display:flex; align-items:center; gap:6px; margin-left:16px; flex-shrink:0 }
.ft-tb-nav-btn { display:inline-flex; align-items:center; justify-content:center; gap:5px; height:30px; padding:0 10px; background:transparent; border:1px solid var(--border,#2a2a2a); color:var(--text,#e5e5e5); border-radius:6px; cursor:pointer; font-size:12px; font-weight:600; line-height:1; white-space:nowrap; transition:background .12s,border-color .12s,color .12s,opacity .12s }
.ft-tb-nav-btn:hover:not([disabled]) { background:var(--bg3,#1a1a1a); border-color:var(--sh-accent); color:var(--strong,#fff) }
.ft-tb-nav-btn[disabled] { opacity:.4; cursor:not-allowed }
.ft-tb-nav-btn i { font-size:12px }
.ft-tb-nav-home { width:30px; padding:0; border-radius:50% }
.ft-tb-nav-home i { font-size:13px }
@media(max-width:768px) {
  .ft-tb-nav { margin-left:8px; gap:4px }
  .ft-tb-nav-btn .ft-tb-nav-lbl { display:none }
  .ft-tb-nav-btn { width:30px; padding:0; border-radius:50% }
}

/* terminal bar */
.ft-tb-term-bar { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); display:flex; align-items:center; gap:7px; padding:6px 14px; background:var(--bg3,#1a1a1a); border:1px solid var(--border,#2a2a2a); border-radius:8px; cursor:pointer; transition:border-color .15s,background .15s; font-size:12px; z-index:1; white-space:nowrap; user-select:none }
.ft-tb-term-bar:hover { border-color:rgba(0,255,136,.3) }
.ft-tb-term-bar.open { border-color:rgba(0,255,136,.35); background:var(--bg2,#141414) }
.ft-tb-term-dot { width:6px; height:6px; border-radius:50%; background:var(--sh-accent,#00ff88); flex-shrink:0; box-shadow:0 0 5px var(--sh-accent,#00ff88) }
.ft-tb-term-sep { color:var(--border,#2a2a2a); font-size:14px; line-height:1; margin:0 1px }
.ft-tb-term-stat { font-family:var(--sh-font-numeric,"monospace"); font-size:12px; color:var(--text,#c0c0c0); font-weight:600 }
.ft-tb-term-eq { color:var(--muted,#808080)!important }
.ft-tb-term-pnl { font-family:var(--sh-font-numeric,"monospace"); font-size:12px; font-weight:800 }
.ft-tb-term-pnl.pos { color:var(--sh-accent,#00ff88) }
.ft-tb-term-pnl.neg { color:var(--red,#f6465d) }
.ft-tb-term-l { color:var(--sh-accent,#00ff88); font-weight:700; font-size:11px }
.ft-tb-term-s { color:var(--red,#f6465d); font-weight:700; font-size:11px }
.ft-tb-term-arrow { font-size:9px; color:var(--muted,#808080); transition:transform .2s; margin-left:2px; flex-shrink:0 }
.ft-tb-term-bar.open .ft-tb-term-arrow { transform:rotate(180deg) }
@media(max-width:1023px) { .ft-tb-term-bar { gap:5px; padding:5px 10px } }
@media(max-width:1023px) { .ft-tb-term-eq { display:none!important } }
@media(max-width:768px) { .ft-tb-term-bar { display:none!important } }

/* mobile: bell always visible — скрываем менее приоритетные элементы (<480px) */
.ft-tb-notif-wrap { flex-shrink:0 }
@media(max-width:480px) {
  .ft-tb-notif-wrap { order:-1 }
  .ft-tb-balance { display:none!important }
  #ft-tb-ai { display:none!important }
  #ft-tb-lang-wrap { display:none!important }
  #ft-tb-theme { display:none!important }
  a[href="/donate/"] { display:none!important }
}

/* ─────────────────────────────────────────────────────────
   LFND-MOB-002 + WCAG 2.5.5 + topbar compact (2026-06-02)
   1) iOS no-zoom: font-size 16px на input/textarea/select при ≤768px
   2) Touch targets ≥44×44px: ft-tb-btn / modal-close / btn-sm / [class*="close-btn"]
   3) Mobile topbar ≤480px: AI/lang/theme показываем как icon-only вместо display:none
   Все правки изолированы в media query mobile — desktop не затронут.
   ───────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  /* 1) iOS Safari зумит при focus на input с font-size <16px — фиксируем минимум 16px */
  input, textarea, select { font-size: 16px !important; }

  /* 2) WCAG 2.5.5 — минимальная touch target 44×44px на mobile */
  .ft-tb-btn,
  .modal-close,
  .btn-sm,
  [class*="close-btn"] {
    min-width: 44px !important;
    min-height: 44px !important;
  }
}

/* 3) Mobile топбар ≤480px: возвращаем AI/lang/theme компактными иконками вместо display:none
      (donate и balance оставляем скрытыми — донат не критичен, балансу нужна цифра).
      Перебиваем существующий @media(max-width:480px) с display:none!important. */
@media (max-width: 480px) {
  #ft-tb-ai,
  #ft-tb-lang-wrap,
  #ft-tb-theme {
    display: inline-flex !important;
    min-width: 44px !important;
    min-height: 44px !important;
    padding: 0 !important;
  }
  /* В компактном виде прячем подписи рядом с иконкой если они есть */
  #ft-tb-ai .ft-tb-btn-label,
  #ft-tb-lang-wrap .ft-tb-btn-label,
  #ft-tb-theme .ft-tb-btn-label { display: none !important; }
}

/* === lib/ui/sidebar.css === */
/* FOMO&TEMA · Единый sidebar (App Shell) — стили
   Extracted from sidebar.js (was dynamic <style> inject).
   Подключается статически через <link> в HTML. */

/* root */
.ft-sb {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 14px 12px;
  gap: 4px;
  position: relative;
}

/* brand */
.ft-sb-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 6px 14px;
  text-decoration: none;
  color: var(--strong, #fff);
  font-family: "Urbanist", sans-serif;
  font-size: 18px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
}
.ft-sb-brand i {
  color: var(--sh-accent);
  flex-shrink: 0;
}
.ft-sb-brand-text {
  transition: opacity .2s;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-brand-text {
  opacity: 0;
  width: 0;
}

/* nav groups */
.ft-sb-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  margin: 2px -6px;
  padding: 0 6px;
}
.ft-sb-group {
  margin-top: 10px;
}
.ft-sb-group:first-child {
  margin-top: 0;
}
.ft-sb-group-hd {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 10px 5px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted, #808080);
  white-space: nowrap;
  overflow: hidden;
  transition: opacity .2s, color .15s;
  cursor: pointer;
  user-select: none;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  font-family: inherit;
}
.ft-sb-group-hd:hover {
  color: var(--text, #c0c0c0);
}
.ft-sb-group-icon {
  font-size: 11px;
  opacity: .7;
  flex-shrink: 0;
}
.ft-sb-group-hd-title {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ft-sb-group-chevron {
  font-size: 10px;
  opacity: .7;
  transition: transform .2s ease;
}
.ft-sb-group[data-collapsed="1"] .ft-sb-group-chevron {
  transform: rotate(-90deg);
}
.ft-sb-group-items {
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow: hidden;
  transition: max-height .25s ease, opacity .2s ease;
  max-height: 2000px;
  opacity: 1;
}
.ft-sb-group[data-collapsed="1"] .ft-sb-group-items {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-group-hd {
  opacity: 0;
  height: 0;
  padding: 0;
  margin: 0;
  cursor: default;
}
/* в свёрнутом сайдбаре группы всегда раскрыты (иконки в ряд) */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-group-items {
  max-height: none !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* item */
.ft-sb-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 6px;
  color: var(--muted, #a0a0a0);
  text-decoration: none;
  font-size: 13px;
  transition: background .12s, color .12s;
  position: relative;
  white-space: nowrap;
  border-left: 2px solid transparent;
}
.ft-sb-item:hover {
  background: var(--bg3, #1a1a1a);
  color: var(--strong, #fff);
}
.ft-sb-item.active {
  background: var(--bg3, #1a1a1a);
  color: var(--strong, #fff);
  border-left-color: var(--sh-accent);
}
.ft-sb-item i {
  width: 18px;
  font-size: 14px;
  text-align: center;
  flex-shrink: 0;
  color: var(--muted, #a0a0a0);
}
.ft-sb-item.active i,
.ft-sb-item:hover i {
  color: var(--sh-accent);
}
.ft-sb-item-label {
  flex: 1;
  min-width: 0;
  text-overflow: ellipsis;
  overflow: hidden;
  transition: opacity .2s;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-item-label {
  opacity: 0;
  width: 0;
}
.ft-sb-item-badge {
  background: var(--red, #f6465d);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 8px;
  min-width: 18px;
  text-align: center;
  flex-shrink: 0;
}
/* Статичная метка состояния пункта меню: BETA (раннее использование),
   NEW (новый раздел). Не блокирует клик, не зависит от тарифа.
   Отличается от SOON (янтарный, ft-features.css) и locked (тарифный). */
.ft-sb-state-tag {
  display: inline-block;
  font-family: 'Urbanist', 'Lato', sans-serif;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 6px;
  flex-shrink: 0;
  pointer-events: none;
  line-height: 1;
}
.ft-sb-state-tag--beta {
  background: rgba(3,105,161,.14);
  color: var(--blue, #0369a1);
  border: 1px solid rgba(3,105,161,.3);
}
.ft-sb-state-tag--new {
  background: rgba(13,148,136,.14);
  color: var(--green, #0d9488);
  border: 1px solid rgba(13,148,136,.3);
}
/* В свёрнутом sidebar метка прячется вместе с label */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-state-tag {
  display: none;
}
.ft-sb-item--lock::after {
  content: "\f023";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  opacity: .4;
  margin-left: auto;
  font-size: 10px;
}

/* Главная кнопка ЦУТ — минималистичная: тонкая рамка, без glow,
   акцент проявляется только на hover и когда кнопка активна. */
.ft-sb-hero {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 2px auto 10px;
  width: calc(100% - 20px);
  max-width: 220px;
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--text, #d1d4dc);
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--border, #2a2a2a);
  transition: color .15s ease, border-color .15s ease, background .15s ease;
  flex-shrink: 0;
}
.ft-sb-hero i {
  color: var(--muted, #848e9c);
  font-size: 13px;
  transition: color .15s ease;
}
.ft-sb-hero:hover {
  color: var(--strong, #fff);
  border-color: color-mix(in oklab, var(--sh-accent, #00ff88) 55%, var(--border, #2a2a2a));
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 6%, transparent);
}
.ft-sb-hero:hover i {
  color: var(--sh-accent, #00ff88);
}
.ft-sb-hero.active {
  color: var(--strong, #fff);
  border-color: color-mix(in oklab, var(--sh-accent, #00ff88) 60%, var(--border, #2a2a2a));
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 8%, transparent);
}
.ft-sb-hero.active i {
  color: var(--sh-accent, #00ff88);
}
.ft-sb-hero-label {
  transition: opacity .2s;
}
/* В collapsed-сайдбаре hero-кнопка не нужна — её роль выполняет
   brand-логотип FOMO&TEMA сверху, он тоже ведёт на /tcc/. */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-hero {
  display: none;
}

/* заголовок-ссылка (Сообщество): hover подсвечивает как обычный group-hd */
.ft-sb-group-hd--link {
  text-decoration: none;
  margin-top: 10px;
  display: flex;
}
.ft-sb-group-hd--link:hover {
  color: var(--text, #c0c0c0);
}
.ft-sb-group-hd--link.active {
  color: var(--sh-accent, #00ff88);
}
.ft-sb-nav > .ft-sb-group-hd--link:first-child {
  margin-top: 0;
}

/* tooltip в collapsed-режиме для hero */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-hero::after {
  content: attr(data-tip);
  position: absolute;
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg2, #141414);
  color: var(--text, #e5e5e5);
  padding: 6px 10px;
  border-radius: 4px;
  white-space: nowrap;
  font-size: 12px;
  border: 1px solid var(--border, #2a2a2a);
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s;
  z-index: 1000;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-hero {
  position: relative;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-hero:hover::after {
  opacity: 1;
}

/* tooltip для collapsed items */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-item {
  justify-content: center;
  padding: 10px;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-item::after {
  content: attr(data-tip);
  position: absolute;
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg2, #141414);
  color: var(--text, #e5e5e5);
  padding: 6px 10px;
  border-radius: 4px;
  white-space: nowrap;
  font-size: 12px;
  border: 1px solid var(--border, #2a2a2a);
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s;
  z-index: 1000;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-item:hover::after {
  opacity: 1;
}

/* footer */
.ft-sb-footer {
  margin-top: auto;
  padding-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: opacity .2s;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-footer {
  opacity: 0;
  height: 0;
  overflow: hidden;
}
.ft-sb-partner {
  padding: 10px;
  background: var(--bg2, #141414);
  border: 1px solid rgba(247, 201, 72, .35);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ft-sb-partner-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #f7c948;
  font-weight: 800;
  text-align: center;
}

/* ── шапка sidebar: строка поиск + режим раскрытия ── */
.ft-sb-header-row {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 8px;
}
.ft-sb-header-row .ft-sb-search-trig {
  flex: 1;
  min-width: 0;
  margin-bottom: 0; /* переопределяем отступ, теперь у .ft-sb-header-row */
}

/* компактные иконочные кнопки (режим, свернуть всё, развернуть всё) */
.ft-sb-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 5px;
  background: transparent;
  border: 1px solid var(--border, #2a2a2a);
  color: var(--muted, #808080);
  cursor: pointer;
  font-size: 11px;
  transition: background .12s, color .12s, border-color .12s;
  flex-shrink: 0;
  padding: 0;
  font-family: inherit;
}
.ft-sb-icon-btn:hover {
  background: var(--bg3, #1a1a1a);
  color: var(--text, #c0c0c0);
  border-color: var(--border-hover, #3a3a3a);
}
.ft-sb-icon-btn:focus-visible {
  outline: 2px solid var(--sh-accent, #00ff88);
  outline-offset: 1px;
}
/* В свёрнутом сайдбаре скрываем кнопки управления режимом */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-header-row .ft-sb-icon-btn {
  display: none;
}

/* выпадающее меню выбора режима */
.ft-sb-em-wrap {
  position: relative;
}
.ft-sb-em-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  background: var(--bg2, #141414);
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 7px;
  min-width: 148px;
  padding: 4px;
  z-index: 200;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .4);
}
.ft-sb-em-opt {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 7px 10px;
  border-radius: 5px;
  background: transparent;
  border: none;
  color: var(--text, #c0c0c0);
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  transition: background .1s;
}
.ft-sb-em-opt:hover {
  background: var(--bg3, #1a1a1a);
}
.ft-sb-em-opt:focus-visible {
  outline: 2px solid var(--sh-accent, #00ff88);
  outline-offset: -2px;
}
.ft-sb-em-check {
  font-size: 10px;
  color: var(--sh-accent, #00ff88);
  width: 12px;
  opacity: 0;
  flex-shrink: 0;
}
.ft-sb-em-opt[aria-checked="true"] .ft-sb-em-check {
  opacity: 1;
}

/* search trigger */
.ft-sb-search-trig {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  /* margin-bottom вынесен в .ft-sb-header-row, оставляем 0 по умолчанию */
  border-radius: 6px;
  border: 1px solid var(--border, #2a2a2a);
  color: var(--muted, #808080);
  font-size: 12px;
  cursor: pointer;
  transition: border-color .15s, color .15s;
  user-select: none;
  background: transparent;
  width: 100%;
  box-sizing: border-box;
  font-family: inherit;
}
.ft-sb-search-trig:hover {
  border-color: var(--sh-accent);
  color: var(--text, #c0c0c0);
}
.ft-sb-search-trig i {
  font-size: 11px;
  flex-shrink: 0;
}
.ft-sb-search-trig-lbl {
  flex: 1;
  text-align: left;
}
.ft-sb-search-trig-kbd {
  font-size: 10px;
  padding: 1px 5px;
  background: var(--bg2, #141414);
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 3px;
  opacity: .55;
  flex-shrink: 0;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-search-trig {
  justify-content: center;
  padding: 10px;
  margin-bottom: 6px;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-search-trig-lbl,
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-search-trig-kbd {
  display: none;
}

.ft-sb-partner-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px;
  background: linear-gradient(135deg, rgba(0, 255, 136, .18), rgba(79, 195, 247, .22));
  border: 1px solid rgba(247, 201, 72, .5);
  color: #f7c948;
  border-radius: 6px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  transition: .15s;
}
.ft-sb-partner-btn:hover {
  background: linear-gradient(135deg, rgba(0, 255, 136, .28), rgba(79, 195, 247, .34));
  color: #fff3b8;
}
.ft-sb-partner-btn img {
  width: 14px;
  height: 14px;
  object-fit: contain;
}
.ft-sb-author {
  padding: 10px;
  background: var(--bg3, #1a1a1a);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ft-sb-author-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--strong, #fff);
  text-align: center;
}
.ft-sb-tg-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px;
  background: rgba(0, 136, 204, .15);
  border: 1px solid rgba(0, 136, 204, .3);
  color: #4fc3f7;
  border-radius: 4px;
  text-decoration: none;
  font-size: 11px;
  font-weight: 700;
  transition: .15s;
}
.ft-sb-tg-btn:hover {
  background: rgba(0, 136, 204, .3);
}
.ft-sb-tg-pair {
  display: flex;
  gap: 4px;
}
.ft-sb-tg-pair .ft-sb-tg-btn {
  flex: 1;
}

/* hide scrollbar nicely */
.ft-sb-nav::-webkit-scrollbar {
  width: 4px;
}
.ft-sb-nav::-webkit-scrollbar-thumb {
  background: var(--border, #2a2a2a);
  border-radius: 2px;
}

/* CTG — циан Cryptorg для токен-раздела */
.ft-sb-group-hd--link[data-key="ctg"] {
  color: #08D3D3;
  border-top: 1px solid var(--border, #2a2a2a);
  margin-top: 6px;
  padding-top: 14px;
}
.ft-sb-group-hd--link[data-key="ctg"] .ft-sb-group-icon {
  color: #08D3D3;
}
.ft-sb-group-hd--link[data-key="ctg"]:hover {
  color: #3de0e0;
}
.ft-sb-group-hd--link[data-key="ctg"].active {
  color: #08D3D3;
  background: rgba(8, 211, 211, .06);
}

/* Фидбэк FAB — внизу под CTG. Кружок-кнопка + подпись «Фидбэк» справа.
   2026-06-05: приподняли (margin-top 12→6, padding 8→4 верх) и добавили подпись. */
.ft-sb-feedback-wrap {
  margin-top: 6px;
  padding: 4px 14px 8px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}
.ft-sb-feedback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--green, #00ff88);
  color: #0a0a0a;
  border: none;
  cursor: pointer;
  font-size: 15px;
  transition: transform .15s, filter .15s;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .25);
  flex-shrink: 0;
}
.ft-sb-feedback:hover {
  filter: brightness(1.08);
  transform: scale(1.05);
}
.ft-sb-feedback-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text, #d1d4dc);
  letter-spacing: .02em;
  white-space: nowrap;
  transition: opacity .2s;
}
/* В свёрнутом sidebar подпись скрывается, кружок центрируется. */
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-feedback-wrap {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}
.ft-shell-root[data-sidebar-collapsed="1"] .ft-sb-feedback-label {
  display: none;
}

/* === lib/ui/right-panel.css === */
/* FOMO&TEMA · Правая панель (App Shell) — стили
   Extracted from right-panel.js (was dynamic <style> inject).
   Подключается статически через <link> в HTML. */

.ft-rp {
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}

/* Компактный ряд иконок-табов: высота ~40px, без подписей */
.ft-rp-tabs {
  display: flex;
  padding: 6px;
  gap: 2px;
  border-bottom: 1px solid var(--border, #2a2a2a);
  background: var(--bg2, #141414);
  flex-shrink: 0;
}
.ft-rp-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--muted, #808080);
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  font-size: 14px;
  min-width: 0;
  position: relative;
}
.ft-rp-tab:hover {
  background: var(--bg3, #1a1a1a);
  color: var(--text, #e5e5e5);
}
.ft-rp-tab.active {
  background: var(--bg3, #1a1a1a);
  color: var(--sh-accent);
  border-color: var(--border, #2a2a2a);
}
.ft-rp-tab i {
  font-size: 14px;
}
.ft-rp-tab-badge {
  position: absolute;
  top: 1px;
  right: 1px;
  background: var(--red, #f6465d);
  color: #fff;
  border-radius: 8px;
  font-size: 9px;
  font-weight: 700;
  padding: 0 4px;
  min-width: 12px;
  height: 12px;
  line-height: 12px;
  text-align: center;
}
.ft-rp-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
}

/* Context mode: user-block + nav groups */
.ft-rp-ctx {
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Компактная шапка: аватар слева, имя/ник/чипы справа в одной строке-колонке */
.ft-rp-ctx-user {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border, #2a2a2a);
  background: var(--bg2, #141414);
  flex-shrink: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  text-align: left;
  gap: 10px;
}
.ft-rp-ctx-urow {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  min-width: 0;
  text-decoration: none;
  color: inherit;
  flex: 1;
}
.ft-rp-ctx-ava {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--sh-accent, #00ff88), #4fc3f7);
  color: #0b0e11;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Urbanist", sans-serif;
  font-weight: 900;
  font-size: 15px;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.ft-rp-ctx-ava img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ft-rp-ctx-ava.role-admin {
  background: linear-gradient(135deg, #a855f7, #ec4899);
  color: #fff;
}
.ft-rp-ctx-ava-dot {
  position: absolute;
  right: -2px;
  bottom: -2px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--green, #00ff88);
  border: 2px solid var(--bg2, #141414);
}
.ft-rp-ctx-uname {
  min-width: 0;
  overflow: hidden;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.ft-rp-ctx-display {
  font-family: "Urbanist", sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--strong, #fff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.ft-rp-ctx-handle {
  font-size: 10px;
  color: var(--muted, #808080);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.ft-rp-ctx-meta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  flex-wrap: nowrap;
  flex-shrink: 0;
}
.ft-rp-ctx-stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px 5px;
  border-radius: 8px;
  background: rgba(247, 201, 72, .12);
  color: #f7c948;
  font-size: 10px;
  font-weight: 700;
  border: 1px solid rgba(247, 201, 72, .25);
}
.ft-rp-ctx-stars i {
  font-size: 8px;
}
.ft-rp-ctx-rating {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px 5px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
  border: 1px solid;
}
.ft-rp-ctx-rating.r-toxic {
  color: var(--red, #f6465d);
  background: rgba(246, 70, 93, .1);
  border-color: rgba(246, 70, 93, .3);
}
.ft-rp-ctx-rating.r-mixed {
  color: #f7a600;
  background: rgba(247, 166, 0, .1);
  border-color: rgba(247, 166, 0, .3);
}
.ft-rp-ctx-rating.r-neutral {
  color: var(--muted, #808080);
  background: var(--bg3, #1a1a1a);
  border-color: var(--border, #2a2a2a);
}
.ft-rp-ctx-rating.r-good {
  color: var(--green, #00ff88);
  background: rgba(0, 255, 136, .1);
  border-color: rgba(0, 255, 136, .25);
}
.ft-rp-ctx-rating.r-idol {
  color: #a855f7;
  background: rgba(168, 85, 247, .1);
  border-color: rgba(168, 85, 247, .3);
}
.ft-rp-ctx-rating.r-founder {
  color: #ffd24a;
  background: linear-gradient(135deg, rgba(247, 201, 72, .18), rgba(247, 166, 0, .12));
  border-color: rgba(247, 201, 72, .55);
  font-weight: 900;
}

/* Section title */
.ft-rp-ctx-sec {
  padding: 10px 12px 4px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted, #808080);
  display: flex;
  align-items: center;
  gap: 6px;
}
.ft-rp-ctx-sec::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border, #2a2a2a);
  opacity: .6;
}

/* Nav body (scrolls) */
.ft-rp-ctx-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 6px 8px 12px;
}

/* Точка монтирования готового DOM-узла (например, сайдбар Pine-скриптов) */
.ft-rp-ctx-mount {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.ft-rp-ctx-mount > * {
  flex: 1;
  min-height: 0;
  width: 100% !important;
}
.ft-rp-ctx-nav::-webkit-scrollbar {
  width: 4px;
}
.ft-rp-ctx-nav::-webkit-scrollbar-thumb {
  background: var(--border, #2a2a2a);
  border-radius: 2px;
}
.ft-rp-ctx-group {
  margin-bottom: 6px;
}
.ft-rp-ctx-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  margin: 1px 0;
  border-radius: 7px;
  color: var(--muted, #a0a0a0);
  text-decoration: none;
  font-size: 12.5px;
  transition: background .12s, color .12s;
  border-left: 2px solid transparent;
}
.ft-rp-ctx-item:hover {
  background: var(--bg3, #1a1a1a);
  color: var(--strong, #fff);
}
.ft-rp-ctx-item.active {
  background: var(--bg3, #1a1a1a);
  color: var(--strong, #fff);
  border-left-color: var(--sh-accent, #00ff88);
}
.ft-rp-ctx-item i {
  width: 16px;
  font-size: 13px;
  text-align: center;
  color: var(--muted, #a0a0a0);
}
.ft-rp-ctx-item:hover i,
.ft-rp-ctx-item.active i {
  color: var(--sh-accent, #00ff88);
}
.ft-rp-ctx-item-label {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ft-rp-ctx-item-badge {
  background: var(--red, #f6465d);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 8px;
  min-width: 18px;
  text-align: center;
}

/* Empty context state (page без подразделов) */
.ft-rp-ctx-empty {
  padding: 32px 14px;
  text-align: center;
  color: var(--muted, #808080);
  font-size: 12px;
  line-height: 1.5;
}
.ft-rp-ctx-empty i {
  font-size: 32px;
  opacity: .3;
  display: block;
  margin-bottom: 10px;
}
.ft-rp-placeholder {
  padding: 32px 14px;
  text-align: center;
  color: var(--muted, #808080);
  font-size: 12.5px;
  line-height: 1.6;
}
.ft-rp-placeholder .icon {
  font-size: 42px;
  opacity: .3;
  margin-bottom: 12px;
}
.ft-rp-placeholder .stage-tag {
  display: inline-block;
  margin-top: 14px;
  padding: 3px 10px;
  background: var(--bg3, #1a1a1a);
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 10px;
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--sh-accent);
  text-transform: uppercase;
}

/* Content styles */
.ft-rp-section {
  margin-bottom: 14px;
}
.ft-rp-section-title {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.ft-rp-stat {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.ft-rp-stat-label {
  font-size: 11px;
  color: var(--muted);
  flex: 1;
}
.ft-rp-stat-value {
  font-size: 13px;
  font-weight: 700;
  color: var(--strong);
  font-family: monospace;
}
.ft-rp-stat-value.pos {
  color: var(--green);
}
.ft-rp-stat-value.neg {
  color: var(--red);
}
.ft-rp-notif {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .12s;
  border-radius: 4px;
  padding: 6px 4px;
}
.ft-rp-notif:hover {
  background: var(--bg3);
}
.ft-rp-notif.unread .ft-rp-notif-text {
  color: var(--strong);
}
.ft-rp-notif-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  flex-shrink: 0;
  color: var(--sh-accent);
}
.ft-rp-notif-text {
  font-size: 12px;
  color: var(--text);
  line-height: 1.4;
  flex: 1;
}
.ft-rp-notif-time {
  font-size: 10px;
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.ft-rp-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 6px;
  text-decoration: none;
  color: var(--text);
  font-size: 12px;
  margin-bottom: 6px;
  transition: border-color .12s;
}
.ft-rp-link:hover {
  border-color: var(--sh-accent);
  color: var(--strong);
}
.ft-rp-link i {
  color: var(--sh-accent);
  width: 14px;
  text-align: center;
}

/* AI chat styles */
.ft-rp-ai {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 0 !important;
}

/* Tier chips (Start/Pro/Expert) */
.ft-rp-ai-tiers {
  display: flex;
  gap: 4px;
  padding: 8px;
  border-bottom: 1px solid var(--border, #2a2a2a);
  background: var(--bg2, #141414);
  flex-shrink: 0;
}
.ft-rp-ai-tier {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  padding: 6px 4px;
  background: var(--bg3, #1a1a1a);
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 6px;
  color: var(--muted, #808080);
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  font-family: inherit;
  transition: .12s;
  line-height: 1.1;
}
.ft-rp-ai-tier:hover {
  color: var(--text, #e5e5e5);
  border-color: var(--sh-accent);
}
.ft-rp-ai-tier.active {
  color: var(--sh-accent, #00ff88);
  border-color: var(--sh-accent, #00ff88);
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 10%, var(--bg3, #1a1a1a));
}
.ft-rp-ai-tier.locked {
  opacity: .55;
  cursor: not-allowed;
}
.ft-rp-ai-bal {
  padding: 4px 10px 6px;
  border-bottom: 1px solid var(--border, #2a2a2a);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ft-rp-bal-row {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
}
.ft-rp-bal-model {
  color: var(--muted, #808080);
  font-size: 11px;
}
.ft-rp-bal-bar {
  flex: 1;
  height: 5px;
  background: var(--bg3, #1a1a1a);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
}
.ft-rp-bal-bar-f {
  background: var(--sh-accent, #00ff88);
  opacity: .7;
  transition: width .4s;
}
.ft-rp-bal-bar-p {
  background: #7c6af8;
  opacity: .7;
  transition: width .4s;
}
.ft-rp-bal-num {
  color: var(--text, #d1d4dc);
  font-size: 10px;
  font-family: monospace;
  min-width: 30px;
  text-align: right;
}
.ft-rp-bal-link {
  font-size: 10px;
  color: var(--sh-accent, #00ff88);
  text-decoration: none;
  text-align: right;
  margin-top: 2px;
  display: block;
  opacity: .7;
}
.ft-rp-bal-link:hover {
  opacity: 1;
}
.ft-rp-ai-tier-model {
  font-size: 9px;
  font-weight: 500;
  opacity: .7;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.ft-rp-ai-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 0;
}
.ft-rp-ai-msg {
  max-width: 90%;
  font-size: 12px;
  line-height: 1.5;
  padding: 7px 10px;
  border-radius: 10px;
  word-break: break-word;
  white-space: pre-wrap;
}
.ft-rp-ai-msg.user {
  align-self: flex-end;
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 14%, var(--bg3, #1a1a1a));
  color: var(--text, #d1d4dc);
  border-radius: 10px 10px 2px 10px;
  border: 1px solid color-mix(in oklab, var(--sh-accent, #00ff88) 28%, var(--border, #2a2a2a));
}
.ft-rp-ai-msg.assistant {
  align-self: flex-start;
  background: var(--bg3);
  color: var(--text);
  border-radius: 10px 10px 10px 2px;
  border: 1px solid var(--border);
}
.ft-rp-ai-msg.error {
  align-self: flex-start;
  background: var(--red-dim, rgba(246, 70, 93, .1));
  color: var(--red);
  border: 1px solid rgba(246, 70, 93, .2);
}
.ft-rp-ai-msg.typing {
  align-self: flex-start;
  background: var(--bg3);
  color: var(--sh-accent, #00ff88);
  font-style: normal;
  display: flex;
  gap: 4px;
  align-items: center;
  padding: 8px 12px;
}
.ft-rp-ai-typing-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  animation: ft-rp-typing-pulse 1.2s ease-in-out infinite;
}
.ft-rp-ai-typing-dot:nth-child(2) {
  animation-delay: .2s;
}
.ft-rp-ai-typing-dot:nth-child(3) {
  animation-delay: .4s;
}
@keyframes ft-rp-typing-pulse {
  0%, 80%, 100% { opacity: .2; transform: scale(.8); }
  40% { opacity: 1; transform: scale(1); }
}
.ft-rp-ai-msg.assistant {
  position: relative;
}
.ft-rp-ai-copy-btn {
  position: absolute;
  bottom: 4px;
  right: 6px;
  background: transparent;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 11px;
  opacity: 0;
  transition: opacity .15s;
  padding: 2px 4px;
  border-radius: 4px;
}
.ft-rp-ai-msg.assistant:hover .ft-rp-ai-copy-btn {
  opacity: 1;
}
.ft-rp-ai-copy-btn:hover {
  color: var(--sh-accent);
}
.ft-rp-ai-regen {
  align-self: center;
  background: transparent;
  border: 1px dashed var(--border);
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  font-size: 11px;
  padding: 4px 10px;
  margin-top: 4px;
  transition: color .12s, border-color .12s;
}
.ft-rp-ai-regen:hover {
  color: var(--sh-accent);
  border-color: var(--sh-accent);
}
.ft-rp-ai-stop-btn {
  background: rgba(246, 70, 93, .12);
  border-color: var(--red);
  color: var(--red);
}
.ft-rp-ai-stop-btn:hover {
  background: var(--red);
  color: #fff;
}
.ft-rp-ai-footer {
  padding: 8px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  display: flex;
  gap: 6px;
}
.ft-rp-ai-input {
  flex: 1;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 7px 10px;
  font-size: 12px;
  color: var(--text);
  resize: none;
  outline: none;
  font-family: inherit;
  min-height: 36px;
  max-height: 100px;
  transition: border-color .12s;
}
.ft-rp-ai-input:focus {
  border-color: var(--sh-accent, var(--green-border));
}
.ft-rp-ai-send {
  width: 34px;
  height: 34px;
  background: var(--sh-accent, var(--green-dim));
  border: 1px solid var(--green-border);
  border-radius: 8px;
  color: var(--green);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  transition: background .12s;
  align-self: flex-end;
}
.ft-rp-ai-send:hover {
  background: var(--green);
  color: #000;
}
.ft-rp-ai-send:disabled {
  opacity: .4;
  cursor: default;
}
.ft-rp-ai-welcome {
  text-align: center;
  padding: 20px 10px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}
.ft-rp-ai-welcome .ai-icon {
  font-size: 32px;
  opacity: .5;
  margin-bottom: 10px;
  color: var(--sh-accent);
}

/* agent-mode: tool indicators */
.ft-rp-ai-tool-calls {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 6px 8px;
  background: color-mix(in oklab, var(--bg2, #141414) 80%, transparent);
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 8px;
  align-self: flex-start;
  max-width: 90%;
  font-size: 11px;
}
.ft-rp-ai-tool-call {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--muted, #808080);
}
.ft-rp-ai-tool-call.failed {
  color: var(--red, #ff4444);
}
.ft-rp-ai-tool-icon {
  font-size: 10px;
  color: var(--sh-accent, #00ff88);
  flex-shrink: 0;
}
.ft-rp-ai-tool-call.failed .ft-rp-ai-tool-icon {
  color: var(--red, #ff4444);
}
.ft-rp-ai-tool-text {
  flex: 1;
}
.ft-rp-ai-tool-status {
  font-size: 10px;
  color: var(--sh-accent, #00ff88);
  flex-shrink: 0;
}
.ft-rp-ai-tool-call.failed .ft-rp-ai-tool-status {
  color: var(--red, #ff4444);
}
.ft-rp-ai-tool-dur {
  font-size: 10px;
  color: var(--muted, #808080);
  flex-shrink: 0;
}
.ft-rp-ai-tool-pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sh-accent, #00ff88);
  animation: ft-rp-tool-blink 1s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes ft-rp-tool-blink {
  0%, 100% { opacity: .3; transform: scale(.8); }
  50% { opacity: 1; transform: scale(1.2); }
}

/* agent-mode: privacy modal */
.ft-rp-ai-privacy-modal {
  display: flex;
  align-items: flex-start;
  align-self: flex-start;
  max-width: 96%;
}
.ft-rp-ai-privacy-modal-body {
  background: var(--bg2, #141414);
  border: 1px solid color-mix(in oklab, var(--sh-accent, #00ff88) 30%, var(--border, #2a2a2a));
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ft-rp-ai-privacy-modal-icon {
  font-size: 18px;
  color: var(--sh-accent, #00ff88);
}
.ft-rp-ai-privacy-modal-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text, #d1d4dc);
}
.ft-rp-ai-privacy-modal-desc {
  font-size: 11px;
  color: var(--muted, #808080);
  line-height: 1.4;
}
.ft-rp-ai-privacy-modal-btns {
  display: flex;
  gap: 6px;
  margin-top: 2px;
}
.ft-rp-ai-privacy-btn-allow {
  flex: 1;
  padding: 5px 8px;
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 15%, transparent);
  border: 1px solid var(--sh-accent, #00ff88);
  border-radius: 5px;
  color: var(--sh-accent, #00ff88);
  font-size: 11px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background .12s;
}
.ft-rp-ai-privacy-btn-allow:hover {
  background: color-mix(in oklab, var(--sh-accent, #00ff88) 25%, transparent);
}
.ft-rp-ai-privacy-btn-cancel {
  padding: 5px 8px;
  background: transparent;
  border: 1px solid var(--border, #2a2a2a);
  border-radius: 5px;
  color: var(--muted, #808080);
  font-size: 11px;
  font-family: inherit;
  cursor: pointer;
}
.ft-rp-ai-privacy-btn-cancel:hover {
  border-color: var(--text, #d1d4dc);
  color: var(--text, #d1d4dc);
}

/* News styles */
.ft-rp-news-item {
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.ft-rp-news-item:last-child {
  border-bottom: none;
}
.ft-rp-news-title {
  font-size: 12px;
  color: var(--strong);
  line-height: 1.4;
  margin-bottom: 3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ft-rp-news-title a {
  color: inherit;
  text-decoration: none;
}
.ft-rp-news-title a:hover {
  color: var(--sh-accent);
}
.ft-rp-news-meta {
  font-size: 10px;
  color: var(--muted);
}
.ft-rp-ticker {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 10px;
}
.ft-rp-ticker-sym {
  font-size: 15px;
  font-weight: 700;
  color: var(--strong);
}
.ft-rp-ticker-price {
  font-size: 20px;
  font-weight: 700;
  font-family: monospace;
  color: var(--strong);
  margin: 4px 0;
}
.ft-rp-ticker-delta {
  font-size: 12px;
  font-weight: 600;
}
.ft-rp-ticker-delta.pos {
  color: var(--green);
}
.ft-rp-ticker-delta.neg {
  color: var(--red);
}

/* Quick alert direction buttons */
.ft-rp-al-dir {
  flex: 1;
  padding: 5px 8px;
  background: var(--bg3, #1a1a1a);
  border: 1px solid var(--border, #2a2a2a);
  color: var(--muted, #808080);
  border-radius: 5px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: .12s;
}
.ft-rp-al-dir:hover {
  border-color: var(--sh-accent);
  color: var(--strong, #fff);
}
.ft-rp-al-dir.active {
  background: rgba(0, 255, 136, .12);
  border-color: var(--sh-accent, #00ff88);
  color: var(--sh-accent, #00ff88);
}

/* === lib/ui/founder-bar/styles/founder-bar-slots.css === */
/* lib/ui/founder-bar/styles/founder-bar-slots.css
   Стили слотов Founder Bar — обёртки, заголовки, чевроны, заглушки, floating popup.
   Подключается через @import из founder-bar.css.
*/

/* ── Слоты ───────────────────────────────────────────────────── */

.ft-founder-bar__slot {
  padding: 10px 12px;
}

/* Разделитель между слотами */
.ft-founder-bar__slot + .ft-founder-bar__slot {
  border-top: 1px solid var(--border, var(--sh-border));
}

/* Заголовок слота (data-slot-label) — показывается через ::before псевдо */
.ft-founder-bar__slot[data-slot-label]::before {
  content: attr(data-slot-label);
  display: block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted, var(--sh-muted));
  margin-bottom: 8px;
}

/* ── Сворачиваемые слоты (T-5.A) ────────────────────────────── */

/* Убираем ::before псевдо-заголовок — теперь кнопка-заголовок */
.ft-founder-bar__slot[data-slot-label]::before {
  display: none;
}

.ft-founder-bar__slot-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 6px 0;
  background: transparent;
  border: none;
  color: var(--muted, var(--sh-muted));
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  user-select: none;
}

/* Закон 15: focus-visible обязателен */
.ft-founder-bar__slot-header:focus-visible {
  outline: 2px solid var(--accent, var(--sh-accent));
  outline-offset: 2px;
  border-radius: 2px;
}

.ft-founder-bar__slot-header:hover {
  color: var(--text, var(--sh-text));
}

.ft-fb-slot-title {
  flex: 1 1 auto;
  text-align: left;
}

.ft-fb-slot-chevron {
  font-size: 9px;
  color: var(--muted, var(--sh-muted));
  flex-shrink: 0;
  transition: transform 200ms ease;
}

/* Повёрнут влево когда свёрнут */
.ft-founder-bar__slot.is-collapsed .ft-fb-slot-chevron {
  transform: rotate(-90deg);
}

.ft-founder-bar__slot-body {
  overflow: hidden;
  transition: max-height 200ms ease;
  max-height: 600px; /* достаточно большое значение для открытого состояния */
}

/* Скрыть тело при collapsed */
.ft-founder-bar__slot.is-collapsed .ft-founder-bar__slot-body {
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  pointer-events: none;
}

/* Заглушка слота */
.ft-founder-bar__slot-stub {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  border: 1px dashed var(--border, var(--sh-border));
  color: var(--muted, var(--sh-muted));
  font-size: 12px;
  opacity: 0.7;
}

.ft-founder-bar__slot-stub i {
  font-size: 12px;
  flex-shrink: 0;
}

/* ── Floating кнопка ─────────────────────────────────────────── */

.ft-founder-bar-float__btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--border, var(--sh-border));
  background: var(--panel-bg, var(--sh-bg-secondary, var(--bg)));
  color: var(--text, var(--sh-text));
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 4px 12px var(--shadow, rgba(0,0,0,0.3));
  transition: background 0.15s, box-shadow 0.15s, transform 0.12s;
}

.ft-founder-bar-float__btn:hover {
  background: var(--hover-bg, var(--sh-hover-bg));
  box-shadow: 0 6px 18px var(--shadow, rgba(0,0,0,0.4));
  transform: scale(1.06);
}

/* Закон 15: focus-visible */
.ft-founder-bar-float__btn:focus-visible {
  outline: 2px solid var(--accent, var(--sh-accent));
  outline-offset: 3px;
}

.ft-founder-bar-float__btn--active {
  background: var(--accent, var(--sh-accent));
  color: var(--on-accent, #fff);
  border-color: var(--accent, var(--sh-accent));
}

/* ── Floating popup ──────────────────────────────────────────── */

.ft-founder-bar-float__popup {
  position: fixed;
  bottom: 84px;
  right: 24px;
  z-index: 9998;
  width: 360px;
  max-height: 500px;
  overflow-y: auto;
  border-radius: 10px;
  border: 1px solid var(--border, var(--sh-border));
  background: var(--panel-bg, var(--sh-bg-secondary, var(--bg)));
  box-shadow: 0 8px 32px var(--shadow, rgba(0,0,0,0.4));

  /* Скрыт по умолчанию */
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity 0.18s, transform 0.18s;
}

.ft-founder-bar-float__popup--open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.ft-founder-bar-float__popup-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px 10px;
  border-bottom: 1px solid var(--border, var(--sh-border));
  gap: 8px;
}

.ft-founder-bar-float__popup-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text, var(--sh-text));
}

.ft-founder-bar-float__popup-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted, var(--sh-muted));
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.12s, color 0.12s;
}

.ft-founder-bar-float__popup-close:hover {
  background: var(--hover-bg, var(--sh-hover-bg));
  color: var(--text, var(--sh-text));
}

/* Закон 15: focus-visible */
.ft-founder-bar-float__popup-close:focus-visible {
  outline: 2px solid var(--accent, var(--sh-accent));
  outline-offset: 2px;
}

.ft-founder-bar-float__popup-body {
  padding: 8px 0;
}

/* Адаптив: на мобильных popup занимает всю ширину */
@media (max-width: 420px) {
  .ft-founder-bar-float__popup {
    right: 8px;
    bottom: 80px;
    width: calc(100vw - 16px);
  }

  .ft-founder-bar-float__btn {
    right: 12px;
    bottom: 16px;
  }
}

/* === lib/ui/founder-bar/styles/founder-bar-impersonation.css === */
/* lib/ui/founder-bar/styles/founder-bar-impersonation.css
   Стили слота «Имитация тарифа» Founder Bar + бейдж «Просмотр как» в топбаре.
   Подключается через @import из founder-bar.css.
*/

/* ── Impersonation slot ──────────────────────────────────────── */

.ft-fb-impersonation {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ft-fb-impersonation__title {
  display: none; /* Заголовок отображается через data-slot-label::before */
}

.ft-fb-impersonation__section {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ft-fb-impersonation__label {
  font-size: 10px;
  color: var(--muted, var(--sh-muted));
  font-weight: 500;
}

/* Radio-список тарифов — строго по одному на строку */
.ft-fb-impersonation__tier-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 2px 0;
}

.ft-fb-impersonation__tier-item {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 2px 0;
  border-radius: 3px;
  font-size: 12px;
  color: var(--text, var(--sh-text));
  transition: color 0.1s;
}

.ft-fb-impersonation__tier-item:hover {
  color: var(--accent, var(--sh-accent));
}

.ft-fb-impersonation__tier-item--active {
  color: var(--accent, var(--sh-accent));
  font-weight: 600;
}

.ft-fb-impersonation__tier-radio {
  accent-color: var(--accent, var(--sh-accent));
  width: 13px;
  height: 13px;
  cursor: pointer;
  flex-shrink: 0;
}

.ft-fb-impersonation__user-input {
  width: 100%;
  box-sizing: border-box;
  padding: 5px 8px;
  border: 1px solid var(--border, var(--sh-border));
  border-radius: 4px;
  background: var(--surface, var(--sh-bg));
  color: var(--text, var(--sh-text));
  font-size: 12px;
}

.ft-fb-impersonation__suggest {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 9999;
  background: var(--surface, var(--sh-bg-secondary));
  border: 1px solid var(--border, var(--sh-border));
  border-radius: 4px;
  box-shadow: 0 4px 12px var(--shadow, rgba(0,0,0,0.3));
  max-height: 140px;
  overflow-y: auto;
}

.ft-fb-impersonation__suggest-item {
  padding: 6px 10px;
  cursor: pointer;
  font-size: 12px;
  border-bottom: 1px solid var(--border, var(--sh-border));
  color: var(--text, var(--sh-text));
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ft-fb-impersonation__suggest-item:hover {
  background: var(--hover-bg, var(--sh-hover-bg));
}

.ft-fb-impersonation__suggest-email {
  font-size: 10px;
  color: var(--muted, var(--sh-muted));
}

/* Кнопки имитации */
.ft-fb-impersonation__btn-row {
  display: flex;
  gap: 6px;
}

.ft-fb-impersonation__btn {
  flex: 1;
  min-width: 100px;
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border-radius: 4px;
  border: 1px solid var(--accent, var(--sh-accent));
  transition: background 0.15s, color 0.15s, opacity 0.15s;
}

.ft-fb-impersonation__btn--enable {
  background: var(--accent, var(--sh-accent));
  color: var(--on-accent, #fff);
}

.ft-fb-impersonation__btn--enable:hover:not(:disabled) {
  opacity: 0.85;
}

.ft-fb-impersonation__btn--disable {
  background: transparent;
  color: var(--accent, var(--sh-accent));
}

.ft-fb-impersonation__btn--disable:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent, var(--sh-accent)) 12%, transparent);
}

.ft-fb-impersonation__btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.ft-fb-impersonation__status {
  font-size: 11px;
  min-height: 16px;
  color: var(--muted, var(--sh-muted));
}

/* ── Бейдж «Просмотр как» в топбаре ────────────────────────── */

.ft-preview-as-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 12px;
  background: var(--accent, var(--sh-accent));
  color: var(--on-accent, #fff);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.4;
  cursor: default;
  white-space: nowrap;
  vertical-align: middle;
  position: relative;
}

.ft-preview-as-badge:hover .ft-preview-as-badge__tip {
  display: block;
}

.ft-preview-as-badge__tip {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--panel-bg, var(--sh-bg-secondary, var(--bg)));
  border: 1px solid var(--border, var(--sh-border));
  border-radius: 4px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 400;
  color: var(--text, var(--sh-text));
  white-space: nowrap;
  z-index: 9000;
  pointer-events: none;
  box-shadow: 0 3px 10px var(--shadow, rgba(0,0,0,0.25));
}

/* === lib/ui/founder-bar/styles/founder-bar-debug-mode.css === */
/* lib/ui/founder-bar/styles/founder-bar-debug-mode.css
   Стили слота «Подсветка платных опций» Founder Bar — toggle + outline + tooltip.
   Подключается через @import из founder-bar.css.
*/

/* ── Simulate User View slot ─────────────────────────────────── */

.ft-simulate-view {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px 0;
}

.ft-simulate-view__toggle-row {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 4px 0;
  border-radius: 4px;
  user-select: none;
}

.ft-simulate-view__checkbox {
  accent-color: var(--warn, gold);
  width: 14px;
  height: 14px;
  cursor: pointer;
  flex-shrink: 0;
}

.ft-simulate-view__label {
  font-size: 12px;
  color: var(--text, var(--sh-text));
  line-height: 1.3;
}

.ft-simulate-view__hint {
  font-size: 11px;
  color: var(--muted, var(--sh-muted));
  padding-left: 22px;
  line-height: 1.4;
}

.ft-simulate-view__badge {
  display: none;
  font-size: 10px;
  font-weight: 700;
  padding-left: 22px;
  color: var(--warn, gold);
  letter-spacing: 0.02em;
}

.ft-simulate-view__badge--active {
  display: block;
}

/* ── Debug Mode slot ─────────────────────────────────────────── */

.ft-debug-mode {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px 0;
}

.ft-debug-mode__toggle-row {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 4px 0;
  border-radius: 4px;
  user-select: none;
}

.ft-debug-mode__checkbox {
  accent-color: var(--accent, var(--sh-accent));
  width: 14px;
  height: 14px;
  cursor: pointer;
  flex-shrink: 0;
}

.ft-debug-mode__label {
  font-size: 12px;
  color: var(--text, var(--sh-text));
}

.ft-debug-mode__stats {
  font-size: 11px;
  color: var(--muted, var(--sh-muted));
  padding-left: 22px;
}

/* ── Overlay на элементах с data-feature ─────────────────────── */

body.founder-debug-paid [data-feature]:not([data-feature=""]) {
  position: relative;
  outline: 2px dashed var(--accent, var(--sh-accent));
  outline-offset: 2px;
  cursor: help;
}

/* Badges: feature-key label над элементом. Закон 15.11: без JS-инжекции */
body.founder-debug-paid:not(.founder-debug-paid-no-badges)
  [data-feature]:not([data-feature=""])::before {
  content: attr(data-feature);
  position: absolute;
  top: -18px;
  right: -2px;
  font-size: 10px;
  background: var(--accent, var(--sh-accent));
  color: var(--bg, var(--sh-bg));
  padding: 1px 6px;
  border-radius: 3px;
  z-index: 1;
  pointer-events: none;
  font-family: monospace;
  white-space: nowrap;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
}

body.founder-debug-paid [data-feature]:not([data-feature=""]):hover {
  outline-color: var(--warn, gold);
  outline-style: solid;
}

/* ── Tooltip матрицы тарифов ──────────────────────────────────── */

.founder-debug-tooltip {
  position: fixed;
  z-index: 10000;
  background: var(--panel-bg, var(--sh-bg-secondary, var(--bg)));
  border: 1px solid var(--accent, var(--sh-accent));
  border-radius: 4px;
  padding: 8px 12px;
  font-size: 12px;
  pointer-events: none;
  box-shadow: 0 4px 12px var(--shadow, rgba(0,0,0,0.3));
  max-width: 320px;
  display: none;
}

.founder-debug-tooltip__header {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 6px;
}

.founder-debug-tooltip__header strong {
  color: var(--text, var(--sh-text));
  font-size: 12px;
}

.founder-debug-tooltip__header code {
  font-size: 10px;
  color: var(--muted, var(--sh-muted));
  font-family: monospace;
}

.founder-debug-tooltip table {
  border-collapse: collapse;
  width: 100%;
}

.founder-debug-tooltip td {
  padding: 2px 8px;
  border-bottom: 1px solid var(--border, var(--sh-border));
  color: var(--text, var(--sh-text));
  font-size: 11px;
}

.founder-debug-tooltip td:first-child {
  font-weight: 600;
  color: var(--muted, var(--sh-muted));
  min-width: 60px;
}

.founder-debug-tooltip__admin-link {
  margin-top: 6px;
  text-align: right;
}

.founder-debug-tooltip__admin-link a {
  font-size: 11px;
  color: var(--accent, var(--sh-accent));
  text-decoration: none;
}

/* === lib/ui/founder-bar/styles/founder-bar.css === */
/* lib/ui/founder-bar/styles/founder-bar.css
   Стили Founder Bar — панель инструментов Основателя.
   Закон 15.12: critical layout через var(--*) токены платформы; никаких хардкод цветов.
   Закон 15: focus-visible на всех интерактивных элементах.
   Закон 15.13: этот файл подключается через <link> с defer-совместимым порядком, не инжектируется из JS.
   Закон 4: разбит на несколько файлов через @import (каждый ≤400 строк).
*/
/* @import stripped — file inlined in bundle */
/* @import stripped — file inlined in bundle */
/* @import stripped — file inlined in bundle */

/* ── Панель в правой панели ──────────────────────────────────── */

.ft-founder-bar {
  border: 1px solid var(--border, var(--sh-border));
  border-radius: 6px;
  padding: 0;
  margin: 8px 8px 4px;
  background: var(--surface, var(--sh-bg-secondary, var(--bg)));
}

.ft-founder-bar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  gap: 8px;
  cursor: default;
  user-select: none;
  border-bottom: 1px solid var(--border, var(--sh-border));
}

.ft-founder-bar__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent, var(--sh-accent));
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ft-founder-bar__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted, var(--sh-muted));
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.ft-founder-bar__toggle:hover {
  background: var(--hover-bg, var(--sh-hover-bg));
  border-color: var(--border, var(--sh-border));
  color: var(--text, var(--sh-text));
}

/* Закон 15: focus-visible */
.ft-founder-bar__toggle:focus-visible {
  outline: 2px solid var(--accent, var(--sh-accent));
  outline-offset: 2px;
}

/* Тело панели — скрыто при collapsed */
.ft-founder-bar__body {
  overflow: hidden;
}

.ft-founder-bar--collapsed .ft-founder-bar__body {
  display: none;
}

/* ── focus-visible на всех интерактивных (Закон 15 CI-инвариант) ── */

.ft-founder-bar input:focus-visible,
.ft-founder-bar button:focus-visible,
.ft-founder-bar select:focus-visible,
.ft-founder-bar textarea:focus-visible,
.ft-founder-bar-float__popup input:focus-visible,
.ft-founder-bar-float__popup button:focus-visible,
.ft-founder-bar-float__popup select:focus-visible,
.ft-founder-bar-float__popup textarea:focus-visible {
  outline: 2px solid var(--accent, var(--sh-accent));
  outline-offset: 2px;
}

/* === lib/ui/cookie-consent.css === */
/* lib/ui/cookie-consent.css — Cookie consent banner styles
   Партия 9B 9B.9: перенесено из JS (Закон 15.20 widget-css-in-bundle).
   PLATFORM-DEBT-015: включить в shell-bundle.css через scripts/build-css-bundles.js */

#ft-cookie-consent-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: var(--ft-bg-secondary, #1a1a1a);
  color: var(--ft-text, #e0e0e0);
  border-top: 1px solid var(--ft-border, #333);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  font-family: Arial, sans-serif;
  font-size: 13px;
  line-height: 1.5;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.25);
}

.ft-cookie-text {
  flex: 1;
  min-width: 200px;
  max-width: 800px;
  color: var(--ft-muted, #aaa);
}

.ft-cookie-text a {
  color: #0bd674;
  text-decoration: underline;
}

.ft-cookie-btn-accept {
  background: #0bd674;
  color: #111;
  border: none;
  border-radius: 6px;
  padding: 10px 24px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.15s ease;
}

.ft-cookie-btn-accept:hover,
.ft-cookie-btn-accept:focus-visible {
  background: #08c066;
}

.ft-cookie-btn-accept:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* === auth/modules/auth-frontend.css === */
/* ─── Кнопка аккаунта в topbar ─── */
[data-ft-acc-btn]{display:inline-flex;flex-shrink:0;align-items:center;gap:6px}

/* ─── Кнопка настроек ─── */
.ft-settings-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:6px;
  border:1px solid var(--border);background:var(--bg2);
  color:var(--muted);font-size:14px;cursor:pointer;
  transition:all .18s;flex-shrink:0;
}
.ft-settings-btn:hover{border-color:var(--blue);color:var(--blue)}
.ft-term-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:6px;
  border:1px solid var(--green-border);background:var(--green-dim);
  color:var(--green-text);font-size:13px;cursor:pointer;
  transition:all .18s;flex-shrink:0;
}
.ft-term-btn:hover{border-color:var(--green-text);background:rgba(0,255,136,.18)}
[data-theme="light"] .ft-term-btn{border-color:rgba(0,158,99,.3);background:rgba(0,158,99,.08);color:var(--green-text)}
[data-theme="light"] .ft-term-btn:hover{background:rgba(0,158,99,.15)}

/* ─── Попап настроек ─── */
.ft-settings-popup{
  position:fixed;top:50px;right:20px;width:300px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.5);
  z-index:9999;display:none;
  animation:ftSlideUp .18s ease-out;
}
.ft-settings-popup.open{display:block}
.ft-settings-popup-head{
  padding:12px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.ft-settings-popup-head span{font-size:13px;font-weight:700;color:var(--strong);flex:1}
.ft-settings-popup-close{
  background:none;border:none;color:var(--muted);
  cursor:pointer;font-size:14px;padding:2px;
}
.ft-settings-popup-close:hover{color:var(--red)}
.ft-settings-popup-body{padding:12px 16px;max-height:70vh;overflow-y:auto;scrollbar-width:none}
.ft-settings-popup-body::-webkit-scrollbar{display:none}
.ft-set-section{margin-bottom:14px}
.ft-set-section-title{
  font-size:11px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;
}
.ft-set-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 0;
  border-bottom:1px solid var(--border);
}
.ft-set-row:last-child{border-bottom:none}
.ft-set-row-info{flex:1;min-width:0}
.ft-set-row-label{font-size:12px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:5px}
.ft-set-row-desc{font-size:10px;color:var(--muted);display:block;margin-top:1px}
.ft-tip{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:14px;border-radius:50%;
  background:var(--border);color:var(--muted);
  font-size:9px;font-weight:700;font-style:normal;
  cursor:help;flex-shrink:0;line-height:1;
}
.ft-tip:hover{background:var(--blue);color:#fff}
.ft-tip::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  width:max-content;max-width:220px;padding:7px 10px;
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:11px;font-weight:400;line-height:1.4;
  white-space:normal;text-align:left;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .15s,visibility .15s;z-index:600;
}
.ft-tip:hover::after{opacity:1;visibility:visible}
[data-theme="light"] .ft-tip::after{box-shadow:0 4px 16px rgba(0,0,0,.12)}

/* Тултипы у правого края — выравнивание вправо */
.topbar-right .ft-tip::after,
.ft-seg .ft-tip::after{
  left:auto;right:0;transform:none;
}

/* Общая защита от переполнения */
.ft-tip::after{max-width:min(220px, calc(100vw - 32px))}

.ft-set-toggle{
  width:36px;height:20px;border-radius:10px;
  background:var(--border);flex-shrink:0;
  position:relative;cursor:pointer;transition:background .2s;
}
.ft-set-toggle.on{background:var(--green)}
.ft-set-toggle-knob{
  width:16px;height:16px;border-radius:50%;background:#fff;
  position:absolute;top:2px;left:2px;
  transition:left .18s;box-shadow:0 1px 3px rgba(0,0,0,.3);
}
.ft-set-toggle.on .ft-set-toggle-knob{left:18px}
.ft-set-sep{border:none;border-top:1px solid var(--border);margin:8px 0}
.ft-set-danger-btn{
  width:100%;padding:8px 12px;border-radius:8px;
  border:1px solid rgba(246,70,93,.2);background:var(--red-dim);
  color:var(--red);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .15s;
  display:flex;align-items:center;gap:6px;justify-content:center;
  margin-bottom:6px;
}
.ft-set-danger-btn:hover{border-color:var(--red);background:rgba(246,70,93,.15)}
.ft-set-warn-btn{
  width:100%;padding:8px 12px;border-radius:8px;
  border:1px solid rgba(247,201,72,.2);background:rgba(247,201,72,.05);
  color:var(--yellow-text);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .15s;
  display:flex;align-items:center;gap:6px;justify-content:center;
  margin-bottom:6px;
}
.ft-set-warn-btn:hover{border-color:var(--yellow-text);background:rgba(247,201,72,.12)}
.ft-set-action-btn{
  flex:1;padding:7px 10px;border-radius:8px;
  border:1px solid var(--border);background:var(--bg3);
  color:var(--text);font-size:11px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .15s;
  display:flex;align-items:center;gap:5px;justify-content:center;
}
.ft-set-action-btn:hover{border-color:var(--green-border);color:var(--green-text);background:var(--green-dim)}
.ft-set-action-btn i{font-size:11px}
.ft-set-nuke-btn{
  width:100%;padding:8px 12px;border-radius:8px;
  border:1px solid rgba(246,70,93,.3);background:rgba(246,70,93,.08);
  color:var(--red);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .15s;
  display:flex;align-items:center;gap:6px;justify-content:center;
  margin-bottom:6px;
}
.ft-set-nuke-btn:hover{border-color:var(--red);background:rgba(246,70,93,.18)}
.ft-acc-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:6px;
  border:1px solid var(--border);background:var(--bg2);
  color:var(--muted);font-size:12px;font-family:inherit;
  cursor:pointer;transition:all .18s;white-space:nowrap;
}
.ft-acc-btn:hover{border-color:var(--blue);color:var(--blue)}
.ft-acc-btn.connected{color:var(--green-text);border-color:var(--green-border)}
.ft-acc-btn.connected:hover{border-color:var(--green-text);color:var(--green-text)}
.ft-acc-btn i{font-size:14px}
.ft-acc-name{overflow:hidden;text-overflow:ellipsis}

/* ─── Account Dropdown ─── */
.ft-acc-wrap{position:relative;display:inline-flex}
.ft-acc-dropdown{
  display:none;position:absolute;top:100%;left:0;padding-top:4px;
  z-index:1000;
}
.ft-acc-dropdown::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.ft-acc-dropdown-inner{
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  min-width:200px;box-shadow:0 8px 24px var(--shadow);
  overflow:hidden;
}
.ft-acc-wrap:hover .ft-acc-dropdown{display:block}
.ft-dd-section{padding:6px 0}
.ft-dd-sep{height:1px;background:var(--border);margin:0}
.ft-dd-section-title{padding:6px 16px 4px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.ft-dd-acc{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;font-size:12px;color:var(--text);transition:background .12s}
.ft-dd-acc:hover{background:var(--bg3)}
.ft-dd-acc.active{background:rgba(0,255,136,.06)}
.ft-dd-acc.disabled{cursor:not-allowed;opacity:.4}
.ft-dd-acc.disabled:hover{background:transparent}
.ft-dd-acc i{font-size:11px;width:14px;text-align:center}
.ft-dd-acc-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ft-dd-acc-ex{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.ft-dd-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;font-size:13px;color:var(--text);
  text-decoration:none;transition:background .15s;cursor:pointer;
}
.ft-dd-item:hover{background:var(--bg3)}
.ft-dd-item i{width:16px;text-align:center;color:var(--muted);font-size:13px}
.ft-dd-logout{color:var(--red)}
.ft-dd-logout i{color:var(--red)}
.ft-dd-logout:hover{background:var(--red-dim,rgba(246,70,93,0.1))}

/* ─── Оверлей ─── */
.ft-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  z-index:10000;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .22s;
}
.ft-overlay.open{opacity:1;pointer-events:all}

/* ─── Модал ─── */
.ft-modal{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;width:560px;max-width:96vw;
  max-height:88vh;display:flex;flex-direction:column;
  box-shadow:0 24px 64px rgba(0,0,0,.6);
  animation:ftSlideUp .22s ease-out;
}
@keyframes ftSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.ft-modal-head{
  display:flex;align-items:center;gap:10px;
  padding:18px 22px 14px;border-bottom:1px solid var(--border);
}
.ft-modal-head-title{font-size:15px;font-weight:700;color:var(--strong);flex:1}
.ft-modal-close{
  background:none;border:none;color:var(--muted);font-size:18px;
  cursor:pointer;padding:4px;border-radius:6px;
}
.ft-modal-close:hover{color:var(--red);background:var(--red-dim)}

/* ─── Вкладки ─── */
.ft-tabs{
  display:flex;gap:0;padding:0 22px;border-bottom:1px solid var(--border);
}
.ft-tab{
  padding:10px 12px;font-size:12px;color:var(--muted);
  background:none;border:none;border-bottom:2px solid transparent;
  cursor:pointer;font-family:inherit;transition:all .15s;
  white-space:nowrap;
}
.ft-tab:hover{color:var(--text)}
.ft-tab.active{color:var(--blue);border-bottom-color:var(--blue)}

/* ─── Тело ─── */
.ft-body{padding:18px 22px;overflow-y:auto;flex:1}

/* ─── Список аккаунтов ─── */
.ft-acc-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:10px;
  border:1px solid var(--border);background:var(--bg3);
  margin-bottom:8px;transition:border-color .15s;
}
.ft-acc-card:hover{border-color:var(--blue)}
.ft-acc-card.active{border-color:var(--green-text);background:rgba(0,255,136,.04)}
.ft-acc-card-icon{
  width:36px;height:36px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
}
.ft-acc-card.active .ft-acc-card-icon{background:var(--green-dim);color:var(--green-text)}
.ft-acc-card:not(.active) .ft-acc-card-icon{background:rgba(132,142,156,.1);color:var(--muted)}
.ft-acc-card-info{flex:1;min-width:0}
.ft-acc-card-name{
  font-size:13px;font-weight:600;color:var(--strong);
  display:flex;align-items:center;gap:6px;
}
.ft-acc-card-name .ft-badge{
  font-size:10px;padding:1px 6px;border-radius:4px;font-weight:500;
}
.ft-badge-active{background:var(--green-dim);color:var(--green-text)}
.ft-acc-card-meta{font-size:11px;color:var(--muted);margin-top:2px}
.ft-acc-card-services{display:flex;gap:4px;margin-top:4px}
.ft-acc-card-services span{
  font-size:10px;padding:1px 6px;border-radius:4px;
  background:rgba(132,142,156,.08);color:var(--muted);
}
.ft-multi-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:8px;
  border:1px solid var(--border);background:var(--bg3);
  transition:.15s;
}
.ft-multi-item.active{border-color:rgba(79,195,247,.25);background:rgba(79,195,247,.04)}
.ft-multi-item-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:.2s}
.ft-multi-item-info{flex:1;min-width:0}
.ft-multi-item-name{font-size:13px;font-weight:600;color:var(--strong)}
.ft-multi-item-meta{font-size:10px;color:var(--muted);margin-top:1px}
.ft-multi-item-btn{
  padding:5px 12px;border-radius:6px;font-size:11px;font-weight:600;
  border:1px solid var(--border);background:transparent;
  color:var(--muted);cursor:pointer;font-family:inherit;
  transition:.15s;white-space:nowrap;
}
.ft-multi-item-btn:hover{border-color:var(--blue);color:var(--blue)}
.ft-multi-item-btn.on{
  border-color:rgba(79,195,247,.3);background:rgba(79,195,247,.1);color:var(--blue);
}
.ft-multi-item-btn.on:hover{background:rgba(79,195,247,.18)}
.ft-multi-item-btn i{font-size:10px;margin-right:2px}
.ft-multi-item-order{display:flex;flex-direction:column;gap:1px;flex-shrink:0}
.ft-multi-arrow{
  width:18px;height:14px;border:none;background:none;
  color:var(--muted);cursor:pointer;font-size:9px;
  display:flex;align-items:center;justify-content:center;
  border-radius:3px;transition:.15s;padding:0;
}
.ft-multi-arrow:hover{background:var(--bg3);color:var(--text)}
.ft-multi-arrow:disabled{opacity:.2;cursor:default;background:none}
.ft-multi-sep{
  display:flex;align-items:center;gap:8px;
  padding:6px 0;color:var(--muted);font-size:10px;
  text-transform:uppercase;letter-spacing:.06em;
}
.ft-multi-sep::before,.ft-multi-sep::after{content:'';flex:1;height:1px;background:var(--border)}
.ft-multi-sep span{flex-shrink:0}
.ft-acc-card-actions{display:flex;gap:4px;flex-shrink:0}
.ft-acc-card-actions button{
  padding:6px 10px;border-radius:6px;border:1px solid var(--border);
  background:var(--bg2);color:var(--muted);font-size:11px;
  cursor:pointer;font-family:inherit;transition:all .15s;
}
.ft-acc-card-actions button:hover{border-color:var(--blue);color:var(--blue)}
.ft-acc-card-actions .ft-btn-del:hover{border-color:var(--red);color:var(--red)}
.ft-acc-card-actions .ft-btn-connect{color:var(--green-text);border-color:var(--green-border)}
.ft-acc-card-actions .ft-btn-connect:hover{background:var(--green-dim)}

/* ─── Кнопка добавить ─── */
.ft-add-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:10px;border-radius:10px;
  border:1px dashed var(--border);background:none;
  color:var(--muted);font-size:13px;cursor:pointer;font-family:inherit;
  transition:all .15s;margin-top:4px;
}
.ft-add-btn:hover{border-color:var(--blue);color:var(--blue)}
.ft-slots-info{font-size:11px;color:var(--muted);text-align:center;margin-top:8px}

/* ─── Сегментированные кнопки (topbar) ─── */
.ft-seg{
  display:flex;align-items:stretch;
  border:1px solid var(--border);border-radius:8px;
  background:var(--bg2);
  flex-shrink:0;height:34px;
}
.ft-seg>.ft-seg-btn:first-child{border-radius:7px 0 0 7px}
.ft-seg>.ft-seg-btn:last-child,
.ft-seg>:last-child .ft-seg-btn{border-radius:0 7px 7px 0}
.ft-seg-btn{
  display:flex;align-items:center;gap:6px;
  padding:0 14px;
  background:transparent;border:none;
  color:var(--muted);font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;
  font-family:'Lato',sans-serif;white-space:nowrap;
  position:relative;
}
.ft-seg-btn+.ft-seg-btn::before{
  content:'';position:absolute;
  left:0;top:20%;bottom:20%;
  width:1px;background:var(--border);
}
.ft-seg-btn i{font-size:12px;transition:color .15s}
.ft-seg-btn:hover{background:var(--bg3);color:var(--text)}
.ft-seg-btn.h-blue:hover{color:var(--blue)}
.ft-seg-btn.h-blue:hover i{color:var(--blue)}
.ft-seg-btn.h-green:hover{color:var(--green-text)}
.ft-seg-btn.h-green:hover i{color:var(--green-text)}
.ft-seg-btn.h-red:hover{color:var(--red)}
.ft-seg-btn.h-red:hover i{color:var(--red)}
.ft-seg-btn.h-purple:hover{color:var(--purple)}
.ft-seg-btn.h-purple:hover i{color:var(--purple)}
.ft-seg-btn.icon-only{padding:0 10px}
.ft-seg-btn.active{color:var(--blue);background:rgba(79,195,247,.08)}
.ft-seg-btn.active i{color:var(--blue)}
.ft-seg-acc-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);box-shadow:0 0 6px rgba(0,255,136,.4);
  flex-shrink:0;
}
[data-theme="light"] .ft-seg{border-color:var(--border);background:var(--bg2)}
[data-theme="light"] .ft-seg-btn+.ft-seg-btn::before{background:var(--border)}

/* Тема — отдельный сегмент */
.ft-theme-seg{
  display:flex;border:1px solid var(--border);
  border-radius:8px;height:34px;flex-shrink:0;
}
.ft-theme-seg>.ft-theme-btn:first-child{border-radius:7px 0 0 7px}
.ft-theme-seg>.ft-theme-btn:last-child{border-radius:0 7px 7px 0}
.ft-theme-btn{
  display:flex;align-items:center;justify-content:center;
  width:34px;background:transparent;border:none;
  color:var(--muted);font-size:13px;cursor:pointer;
  transition:all .15s;position:relative;
}
.ft-theme-btn+.ft-theme-btn::before{
  content:'';position:absolute;
  left:0;top:20%;bottom:20%;
  width:1px;background:var(--border);
}
.ft-theme-btn:hover{background:var(--bg3)}
.ft-theme-btn.active-dark{color:var(--purple);background:rgba(167,139,250,.08)}
.ft-theme-btn.active-light{color:var(--yellow-text);background:rgba(247,201,72,.08)}

/* ─── Мульти-слоты (нумерованные кружки) ─── */
[data-ft-multi-slots]{display:flex;align-items:stretch}
.ft-mslot{
  display:flex;align-items:center;justify-content:center;
  width:26px;background:transparent;border:none;
  color:var(--muted);font-size:10px;font-weight:700;
  cursor:pointer;transition:all .15s;
  position:relative;font-family:'Lato',sans-serif;
}
.ft-mslot+.ft-mslot::before,
.ft-mslot:first-child::before{
  content:'';position:absolute;
  left:0;top:25%;bottom:25%;
  width:1px;background:var(--border);
}
.ft-mslot-circle{
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--border);
  font-size:10px;font-weight:700;
  transition:all .15s;
}
.ft-mslot.filled .ft-mslot-circle{
  border-color:currentColor;
  box-shadow:0 0 6px rgba(0,0,0,.3);
}
.ft-mslot.empty .ft-mslot-circle{border-style:dashed;border-color:var(--blue);color:var(--blue)}
.ft-mslot:hover{background:var(--bg3)}
.ft-mslot.empty{opacity:.55}
.ft-mslot.empty:hover{opacity:1}

/* Мульти-слот разделитель */
.ft-msep{
  width:1px;align-self:stretch;
  margin:6px 0;background:var(--border);
}

/* Попап выбора аккаунта для мульти-слота */
.ft-mslot-popup{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:180px;padding:6px 0;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.45);
  z-index:9999;
  animation:ftSlideUp .15s ease-out;
}
.ft-mslot-popup-item{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;width:100%;
  background:none;border:none;
  color:var(--text);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:.12s;
  text-align:left;
}
.ft-mslot-popup-item:hover{background:var(--bg3);color:var(--green-text)}
.ft-mslot-popup-item i{font-size:11px;color:var(--muted);width:14px;text-align:center}
.ft-mslot-popup-empty{
  padding:10px 14px;font-size:11px;color:var(--muted);text-align:center;
}
[data-theme="light"] .ft-mslot-popup{box-shadow:0 8px 28px rgba(0,0,0,.15)}

/* ─── Форма нового аккаунта ─── */
.ft-form-group{margin-bottom:14px}
.ft-form-label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:500}
.ft-form-input{
  width:100%;padding:9px 12px;border-radius:8px;
  border:1px solid var(--border);background:var(--bg3);
  color:var(--text);font-size:13px;font-family:inherit;
  box-sizing:border-box;
}
.ft-form-input:focus{outline:none;border-color:var(--blue)}
.ft-form-input::placeholder{color:var(--placeholder)}
.ft-form-input::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer;opacity:.8}
.ft-form-input::-webkit-calendar-picker-indicator:hover{opacity:1}
[data-theme="light"] .ft-form-input::-webkit-calendar-picker-indicator{filter:none}
.ft-key-wrap{position:relative}
.ft-key-wrap input{padding-right:36px}
.ft-key-masked{-webkit-text-security:disc;text-security:disc}
.ft-key-masked.ft-eye-open{-webkit-text-security:none;text-security:none}
.ft-key-eye{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:13px;padding:4px;
}
.ft-key-eye:hover{color:var(--text)}


/* ─── Сервисы ─── */
.ft-services-row{display:flex;gap:14px;flex-wrap:wrap}
.ft-svc-checks{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.ft-svc-chk{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text);cursor:pointer;background:var(--bg3);transition:all .15s}
.ft-svc-chk:hover{border-color:var(--blue)}
.ft-svc-chk:has(input:checked){border-color:var(--green-text);background:rgba(0,255,136,.05);color:var(--strong)}
.ft-svc-chk input{accent-color:var(--green-text);cursor:pointer}
.ft-svc-chk i{font-size:11px;opacity:.7}
.ft-svc-main{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);cursor:pointer}
.ft-svc-main input{accent-color:var(--green-text)}
.ft-service-opt{
  display:flex;align-items:center;gap:4px;
  font-size:12px;color:var(--text);cursor:pointer;
}
.ft-service-opt input{accent-color:var(--blue)}

/* ─── Памятка безопасности ─── */
.ft-security-box{
  padding:12px 14px;border-radius:10px;
  background:rgba(79,195,247,.04);border:1px solid rgba(79,195,247,.12);
  font-size:11px;color:var(--muted);line-height:1.6;
}
.ft-security-box i{color:var(--blue);margin-right:6px}
.ft-security-box ul{margin:6px 0 0 0;padding-left:18px}
.ft-security-box li{margin-bottom:2px}

/* ─── Кнопка сохранить ─── */
.ft-save-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:11px;border-radius:10px;border:none;
  background:var(--blue);color:#0b0e11;
  font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;
  transition:all .18s;margin-top:6px;
}
.ft-save-btn:hover{filter:brightness(1.1)}
.ft-save-btn:disabled{opacity:.5;cursor:default}

.ft-exp-title{font-size:13px;font-weight:600;color:var(--strong);margin-bottom:10px}

.ft-error{
  padding:8px 12px;border-radius:8px;
  background:var(--red-dim);border:1px solid rgba(246,70,93,.2);
  font-size:12px;color:var(--red);margin-top:8px;
}
.ft-success{
  padding:8px 12px;border-radius:8px;
  background:var(--green-dim);border:1px solid var(--green-border);
  font-size:12px;color:var(--green-text);margin-top:8px;
}

/* ─── Лимит слотов ─── */
.ft-limit-row{
  display:flex;align-items:center;gap:8px;
  margin-top:10px;padding:10px 14px;border-radius:8px;
  background:rgba(247,201,72,.04);border:1px solid rgba(247,201,72,.12);
}
.ft-limit-input{
  width:50px;padding:5px 8px;border-radius:6px;
  border:1px solid var(--border);background:var(--bg3);
  color:var(--text);font-size:13px;text-align:center;font-family:inherit;
}
.ft-limit-btn{
  padding:5px 10px;border-radius:6px;border:1px solid var(--yellow);
  background:none;color:var(--yellow-text);font-size:11px;
  cursor:pointer;font-family:inherit;
}
.ft-limit-btn:hover{background:rgba(247,201,72,.1)}

/* ─── Пустой список ─── */
.ft-empty{
  text-align:center;padding:30px 20px;color:var(--muted);
}
.ft-empty i{font-size:28px;display:block;margin-bottom:10px;opacity:.4}
.ft-empty-text{font-size:13px;margin-bottom:14px}

/* ─── Spinner ─── */
.ft-spin{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(255,255,255,.2);border-top-color:#fff;
  border-radius:50%;animation:ftSpin .6s linear infinite;
}
@keyframes ftSpin{to{transform:rotate(360deg)}}

/* ─── Edit inline ─── */
.ft-inline-edit{
  background:var(--bg3);border:1px solid var(--blue);
  border-radius:4px;color:var(--strong);font-size:13px;
  padding:1px 6px;font-family:inherit;width:140px;
}

/* ─── Селектор биржи ─── */
.ft-exchange-row{display:flex;gap:8px;flex-wrap:wrap}
.ft-exchange-opt{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:8px;
  border:1px solid var(--border);background:var(--bg3);
  color:var(--text);font-size:12px;cursor:pointer;
  transition:all .15s;flex:1;min-width:140px;
}
.ft-exchange-opt:hover:not(.is-disabled){border-color:var(--blue)}
.ft-exchange-opt.selected{border-color:var(--blue);background:rgba(79,195,247,.06)}
.ft-exchange-opt input{display:none}
.ft-exchange-opt i{font-size:14px}
/* Заглушенная биржа: серая, не реагирует на hover/click, иконка обесцвечена.
   2026-06-04 — Binance отключён до готовности интеграции. */
.ft-exchange-opt.is-disabled{
  opacity:.45;cursor:not-allowed;
  border-color:var(--border);background:var(--bg3);
}
.ft-exchange-opt.is-disabled:hover{border-color:var(--border)}
.ft-exchange-opt.is-disabled i{filter:grayscale(1)}
.ft-exchange-soon{
  margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.05em;
  padding:2px 6px;border-radius:4px;text-transform:uppercase;
  background:rgba(128,128,128,.15);color:var(--muted);
}
.ft-exchange-badge{
  font-size:10px;padding:1px 6px;border-radius:4px;font-weight:500;
  display:inline-flex;align-items:center;gap:3px;
  background:rgba(132,142,156,.1);color:var(--muted);
}

/* ─── Палитра цветов аккаунта ─── */
.ft-color-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ft-color-dot{
  width:24px;height:24px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:all .15s;flex-shrink:0;
}
.ft-color-dot:hover{transform:scale(1.15);border-color:var(--strong)}
.ft-color-dot.selected{border-color:var(--strong);box-shadow:0 0 0 2px var(--bg),0 0 0 4px currentColor}
.ft-acc-color-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
}

/* ─── Мультиаккаунт чипы ─── */


/* === terminal/mobile/app.css === */
/* ── Backdrop ── */
#mt-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.38);
  z-index:399;
  opacity:0;pointer-events:none;
  transition:opacity .22s ease;
}
#mt-backdrop.open{opacity:1;pointer-events:auto;}
.mt-mode-float #mt-backdrop{display:none}

/* ── Панель ── */
.mt-panel{
  position:fixed;z-index:400;
  background:var(--bg2);
  border:1px solid var(--border);
  display:flex;flex-direction:column;
  overflow:hidden;
  opacity:0;pointer-events:none;
}

/* Dropdown (default) */
body:not(.mt-mode-bottom):not(.mt-mode-float) .mt-panel{
  top:var(--sh-topbar-h,52px);
  left:50%;
  transform:translateX(-50%) translateY(8px);
  width:740px;
  max-width:calc(100vw - 32px);
  max-height:calc(100vh - var(--sh-topbar-h,52px) - 20px);
  border-radius:0 0 12px 12px;
  border-top:none;
  box-shadow:0 20px 60px rgba(0,0,0,.55);
  opacity:0;pointer-events:none;
  transition:opacity .22s ease,transform .22s cubic-bezier(.4,0,.2,1);
}
body:not(.mt-mode-bottom):not(.mt-mode-float) .mt-panel.open{
  transform:translateX(-50%) translateY(0);
  opacity:1;pointer-events:auto;
}

/* Bottom sheet */
.mt-mode-bottom .mt-panel{
  bottom:0;top:auto;
  left:50%;
  transform:translateX(-50%) translateY(24px);
  width:740px;
  max-width:calc(100vw - 32px);
  max-height:74vh;
  border-radius:14px 14px 0 0;
  border-bottom:none;
  box-shadow:0 -8px 40px rgba(0,0,0,.45);
  opacity:0;pointer-events:none;
  transition:opacity .22s ease,transform .22s cubic-bezier(.4,0,.2,1);
}
.mt-mode-bottom .mt-panel.open{
  transform:translateX(-50%) translateY(0);
  opacity:1;pointer-events:auto;
}

/* Float widget */
.mt-mode-float .mt-panel{
  border-radius:12px;
  box-shadow:0 8px 40px rgba(0,0,0,.6);
  width:400px;height:560px;
  min-width:280px;min-height:260px;
  opacity:0;pointer-events:none;
  transition:opacity .18s ease;
}
.mt-mode-float .mt-panel.open{opacity:1;pointer-events:auto;}

/* Drag handle (float only) */
.mt-drag-handle{
  display:none;align-items:center;justify-content:center;
  height:22px;background:var(--bg3);
  border-bottom:1px solid var(--border);
  cursor:grab;flex-shrink:0;
  color:var(--muted);font-size:11px;letter-spacing:3px;
  user-select:none;border-radius:12px 12px 0 0;
}
.mt-drag-handle:active{cursor:grabbing}
.mt-mode-float .mt-drag-handle{display:flex}

/* Resize handle (float only) */
.mt-resize-handle{
  position:absolute;bottom:0;right:0;
  width:18px;height:18px;
  cursor:se-resize;
  display:none;
  background:linear-gradient(135deg,transparent 40%,var(--border) 40%,var(--border) 55%,transparent 55%,transparent 70%,var(--border) 70%,var(--border) 85%,transparent 85%);
  z-index:10;
}
.mt-mode-float .mt-resize-handle{display:block}

/* Mode buttons in settings */
.mt-mode-btns{display:flex;gap:6px;margin-top:4px}
.mt-mode-btn{
  flex:1;padding:7px 4px;background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;color:var(--muted);font-size:10px;font-weight:700;
  font-family:inherit;cursor:pointer;transition:.15s;text-align:center;line-height:1.4;
}
.mt-mode-btn:hover{border-color:var(--muted);color:var(--text)}
.mt-mode-btn.active{background:rgba(0,255,136,.08);border-color:rgba(0,255,136,.3);color:var(--green-text)}
.mt-mode-btn i{display:block;font-size:13px;margin-bottom:3px}

/* ── Header ── */
.mt-panel-head{
  padding:8px 12px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;flex-shrink:0;position:relative;
  background:var(--bg2);
}
.mt-head-row{display:flex;align-items:center;width:100%}
.mt-head-row-ctrl{justify-content:space-between}
.mt-head-row-counts{gap:6px;flex-wrap:nowrap}
.mt-head-row-fin{font-size:12px}

/* Width buttons */
.mt-width-btns{
  display:flex;gap:0;
  border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0;
}
.mt-w-btn{
  padding:4px 9px;background:transparent;border:none;border-right:1px solid var(--border);
  color:var(--muted);font-size:11px;font-weight:700;
  font-family:inherit;cursor:pointer;transition:background .12s,color .12s;line-height:1;
}
.mt-w-btn:last-child{border-right:none}
.mt-w-btn:hover{background:var(--bg3);color:var(--strong)}
.mt-w-btn.active{background:rgba(0,255,136,.08);color:var(--sh-accent,#00ff88)}
.mt-w-btn.chart-btn{color:var(--muted)}
.mt-w-btn.chart-btn:hover{background:var(--bg3);color:var(--strong)}
.mt-w-btn.chart-btn.active{background:rgba(0,255,136,.08);color:var(--sh-accent,#00ff88)}

/* Icon buttons */
.mt-head-btn{
  background:transparent;border:1px solid var(--border);border-radius:6px;
  color:var(--muted);cursor:pointer;font-size:12px;padding:5px 8px;
  transition:background .12s,border-color .12s,color .12s;line-height:1;font-family:inherit;
}
.mt-head-btn:hover{background:var(--bg3);border-color:var(--sh-accent,#00ff88);color:var(--strong)}

/* Счётчики */
.mt-count-badge{
  font-size:11px;padding:2px 8px;border-radius:20px;font-weight:700;
  background:var(--bg3);color:var(--text);border:1px solid var(--border);
}
.mt-ls-badge{
  font-size:11px;padding:2px 7px;border-radius:20px;font-weight:700;
  display:inline-flex;align-items:center;gap:3px;border:1px solid var(--border);
  background:var(--bg3);
}
.mt-ls-badge.long{color:var(--sh-accent,#00ff88);border-color:rgba(0,255,136,.2)}
.mt-ls-badge.short{color:var(--red,#f6465d);border-color:rgba(246,70,93,.2)}
.mt-ls-badge i{font-size:8px}

/* Финансовая строка */
.mt-fin-row{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;flex:1;min-width:0}
.mt-fin-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.mt-fin-sep{color:var(--border);font-size:12px;flex-shrink:0}
.mt-total-pnl{font-size:12px;font-weight:700;color:var(--muted)}
.mt-total-pnl.pos{color:var(--sh-accent,#00ff88)}
.mt-total-pnl.neg{color:var(--red,#f6465d)}
.mt-bal-val{font-size:12px;font-weight:700;color:var(--text)}

/* Body row */
.mt-body-row{flex:1;display:flex;flex-direction:row;min-height:0;overflow:hidden}
.mt-body-row .mt-list{flex:1;overflow-y:auto;overflow-x:hidden}

/* List */
.mt-list{
  flex:1;min-height:0;overflow-y:auto;padding:10px;
  display:flex;flex-direction:column;gap:7px;
}
.mt-list::-webkit-scrollbar{width:5px}
.mt-list::-webkit-scrollbar-track{background:transparent}
.mt-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.mt-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* Grid modes */
.mt-list.cols-2{display:grid!important;grid-template-columns:1fr 1fr;align-items:start;align-content:start}
.mt-list.cols-3{display:grid!important;grid-template-columns:1fr 1fr 1fr;align-items:start;align-content:start}
.mt-list.cols-4{display:grid!important;grid-template-columns:1fr 1fr 1fr 1fr;align-items:start;align-content:start}
.mt-list.cols-auto{
  display:grid!important;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  align-items:start;align-content:start;
}
.mt-list.cols-auto .mt-card-head{padding:7px 10px;gap:5px}
.mt-list.cols-auto .mt-sym{font-size:12px}
.mt-list.cols-auto .mt-side{font-size:9px;padding:1px 5px}
.mt-list.cols-auto .mt-pnl{font-size:11px}
.mt-list.cols-auto .mt-card-body{padding:0 8px 8px}
.mt-list.cols-auto .mt-details-grid{gap:5px;padding:8px}
.mt-list.cols-auto .mt-detail-lbl{font-size:9px}
.mt-list.cols-auto .mt-detail-val{font-size:11px}
.mt-list.cols-2 .mt-empty,.mt-list.cols-3 .mt-empty{grid-column:1/-1}

/* ── Cards ── */
.mt-card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-left:3px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  transition:background .12s,border-color .12s;
}
.mt-card.long{border-left-color:rgba(0,255,136,.5)}
.mt-card.short{border-left-color:rgba(246,70,93,.45)}
.mt-card:hover{background:var(--bg3)}
.mt-card-head{
  display:flex;align-items:center;gap:8px;padding:9px 12px;
  cursor:pointer;user-select:none;
}
.mt-sym{font-weight:700;color:var(--strong);font-size:13px;letter-spacing:.01em}
.mt-side{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;flex-shrink:0}
.mt-side.long{background:rgba(0,255,136,.1);color:var(--sh-accent,#00ff88)}
.mt-side.short{background:rgba(246,70,93,.1);color:var(--red,#f6465d)}
.mt-pnl{margin-left:auto;font-weight:700;font-size:12px}
.mt-pnl.pos{color:var(--sh-accent,#00ff88)}
.mt-pnl.neg{color:var(--red,#f6465d)}
.mt-chevron{font-size:9px;color:var(--muted);transition:transform .2s;flex-shrink:0;opacity:.5}
.mt-card.expanded .mt-chevron{transform:rotate(180deg)}
.mt-card-body{display:none;padding:0 12px 10px}
.mt-card.expanded .mt-card-body{display:block}
.mt-details-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
  padding:10px;background:var(--bg);border-radius:6px;border:1px solid var(--border);
}
.mt-detail{display:flex;flex-direction:column;gap:2px}
.mt-detail-lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.mt-detail-val{font-size:11px;color:var(--text);font-weight:700}
.mt-detail-val.pos{color:var(--sh-accent,#00ff88)}
.mt-detail-val.neg{color:var(--red,#f6465d)}
.mt-card-left{display:flex;align-items:center;gap:6px;flex-shrink:0}
.mt-card-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.mt-card-roe{font-size:11px;font-weight:600;color:var(--muted)}
.mt-card-roe.pos{color:var(--sh-accent,#00ff88)}
.mt-card-roe.neg{color:var(--red,#f6465d)}

/* Empty */
.mt-empty{
  text-align:center;padding:40px 20px;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:10px;font-size:13px;
}
.mt-empty i{font-size:28px}

/* ── Footer ── */
.mt-panel-foot{
  padding:8px 14px;border-top:1px solid var(--border);
  font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px;
  flex-shrink:0;background:var(--bg2);
}
.mt-conn-dot{
  width:6px;height:6px;border-radius:50%;background:var(--sh-accent,#00ff88);
  flex-shrink:0;opacity:.8;
}

/* Risk bar — скрыт */
.mt-risk-wrap{display:none!important}

/* Settings — центрированная модалка по центру окна (выбор Founder 2026-06-09) */
#mt-set-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  z-index:1190;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
#mt-set-backdrop.open{opacity:1;pointer-events:auto;}
.mt-settings-pop{
  position:fixed;top:50%;left:50%;
  width:min(92vw,380px);
  max-height:min(82vh,620px);overflow-y:auto;overflow-x:hidden;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;
  padding:8px;
  box-shadow:0 18px 50px rgba(0,0,0,.55);
  z-index:1200;
  transform:translate(-50%,-50%) scale(.96);
  opacity:0;pointer-events:none;
  transition:transform .18s cubic-bezier(.4,0,.2,1),opacity .18s ease;
}
.mt-settings-pop.open{
  transform:translate(-50%,-50%) scale(1);
  opacity:1;pointer-events:auto;
}
/* Кастомный скроллбар как у .mt-list */
.mt-settings-pop::-webkit-scrollbar{width:5px}
.mt-settings-pop::-webkit-scrollbar-track{background:transparent}
.mt-settings-pop::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.mt-settings-pop::-webkit-scrollbar-thumb:hover{background:var(--muted)}
@media (prefers-reduced-motion:reduce){
  .mt-settings-pop,#mt-set-backdrop{transition:none}
}
.mt-set-item{
  display:flex;align-items:center;gap:9px;
  padding:8px 10px;border-radius:6px;cursor:pointer;user-select:none;
  transition:background .15s;
}
.mt-set-item:hover{background:var(--bg3)}
.mt-set-icon{width:20px;text-align:center;color:var(--muted);font-size:12px;flex-shrink:0}
.mt-set-info{flex:1;min-width:0}
.mt-set-title{font-size:12px;font-weight:700;color:var(--text);display:block}
.mt-set-desc{font-size:10px;color:var(--muted);display:block;margin-top:1px;line-height:1.3}
.mt-toggle{
  width:32px;height:18px;border-radius:9px;
  background:var(--border);flex-shrink:0;
  position:relative;transition:background .2s;
}
.mt-toggle.on{background:var(--green)}
.mt-toggle-knob{
  width:14px;height:14px;border-radius:50%;background:#fff;
  position:absolute;top:2px;left:2px;
  transition:left .18s;box-shadow:0 1px 3px rgba(0,0,0,.3);
}
.mt-toggle.on .mt-toggle-knob{left:16px}
.mt-set-sep{border:none;border-top:1px solid var(--border);margin:5px 6px}

/* Hover tab — скрыт */
.mt-hover-tab{display:none!important}

/* Chart panel */
.mt-chart-panel{
  display:none;flex-direction:column;
  background:var(--bg);border-right:1px solid var(--border);min-width:0;
}
.mt-chart-panel.open{display:flex;flex:1}
#mt-chart-inner{flex:1;min-height:0;min-width:0;overflow:hidden}

/* Chart fullscreen mode */
.mt-panel.chart-mode{
  height:calc(100vh - var(--sh-topbar-h,52px)) !important;
  overflow:hidden;
}

/* Chart-open compact mode */
.mt-panel.chart-open .mt-list{flex:none!important;width:220px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;overflow-x:hidden}
.mt-panel.chart-open .mt-list.cols-2,
.mt-panel.chart-open .mt-list.cols-3,
.mt-panel.chart-open .mt-list.cols-4,
.mt-panel.chart-open .mt-list.cols-auto{display:flex!important;flex-direction:column!important;grid-template-columns:unset!important}
.mt-panel.chart-open .mt-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;margin:3px 6px;width:calc(100% - 12px)!important;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}
.mt-panel.chart-open .mt-card.long:hover{border-color:rgba(0,255,136,.5);box-shadow:0 0 0 1px rgba(0,255,136,.15)}
.mt-panel.chart-open .mt-card.short:hover{border-color:rgba(246,70,93,.5);box-shadow:0 0 0 1px rgba(246,70,93,.15)}
.mt-panel.chart-open .mt-card.chart-selected.long{border-color:rgba(0,255,136,.6)!important;background:rgba(0,255,136,.07)!important;box-shadow:0 0 0 1px rgba(0,255,136,.2)!important}
.mt-panel.chart-open .mt-card.chart-selected.short{border-color:rgba(246,70,93,.6)!important;background:rgba(246,70,93,.07)!important;box-shadow:0 0 0 1px rgba(246,70,93,.2)!important}
.mt-panel.chart-open .mt-card-head{display:flex;align-items:center;justify-content:space-between;padding:6px 10px 6px 8px;gap:0;width:100%;box-sizing:border-box}
.mt-panel.chart-open .mt-sym{font-size:11px;font-weight:700}
.mt-panel.chart-open .mt-side{font-size:9px;padding:1px 4px}
.mt-panel.chart-open .mt-pnl{font-size:11px}
.mt-panel.chart-open .mt-chevron{display:none}
.mt-panel.chart-open .mt-card-body{display:none!important}

/* Spinner */
.mt-spin{
  display:inline-block;width:13px;height:13px;
  border:2px solid var(--border);border-top-color:var(--green-text);
  border-radius:50%;animation:mtSpin .7s linear infinite;vertical-align:middle;
}
@keyframes mtSpin{to{transform:rotate(360deg)}}

/* ── Мультирежим: группы аккаунтов ── */
.mt-group{margin-bottom:2px}
.mt-group-header{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:8px;
  background:var(--bg3);border:1px solid var(--border);
  cursor:pointer;user-select:none;transition:.15s;
}
.mt-group-header:hover{border-color:var(--muted)}
.mt-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.mt-group-name{font-size:12px;font-weight:700;color:var(--strong);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mt-group-stats{display:flex;align-items:center;gap:6px;font-size:11px;flex-shrink:0}
.mt-group-bal{color:var(--blue);font-weight:700}
.mt-group-pnl{font-weight:700}
.mt-group-pnl.pos{color:var(--green-text)}
.mt-group-pnl.neg{color:var(--red)}
.mt-group-cnt{font-size:10px;color:var(--muted);background:var(--bg2);padding:1px 6px;border-radius:10px;border:1px solid var(--border)}
.mt-group-chevron{font-size:9px;color:var(--muted);transition:transform .2s;flex-shrink:0}
.mt-group.collapsed .mt-group-chevron{transform:rotate(-90deg)}
.mt-group-body{display:flex;flex-direction:column;gap:4px;padding:4px 0 0 8px}
.mt-group.collapsed .mt-group-body{display:none}
.mt-group-error{padding:8px 12px;font-size:12px;color:var(--red);background:rgba(246,70,93,.06);border-radius:6px;border:1px solid rgba(246,70,93,.15)}
.mt-card.multi-acc{border-left:3px solid var(--border)}
.mt-group-body .mt-card{border-radius:8px}
.mt-group-body .mt-card-head{padding:7px 10px;gap:5px}
.mt-group-body .mt-sym{font-size:12px}
.mt-group-body .mt-side{font-size:9px;padding:1px 5px}
.mt-group-body .mt-pnl{font-size:11px}
.mt-group-body .mt-card-roe{font-size:9px}

/* Grid: группа занимает всю ширину */
.mt-list.cols-2 .mt-group,
.mt-list.cols-3 .mt-group,
.mt-list.cols-4 .mt-group,
.mt-list.cols-auto .mt-group{grid-column:1/-1}
.mt-list.cols-2 .mt-group-body,
.mt-list.cols-3 .mt-group-body,
.mt-list.cols-4 .mt-group-body,
.mt-list.cols-auto .mt-group-body{
  display:grid;gap:5px;
}
.mt-list.cols-2 .mt-group-body{grid-template-columns:1fr 1fr}
.mt-list.cols-3 .mt-group-body{grid-template-columns:1fr 1fr 1fr}
.mt-list.cols-4 .mt-group-body{grid-template-columns:1fr 1fr 1fr 1fr}
.mt-list.cols-auto .mt-group-body{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
.mt-group.collapsed .mt-group-body{display:none!important}

/* ── Вкладки панели — скрыты (только терминал) ── */
.mt-tabs{display:none}
.mt-tab-btn{
  flex:1;padding:8px 4px;background:none;border:none;border-bottom:2px solid transparent;
  color:var(--muted);font-size:11px;font-weight:700;font-family:inherit;
  cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;gap:4px;
  letter-spacing:.03em;text-transform:uppercase;position:relative;
}
.mt-tab-btn:hover{color:var(--text);background:var(--bg3)}
.mt-tab-btn.active{color:var(--green-text);border-bottom-color:var(--green-text)}
.mt-tab-badge{
  min-width:16px;height:16px;border-radius:8px;padding:0 4px;
  background:var(--red);color:#fff;font-size:9px;font-weight:900;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
}

/* ── Соц-вкладка ── */
.mt-soc-events{display:flex;flex-direction:column;gap:1px}
.mt-soc-event{
  display:flex;align-items:flex-start;gap:9px;padding:9px 12px;
  border-radius:8px;cursor:default;transition:.15s;
}
.mt-soc-event:hover{background:var(--bg3)}
.mt-soc-event.unread{background:rgba(79,195,247,.05)}
.mt-soc-event-icon{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:12px;
  background:var(--bg3);color:var(--muted);
}
.mt-soc-event-icon.like{background:rgba(246,70,93,.1);color:var(--red)}
.mt-soc-event-icon.message{background:rgba(79,195,247,.1);color:var(--blue)}
.mt-soc-event-icon.mention{background:rgba(247,201,72,.1);color:var(--yellow,#f7c948)}
.mt-soc-event-icon.follow{background:rgba(0,255,136,.1);color:var(--green-text)}
.mt-soc-event-icon.system{background:var(--bg3);color:var(--muted)}
.mt-soc-event-body{flex:1;min-width:0}
.mt-soc-event-title{font-size:12px;color:var(--text);font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-soc-event-body p{font-size:11px;color:var(--muted);margin:2px 0 0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mt-soc-event-time{font-size:10px;color:var(--muted);flex-shrink:0;margin-top:2px}
.mt-soc-links{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:10px 12px;
  border-top:1px solid var(--border);
}
.mt-soc-link{
  display:flex;align-items:center;gap:7px;padding:8px 10px;
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  color:var(--text);text-decoration:none;font-size:11px;font-weight:700;
  transition:.15s;
}
.mt-soc-link:hover{border-color:var(--green-text);color:var(--green-text);background:rgba(0,255,136,.05)}
.mt-soc-link i{width:14px;text-align:center;color:var(--muted);font-size:12px;flex-shrink:0}
.mt-soc-link:hover i{color:var(--green-text)}
.mt-soc-unread-row{
  display:flex;align-items:center;gap:6px;padding:8px 12px;
  font-size:11px;color:var(--muted);border-bottom:1px solid var(--border);
  background:rgba(79,195,247,.04);
}
.mt-soc-unread-row b{color:var(--blue)}

/* ── Дневник-вкладка ── */
.mt-jrnl-period{
  display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;
  margin:12px 12px 0;
}
.mt-jrnl-period-btn{
  flex:1;padding:5px 0;background:transparent;border:none;
  color:var(--muted);font-size:11px;font-weight:700;font-family:inherit;
  cursor:pointer;transition:.15s;border-right:1px solid var(--border);
}
.mt-jrnl-period-btn:last-child{border-right:none}
.mt-jrnl-period-btn:hover{background:var(--bg3);color:var(--text)}
.mt-jrnl-period-btn.active{background:var(--green-dim);color:var(--green-text)}
.mt-jrnl-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 12px;
}
.mt-jrnl-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  padding:10px 12px;display:flex;flex-direction:column;gap:3px;
}
.mt-jrnl-card-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.mt-jrnl-card-val{font-size:18px;font-weight:900;color:var(--text)}
.mt-jrnl-card-val.pos{color:var(--green-text)}
.mt-jrnl-card-val.neg{color:var(--red)}
.mt-jrnl-card-sub{font-size:10px;color:var(--muted)}
.mt-jrnl-share{
  margin:4px 12px 12px;padding:9px;border-radius:8px;
  background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.25);
  color:var(--green-text);font-size:12px;font-weight:700;font-family:inherit;
  cursor:pointer;transition:.15s;width:calc(100% - 24px);
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.mt-jrnl-share:hover{background:rgba(0,255,136,.15)}
