﻿#projectsTreeRoot.is-collapsed {
  width: 60px !important;
  min-width: 60px !important;
  max-width: 60px !important;
  transition: width 0.2s;
}

/* Для сетки main на странице проекты — уменьшить первую колонку при is-collapsed */
body #projectsTreeRoot.is-collapsed {
  grid-column: 1 / 2;
}
body .main.projects-tree-collapsed {
  grid-template-columns: 60px 420px 1fr !important;
}
#projectsTreeRoot.is-collapsed .panel-header {
  display: none !important;
}
#projectsTreeRoot.is-collapsed .aidc-scroll,
#projectsTreeRoot.is-collapsed .panel-content,
#projectsTreeRoot.is-collapsed .panel-body,
#projectsTreeRoot.is-collapsed .panel > :not(.panel-header):not(.expand-btn) {
  display: none !important;
}
/* --- Финальная логика видимости тулбара и поиска --- */
#projectsTreeRoot.is-collapsed .tree-toolbar-search-row,
#projectsTreeRoot.is-collapsed .tree-toolbar-actions {
  display: none !important;
}
#projectsTreeRoot.aidc-guest .tree {
  display: none !important;
}
#projectsTreeRoot.is-collapsed .tree {
  display: none !important;
}
#projectsTreeRoot.is-collapsed .panel-header {
  flex-direction: row;
  align-items: center;
  gap: 8px;
}
/* Для гостей и в collapsed поиск и кнопки видны/скрыты по логике */
#projectsTreeRoot .tree-toolbar-actions {
  display: flex;
  gap: 6px;
  justify-content: space-between;
}

#projectsTreeRoot .tree-toolbar-actions .icon-btn {
  flex: 1;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  border-radius: 8px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.04);
  transition: background .15s ease, box-shadow .15s ease;
}

#projectsTreeRoot .tree-toolbar-actions .icon-btn:hover {
  background: rgba(255,255,255,0.08);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.12);
}

#projectsTreeRoot .tree-toolbar-actions .icon-btn.is-active {
  background: rgba(236,0,140,0.18);
  box-shadow: 0 0 0 1px rgba(236,0,140,0.5);
}

#projectsTreeRoot .tree-toolbar-actions .icon-btn svg,
#projectsTreeRoot .tree-toolbar-actions .icon-btn img {
  width: 16px;
  height: 16px;
}
/* Общие стили для панелей и дерева проектов (повторное использование на видео/ресурсах и др.) */

#projectsTreeRoot,
#projectsTreeRoot * {
  box-sizing: border-box;
}

#projectsTreeRoot .panel {
  border-radius: 24px;
  background: var(--aidc-bg-surface, #1a1b1e);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 24px 64px rgba(0,0,0,0.7),
    0 0 0 1px rgba(255,255,255,0.02);
  padding: 14px 14px 12px;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
/* для блока дерева убираем градиент, оставляем ровный фон */
#projectsTreeRoot.panel-tree,
#projectsTreeRoot .panel.panel-tree {
  background: #111214;
  overflow-x: hidden;
}

#projectsTreeRoot .panel-tree .panel-header {
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

#projectsTreeRoot.panel-tree.is-collapsed,
#projectsTreeRoot .panel.panel-tree.is-collapsed {
  padding: 8px 6px;
  overflow: hidden;
  overflow-x: hidden;
}


#projectsTreeRoot.panel-tree .panel-toolbar,
#projectsTreeRoot .panel-tree .panel-toolbar {
  width: 100%;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;     /* было nowrap */
  overflow: visible;   /* было hidden */
  max-width: 100%;
}


#projectsTreeRoot .panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

#projectsTreeRoot .panel-title {
  font-size: 14px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #d6d6e5;
}

#projectsTreeRoot .panel-sub {
  font-size: 12px;
  color: #9090a5;
}

