/* ============================================
   Al-Mahdi Theme — Entrance Animations
   Scroll-reveal & page-load animations
============================================ */

/* --- Base reveal state (hidden) --- */
.almahdi-reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
                transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}

/* --- Revealed state --- */
.almahdi-reveal.revealed {
    opacity: 1;
    transform: translateY(0) translateX(0) scale(1);
}

/* --- Direction variants --- */
.almahdi-reveal[data-reveal="fade-up"] {
    transform: translateY(40px);
}
.almahdi-reveal[data-reveal="fade-down"] {
    transform: translateY(-40px);
}
.almahdi-reveal[data-reveal="fade-right"] {
    transform: translateX(-50px);
}
.almahdi-reveal[data-reveal="fade-left"] {
    transform: translateX(50px);
}
.almahdi-reveal[data-reveal="scale-in"] {
    transform: scale(0.85);
}
.almahdi-reveal[data-reveal="fade-in"] {
    transform: none;
}

/* --- Stagger delay utility (set via JS) --- */
.almahdi-reveal[data-delay="1"] { transition-delay: 0.08s; }
.almahdi-reveal[data-delay="2"] { transition-delay: 0.16s; }
.almahdi-reveal[data-delay="3"] { transition-delay: 0.24s; }
.almahdi-reveal[data-delay="4"] { transition-delay: 0.32s; }
.almahdi-reveal[data-delay="5"] { transition-delay: 0.40s; }
.almahdi-reveal[data-delay="6"] { transition-delay: 0.48s; }

/* --- Hero special entrance (page load, not scroll) --- */
@keyframes heroFadeIn {
    from { opacity: 0; transform: scale(1.05); }
    to   { opacity: 1; transform: scale(1); }
}
@keyframes heroTextSlide {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
}
.hero-splash .hero-bg-main-image {
    animation: heroFadeIn 1.2s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.hero-splash .hero-text-overlay {
    animation: heroTextSlide 1s 0.3s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* --- Live broadcast card pulse-in --- */
@keyframes cardSlideUp {
    from { opacity: 0; transform: translateY(50px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Prayer time cards stagger --- */
.pt-card.revealed-child {
    animation: cardSlideUp 0.5s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* --- Footer columns stagger --- */
.footer-col.revealed-child {
    animation: cardSlideUp 0.6s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* --- Video / folder card hover lift (bonus) --- */
.ma-main-video,
.ma-sub-video,
.folder-card,
.video-card-new {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ma-main-video:hover,
.ma-sub-video:hover,
.folder-card:hover,
.video-card-new:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.15);
}

/* --- Reduce motion preference --- */
@media (prefers-reduced-motion: reduce) {
    .almahdi-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .hero-splash .hero-bg-main-image,
    .hero-splash .hero-text-overlay {
        animation: none !important;
    }
    .pt-card.revealed-child,
    .footer-col.revealed-child {
        animation: none !important;
    }
}
