/* Ninsore generală pe tot ecranul */
.snow {
    pointer-events: none;           /* să nu blocheze click-urile */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 9999;                  /* deasupra conținutului */
}

/* Stil pentru fiecare fulg */
.snowflake {
    position: absolute;
    top: -10vh;
    color: #ffffff;
    opacity: 0.9;
    font-size: 16px;
    text-shadow: 0 0 4px rgba(0,0,0,0.3);
    animation-name: fall, sway;
    animation-iteration-count: infinite;
    animation-timing-function: linear, ease-in-out;
}

/* Căderea fulgului */
@keyframes fall {
    0% {
        transform: translate3d(0, -10vh, 0);
    }
    100% {
        transform: translate3d(0, 110vh, 0);
    }
}

/* Legănarea stânga-dreapta (să pară mai natural) */
@keyframes sway {
    0% {
        margin-left: 0;
    }
    50% {
        margin-left: 40px;
    }
    100% {
        margin-left: 0;
    }
}

/* Mai "ușoară" pe telefon */
@media (max-width: 768px) {
    .snowflake {
        opacity: 0.6;
        font-size: 12px;
    }
}
