.banner-section {
    position: relative;
    contain: layout style paint;
}

.banner-section .absolute.inset-0.z-0 {
    will-change: auto;
}

.banner-section img {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

.banner-section img {
    transition: opacity 0.3s ease-in-out;
}

.banner-section .bg-black {
    will-change: opacity;
    transition: opacity 0.3s ease-in-out;
}

@media (max-width: 640px) {
    .banner-section h1 {
        font-size: 2rem;
        line-height: 1.2;
    }
    
    .banner-section p {
        font-size: 1rem;
    }
}

.banner-section.bg-gray-900 h1,
.banner-section.bg-gray-900 p {
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.banner-section .pointer-events-none > div {
    transform: translateZ(0);
    will-change: transform;
}
