/* File: public/css/blinds-animation.css */

.blinds-wrapper {
    perspective: 300px;
}

.blinds-letter {
    backface-visibility: hidden;
    display: inline-block;
    transform: rotateY(180deg);
    transition: transform 0.6s ease-in-out;
}

.blinds-letter.animate-in {
    transform: rotateY(0deg);
}

.blinds-letter.animate-out {
    transform: rotateY(-180deg);
}

/* Ensure complete reset state */
.blinds-letter:not(.animate-in) {
    transform: rotateY(180deg);
}

.blinds-letter[data-char=" "] {
    width: 0.25em;
}

.blinds-animate:not([data-blinds-initialized]) {
    opacity: 0;
    transition: opacity 0.3s;
}

.blinds-animate[data-blinds-initialized] {
    opacity: 1;
}
