/* =========================================================
   Homiwork App · v3-calm · Sidebar + Bottom-bar (Phase 1)
   Бренд-язык v3 (pink / yellow) — только в акцентах
   (CTA, balance-chip, маскот). Интерьер спокойный:
   1px бордеры, без offset-shadow на рядовых элементах.

   Подключается ПОСЛЕ pictures.css. Старые стили остаются
   в живых, новые перекрывают за счёт уникальных классов
   с префиксом .v3-* и переменных-токенов.
   ========================================================= */

/* ---------- App tokens (light) ---------- */
.v3-sidebar,
.v3-bottom-bar,
.v3-mascot-host {
  --bg:        #FAFAF7;
  --bg-alt:    #F4F2EC;
  --surface:   #FFFFFF;
  --surface-2: #F7F6F1;
  --ink:       #111114;
  --ink-2:     #2A2A30;
  --ink-3:     #6B6B72;
  --ink-4:     #9D9D9F;
  --line:      #E4E2D8;
  --line-md:   #D0CEC2;

  --pink:      #FF2D95;
  --pink-sft:  #FFE8F1;
  --blue:      #2D5EFF;
  --blue-sft:  #E1E7FF;
  --yellow:    #FFEB00;
  --yellow-sft:#FFFACB;

  --f-disp: 'Unbounded', ui-sans-serif, system-ui, sans-serif;
  --f-body: 'IBM Plex Sans', ui-sans-serif, system-ui, sans-serif;
  --f-mono: 'IBM Plex Mono', ui-monospace, Menlo, monospace;
}

/* ---------- App tokens (dark) ---------- */
/* Поддерживаем оба механизма тёмной темы:
   - data-theme="dark" (v3-стиль, наш собственный тогл)
   - .theme-dark (унаследованный класс из старого темпейта app-bootstrap) */
[data-theme="dark"] .v3-sidebar,
[data-theme="dark"] .v3-bottom-bar,
[data-theme="dark"] .v3-mascot-host,
.theme-dark .v3-sidebar,
.theme-dark .v3-bottom-bar,
.theme-dark .v3-mascot-host {
  --bg:        #16181F;
  --bg-alt:    #1D1F29;
  --surface:   #232531;
  --surface-2: #292C38;
  --ink:       #F5F4EC;
  --ink-2:     #DDDCD1;
  --ink-3:     #98968A;
  --ink-4:     #65645B;
  --line:      #313442;
  --line-md:   #41455A;

  --pink:      #FF5FAF;
  --pink-sft:  #2E1522;
  --blue:      #6E8BFF;
  --blue-sft:  #1A2040;
  --yellow:    #F6E23F;
  --yellow-sft:#2E2810;
}

/* =========================================================
   SIDEBAR — нейтральная
   ========================================================= */
.v3-sidebar {
  display: flex;
  flex-direction: column;
  padding: 16px 12px;
  gap: 14px;
  background: var(--bg-alt);
  font-family: var(--f-body);
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink);
  /* height + overflow-y: auto, чтобы длинный контент скроллился внутри
     и в desktop-обёртке (.col-lg-3.vh-100), и в mobile-шторке (#menu-sidebar-left-6 100vh). */
  height: 100%;
  min-height: 100%;
  overflow-y: auto;
  box-sizing: border-box;
}
.v3-sidebar * { box-sizing: border-box; }
.v3-sidebar a { color: inherit; text-decoration: none; }
.v3-sidebar button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }

/* Brand */
.v3-side-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 4px 6px 12px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 2px;
}
.v3-side-brand-link {
  display: inline-flex; align-items: center; gap: 10px;
  text-decoration: none; color: inherit;
  min-width: 0;
}
.v3-side-brand-name {
  font-family: var(--f-disp); font-weight: 600;
  font-size: 17px; letter-spacing: -0.015em;
  text-transform: lowercase;
  color: var(--ink);
  line-height: 1;
}

/* Кнопка «Скачать приложение» — calm: круглая 28×28, нейтральная подложка,
   pink на hover. Прижата к правому краю brand-секции. */