#projectsTreeRoot .tree {
  font-size: 13px;
  color: #d0d0df;
  padding: 4px 8px 4px 0;
  margin-right: 0;
  overflow: visible;
  overflow-x: hidden;
  height: 100%;
  min-height: 0;
  /* max-height: 60vh; убрано для универсальности */
}

#projectsTreeRoot .tree-node {
  display: flex;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 12px;
  cursor: pointer;
  border: 1px solid transparent;
  background: transparent;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  align-items: flex-start;
  min-width: 0;
}
#projectsTreeRoot .tree-node:hover {
  border-color: rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.05);
}
#projectsTreeRoot .tree-node.active {
  border-color: rgba(255,255,255,0.32);
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,0,140,0.18));
  box-shadow: 0 0 0 1px rgba(255,0,140,0.5);
}
#projectsTreeRoot .tree-node.favorite {
  border-color: transparent;
  background: transparent;
}
#projectsTreeRoot .tree-node.active.favorite {
  border-color: #ffd86f;
  background: rgba(255,215,120,0.28);
  box-shadow:
    0 0 0 1px rgba(255,215,120,0.65),
    0 8px 22px rgba(255,215,120,0.3);
}

#projectsTreeRoot .tree-head {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  /* nowrap: hover-actions (настройки/удалить) НЕ должны падать на отдельную
     строку при длинном имени. .tree-name сжимается (min-width:0), текст
     переносится внутри своей колонки, а .tree-actions остаётся справа. */
  flex-wrap: nowrap;
}
#projectsTreeRoot .tree-name {
  /* block + инлайн-поток внутри (а НЕ inline-flex): так звёздочка-кнопка
     становится частью текстового потока и прилипает к последнему слову
     имени. При inline-flex+flex-wrap звезда отрывалась на отдельную строку. */
  display: block;
  min-width: 0;
  flex: 1 1 auto;
}
#projectsTreeRoot .tree-icon {
  width: 26px;
  min-width: 26px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  opacity: 0.9;
}
#projectsTreeRoot .tree-icon img {
  width: 22px;
  height: 20px;
  object-fit: contain;
  display: block;
  filter: brightness(0) invert(1);
}
/* Workspace root folder icons: pink tint */
#projectsTreeRoot .tree-icon--workspace img {
  filter: invert(46%) sepia(96%) saturate(2000%) hue-rotate(295deg) brightness(100%) contrast(102%) !important;
}
/* Sub-folder icons inside workspace: blue tint */
#projectsTreeRoot .tree-node--subfolder > .tree-label .tree-icon img {
  filter: brightness(0) saturate(100%) invert(65%) sepia(60%) saturate(400%) hue-rotate(175deg) brightness(105%) !important;
}

/* Favorite star button: inactive light gray, active gold (works for <img src="*.svg">) */
.project-fav-star-btn img{
  width: 14px;
  height: 14px;
  display: block;
  /* light gray */
  filter: invert(63%) sepia(7%) saturate(426%) hue-rotate(200deg) brightness(95%) contrast(90%);
}
.project-fav-star-btn.active img{
  /* gold */
  filter: invert(88%) sepia(26%) saturate(695%) hue-rotate(347deg) brightness(104%) contrast(103%);
}
#projectsTreeRoot .tree-icon svg {
  width: 20px;
  height: 20px;
  stroke: #ff62c5;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
#projectsTreeRoot .tree-label {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1 1 auto;
}
#projectsTreeRoot .tree-label-main {
  /* inline (not block): keeps the favorite star inline right after the last
     word of the (possibly multi-line) name instead of dropping to a new row. */
  display: inline;
  font-size: 13px;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
/* Tail = last word of the name + the favorite star. nowrap guarantees the
   star never wraps alone onto a new line; it always stays beside the last
   word. The whole tail still wraps as one unit if it doesn't fit. */
#projectsTreeRoot .tree-name-tail {
  white-space: nowrap;
}
#projectsTreeRoot .tree-label-sub {
  font-size: 11px;
  color: #8f90a5;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
