/* Кабинет Лидера — стили */
* { margin: 0; padding: 0; box-sizing: border-box; }

/* ── Тематические переменные. Дефолт = зелёный. ────────────────────────── */
/* Пастельные палитры — мягкие приглушённые тона.
   --accent держим средне-насыщенным (на нём белый текст кнопок),
   фоны/границы — нежные. */
:root {
  /* 🌿 Шалфейно-зелёный */
  --accent:        var(--g-accent2);
  --accent-dark:   #5f8a64;
  --accent-light:  #a6c8aa;
  --accent-soft:   #f0f6f0;
  --accent-soft2:  #e4efe5;
  --accent-border: #d3e3d5;
  --accent-text:   #4a6a4e;
  --accent-text2:  #7d9a80;
  --accent-link:   #5f9065;
  --bg-gradient:   linear-gradient(135deg, #f5f1e8 0%, #eef6ef 100%);
}
html.theme-orange {
  /* 🍑 Персиково-терракотовый */
  --accent: #d49d72; --accent-dark: #bd8456; --accent-light: #ecc6a4;
  --accent-soft: #fbf3ea; --accent-soft2: #f6e7d6; --accent-border: #edd7bf;
  --accent-text: #7a5532; --accent-text2: #ab8763; --accent-link: #c2824f;
  --bg-gradient: linear-gradient(135deg, #fbf3ea 0%, #f7ead9 100%);
}
html.theme-purple {
  /* 💜 Лавандовый */
  --accent: #a98fd0; --accent-dark: #8e74bb; --accent-light: #cab7e6;
  --accent-soft: #f4f0fa; --accent-soft2: #eae1f4; --accent-border: #ddd0ee;
  --accent-text: #574080; --accent-text2: #8a76ab; --accent-link: #8163b3;
  --bg-gradient: linear-gradient(135deg, #f4f0fa 0%, #ece4f5 100%);
}
html.theme-blue {
  /* 💙 Пыльно-голубой */
  --accent: #7fa8cc; --accent-dark: #6690b8; --accent-light: #aacae2;
  --accent-soft: #eef5fb; --accent-soft2: #dfeaf5; --accent-border: #cadcec;
  --accent-text: #3a5a7a; --accent-text2: #6f90ad; --accent-link: #5a85ad;
  --bg-gradient: linear-gradient(135deg, #eef5fb 0%, #e1ecf6 100%);
}
html.theme-yellow {
  /* 💛 Мягкая горчица / песочный */
  --accent: #cdb46a; --accent-dark: #b39c54; --accent-light: #e3d29c;
  --accent-soft: #faf6e9; --accent-soft2: #f3ead1; --accent-border: #e8dcb8;
  --accent-text: #6e5a28; --accent-text2: #9a8a5a; --accent-link: #ab964a;
  --bg-gradient: linear-gradient(135deg, #faf6e9 0%, #f4edd6 100%);
}
html.theme-red {
  /* ❤️ Пыльная роза */
  --accent: #d2929a; --accent-dark: #ba7880; --accent-light: #e7babf;
  --accent-soft: #fbeef0; --accent-soft2: #f5dfe1; --accent-border: #edcace;
  --accent-text: #7a4248; --accent-text2: #ab777c; --accent-link: #bd6a72;
  --bg-gradient: linear-gradient(135deg, #fbeef0 0%, #f6e0e3 100%);
}
html.theme-gray {
  /* 🌫 Тёплый серый */
  --accent: #9aa0a8; --accent-dark: #7e8590; --accent-light: #c1c6cd;
  --accent-soft: #f4f5f6; --accent-soft2: #e9ebed; --accent-border: #d7dade;
  --accent-text: #4a4f57; --accent-text2: #80868f; --accent-link: #6b7079;
  --bg-gradient: linear-gradient(135deg, #f4f5f6 0%, #e9ebed 100%);
}

html, body {
  min-height: 100vh;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg-gradient);
  color: #2d3e2f;
}

a { color: var(--accent-link); text-decoration: none; }
a:hover { text-decoration: underline; }

/* === Баннер «Просмотр как лидер» (impersonation) === */
.impersonate-bar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 4000;
  background: linear-gradient(135deg, #d99655, #c97a2e);
  color: #fff; font-size: 14px; font-weight: 600;
  padding: 8px 16px; text-align: center;
  box-shadow: 0 2px 10px rgba(0,0,0,0.18);
}
.impersonate-bar a {
  color: #fff; text-decoration: underline; margin-left: 14px; font-weight: 700;
}
.has-impersonate-bar { padding-top: 40px; }
html.dark-active .impersonate-bar {
  background: linear-gradient(135deg, #8c5a2e, #6b4220);
}

/* === Шестерёнка настроек в шапке === */
.settings-gear {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 50%;
  text-decoration: none; font-size: 17px; line-height: 1;
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--accent-border, var(--g-border));
  transition: all 0.15s; color: var(--g-text);
}
.settings-gear:hover {
  background: var(--accent-soft, var(--g-soft));
  border-color: var(--accent, var(--g-accent));
  transform: rotate(40deg); text-decoration: none;
}
html.dark-active .settings-gear {
  background: var(--d-surface-2); border-color: var(--d-border-2); color: var(--d-text);
}

/* === Имя+аватар в шапке (клик → Мой кабинет) === */
.hello-link {
  display: inline-flex; align-items: center; gap: 9px;
  text-decoration: none; padding: 4px 10px 4px 4px;
  border-radius: 22px; transition: all 0.15s;
  border: 1px solid transparent;
}
.hello-link:hover {
  background: rgba(255,255,255,0.55);
  border-color: var(--accent-border, var(--g-border));
  text-decoration: none;
}
.hello-avatar {
  width: 32px; height: 32px; border-radius: 50%; object-fit: cover;
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  border: 1.5px solid rgba(255,255,255,0.7);
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
.hello-avatar-ph { color: #fff; font-size: 13px; font-weight: 600; }
.hello-name { font-size: 14px; color: var(--accent-text, var(--g-text2)); font-weight: 500; }
html.dark-active .hello-link:hover { background: var(--d-surface-2); border-color: var(--d-border-2); }
html.dark-active .hello-name { color: var(--d-text); }
html.dark-active .hello-avatar { border-color: rgba(120,160,130,0.3); }

/* === Переключатель темы (legacy, на странице настроек) === */
.theme-switcher { position: relative; display: inline-block; z-index: 3000; }
.theme-switcher-floating {
  position: fixed; bottom: 18px; left: 18px; z-index: 1000;
}
.theme-switcher-floating .theme-menu {
  bottom: calc(100% + 6px); right: auto; left: 0;
}
.theme-btn {
  min-width: 44px; height: 36px; padding: 0 10px;
  border-radius: 20px; gap: 6px;
  background: white; border: 1px solid var(--accent-border);
  cursor: pointer; display: flex;
  align-items: center; justify-content: center; transition: all 0.15s;
  box-shadow: 0 2px 8px rgba(60,100,60,0.08);
}
.theme-btn:hover { border-color: var(--accent); transform: scale(1.05); }
.theme-dot {
  display: inline-block; width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid white; box-shadow: 0 0 0 1px rgba(0,0,0,0.08);
}
.theme-mode-icon { font-size: 14px; line-height: 1; }
.theme-menu {
  position: absolute; bottom: calc(100% + 6px); right: 0;
  background: white; border: 1px solid #e0eae2; border-radius: 12px;
  box-shadow: 0 12px 28px rgba(60,100,60,0.14);
  z-index: 3001; min-width: 220px; padding: 6px;
}
.theme-switcher:not(.theme-switcher-floating) .theme-menu {
  top: calc(100% + 4px); bottom: auto;
}
.theme-menu-title { font-size: 11px; color: var(--g-muted); text-transform: uppercase; padding: 8px 12px 4px; letter-spacing: 0.4px; }
.theme-menu-sep { height: 1px; background: #e8ede9; margin: 4px 8px; }
.theme-opt {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 8px 12px; border: none; background: none; cursor: pointer;
  border-radius: 8px; color: var(--g-text); font-size: 14px; text-align: left;
}
.theme-opt:hover { background: var(--g-soft); }
.theme-opt-active { background: #eaf3eb; font-weight: 600; }
.theme-opt .theme-dot { width: 16px; height: 16px; }
.theme-mode-emoji { font-size: 16px; width: 16px; text-align: center; }
.theme-check { margin-left: auto; color: var(--accent); }

/* ═══════════════════════════════════════════════════════════════
   🌙 НОЧНОЙ РЕЖИМ — полноценный
   Включается классом html.dark-active (его вешает theme.js при режиме
   "Тёмная" ИЛИ "Как в системе"+системная тёмная). Один источник правды.
   ═══════════════════════════════════════════════════════════════ */
html.dark-active {
  color-scheme: dark;
  --bg-gradient: linear-gradient(160deg, #14201a 0%, #0c1410 100%);
  /* Тёмные поверхности */
  --d-surface:   #1b2721;     /* карточки */
  --d-surface-2: #223029;     /* приподнятые блоки / hover */
  --d-surface-3: #16201b;     /* инпуты, утопленные */
  --d-border:    rgba(120,160,130,0.16);
  --d-border-2:  rgba(120,160,130,0.28);
  --d-text:      #dde6df;     /* основной текст */
  --d-text-strong:#eef4ef;    /* заголовки */
  --d-text-dim:  #93a89a;     /* подписи */
}

/* ─── 🌃 Тёмная — Telegram (по умолчанию глубокий сине-стальной) ─── */
html.dark-active.night-telegram {
  --bg-gradient: linear-gradient(160deg, #17212B 0%, #0E1621 100%);
  --d-surface:   #182533;
  --d-surface-2: #1F2C3A;
  --d-surface-3: #131C26;
  --d-border:    rgba(122,160,200,0.18);
  --d-border-2:  rgba(122,160,200,0.32);
  --d-text:      #DCE5EE;
  --d-text-strong: #F5F8FB;
  --d-text-dim:  #7E96AB;
}

─── 💡 Тёмная — Ламповая (тёплый янтарный свет вечером, кремово-шоколадная) ─── */
html.dark-active.night-cozy {
  --bg-gradient:
    radial-gradient(circle at 18% 22%, rgba(255,176,77,0.18), transparent 38%),
    radial-gradient(circle at 80% 88%, rgba(204,121,52,0.10), transparent 42%),
    linear-gradient(160deg, #1F140C 0%, #120A05 100%);
  --d-surface:    #261A11;     /* тёплый шоколад для карточек */
  --d-surface-2:  #311F12;     /* приподнятые блоки / hover */
  --d-surface-3:  #170E07;     /* инпуты, утопленные */
  --d-border:     rgba(255,176,77,0.22);
  --d-border-2:   rgba(255,176,77,0.40);
  --d-text:       #F1DDC4;     /* кремовый */
  --d-text-strong:#FFEDD2;     /* ярко-янтарный */
  --d-text-dim:   #A89178;     /* тёплый бежево-серый */
}
/* Ламповые акценты — мягкое тёплое свечение карточек, заголовков и кнопок */
html.dark-active.night-cozy .settings-card,
html.dark-active.night-cozy .card,
html.dark-active.night-cozy .panel,
html.dark-active.night-cozy .tile,
html.dark-active.night-cozy .product-card {
  box-shadow:
    0 0 0 1px rgba(255,176,77,0.15),
    0 8px 28px rgba(0,0,0,0.45),
    0 0 36px rgba(255,176,77,0.05);
}
html.dark-active.night-cozy h1,
html.dark-active.night-cozy h2,
html.dark-active.night-cozy h3,
html.dark-active.night-cozy .settings-h {
  color: #FFD9A8 !important;
  text-shadow: 0 0 8px rgba(255,176,77,0.30);
}
html.dark-active.night-cozy .seg-btn.active,
html.dark-active.night-cozy a.btn-primary,
html.dark-active.night-cozy button.primary,
html.dark-active.night-cozy .settings-btn.active,
html.dark-active.night-cozy .btn-success,
html.dark-active.night-cozy button[type="submit"] {
  background: linear-gradient(135deg, #FFB04D 0%, #C97934 100%) !important;
  color: #1F140C !important;
  border-color: transparent !important;
  text-shadow: none !important;
  box-shadow:
    0 0 10px rgba(255,176,77,0.55),
    0 0 22px rgba(201,121,52,0.35) !important;
}
/* Аватары — тёплое кольцо как абажур */
html.dark-active.night-cozy .hello-avatar,
html.dark-active.night-cozy .recruit-avatar,
html.dark-active.night-cozy .tg-chat-avatar,
html.dark-active.night-cozy .prof-avatar,
html.dark-active.night-cozy .prof-avatar-ph,
html.dark-active.night-cozy .hello-avatar-ph {
  border: 2px solid rgba(255,176,77,0.55) !important;
  box-shadow: 0 0 12px rgba(255,176,77,0.45) !important;
}
/* Капельки/PV — янтарные */
html.dark-active.night-cozy .badge,
html.dark-active.night-cozy .drop-count,
html.dark-active.night-cozy .pv-cell {
  color: #FFB04D !important;
  text-shadow: 0 0 6px rgba(255,176,77,0.40);
}
/* Поля ввода — мягко-янтарная рамка */
html.dark-active.night-cozy input,
html.dark-active.night-cozy select,
html.dark-active.night-cozy textarea,
html.dark-active.night-cozy .settings-input {
  background: rgba(23,14,7,0.75) !important;
  border-color: rgba(255,176,77,0.30) !important;
  color: #F1DDC4 !important;
}
html.dark-active.night-cozy input:focus,
html.dark-active.night-cozy select:focus,
html.dark-active.night-cozy textarea:focus {
  border-color: #FFB04D !important;
  box-shadow: 0 0 0 2px rgba(255,176,77,0.30) !important;
  outline: none;
}
/* Ссылки — мягко-янтарные */
html.dark-active.night-cozy a:not(.btn-primary):not(.seg-btn):not(.settings-btn):not(.night-card) {
  color: #FFB04D !important;
}
/* Лого/брендинг */
html.dark-active.night-cozy .brand,
html.dark-active.night-cozy .logo,
html.dark-active.night-cozy .top-left b {
  color: #FFD9A8 !important;
  text-shadow: 0 0 6px rgba(255,176,77,0.45);
}

/* ─── 🌈 Тёмная — Неон (настоящий неон: cyan/magenta/lime контуры + свечение) ─── */
html.dark-active.night-neon {
  --bg-gradient:
    radial-gradient(circle at 12% 12%, rgba(0,224,255,0.10), transparent 38%),
    radial-gradient(circle at 88% 22%, rgba(255,46,196,0.10), transparent 38%),
    radial-gradient(circle at 50% 90%, rgba(167,107,255,0.12), transparent 42%),
    linear-gradient(160deg, #07021A 0%, #04010F 100%);
  --d-surface:    #0F0826;
  --d-surface-2:  #160C33;
  --d-surface-3:  #07021A;
  --d-border:     rgba(0,224,255,0.40);
  --d-border-2:   rgba(255,46,196,0.55);
  --d-text:       #E0F2FF;
  --d-text-strong:#FFFFFF;
  --d-text-dim:   #9BB6D9;
}
/* 🌈 Неон-эффекты: свечение по контурам, заголовкам и активным кнопкам */
html.dark-active.night-neon .settings-card,
html.dark-active.night-neon .card,
html.dark-active.night-neon .panel,
html.dark-active.night-neon .tile,
html.dark-active.night-neon .dash-card,
html.dark-active.night-neon .product-card,
html.dark-active.night-neon .search-result-card,
html.dark-active.night-neon .member-block,
html.dark-active.night-neon .member-hero,
html.dark-active.night-neon .lesson-card,
html.dark-active.night-neon .lesson-row,
html.dark-active.night-neon details.card {
  box-shadow:
    0 0 0 1px rgba(0,224,255,0.32),
    0 0 18px rgba(0,224,255,0.18),
    0 0 38px rgba(255,46,196,0.10);
}
html.dark-active.night-neon h1,
html.dark-active.night-neon h2,
html.dark-active.night-neon h3,
html.dark-active.night-neon .settings-h {
  text-shadow:
    0 0 8px rgba(0,224,255,0.55),
    0 0 18px rgba(0,224,255,0.30);
  color: #BFF6FF !important;
}
/* ── 🌈 Активные кнопки — cyan→magenta gradient ── */
html.dark-active.night-neon .seg-btn.active,
html.dark-active.night-neon a.btn-primary,
html.dark-active.night-neon button.primary,
html.dark-active.night-neon button[type="submit"],
html.dark-active.night-neon .settings-btn.active,
html.dark-active.night-neon .btn-success,
html.dark-active.night-neon .filter-apply,
html.dark-active.night-neon .nav-cta {
  background: linear-gradient(135deg, #00E0FF 0%, #FF2EC4 100%) !important;
  color: #04010F !important;
  border: 1px solid rgba(0,224,255,0.55) !important;
  text-shadow: none !important;
  box-shadow:
    0 0 10px rgba(0,224,255,0.65),
    0 0 24px rgba(255,46,196,0.40) !important;
}

/* Неон: универсальный белый текст внутри тёмных карточек, чтобы заголовки/имена не сливались */
html.dark-active.night-neon .src-name,
html.dark-active.night-neon .src-meta,
html.dark-active.night-neon .src-foot,
html.dark-active.night-neon .lesson-title,
html.dark-active.night-neon .lesson-desc,
html.dark-active.night-neon .ss-name,
html.dark-active.night-neon .ss-meta {
  color: #E0F2FF !important;
}
html.dark-active.night-neon .src-meta,
html.dark-active.night-neon .src-foot,
html.dark-active.night-neon .lesson-desc,
html.dark-active.night-neon .ss-meta {
  color: #9BB6D9 !important;
}
html.dark-active.night-neon .ss-rank {
  background: rgba(0,224,255,0.15) !important;
  color: #BFF6FF !important;
  text-shadow: 0 0 6px rgba(0,224,255,0.45) !important;
}

/* ── Неактивные кнопки — тёмная подложка, неоновая рамка ── */
html.dark-active.night-neon .seg-btn:not(.active),
html.dark-active.night-neon .settings-btn:not(.active),
html.dark-active.night-neon .btn-ghost,
html.dark-active.night-neon button:not(.primary):not([type="submit"]):not(.color-dot):not(.night-card):not(.nav-close):not(.msg-menu-btn):not(.rs-star):not(.active) {
  background: rgba(7, 2, 26, 0.55) !important;
  color: #BFF6FF !important;
  border: 1px solid rgba(0,224,255,0.40) !important;
  text-shadow: 0 0 4px rgba(0,224,255,0.25) !important;
  box-shadow: inset 0 0 6px rgba(0,224,255,0.10) !important;
}
/* Кнопка закрытия ☰-меню — без рамки во всех палитрах */
.nav-close,
html.dark-active .nav-close,
html.dark-active.night-neon .nav-close,
html.dark-active.night-cozy .nav-close {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
/* На странице логина — ничего лишнего: ни бургер-меню, ни FAB-чат, ни кнопки 🔍/🔔 */
html.cab-unauth .nav-fab,
html.cab-unauth .cab-actions,
html.cab-unauth .fab-chat,
html.cab-unauth .theme-switcher-floating,
html.cab-unauth .nav-overlay { display: none !important; }
html.dark-active.night-neon .seg-btn:not(.active):hover,
html.dark-active.night-neon .settings-btn:not(.active):hover {
  border-color: rgba(255,46,196,0.65) !important;
  box-shadow:
    0 0 8px rgba(255,46,196,0.45),
    inset 0 0 8px rgba(255,46,196,0.18) !important;
}
/* ── Поля ввода ── */
html.dark-active.night-neon input[type="text"],
html.dark-active.night-neon input[type="search"],
html.dark-active.night-neon input[type="number"],
html.dark-active.night-neon input[type="email"],
html.dark-active.night-neon input[type="tel"],
html.dark-active.night-neon input[type="date"],
html.dark-active.night-neon select,
html.dark-active.night-neon textarea,
html.dark-active.night-neon .settings-input {
  background: rgba(4, 1, 15, 0.65) !important;
  color: #E0F2FF !important;
  border: 1px solid rgba(255,46,196,0.50) !important;
  box-shadow: 0 0 8px rgba(255,46,196,0.18) inset !important;
}
html.dark-active.night-neon input:focus,
html.dark-active.night-neon select:focus,
html.dark-active.night-neon textarea:focus {
  border-color: #00E0FF !important;
  box-shadow:
    0 0 0 1px #00E0FF,
    0 0 14px rgba(0,224,255,0.50) !important;
  outline: none !important;
}
html.dark-active.night-neon ::placeholder { color: #6F89A8 !important; opacity: 0.9; }

/* ── Таблицы — заголовки и hover ── */
html.dark-active.night-neon table th,
html.dark-active.night-neon .ct-table th,
html.dark-active.night-neon .ph-table th {
  color: #FF7AD8 !important;
  text-shadow: 0 0 6px rgba(255,46,196,0.45) !important;
  border-bottom: 1px solid rgba(255,46,196,0.35) !important;
}
html.dark-active.night-neon table td,
html.dark-active.night-neon .ct-table td,
html.dark-active.night-neon .ph-table td {
  border-bottom: 1px solid rgba(0,224,255,0.12) !important;
}
html.dark-active.night-neon table tr:hover td,
html.dark-active.night-neon .ct-table tr:hover,
html.dark-active.night-neon .ph-table tbody tr:hover {
  background: rgba(0,224,255,0.05) !important;
  box-shadow: inset 3px 0 0 #00E0FF !important;
}

/* ── Аватары: неоновое кольцо ── */
html.dark-active.night-neon .hello-avatar,
html.dark-active.night-neon .recruit-avatar,
html.dark-active.night-neon .tg-chat-avatar,
html.dark-active.night-neon .prof-avatar,
html.dark-active.night-neon .prof-avatar-ph,
html.dark-active.night-neon .hello-avatar-ph {
  border: 2px solid #00E0FF !important;
  box-shadow:
    0 0 8px rgba(0,224,255,0.65),
    0 0 16px rgba(255,46,196,0.35) !important;
}

/* ── Бейджи капелек / счётчики ── */
html.dark-active.night-neon .badge,
html.dark-active.night-neon .drop-count,
html.dark-active.night-neon .pv-cell,
html.dark-active.night-neon .lrp-badge {
  color: #00E0FF !important;
  text-shadow: 0 0 6px rgba(0,224,255,0.55) !important;
}

/* ── Подписи / dim текст: поднять читаемость ── */
html.dark-active.night-neon .subtitle,
html.dark-active.night-neon .field-hint,
html.dark-active.night-neon .tile-desc,
html.dark-active.night-neon .settings-label,
html.dark-active.night-neon .new-meta,
html.dark-active.night-neon .dim,
html.dark-active.night-neon .muted,
html.dark-active.night-neon td.muted,
html.dark-active.night-neon .small,
html.dark-active.night-neon small {
  color: #B7C8DB !important;
}
html.dark-active.night-neon .rank,
html.dark-active.night-neon td .rank,
html.dark-active.night-neon .rank-cell {
  color: #D8B5FF !important;
  text-shadow: 0 0 4px rgba(167,107,255,0.35) !important;
}

/* ── Чекбоксы / радио (accent-color) ── */
html.dark-active.night-neon input[type="checkbox"],
html.dark-active.night-neon input[type="radio"] {
  accent-color: #00E0FF !important;
}

/* ── Превью неон-карточки в settings — сияние ВОКРУГ круга, не квадрата ── */
html.dark-active.night-neon .night-card.active {
  box-shadow: none !important;
  background: transparent !important;
  border: none !important;
}
html.dark-active.night-neon .night-card.active .nc-swatch {
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,0.06),
    0 0 0 3px #00E0FF,
    0 0 16px rgba(0,224,255,0.65),
    0 0 28px rgba(255,46,196,0.35) !important;
  border-color: #00E0FF !important;
}
html.dark-active.night-cozy .night-card.active .nc-swatch {
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,0.06),
    0 0 0 3px #FFB04D,
    0 0 16px rgba(255,176,77,0.60) !important;
  border-color: #FFB04D !important;
}

/* ── Ссылки общего вида — cyan ── */
html.dark-active.night-neon a:not(.btn-primary):not(.seg-btn):not(.settings-btn):not(.night-card):not(.nav-cta) {
  color: #00E0FF !important;
  text-shadow: 0 0 6px rgba(0,224,255,0.40);
}
html.dark-active.night-neon a:hover {
  color: #FF7AD8 !important;
  text-shadow: 0 0 8px rgba(255,46,196,0.55) !important;
}

/* ── Лого/брендинг ── */
html.dark-active.night-neon .brand,
html.dark-active.night-neon .logo,
html.dark-active.night-neon .top-left b {
  color: #00E0FF !important;
  text-shadow:
    0 0 6px rgba(0,224,255,0.55),
    0 0 14px rgba(0,224,255,0.30) !important;
}

/* ── Скроллбар — cyan ── */
html.dark-active.night-neon ::-webkit-scrollbar { width: 10px; height: 10px; }
html.dark-active.night-neon ::-webkit-scrollbar-track { background: #07021A; }
html.dark-active.night-neon ::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #00E0FF, #A76BFF);
  border-radius: 6px;
  box-shadow: 0 0 8px rgba(0,224,255,0.40);
}

/* ════════════════════════════════════════════════════════════
   🎨 Зачистка зелёного по широкому списку страниц
   (Базе продуктов, главной, каталогу «где взять» и т.п.)
   ════════════════════════════════════════════════════════════ */
html.dark-active .pcat-hero,
html.dark-active .pcat-intro,
html.dark-active .pcat-section,
html.dark-active .pcat-group,
html.dark-active .pcat-block,
html.dark-active .pcat-card,
html.dark-active .product-card,
html.dark-active .product-tile,
html.dark-active .product-link,
html.dark-active .global-channel,
html.dark-active .global-channel-card,
html.dark-active .pcat-title,
html.dark-active .pcat-name,
html.dark-active .cat-title,
html.dark-active .tile-title {
  color: var(--d-text-strong) !important;
}
html.dark-active .pcat-section,
html.dark-active .pcat-block,
html.dark-active .pcat-card,
html.dark-active .product-card,
html.dark-active .product-tile,
html.dark-active .global-channel-card,
html.dark-active .pcat-group,
html.dark-active .cat-block .tile {
  background: var(--d-surface) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .pcat-card:hover,
html.dark-active .product-card:hover,
html.dark-active .global-channel-card:hover,
html.dark-active .cat-block .tile:hover {
  border-color: var(--d-border-2) !important;
  background: var(--d-surface-2) !important;
}
/* Подзаголовки/описания/латинские названия */
html.dark-active .pcat-sub,
html.dark-active .pcat-desc,
html.dark-active .pcat-latin,
html.dark-active .product-latin,
html.dark-active .product-desc,
html.dark-active .pcat-intro p,
html.dark-active .cat-sub,
html.dark-active .tile-desc {
  color: var(--d-text-dim) !important;
}
/* Зелёные «боковые акценты» border-left убираем — везде через --accent или прозрачно */
html.dark-active .pcat-card,
html.dark-active .global-channel-card,
html.dark-active .product-card {
  border-left-color: var(--d-border-2) !important;
}
/* Иконки-эмодзи в плитках — оставляем как есть (это unicode-картинки),
   но контейнеры под ними тоже из палитры */
html.dark-active .tile-emoji,
html.dark-active .pcat-emoji,
html.dark-active .product-emoji {
  filter: none !important;
}

/* ════════════════════════════════════════════════════════════
   🎨 Глобальная унификация ВСЕХ зелёных KPI / цифр / сводок
   ────────────────────────────────────────────────────────────
   На тёмных палитрах любые прибитые var(--g-text) в KPI-плитках
   подменяем на --d-text-strong. Бары графиков (Chart.js)
   слегка перекрашиваем через mix-blend для согласованности.
   ════════════════════════════════════════════════════════════ */
html.dark-active .stat-num-mini,
html.dark-active .stat-label-mini,
html.dark-active .ph-val,
html.dark-active .ph-label,
html.dark-active .ph-sub,
html.dark-active .pv-summary .pv-num,
html.dark-active .pv-summary .pv-label,
html.dark-active .summary-num,
html.dark-active .summary-label,
html.dark-active .drop-num,
html.dark-active .stat-card .stat-num,
html.dark-active .stat-card .stat-label,
html.dark-active table b,
html.dark-active table strong {
  color: var(--d-text-strong) !important;
}
html.dark-active .ph-label,
html.dark-active .ph-sub,
html.dark-active .pv-summary .pv-label,
html.dark-active .summary-label,
html.dark-active .stat-card .stat-label,
html.dark-active .stat-label-mini {
  color: var(--d-text-dim) !important;
}
/* Имя в шапке карточки участника + крупные заголовки в member_card */
html.dark-active #mNameTitle,
html.dark-active .member-name,
html.dark-active .member-hero h1,
html.dark-active .member-block h3 {
  color: var(--d-text-strong) !important;
}
/* Подложки KPI-плиток — берут из палитры */
html.dark-active .ph-card,
html.dark-active .pv-summary > div,
html.dark-active .stat-card {
  background: var(--d-surface) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .ph-card-best {
  background: linear-gradient(135deg, rgba(255,176,77,0.18), rgba(255,176,77,0.08)) !important;
}
/* Заголовки таблиц истории */
html.dark-active .ph-table th,
html.dark-active .ph-table td {
  color: var(--d-text) !important;
  border-bottom-color: var(--d-border) !important;
}

/* ════════════════════════════════════════════════════════════
   Унификация старых KPI/блоков под текущую палитру
   (история покупок, активность, аналитика ветки и пр.)
   ════════════════════════════════════════════════════════════ */
html.dark-active .info-line,
html.dark-active .info-label,
html.dark-active .info-block,
html.dark-active .member-block,
html.dark-active .activity-block,
html.dark-active .pv-summary,
html.dark-active .pv-card,
html.dark-active .ld-stat,
html.dark-active .stats-grid > *,
html.dark-active .info-grid > *,
html.dark-active .kpi-tile {
  background: var(--d-surface-3) !important;
  color: var(--d-text) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .info-label,
html.dark-active .pv-card .label,
html.dark-active .kpi-tile .label,
html.dark-active .ld-stat .label {
  color: var(--d-text-dim) !important;
}
html.dark-active .pv-card .value,
html.dark-active .kpi-tile .value,
html.dark-active .ld-stat .value {
  color: var(--d-text-strong) !important;
}
/* hover у таблиц команды/общих списков — не белый, а из палитры */
html.dark-active table tbody tr:hover,
html.dark-active .team-row:hover {
  background: var(--d-surface-2) !important;
}
/* Чтобы цвета Chart.js не «бились» — у нас в JS остался зелёный fallback;
   на тёмных палитрах вернём через CSS-фильтр (canvas адаптируется частично) */
html.dark-active canvas { filter: brightness(1.0); }
html.dark-active.night-neon canvas { filter: brightness(1.15) saturate(1.20); }
html.dark-active.night-cozy canvas { filter: brightness(1.10) sepia(0.10); }

/* ════════════════════════════════════════════════════════════
   Глобальные действия 🔍 / 🔔 — единый стиль на всех страницах
   (инжектится через JS в _base.html → host .cab-actions)
   ════════════════════════════════════════════════════════════ */
.cab-actions { display: inline-flex; gap: 8px; align-items: center; }
.cab-actions-floating {
  position: fixed; top: 12px; right: 64px; z-index: 100;
}
.notif-bell {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--accent-border, var(--g-border));
  text-decoration: none; font-size: 18px;
  transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
  color: var(--g-text);
}
.notif-bell:hover {
  transform: scale(1.05);
  border-color: var(--accent, var(--g-accent));
  text-decoration: none;
}
.notif-bell-dot {
  position: absolute; top: -4px; right: -4px;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: #c94d4d; color: white; border-radius: 9px;
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid white;
}
/* Глаз «скрыть суммы» — это <button>, сбрасываем дефолтный вид кнопки */
button.notif-bell { cursor: pointer; padding: 0; font-family: inherit; -webkit-appearance: none; appearance: none; }
.notif-bell[aria-pressed="true"] { border-color: var(--accent, var(--g-accent)); }

/* Тёмная тема — общая */
html.dark-active .notif-bell {
  background: var(--d-surface) !important;
  border-color: var(--d-border-2) !important;
  color: var(--d-text-strong) !important;
}
html.dark-active .notif-bell:hover {
  background: var(--d-surface-2) !important;
  border-color: var(--accent, var(--g-accent2)) !important;
}
html.dark-active .notif-bell-dot { border-color: var(--d-surface) !important; }

/* 🌈 Неон */
html.dark-active.night-neon .notif-bell {
  background: rgba(15,8,38,0.85) !important;
  border: 1px solid rgba(0,224,255,0.55) !important;
  box-shadow:
    0 0 10px rgba(0,224,255,0.50),
    inset 0 0 8px rgba(0,224,255,0.18) !important;
  color: #BFF6FF !important;
  text-shadow: 0 0 4px rgba(0,224,255,0.40);
}
html.dark-active.night-neon .notif-bell:hover {
  border-color: #FF2EC4 !important;
  box-shadow:
    0 0 14px rgba(255,46,196,0.65),
    inset 0 0 10px rgba(255,46,196,0.25) !important;
}
html.dark-active.night-neon .notif-bell-dot {
  background: #FF2EC4 !important;
  box-shadow: 0 0 8px rgba(255,46,196,0.7);
  border-color: #0F0826 !important;
}

@media (max-width: 640px) {
  .cab-actions-floating { top: 10px; right: 56px; gap: 6px; }
  .notif-bell { width: 32px; height: 32px; font-size: 16px; }
}

/* ════════════════════════════════════════════════════════════
   Универсальные правила для МОДАЛОВ в тёмных темах
   Перебивают inline `background:#fff` через специфичный селектор
   ════════════════════════════════════════════════════════════ */
html.dark-active #giftDialog > div,
html.dark-active .modal-dialog,
html.dark-active [data-modal-card] {
  background: var(--d-surface) !important;
  color: var(--d-text) !important;
  border: 1px solid var(--d-border) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.55) !important;
}
html.dark-active #giftDialog h1,
html.dark-active #giftDialog h2,
html.dark-active #giftDialog h3,
html.dark-active .modal-dialog h1,
html.dark-active .modal-dialog h2,
html.dark-active .modal-dialog h3 {
  color: var(--d-text-strong) !important;
}
html.dark-active #giftDialog p,
html.dark-active .modal-dialog p {
  color: var(--d-text-dim) !important;
}
html.dark-active #giftDialog #giftSearchResults,
html.dark-active #giftDialog #giftSelected {
  background: var(--d-surface-3) !important;
  border: 1px solid var(--d-border) !important;
}
html.dark-active .modal-cancel {
  background: var(--d-surface-3) !important;
  color: var(--d-text-dim) !important;
  border-color: var(--d-border) !important;
}

/* ── Неон: модалы дополнительно подсвечены ── */
html.dark-active.night-neon #giftDialog > div,
html.dark-active.night-neon .modal-dialog {
  background: #0A0420 !important;
  border: 1px solid rgba(0,224,255,0.55) !important;
  box-shadow:
    0 0 0 1px rgba(0,224,255,0.35),
    0 0 28px rgba(0,224,255,0.30),
    0 0 60px rgba(255,46,196,0.18),
    0 12px 50px rgba(0,0,0,0.7) !important;
}
html.dark-active.night-neon #giftDialog {
  background: rgba(4,1,15,0.78) !important;
  backdrop-filter: blur(4px);
}
html.dark-active.night-neon #giftDialog h2 {
  color: #BFF6FF !important;
  text-shadow: 0 0 8px rgba(0,224,255,0.55), 0 0 18px rgba(0,224,255,0.35) !important;
}
html.dark-active.night-neon #giftDialog p {
  color: #B7C8DB !important;
}
html.dark-active.night-neon #giftDialog .btn-primary {
  /* подхватит правило неон-кнопки выше — здесь только усиление */
  flex: 1;
}
html.dark-active body { color: var(--d-text); }

/* Текст / заголовки / подписи (широкий охват) */
html.dark-active h1, html.dark-active h2, html.dark-active h3,
html.dark-active h4 { color: var(--d-text-strong) !important; }
html.dark-active .subtitle, html.dark-active .tile-desc,
html.dark-active .cat-sub, html.dark-active .dash-sub,
html.dark-active .tg-chat-last, html.dark-active .tg-username,
html.dark-active .field-hint, html.dark-active .new-meta,
html.dark-active .dash-title, html.dark-active .lead-meta,
html.dark-active .subtask-meta, html.dark-active .today-details,
html.dark-active .today-meta, html.dark-active .info-label,
html.dark-active .uplink-meta, html.dark-active .step-hint,
html.dark-active label, html.dark-active .field label,
html.dark-active .td-meta, html.dark-active .stat-time,
html.dark-active .member-block h3, html.dark-active .group-ref,
html.dark-active .rec-row .rec-vol, html.dark-active .crm-strip-link {
  color: var(--d-text-dim) !important;
}
html.dark-active .new-name, html.dark-active .new-name-link,
html.dark-active .lead-name, html.dark-active .tile-title,
html.dark-active .tg-chat-name, html.dark-active .group-label,
html.dark-active .dash-value, html.dark-active .uplink-name,
html.dark-active .subtask-name, html.dark-active .today-task-title,
html.dark-active .hello, html.dark-active .top-left,
html.dark-active .info-line, html.dark-active .stat b,
html.dark-active .ct-table td, html.dark-active .ph-table td {
  color: var(--d-text-strong) !important;
}

/* Поверхности-карточки (всё, что было белым/светлым) */
html.dark-active .card,
html.dark-active .tile,
html.dark-active .dash-card,
html.dark-active .member-block,
html.dark-active .today-block,
html.dark-active .today-task,
html.dark-active .today-done-block,
html.dark-active .tg-chat-row,
html.dark-active .tg-msg-in .tg-msg-bubble,
html.dark-active .new-card,
html.dark-active .group-card,
html.dark-active .lead-row,
html.dark-active .broadcast-filters,
html.dark-active .broadcast-message,
html.dark-active .add-group-card,
html.dark-active .presets,
html.dark-active .connect-block,
html.dark-active .ph-card,
html.dark-active .status-card,
html.dark-active .level-card,
html.dark-active .service-card,
html.dark-active .search-result-card,
html.dark-active .recipients-block,
html.dark-active .preview-summary,
html.dark-active .crm-strip,
html.dark-active .tg-actions,
html.dark-active .tg-send-form,
html.dark-active .empty-state,
html.dark-active .av-modal,
html.dark-active .inv-modal,
html.dark-active .bd-modal {
  background: var(--d-surface) !important;
  border-color: var(--d-border) !important;
  box-shadow: none !important;
}
/* Приподнятые / вложенные */
html.dark-active .subtask,
html.dark-active .today-snooze-menu,
html.dark-active .theme-menu,
html.dark-active .fab-panel,
html.dark-active .dash-green,
html.dark-active .dash-orange,
html.dark-active .dash-pink,
html.dark-active .dash-primary,
html.dark-active .tg-chat-count,
html.dark-active .recruit-count {
  background: var(--d-surface-2) !important;
  border-color: var(--d-border) !important;
  color: var(--d-text) !important;
}
/* Hover-состояния */
html.dark-active .tile:hover,
html.dark-active .dash-card:hover,
html.dark-active .tg-chat-row:hover,
html.dark-active .uplink-row:hover,
html.dark-active .subtask-action:hover,
html.dark-active .theme-opt:hover,
html.dark-active .preset:hover { background: var(--d-surface-3) !important; }

/* Поля ввода */
html.dark-active input,
html.dark-active textarea,
html.dark-active select,
html.dark-active .filter-input,
html.dark-active .broadcast-textarea,
html.dark-active .tg-send-form textarea {
  background: var(--d-surface-3) !important;
  color: var(--d-text-strong) !important;
  border-color: var(--d-border-2) !important;
}
html.dark-active input::placeholder,
html.dark-active textarea::placeholder { color: #6f8478 !important; }

/* Хедер */
html.dark-active .top {
  background: rgba(20,30,25,0.75) !important;
  border-bottom-color: var(--d-border) !important;
}
html.dark-active .back-arrow,
html.dark-active .theme-btn,
html.dark-active .btn-ghost,
html.dark-active .today-add-btn,
html.dark-active .today-expand-btn,
html.dark-active .group-sync-btn,
html.dark-active .preset,
html.dark-active .subtask-action,
html.dark-active .new-action-btn,
html.dark-active .open-card-btn,
html.dark-active .tg-open-btn {
  background: var(--d-surface-2) !important;
  color: var(--d-text) !important;
  border-color: var(--d-border-2) !important;
}

/* Таблицы */
html.dark-active table th { color: var(--d-text-dim) !important; border-bottom-color: var(--d-border) !important; }
html.dark-active table td { border-bottom-color: var(--d-border) !important; }
html.dark-active .ct-table tr:hover,
html.dark-active .ph-table tbody tr:hover { background: var(--d-surface-2) !important; }

/* Прогресс-бары / разделители */
html.dark-active .today-progress-bar { background: rgba(120,160,130,0.15) !important; }
html.dark-active .theme-menu-sep,
html.dark-active .new-actions,
html.dark-active .tg-limits { border-color: var(--d-border) !important; }
html.dark-active .today-subtasks { border-left-color: var(--d-border-2) !important; }

/* Ссылки */
html.dark-active a { color: #7fc98a; }
html.dark-active .uplink-name,
html.dark-active .new-name-link,
html.dark-active .ct-table a,
html.dark-active .sponsor-link { color: var(--d-text-strong) !important; }

/* Капсулы-чипы — слегка приглушаем фон */
html.dark-active .badge,
html.dark-active .tg-chip-empty,
html.dark-active .lead-tag { background: var(--d-surface-3) !important; color: var(--d-text-dim) !important; border-color: var(--d-border) !important; }

/* Превью-маска дохода и прочие приглушённые */
html.dark-active .income-mask { color: #4a5a4f !important; }
html.dark-active .income-eye { background: var(--d-surface-3) !important; border-color: var(--d-border-2) !important; }

/* Переписка в тёмной теме — входящие пузыри читаемые */
html.dark-active .tg-msg-in .tg-msg-bubble {
  background: var(--d-surface-2) !important;
  color: var(--d-text-strong) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .tg-msg-time { color: var(--d-text-dim) !important; opacity: 0.95; }
/* Исходящие — акцент + белый (var(--accent) сам по теме) */
html.dark-active .tg-msg-out .tg-msg-bubble { color: #fff !important; }

/* Полноэкранные центрированные страницы (landing, login) */
.page-center {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.card {
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(10px);
  border-radius: 24px;
  padding: 60px 50px;
  max-width: 520px;
  text-align: center;
  box-shadow: 0 20px 60px rgba(60, 80, 60, 0.08);
}
.emoji { font-size: 64px; margin-bottom: 20px; }
h1 { font-size: 32px; font-weight: 600; margin-bottom: 12px; color: var(--g-text); }
.subtitle { font-size: 17px; color: var(--g-muted2); margin-bottom: 28px; line-height: 1.55; }
.btn {
  display: inline-block; background: var(--accent); color: white;
  padding: 14px 32px; border-radius: 14px; font-weight: 500;
  border: none; cursor: pointer; transition: transform 0.1s;
}
.btn:hover { background: var(--accent-dark); text-decoration: none; transform: translateY(-1px); }
.btn-ghost {
  background: transparent; color: var(--accent-text2);
  padding: 10px 18px; border-radius: 10px; border: 1px solid var(--accent-border);
  cursor: pointer; font: inherit;
}
.btn-ghost:hover { background: var(--accent-soft); }
.footer { margin-top: 36px; color: var(--g-muted); font-size: 13px; }
.tg-widget { margin: 12px 0 8px; min-height: 56px; }
.error {
  background: #fde8e8; color: #8a3030;
  padding: 14px 18px; border-radius: 12px; margin: 16px 0;
  font-size: 14px;
}
.hint { color: var(--g-muted2); font-size: 14px; margin: 16px 0; }
.hint code {
  background: #eaf4eb; padding: 2px 6px; border-radius: 4px;
  font-family: ui-monospace, monospace;
}

/* Кабинет — header + tiles */
.top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px;
  background: rgba(255, 255, 255, 0.85);
  border-bottom: 1px solid rgba(60, 100, 60, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  /* Закреплённый сверху хедер — скрывается при скролле вниз, появляется при скролле вверх */
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  transform: translateY(0);
  transition: transform 0.25s ease;
  will-change: transform;
}
.top.top--hidden { transform: translateY(-105%); }
/* Чтобы первый блок страницы не уходил под закреплённый хедер */
body { padding-top: 68px; }
html.dark-active .top { background: rgba(10, 20, 12, 0.82); }
.top-left { font-size: 18px; color: var(--accent-text, var(--g-text)); }
.top-right { display: flex; align-items: center; gap: 16px; }
.hello { color: var(--g-text2); font-size: 14px; }
.badge {
  background: #d4e8d6; color: #2d5a32;
  padding: 3px 10px; border-radius: 10px; font-size: 11px;
  margin-left: 4px;
}

.wrap { max-width: 1100px; margin: 0 auto; padding: 40px 24px; }
.hero { text-align: center; margin-bottom: 48px; }
.hero h1 { font-size: 36px; margin-bottom: 10px; }
.hero .subtitle { max-width: 640px; margin: 0 auto; }

.tiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
}
.tile {
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 28px 24px;
  text-align: left;
  position: relative;
  transition: transform 0.15s, box-shadow 0.15s;
  border: 1px solid rgba(60, 100, 60, 0.06);
}
.tile:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 32px rgba(60, 100, 60, 0.08);
}
.tile-emoji { font-size: 40px; margin-bottom: 14px; }
.tile-title { font-size: 18px; font-weight: 600; color: var(--accent-text, var(--g-text)); margin-bottom: 8px; }
.tile-desc { font-size: 14px; color: var(--g-muted2); line-height: 1.5; }
.tile-status {
  position: absolute; top: 20px; right: 20px;
  background: #eaf0e9; color: #5a7a5d;
  padding: 3px 10px; border-radius: 8px; font-size: 11px;
}
.tile.soon { opacity: 0.85; }

/* ═══════════════════════════════════════════════════════════════
   📱 МОБИЛЬНАЯ АДАПТАЦИЯ
   Telegram / VK / iOS-Safari / Chrome Android
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Общее */
  .wrap { padding: 16px 12px; max-width: 100%; }
  h1 { font-size: 22px; line-height: 1.25; }
  h2 { font-size: 18px; }
  h3 { font-size: 16px; }
  .subtitle { font-size: 14px; line-height: 1.5; }

  /* Шапка — переносим в 2 строки + уменьшаем */
  .top {
    flex-wrap: wrap; padding: 10px 14px; gap: 8px;
    font-size: 14px;
  }
  .top-left { font-size: 14px; min-width: 0; flex: 1; }
  .top-left b { font-size: 14px; }
  .top-right { gap: 6px; flex-wrap: wrap; }
  .hello { font-size: 12px; }
  .badge { font-size: 10px; padding: 2px 6px; }
  .btn-ghost { padding: 6px 10px; font-size: 12px; }
  /* Скрываем разделители «/» в крошках на узких экранах */
  .top-left > span[style*="opacity"] { display: none; }

  /* Hero */
  .hero { margin-bottom: 16px; }
  .hero h1 { font-size: 22px; }

  /* Дашборд: 1 колонка */
  .dash-grid, .tiles {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .dash-card, .tile { padding: 14px 16px !important; }
  .dash-emoji, .tile-emoji { font-size: 28px !important; margin-bottom: 4px !important; }
  .dash-value { font-size: 22px !important; }
  .dash-title, .tile-title { font-size: 15px !important; }
  .dash-sub, .tile-desc { font-size: 12.5px !important; }

  /* «Что важно сегодня» */
  .today-block { padding: 14px 14px; border-radius: 12px; }
  .today-head { gap: 8px; }
  .today-title h2 { font-size: 17px; }
  .today-meta { font-size: 11.5px; }
  .today-add-btn { padding: 6px 10px; font-size: 12px; }
  .today-task { padding: 10px 12px; gap: 10px; }
  .today-task-title { font-size: 14px; }
  .today-details { font-size: 12px; }

  /* Кнопки */
  .btn { padding: 10px 18px; font-size: 14px; }

  /* Карточка участника / лида / новых */
  .new-card, .group-card, .lead-row { padding: 12px 14px !important; }
  .new-card-head { flex-direction: column; align-items: flex-start; gap: 6px; }
  .new-pv { align-self: flex-end; margin-top: -28px; }
  .new-actions { gap: 6px; }
  .new-action-btn { padding: 5px 9px; font-size: 11.5px; }

  /* Сегментация: фильтры под сообщение, не рядом */
  .broadcast-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .broadcast-filters, .broadcast-message { padding: 14px !important; }
  .preset { padding: 5px 10px; font-size: 12px; }
  .presets { padding: 10px 12px; }
  .recipients-list { max-height: 220px; }
  .rec-row { font-size: 13px; }
  .rec-row .rec-vol { display: block; margin-top: 2px; }

  /* Переписка */
  .tg-chat-row { padding: 10px 12px !important; gap: 10px !important; }
  .tg-chat-avatar { width: 36px !important; height: 36px !important; font-size: 15px !important; }
  .tg-chat-name { font-size: 14px !important; }
  .tg-chat-last { font-size: 12px !important; }
  .tg-chip { font-size: 10.5px; padding: 2px 7px; }
  .tg-msg { max-width: 88%; }

  /* CRM-полоска внутри чата */
  .crm-strip { padding: 12px; }
  .crm-stages-row { gap: 4px; }
  .crm-stage-step { padding: 6px 8px; font-size: 11.5px; }
  .crm-step-label { font-size: 11.5px; }

  /* Таблицы — в горизонтальный скролл */
  .ph-table, .placements-table, .registrations-table,
  table:not(.calendar):not(.tg-table) {
    font-size: 12px;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .ph-table th, .ph-table td { padding: 6px 8px; }

  /* Чаты → воронка */
  .add-group-row { flex-direction: column; align-items: stretch; }
  .add-group-row .btn { width: 100%; height: auto !important; align-self: auto !important; }
  .group-head { flex-direction: column; align-items: flex-start; }
  .group-actions { width: 100%; justify-content: space-between; }
  .group-sync-btn { flex: 1; }

  /* Дерево — даём scroll */
  #treeSvg, #treeContainer, .tree-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }

  /* График дохода — сжимаем */
  canvas { max-width: 100% !important; height: auto !important; }

  /* fab-chat сделаем чуть меньше и сместим выше theme-switcher не мешать */
  .fab-chat { width: 48px; height: 48px; font-size: 22px; right: 14px; bottom: 14px; }
  .fab-panel { right: 8px !important; bottom: 70px !important; width: calc(100vw - 16px) !important; max-width: 380px; }

  /* Тёмный/светлый переключатель — компактнее */
  .theme-switcher-floating { bottom: 14px; left: 14px; }
  .theme-btn { min-width: 38px; height: 32px; padding: 0 8px; }

  /* Стрелка назад — мельче */
  .back-arrow { width: 28px; height: 28px; font-size: 15px; margin-right: 6px; }

  /* Range-toggle (новые/неделя/месяц) */
  .range-toggle { flex-wrap: wrap; gap: 4px; }
  .range-btn { padding: 5px 10px; font-size: 12px; }

  /* Notif bell */
  .notif-bell { width: 32px; height: 32px; font-size: 16px; }

  /* Empty-state — мельче эмодзи на телефоне */
  .empty-state { padding: 30px 16px; }
  .empty-state .emoji, .today-empty-emoji { font-size: 36px !important; }

  /* Calculator */
  .calc-grid, .income-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* Узкий мобильный (≤400) — ещё компактнее */
@media (max-width: 400px) {
  h1 { font-size: 20px; }
  .top-left { font-size: 13px; }
  .top-left b { font-size: 13px; }
  .dash-value { font-size: 20px !important; }
  .crm-stages-row { flex-direction: column; }
  .crm-stage-step { width: 100%; justify-content: flex-start; padding: 7px 10px; }
}

/* Telegram WebApp: убираем горизонтальный paddings, цвет фона = telegram */
@media (display-mode: standalone), (display-mode: minimal-ui) {
  body { padding-bottom: env(safe-area-inset-bottom); }
}
.is-tma .top { display: none; }     /* В Mini App шапка от Telegram сама */
.is-tma .wrap { padding-top: 12px; }

/* Чат с помощником */
.chat-wrap {
  max-width: 820px; margin: 0 auto;
  display: flex; flex-direction: column;
  height: calc(100vh - 64px); padding: 0 16px;
}
.chat-list {
  flex: 1; overflow-y: auto; padding: 24px 8px;
  display: flex; flex-direction: column; gap: 14px;
}
.empty-state {
  text-align: center; max-width: 480px; margin: 60px auto;
  color: var(--g-muted2);
}
.empty-state .emoji { font-size: 56px; margin-bottom: 14px; }
.empty-state h2 { font-size: 22px; color: var(--g-text); margin-bottom: 10px; font-weight: 600; }
.empty-state p { font-size: 15px; line-height: 1.55; }

.msg { display: flex; flex-direction: column; max-width: 76%; }
.msg-user { align-self: flex-end; align-items: flex-end; }
.msg-assistant { align-self: flex-start; align-items: flex-start; }
.msg-bubble {
  padding: 12px 16px;
  border-radius: 18px;
  font-size: 15px; line-height: 1.55;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}
.msg-user .msg-bubble {
  background: var(--g-accentdk); color: white;
  border-bottom-right-radius: 6px;
}
.msg-assistant .msg-bubble {
  background: rgba(255,255,255,0.85);
  color: #2d3e2f;
  border: 1px solid rgba(60,100,60,0.08);
  border-bottom-left-radius: 6px;
}
.msg-pending .msg-bubble {
  background: rgba(255,255,255,0.6);
  color: var(--g-muted2);
  font-size: 18px; letter-spacing: 4px;
  animation: thinking-pulse 1.4s ease-in-out infinite;
}
@keyframes thinking-pulse {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 1; }
}

.chat-form {
  padding: 16px 0 20px;
  border-top: 1px solid rgba(60,100,60,0.08);
}
.input-wrap { display: flex; flex-direction: column; gap: 10px; }
.input-row { display: flex; gap: 10px; align-items: flex-end; }
.attach-btn {
  flex: 0 0 auto;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.85);
  border: 1px solid #c8dcc9;
  border-radius: 14px;
  cursor: pointer; font-size: 22px;
  transition: background 0.15s, border-color 0.15s;
}
.attach-btn:hover { background: #f0f7f1; border-color: var(--g-accentdk); }
.attach-btn.recording {
  background: #fde4e4 !important;
  border-color: #d66464 !important;
  color: #c44 !important;
  animation: rec-pulse 1.2s ease-in-out infinite;
}
@keyframes rec-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(214, 100, 100, 0.45); }
  50%      { box-shadow: 0 0 0 8px rgba(214, 100, 100, 0); }
}

.chat-form textarea {
  flex: 1;
  resize: none;
  border: 1px solid #c8dcc9;
  border-radius: 14px;
  padding: 12px 16px;
  font: inherit; font-size: 15px;
  background: rgba(255,255,255,0.85);
  color: #2d3e2f;
  min-height: 48px; max-height: 200px;
  outline: none;
}
.chat-form textarea:focus { border-color: var(--g-accentdk); }
.chat-form button[type="submit"] {
  background: var(--g-accentdk); color: white;
  border: none; border-radius: 14px;
  padding: 0 24px; height: 48px;
  font: inherit; font-weight: 500;
  cursor: pointer; transition: background 0.15s;
}
.chat-form button[type="submit"]:hover { background: var(--g-link); }
.chat-form button[type="submit"]:disabled { background: #b0c8b3; cursor: wait; }

/* Превью прикреплённой картинки */
.image-preview {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.85);
  border: 1px solid #c8dcc9;
  border-radius: 12px;
  padding: 8px 12px 8px 8px;
  align-self: flex-start;
  max-width: 100%;
}
.image-preview img {
  max-height: 64px; max-width: 100px;
  border-radius: 6px; object-fit: cover;
}
.image-preview button {
  background: none; border: none;
  font-size: 22px; color: var(--g-muted2);
  cursor: pointer; padding: 4px 8px;
  line-height: 1;
}
.image-preview button:hover { color: #c44; }

/* Картинка в сообщении */
.msg-image {
  max-width: 280px; max-height: 280px;
  border-radius: 14px; margin-bottom: 6px;
  object-fit: cover;
  background: rgba(0,0,0,0.04);
  box-shadow: 0 2px 8px rgba(60,100,60,0.10);
}
.msg-user .msg-image {
  border-bottom-right-radius: 6px;
}
.msg-assistant .msg-image {
  border-bottom-left-radius: 6px;
}

/* Карточки сводки и графики */
.summary-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px; margin-bottom: 32px;
}
.stat-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 16px;
  padding: 24px 22px;
  border: 1px solid rgba(60,100,60,0.06);
}
.stat-num {
  font-size: 36px; font-weight: 600; color: var(--g-text);
  line-height: 1.1; margin-bottom: 6px;
}
.stat-label { color: var(--g-muted2); font-size: 14px; }

.chart-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px 28px;
  margin-bottom: 24px;
  border: 1px solid rgba(60,100,60,0.06);
}
.chart-block h2 { font-size: 20px; font-weight: 600; color: var(--g-text); margin-bottom: 16px; }
.chart-header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 12px;
}
.chart-header h2 { margin-bottom: 0; }
.chart-canvas { position: relative; height: 280px; }

.range-toggle {
  display: inline-flex; background: var(--d-surface-2, #eaf0e9);
  border-radius: 12px; padding: 4px; gap: 2px;
  border: 1px solid var(--d-border, rgba(122,163,127,0.18));
}
.range-btn {
  background: transparent; border: none;
  padding: 7px 14px; border-radius: 8px;
  color: var(--d-text-strong, #5a7a5d); font: inherit; font-size: 14px;
  cursor: pointer; transition: background 0.15s, color 0.15s, box-shadow 0.15s;
  outline: none !important;
  text-decoration: none;
}
.range-btn:focus, .range-btn:focus-visible { outline: none !important; box-shadow: none !important; }
.range-btn:hover { background: var(--d-surface-3, rgba(122,163,127,0.15)); }
.range-btn.active {
  background: var(--d-accent, var(--g-accent)); color: var(--d-on-accent, #fff);
  box-shadow: none;
  text-decoration: none;
}
html.dark-active .range-btn.active { box-shadow: none !important; }
/* Кнопки гранулярности (недели/месяцы/...) */
.gran-btn {
  background: rgba(255,255,255,0.6);
  border: 1px solid var(--accent-border, var(--g-border));
  padding: 6px 13px; border-radius: 16px;
  color: var(--accent-text, #5a7a5d); font: inherit; font-size: 13px;
  cursor: pointer; transition: all 0.15s;
}
.gran-btn:hover { background: var(--accent-soft, var(--g-soft)); border-color: var(--accent, var(--g-accent)); }
.gran-btn.active {
  background: var(--accent, var(--g-accent)); color: #fff; border-color: var(--accent, var(--g-accent));
}
html.dark-active .gran-btn { background: var(--d-surface-2); color: var(--d-text); border-color: var(--d-border-2); }
html.dark-active .gran-btn.active { background: var(--accent, var(--g-accent)); color: #fff; }

/* Плавающий чат на каждой странице */
.fab-chat { position: fixed; right: 22px; bottom: 22px; width: 56px; height: 56px; border: none; border-radius: 50%; background: linear-gradient(135deg, var(--accent-light, var(--g-accent)), var(--accent-dark, var(--g-link))); color: white; font-size: 26px; cursor: pointer; z-index: 999; box-shadow: 0 8px 24px rgba(60,100,60,0.32); transition: transform 0.15s, box-shadow 0.15s; display: flex; align-items: center; justify-content: center; }
.fab-chat:hover { transform: translateY(-3px) scale(1.05); box-shadow: 0 12px 32px rgba(60,100,60,0.42); }
.fab-panel { position: fixed; right: 22px; bottom: 22px; width: 380px; max-width: calc(100vw - 32px); height: 540px; max-height: calc(100vh - 60px); background: white; border-radius: 18px; box-shadow: 0 18px 48px rgba(60,100,60,0.28); z-index: 1000; display: flex; flex-direction: column; overflow: hidden; border: 1px solid rgba(60,100,60,0.10); }
.fab-head { display: flex; align-items: center; gap: 10px; padding: 14px 18px; background: linear-gradient(135deg, var(--accent-soft, #eef5ee), var(--accent-soft2, #d4e8d6)); border-bottom: 1px solid rgba(60,100,60,0.08); font-size: 15px; color: var(--accent-text, var(--g-text)); }
.fab-head > span:first-child { flex: 1; }
.fab-open-full, .fab-close { background: transparent; border: none; font-size: 18px; color: var(--g-muted2); cursor: pointer; padding: 4px 8px; text-decoration: none; line-height: 1; }
.fab-close { font-size: 22px; }
.fab-open-full:hover, .fab-close:hover { color: var(--g-text); }
.fab-list { flex: 1; overflow-y: auto; padding: 14px 16px; display: flex; flex-direction: column; gap: 10px; }
.fab-empty { text-align: center; padding: 24px 8px; color: var(--g-muted2); font-size: 13px; line-height: 1.6; }
.fab-msg { display: flex; }
.fab-msg-user { justify-content: flex-end; }
.fab-msg-assistant { justify-content: flex-start; }
.fab-bubble { max-width: 84%; padding: 10px 14px; border-radius: 14px; font-size: 14px; line-height: 1.5; word-wrap: break-word; overflow-wrap: anywhere; }
.fab-msg-user .fab-bubble { background: var(--accent, var(--g-accentdk)); color: white; border-bottom-right-radius: 4px; }
.fab-msg-assistant .fab-bubble { background: #f0f7f1; color: #2d3e2f; border-bottom-left-radius: 4px; }
.fab-pending .fab-bubble { background: #eaf0e9; color: var(--g-muted2); letter-spacing: 3px; font-size: 16px; animation: thinking-pulse 1.4s ease-in-out infinite; }
.fab-bubble a { color: #3d7a45; text-decoration: underline; }
.fab-msg-user .fab-bubble a { color: #d4e8d6; }
.fab-bubble code { background: rgba(60,100,60,0.10); padding: 1px 5px; border-radius: 4px; font-family: ui-monospace, monospace; font-size: 0.9em; }
.fab-form { display: flex; gap: 8px; padding: 12px; border-top: 1px solid rgba(60,100,60,0.08); }
.fab-form textarea { flex: 1; padding: 9px 12px; border: 1px solid #c8dcc9; border-radius: 12px; font: inherit; font-size: 14px; background: white; color: #2d3e2f; outline: none; resize: none; min-height: 38px; max-height: 120px; }
.fab-form textarea:focus { border-color: var(--g-accentdk); }
.fab-form button { background: var(--g-accentdk); color: white; border: none; border-radius: 12px; width: 44px; font-size: 20px; font-weight: 500; cursor: pointer; transition: background 0.15s; }
.fab-form button:hover { background: var(--g-link); }
.fab-form button:disabled { background: #b0c8b3; cursor: wait; }
@media (max-width: 540px) { .fab-panel { right: 10px; bottom: 10px; left: 10px; width: auto; max-width: none; height: 70vh; } }

/* Telegram Business чаты */
.connect-block { background: rgba(255,255,255,0.85); border-radius: 18px; padding: 32px; border: 1px solid rgba(60,100,60,0.06); max-width: 720px; }
.connect-block h2 { color: var(--g-text); font-size: 22px; margin-bottom: 10px; text-align: center; }
.connect-emoji { font-size: 56px; margin-bottom: 14px; text-align: center; }
.connect-steps { padding-left: 24px; margin: 18px 0; }
.connect-steps li { margin: 12px 0; line-height: 1.5; color: var(--g-text); }
.connect-steps .step-hint { font-size: 13px; color: var(--g-muted); margin-top: 4px; }
.connect-steps code { background: #f0f7f1; color: var(--g-text); padding: 2px 8px; border-radius: 6px; font-weight: 600; }
.connect-note { margin-top: 18px; padding: 14px 18px; background: #eef5ee; border-radius: 12px; font-size: 13px; color: var(--g-text2); line-height: 1.6; }

.connect-only-you { margin: 22px 0 18px; padding: 18px 20px; background: linear-gradient(135deg, #fff5f7 0%, #fef0f4 100%); border-radius: 14px; border: 1px solid rgba(220,150,170,0.18); }
.only-you-label { font-size: 13px; font-weight: 600; color: #b85a7a; text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 10px; }
.connect-only-you .connect-steps { margin: 0; }
.connect-only-you .connect-steps li::marker { color: #b85a7a; font-weight: 700; }

.connect-bot-does { margin: 14px 0 18px; padding: 18px 20px; background: linear-gradient(135deg, var(--g-soft) 0%, var(--g-soft2) 100%); border-radius: 14px; border: 1px solid rgba(60,140,80,0.15); }
.bot-does-label { font-size: 13px; font-weight: 600; color: var(--g-mid); text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 10px; }
.bot-does-list { margin: 0; padding-left: 20px; }
.bot-does-list li { margin: 6px 0; color: var(--g-text2); font-size: 14px; line-height: 1.5; }
.bot-does-list li::marker { color: var(--g-accent); }

.connect-status { margin-top: 22px; padding: 14px 18px; background: rgba(255,255,255,0.6); border: 1px dashed rgba(60,140,80,0.3); border-radius: 12px; text-align: center; font-size: 14px; color: var(--g-muted3); display: flex; align-items: center; justify-content: center; gap: 10px; }
.pulse-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--g-accent); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); box-shadow: 0 0 12px rgba(110,166,118,0.6); }
}

.tg-chats-list { display: flex; flex-direction: column; gap: 8px; }
.tg-chat-row { display: flex; align-items: center; gap: 14px; padding: 14px 18px; background: rgba(255,255,255,0.85); border-radius: 14px; border: 1px solid rgba(60,100,60,0.06); text-decoration: none; color: inherit; transition: all 0.15s; }
.tg-chat-row:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(60,100,60,0.08); text-decoration: none; }
.tg-chat-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--g-accentdk), var(--g-link)); color: white; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 18px; flex-shrink: 0; }
.tg-chat-body { flex: 1; min-width: 0; }
.tg-chat-name { font-size: 15px; font-weight: 600; color: var(--g-text); }
.tg-chat-name .tg-username { color: var(--g-muted); font-weight: 400; font-size: 13px; }
.tg-chat-last { font-size: 13px; color: var(--g-muted2); margin-top: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tg-chat-meta { flex: 0 0 auto; }
.tg-chat-count { background: #eaf0e9; color: #5a7a5d; padding: 3px 10px; border-radius: 10px; font-size: 12px; font-weight: 600; }
.tg-chat-thread { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.tg-msg { display: flex; }
.tg-msg-in { justify-content: flex-start; }
.tg-msg-out { justify-content: flex-end; }
.tg-msg-bubble { max-width: 75%; padding: 10px 14px; border-radius: 16px; font-size: 14px; line-height: 1.5; word-wrap: break-word; overflow-wrap: anywhere; position: relative; }
.tg-msg-in .tg-msg-bubble { background: rgba(255,255,255,0.95); color: #2d3e2f; border: 1px solid rgba(60,100,60,0.08); border-bottom-left-radius: 4px; }
.tg-msg-out .tg-msg-bubble { background: var(--accent, var(--g-accentdk)); color: white; border-bottom-right-radius: 4px; }
.tg-msg-time { font-size: 11px; opacity: 0.7; margin-top: 4px; }
.tg-chat-hint { padding: 12px 16px; background: rgba(255,255,255,0.6); border-radius: 12px; color: var(--g-muted2); font-size: 13px; text-align: center; }

/* ЛРП */
.lrp-block { background: rgba(255,255,255,0.85); backdrop-filter: blur(8px); border-radius: 18px; padding: 24px 28px; margin-bottom: 20px; border: 1px solid rgba(60,100,60,0.06); }
.lrp-block h2 { font-size: 18px; font-weight: 600; margin-bottom: 4px; }
.lrp-block .subtitle { font-size: 13px; color: var(--g-muted2); margin-bottom: 14px; }
.lrp-list { display: flex; flex-direction: column; gap: 8px; }
.lrp-row-link { text-decoration: none; color: inherit; }
.lrp-row { display: flex; align-items: center; gap: 14px; padding: 12px 16px; background: rgba(255,255,255,0.6); border: 1px solid rgba(60,100,60,0.06); border-radius: 12px; transition: background 0.15s; }
.lrp-row:hover { background: rgba(234,245,235,0.7); }
.lrp-day { flex: 0 0 40px; background: #fff4e0; color: #c47a20; padding: 6px 10px; border-radius: 10px; font-weight: 600; font-size: 16px; text-align: center; line-height: 1.1; }
.lrp-body { flex: 1; min-width: 0; }
.lrp-name { font-size: 15px; font-weight: 600; color: var(--g-text); }
.lrp-meta { font-size: 12px; color: var(--g-muted2); margin-top: 3px; }
.lrp-contacts { flex: 0 0 auto; }
.lrp-contacts a { margin: 0 4px; font-size: 12px; font-weight: 500; color: #3d7a45; }

/* Лиды-воронка */
.leads-stages-bar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.stage-tab { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; background: rgba(255,255,255,0.7); border: 1px solid rgba(60,100,60,0.08); border-radius: 20px; color: var(--g-text2); font-size: 13px; text-decoration: none; transition: all 0.15s; }
.stage-tab:hover { background: white; text-decoration: none; }
.stage-tab.active { background: var(--stage-color, var(--g-text)); color: white; border-color: var(--stage-color, var(--g-text)); }
.stage-tab.active .stage-count { background: rgba(255,255,255,0.25); color: white; }
.stage-count { background: #eaf0e9; color: #5a7a5d; padding: 1px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; }
.leads-list { display: flex; flex-direction: column; gap: 10px; }
.lead-row-link { text-decoration: none; color: inherit; }
.lead-row { background: rgba(255,255,255,0.85); border-radius: 14px; padding: 14px 18px; border: 1px solid rgba(60,100,60,0.06); border-left: 4px solid var(--stage-color, #b0c8b3); display: flex; align-items: center; gap: 16px; transition: transform 0.15s, box-shadow 0.15s; }
.lead-row:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(60,100,60,0.08); }
.lead-stage-pill { flex: 0 0 auto; background: var(--stage-color, #b0c8b3); color: white; padding: 4px 12px; border-radius: 12px; font-size: 12px; font-weight: 500; white-space: nowrap; }
.lead-body { flex: 1; min-width: 0; }
.lead-name { font-size: 15px; font-weight: 600; color: var(--g-text); }
.lead-meta { font-size: 12px; color: var(--g-muted2); margin-top: 3px; }
.lead-note { margin-top: 6px; font-size: 13px; color: #5a7a5d; font-style: italic; }
.lead-tag { background: #d4e8d6; color: #2d5a32; padding: 4px 10px; border-radius: 10px; font-size: 12px; font-weight: 500; white-space: nowrap; }
.lead-stage-block { background: rgba(255,255,255,0.85); border-radius: 16px; padding: 20px 24px; border: 1px solid rgba(60,100,60,0.06); margin-top: 20px; }
.stage-flow { display: flex; flex-wrap: wrap; gap: 6px; }
.stage-pill { padding: 8px 14px; background: white; border: 1px solid rgba(60,100,60,0.10); border-radius: 14px; font: inherit; font-size: 13px; color: var(--g-text2); cursor: pointer; transition: all 0.15s; }
.stage-pill:hover { background: #f0f7f1; }
.stage-pill-active { background: var(--stage-color, var(--g-text)); color: white; border-color: var(--stage-color, var(--g-text)); }
.match-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 0; border-bottom: 1px solid rgba(60,100,60,0.06); }
.match-row:last-child { border-bottom: none; }
.event-row { padding: 10px 14px; border-radius: 10px; margin: 8px 0; border-left: 3px solid #c8dcc9; background: #fafdfa; }
.event-note { background: #fff8e0; border-left-color: #e8c474; }
.event-stage { background: #eaf5eb; border-left-color: var(--g-accentdk); }
.event-converted { background: #d4e8d6; border-left-color: #2d5a32; }
.event-time { font-size: 11px; color: var(--g-muted); margin-bottom: 4px; }
.event-text { font-size: 14px; color: var(--g-text); line-height: 1.4; }

/* Рассылка */
.broadcast-grid {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 20px;
}
@media (max-width: 800px) { .broadcast-grid { grid-template-columns: 1fr; } }
.broadcast-filters, .broadcast-message {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px 28px;
  border: 1px solid rgba(60,100,60,0.06);
}
.broadcast-filters h3, .broadcast-message h3 { color: var(--g-text); font-size: 16px; font-weight: 600; }
.filter-input {
  width: 100%; padding: 10px 14px;
  border: 1px solid #c8dcc9; border-radius: 10px;
  font: inherit; font-size: 14px;
  background: rgba(255,255,255,0.85);
  color: #2d3e2f; outline: none;
}
.filter-input:focus { border-color: var(--g-accentdk); }
.field { margin-bottom: 12px; }
.field label { display: block; font-size: 13px; color: var(--g-muted2); margin-bottom: 5px; }
.preview-summary {
  margin-top: 16px; padding: 14px 16px;
  background: #eaf5eb; border-radius: 12px;
  font-size: 14px; line-height: 1.5;
}
.ps-row { margin: 4px 0; color: var(--g-text); }
.ps-list { margin-top: 8px; color: var(--g-muted2); font-size: 13px; }
.broadcast-textarea {
  width: 100%; padding: 14px 18px;
  border: 1px solid #c8dcc9; border-radius: 12px;
  font: inherit; font-size: 15px; line-height: 1.5;
  background: rgba(255,255,255,0.85); color: #2d3e2f;
  outline: none; resize: vertical; min-height: 200px;
}
.broadcast-textarea:focus { border-color: var(--g-accentdk); }
.broadcast-hint {
  margin-top: 10px; font-size: 12px; color: var(--g-muted);
  padding: 10px 14px; background: #f7faf7; border-radius: 8px;
}
.send-result {
  margin-top: 14px; padding: 14px 16px;
  background: #d4e8d6; border-radius: 12px;
  font-size: 14px;
}
.sr-line { margin: 4px 0; color: #2d5a32; }

/* Поиск участника */
.search-form { display: flex; gap: 10px; align-items: center; }
.search-input-big {
  flex: 1; width: 100%; padding: 20px 24px;
  border: 2px solid var(--accent-border, #c8dcc9); border-radius: 18px;
  font: inherit; font-size: 20px;
  background: rgba(255,255,255,0.9);
  color: #2d3e2f; outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.search-input-big::placeholder { font-size: 18px; color: var(--g-hint); }
.search-input-big:focus {
  border-color: var(--accent, var(--g-accentdk));
  box-shadow: 0 0 0 3px rgba(110,166,118,0.15);
}
html.dark-active .search-input-big {
  background: var(--d-surface-3) !important; color: var(--d-text-strong) !important;
  border-color: var(--d-border-2) !important;
}

.search-results-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.search-result-card-link { text-decoration: none; color: inherit; display: block; }
.search-result-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 14px;
  padding: 16px 18px;
  border: 1px solid rgba(60,100,60,0.06);
  transition: transform 0.15s, box-shadow 0.15s;
}
.search-result-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(60,100,60,0.08);
}
.src-head { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.src-name { font-size: 15px; font-weight: 600; color: var(--g-text); margin-bottom: 4px; }
.src-meta { font-size: 12px; color: var(--g-muted2); }
.src-foot {
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid rgba(60,100,60,0.06);
  display: flex; justify-content: space-between;
  font-size: 12px; color: var(--g-muted);
}

/* Карточка участника */
.member-hero {
  display: flex; justify-content: space-between; gap: 24px;
  flex-wrap: wrap; align-items: center;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 20px;
  padding: 24px 30px;
  margin-bottom: 24px;
  border: 1px solid rgba(60,100,60,0.06);
}
.member-hero-right { display: flex; gap: 12px; flex-wrap: wrap; }
.stat-card-mini {
  background: #eaf5eb; border-radius: 12px;
  padding: 12px 18px; text-align: center;
  min-width: 100px;
}
.stat-num-mini { font-size: 22px; font-weight: 600; color: var(--g-text); }
.stat-label-mini { font-size: 11px; color: var(--g-muted2); }

.member-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.member-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 16px;
  padding: 20px 22px;
  border: 1px solid rgba(60,100,60,0.06);
}
.member-block h3 { font-size: 14px; color: var(--g-muted2); margin-bottom: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; }
.info-line { font-size: 14px; color: var(--g-text); margin: 8px 0; line-height: 1.5; }
.info-label { color: var(--g-muted2); margin-right: 6px; }

/* Цепочка наставников вверх (спонсорская / рекрутёрская ветка) */
.uplink-chain { display: flex; flex-direction: column; gap: 2px; }
.uplink-row {
  display: flex; align-items: baseline; gap: 8px;
  padding: 7px 10px; border-radius: 8px; text-decoration: none;
  transition: background 0.15s; position: relative;
}
.uplink-row:hover { background: var(--accent-soft, var(--g-soft)); text-decoration: none; }
.uplink-arrow {
  color: var(--accent-light, var(--g-accent)); font-weight: 700; flex: 0 0 auto;
  font-size: 13px; width: 14px; text-align: center;
}
.uplink-name { font-weight: 600; color: var(--accent-text, var(--g-text)); flex: 0 0 auto; }
.uplink-meta { font-size: 12px; color: var(--g-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* Лёгкая «лесенка»: каждый следующий уровень чуть правее */
.uplink-chain .uplink-row:nth-child(n+2) { margin-left: 6px; }
.uplink-chain .uplink-row:nth-child(n+3) { margin-left: 12px; }
.uplink-chain .uplink-row:nth-child(n+4) { margin-left: 18px; }
.uplink-chain .uplink-row:nth-child(n+5) { margin-left: 24px; }

/* Доход */
.income-hero {
  background: linear-gradient(135deg, #eef5ee, #d4e8d6);
  border-radius: 20px;
  padding: 32px 32px;
  margin-bottom: 24px;
  text-align: center;
  border: 1px solid #b8d4ba;
}
.income-hero-label { color: #5a7a5d; font-size: 14px; }
.income-hero-amount {
  font-size: 48px; font-weight: 600;
  color: #2d5a32; margin: 6px 0 8px;
}
.income-hero-sub { color: var(--g-muted2); font-size: 14px; }

.income-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.income-row {
  background: rgba(255,255,255,0.85);
  border-radius: 14px; padding: 16px 22px;
  border: 1px solid rgba(60,100,60,0.08);
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px;
}
.income-row-done { background: linear-gradient(90deg, #eef5ee, rgba(255,255,255,0.85) 70%); }
.income-row-estimate { background: linear-gradient(90deg, #f0f4f8, rgba(255,255,255,0.85) 70%); }
.income-row-left { display: flex; align-items: center; gap: 14px; }
.income-icon { font-size: 26px; }
.income-title { font-size: 15px; font-weight: 600; color: var(--g-text); }
.income-desc { font-size: 13px; color: var(--g-muted2); margin-top: 3px; }
.income-amount {
  font-size: 22px; font-weight: 600;
  color: var(--g-accentdk); white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.next-bonus {
  background: linear-gradient(135deg, #fff8e0, #ffe9b8);
  border-radius: 16px;
  padding: 20px 26px;
  margin-bottom: 20px;
  display: flex; gap: 20px; align-items: center;
  border: 1px solid #f0d090;
}
.next-bonus-emoji { font-size: 40px; }
.next-bonus-label { color: #8a6a20; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.next-bonus-title { font-size: 18px; color: #5a4520; margin: 4px 0; }
.next-bonus-hint  { color: #8a6a20; font-size: 14px; }

.hint-box {
  background: rgba(255,255,255,0.7);
  border-radius: 14px;
  padding: 18px 24px;
  border: 1px solid rgba(60,100,60,0.06);
}
.hint-box h3 { font-size: 14px; color: var(--g-muted2); margin-bottom: 8px; font-weight: 600; }
.hint-box ul { padding-left: 22px; color: var(--g-muted2); font-size: 13px; line-height: 1.7; }

/* Сервисы команды */
.service-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 26px 28px;
  margin-bottom: 20px;
  border: 1px solid rgba(60,100,60,0.06);
}
.service-head { display: flex; gap: 18px; align-items: flex-start; margin-bottom: 16px; }
.service-emoji { font-size: 42px; line-height: 1; flex: 0 0 auto; }
.service-card h2 { font-size: 20px; color: var(--g-text); margin-bottom: 4px; }
.service-card .subtitle { font-size: 14px; color: var(--g-muted2); }

.link-block {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  margin-bottom: 14px;
}
.link-input {
  flex: 1; min-width: 220px;
  padding: 10px 14px;
  background: #f7faf7;
  border: 1px solid #c8dcc9;
  border-radius: 10px;
  font-family: ui-monospace, monospace;
  font-size: 12px;
  color: var(--g-text2);
  outline: none;
}
.copy-btn { padding: 10px 16px; font-size: 14px; }

.qr-block {
  display: inline-block;
  padding: 12px;
  background: white;
  border-radius: 12px;
  border: 1px solid rgba(60,100,60,0.10);
  margin-bottom: 10px;
}

.instr {
  margin-top: 10px;
  border-top: 1px solid rgba(60,100,60,0.06);
  padding-top: 12px;
}
.instr summary {
  cursor: pointer;
  color: var(--g-accentdk); font-weight: 500;
  padding: 6px 0;
}
.instr-body {
  padding: 12px 0;
  color: var(--g-text);
  font-size: 14px; line-height: 1.6;
}
.instr-body h3 { font-size: 14px; margin-top: 12px; margin-bottom: 6px; color: var(--g-text); }
.instr-body h3:first-child { margin-top: 0; }
.instr-body ol { padding-left: 22px; }
.instr-body li { margin: 4px 0; }

.share-tips {
  background: linear-gradient(135deg, #eef5ee, #e0f0e0);
  border-radius: 16px; padding: 20px 24px;
  border: 1px solid #c8e0ca;
}
.share-tips h3 { font-size: 16px; color: var(--g-text); margin-bottom: 10px; }
.share-tips ul { padding-left: 22px; color: var(--g-text2); line-height: 1.7; }

/* Обучение */
.learn-hero {
  display: flex; gap: 24px; flex-wrap: wrap;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 20px;
  padding: 28px 30px;
  margin-bottom: 28px;
  border: 1px solid rgba(60,100,60,0.06);
}
.learn-hero-left { flex: 1; min-width: 260px; }
.learn-hero-right { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.player-rank {
  display: inline-block;
  background: linear-gradient(135deg, #d4e8d6, #a8d4ab);
  color: #2d5a32; padding: 4px 14px;
  border-radius: 12px; font-size: 13px; font-weight: 600;
  margin-bottom: 8px;
}
.player-name { font-size: 24px; font-weight: 600; color: var(--g-text); margin-bottom: 12px; }
.xp-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.xp-value { font-size: 22px; font-weight: 600; color: var(--g-accentdk); }
.xp-next { font-size: 13px; color: var(--g-muted); }
.xp-bar {
  height: 8px; background: #eaf0e9;
  border-radius: 4px; overflow: hidden;
  max-width: 460px;
}
.xp-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #7ab07c, var(--g-accentdk));
  transition: width 0.4s ease;
}

.streak-box {
  background: linear-gradient(135deg, #fff4e0, #ffe0b8);
  border-radius: 16px;
  padding: 16px 22px;
  text-align: center;
  min-width: 120px;
}
.streak-num { font-size: 28px; font-weight: 600; color: #c47a20; line-height: 1; }
.streak-label { font-size: 12px; color: #8a6a20; margin-top: 4px; }
.streak-best { font-size: 11px; color: #b08850; margin-top: 4px; }
.rank-pos {
  background: linear-gradient(135deg, #e8d4f0, #c8a8e6);
  color: #553377;
  padding: 14px 22px; border-radius: 16px;
  font-size: 16px; font-weight: 600;
  text-align: center; min-width: 120px;
}

.levels-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px; margin-bottom: 32px;
}
.level-card-link { text-decoration: none; color: inherit; display: block; }
.level-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 22px 22px 20px;
  border: 1px solid rgba(60,100,60,0.08);
  border-top: 4px solid var(--lvl-color);
  transition: transform 0.15s, box-shadow 0.15s;
  position: relative;
}
.level-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(60,100,60,0.10);
}
.level-card-done::after {
  content: "💚"; position: absolute; top: 14px; right: 14px; font-size: 18px;
}
.level-num { font-size: 11px; color: var(--g-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.level-emoji { font-size: 40px; margin: 6px 0 4px; }
.level-title { font-size: 18px; font-weight: 600; color: var(--g-text); margin-bottom: 6px; }
.level-desc { font-size: 13px; color: var(--g-muted2); min-height: 36px; line-height: 1.45; }
.level-progress-row {
  display: flex; align-items: center; gap: 10px; margin-top: 14px;
}
.level-progress-bar {
  flex: 1; height: 6px; background: #eaf0e9;
  border-radius: 3px; overflow: hidden;
}
.level-progress-bar > div {
  height: 100%; background: var(--lvl-color);
  transition: width 0.4s ease;
}
.level-progress-text { font-size: 12px; color: var(--g-muted2); white-space: nowrap; }

.badges-block, .lb-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px 28px;
  margin-bottom: 20px;
  border: 1px solid rgba(60,100,60,0.06);
}
.badges-block h2, .lb-block h2 {
  font-size: 19px; font-weight: 600; color: var(--g-text); margin-bottom: 16px;
}
.badges-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}
.badge-card {
  background: linear-gradient(135deg, #fffaf0, #fff4e0);
  border: 1px solid #f0e0c0;
  border-radius: 12px; padding: 14px 12px; text-align: center;
  transition: transform 0.15s;
}
.badge-card:hover { transform: scale(1.03); }
.badge-emoji { font-size: 32px; margin-bottom: 4px; }
.badge-title { font-size: 13px; font-weight: 600; color: #5a4520; }
.badge-desc  { font-size: 11px; color: #8a7050; margin-top: 2px; }
.badge-locked {
  background: #f0f0f0; border-color: #d8d8d8;
  filter: grayscale(0.8); opacity: 0.55;
}

/* Регистрации - топ рекрутеров */
.recruit-list { list-style: none; padding: 0; margin: 0; }
.recruit-row { display: flex; align-items: center; gap: 14px; padding: 10px 0; border-bottom: 1px solid rgba(60,100,60,0.06); }
.recruit-row:last-child { border-bottom: none; }
.recruit-place { flex: 0 0 30px; font-size: 18px; font-weight: 600; color: var(--g-muted2); text-align: center; }
.recruit-avatar { flex: 0 0 34px; width: 34px; height: 34px; border-radius: 50%; object-fit: cover; }
.recruit-avatar-ph { display: flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; font-weight: 600; }
.recruit-name { flex: 1; color: var(--g-text); font-weight: 500; text-decoration: none; }
.recruit-name:hover { color: var(--g-accentdk); text-decoration: underline; }
.recruit-count { background: #d4e8d6; color: #2d5a32; padding: 3px 10px; border-radius: 10px; font-size: 13px; font-weight: 600; white-space: nowrap; }

.lb-list { list-style: none; padding: 0; margin: 0; }
.lb-row {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(60,100,60,0.06);
}
.lb-row:last-child { border-bottom: none; }
.lb-place {
  flex: 0 0 32px; font-size: 18px; font-weight: 600;
  color: var(--g-muted2); text-align: center;
}
.lb-name { flex: 1; color: var(--g-text); font-weight: 500; }
.lb-stats { color: var(--g-muted); font-size: 13px; }
.lb-me { background: linear-gradient(90deg, #eaf5eb, transparent 80%); border-radius: 10px; padding-left: 8px; }

/* Уровень - страница */
.lvl-hero {
  background: rgba(255,255,255,0.85);
  border-radius: 20px;
  padding: 28px 30px;
  margin-bottom: 24px;
  border-left: 6px solid var(--lvl-color);
  display: flex; align-items: center; gap: 24px;
}
.lvl-hero-emoji { font-size: 64px; }
.lvl-hero-tag { font-size: 12px; color: var(--g-muted); text-transform: uppercase; }
.lvl-hero-title { font-size: 28px; color: var(--g-text); margin: 4px 0 6px; }
.lvl-hero-desc { color: var(--g-muted2); font-size: 15px; line-height: 1.5; }

.lessons-list { display: flex; flex-direction: column; gap: 10px; }
.lesson-row {
  background: rgba(255,255,255,0.85);
  border-radius: 14px; padding: 16px 20px;
  border: 1px solid rgba(60,100,60,0.06);
  display: flex; align-items: center; gap: 16px;
  transition: background 0.15s;
}
.lesson-row.lesson-done { background: linear-gradient(90deg, #eaf5eb, rgba(255,255,255,0.85) 70%); }
.lesson-check { font-size: 22px; flex: 0 0 28px; }
.lesson-body { flex: 1; }
.lesson-title { font-size: 16px; font-weight: 600; color: var(--g-text); }
.lesson-desc  { font-size: 13px; color: var(--g-muted2); margin-top: 3px; }
.lesson-meta  { font-size: 12px; color: #c47a20; margin-top: 4px; font-weight: 500; }
.lesson-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.lesson-status { color: var(--g-accentdk); font-size: 14px; font-weight: 500; }
.lesson-complete-btn { padding: 8px 16px; font-size: 14px; }

/* Dark theme for lesson rows */
html.dark-active .lesson-row {
  background: rgba(122,163,127,0.08);
  border-color: rgba(122,163,127,0.2);
}
html.dark-active .lesson-row.lesson-done {
  background: linear-gradient(90deg, rgba(122,163,127,0.18), rgba(122,163,127,0.08) 70%);
}
html.dark-active .lesson-title { color: var(--g-dtext); }
html.dark-active .lesson-title a { color: var(--g-dtext); }
html.dark-active .lesson-desc  { color: var(--g-muted); }
html.dark-active .lesson-meta  { color: #d4af6a; }
html.dark-active .lesson-status { color: #7ab87a; }

/* ─── Universal modal styles (light + dark) ─── */
.ev-modal-bg {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 9999;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 20px; overflow-y: auto;
}
.ev-modal-bg-center { align-items: center; }
.ev-modal-panel {
  background: #ffffff;
  color: #2d3a2f;
  border-radius: 16px;
  max-width: 520px; width: 100%;
  padding: 24px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
  margin: auto;
}
.ev-modal-title {
  margin: 0 0 16px;
  color: var(--g-text);
  font-size: 19px; font-weight: 700;
}
.ev-modal-cancel {
  background: rgba(0,0,0,0.08) !important;
  color: #5a5a5a !important;
}
.ev-modal-cancel:hover { background: rgba(0,0,0,0.14) !important; }
html.dark-active .ev-modal-panel {
  background: #1e2a20;
  color: #d5e6d8;
  box-shadow: 0 12px 40px rgba(0,0,0,0.6);
}
html.dark-active .ev-modal-title { color: var(--g-light2); }
html.dark-active .ev-modal-panel .settings-label { color: var(--g-light2); opacity: 0.9; }
html.dark-active .ev-modal-panel h2,
html.dark-active .ev-modal-panel h3 { color: var(--g-light2); }
html.dark-active .ev-modal-cancel {
  background: rgba(255,255,255,0.08) !important;
  color: #d5e6d8 !important;
}
html.dark-active .ev-modal-cancel:hover { background: rgba(255,255,255,0.14) !important; }

/* Toast */
.toast {
  position: fixed; right: 24px; bottom: 24px;
  background: white; border-radius: 16px;
  padding: 16px 22px;
  box-shadow: 0 12px 36px rgba(60,100,60,0.20);
  border: 1px solid #c8e0ca;
  min-width: 240px; max-width: 340px;
  animation: slide-in 0.3s ease;
  z-index: 1000;
}
@keyframes slide-in {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.toast-xp { font-size: 20px; font-weight: 600; color: var(--g-accentdk); }
.toast-badges { margin-top: 10px; display: flex; flex-direction: column; gap: 8px; }
.toast-badge {
  background: linear-gradient(135deg, #fff4e0, #ffe9c0);
  padding: 10px 14px; border-radius: 12px;
  font-size: 14px; color: #5a4520; line-height: 1.35;
}
.toast-badge span { color: #8a7050; font-size: 12px; }

/* Дерево команды */
.tree-controls {
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap; margin-bottom: 20px;
}
.view-toggle {
  display: inline-flex; background: #eaf0e9;
  border-radius: 10px; padding: 3px; gap: 2px;
}
.view-btn {
  background: transparent; border: none;
  padding: 8px 16px; border-radius: 8px;
  color: #5a7a5d; font: inherit; font-size: 14px;
  cursor: pointer; transition: background 0.15s, color 0.15s;
}
.view-btn:hover { background: rgba(255,255,255,0.5); }
.view-btn.active {
  background: white; color: var(--g-text);
  box-shadow: 0 2px 6px rgba(60,100,60,0.08);
}

.tree-visual {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px;
  border: 1px solid rgba(60,100,60,0.06);
  position: relative;   /* якорь для кнопок зума */
}
.visual-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 18px;
  font-size: 14px; color: var(--g-muted2);
}
.visual-breadcrumb a { color: #3d7a45; text-decoration: none; font-weight: 500; }
.visual-breadcrumb a:hover { text-decoration: underline; }
.bc-sep { color: #b0c8b3; }
.bc-current { color: var(--g-text); font-weight: 600; }
.visual-canvas-wrap {
  width: 100%; overflow: auto;
  position: relative;
  -webkit-overflow-scrolling: touch;
}
#visual-svg { display: block; }

/* Кнопки зума карты — закреплены в углу панели, не уезжают со скроллом */
.zoom-controls {
  position: absolute; top: 16px; right: 16px; z-index: 8;
  display: flex; align-items: center; gap: 4px;
  background: rgba(255,255,255,0.95);
  border: 1px solid var(--accent-border, var(--g-border));
  border-radius: 12px; padding: 4px 6px;
  box-shadow: 0 4px 14px rgba(60,100,60,0.14);
}
.zoom-controls button {
  width: 30px; height: 30px; border: none; border-radius: 8px;
  background: transparent; cursor: pointer; font-size: 18px;
  color: var(--accent-text, var(--g-text)); line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.zoom-controls button:hover { background: var(--accent-soft, var(--g-soft)); }
#zoom-label { font-size: 12px; color: var(--g-muted2); min-width: 38px; text-align: center; }

.node-svg:hover rect:first-of-type {
  filter: brightness(0.96);
}

/* Тёмная тема для карты дерева */
html.dark-active .tree-visual {
  background: var(--d-surface) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .visual-canvas-wrap { background: transparent; }
html.dark-active .zoom-controls {
  background: var(--d-surface-2); border-color: var(--d-border-2);
}
html.dark-active .zoom-controls button { color: var(--d-text); }
html.dark-active .zoom-controls button:hover { background: var(--d-surface-3); }
html.dark-active .visual-breadcrumb a { color: #7fc98a; }
html.dark-active .bc-current { color: var(--d-text-strong); }
.node-svg:hover rect:first-of-type {
  filter: brightness(0.96);
}

.filter-btn {
  background: white;
  border: 1px solid #c8dcc9;
  color: #5a7a5d;
  padding: 9px 14px;
  border-radius: 10px;
  font: inherit; font-size: 14px;
  cursor: pointer; transition: all 0.15s;
}
.filter-btn:hover { background: #f0f7f1; }
.filter-btn.active {
  background: #fdf6e8;
  border-color: #e6cf94;
  color: #8a6a20;
}

.tree-search-block {
  position: relative; flex: 1; min-width: 240px;
}
.tree-search-block input {
  width: 100%; padding: 14px 18px;
  border: 1px solid #c8dcc9; border-radius: 14px;
  font: inherit; font-size: 15px;
  background: rgba(255,255,255,0.85);
  color: #2d3e2f; outline: none;
}
.tree-search-block input:focus { border-color: var(--g-accentdk); }

.search-results {
  position: absolute; top: 54px; left: 0; right: 0;
  background: white; border-radius: 14px;
  box-shadow: 0 8px 28px rgba(60,100,60,0.16);
  max-height: 420px; overflow-y: auto;
  display: none; z-index: 10;
}
.search-results.open { display: block; }
.search-item {
  padding: 12px 18px; cursor: pointer;
  border-bottom: 1px solid rgba(60,100,60,0.06);
  display: flex; align-items: center;
}
.search-item:last-child { border-bottom: none; }
.search-item:hover { background: #f0f7f1; }
.search-name { color: var(--g-text); font-size: 15px; }
.search-meta { font-size: 12px; color: var(--g-muted2); margin-top: 2px; }
.search-empty { padding: 20px; text-align: center; color: var(--g-muted); }

.tree-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 20px 24px;
  border: 1px solid rgba(60,100,60,0.06);
}

.tree-list, .tree-children {
  list-style: none; padding: 0; margin: 0;
}
.tree-children {
  margin-left: 28px;
  border-left: 1px dashed rgba(60,100,60,0.15);
  padding-left: 12px;
  display: none;
}
.tree-node.expanded > .tree-children { display: block; }

.node-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 10px;
  transition: background 0.15s;
}
.node-row.expandable { cursor: pointer; }
.node-row.expandable:hover { background: #f0f7f1; }
.node-row.highlight { background: #d4e8d6; animation: pulse 0.6s ease; }
@keyframes pulse {
  0% { transform: scale(0.98); }
  50% { transform: scale(1.02); }
  100% { transform: scale(1); }
}
.node-root { background: rgba(74, 122, 79, 0.08); }

.node-toggle {
  flex: 0 0 18px; font-size: 11px;
  color: var(--g-muted2); user-select: none;
}
.node-info { flex: 1; min-width: 0; }
.node-name { color: #2d3e2f; font-size: 15px; }
.node-rank {
  background: #eaf0e9; color: #5a7a5d;
  padding: 2px 8px; border-radius: 8px;
  font-size: 11px; margin-left: 4px;
  font-weight: 500; letter-spacing: 0.2px;
}
/* doTERRA-цвета рангов */
.node-rank[data-rank="Консультант"]              { background: #c8a8e6; color: #fff; }
.node-rank[data-rank="Менеджер"]                 { background: #a47fd4; color: #fff; }
.node-rank[data-rank="Директор"]                 { background: #6a4ca8; color: #fff; }
.node-rank[data-rank="Экзекьютив"]               { background: #2e7a3d; color: #fff; }
.node-rank[data-rank="Элит"]                     { background: #e8d63a; color: #4a4400; }
.node-rank[data-rank="Премьер"]                  { background: #d6478e; color: #fff; }
.node-rank[data-rank="Серебро"]                  { background: #b0b0b0; color: #fff; }
.node-rank[data-rank="Золото"]                   { background: #e89a3c; color: #fff; }
.node-rank[data-rank="Платина"]                  { background: #1a1a1a; color: #fff; }
.node-rank[data-rank="Бриллиант"]                { background: #6dcfd4; color: #1a3d40; }
.node-rank[data-rank="Голубой Бриллиант"]        { background: #3a4ec6; color: #fff; }
.node-rank[data-rank="Президентский Бриллиант"]  { background: #5b32a3; color: #fff; }
.node-meta { font-size: 12px; color: var(--g-muted2); margin-top: 2px; }
.node-row.is-recruit {
  background: linear-gradient(90deg, #fff8e8, transparent 80%);
  border-radius: 8px;
}
.my-recruit-star { font-size: 13px; }

/* Кто остыл - сворачиваемые блоки */
details.cool-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 0;
  margin-bottom: 14px;
  border: 1px solid rgba(60,100,60,0.06);
  overflow: hidden;
}
summary.cool-summary {
  list-style: none !important;
  list-style-type: none !important;
  cursor: pointer;
  padding: 20px 28px;
  display: flex !important;
  align-items: center;
  gap: 14px;
  user-select: none;
  transition: background 0.15s;
}
summary.cool-summary::-webkit-details-marker { display: none !important; }
summary.cool-summary::marker { content: "" !important; }
details.cool-block > summary.cool-summary:hover { background: rgba(60,100,60,0.04); }
details.cool-block > summary > .cool-h {
  font-size: 18px; font-weight: 600; color: var(--g-text);
  flex: 1;
}
details.cool-block > summary > .cool-count {
  background: #eaf0e9; color: #5a7a5d;
  padding: 3px 12px; border-radius: 12px;
  font-size: 13px; font-weight: 600;
}
details.cool-block > summary > .cool-arrow {
  color: var(--g-muted); font-size: 14px;
  transition: transform 0.2s ease;
}
details.cool-block[open] > summary > .cool-arrow { transform: rotate(180deg); }
details.cool-block > *:not(summary) {
  padding-left: 28px; padding-right: 28px;
}
details.cool-block > *:last-child { padding-bottom: 22px; }
details.cool-block .subtitle { font-size: 14px; color: var(--g-muted2); }

.cool-list {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 12px; align-items: start;            /* было stretch — давало вылет */
}
.cool-card {
  background: white;
  border-radius: 12px; padding: 14px 16px;
  border: 1px solid rgba(60,100,60,0.08);
  display: flex; flex-direction: column; gap: 8px;
  overflow: hidden;                          /* фикс: контакты больше не вылетают */
}
.cool-card .cool-contacts { padding-top: 4px; }  /* убран margin-top:auto */
.cool-card .cool-prev:empty { display: none; }   /* пустой блок PV не оставляет дыру */
.cool-card-hot   { border-left: 3px solid #c66; }
.cool-card-warm  { border-left: 3px solid #d99655; }
.cool-card-cold  { border-left: 3px solid #b0c8b3; }
.cool-head {
  display: flex; justify-content: space-between; gap: 10px;
  margin-bottom: 6px;
}
.cool-name { font-size: 15px; font-weight: 600; color: var(--g-text); }
.cool-meta { font-size: 12px; color: var(--g-muted2); }
.cool-days {
  background: #eaf0e9; color: #5a7a5d;
  padding: 2px 8px; border-radius: 8px;
  font-size: 12px; white-space: nowrap;
}
.cool-prev { font-size: 13px; color: var(--g-text2); margin-bottom: 6px; }
.cool-contacts a {
  margin-right: 12px; font-size: 13px; font-weight: 500;
  color: #3d7a45;
}

/* Новые участники */
.new-header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px; margin-bottom: 24px;
}
.new-header .subtitle { color: var(--g-muted2); font-size: 15px; }

.new-list {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 16px;
}
.new-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 16px;
  padding: 18px 20px;
  border: 1px solid rgba(60,100,60,0.08);
}
.new-card-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px; margin-bottom: 10px;
}
.new-name { font-size: 17px; font-weight: 600; color: var(--g-text); margin-bottom: 2px; }
.new-meta { font-size: 13px; color: var(--g-muted2); }
.new-pv {
  background: #d4e8d6; color: #2d5a32;
  padding: 4px 10px; border-radius: 10px;
  font-weight: 600; font-size: 13px; white-space: nowrap;
}
.new-contacts, .new-sponsor {
  font-size: 14px; color: var(--g-text2); margin-top: 6px;
}
.new-contacts a { margin: 0 6px; color: #3d7a45; font-weight: 500; }
.new-contacts-label, .new-sponsor-label {
  color: var(--g-muted2); margin-right: 6px;
}

a.range-btn { text-decoration: none; }
a.range-btn:hover { text-decoration: none; }

/* Сила Трёх */
.p3-status {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px; margin-bottom: 32px;
}
.status-card {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px;
  border: 1px solid rgba(60,100,60,0.06);
  text-align: center;
}
.status-card.status-done { background: #d4e8d6; border-color: #a8c8aa; }
.status-emoji { font-size: 40px; margin-bottom: 8px; }
.status-label { color: var(--g-muted2); font-size: 13px; margin-bottom: 6px; }
.status-value { font-size: 22px; font-weight: 600; color: var(--g-text); margin-bottom: 4px; }
.status-bonus { color: var(--g-muted2); font-size: 13px; }

.p3-block {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  border-radius: 18px;
  padding: 24px 28px;
  margin-bottom: 20px;
  border: 1px solid rgba(60,100,60,0.06);
}
.p3-block h2 { font-size: 19px; font-weight: 600; color: var(--g-text); margin-bottom: 8px; }
.p3-block .subtitle { font-size: 14px; color: var(--g-muted2); }

.p3-list { list-style: none; padding: 0; margin: 0; }
.p3-list li {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 0; border-bottom: 1px solid rgba(60,100,60,0.06);
  font-size: 15px;
}
.p3-list li:last-child { border-bottom: none; }
.p3-emoji { font-size: 18px; flex: 0 0 24px; }
.p3-name { flex: 1; color: #2d3e2f; }
.p3-pv { color: var(--g-muted2); font-variant-numeric: tabular-nums; }

.p3-cta { text-align: center; }
.p3-cta h2 { margin-bottom: 8px; }

@media (max-width: 600px) {
  .status-card { padding: 18px; }
  .p3-block { padding: 18px 20px; }
}

/* Markdown в ответах ассистента */
.msg-bubble h2 { font-size: 18px; font-weight: 600; margin: 12px 0 6px; color: var(--g-text); }
.msg-bubble h3 { font-size: 16px; font-weight: 600; margin: 10px 0 4px; color: var(--g-text); }
.msg-bubble h4 { font-size: 15px; font-weight: 600; margin: 8px 0 4px; color: var(--g-text); }
.msg-bubble h2:first-child, .msg-bubble h3:first-child, .msg-bubble h4:first-child { margin-top: 0; }
.msg-bubble b, .msg-bubble strong { font-weight: 600; }
.msg-bubble ul, .msg-bubble ol { margin: 8px 0; padding-left: 22px; }
.msg-bubble li { margin: 3px 0; }
.msg-bubble code {
  background: rgba(60,100,60,0.08);
  padding: 1px 6px; border-radius: 4px;
  font-family: ui-monospace, monospace;
  font-size: 0.92em;
}
.msg-bubble pre {
  background: rgba(60,100,60,0.08);
  padding: 12px 14px; border-radius: 8px;
  margin: 8px 0; overflow-x: auto;
}
.msg-bubble pre code { background: none; padding: 0; }
.msg-bubble a { color: #3d7a45; text-decoration: underline; }
.msg-user .msg-bubble a { color: #d4e8d6; }

.tile-link {
  text-decoration: none; color: inherit; display: block;
}

@media (max-width: 600px) {
  .chat-wrap { padding: 0 8px; }
  .msg-bubble { max-width: 88%; font-size: 14px; padding: 12px 14px; }
}

/* === Переключатель валюты === */
.cur-switcher { position: relative; display: inline-block; }
.cur-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; background: rgba(255,255,255,0.9);
  border: 1px solid var(--g-border); border-radius: 10px;
  color: var(--g-text); font-weight: 600; font-size: 14px;
  cursor: pointer; transition: all 0.15s;
}
.cur-btn:hover { background: var(--g-soft); border-color: var(--g-accent); }
.cur-flag { font-size: 16px; line-height: 1; }
.cur-code { letter-spacing: 0.4px; }
.cur-arrow { opacity: 0.5; font-size: 10px; margin-left: 2px; }
.cur-menu {
  position: absolute; top: calc(100% + 4px); right: 0;
  background: white; border: 1px solid #e0eae2; border-radius: 10px;
  box-shadow: 0 8px 20px rgba(60,100,60,0.12);
  z-index: 100; min-width: 130px; padding: 4px;
}
.cur-opt {
  display: flex; align-items: center; gap: 8px; width: 100%;
  padding: 8px 12px; background: none; border: none; cursor: pointer;
  color: var(--g-text); font-size: 14px; border-radius: 6px;
  text-align: left;
}
.cur-opt:hover { background: var(--g-soft); }
.cur-opt-active { background: #eaf3eb; font-weight: 600; }
.cur-check { margin-left: auto; color: var(--g-mid); }

/* === Онбординг-тур === */
.tour-overlay {
  position: fixed; inset: 0; background: rgba(20, 40, 25, 0.55);
  z-index: 9000; backdrop-filter: blur(2px);
}
.tour-highlight {
  position: absolute; z-index: 9100;
  border: 3px solid var(--g-accent); border-radius: 14px;
  box-shadow: 0 0 0 9999px rgba(20,40,25,0.55), 0 0 28px rgba(110,166,118,0.7);
  background: transparent; pointer-events: none;
  transition: all 0.3s ease;
  animation: tourPulse 1.8s ease-in-out infinite;
}
@keyframes tourPulse {
  0%, 100% { box-shadow: 0 0 0 9999px rgba(20,40,25,0.55), 0 0 28px rgba(110,166,118,0.5); }
  50% { box-shadow: 0 0 0 9999px rgba(20,40,25,0.55), 0 0 36px rgba(110,166,118,0.9); }
}
.tour-card {
  position: absolute; z-index: 9200; width: 340px;
  background: white; border-radius: 14px; padding: 20px 22px;
  box-shadow: 0 18px 50px rgba(20,40,25,0.35);
  font-family: inherit;
}
.tour-skip {
  position: absolute; top: 8px; right: 10px; background: none; border: none;
  font-size: 24px; color: #b5b5b5; cursor: pointer; line-height: 1;
  width: 28px; height: 28px; border-radius: 50%;
}
.tour-skip:hover { background: #f5f5f5; color: #c94d4d; }
.tour-title { font-size: 17px; font-weight: 700; color: var(--g-text); margin-bottom: 8px; padding-right: 30px; }
.tour-text { color: var(--g-text2); font-size: 14px; line-height: 1.5; margin-bottom: 16px; }
.tour-nav { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.tour-prev, .tour-next {
  background: var(--g-accentdk); color: white; border: none; border-radius: 8px;
  padding: 8px 16px; font-weight: 600; font-size: 13px; cursor: pointer;
  transition: all 0.15s;
}
.tour-prev { background: var(--g-border); color: var(--g-text); }
.tour-prev:hover:not([disabled]) { background: #c0d5c4; }
.tour-prev[disabled] { opacity: 0.4; cursor: not-allowed; }
.tour-next:hover { background: var(--g-link); }
.tour-count { font-size: 12px; color: var(--g-muted); }

@media (max-width: 540px) {
  .tour-card { width: calc(100vw - 24px); left: 12px !important; right: 12px; }
}

/* ─── Хлебные крошки по структуре команды (upline на карточке участника) ─── */
.struct-crumbs {
  background: rgba(122,163,127,0.08);
  border: 1px solid rgba(122,163,127,0.18);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 16px;
  font-size: 13px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  line-height: 1.6;
}
.struct-crumbs .sc-label {
  color: var(--g-muted3);
  font-weight: 500;
  margin-right: 4px;
}
.struct-crumbs .sc-link {
  color: var(--g-text);
  text-decoration: none;
  border-bottom: 1px dashed rgba(122,163,127,0.4);
  transition: color .12s ease, border-color .12s ease;
}
.struct-crumbs .sc-link:hover {
  color: #1f3a23;
  border-bottom-color: var(--g-accent2);
}
.struct-crumbs .sc-sep {
  color: var(--g-hint);
  font-size: 11px;
  user-select: none;
}
.struct-crumbs .sc-current {
  color: var(--g-text);
  font-weight: 600;
}
html.dark-active .struct-crumbs {
  background: rgba(122,163,127,0.12);
  border-color: rgba(122,163,127,0.25);
}
html.dark-active .struct-crumbs .sc-link { color: var(--g-dtext); }
html.dark-active .struct-crumbs .sc-current { color: #e3f0e5; }
html.dark-active .struct-crumbs .sc-label { color: var(--g-hint); }

/* ─── Переключатель языка ─── */
.lang-switcher {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 3000;
  font-size: 14px;
}
.lang-current {
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 20px;
  width: 38px; height: 38px;
  padding: 0;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  transition: all .15s ease;
}
.lang-current:hover { background: #fff; border-color: rgba(122,163,127,0.6); }
.lang-list {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: #fff;
  border: 1px solid rgba(122,163,127,0.25);
  border-radius: 10px;
  padding: 6px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.1);
  display: none;
  min-width: 160px;
}
.lang-switcher.open .lang-list { display: block; }
.lang-opt {
  display: block;
  padding: 8px 12px;
  text-decoration: none;
  color: var(--g-text);
  border-radius: 6px;
  font-size: 14px;
}
.lang-opt:hover { background: rgba(122,163,127,0.1); }
.lang-opt.active { background: var(--g-accent2); color: #fff; }

html.dark-active .lang-current { background: rgba(40,55,42,0.85); border-color: rgba(122,163,127,0.4); }
html.dark-active .lang-list { background: #283729; border-color: rgba(122,163,127,0.35); }
html.dark-active .lang-opt { color: var(--g-dtext); }
html.dark-active .lang-opt:hover { background: rgba(122,163,127,0.2); }

/* На моб не загораживаем основной контент — чуть меньше */
@media (max-width: 640px) {
  .lang-switcher { top: 10px; right: 10px; }
  .lang-current { width: 32px; height: 32px; font-size: 15px; }
}

/* ─── Универсальное навигационное меню (плавающая ☰), слева ─── */
.nav-fab {
  position: fixed;
  top: 16px;
  left: 16px;
  z-index: 3000;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(122,163,127,0.3);
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  transition: all .15s ease;
  display: flex; align-items: center; justify-content: center;
  color: var(--g-text);
}
.nav-fab:hover { background: #fff; border-color: var(--g-accent2); transform: scale(1.05); }
.nav-overlay {
  position: fixed; inset: 0;
  background: rgba(40,55,42,0.45);
  z-index: 4000;
  opacity: 0; pointer-events: none;
  transition: opacity .18s ease;
  display: flex; justify-content: flex-start; align-items: stretch;
}
.nav-overlay.open { opacity: 1; pointer-events: auto; }
.nav-panel {
  background: #fff;
  width: 360px;
  max-width: 92vw;
  height: 100vh;
  padding: 56px 16px 20px;
  overflow-y: auto;
  box-shadow: 8px 0 24px rgba(0,0,0,0.15);
  position: relative;
  transform: translateX(-20px);
  opacity: 0;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-overlay.open .nav-panel { transform: translateX(0); opacity: 1; }
.nav-close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: 0; font-size: 26px; cursor: pointer;
  color: var(--g-muted3); line-height: 1;
}
.nav-close:hover { color: #1f3a23; }
.nav-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.nav-item {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  text-decoration: none;
  color: var(--g-text);
  background: rgba(122,163,127,0.08);
  border-radius: 10px;
  font-size: 14px;
  transition: background .12s ease;
  line-height: 1.25;
}
.nav-item:hover { background: rgba(122,163,127,0.18); }
.nav-item span { flex: 1; }

/* ── Тёмные палитры — берут переменные текущей ночной темы ── */
html.dark-active .nav-fab {
  background: var(--d-surface) !important;
  border: 1px solid var(--d-border-2) !important;
  color: var(--d-text-strong) !important;
}
html.dark-active .nav-overlay { background: rgba(0,0,0,0.55); }
html.dark-active .nav-panel {
  background: var(--d-surface) !important;
  color: var(--d-text) !important;
  border-right: 1px solid var(--d-border) !important;
  box-shadow: 8px 0 28px rgba(0,0,0,0.6);
}
html.dark-active .nav-item {
  background: var(--d-surface-3) !important;
  color: var(--d-text-strong) !important;
  border: 1px solid var(--d-border) !important;
}
html.dark-active .nav-item:hover {
  background: var(--d-surface-2) !important;
  border-color: var(--d-border-2) !important;
}
html.dark-active .nav-close { color: var(--d-text-dim) !important; }
html.dark-active .nav-close:hover { color: var(--d-text-strong) !important; }
html.dark-active .nav-section { color: var(--d-text-dim) !important; }

/* ── 🌈 Неон: дополнительное свечение для меню ── */
html.dark-active.night-neon .nav-fab {
  border-color: rgba(0,224,255,0.55) !important;
  box-shadow: 0 0 10px rgba(0,224,255,0.50) !important;
  color: #BFF6FF !important;
}
html.dark-active.night-neon .nav-panel {
  background: #07021A !important;
  border-right: 1px solid rgba(0,224,255,0.45) !important;
  box-shadow: 8px 0 36px rgba(0,224,255,0.20), 0 0 60px rgba(255,46,196,0.10) !important;
}
html.dark-active.night-neon .nav-item {
  background: rgba(15,8,38,0.7) !important;
  border: 1px solid rgba(0,224,255,0.30) !important;
  color: #BFF6FF !important;
  text-shadow: 0 0 4px rgba(0,224,255,0.20);
}
html.dark-active.night-neon .nav-item:hover {
  border-color: #FF2EC4 !important;
  box-shadow: 0 0 12px rgba(255,46,196,0.45) !important;
  color: #FFD3F0 !important;
}
html.dark-active.night-neon .nav-section {
  color: #FF7AD8 !important;
  text-shadow: 0 0 6px rgba(255,46,196,0.35);
}

/* ── 💡 Ламповая: тёплое мягкое меню ── */
html.dark-active.night-cozy .nav-panel {
  background: #1F140C !important;
  border-right: 1px solid rgba(255,176,77,0.30) !important;
  box-shadow: 8px 0 36px rgba(255,176,77,0.12) !important;
}
html.dark-active.night-cozy .nav-item {
  background: rgba(38,26,17,0.70) !important;
  border: 1px solid rgba(255,176,77,0.22) !important;
  color: #FFEDD2 !important;
}
html.dark-active.night-cozy .nav-item:hover {
  border-color: #FFB04D !important;
  box-shadow: 0 0 10px rgba(255,176,77,0.35) !important;
}
html.dark-active.night-cozy .nav-section { color: #C9A57A !important; }

@media (max-width: 640px) {
  .nav-fab { top: 10px; left: 10px; width: 36px; height: 36px; font-size: 16px; }
  .nav-grid { grid-template-columns: 1fr; }
  .nav-panel { width: 280px; }
}

/* hello-link иконка без имени — выравнивание */
.hello-link-icon { display: inline-flex; align-items: center; }
.hello-link-icon .hello-avatar { margin: 0; }

/* ─── Чат: новый layout с сайдбаром (multi-chat) ─── */
.chat-app {
  display: grid;
  grid-template-columns: 280px 1fr;
  height: 100vh;
  background: #fff;
  overflow: hidden;
}
.chat-side {
  background: #f4f7f4;
  border-right: 1px solid rgba(122,163,127,0.2);
  display: flex; flex-direction: column;
  min-width: 0;
  transition: transform .2s ease;
}
.chat-side-head {
  display: flex; align-items: center; gap: 6px;
  padding: 12px;
  border-bottom: 1px solid rgba(122,163,127,0.18);
}
.chat-back-btn, .chat-side-toggle {
  background: rgba(122,163,127,0.1);
  border: 0; border-radius: 8px;
  width: 34px; height: 34px;
  text-decoration: none; color: var(--g-text);
  font-size: 18px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.chat-back-btn:hover, .chat-side-toggle:hover { background: rgba(122,163,127,0.2); }
.chat-new-btn {
  flex: 1;
  background: var(--g-accent2); color: #fff;
  border: 0; border-radius: 8px;
  padding: 8px 12px;
  font-size: 14px; font-weight: 500;
  cursor: pointer;
}
.chat-new-btn:hover { background: #6a9370; }
.chat-side-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  display: flex; flex-direction: column; gap: 4px;
}
.chat-side-item {
  display: block;
  position: relative;
  padding: 10px 32px 10px 12px;
  border-radius: 8px;
  text-decoration: none; color: var(--g-text);
  background: transparent;
  transition: background .12s;
  cursor: pointer;
}
.chat-side-item:hover { background: rgba(122,163,127,0.1); }
.chat-side-item.active { background: rgba(122,163,127,0.22); }
.csi-title { font-weight: 500; font-size: 14px; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap; }
.csi-preview { font-size: 12px; opacity: 0.65; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; }
.csi-menu {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px;
  background: transparent; border: 0; cursor: pointer;
  color: var(--g-muted3); font-size: 16px; line-height: 1;
  border-radius: 4px;
  opacity: 0;
  transition: opacity .12s;
}
.chat-side-item:hover .csi-menu { opacity: 1; }
.csi-menu:hover { background: rgba(0,0,0,0.06); }

.chat-main {
  display: flex; flex-direction: column;
  min-width: 0;
  height: 100vh;
}
.chat-top-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: #fff;
  border-bottom: 1px solid rgba(122,163,127,0.18);
  flex-shrink: 0;
}
.chat-burger {
  background: transparent; border: 0; cursor: pointer;
  font-size: 20px; color: var(--g-text);
  display: none; padding: 6px;
}
.chat-top-title { flex: 1; min-width: 0; }
.ctt-name { font-weight: 600; color: var(--g-text); font-size: 15px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ctt-sub { font-size: 11px; opacity: 0.6; }
.chat-clear-btn {
  background: rgba(122,163,127,0.1);
  border: 1px solid rgba(122,163,127,0.2);
  border-radius: 50%;
  width: 32px; height: 32px;
  cursor: pointer; font-size: 15px;
  color: var(--g-text);
}
.chat-clear-btn:hover { background: rgba(122,163,127,0.2); }

/* Список сообщений и форма — заполняют всё пространство */
.chat-app .chat-list { flex: 1; overflow-y: auto; padding: 16px; }
.chat-app .chat-form { padding: 12px 14px 16px; border-top: 1px solid rgba(122,163,127,0.12); background: #fff; }
.chat-app .input-wrap { max-width: 100%; }
.chat-app .input-row { display: flex; gap: 8px; align-items: flex-end; }
.chat-app #msg-input {
  flex: 1;
  min-height: 40px;
  max-height: 220px;
  padding: 10px 12px;
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 12px;
  font-size: 15px; font-family: inherit;
  resize: none;
  background: #fff;
  color: #2a3a2c;
}
.chat-app #msg-input:focus { outline: none; border-color: var(--g-accent2); }
.chat-app #send-btn {
  background: var(--g-accent2); color: #fff;
  border: 0; border-radius: 50%;
  width: 40px; height: 40px;
  font-size: 18px; cursor: pointer;
  flex-shrink: 0;
}
.chat-app #send-btn:hover:not(:disabled) { background: #6a9370; }
.chat-app #send-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.chat-app .attach-btn {
  width: 40px; height: 40px;
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 50%;
  background: #fff;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.chat-app .attach-btn:hover { background: rgba(122,163,127,0.1); }
.chat-app .attach-btn.recording { background: #c97a7a; color: #fff; }

/* Кнопка копирования на сообщении */
.msg { position: relative; }
.msg-copy {
  position: absolute;
  bottom: 6px; right: -36px;
  width: 28px; height: 28px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 50%;
  cursor: pointer;
  font-size: 13px;
  display: inline-flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: opacity .15s ease, background .12s ease, transform .12s;
}
.msg-copy:hover { transform: scale(1.08); }
.msg-assistant:hover .msg-copy { opacity: 1; }
.msg-copy:hover { background: #fff; }
.msg-copy.copied { background: var(--g-accent2); color: #fff; border-color: var(--g-accent2); opacity: 1; }

/* Меню действий чата (rename/delete) */
.thread-menu {
  position: fixed;
  z-index: 5000;
  background: #fff;
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 10px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  padding: 6px;
  min-width: 160px;
}
.thread-menu button {
  display: block; width: 100%;
  background: transparent; border: 0;
  padding: 8px 12px;
  text-align: left;
  cursor: pointer;
  font-size: 14px;
  color: var(--g-text);
  border-radius: 6px;
}
.thread-menu button:hover { background: rgba(122,163,127,0.12); }
.thread-menu button.danger { color: #9a3a44; }
.thread-menu button.danger:hover { background: rgba(210,146,154,0.15); }

/* Мобильный layout */
@media (max-width: 900px) {
  .chat-app { grid-template-columns: 1fr; }
  .chat-side {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: 280px;
    z-index: 100;
    transform: translateX(-100%);
    box-shadow: 4px 0 16px rgba(0,0,0,0.15);
  }
  .chat-side.open { transform: translateX(0); }
  .chat-side-toggle { display: none; }
  .chat-burger { display: inline-flex; align-items: center; justify-content: center; }
  .msg-copy { right: 6px; bottom: 6px; top: auto; opacity: 1; background: rgba(255,255,255,0.85); }
}

/* Тёмная тема для нового layout */
html.dark-active .chat-app { background: #1a221b; }
html.dark-active .chat-side { background: #20292a; border-right-color: rgba(122,163,127,0.3); }
html.dark-active .chat-side-item { color: var(--g-dtext); }
html.dark-active .chat-side-item:hover { background: rgba(122,163,127,0.15); }
html.dark-active .chat-side-item.active { background: rgba(122,163,127,0.28); }
html.dark-active .chat-top-bar { background: #1f2a20; border-bottom-color: rgba(122,163,127,0.25); }
html.dark-active .ctt-name { color: #d5e6d8; }
html.dark-active .chat-app .chat-form { background: #1f2a20; border-top-color: rgba(122,163,127,0.2); }
html.dark-active .chat-app #msg-input { background: #2a3a2c; color: #d5e6d8; border-color: rgba(122,163,127,0.3); }
html.dark-active .thread-menu { background: #2a3a2c; border-color: rgba(122,163,127,0.4); }
html.dark-active .thread-menu button { color: #d5e6d8; }
html.dark-active .thread-menu button:hover { background: rgba(122,163,127,0.2); }
html.dark-active .msg-copy { background: rgba(40,55,42,0.85); border-color: rgba(122,163,127,0.35); color: var(--g-dtext); }

/* ─── Путь лида (вехи) + напоминания ─── */
.lead-path .path-phase-title {
  font-size: 13px; color: var(--g-muted2); font-weight: 600;
  text-transform: uppercase; letter-spacing: .3px; margin-bottom: 8px;
}
.path-milestones { display: flex; flex-wrap: wrap; gap: 8px; }
.milestone {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px;
  border: 1px solid rgba(122,163,127,0.3);
  border-radius: 20px;
  background: #fff; cursor: pointer;
  font-size: 13px; color: var(--g-text);
  transition: all .12s ease;
}
.milestone:hover { border-color: var(--g-accent2); background: rgba(122,163,127,0.06); }
.milestone.done {
  background: var(--g-accent2); border-color: var(--g-accent2); color: #fff;
}
.milestone .ms-check {
  width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px;
}
.milestone.done .ms-check { font-weight: 700; }

.reminder-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px;
  background: rgba(122,163,127,0.06);
  margin-bottom: 6px;
}
.reminder-row.reminder-done { opacity: 0.5; text-decoration: line-through; }
.rem-date {
  font-size: 12px; font-variant-numeric: tabular-nums;
  background: rgba(122,163,127,0.15); padding: 3px 8px; border-radius: 6px;
  color: var(--g-muted3); white-space: nowrap;
}
.rem-date.rem-due { background: #d99655; color: #fff; }
.rem-text { flex: 1; font-size: 14px; color: #3d4d3f; }
.rem-act {
  width: 26px; height: 26px; border: 0; border-radius: 50%;
  background: rgba(122,163,127,0.15); cursor: pointer; font-size: 14px;
  color: var(--g-text);
}
.rem-act:hover { background: var(--g-accent2); color: #fff; }
.rem-del:hover { background: #c97a7a; }
.preset-btn {
  background: rgba(122,163,127,0.1); border: 1px solid rgba(122,163,127,0.25);
  border-radius: 16px; padding: 6px 12px; font-size: 13px;
  color: var(--g-text); cursor: pointer;
}
.preset-btn:hover { background: rgba(122,163,127,0.2); }

/* ─── Напоминания на дашборде («кому написать сегодня») ─── */
.lead-rem-block {
  background: linear-gradient(135deg, rgba(217,150,85,0.08), rgba(201,122,46,0.05));
  border: 1px solid rgba(217,150,85,0.3);
  border-radius: 16px; padding: 18px 20px; margin-bottom: 18px;
}
.lead-rem-title { font-size: 17px; color: #9a6a3a; margin: 0 0 12px; }
.lead-rem-list { display: flex; flex-direction: column; gap: 8px; }
.lead-rem-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  background: #fff; border-radius: 10px; padding: 10px 14px;
}
.lrem-main { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; min-width: 0; }
.lrem-name { font-weight: 600; color: var(--g-text); text-decoration: none; }
.lrem-name:hover { text-decoration: underline; }
.lrem-text { font-size: 14px; color: #5a6a5c; }
.lrem-overdue {
  font-size: 11px; background: #c97a7a; color: #fff;
  padding: 2px 8px; border-radius: 10px;
}
.lrem-actions { display: flex; gap: 6px; flex-shrink: 0; }
.lrem-btn, .lrem-done {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid rgba(122,163,127,0.25); background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  text-decoration: none; cursor: pointer; font-size: 15px; color: var(--g-text);
}
.lrem-done:hover { background: var(--g-accent2); color: #fff; }
.lrem-btn:hover { background: rgba(122,163,127,0.1); }

html.dark-active .milestone { background: #2a3a2c; color: var(--g-dtext); border-color: rgba(122,163,127,0.3); }
html.dark-active .milestone.done { background: var(--g-accent2); color: #fff; }
html.dark-active .reminder-row { background: rgba(122,163,127,0.12); }
html.dark-active .rem-text { color: #d5e6d8; }
html.dark-active .lead-rem-item { background: #2a3a2c; }
html.dark-active .lrem-name { color: #d5e6d8; }

/* ─── Глобальные form-контролы (единый вид на всех страницах) ─── */
.settings-input {
  padding: 10px 12px;
  border: 1px solid var(--accent-border, var(--g-border));
  border-radius: 10px;
  font-size: 15px; color: var(--g-text); font-family: inherit;
  background: #fff;
}
.settings-input:focus { outline: none; border-color: var(--accent, var(--g-accent2)); }

/* select — убираем нативную стрелку, рисуем свою */
select.settings-input,
.team-filter select,
select.filter-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%237aa37f' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
  cursor: pointer;
}

.settings-btn {
  padding: 9px 16px; border-radius: 10px; cursor: pointer;
  border: 1px solid var(--accent-border, var(--g-border));
  background: rgba(255,255,255,0.9); color: var(--g-text);
  font-size: 14px; font-family: inherit; transition: all 0.15s;
  display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
}
.settings-btn:hover { background: var(--accent-soft, var(--g-soft)); border-color: var(--accent, var(--g-accent2)); }
.settings-btn-danger { color: #b85a5a; }
.settings-btn-danger:hover { background: #fbe9e9; border-color: #e0b0b0; }

/* filter-input (карточки лидов и т.п.) — выравниваем с settings-input */
.filter-input {
  padding: 10px 12px;
  border: 1px solid var(--accent-border, var(--g-border));
  border-radius: 10px;
  font-size: 15px; color: var(--g-text); font-family: inherit;
  background: #fff;
}
.filter-input:focus { outline: none; border-color: var(--accent, var(--g-accent2)); }

html.dark-active .settings-input,
html.dark-active .filter-input,
html.dark-active select.settings-input {
  background-color: #2a3a2c; color: #d5e6d8; border-color: rgba(122,163,127,0.3);
}
html.dark-active .settings-btn {
  background: rgba(122,163,127,0.12); color: #d5e6d8; border-color: rgba(122,163,127,0.3);
}
html.dark-active .settings-btn:hover { background: rgba(122,163,127,0.22); }

/* Акцентная (primary) кнопка */
.settings-btn-primary {
  background: var(--accent, var(--g-accent2)); color: #fff; border-color: var(--accent, var(--g-accent2));
}
.settings-btn-primary:hover { background: #6a9370; border-color: #6a9370; color: #fff; }
html.dark-active .settings-btn-primary { background: var(--g-accent2); color: #fff; }

/* ─── Ежедневный бонус за вход ─── */
.daily-bonus {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg, rgba(127,168,204,0.12), rgba(122,163,127,0.1));
  border: 1px solid rgba(127,168,204,0.3);
  border-radius: 16px;
  padding: 14px 20px;
  margin-bottom: 18px;
}
.daily-bonus.claimed {
  background: linear-gradient(135deg, rgba(122,163,127,0.12), rgba(122,163,127,0.06));
  border-color: rgba(122,163,127,0.3);
}
.db-left { display: flex; align-items: center; gap: 14px; }
.db-drop { font-size: 32px; line-height: 1; }
.db-title { font-weight: 600; color: var(--g-text); font-size: 15px; }
.db-sub { font-size: 13px; color: var(--g-muted2); margin-top: 2px; }
.db-claim {
  background: #7fa8cc; color: #fff; border: 0;
  border-radius: 12px; padding: 10px 20px;
  font-size: 15px; font-weight: 600; cursor: pointer;
  white-space: nowrap; transition: all .15s;
}
.db-claim:hover:not(:disabled) { background: #6a96bc; transform: scale(1.04); }
.db-claim:disabled { opacity: 0.6; cursor: wait; }
.daily-bonus.just-claimed { animation: db-pop .5s ease; }
@keyframes db-pop {
  0% { transform: scale(1); }
  40% { transform: scale(1.02); box-shadow: 0 6px 24px rgba(122,163,127,0.3); }
  100% { transform: scale(1); }
}
html.dark-active .daily-bonus {
  background: var(--d-surface-3) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .db-title { color: var(--d-text-strong) !important; }
html.dark-active .db-sub   { color: var(--d-text-dim) !important; }
/* 🌈 Неон — кнопка «Получить» сияет */
html.dark-active.night-neon .db-claim {
  background: linear-gradient(135deg, #00E0FF 0%, #FF2EC4 100%) !important;
  color: #04010F !important;
  box-shadow: 0 0 10px rgba(0,224,255,0.55), 0 0 22px rgba(255,46,196,0.35);
}
html.dark-active.night-cozy .db-claim {
  background: linear-gradient(135deg, #FFB04D 0%, #C97934 100%) !important;
  color: #1F140C !important;
  box-shadow: 0 0 10px rgba(255,176,77,0.50);
}

/* ─── Q&A с кураторами ─── */
.qa-list { display: flex; flex-direction: column; gap: 12px; }
.qa-item {
  background: rgba(122,163,127,0.06);
  border-radius: 10px; padding: 12px 14px;
}
.qa-q { display: flex; gap: 8px; align-items: flex-start; flex-wrap: wrap; }
.qa-text { font-size: 14px; color: #3d4d3f; flex: 1; min-width: 0; }
.qa-badge {
  font-size: 11px; padding: 3px 8px; border-radius: 10px; white-space: nowrap;
}
.qa-open { background: rgba(217,150,85,0.2); color: #9a6a3a; }
.qa-ans { background: rgba(122,163,127,0.2); color: var(--g-text); }
.qa-a {
  margin-top: 8px; padding: 10px 12px;
  background: rgba(169,143,208,0.1);
  border-left: 3px solid #a98fd0;
  border-radius: 0 8px 8px 0;
  font-size: 14px; color: #3d4d3f;
}
.qa-a-label { font-weight: 600; color: #7a5fa0; }
html.dark-active .qa-item { background: rgba(122,163,127,0.12); }
html.dark-active .qa-text, html.dark-active .qa-a { color: #d5e6d8; }

/* ─── Совместный чат ─── */
.shared-badge {
  font-size: 11px; background: rgba(169,143,208,0.2); color: #7a5fa0;
  padding: 2px 8px; border-radius: 10px; margin-left: 8px; vertical-align: middle;
}
.chat-collab-btn {
  background: rgba(122,163,127,0.1); border: 1px solid rgba(122,163,127,0.2);
  border-radius: 50%; width: 32px; height: 32px; cursor: pointer;
  font-size: 15px; color: var(--g-text);
}
.chat-collab-btn:hover { background: rgba(122,163,127,0.2); }
.msg-author {
  font-size: 11px; color: #7a5fa0; font-weight: 600;
  margin-bottom: 3px; padding-left: 4px;
}
.collab-overlay {
  position: fixed; inset: 0; background: rgba(40,55,42,0.45);
  z-index: 6000; display: flex; align-items: center; justify-content: center; padding: 20px;
}
.collab-panel {
  background: #fff; border-radius: 16px; padding: 24px;
  max-width: 420px; width: 100%; position: relative;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
}
.collab-close {
  position: absolute; top: 12px; right: 14px; background: none; border: 0;
  font-size: 24px; cursor: pointer; color: var(--g-muted3);
}
.collab-member {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 10px; background: rgba(122,163,127,0.08);
  border-radius: 8px; margin-bottom: 5px; font-size: 14px; color: var(--g-text);
}
.collab-kick {
  background: none; border: 0; color: #c97a7a; cursor: pointer; font-size: 13px;
}
.collab-result {
  padding: 8px 10px; cursor: pointer; border-radius: 8px; font-size: 14px; color: var(--g-text);
}
.collab-result:hover { background: rgba(122,163,127,0.12); }
html.dark-active .collab-panel { background: #1f2a20; }
html.dark-active .collab-member { background: rgba(122,163,127,0.15); color: #d5e6d8; }
html.dark-active .collab-result { color: #d5e6d8; }
html.dark-active .collab-result:hover { background: rgba(122,163,127,0.2); }

/* ─── Карточки событий — вертикальные, просторные ─── */
.events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px; margin-bottom: 28px;
}
.event-card {
  position: relative;
  display: flex; flex-direction: column;
  background: #fff; border: 1px solid rgba(122,163,127,0.18);
  border-radius: 16px; padding: 16px 16px 14px;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.event-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(60,100,60,0.12);
  border-color: rgba(122,163,127,0.40);
}
.event-card.claim-approved { border-color: rgba(122,163,127,0.45); background: rgba(122,163,127,0.05); }
.event-card.claim-pending  { border-color: rgba(212,157,114,0.45); }

/* Шапка карточки: лого слева + текст справа */
.event-card .event-head {
  display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px;
}
.event-logo {
  width: 52px; height: 52px; flex-shrink: 0;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  background: rgba(122,163,127,0.12);
}
.event-logo[data-type="convention"]     { background: rgba(127,168,204,0.15); }
.event-logo[data-type="retreat"]        { background: rgba(169,143,208,0.15); }
.event-logo[data-type="sourcing"]       { background: rgba(122,163,127,0.18); }
.event-logo[data-type="leader_meeting"] { background: rgba(210,146,154,0.15); }
.event-info { flex: 1; min-width: 0; }
.event-name {
  font-weight: 700; color: var(--g-text); font-size: 15px; line-height: 1.30;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; text-overflow: ellipsis;
  word-break: break-word; hyphens: auto;
  margin: 0 56px 4px 0; /* справа место под admin-кнопки */
}
.event-meta {
  font-size: 12.5px; opacity: 0.70; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.event-drops {
  font-size: 12px; color: #5a7a8e; margin-top: 6px; font-weight: 500;
}

/* Action-зона: CTA на всю ширину снизу */
.event-action { margin-top: 12px; }
.event-btn {
  background: var(--g-accent2); color: #fff; border: 0;
  border-radius: 10px; padding: 10px 14px;
  font-size: 13.5px; font-weight: 600; cursor: pointer;
  white-space: nowrap; width: 100%;
  transition: background 0.12s, transform 0.08s;
}
.event-btn:hover { background: #6a9370; }
.event-btn:active { transform: scale(0.98); }
.event-status {
  font-size: 12.5px; padding: 8px 12px; border-radius: 10px;
  white-space: nowrap; display: block; text-align: center; font-weight: 500;
}
.st-pending  { background: rgba(212,157,114,0.18); color: #9a6a3a; }
.st-approved { background: rgba(122,163,127,0.20); color: var(--g-text); }
.st-rejected { background: rgba(210,146,154,0.18); color: #9a3a44; cursor: help; }

/* Admin-кнопки в правом верхнем углу — мини, не отвлекают */
.event-card .event-admin-tools {
  position: absolute; top: 10px; right: 10px;
  display: flex; gap: 4px;
}
.ev-admin-btn-mini {
  width: 28px; height: 28px; padding: 0;
  border: 1px solid rgba(122,163,127,0.25);
  background: rgba(255,255,255,0.85);
  border-radius: 8px;
  font-size: 13px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background 0.12s, border-color 0.12s;
}
.ev-admin-btn-mini:hover { background: rgba(122,163,127,0.20); border-color: rgba(122,163,127,0.50); }

/* Тёмные палитры через переменные */
html.dark-active .event-card {
  background: var(--d-surface) !important;
  border-color: var(--d-border) !important;
  color: var(--d-text) !important;
}
html.dark-active .event-card:hover { border-color: var(--d-border-2) !important; }
html.dark-active .event-name { color: var(--d-text-strong) !important; }
html.dark-active .event-meta { color: var(--d-text-dim) !important; }
html.dark-active .event-drops { color: var(--d-text-dim) !important; }
html.dark-active .ev-admin-btn-mini {
  background: var(--d-surface-3) !important;
  border-color: var(--d-border) !important;
  color: var(--d-text) !important;
}
/* 🌈 Неон — главная CTA сияет */
html.dark-active.night-neon .event-btn {
  background: linear-gradient(135deg, #00E0FF 0%, #FF2EC4 100%) !important;
  color: #04010F !important;
  box-shadow: 0 0 10px rgba(0,224,255,0.55), 0 0 22px rgba(255,46,196,0.35);
}
html.dark-active.night-cozy .event-btn {
  background: linear-gradient(135deg, #FFB04D 0%, #C97934 100%) !important;
  color: #1F140C !important;
  box-shadow: 0 0 10px rgba(255,176,77,0.55);
}

/* Мелкие превью фото в модерации заявок */
.claim-photo-thumb {
  width: 64px; height: 64px; border-radius: 10px; object-fit: cover;
  border: 1px solid rgba(122,163,127,0.2); cursor: zoom-in;
}
.claim-photo-empty {
  width: 64px; height: 64px; border-radius: 10px;
  background: rgba(0,0,0,0.05); display: flex; align-items: center; justify-content: center;
  font-size: 20px; opacity: 0.4;
}

/* Заголовки групп в навигационном меню */
.nav-section {
  font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
  color: var(--g-muted); font-weight: 600;
  margin: 14px 4px 6px;
}
.nav-section:first-of-type { margin-top: 4px; }
html.dark-active .nav-section { color: #7a9a7e; }

/* Кнопка «✏» рядом с именем на карточке участника */
.name-edit-btn {
  background: rgba(122,163,127,0.12); border: 0; border-radius: 50%;
  width: 30px; height: 30px; font-size: 14px; cursor: pointer;
  color: var(--g-muted3); vertical-align: middle; margin-left: 6px;
  transition: all .12s;
}
.name-edit-btn:hover { background: var(--g-accent2); color: #fff; transform: scale(1.08); }
html.dark-active .name-edit-btn { background: rgba(122,163,127,0.18); color: var(--g-dtext); }

/* ═══ MOBILE FIXES (@media max-width:480px) ══════════════════════════════
   Patched after mobile audit — June 2026
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {

  /* ── Income: stat cards — large numbers с переносом ── */
  .income-stat-val, .inc-val, .ph-val,
  [data-usd], .stat-big {
    font-size: clamp(14px, 5vw, 22px) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* ── Income: chart granularity tabs — overflow + fade ── */
  .gran-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
    mask-image: linear-gradient(to right, black 80%, transparent 100%);
  }

  /* ── Leaderboard / Income period pills — fade right ── */
  .lb-months, .br-pill-row {
    -webkit-mask-image: linear-gradient(to right, black 85%, transparent 100%);
    mask-image: linear-gradient(to right, black 85%, transparent 100%);
  }

  /* ── Income records table — horizontal scroll hint ── */
  .ct-table-wrap, .records-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    /* right shadow = скрытый контент справа */
    background: linear-gradient(to right, white 0%, white 90%, rgba(122,163,127,.2) 100%);
  }
  html.dark-active .ct-table-wrap,
  html.dark-active .records-table-wrap {
    background: linear-gradient(to right, #1a2e1c 0%, #1a2e1c 90%, rgba(122,163,127,.15) 100%);
  }

  /* ── Breadcrumb: длинные цепочки — скрываем средние элементы ── */
  .top-left .bc-sep + span + .bc-sep { display: none; }

  /* ── Hero заголовок — меньше отступов ── */
  .hero { margin-bottom: 20px; }
  .hero h1 { font-size: 20px; }

  /* ── Кнопки в хедере — не переносятся ── */
  .top-right { gap: 6px; }
  .top { padding: 8px 12px; }

  /* ── Карточки дашборда — правильный gap ── */
  .dash-tiles, .dash-grid {
    gap: 8px;
  }

  /* ── Settings socials — кнопка «Сохранить» адаптируется ── */
  #socials .settings-btn { font-size: 12px; padding: 6px 8px; }

  /* ── Модальные окна — не выходят за края ── */
  .collab-panel, .ev-modal, [id$="Dialog"] > div {
    max-width: calc(100vw - 24px) !important;
    margin: 12px auto !important;
  }

  /* ── Tables: min-width убирает переполнение там где нет wrapper ── */
  table { min-width: unset; }
  .ph-table th, .ph-table td { padding: 5px 4px; font-size: 12px; }

  /* ── Income manage — CSV textarea ── */
  textarea[placeholder*="period"] { font-size: 11px; }
}

/* ═════════════════════════════════════════════
   Dark theme fallbacks — глобальные override
   ═════════════════════════════════════════════ */
html.dark-active .stat-card {
  background: rgba(122,163,127,0.08) !important;
  border-color: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext);
}
html.dark-active .stat-card .stat-num { color: var(--g-dtext) !important; }
html.dark-active .stat-card .stat-label { color: var(--g-muted) !important; }
html.dark-active .stat-card-mini {
  background: rgba(122,163,127,0.1) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .lrp-block {
  background: rgba(122,163,127,0.06) !important;
  border-color: rgba(122,163,127,0.2) !important;
}
html.dark-active .lrp-block h2 { color: var(--g-dtext) !important; }
html.dark-active .chart-block {
  background: rgba(122,163,127,0.06) !important;
  border-color: rgba(122,163,127,0.2) !important;
}
html.dark-active .chart-block h2 { color: var(--g-dtext) !important; }

/* Tree (Дерево команды) — карточки узлов */
html.dark-active .node-row {
  background: rgba(122,163,127,0.1) !important;
  border-color: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .node-row.expandable:hover {
  background: rgba(122,163,127,0.18) !important;
}
html.dark-active .node-row.highlight {
  background: rgba(122,163,127,0.25) !important;
}
html.dark-active .node-root {
  background: rgba(122,163,127,0.18) !important;
}
html.dark-active .node-row.is-recruit {
  background: linear-gradient(90deg, rgba(196,122,32,0.18), rgba(122,163,127,0.1) 80%) !important;
}
html.dark-active .node-name { color: var(--g-dtext) !important; }
html.dark-active .node-meta { color: var(--g-muted) !important; }

/* Hint box (Поиск, How-to) */
html.dark-active .hint-box {
  background: rgba(122,163,127,0.08) !important;
  border-color: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .hint-box h3,
html.dark-active .hint-box b { color: var(--g-dtext) !important; }

/* Search dropdown */
html.dark-active .search-history,
html.dark-active .search-suggest {
  background: rgba(40,55,42,0.98) !important;
  border-color: rgba(122,163,127,0.3) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .sh-row:hover,
html.dark-active .ss-row:hover { background: rgba(122,163,127,0.18) !important; }

/* Daily bonus / leads stages — берут переменные палитры */
html.dark-active .daily-bonus {
  background: var(--d-surface-3) !important;
  border-color: var(--d-border) !important;
  color: var(--d-text) !important;
}
html.dark-active .daily-bonus .db-title { color: var(--d-text-strong) !important; }
html.dark-active .daily-bonus .db-sub { color: var(--d-text-dim) !important; }
html.dark-active .stage-tab {
  background: rgba(122,163,127,0.1) !important;
  border-color: rgba(122,163,127,0.25) !important;
  color: var(--g-light2) !important;
}
html.dark-active .stage-tab.active {
  background: var(--stage-color, var(--g-accent3)) !important;
  color: #fff !important;
}
html.dark-active .stage-count {
  background: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .lead-row {
  background: rgba(122,163,127,0.08) !important;
  border-color: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .lead-name { color: var(--g-dtext) !important; }
html.dark-active .lead-meta { color: var(--g-muted) !important; }

/* Tree List/Map container — dark */
html.dark-active .tree-block {
  background: rgba(122,163,127,0.06) !important;
  border-color: rgba(122,163,127,0.2) !important;
}
html.dark-active .tree-children {
  border-left-color: rgba(122,163,127,0.25) !important;
}

/* Member card hero + info blocks — dark */
html.dark-active .member-hero {
  background: rgba(122,163,127,0.08) !important;
  border-color: rgba(122,163,127,0.2) !important;
  color: var(--g-dtext);
}
html.dark-active .member-hero h1,
html.dark-active .member-hero .member-name { color: var(--g-dtext) !important; }
html.dark-active .stat-card-mini {
  background: rgba(122,163,127,0.15) !important;
  color: var(--g-dtext) !important;
}
html.dark-active .stat-card-mini .stat-num { color: var(--g-dtext) !important; }
html.dark-active .stat-card-mini .stat-label { color: var(--g-muted) !important; }

/* ── Мобильные правки: ☰ не перекрывает шапку, 💬 FAB не заходит на кнопки ── */
@media (max-width: 720px) {
  /* Сдвигаем шапку вправо от плавающей ☰ кнопки */
  .top { padding-left: 60px !important; }
  /* Мини-аппстайл (когда .is-tma) шапку прячет, поэтому ничего не делает */

  /* FAB чата меньше + ниже-правее, чтобы не наезжать на действия */
  .fab-chat { width: 44px !important; height: 44px !important; font-size: 20px !important; right: 10px !important; bottom: 10px !important; opacity: 0.85; }
  .fab-chat:hover { opacity: 1; }
  /* Гарантируем место под FAB-кнопкой внизу страницы */
  .wrap { padding-bottom: 80px; }

  /* Иконки контактов в карточках не должны вылезать */
  .new-card, .lead-row, .lrp-row, .cool-card { overflow: hidden; }
  .new-contacts, .lead-contacts, .recruit-row, .cool-contacts { flex-wrap: wrap; max-width: 100%; }
}

/* ── Tree map: на мобиле зум-контролы не наезжают на имя ── */
@media (max-width: 720px) {
  .zoom-controls {
    position: relative !important;
    top: auto !important; right: auto !important;
    margin: 8px auto 12px !important;
    width: fit-content;
  }
  /* Имя корня — переносим, не обрезаем */
  .tree-block > .node-row.node-root .node-name,
  .tree-block > .node-row .node-name {
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word;
  }
}

/* ── Settings: соц.сети на мобиле кнопка не должна выпадать ── */
@media (max-width: 720px) {
  .soc-input-wrap { min-width: 0 !important; }
  .settings-btn[id^="socBtn_"] {
    padding: 8px 10px !important; font-size: 12px !important;
  }
  /* Если узко — переносим Сохранить под input */
}
@media (max-width: 420px) {
  .settings-btn[id^="socBtn_"] {
    width: auto !important; min-width: 110px;
  }
  /* Социальная строка — кнопка под полем */
  div[style*="display:flex"][style*="gap:8px"]:has(> .soc-input-wrap) {
    flex-wrap: wrap !important;
  }
}

/* Кнопки выбора языка — используем переменную темы, не зелёный хардкод */
.seg-btn { transition: background 0.15s, color 0.15s; }
.seg-btn.active {
  background: var(--accent, var(--g-accent2)) !important;
  color: #fff !important;
  border-color: var(--accent, var(--g-accent2)) !important;
}

/* ── FAB ICQ-ромашка — БЕЗ круглой подложки, цветок «парит» с мягкой тенью ── */
.fab-chat.fab-icq {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0;
  text-decoration: none;
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
}
.fab-chat.fab-icq img {
  display: block;
  width: 42px; height: 42px;
  /* мягкая тень под лепестками, чтобы цветок не сливался с фоном */
  filter: drop-shadow(0 4px 10px rgba(0,0,0,0.22))
          drop-shadow(0 2px 4px rgba(0,0,0,0.10));
  transition: filter 0.2s, transform 0.2s;
}
.fab-chat.fab-icq:hover {
  background: transparent !important;
  transform: translateY(-3px) rotate(-8deg);
  box-shadow: none !important;
}
.fab-chat.fab-icq:hover img {
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.30))
          drop-shadow(0 0 14px rgba(122,200,90,0.45));
  transform: scale(1.10);
}
html.dark-active .fab-chat.fab-icq {
  background: transparent !important;
  border: none !important;
}
html.dark-active .fab-chat.fab-icq img {
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.65))
          drop-shadow(0 0 8px rgba(122,200,90,0.35));
}
/* 🌈 Неон — цветок засветится cyan/magenta */
html.dark-active.night-neon .fab-chat.fab-icq img {
  filter: drop-shadow(0 0 12px rgba(0,224,255,0.65))
          drop-shadow(0 0 22px rgba(255,46,196,0.45));
}
/* 💡 Ламповая — янтарное свечение */
html.dark-active.night-cozy .fab-chat.fab-icq img {
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.55))
          drop-shadow(0 0 14px rgba(255,176,77,0.55));
}
/* Бейдж кол-ва непрочитанных на ромашке */
.fab-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 22px; height: 22px;
  padding: 0 6px;
  border-radius: 11px;
  background: #e74c3c;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(231,76,60,0.4);
  border: 2px solid #fff;
}

/* ── Глобальный отступ шапки от плавающей ☰ кнопки (на всех ширинах) ── */
.top { padding-left: 70px !important; }
.is-tma .top { padding-left: 16px !important; }  /* в TG Mini App шапка скрыта */
@media (min-width: 1100px) {
  /* На широких — кнопка в углу, контент тянем влево чуть меньше */
  .top { padding-left: 74px !important; }
}

/* Улучшения для страницы /cabinet/reports */
.reports-grid { margin-top: 8px; }
.rep-card .rep-emoji {
  display: inline-block;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.12));
}
.rep-card h3 { letter-spacing: -0.01em; }
@media (max-width: 600px) {
  .reports-grid { grid-template-columns: 1fr !important; }
  .rep-card { padding: 16px 18px 14px; }
  .rep-card .rep-emoji { font-size: 30px; margin-bottom: 6px; }
  .rep-card h3 { font-size: 16px; }
  .rep-card p { font-size: 12px; }
}

/* ── Inline-подсказки (i) рядом с заголовками таблиц ── */
.info-i {
  display: inline-block;
  width: 14px; height: 14px;
  line-height: 14px; text-align: center;
  border-radius: 50%;
  background: rgba(122,163,127,0.25);
  color: var(--g-text);
  font-size: 9px; font-weight: 700;
  cursor: help;
  margin-left: 3px;
  vertical-align: middle;
}
.info-i:hover { background: var(--g-accent); color: #fff; }
html.dark-active .info-i {
  background: rgba(122,163,127,0.3);
  color: var(--g-dtext);
}
html.dark-active .info-i:hover { background: var(--g-accent); color: #fff; }

/* ── Выпадашка выбора месяца (вместо длинного скролла пиллов) ── */
.month-dropdown {
  appearance: none; -webkit-appearance: none;
  padding: 6px 28px 6px 14px;
  border-radius: 18px;
  border: 1px solid rgba(122,163,127,0.3);
  background: rgba(255,255,255,0.85) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%234a7a4f' d='M0 0l5 6 5-6z'/></svg>") no-repeat right 12px center;
  color: var(--g-text); font-size: 13px; font-weight: 600;
  cursor: pointer;
  font-family: inherit;
}
.month-dropdown:focus { outline: none; border-color: var(--g-accent); }
html.dark-active .month-dropdown {
  background-color: rgba(122,163,127,0.12);
  color: var(--g-dtext);
  border-color: rgba(122,163,127,0.4);
}

/* (i)-подсказки: кастомный тултип по тапу/наведению — работает на мобиле */
.info-i { position: relative; }
.info-tip {
  position: fixed;
  z-index: 9999;
  background: var(--g-deep2);
  color: #fff;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 12px; font-weight: 500;
  line-height: 1.45;
  max-width: 280px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.35);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 0.15s, transform 0.15s;
}
.info-tip.open { opacity: 1; transform: translateY(0); }
html.dark-active .info-tip {
  background: var(--g-dtext); color: #1a2620;
}

/* === 🌿 Базовая карточка участника (m-tile) — общая для new/cooling/etc === */
.m-tile {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--d-surface-2, rgba(122,163,127,0.06));
  border: 1px solid var(--d-border, rgba(122,163,127,0.18));
  border-left-width: 3px;
  border-radius: 14px;
  text-decoration: none !important;
  color: inherit;
  transition: all .15s;
}
.m-tile:hover {
  border-color: var(--d-accent, var(--g-accent));
  border-left-color: var(--d-accent, var(--g-accent));
  transform: translateX(2px);
  text-decoration: none !important;
}
.m-tile-hot   { border-left-color: #e8804f; }
.m-tile-warm  { border-left-color: #d4a017; }
.m-tile-cold  { border-left-color: var(--d-text-dim, var(--g-muted2)); opacity: .9; }
.m-tile-fresh { border-left-color: var(--g-accent); }
.m-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 16px; color: #fff;
  flex-shrink: 0;
}
.m-body { min-width: 0; }
.m-name {
  font-weight: 600; font-size: 14.5px;
  color: var(--d-text-strong, var(--g-deep));
  text-decoration: none;
}
.m-name:hover { color: var(--d-accent, var(--g-accent)); }
.m-meta {
  font-size: 12px; color: var(--d-text-dim, var(--g-muted2));
  margin-top: 2px;
  display: flex; flex-wrap: wrap; gap: 4px 8px; align-items: center;
}
.m-meta .meta-link { color: inherit; }
.m-status {
  font-size: 12px; color: var(--d-text-dim, #7a8e7a);
  margin-top: 4px; opacity: .9;
}
.m-status b { color: var(--d-text-strong, var(--g-text)); font-weight: 600; }
.m-contacts {
  display: inline-flex; gap: 4px; align-items: center;
}
.m-contacts a {
  text-decoration: none !important;
  font-size: 12px;
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 6px;
  background: var(--d-surface-3, rgba(122,163,127,0.12));
  color: var(--d-text-strong, var(--g-text));
  transition: all .12s;
}
.m-contacts a:hover { background: var(--d-accent, var(--g-accent)); color: #fff; }
.m-badge {
  padding: 3px 10px; border-radius: 12px;
  font-size: 12px; font-weight: 600;
  background: var(--d-surface-3, rgba(122,163,127,0.15));
  color: var(--d-text-strong, var(--g-text));
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.m-badge-hot  { background: rgba(232,128,79,0.18); color: #c25e2c; }
.m-badge-warm { background: rgba(212,160,23,0.18); color: #a87a10; }
.m-badge-cold { background: rgba(122,163,127,0.12); color: var(--d-text-dim, var(--g-muted2)); }
html.dark-active .m-tile {
  background: var(--d-surface-2) !important;
  border-color: var(--d-border) !important;
}
html.dark-active .m-tile:hover {
  background: var(--d-surface-3) !important;
  border-color: var(--d-accent) !important;
}
html.dark-active .m-badge-hot  { background: rgba(232,128,79,0.25); color: #ff9c6a; }
html.dark-active .m-badge-warm { background: rgba(212,160,23,0.25); color: #ffc966; }

/* === Дополнения к m-tile === */
.m-tile-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 8px; margin-top: 12px; }
.m-name-row { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.m-extra { font-size: 12px; color: var(--d-text-dim, var(--g-muted2)); margin-top: 4px; }
.m-extra-lbl { opacity: .75; }
.m-extra-link { color: var(--d-text-strong, var(--g-text)); font-weight: 600; text-decoration: none; }
.m-extra-link:hover { color: var(--d-accent, var(--g-accent)); }
.meta-link { color: inherit; text-decoration: underline; text-decoration-style: dotted; text-decoration-color: rgba(122,163,127,0.4); }
.meta-link:hover { color: var(--d-accent, var(--g-accent)); }
.m-actions { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 8px; }
.m-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 12px;
  background: var(--d-surface-3, rgba(122,163,127,0.12));
  color: var(--d-text-strong, var(--g-text));
  font-size: 11.5px; text-decoration: none;
  border: 1px solid transparent;
  transition: all .12s;
}
.m-chip:hover { background: var(--d-surface-2, rgba(122,163,127,0.2)); }
.m-chip-accent {
  background: var(--d-accent, var(--g-accent)); color: var(--d-on-accent, #fff);
}
.m-chip-accent:hover { filter: brightness(1.1); }
.m-badge-pv {
  font-size: 14px; padding: 5px 12px;
  background: var(--d-surface-3, rgba(122,163,127,0.15));
  color: var(--d-text-strong, var(--g-text));
}
html.dark-active .m-chip { background: var(--d-surface-3); color: var(--d-text); }
html.dark-active .m-chip:hover { background: var(--d-surface); border-color: var(--d-accent); }

/* === 🌸 Rarity бейджей (Тёплый → Сокровенный) === */
@keyframes rarity-pulse-rare    { 0%,100%{opacity:.7} 50%{opacity:1} }
@keyframes rarity-pulse-epic    { 0%,100%{opacity:.65} 50%{opacity:1} }
@keyframes rarity-pulse-leg     { 0%,100%{opacity:.6} 50%{opacity:1} }
@keyframes rarity-hue-mythic    { 0%{filter:hue-rotate(0deg)} 100%{filter:hue-rotate(360deg)} }
@keyframes rarity-glow-leg      { 0%,100%{box-shadow: 0 0 24px var(--rarity-glow), inset 0 0 12px rgba(255,230,150,.18)} 50%{box-shadow: 0 0 36px var(--rarity-glow), inset 0 0 20px rgba(255,230,150,.32)} }

.rarity-card {
  --rarity-color: #B8997A;
  --rarity-glow: rgba(184,153,122,.25);
  --rarity-border-px: 1.5px;
  position: relative;
  border-radius: 16px;
  border: var(--rarity-border-px) solid var(--rarity-color);
  background: var(--d-surface-2, #FAF6F0);
  transition: transform .15s, box-shadow .3s;
}

/* common — Тёплый */
.rarity-common {
  --rarity-color: #B8997A;
  --rarity-glow: rgba(184,153,122,.25);
}
.rarity-common:hover { box-shadow: 0 0 8px var(--rarity-glow); transform: translateY(-2px); }

/* uncommon — Живой */
.rarity-uncommon {
  --rarity-color: #7BAE6E;
  --rarity-glow: rgba(123,174,110,.40);
  box-shadow: 0 0 12px var(--rarity-glow);
}
.rarity-uncommon:hover { transform: translateY(-2px); }

/* rare — Глубокий */
.rarity-rare {
  --rarity-color: #4A90C2;
  --rarity-glow: rgba(74,144,194,.55);
  --rarity-border-px: 2px;
  box-shadow: 0 0 18px var(--rarity-glow);
  animation: rarity-pulse-rare 4s ease-in-out infinite;
}
.rarity-rare:hover { transform: translateY(-3px) scale(1.02); }

/* epic — Сияющий */
.rarity-epic {
  --rarity-color: #9B6BB8;
  --rarity-glow: rgba(155,107,184,.65);
  --rarity-border-px: 2px;
  box-shadow: 0 0 24px var(--rarity-glow), inset 0 0 12px rgba(255,255,255,.15);
  animation: rarity-pulse-epic 5s ease-in-out infinite;
}
.rarity-epic:hover { transform: translateY(-3px) rotate(2deg); }

/* legendary — Драгоценный */
.rarity-legendary {
  --rarity-color: #D4A537;
  --rarity-glow: rgba(212,165,55,.75);
  --rarity-border-px: 2.5px;
  animation: rarity-glow-leg 6s ease-in-out infinite, rarity-pulse-leg 6s ease-in-out infinite;
}
.rarity-legendary:hover { transform: translateY(-4px) scale(1.03); }
.rarity-legendary .rarity-name { text-shadow: 0 0 4px rgba(255,215,128,.6); }

/* mythic — Сокровенный */
.rarity-mythic {
  --rarity-color: #E85EAB;
  --rarity-glow: rgba(232,94,171,.85);
  --rarity-border-px: 3px;
  border-style: double;
  box-shadow: 0 0 40px var(--rarity-glow),
              inset 0 0 22px rgba(255,200,230,.35),
              0 0 80px rgba(255,215,100,.3);
  animation: rarity-hue-mythic 8s linear infinite;
}
.rarity-mythic:hover { transform: translateY(-5px) scale(1.04); }
.rarity-mythic .rarity-name {
  background: linear-gradient(90deg, #E85EAB, #FFD782, #B8E0E5, #E85EAB);
  background-size: 300% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: rarity-hue-mythic 8s linear infinite;
}

/* Locked (не получен) */
.rarity-card.is-locked {
  filter: grayscale(.85);
  opacity: .55;
  animation: none !important;
  box-shadow: none !important;
}
.rarity-card.is-locked:hover {
  opacity: .8;
  filter: grayscale(.5);
}

/* Tagline под именем */
.rarity-tagline {
  font-size: 10.5px;
  color: var(--rarity-color);
  opacity: .85;
  font-style: italic;
  margin-top: 2px;
  letter-spacing: .02em;
}


/* === Базовые зелёные переменные (точные исходные значения; меняй ЗДЕСЬ) === */
:root{
  --g-text: #3d5a40;
  --g-dtext: #c5dac8;
  --g-accent: #6ea676;
  --g-muted: #8aa68d;
  --g-muted2: #6b8e6f;
  --g-accent2: #7aa37f;
  --g-muted3: #5a7a5e;
  --g-border: #d4e1d6;
  --g-deep: #2a4a2d;
  --g-mid: #3d7a48;
  --g-soft: #f3f8f3;
  --g-link: #3d6842;
  --g-hint: #9ab2a0;
  --g-accentdk: #4a7a4f;
  --g-light: #a3c4a8;
  --g-light2: #b8d4bc;
  --g-deep2: #2a3d2d;
  --g-deep3: #1a261d;
  --g-text2: #4a6b4d;
  --g-soft2: #e9f3ec;
  --g-accent3: #5a9560;
}
