/* ============================================
   АНИМАЦИИ ТОЛЬКО ДЛЯ ТЕКСТОВ И КАРТОЧЕК КАМНЯ
   Слайдер и каталог товаров НЕ ТРОГАЕМ
   ============================================ */

/* Hero секция - текст появляется из ниоткуда */
.hero .hero-badge,
.hero h1,
.hero p,
.hero .btn {
    opacity: 0;
}

.hero .hero-badge {
    animation: heroBadgeAnim 0.65s cubic-bezier(0.34, 1.2, 0.64, 1) 0.3s forwards;
}

.hero h1 {
    animation: heroTitleAnim 1.04s cubic-bezier(0.34, 1.3, 0.55, 1) 0.45s forwards;
}

.hero p {
    animation: heroTextAnim 0.91s cubic-bezier(0.34, 1.2, 0.64, 1) 0.6s forwards;
}

.hero .btn:first-of-type {
    animation: heroBtnAnim 0.65s cubic-bezier(0.34, 1.4, 0.55, 1) 0.8s forwards;
}

.hero .btn:last-of-type {
    animation: heroBtnAnim 0.65s cubic-bezier(0.34, 1.4, 0.55, 1) 0.98s forwards;
}

@keyframes heroBadgeAnim {
    0% { opacity: 0; transform: translateY(-15px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes heroTitleAnim {
    0% { opacity: 0; transform: translateY(30px); }
    60% { opacity: 0.9; transform: translateY(-5px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes heroTextAnim {
    0% { opacity: 0; transform: translateY(20px); }
    100% { opacity: 1; transform: translateY(0); }
}

@keyframes heroBtnAnim {
    0% { opacity: 0; transform: scale(0.9); }
    50% { opacity: 0.9; transform: scale(1.05); }
    100% { opacity: 1; transform: scale(1); }
}

/* Анимации для элементов при скролле */
.scroll-animate {
    opacity: 0;
    transition: opacity 0.78s ease, transform 0.78s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.15s;
}

.scroll-animate.visible {
    opacity: 1;
}

/* Типы анимаций */
.scroll-animate-bottom {
    transform: translateY(30px);
}
.scroll-animate-bottom.visible {
    transform: translateY(0);
}

.scroll-animate-left {
    transform: translateX(-30px);
}
.scroll-animate-left.visible {
    transform: translateX(0);
}

.scroll-animate-right {
    transform: translateX(30px);
}
.scroll-animate-right.visible {
    transform: translateX(0);
}

.scroll-animate-scale {
    transform: scale(0.95);
}
.scroll-animate-scale.visible {
    transform: scale(1);
}

/* Заголовки секций */
section h2 {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.78s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.78s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.1s;
}
section h2.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Декоративная линия */
.title-line {
    width: 0 !important;
    transition: width 0.78s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.15s;
}
.title-line.visible {
    width: 80px !important;
}

/* Подзаголовок */
.section-subhead {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.65s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.65s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.2s;
}
.section-subhead.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Текст в секции about */
.about .two-columns > div:first-child {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 0.91s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.91s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.1s;
}
.about .two-columns > div:first-child.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Карточки цвета камня */
.stone-card {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.78s cubic-bezier(0.34, 1.25, 0.55, 1), 
                transform 0.78s cubic-bezier(0.34, 1.25, 0.55, 1);
    transition-delay: 0.12s;
}
.stone-card.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Карточки преимуществ */
.card-premium {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.78s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.78s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.1s;
}
.card-premium.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Секция доставки - текст */
.delivery-content {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 0.91s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.91s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.1s;
}
.delivery-content.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Секция доставки - иконка */
.delivery-icon {
    opacity: 0;
    transform: translateX(30px) scale(0.9);
    transition: opacity 0.78s cubic-bezier(0.34, 1.3, 0.55, 1), 
                transform 0.78s cubic-bezier(0.34, 1.3, 0.55, 1);
    transition-delay: 0.2s;
}
.delivery-icon.visible {
    opacity: 1;
    transform: translateX(0) scale(1);
}

/* PDF секция */
#catalog .card-premium {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.91s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.91s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.1s;
}
#catalog .card-premium.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Контактные элементы */
.contact-item {
    opacity: 0;
    transform: translateX(-20px);
    transition: opacity 0.65s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 0.65s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.08s;
}
.contact-item.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Карта */
.map-container {
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 1.04s cubic-bezier(0.34, 1.2, 0.64, 1), 
                transform 1.04s cubic-bezier(0.34, 1.2, 0.64, 1);
    transition-delay: 0.15s;
}
.map-container.visible {
    opacity: 1;
    transform: scale(1);
}

/* Hover эффекты для карточек */
.stone-card:hover {
    transform: translateY(-5px);
    transition: transform 0.3s ease;
}

.card-premium:hover {
    transform: translateY(-4px);
    transition: transform 0.3s ease;
}

/* Отключение анимаций при необходимости */
@media (prefers-reduced-motion: reduce) {
    .hero .hero-badge,
    .hero h1,
    .hero p,
    .hero .btn,
    .scroll-animate,
    section h2,
    .title-line,
    .section-subhead,
    .about .two-columns > div:first-child,
    .stone-card,
    .card-premium,
    .delivery-content,
    .delivery-icon,
    #catalog .card-premium,
    .contact-item,
    .map-container {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    
    .title-line {
        width: 80px !important;
    }
}