.mp-reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
    will-change: opacity, transform;
}
.mp-reveal.is-visible {
    opacity: 1 !important;
    transform: translateY(0) !important;
}
@media (prefers-reduced-motion: reduce) {
    .mp-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

.mp-lift {
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s ease;
}
.mp-lift:hover {
    transform: translateY(-5px); /* Kevyt nosto */
}

.mp-btn-shimmer .wp-block-button__link,
.wp-block-button__link.mp-btn-shimmer {
    position: relative;
    overflow: hidden;
}
.mp-btn-shimmer .wp-block-button__link::after,
.wp-block-button__link.mp-btn-shimmer::after {
    content: '';
    position: absolute;
    top: 0; 
    left: -100%;
    width: 50%; 
    height: 100%;
    /* Hienovarainen valkoinen kiilto */
    background: linear-gradient(
        to right, 
        rgba(255,255,255,0) 0%, 
        rgba(255,255,255,0.2) 50%, 
        rgba(255,255,255,0) 100%
    );
    transform: skewX(-20deg);
    pointer-events: none;
    transition: none;
}
.mp-btn-shimmer:hover .wp-block-button__link::after,
.wp-block-button__link.mp-btn-shimmer:hover::after {
    animation: mpShimmer 0.75s forwards;
}
@keyframes mpShimmer {
    0% { left: -100%; }
    100% { left: 200%; }
}
.mp-img-zoom .mp-img-cover,
.mp-img-zoom img {
    transition: transform 0.6s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.mp-img-zoom:hover .mp-img-cover,
.mp-img-zoom:hover img {
    transform: scale(1.08);
}
.mp-img-zoom .mp-slide-image,
.mp-img-zoom figure {
    overflow: hidden;
}