/* Falling petals effect — overlay on entire page */
.falling-leaves {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    pointer-events: none;
    overflow: hidden;
    z-index: 99999;
}

.falling-leaves .leaf {
    position: absolute;
    top: -10vh;
    display: inline-block;
    line-height: 1;
    user-select: none;
    opacity: 0.9;
    will-change: transform;
    animation-name: leaf-fall;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
}

.falling-leaves .leaf > img {
    display: block;
    width: 100%;
    height: auto;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.25));
    animation: leaf-sway 3s ease-in-out infinite alternate;
}

@keyframes leaf-fall {
    0%   { transform: translate3d(0, -10vh, 0) rotate(0deg); }
    100% { transform: translate3d(0, 110vh, 0) rotate(720deg); }
}

@keyframes leaf-sway {
    0%   { transform: translateX(-30px); }
    100% { transform: translateX(30px); }
}

@media (prefers-reduced-motion: reduce) {
    .falling-leaves { display: none; }
}
