
/* Full-width hero image – no crop (replaces background-size: cover heroes) */

.hero-section.hero-banner-full {
    display: block !important;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    position: relative;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    margin: 0;
    overflow: hidden;
    background-color: #0d0d0d;
    background-image: none !important;
    background-attachment: scroll !important;
}

.hero-section.hero-banner-full::before {
    display: none;
}

.hero-section.hero-banner-full.hero-banner-full--overlay::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    background: linear-gradient(
        135deg,
        rgba(0, 0, 0, 0.55) 0%,
        rgba(0, 0, 0, 0.25) 45%,
        rgba(102, 0, 59, 0.35) 100%
    );
    z-index: 1;
    pointer-events: none;
}

.hero-section.hero-banner-full.hero-banner-full--overlay-light::after {
    background: linear-gradient(
        to right,
        rgba(0, 0, 0, 0.65) 0%,
        rgba(0, 0, 0, 0.35) 55%,
        rgba(0, 0, 0, 0.2) 100%
    );
}

.hero-section.hero-banner-full.hero-banner-full--overlay-home::after {
    background: linear-gradient(
        135deg,
        rgba(0, 0, 0, 0.72) 0%,
        rgba(102, 0, 59, 0.48) 100%
    );
}

.hero-section.hero-banner-full.hero-banner-full--overlay-bottom::after {
    top: auto;
    height: 45%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.55) 0%, transparent 100%);
}

/* Event details page – full artwork visible; overrides global .hero-section from app layout */
.hero-section.event-details-hero.hero-banner-full {
    margin: 0;
    z-index: 1;
}

.hero-section.event-details-hero.hero-banner-full--no-title::after {
    display: none;
}

.hero-section.event-details-hero .hero-title {
    word-wrap: break-word;
    overflow-wrap: break-word;
    text-shadow:
        0 2px 24px rgba(0, 0, 0, 0.85),
        0 1px 4px rgba(0, 0, 0, 0.95);
}

@media (max-width: 992px) {
    .hero-section.event-details-hero .hero-title {
        font-size: clamp(1.15rem, 4.5vw, 1.65rem) !important;
        line-height: 1.22;
        margin-bottom: 0;
        font-weight: 700;
    }

    .hero-section.event-details-hero .hero-title span {
        display: inline-block;
        margin-top: 0.15em;
    }
}

@media (max-width: 576px) {
    .hero-section.event-details-hero .hero-title {
        font-size: clamp(1.05rem, 4.2vw, 1.4rem) !important;
        line-height: 1.2;
    }
}

@media (max-width: 400px) {
    .hero-section.event-details-hero .hero-title {
        font-size: 1.05rem !important;
    }
}

/* Home / slider banners: cinematic fill (cover) inside a fixed hero height */
.hero-section.hero-banner-full.hero-banner-full--cover {
    height: min(70vh, 900px) !important;
    min-height: clamp(280px, 45vh, 520px) !important;
    max-height: min(70vh, 900px);
}

.hero-section.hero-banner-full.hero-banner-full--cover .hero-banner-full__media {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.hero-section.hero-banner-full.hero-banner-full--cover .hero-banner-full__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

.hero-section.hero-banner-full.hero-banner-full--cover .hero-content,
.hero-section.hero-banner-full.hero-banner-full--cover [class*='-hero-content'] {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
}

@media (max-width: 768px) {
    .hero-section.hero-banner-full.hero-banner-full--cover {
        height: min(52vh, 560px) !important;
        min-height: clamp(240px, 42vh, 480px) !important;
        max-height: min(52vh, 560px);
    }

    .hero-section.hero-banner-full.hero-banner-full--cover .hero-banner-full__img {
        object-position: center top;
    }
}

.home-hero .hero-title {
    font-size: clamp(2rem, 5.5vw, 4rem);
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 1.5rem;
    text-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}

.home-hero .hero-title span {
    color: #ff0080;
}

.hero-banner-full__media {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    line-height: 0;
}

.hero-banner-full__img {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    vertical-align: top;
}

.hero-section.hero-banner-full .hero-content,
.hero-section.hero-banner-full [class*='-hero-content'] {
    position: absolute;
    z-index: 2;
    box-sizing: border-box;
}

.hero-section.hero-banner-full.hero-banner-full--content-center .hero-content,
.hero-section.hero-banner-full.hero-banner-full--content-center [class*='-hero-content'] {
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: clamp(100px, 16vw, 160px) clamp(1rem, 5vw, 10%) clamp(40px, 5vw, 60px);
}

.hero-section.hero-banner-full.hero-banner-full--content-center-center .hero-content,
.hero-section.hero-banner-full.hero-banner-full--content-center-center [class*='-hero-content'] {
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: clamp(100px, 16vw, 160px) clamp(1rem, 5vw, 10%) clamp(40px, 5vw, 60px);
}

.hero-section.hero-banner-full.hero-banner-full--content-bottom .hero-content,
.hero-section.hero-banner-full.hero-banner-full--content-bottom [class*='-hero-content'] {
    left: 0;
    right: 0;
    bottom: clamp(20px, 4vw, 48px);
    padding: 0 clamp(14px, 3vw, 24px);
}

.hero-section.hero-banner-full.hero-banner-full--fallback {
    display: flex !important;
    align-items: flex-end;
    justify-content: center;
    min-height: clamp(220px, 45vh, 500px) !important;
    padding: clamp(120px, 18vw, 160px) 24px 40px !important;
    background: linear-gradient(135deg, #1a1a1a 0%, #2d0020 100%) !important;
}

.hero-section.hero-banner-full.hero-banner-full--fallback::before {
    display: block;
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(102, 0, 59, 0.5) 100%);
    z-index: 1;
}

.hero-section.hero-banner-full.hero-banner-full--fallback .hero-content,
.hero-section.hero-banner-full.hero-banner-full--fallback [class*='-hero-content'] {
    position: relative;
    inset: auto;
    display: block;
    padding: 0;
}

.hero-section.hero-banner-full.hero-banner-full--mb {
    margin-bottom: 40px;
}

@media (max-width: 768px) {
    .hero-section.hero-banner-full.hero-banner-full--mb {
        margin-bottom: 24px;
    }
}
