/* === Hierarchy Panel === */ .hierarchy { flex: 1; overflow-y: auto; padding: 6px 0; font-size: 12px; user-select: none; position: relative; } .root { padding: 0 8px; } .rootLine { padding: 6px 8px; color: var(--text); font-size: 13px; } .systemItem { padding: 4px 8px 4px 28px; color: var(--text-dim); font-size: 12px; } .groupHeader { display: flex; align-items: center; gap: 4px; padding: 6px 8px; color: var(--text); cursor: pointer; border-radius: 4px; margin-top: 6px; font-weight: 600; } .groupHeader:hover { background: var(--bg-mid); } .chevron { display: inline-block; width: 12px; color: var(--text-dim); font-size: 10px; } .groupBody { padding-left: 16px; } .empty { padding: 4px 8px; color: var(--text-dim); font-style: italic; } .subGroup { margin-bottom: 4px; } .subGroupHeader { padding: 3px 8px; color: var(--text-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; } .item { display: flex; align-items: center; gap: 8px; padding: 4px 8px; cursor: pointer; border-radius: 4px; color: var(--text); transition: background 0.1s; } .item:hover { background: var(--bg-mid); } .itemSelected { background: var(--accent) !important; color: #fff; } .itemSelected .itemLabel { color: #fff; } .itemIcon { width: 16px; text-align: center; flex-shrink: 0; } .itemLabel { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .moreNote { padding: 4px 8px; color: var(--text-dim); font-style: italic; font-size: 11px; } /* === Контекст-меню === */ .contextMenu { position: fixed; background: var(--bg-dark); border: 1px solid var(--border); border-radius: 6px; box-shadow: 0 8px 24px rgba(0,0,0,0.5); padding: 4px; min-width: 160px; z-index: 1000; } .contextItem { padding: 8px 12px; color: var(--text); cursor: pointer; border-radius: 4px; font-size: 13px; display: flex; align-items: center; gap: 8px; } .contextItem:hover { background: var(--bg-light); } .contextDanger { color: #ef4444; } .contextDanger:hover { background: rgba(239, 68, 68, 0.18); color: #ff6b6b; } /* === Папки === */ .toolbar { display: flex; gap: 4px; padding: 6px 8px; border-bottom: 1px solid var(--border); background: var(--bg-darkest); } .toolbarBtn { padding: 5px 10px; background: var(--bg-mid); border: 1px solid var(--border); border-radius: 4px; color: var(--text); font-size: 11px; cursor: pointer; transition: all 0.12s; } .toolbarBtn:hover { background: var(--accent); color: #fff; border-color: var(--accent-bright); } .folderWrap { /* контейнер папки + её содержимое */ } .folderHeader { display: flex; align-items: center; gap: 4px; padding: 5px 8px; cursor: pointer; border-radius: 4px; color: var(--text); font-weight: 500; transition: background 0.1s; } .folderHeader:hover { background: var(--bg-mid); } .folderIcon { flex-shrink: 0; } .folderName { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .folderCount { color: var(--text-dim); font-size: 11px; font-weight: 400; } .eyeBtn { background: transparent; border: none; color: var(--text-dim); cursor: pointer; font-size: 14px; padding: 2px 4px; border-radius: 3px; flex-shrink: 0; } .eyeBtn:hover { background: var(--bg-light); color: var(--text); } .renameInput { flex: 1; background: var(--bg-darkest); border: 1px solid var(--accent); border-radius: 3px; color: var(--text); padding: 2px 6px; font-size: 12px; outline: none; } /* Подсветка drop-зоны при drag над папкой */ .folderHeader[draggable="false"]:hover { background: var(--accent); color: #fff; } .contextSubmenu { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin: 4px 0; max-height: 200px; overflow-y: auto; } .contextSubmenuTitle { padding: 6px 12px 4px; color: var(--text-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; }