.v3-side-download {
  margin-left: auto; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--line-md);
  color: var(--ink-2);
  text-decoration: none;
  transition: border-color .12s, color .12s, background .12s;
}
@media (hover: hover) {
  .v3-side-download:hover {
    border-color: var(--pink);
    color: var(--pink);
    background: var(--surface);
  }
}
.v3-side-download svg { width: 14px; height: 14px; flex: 0 0 14px; color: currentColor; }
.v3-mascot {
  width: 32px; height: 36px;
  flex: 0 0 32px;
  display: block;
  color: var(--ink);
}
.v3-mascot .brand-frame { fill: #0A0A0A; }
.v3-mascot .brand-body  { fill: #FFE20E; }
.v3-mascot .brand-eye   { fill: #FFE20E; }

/* Main nav */
.v3-side-nav { display: flex; flex-direction: column; gap: 2px; }
.v3-side-link {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 9px 12px; border-radius: 8px;
  font-family: var(--f-body); font-weight: 500;
  font-size: 14px; color: var(--ink-2);
  position: relative;
  transition: background .12s, color .12s;
}
.v3-side-link svg { width: 17px; height: 17px; flex: 0 0 17px; color: var(--ink-3); }
@media (hover: hover) {
  .v3-side-link:hover { background: var(--surface-2); color: var(--ink); }
  .v3-side-link:hover svg { color: var(--ink); }
}
/* navigationUpdate в custom.js ставит active-nav/color-highlight, а наша эстетика
   использует is-active. Поддерживаем оба класса как алиасы.
   Active = pink текст + pink иконка + pink-полоска слева + светлая подложка.
   Подложка var(--surface) (белый/тёмный surface), а не var(--surface-2),
   чтобы контрастировать с фоном sidebar (--bg-alt) в светлой теме.
   !important на color — потому что глобальный .color-highlight (style.css:5411)
   ставит свой #D83B4B !important и перебивает наш pink. */
.v3-side-link.is-active,
.v3-side-link.active-nav { background: var(--surface); color: var(--pink) !important; font-weight: 600; }
.v3-side-link.is-active::before,
.v3-side-link.active-nav::before {
  content: ""; position: absolute;
  left: -12px; top: 8px; bottom: 8px;
  width: 3px; border-radius: 2px; background: var(--pink);
}
.v3-side-link.is-active svg,
.v3-side-link.active-nav svg { color: var(--pink); }

.v3-side-link--sm { padding: 7px 12px; font-size: 13px; gap: 10px; color: var(--ink-3); font-weight: 500; }
.v3-side-link--sm svg { width: 15px; height: 15px; flex: 0 0 15px; }

/* Theme toggle inside sidebar — два набора иконка/лейбл, переключаем по data-theme */
.v3-side-theme { width: 100%; text-align: left; }
.v3-side-theme .v3-ic-moon,
.v3-side-theme .v3-theme-lbl-dark { display: none; }
[data-theme="dark"] .v3-side-theme .v3-ic-sun,
[data-theme="dark"] .v3-side-theme .v3-theme-lbl-light,
.theme-dark .v3-side-theme .v3-ic-sun,
.theme-dark .v3-side-theme .v3-theme-lbl-light { display: none; }
[data-theme="dark"] .v3-side-theme .v3-ic-moon,
[data-theme="dark"] .v3-side-theme .v3-theme-lbl-dark,
.theme-dark .v3-side-theme .v3-ic-moon,
.theme-dark .v3-side-theme .v3-theme-lbl-dark { display: inline; }
[data-theme="dark"] .v3-side-theme .v3-ic-moon,
.theme-dark .v3-side-theme .v3-ic-moon { display: inline-block; }

/* User-row + 3 состояния */
.v3-side-link--user { padding: 8px 12px; gap: 10px; align-items: center; }
.v3-user-avatar {
  width: 28px; height: 28px; flex: 0 0 28px;
  border-radius: 50%;
  background: var(--yellow);
  color: #0A0A0A;
  font-family: var(--f-disp); font-weight: 700;
  font-size: 13px; line-height: 28px;
  text-align: center;
  border: 1px solid var(--line-md);
  position: relative;
  overflow: hidden;
}
.v3-user-avatar-letter { display: block; }
.v3-user-avatar-guest { display: none; width: 16px; height: 16px; margin: 6px auto; color: var(--ink-3); }
.v3-user-info { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; flex: 1 1 auto; }
.v3-user-email {
  font-family: var(--f-body); font-weight: 600;
  font-size: 13px; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.v3-user-email--guest { display: none; color: var(--ink-3); font-style: italic; }
.v3-user-id {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-4);
  letter-spacing: 0.04em;
  margin-top: 1px;
}
.v3-user-chevron {
  width: 14px; height: 14px;
  color: var(--ink-4); flex-shrink: 0;
  transition: color .12s, transform .12s;
}
@media (hover: hover) {
  .v3-side-link--user:hover .v3-user-chevron { color: var(--ink-2); transform: translateX(2px); }
}

.v3-user-cta {
  display: none;
  align-items: center; gap: 4px;
  font-family: var(--f-mono); font-size: 10px;
  background: var(--pink); color: #fff;
  padding: 5px 10px; border-radius: 999px;
  font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
  transition: filter .12s;
}
@media (hover: hover) {
  .v3-side-link--user:hover .v3-user-cta { filter: brightness(1.05); }
}
[data-theme="dark"] .v3-user-cta,
.theme-dark .v3-user-cta { color: #1A0E14; }

/* Большая login-кнопка — режим no-account */
.v3-side-login-btn {
  display: none;
  align-items: center; justify-content: center;
  padding: 11px 18px; border-radius: 999px;
  background: var(--pink); color: #fff;
  font-family: var(--f-mono); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  border: 0; width: 100%;
  transition: filter .12s;
}
@media (hover: hover) {
  .v3-side-login-btn:hover { filter: brightness(1.05); }
}
[data-theme="dark"] .v3-side-login-btn,
.theme-dark .v3-side-login-btn { color: #1A0E14; }

/* State: email_not_set */
.v3-side-bottom.is-guest .v3-user-avatar-letter,
.v3-side-bottom.is-guest .v3-user-email--auth,
.v3-side-bottom.is-guest .v3-user-chevron { display: none; }
.v3-side-bottom.is-guest .v3-user-avatar-guest { display: block; }
.v3-side-bottom.is-guest .v3-user-email--guest { display: inline; }
.v3-side-bottom.is-guest .v3-user-cta { display: inline-flex; }
.v3-side-bottom.is-guest .v3-user-avatar { background: var(--surface-2); border-color: var(--line); }

/* State: no_account — user-row скрыт, видна большая login-кнопка */
.v3-side-bottom.is-anonymous .v3-side-link--user { display: none; }
.v3-side-bottom.is-anonymous .v3-side-login-btn { display: inline-flex; }

/* Pill-status (Prime) */
.v3-side-status {
  margin-left: auto;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-3);
  letter-spacing: 0.02em;
}
.v3-side-status--ended { color: var(--ink-4); }

/* Badge непрочитанного — общий UI-kit элемент для sidebar и bottom-bar */
.v3-side-badge,
.v3-bot-badge {
  min-width: 18px; height: 18px; padding: 0 4px;
  border-radius: 999px;
  background: var(--pink); color: #fff !important;
  font-family: var(--f-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0;
  display: inline-flex; align-items: center; justify-content: center;
  box-sizing: border-box;
}
.v3-side-badge { margin-left: auto; }
[data-theme="dark"] .v3-side-badge,
.theme-dark .v3-side-badge,
[data-theme="dark"] .v3-bot-badge,
.theme-dark .v3-bot-badge { color: #1A0E14 !important; }

/* Balance-chip */
.v3-side-balance { display: flex; flex-direction: column; gap: 8px; padding-top: 4px; }
.v3-balance-chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  background: var(--surface);
  border: 1px solid var(--line-md);
  border-radius: 10px;
  font-family: var(--f-body); font-weight: 600;
  color: var(--ink);
  transition: border-color .12s, background .12s;
}
@media (hover: hover) {
  .v3-balance-chip:hover { border-color: var(--ink-3); background: var(--surface-2); }
}
.v3-balance-bolt {
  width: 18px; height: 18px;
  color: var(--ink);
  flex: 0 0 18px;
}
.v3-balance-num { font-size: 15px; letter-spacing: -0.01em; color: var(--ink); margin-right: auto; }
.v3-balance-add {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.06em;
  font-weight: 500;
}
@media (hover: hover) {
  .v3-balance-chip:hover .v3-balance-add { color: var(--ink); }
}

/* Recent tools — недавно использованные пресеты. Иконка S3 + название. */
.v3-side-recent { display: flex; flex-direction: column; gap: 1px; padding-top: 4px; }
.v3-side-label {
  font-family: var(--f-mono); font-size: 10px; font-weight: 500;
  color: var(--ink-4); text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px 6px;
}
.v3-side-link--recent { padding: 6px 12px; gap: 10px; font-size: 13px; color: var(--ink-2); font-weight: 500; }
.v3-side-recent-img {
  width: 22px; height: 22px; flex: 0 0 22px;
  border-radius: 5px;
  object-fit: cover;
  border: 1px solid var(--line);
  background: var(--surface-2);
}
.v3-side-link--recent span {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  min-width: 0;
}

/* Settings group + divider */
.v3-side-group { display: flex; flex-direction: column; gap: 1px; padding-top: 8px; }
.v3-side-bottom { margin-top: auto; display: flex; flex-direction: column; }
.v3-side-divider {
  height: 1px; background: var(--line);
  margin: 8px -12px;
}

/* =========================================================
   BOTTOM BAR (mobile)
   ========================================================= */
.v3-bottom-bar {
  display: flex;
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 90;
  background: var(--bg);
  border-top: 1px solid var(--line);
  /* Высота ЖЁСТКО 62px (как у старого .footer-bar-1) — на эту константу
     завязаны .app-page-height (extra_style.css:74), .mobile-padding-bottom
     (extra_style.css:988) и task-photo-upload-container (chat input_field).
     Любое отклонение → bar перекрывает chat-input на странице чата. */
  height: 62px;
  box-sizing: content-box;
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: 10px; padding-right: 10px;
  align-items: center;
  justify-content: space-around; gap: 4px;
  font-family: var(--f-body);
}
@media (min-width: 992px) { .v3-bottom-bar { display: none; } }

.v3-bot-link {
  flex: 1 1 0;
  display: flex; flex-direction: column; align-items: center;
  gap: 1px; padding: 4px 4px;
  color: var(--ink-3);
  font-family: var(--f-body); font-size: 10px; font-weight: 500;
  position: relative;
  text-decoration: none;
  transition: color .12s;
  background: transparent;
  border: 0;
}
.v3-bot-link svg { width: 20px; height: 20px; color: var(--ink-2); transition: color .12s, stroke-width .12s; }
@media (hover: hover) {
  .v3-bot-link:hover { color: var(--ink); }
  .v3-bot-link:hover svg { color: var(--ink); }
}
/* Active state в bottom-bar: и текст, и иконка pink (текст ink не выделяется
   достаточно в тёмной теме на нейтральном фоне).
   !important — глобальный .color-highlight (style.css:5411) с !important
   перебивает цвет на <a>. Handler в navigationUpdate добавляет color-highlight
   вместе с active-nav. */
.v3-bot-link.is-active,
.v3-bot-link.active-nav { color: var(--pink) !important; font-weight: 600; }
.v3-bot-link.is-active svg,
.v3-bot-link.active-nav svg { color: var(--pink); stroke-width: 2.6; }

/* Глобальное `.theme-dark span:not(.badge):not(.span-theme-ignore) { color: #fff !important }`
   из style.css перебивает цвет любого <span> в темной теме. Под текст активного
   пункта bot-link нужен селектор такой же или большей специфичности
   (0,3,1 vs их 0,3,1 — выигрывает позднее объявленный, наш файл подключён после). */
.theme-dark .v3-bot-link.is-active span,
.theme-dark .v3-bot-link.active-nav span,
[data-theme="dark"] .v3-bot-link.is-active span,
[data-theme="dark"] .v3-bot-link.active-nav span { color: var(--pink) !important; }

.v3-bot-badge {
  position: absolute;
  top: 4px; left: calc(50% + 6px);
  border: 2px solid var(--bg);
}

/* Скрываем старый footer-bar при v3-bottom-bar (через .v3-app-host на body/.col) */
.v3-app-host #footer-bar { display: none !important; }

/* На мобилке резерв под bottom-bar */
@media (max-width: 991px) {
  .v3-app-host { padding-bottom: 82px; }
}

/* =========================================================
   FAQ floating bubble — только в чате поддержки.
   Плавает поверх чата, не двигает UI.
   На мобилке — кружок (только иконка, чтоб не закрывать сообщения).
   На десктопе — pill с подписью «FAQ».
   ========================================================= */
.v3-faq-bubble {
  position: absolute;
  top: 12px; right: 12px;
  z-index: 12;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 14px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid #D0CEC2;
  color: #2A2A30;
  font-family: 'IBM Plex Sans', ui-sans-serif, system-ui, sans-serif;
  font-size: 13px; font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 14px -4px rgba(0,0,0,.18);
  transition: border-color .12s, color .12s, transform .12s, box-shadow .12s;
}
.theme-dark .v3-faq-bubble,
[data-theme="dark"] .v3-faq-bubble {
  background: #232531; border-color: #41455A; color: #DDDCD1;
  box-shadow: 0 4px 14px -4px rgba(0,0,0,.5);
}
@media (hover: hover) {
  .v3-faq-bubble:hover {
    border-color: #FF2D95; color: #FF2D95;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px -4px rgba(0,0,0,.22);
  }
  .theme-dark .v3-faq-bubble:hover,
  [data-theme="dark"] .v3-faq-bubble:hover { border-color: #FF5FAF; color: #FF5FAF; }
}
.v3-faq-bubble svg { width: 15px; height: 15px; flex: 0 0 15px; color: currentColor; }

/* Мобилка: только иконка, кружок 40×40, без подписи. */
@media (max-width: 767px) {
  .v3-faq-bubble {
    padding: 0;
    width: 40px; height: 40px;
    justify-content: center;
  }
  .v3-faq-bubble-lbl { display: none; }
}

/* RTL: бабл переезжает в left-угол. */
[dir="rtl"] .v3-faq-bubble { right: auto; left: 12px; }

/* =========================================================
   ARCHIVE TABS — «Активные» / «Удалённые»
   Calm: pink-полоска снизу у активного, остальное нейтрально.
   ========================================================= */
.v3-arch-tabs {
  display: flex; gap: 4px;
  padding: 4px 4px 12px;
  border-bottom: 1px solid #E4E2D8;
  margin: 0 0 12px;
  font-family: 'IBM Plex Sans', ui-sans-serif, system-ui, sans-serif;
}
.theme-dark .v3-arch-tabs,
[data-theme="dark"] .v3-arch-tabs { border-bottom-color: #313442; }

.v3-arch-tab {
  display: inline-flex; align-items: center;
  padding: 8px 14px;
  border-radius: 8px 8px 0 0;
  color: #6B6B72;
  font-weight: 500; font-size: 14px;
  text-decoration: none;
  position: relative;
  transition: color .12s, background .12s;
}
.theme-dark .v3-arch-tab,
[data-theme="dark"] .v3-arch-tab { color: #98968A; }

@media (hover: hover) {
  .v3-arch-tab:hover { color: #111114; background: #F7F6F1; }
  .theme-dark .v3-arch-tab:hover,
  [data-theme="dark"] .v3-arch-tab:hover { color: #F5F4EC; background: #292C38; }
}

.v3-arch-tab.is-active { color: #111114; font-weight: 600; }
.theme-dark .v3-arch-tab.is-active,
[data-theme="dark"] .v3-arch-tab.is-active { color: #F5F4EC; }
.v3-arch-tab.is-active::after {
  content: ""; position: absolute;
  left: 14px; right: 14px; bottom: -5px;
  height: 2px; border-radius: 2px;
  background: #FF2D95;
}
.theme-dark .v3-arch-tab.is-active::after,
[data-theme="dark"] .v3-arch-tab.is-active::after { background: #FF5FAF; }

/* =========================================================
   RTL — арабский, иврит, фарси
   В RTL ось «дальше/глубже» зеркалируется: chevron смотрит
   влево, активная полоска — справа от пункта, стрелка в CTA
   тоже влево.
   ========================================================= */
[dir="rtl"] .v3-user-chevron { transform: scaleX(-1); }
@media (hover: hover) {
  [dir="rtl"] .v3-side-link--user:hover .v3-user-chevron { transform: scaleX(-1) translateX(2px); }
}
[dir="rtl"] .v3-side-link.is-active::before,
[dir="rtl"] .v3-side-link.active-nav::before { left: auto; right: -12px; }
[dir="rtl"] .v3-user-cta-arrow { display: inline-block; transform: scaleX(-1); }

