/* Начальный стиль для устранения блика при загрузке - добавить встроенным стилем в head */

html {
    background-color: #000000;
}

body {
    background-color: #000000;
    visibility: hidden;
    /* Скрываем контент до загрузки стилей */
}


/* Стили для эффекта затемнения */

#page-transition-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000;
    z-index: 9999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}


/* Предотвращаем прокрутку во время перехода */

body.transitioning {
    overflow: hidden;
}


/* Плавное появление контента */

.page-content {
    opacity: 0;
    animation: smoothAppear 2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    animation-delay: 0.2s;
}

@keyframes smoothAppear {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}


/* Скрываем мигание при начальной загрузке контента */

body::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000000;
    z-index: -1;
}


/* Оптимизация для мобильных устройств */

@media (max-width: 768px) {
    #page-transition-overlay {
        transition: opacity 1.2s cubic-bezier(0.16, 1, 0.3, 1);
    }
}