#projectsTreeRoot .tree-placeholder {
  padding: 12px;
  text-align: center;
}

#projectsTreeRoot .tree-indent-1 { padding-left: 16px; }
#projectsTreeRoot .tree-indent-2 { padding-left: 32px; }
#projectsTreeRoot .tree-indent-3 { padding-left: 48px; }
#projectsTreeRoot .tree-indent-4 { padding-left: 64px; }
#projectsTreeRoot .tree-indent-5 { padding-left: 80px; }
#projectsTreeRoot .tree-indent-6 { padding-left: 96px; }

.project-fav-star-btn {
  border: none;
  background: transparent;
  color: #8b8ea3;
  font-size: 14px;
  line-height: 1;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-left: 4px;
  padding: 0;
  /* Sits inside the name's inline flow → align it with the text baseline so it
     hugs the last word instead of floating. */
  vertical-align: -3px;
}
.project-fav-star-btn.active {
  color: #ffd86f;
  text-shadow: 0 0 6px rgba(255,216,111,0.65);
}
.project-fav-star-btn img{
  width: 14px;
  height: 14px;
  display: block;
  /* Make black SVG in <img> look like "inactive" light gray */
  filter: invert(63%) sepia(9%) saturate(274%) hue-rotate(202deg) brightness(95%) contrast(90%);
}
.project-fav-star-btn.active img{
  /* Make black SVG in <img> look like "active" gold */
  filter: invert(88%) sepia(26%) saturate(695%) hue-rotate(347deg) brightness(104%) contrast(103%);
}

/* --- collapsible tree --- */
#projectsTreeRoot .panel-tree {
  position: relative;
}
#projectsTreeRoot .tree-collapse-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 10;
  border: 1px solid rgba(255,255,255,0.18);
  background: linear-gradient(135deg, #1d1e21, #111214);
  color: #e8ecff;
  border-radius: 999px;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 12px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.7);
  padding: 0;
  line-height: 1;
  position: absolute;
}
#projectsTreeRoot .tree-collapse-btn:hover {
  background: linear-gradient(135deg, #252628, #16171a);
  border-color: rgba(255,255,255,0.28);
}
#projectsTreeRoot .tree-collapse-btn::after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 0;
  border-right: 7px solid #f6f7ff; /* стрелка влево при раскрытом дереве */
}
#projectsTreeRoot .tree-collapse-btn.collapsed::after {
  border-right: 0;
  border-left: 7px solid #f6f7ff; /* стрелка вправо при свёрнутом дереве */
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}
#projectsTreeRoot .panel-tree.is-collapsed .tree-collapse-btn {
  right: 4px;
  top: 6px;
}
#projectsTreeRoot .panel-tree.is-collapsed {
  width: 40px;
  min-width: 40px;
  padding: 8px 6px;
}

/* =========================
   COLLAPSED: скрываем ВСЁ,
   кроме кнопки раскрытия
   ========================= */

/* скрываем весь контент панели */
#projectsTreeRoot .panel-tree.is-collapsed .panel-header,
#projectsTreeRoot .panel-tree.is-collapsed .panel-toolbar,
#projectsTreeRoot .panel-tree.is-collapsed .tree,
#projectsTreeRoot .panel-tree.is-collapsed #folderTree{
  display:none !important;
}

/* оставляем ТОЛЬКО кнопку раскрытия */
#projectsTreeRoot .panel-tree.is-collapsed .tree-collapse-btn{
  display:flex !important;
}
/* =========================
   GUEST: скрываем ТОЛЬКО дерево
   ========================= */

#projectsTreeRoot.aidc-guest .tree,
#projectsTreeRoot.aidc-guest #folderTree{
  display:none !important;
}

#projectsTreeRoot.aidc-guest .panel-toolbar,
#projectsTreeRoot.aidc-guest .tree-toolbar-actions{
  display:flex !important;
}

