/**
 * Revolution Slider - Animation Presets Library
 * Phase 1.1: Advanced Animations
 * Comprehensive CSS animation library for professional slider effects
 */

/* ==========================================================================
   ENTRANCE ANIMATIONS - Fade
   ========================================================================== */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
.fadeIn { animation-name: fadeIn; }

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(40px); }
    to { opacity: 1; transform: translateY(0); }
}
.fadeInUp { animation-name: fadeInUp; }

@keyframes fadeInDown {
    from { opacity: 0; transform: translateY(-40px); }
    to { opacity: 1; transform: translateY(0); }
}
.fadeInDown { animation-name: fadeInDown; }

@keyframes fadeInLeft {
    from { opacity: 0; transform: translateX(-40px); }
    to { opacity: 1; transform: translateX(0); }
}
.fadeInLeft { animation-name: fadeInLeft; }

@keyframes fadeInRight {
    from { opacity: 0; transform: translateX(40px); }
    to { opacity: 1; transform: translateX(0); }
}
.fadeInRight { animation-name: fadeInRight; }

@keyframes fadeInUpBig {
    from { opacity: 0; transform: translateY(100px); }
    to { opacity: 1; transform: translateY(0); }
}
.fadeInUpBig { animation-name: fadeInUpBig; }

@keyframes fadeInDownBig {
    from { opacity: 0; transform: translateY(-100px); }
    to { opacity: 1; transform: translateY(0); }
}
.fadeInDownBig { animation-name: fadeInDownBig; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Zoom
   ========================================================================== */
@keyframes zoomIn {
    from { opacity: 0; transform: scale(0.3); }
    to { opacity: 1; transform: scale(1); }
}
.zoomIn { animation-name: zoomIn; }

@keyframes zoomInUp {
    from { opacity: 0; transform: scale(0.3) translateY(100px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}
.zoomInUp { animation-name: zoomInUp; }

@keyframes zoomInDown {
    from { opacity: 0; transform: scale(0.3) translateY(-100px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}
.zoomInDown { animation-name: zoomInDown; }

@keyframes zoomInLeft {
    from { opacity: 0; transform: scale(0.3) translateX(-100px); }
    to { opacity: 1; transform: scale(1) translateX(0); }
}
.zoomInLeft { animation-name: zoomInLeft; }

@keyframes zoomInRight {
    from { opacity: 0; transform: scale(0.3) translateX(100px); }
    to { opacity: 1; transform: scale(1) translateX(0); }
}
.zoomInRight { animation-name: zoomInRight; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Slide
   ========================================================================== */
@keyframes slideInUp {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
.slideInUp { animation-name: slideInUp; }

@keyframes slideInDown {
    from { transform: translateY(-100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}
.slideInDown { animation-name: slideInDown; }

@keyframes slideInLeft {
    from { transform: translateX(-100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}
.slideInLeft { animation-name: slideInLeft; }

@keyframes slideInRight {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}
.slideInRight { animation-name: slideInRight; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Bounce
   ========================================================================== */
@keyframes bounceIn {
    0% { opacity: 0; transform: scale(0.3); }
    50% { transform: scale(1.05); }
    70% { transform: scale(0.9); }
    100% { opacity: 1; transform: scale(1); }
}
.bounceIn { animation-name: bounceIn; }

@keyframes bounceInUp {
    0% { opacity: 0; transform: translateY(100px); }
    60% { opacity: 1; transform: translateY(-20px); }
    80% { transform: translateY(10px); }
    100% { transform: translateY(0); }
}
.bounceInUp { animation-name: bounceInUp; }

@keyframes bounceInDown {
    0% { opacity: 0; transform: translateY(-100px); }
    60% { opacity: 1; transform: translateY(20px); }
    80% { transform: translateY(-10px); }
    100% { transform: translateY(0); }
}
.bounceInDown { animation-name: bounceInDown; }

@keyframes bounceInLeft {
    0% { opacity: 0; transform: translateX(-100px); }
    60% { opacity: 1; transform: translateX(20px); }
    80% { transform: translateX(-10px); }
    100% { transform: translateX(0); }
}
.bounceInLeft { animation-name: bounceInLeft; }

@keyframes bounceInRight {
    0% { opacity: 0; transform: translateX(100px); }
    60% { opacity: 1; transform: translateX(-20px); }
    80% { transform: translateX(10px); }
    100% { transform: translateX(0); }
}
.bounceInRight { animation-name: bounceInRight; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Flip
   ========================================================================== */
@keyframes flipInX {
    0% { opacity: 0; transform: perspective(400px) rotateX(90deg); }
    40% { transform: perspective(400px) rotateX(-10deg); }
    70% { transform: perspective(400px) rotateX(10deg); }
    100% { opacity: 1; transform: perspective(400px) rotateX(0deg); }
}
.flipInX { animation-name: flipInX; backface-visibility: visible !important; }

@keyframes flipInY {
    0% { opacity: 0; transform: perspective(400px) rotateY(90deg); }
    40% { transform: perspective(400px) rotateY(-10deg); }
    70% { transform: perspective(400px) rotateY(10deg); }
    100% { opacity: 1; transform: perspective(400px) rotateY(0deg); }
}
.flipInY { animation-name: flipInY; backface-visibility: visible !important; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Rotate
   ========================================================================== */
@keyframes rotateIn {
    0% { opacity: 0; transform: rotate(-200deg); }
    100% { opacity: 1; transform: rotate(0deg); }
}
.rotateIn { animation-name: rotateIn; }

@keyframes rotateInDownLeft {
    0% { opacity: 0; transform: rotate(-45deg); transform-origin: left bottom; }
    100% { opacity: 1; transform: rotate(0deg); transform-origin: left bottom; }
}
.rotateInDownLeft { animation-name: rotateInDownLeft; }

@keyframes rotateInDownRight {
    0% { opacity: 0; transform: rotate(45deg); transform-origin: right bottom; }
    100% { opacity: 1; transform: rotate(0deg); transform-origin: right bottom; }
}
.rotateInDownRight { animation-name: rotateInDownRight; }

@keyframes rotateInUpLeft {
    0% { opacity: 0; transform: rotate(45deg); transform-origin: left bottom; }
    100% { opacity: 1; transform: rotate(0deg); transform-origin: left bottom; }
}
.rotateInUpLeft { animation-name: rotateInUpLeft; }

@keyframes rotateInUpRight {
    0% { opacity: 0; transform: rotate(-45deg); transform-origin: right bottom; }
    100% { opacity: 1; transform: rotate(0deg); transform-origin: right bottom; }
}
.rotateInUpRight { animation-name: rotateInUpRight; }

/* ==========================================================================
   ENTRANCE ANIMATIONS - Special
   ========================================================================== */
@keyframes rollIn {
    0% { opacity: 0; transform: translateX(-100%) rotate(-120deg); }
    100% { opacity: 1; transform: translateX(0) rotate(0deg); }
}
.rollIn { animation-name: rollIn; }

@keyframes lightSpeedIn {
    0% { opacity: 0; transform: translateX(100%) skewX(-30deg); }
    60% { transform: translateX(-10%) skewX(20deg); opacity: 1; }
    80% { transform: translateX(5%) skewX(-5deg); }
    100% { transform: translateX(0) skewX(0deg); }
}
.lightSpeedIn { animation-name: lightSpeedIn; }

@keyframes jackInTheBox {
    0% { opacity: 0; transform: scale(0.1) rotate(30deg); transform-origin: center bottom; }
    50% { transform: rotate(-10deg); }
    70% { transform: rotate(3deg); }
    100% { opacity: 1; transform: scale(1) rotate(0deg); }
}
.jackInTheBox { animation-name: jackInTheBox; }

/* ==========================================================================
   EXIT ANIMATIONS - Fade
   ========================================================================== */
@keyframes fadeOut {
    from { opacity: 1; }
    to { opacity: 0; }
}
.fadeOut { animation-name: fadeOut; }

@keyframes fadeOutUp {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(-40px); }
}
.fadeOutUp { animation-name: fadeOutUp; }

@keyframes fadeOutDown {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(40px); }
}
.fadeOutDown { animation-name: fadeOutDown; }

@keyframes fadeOutLeft {
    from { opacity: 1; transform: translateX(0); }
    to { opacity: 0; transform: translateX(-40px); }
}
.fadeOutLeft { animation-name: fadeOutLeft; }

@keyframes fadeOutRight {
    from { opacity: 1; transform: translateX(0); }
    to { opacity: 0; transform: translateX(40px); }
}
.fadeOutRight { animation-name: fadeOutRight; }

/* ==========================================================================
   EXIT ANIMATIONS - Zoom
   ========================================================================== */
@keyframes zoomOut {
    from { opacity: 1; transform: scale(1); }
    to { opacity: 0; transform: scale(0.3); }
}
.zoomOut { animation-name: zoomOut; }

@keyframes zoomOutUp {
    from { opacity: 1; transform: scale(1) translateY(0); }
    to { opacity: 0; transform: scale(0.3) translateY(-100px); }
}
.zoomOutUp { animation-name: zoomOutUp; }

@keyframes zoomOutDown {
    from { opacity: 1; transform: scale(1) translateY(0); }
    to { opacity: 0; transform: scale(0.3) translateY(100px); }
}
.zoomOutDown { animation-name: zoomOutDown; }

/* ==========================================================================
   EXIT ANIMATIONS - Slide
   ========================================================================== */
@keyframes slideOutUp {
    from { transform: translateY(0); opacity: 1; }
    to { transform: translateY(-100%); opacity: 0; }
}
.slideOutUp { animation-name: slideOutUp; }

@keyframes slideOutDown {
    from { transform: translateY(0); opacity: 1; }
    to { transform: translateY(100%); opacity: 0; }
}
.slideOutDown { animation-name: slideOutDown; }

@keyframes slideOutLeft {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(-100%); opacity: 0; }
}
.slideOutLeft { animation-name: slideOutLeft; }

@keyframes slideOutRight {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(100%); opacity: 0; }
}
.slideOutRight { animation-name: slideOutRight; }

/* ==========================================================================
   EXIT ANIMATIONS - Special
   ========================================================================== */
@keyframes bounceOut {
    20% { transform: scale(0.9); }
    50%, 55% { opacity: 1; transform: scale(1.1); }
    100% { opacity: 0; transform: scale(0.3); }
}
.bounceOut { animation-name: bounceOut; }

@keyframes flipOutX {
    0% { transform: perspective(400px); }
    30% { transform: perspective(400px) rotateX(-20deg); opacity: 1; }
    100% { transform: perspective(400px) rotateX(90deg); opacity: 0; }
}
.flipOutX { animation-name: flipOutX; backface-visibility: visible !important; }

@keyframes flipOutY {
    0% { transform: perspective(400px); }
    30% { transform: perspective(400px) rotateY(-15deg); opacity: 1; }
    100% { transform: perspective(400px) rotateY(90deg); opacity: 0; }
}
.flipOutY { animation-name: flipOutY; backface-visibility: visible !important; }

@keyframes rotateOut {
    from { opacity: 1; transform: rotate(0deg); }
    to { opacity: 0; transform: rotate(200deg); }
}
.rotateOut { animation-name: rotateOut; }

@keyframes rollOut {
    from { opacity: 1; transform: translateX(0) rotate(0deg); }
    to { opacity: 0; transform: translateX(100%) rotate(120deg); }
}
.rollOut { animation-name: rollOut; }

@keyframes lightSpeedOut {
    from { opacity: 1; transform: translateX(0) skewX(0deg); }
    to { opacity: 0; transform: translateX(100%) skewX(30deg); }
}
.lightSpeedOut { animation-name: lightSpeedOut; }

/* ==========================================================================
   LOOP ANIMATIONS - Attention Seekers
   ========================================================================== */
@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}
.pulse { animation-name: pulse; }

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-20px); }
    60% { transform: translateY(-10px); }
}
.bounce { animation-name: bounce; }

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-10px); }
    20%, 40%, 60%, 80% { transform: translateX(10px); }
}
.shake { animation-name: shake; }

@keyframes swing {
    20% { transform: rotate(15deg); }
    40% { transform: rotate(-10deg); }
    60% { transform: rotate(5deg); }
    80% { transform: rotate(-5deg); }
    100% { transform: rotate(0deg); }
}
.swing { animation-name: swing; transform-origin: top center; }

@keyframes wobble {
    0% { transform: translateX(0) rotate(0deg); }
    15% { transform: translateX(-25%) rotate(-5deg); }
    30% { transform: translateX(20%) rotate(3deg); }
    45% { transform: translateX(-15%) rotate(-3deg); }
    60% { transform: translateX(10%) rotate(2deg); }
    75% { transform: translateX(-5%) rotate(-1deg); }
    100% { transform: translateX(0) rotate(0deg); }
}
.wobble { animation-name: wobble; }

@keyframes jello {
    0%, 11.1%, 100% { transform: none; }
    22.2% { transform: skewX(-12.5deg) skewY(-12.5deg); }
    33.3% { transform: skewX(6.25deg) skewY(6.25deg); }
    44.4% { transform: skewX(-3.125deg) skewY(-3.125deg); }
    55.5% { transform: skewX(1.5625deg) skewY(1.5625deg); }
    66.6% { transform: skewX(-0.78125deg) skewY(-0.78125deg); }
    77.7% { transform: skewX(0.390625deg) skewY(0.390625deg); }
    88.8% { transform: skewX(-0.1953125deg) skewY(-0.1953125deg); }
}
.jello { animation-name: jello; transform-origin: center; }

@keyframes heartBeat {
    0% { transform: scale(1); }
    14% { transform: scale(1.3); }
    28% { transform: scale(1); }
    42% { transform: scale(1.3); }
    70% { transform: scale(1); }
}
.heartBeat { animation-name: heartBeat; }

@keyframes flash {
    0%, 50%, 100% { opacity: 1; }
    25%, 75% { opacity: 0; }
}
.flash { animation-name: flash; }

@keyframes rubberBand {
    0% { transform: scale(1, 1); }
    30% { transform: scale(1.25, 0.75); }
    40% { transform: scale(0.75, 1.25); }
    50% { transform: scale(1.15, 0.85); }
    65% { transform: scale(0.95, 1.05); }
    75% { transform: scale(1.05, 0.95); }
    100% { transform: scale(1, 1); }
}
.rubberBand { animation-name: rubberBand; }

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}
.float { animation-name: float; }

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
.spin { animation-name: spin; }

@keyframes tada {
    0% { transform: scale(1) rotate(0deg); }
    10%, 20% { transform: scale(0.9) rotate(-3deg); }
    30%, 50%, 70%, 90% { transform: scale(1.1) rotate(3deg); }
    40%, 60%, 80% { transform: scale(1.1) rotate(-3deg); }
    100% { transform: scale(1) rotate(0deg); }
}
.tada { animation-name: tada; }

/* ==========================================================================
   TEXT ANIMATIONS - Special Effects
   ========================================================================== */
@keyframes typewriter {
    from { width: 0; }
    to { width: 100%; }
}
.typewriter {
    overflow: hidden;
    white-space: nowrap;
    animation-name: typewriter;
    animation-timing-function: steps(40, end);
}

@keyframes blurIn {
    from { filter: blur(10px); opacity: 0; }
    to { filter: blur(0); opacity: 1; }
}
.blurIn { animation-name: blurIn; }

@keyframes glitchIn {
    0% { opacity: 0; transform: translate(-5px, 5px); filter: hue-rotate(90deg); }
    20% { opacity: 0.5; transform: translate(5px, -5px); filter: hue-rotate(180deg); }
    40% { opacity: 0.7; transform: translate(-3px, 3px); filter: hue-rotate(270deg); }
    60% { opacity: 0.8; transform: translate(3px, -3px); filter: hue-rotate(360deg); }
    80% { opacity: 0.9; transform: translate(-1px, 1px); filter: hue-rotate(0deg); }
    100% { opacity: 1; transform: translate(0, 0); filter: hue-rotate(0deg); }
}
.glitchIn { animation-name: glitchIn; }

@keyframes neonFlicker {
    0%, 18%, 22%, 25%, 53%, 57%, 100% {
        text-shadow: 0 0 4px #fff, 0 0 11px #fff, 0 0 19px #fff, 0 0 40px #fd4513, 0 0 80px #fd4513;
        opacity: 1;
    }
    20%, 24%, 55% {
        text-shadow: none;
        opacity: 0.8;
    }
}
.neonFlicker { animation-name: neonFlicker; }

/* ==========================================================================
   UTILITY CLASSES
   ========================================================================== */
.animated {
    animation-duration: 1s;
    animation-fill-mode: both;
}

.animated.faster {
    animation-duration: 0.5s;
}

.animated.fast {
    animation-duration: 0.8s;
}

.animated.slow {
    animation-duration: 2s;
}

.animated.slower {
    animation-duration: 3s;
}

.animated.infinite {
    animation-iteration-count: infinite;
}

/* Delay utilities */
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-400 { animation-delay: 0.4s; }
.delay-500 { animation-delay: 0.5s; }
.delay-600 { animation-delay: 0.6s; }
.delay-700 { animation-delay: 0.7s; }
.delay-800 { animation-delay: 0.8s; }
.delay-900 { animation-delay: 0.9s; }
.delay-1000 { animation-delay: 1s; }
.delay-1500 { animation-delay: 1.5s; }
.delay-2000 { animation-delay: 2s; }

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    .animated {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
