/* Кастомные анимации и стили, которые сложнее сделать через утилиты */
html {
    scroll-behavior: smooth;
}

body {
    overflow-x: hidden;
}

/* Бегущая строка */
.marquee-container {
    overflow: hidden;
    white-space: nowrap;
    position: relative;
}
.marquee-content {
    display: inline-flex;
    white-space: nowrap;
    animation: scroll 20s linear infinite;
}
.marquee-item {
    display: inline-block;
    padding-right: 2rem;
}
@keyframes scroll {
    0% { 
        transform: translateX(0); 
    }
    100% { 
        transform: translateX(calc(-100% / 3)); 
    }
}

/* Классы для появления при скролле */
.reveal {
    opacity: 0;
    transform: translateY(50px) rotate(2deg);
    transition: all 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.reveal.active {
    opacity: 1;
    transform: translateY(0) rotate(0deg);
}

/* Эффект шума на фоне */
.noise-bg {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    pointer-events: none;
    z-index: 50;
    opacity: 0.03;
    background: url('https://grainy-gradients.vercel.app/noise.svg');
}

/* Кастомный скроллбар */
::-webkit-scrollbar {
    width: 16px;
}
::-webkit-scrollbar-track {
    background: #FFDE00;
    border-left: 4px solid #000;
}
::-webkit-scrollbar-thumb {
    background: #FF90E8;
    border: 4px solid #000;
}
::-webkit-scrollbar-thumb:hover {
    background: #2222FF;
}
