        html, body{
            overflow-x: hidden;
            scroll-behavior: smooth;
        }
        .hero-carousel {
            height: 100vh;
            max-height: 800px;
        }
        .carousel-item {
            transition: opacity 0.5s ease-in-out;
        }
        .carousel-image {
            height: 100%;
            width: 100%;
            object-fit: cover;
            filter: brightness(0.7);
        }
        .carousel-caption {
            position: absolute;
            bottom: 20%;
            left: 0;
            right: 0;
            padding: 0 2rem;
        }
        .carousel-indicators {
            bottom: 10%;
        }
        .carousel-control {
            width: 50px;
            height: 50px;
            background: rgba(255,255,255,0.3);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .event-title {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
        line-height: 1.25;
        min-height: 2.5em;       /* 2 lines × line-height */
        }