/**
 * hamburger-animation.css - Анимация для гамбургер-иконки
 */

/* Базовые стили для кнопки */
.navbar-toggler {
    border: none !important;
    padding: 0.5rem;
    min-width: 48px;
    min-height: 48px;
    position: relative;
    z-index: 1000;
    /* Предотвращаем перезагрузку страницы при двойном клике */
    user-select: none;
}

.navbar-toggler:focus {
    box-shadow: none !important;
    outline: none !important;
}

/* Контейнер для линий гамбургера */
.navbar-toggler-icon {
    position: relative;
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    background-image: none !important;
}

/* Стили для трех линий гамбургера */
.hamburger-line {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background-color: var(--bs-body-color);
    /* Ультра-быстрая анимация */
    transition: transform 80ms linear, top 80ms linear, opacity 80ms linear;
}

/* Верхняя линия */
.hamburger-line:nth-child(1) {
    top: 30%;
}

/* Средняя линия */
.hamburger-line:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
}

/* Нижняя линия */
.hamburger-line:nth-child(3) {
    top: 70%;
}

/* Анимация для открытого состояния (крестик) */
.is-active .hamburger-line:nth-child(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
}

.is-active .hamburger-line:nth-child(2) {
    opacity: 0;
}

.is-active .hamburger-line:nth-child(3) {
    top: 50%;
    transform: translateY(-50%) rotate(-45deg);
}

/* Оптимизируем для мобильных устройств */
@media (max-width: 767.98px) {
    .navbar-toggler {
        margin-left: auto;
    }
}

/* Уменьшение движения для пользователей с соответствующими настройками */
@media (prefers-reduced-motion: reduce) {
    .hamburger-line {
        transition: none !important;
    }
} 