/* Стили для навигационного меню */
.main-menu {
    background-color: #ffffff;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    padding: 0 10px;
}

.main-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    /* ДОБАВЛЕНО: Тонкая линия снизу, чтобы убрать ощущение пустого пространства */
    border-bottom: 1px solid #f0f0f0;
}

.main-menu ul li {
    position: relative; /* Для позиционирования подменю */
    /* ДОБАВЛЕНО: Делаем li флекс-контейнером, чтобы его дочерние элементы растягивались на всю высоту */
    display: flex;
}

.main-menu ul li a,
.group-header {
    display: flex;
    align-items: center;
    padding: 15px 20px; /* Уменьшенные отступы */
    text-decoration: none;
    font-size: 12px; /* Уменьшенный шрифт */
    /* ДОБАВЛЕНО: Растягиваем элемент на всю доступную ширину внутри li */
    flex-grow: 1;
    color: #333;
    font-weight: 500;
    /* ИЗМЕНЕНО: Добавлена анимация для цвета и относительное позиционирование */
    transition: background-color 0.3s ease, color 0.3s ease;
    position: relative;
    cursor: pointer;
}

/* ДОБАВЛЕНО: Псевдо-элемент для анимированного подчеркивания */
.main-menu ul li a::after,
.group-header::after {
    content: '';
    position: absolute;
    bottom: -1px; /* Размещаем поверх border-bottom у ul */
    left: 0;
    width: 100%;
    height: 3px;
    background-color: var(--primary-color); /* ИЗМЕНЕНО: Используем переменную основного цвета */
    transform: scaleX(0); /* Изначально линия скрыта (ширина 0) */
    transform-origin: center;
    transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}

.main-menu ul li:hover > a,
.main-menu ul li:hover > .group-header {
    background-color: #f9f9f9;
    color: #000; /* Делаем текст активного пункта темнее */
}

/* ДОБАВЛЕНО: Анимация подчеркивания при наведении */
.main-menu ul li:hover > a::after,
.main-menu ul li:hover > .group-header::after {
    transform: scaleX(1); /* Показываем линию */
}


/* Контейнер для папки-иконки */
.folder-container {
    width: 32px; /* Уменьшенная ширина */
    height: 24px; /* Уменьшенная высота */
    position: relative;
    perspective: 800px;
    margin-right: 10px;
    flex-shrink: 0;
}

/* Общие стили для частей папки */
.folder-part {
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: var(--primary-color); /* ИЗМЕНЕНО: Используем переменную основного цвета */
    border-radius: 4px;
    transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
}

/* Задняя часть папки */
.folder-back {
    z-index: 1;
}

/* "Язычок" задней части папки */
.folder-back::before {
    content: '';
    position: absolute;
    top: -3px;
    left: 0;
    width: 15px;
    height: 3px;
    background-color: var(--primary-color); /* ИЗМЕНЕНО: Используем переменную основного цвета */
    border-top-left-radius: 4px;
    border-top-right-radius: 4px;
}

/* Лист бумаги внутри папки */
.paper {
    z-index: 2;
    background-color: #ffffff;
    width: 90%;
    height: 85%;
    left: 5%;
    bottom: 0;
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
    transform-origin: bottom;
    opacity: 0; /* Скрываем бумагу по умолчанию */
}

/* Передняя часть папки */
.folder-front {
    z-index: 3;
    transform-origin: bottom center;
}

/* Подменю */
.submenu {
    position: absolute;
    top: 100%;
    left: 0;
    background-color: #ffffff;
    border-radius: 0 0 12px 12px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08);
    padding: 10px 0;
    min-width: 200px;
    z-index: 10;
    display: flex;
    flex-direction: column;

    /* По умолчанию полностью скрыто и неактивно */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s 0.3s;
}

.submenu li a {
    padding: 12px 25px;
    width: 100%;
    box-sizing: border-box;
    display: block;
}

.menu-group:hover .folder-front {
    transform: rotateX(-30deg);
    background: #1a3a99; /* Затемненный вариант основного цвета */
}

.menu-group:hover .paper {
    transform: translateY(-15px);
    opacity: 1;
}

.menu-group:hover .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s 0s;
}

/* Стили для полноширинной обертки */
.full-width-nav-wrapper {
    background-color: #ffffff;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    width: 100%;
}

.full-width-nav-wrapper .main-menu {
    max-width: 1200px; /* Вы можете настроить максимальную ширину */
    margin: 0; /* Убираем центрирование, элементы будут слева */
    padding: 0;
    box-shadow: none;
    border-radius: 0;
}

.full-width-nav-wrapper .main-menu ul {
    border-bottom: none; /* Убираем нижнюю границу, так как есть тень */
}
