/* Изолируем стили только для нашего меню */
.left-menu__container {
    width: 100%;
    /* Подложка для всего меню */
    background-color: var(--card_bg_black, #fff);
    border-radius: var(--theme-button-border-radius, 8px);
    padding: 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--stroke_black, #e5e5e5);
}

/* Отключаем sticky у родительского блока чтобы меню скроллилось со страницей */
.sticky-block:has(.left-menu__container),
.ticky-block:has(.left-menu__container) {
    position: static !important;
}

/* Для старых браузеров без поддержки :has() - добавить класс через JS */
.sticky-block.no-sticky,
.ticky-block.no-sticky {
    position: static !important;
}

/* Убираем маркеры списков (точки) */
.left-menu__container .left-menu__wrapper,
.left-menu__container .left-menu__submenu,
.left-menu__container .left-menu__item {
    list-style: none;
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.left-menu__container .left-menu__item::before,
.left-menu__container .left-menu__item::marker {
    display: none;
    content: none;
}

/* Логика раскрытия/складывания подменю */
.left-menu__container .left-menu__submenu {
    display: none;
    overflow: hidden;
    margin-top: 8px;
    margin-bottom: 8px;
    transition: all 0.3s ease;
}

/* Показываем подменю когда родительский контейнер имеет класс opened */
.left-menu__container .left-menu__item-container.opened > .left-menu__submenu {
    display: block;
}

/* Стили для ссылок меню - как у фильтров */
.left-menu__container .left-menu__item-link {
    /* Добавляем рамку как у bordered */
    --box_shadow: var(--stroke_black);
    border: none;
    box-shadow: inset 0 0 0 1px var(--box_shadow);
    transition: all 0.2s ease;
    background-color: transparent;
    /* Отступы как у dropdown-select bordered */
    padding: 8px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    font-size: 15px;
    text-decoration: none;
    color: var(--white_text_black);
}

/* Текст занимает всё доступное место */
.left-menu__container .left-menu__item-text {
    flex: 1;
}

/* Эффект hover как у фильтров */
.left-menu__container .left-menu__item-link:hover {
    --box_shadow: var(--grey_border);
    background-color: var(--grey_bg);
    box-shadow: inset 0 0 0 1px var(--box_shadow);
}

/* Активная ссылка - синий цвет как у кнопки "Каталог" */
a.left-menu__item-link.active[href],
.left-menu__container a.left-menu__item-link.active {
    background-color: rgba(37, 99, 235, 0.1) !important;
    box-shadow: inset 0 0 0 2px var(--theme-base-color, #2563eb) !important;
    color: var(--theme-base-color, #2563eb) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
}

/* Убираем hover эффект для активного пункта */
a.left-menu__item-link.active[href]:hover,
.left-menu__container a.left-menu__item-link.active:hover {
    background-color: rgba(37, 99, 235, 0.15) !important;
    box-shadow: inset 0 0 0 2px var(--theme-base-color, #2563eb) !important;
    color: var(--theme-base-color, #2563eb) !important;
}

/* Текст и стрелка активного пункта синие */
a.left-menu__item-link.active .left-menu__item-text,
a.left-menu__item-link.active .toggle-arrow svg,
a.left-menu__item-link.active .toggle-arrow svg *,
a.left-menu__item-link.active .toggle-arrow svg use {
    color: var(--theme-base-color, #2563eb) !important;
    fill: var(--theme-base-color, #2563eb) !important;
}

/* Hover только на текст, не на стрелку */
.left-menu__container .left-menu__item-link:hover .toggle-arrow {
    opacity: 1;
}

/* Анимация стрелки при раскрытии */
.left-menu__container .left-menu__item-container .toggle-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, background-color 0.2s ease;
    min-width: 20px;
    min-height: 20px;
    cursor: pointer;
    flex-shrink: 0;
    border-radius: 4px;
    margin-left: 4px;
    position: relative;
}

.left-menu__container .left-menu__item-container .toggle-arrow:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.left-menu__container .left-menu__item-container .toggle-arrow svg {
    width: 6px;
    height: 8px;
    pointer-events: none;
}

.left-menu__container .left-menu__item-container.opened .toggle-arrow {
    transform: rotate(90deg);
}

/* Увеличенная область клика для стрелки */
.left-menu__container .left-menu__item-container .toggle-arrow::before {
    content: '';
    position: absolute;
    inset: -4px;
}

/* Дополнительные отступы для вложенных элементов */
.left-menu__container .left-menu__submenu .left-menu__item-link {
    font-size: 14px;
    padding: 8px 12px;
}

/* Расстояние между элементами подменю */
.left-menu__container .left-menu__submenu .left-menu__item {
    margin-bottom: 4px;
}

.left-menu__container .left-menu__submenu .left-menu__item:last-child {
    margin-bottom: 0;
}

/* Отступ для более глубоких уровней вложенности */
.left-menu__container .left-menu__submenu .left-menu__submenu {
    padding-left: 8px;
}

.left-menu__container .left-menu__submenu.pl {
    padding-left: 16px;
}