/* ── Drag & Drop visual feedback ── */
#projectsTreeRoot .tree-node.tree-dragging {
  opacity: 0.45;
}
#projectsTreeRoot .tree-node.tree-drop-target {
  border-color: rgba(100, 200, 255, 0.7) !important;
  background: rgba(100, 200, 255, 0.08) !important;
  box-shadow: 0 0 0 2px rgba(100, 200, 255, 0.35);
}
#projectsTreeRoot .tree-node[draggable="true"] {
  cursor: grab;
}
#projectsTreeRoot .tree-node[draggable="true"]:active {
  cursor: grabbing;
}

/* ── ТЗ: унификация структуры проектов с чатами (v1.8.69) ─────────────── */

/* CTA «+ Новый проект» под поиском (как «+ Новый чат» в чатах) */
#projectsTreeRoot .tree-cta-new-project {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  margin-top: 10px;
  padding: 10px 16px;
  background: linear-gradient(135deg, #ff008c 0%, #ff2da5 100%);
  border: none;
  border-radius: 10px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s, transform .12s;
  box-shadow: 0 4px 14px rgba(255, 8, 140, 0.18);
  letter-spacing: 0.01em;
}
#projectsTreeRoot .tree-cta-new-project:hover { opacity: .9; }
#projectsTreeRoot .tree-cta-new-project:active { transform: translateY(1px); }
#projectsTreeRoot .tree-cta-new-project__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px;
}
#projectsTreeRoot .tree-cta-new-project__icon svg { width: 16px; height: 16px; display: block; }
#projectsTreeRoot.is-collapsed .tree-cta-new-project__label { display: none; }
#projectsTreeRoot.is-collapsed .tree-cta-new-project { padding: 10px 8px; }

/* Hover-actions у tree-node (папка/проект) */
#projectsTreeRoot .tree-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  padding-left: 6px;
  /* Always keep the action buttons on the top row next to the icon/name —
     never shrink them and never let them wrap below the name. */
  flex: 0 0 auto;
  align-self: flex-start;
  opacity: 0;
  transition: opacity .12s ease;
  pointer-events: none;
}
#projectsTreeRoot .tree-node:hover > .tree-label > .tree-head > .tree-actions,
#projectsTreeRoot .tree-node.active > .tree-label > .tree-head > .tree-actions,
#projectsTreeRoot .tree-node:focus-within > .tree-label > .tree-head > .tree-actions {
  opacity: 1;
  pointer-events: auto;
}
#projectsTreeRoot .tree-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.65);
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  padding: 0;
}
#projectsTreeRoot .tree-action-btn:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.18);
}
#projectsTreeRoot .tree-action-btn--danger:hover {
  background: rgba(239, 68, 68, 0.14);
  color: #ff6b6b;
  border-color: rgba(239, 68, 68, 0.32);
}
#projectsTreeRoot .tree-action-btn svg { display: block; width: 14px; height: 14px; }

/* На мобильных touch — иконки видны постоянно */
@media (hover: none) and (pointer: coarse) {
  #projectsTreeRoot .tree-actions { opacity: 1; pointer-events: auto; }
}

/* Чтобы tree-head корректно растягивался под action-bar */
#projectsTreeRoot .tree-head {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  /* Explicit nowrap here too (this rule overrides the earlier .tree-head):
     hover-actions must never wrap to a new line under a long name. */
  flex-wrap: nowrap;
  min-width: 0;
}

/* Footer-«Корзина» (как у чатов) */
#projectsTreeRoot .tree-footer {
  margin-top: auto;
  padding: 8px 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  flex-shrink: 0;
}
#projectsTreeRoot .tree-footer__trash-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: none;
  border: none;
  color: #888;
  font-size: 13px;
  cursor: pointer;
  border-radius: 6px;
  transition: background .15s, color .15s;
}
#projectsTreeRoot .tree-footer__trash-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  color: #ccc;
}
#projectsTreeRoot .tree-footer__trash-icon {
  display: inline-flex; align-items: center; justify-content: center;
}
#projectsTreeRoot .tree-footer__trash-icon svg { width: 16px; height: 16px; display: block; }
#projectsTreeRoot.is-collapsed .tree-footer__trash-btn span:not(.tree-footer__trash-icon) { display: none; }

