/* Ajustes finos para fugir do padrão genérico */
::selection {
    background-color: #005CE6;
    color: #ffffff;
}

body {
    background-color: #F2F6FE;
    color: #0A1A33;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Animações de entrada reveladoras */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

.delay-100 { transition-delay: 100ms; }
.delay-200 { transition-delay: 200ms; }
.delay-300 { transition-delay: 300ms; }

/* Estética do grid de imagens */
.image-mask {
    border-radius: 2rem;
    overflow: hidden;
    position: relative;
}

.image-mask img {
    transition: transform 0.7s ease;
}

.image-mask:hover img {
    transform: scale(1.05);
}

/* Ruído sutil no fundo azul escuro para textura tátil */
.bg-noise {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.04'/%3E%3C/svg%3E");
}
