/* ========================================
   АНИМАЦИИ ПОЯВЛЕНИЯ ПРИ СКРОЛЛЕ
   ======================================== */

/* Базовые стили для элементов до появления */
.scroll-reveal {
    opacity: 0;
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Элемент стал видимым */
.scroll-reveal.revealed {
    opacity: 1;
}

/* ========================================
   ТИПЫ АНИМАЦИЙ
   ======================================== */

/* Fade In - простое появление */
.fade-in {
    opacity: 0;
    transform: translateY(0);
}

.fade-in.revealed {
    opacity: 1;
}

/* Slide Up - появление снизу */
.slide-up {
    opacity: 0;
    transform: translateY(60px);
}

.slide-up.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* Slide Down - появление сверху */
.slide-down {
    opacity: 0;
    transform: translateY(-60px);
}

.slide-down.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* Slide Left - появление слева */
.slide-left {
    opacity: 0;
    transform: translateX(-80px);
}

.slide-left.revealed {
    opacity: 1;
    transform: translateX(0);
}

/* Slide Right - появление справа */
.slide-right {
    opacity: 0;
    transform: translateX(80px);
}

.slide-right.revealed {
    opacity: 1;
    transform: translateX(0);
}

/* Scale Up - появление с увеличением */
.scale-up {
    opacity: 0;
    transform: scale(0.9);
}

.scale-up.revealed {
    opacity: 1;
    transform: scale(1);
}

/* Zoom In - появление с масштабированием */
.zoom-in {
    opacity: 0;
    transform: scale(0.8);
}

.zoom-in.revealed {
    opacity: 1;
    transform: scale(1);
}

/* Rotate In - появление с поворотом */
.rotate-in {
    opacity: 0;
    transform: rotate(-5deg) scale(0.95);
}

.rotate-in.revealed {
    opacity: 1;
    transform: rotate(0) scale(1);
}

/* ========================================
   ЗАДЕРЖКИ ДЛЯ ПОСЛЕДОВАТЕЛЬНОГО ПОЯВЛЕНИЯ
   ======================================== */

.delay-1 {
    transition-delay: 0.1s;
}

.delay-2 {
    transition-delay: 0.2s;
}

.delay-3 {
    transition-delay: 0.3s;
}

.delay-4 {
    transition-delay: 0.4s;
}

.delay-5 {
    transition-delay: 0.5s;
}

.delay-6 {
    transition-delay: 0.6s;
}

.delay-7 {
    transition-delay: 0.7s;
}

/* ========================================
   СКОРОСТИ АНИМАЦИИ
   ======================================== */

.anim-slow {
    transition-duration: 1.2s;
}

.anim-normal {
    transition-duration: 0.8s;
}

.anim-fast {
    transition-duration: 0.5s;
}

/* ========================================
   СПЕЦИАЛЬНЫЕ АНИМАЦИИ ДЛЯ КОНКРЕТНЫХ ЭЛЕМЕНТОВ
   ======================================== */

/* Анимация для заголовков секций */
.section-title {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.9s cubic-bezier(0.4, 0, 0.2, 1);
}

.section-title.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* Анимация для текстовых блоков */
.text-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1) 0.2s;
}

.text-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* Анимация для кнопок - ИСПРАВЛЕНО */
.button-reveal {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
    transition: opacity 0.7s cubic-bezier(0.4, 0, 0.2, 1) 0.3s,
                transform 0.7s cubic-bezier(0.4, 0, 0.2, 1) 0.3s;
    pointer-events: auto !important;
}

/* После появления кнопка ведет себя как обычная */
.button-reveal.revealed {
    opacity: 1 !important;
    transform: translateY(0) scale(1) !important;
    /* Переключаем на быстрый transition для hover эффектов */
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    transition-delay: 0s !important;
}

/* Hover работает как у обычной кнопки */
.button-reveal.revealed:hover {
    background-color: #d95a1a !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(240, 105, 34, 0.4) !important;
}

.button-reveal.revealed:active {
    transform: translateY(0) !important;
}

/* Анимация для карточек услуг */
.service-card-reveal {
    opacity: 0;
    transform: translateY(40px) scale(0.95);
    transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.service-card-reveal.revealed {
    opacity: 1;
    transform: translateY(0) scale(1);
}

/* Анимация для логотипов клиентов - ИСПРАВЛЕНО */
.client-logo-reveal {
    opacity: 0;
    transform: scale(0.8);
    transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* После появления логотипы ведут себя как обычные */
.client-logo-reveal.revealed {
    opacity: 0.9 !important; /* Базовая прозрачность как у .client-logo */
    transform: scale(1) !important;
    /* Переключаем на быстрый transition для hover */
    transition: all 0.3s ease !important;
}

/* Hover работает как обычно */
.client-logo-reveal.revealed:hover {
    opacity: 1 !important;
    transform: translateY(-5px) !important;
    filter: drop-shadow(0 8px 16px rgba(240, 105, 34, 0.2)) !important;
}

/* Анимация для отзывов */
.testimonial-reveal {
    opacity: 0;
    transform: translateX(-40px);
    transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-reveal.revealed {
    opacity: 1;
    transform: translateX(0);
}

/* Анимация для footer */
.footer-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.9s cubic-bezier(0.4, 0, 0.2, 1);
}

.footer-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* ========================================
   АДАПТИВНОСТЬ
   ======================================== */

/* Уменьшаем смещение на мобильных */
@media (max-width: 768px) {
    .slide-up {
        transform: translateY(40px);
    }
    
    .slide-down {
        transform: translateY(-40px);
    }
    
    .slide-left {
        transform: translateX(-40px);
    }
    
    .slide-right {
        transform: translateX(40px);
    }
    
    .section-title {
        transform: translateY(30px);
    }
    
    .text-reveal {
        transform: translateY(20px);
    }
    
    .service-card-reveal {
        transform: translateY(30px) scale(0.95);
    }
}

.star {
    opacity: 0;
    transform: scale(0) rotate(-180deg);
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.star.star-revealed {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}

/* Отзывы появляются по одному */
.testimonial-item {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-item.revealed {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .scroll-reveal,
    .fade-in,
    .slide-up,
    .slide-down,
    .slide-left,
    .slide-right,
    .scale-up,
    .zoom-in,
    .rotate-in,
    .section-title,
    .text-reveal,
    .button-reveal,
    .service-card-reveal,
    .client-logo-reveal,
    .testimonial-reveal,
    .footer-reveal {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        transform: none !important;
    }
}