.fade-up {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 1s cubic-bezier(0.16, 1, 0.3, 1), transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.fade-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.stagger-1 { transition-delay: 0.1s; }
.stagger-2 { transition-delay: 0.2s; }
.stagger-3 { transition-delay: 0.3s; }
.stagger-4 { transition-delay: 0.4s; }

.image-reveal {
    clip-path: inset(0 100% 0 0);
    transition: clip-path 1.2s cubic-bezier(0.77, 0, 0.175, 1);
}
.image-reveal.visible {
    clip-path: inset(0 0 0 0);
}

.scale-down {
    transform: scale(1.1);
    transition: transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.scale-down.visible {
    transform: scale(1);
}

.fade-in {
    opacity: 0;
    transition: opacity 1.5s ease-in-out;
}
.fade-in.visible {
    opacity: 1;
}

body {
    font-family: 'Inter', sans-serif; 
    background-color: #fbf9f4; 
    color: #1b1c19; 
    overflow-x: hidden;
}
h1, h2, h3, .serif { font-family: 'Newsreader', serif; }
.material-symbols-outlined { font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24; }
.no-scrollbar::-webkit-scrollbar { display: none; }
spline-viewer::part(logo) { display: none !important; }