/* Скрываем старую панель кнопок (на случай если она ещё где-то есть в DOM) */
#projectsTreeRoot .tree-toolbar-actions { display: none !important; }

/* Гость: CTA скрыта (как и старая toolbar) */
#projectsTreeRoot.aidc-guest .tree-cta-new-project,
#projectsTreeRoot.aidc-guest .tree-footer { display: none !important; }

/* ── v1.8.70: Resize handle для #projectsTreeRoot (по образцу .chat-sidebar) ── */
#projectsTreeRoot { position: relative; }
#projectsTreeRoot .tree-resize-handle {
  position: absolute;
  top: 0;
  right: 0;
  width: 5px;
  height: 100%;
  cursor: col-resize;
  z-index: 50;
  background: transparent;
  transition: background .15s;
}
#projectsTreeRoot .tree-resize-handle:hover,
#projectsTreeRoot .tree-resize-handle.is-active {
  background: rgba(255, 0, 140, 0.35);
}
/* Ресайз дерева доступен ТОЛЬКО в 3-колоночном layout (десктоп >1200px).
   На ≤1200px layout становится 2-/1-колоночным (см. @media в core.css /
   layout-3col.css), дерево там гибкое — тянуть его за ручку бессмысленно,
   а JS-логика resize намеренно не вмешивается (DESKTOP_MIN=1201). Поэтому
   прячем ручку, чтобы не вводить в заблуждение. */
@media (max-width: 1200px) {
  #projectsTreeRoot .tree-resize-handle { display: none; }
}

/* ── v1.8.70: Корзина — расширенная модалка + иконка типа + flex-wrap ── */
.tree-modal.tree-modal--trash {
  width: min(820px, 92vw);
  max-width: 92vw;
}
.tree-modal--trash .trash-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.tree-modal--trash .trash-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1 1 280px;
  min-width: 0;
}
.tree-modal--trash .trash-icon {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: rgba(255,255,255,.78);
}
.tree-modal--trash .trash-icon img {
  width: 18px;
  height: 18px;
  display: block;
  filter: invert(.85);
}
.tree-modal--trash .trash-meta__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.tree-modal--trash .trash-name {
  font-weight: 600;
  color: #f4f4ff;
  overflow-wrap: anywhere;
}
.tree-modal--trash .trash-sub {
  font-size: 12px;
  color: rgba(232,235,255,.55);
  overflow-wrap: anywhere;
}
.tree-modal--trash .trash-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-left: auto;
}
@media (max-width: 540px) {
  .tree-modal--trash .trash-actions {
    width: 100%;
    margin-left: 0;
    justify-content: flex-end;
  }
}

/* textarea внутри tree-modal формы — корректный visual */
.tree-modal__field textarea {
  width: 100%;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 8px;
  color: #f4f4ff;
  padding: 8px 10px;
  font: inherit;
  box-sizing: border-box;
}
.tree-modal__field textarea:focus {
  outline: none;
  border-color: rgba(255,0,140,.55);
}

