/* Родительский блок */
.block-with-leaves {
  position: relative;
  overflow: hidden;
}

/* Контейнер с листьями */
.falling-leaves {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.leaf {
  position: absolute;
  top: -50px;
  left: var(--x);              /* стартовая позиция */
  width: var(--size);
  height: var(--size);
  background-size: contain;
  background-repeat: no-repeat;

  /* === сюда добавляем хаотичность === */
  animation: fall var(--duration, 12s) linear infinite; /* длительность через переменную --duration, запасное 12s */
  animation-delay: var(--delay, 0s);                     /* задержка старта для каждого листа */
}

/* Анимация падения */
@keyframes fall {
  0% {
    transform: translateX(0) translateY(0) rotate(0deg);
    opacity: 1;
  }
  100% {
    transform: translateX(var(--sway, 100px)) translateY(100vh) rotate(360deg);
    opacity: 0.5;
  }
}