/* ═══════════════════════════════════════════════════════════════════════
   УЗКИЙ ЭКРАН (≤900px): дерево сворачивается ВВЕРХ (по высоте),
   а НЕ в боковую полоску 40–60px.
   ───────────────────────────────────────────────────────────────────────
   На широком десктопе колонки идут в ряд, поэтому сворачивание дерева в
   узкую вертикальную полоску слева логично (освобождает место центру).
   Но на узком экране layout уже одноколоночный (колонки сложены вертикально),
   и боковая полоска 60px смотрится сломанной — панель превращается в
   крошечный квадрат слева, а под ней пусто.

   На узком экране дерево должно вести себя как аккордеон: остаётся на всю
   ширину, при сворачивании прячется тело (поиск, дерево, кнопки), видна
   только шапка с кнопкой-стрелкой, направленной вверх/вниз.

   Этот файл (projects-tree.css) подключается ПОСЛЕ core.css и layout-*.css
   на всех страницах с деревом, поэтому правила ниже с !important корректно
   перебивают и core `.main--tree-collapsed{60px 420px 1fr}`, и
   layout-3col `.aidc-layout--3col.tree-collapsed`.
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* ── A. Родительский грид при свёрнутом дереве → ОДНА колонка ──
     (перебиваем боковую 60px-колонку, которую навешивают core/layout). */
  .main.main--tree-collapsed,
  .main.tree-collapsed,
  .aidc-layout--3col.tree-collapsed,
  .aidc-layout--2col.tree-collapsed,
  .aidc-layout--4col.tree-collapsed {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  .aidc-layout.tree-collapsed > .aidc-col--left,
  .aidc-layout.tree-collapsed > .aidc-col--center,
  .aidc-layout.tree-collapsed > .aidc-col--right {
    grid-column: 1 !important;
  }

  /* ── B. Свёрнутая панель дерева — на ВСЮ ширину, компактная по высоте ── */
  #projectsTreeRoot.is-collapsed,
  #projectsTreeRoot.panel-tree.is-collapsed,
  #projectsTreeRoot .panel.panel-tree.is-collapsed {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    padding: 12px 14px !important;
  }

  /* Контейнер контента виден (на десктопе он схлопнут), но внутри —
     только заголовок панели; остальное прячем. */
  #projectsTreeRoot.is-collapsed .aidc-scroll-host {
    display: flex !important;
  }
  #projectsTreeRoot.is-collapsed .panel-header,
  #projectsTreeRoot.panel-tree.is-collapsed .panel-header,
  #projectsTreeRoot .panel.panel-tree.is-collapsed .panel-header {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding-right: 40px; /* место под кнопку-стрелку */
  }
  /* В свёрнутом виде оставляем только заголовок (без подписи) */
  #projectsTreeRoot.is-collapsed .panel-sub {
    display: none !important;
  }
  /* Прячем ТЕЛО: скролл/дерево/футер/ресайз/поиск/кнопку «Новый проект» */
  #projectsTreeRoot.is-collapsed .aidc-scroll,
  #projectsTreeRoot.is-collapsed .tree,
  #projectsTreeRoot.is-collapsed #folderTree,
  #projectsTreeRoot.is-collapsed .tree-footer,
  #projectsTreeRoot.is-collapsed .tree-resize-handle,
  #projectsTreeRoot.is-collapsed .tree-toolbar-search-row,
  #projectsTreeRoot.is-collapsed .tree-cta-new-project {
    display: none !important;
  }

  /* Кнопку держим в правом верхнем углу панели (а не у края 4px-полоски) */
  #projectsTreeRoot.panel-tree.is-collapsed .tree-collapse-btn {
    right: 8px !important;
    top: 8px !important;
  }

  /* ── C. Стрелка кнопки: ВВЕРХ при раскрытом (нажать → свернуть вверх) ── */
  #projectsTreeRoot .tree-collapse-btn::after {
    border-left: 5px solid transparent !important;
    border-right: 5px solid transparent !important;
    border-top: 0 !important;
    border-bottom: 7px solid #f6f7ff !important;
  }
  /* ВНИЗ при свёрнутом (нажать → развернуть вниз) */
  #projectsTreeRoot .tree-collapse-btn.collapsed::after {
    border-left: 5px solid transparent !important;
    border-right: 5px solid transparent !important;
    border-bottom: 0 !important;
    border-top: 7px solid #f6f7ff !important;
  }
}
