/* Loyalty program landing — glass + carousel */

.loyalty-landing {
    --loyalty-bg: url('../images/loyalty/loyalty-hero-1.jpg');
}

.loyalty-landing.menu-page-bg {
    --menu-bg-photo: var(--loyalty-bg);
}

.loyalty-hero-carousel {
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
    padding: 6rem 1rem 2rem;
}

@media (max-width: 767px) {
    .loyalty-hero-carousel {
        padding: 0.75rem 0.75rem 1.25rem;
        margin-top: 0;
    }
}

.loyalty-hero-frame {
    position: relative;
    height: clamp(420px, 58vh, 600px);
    border-radius: 22px;
    overflow: hidden;
    border: 1px solid rgba(245, 158, 11, 0.2);
    box-shadow: 0 28px 56px rgba(0, 0, 0, 0.45);
}

.loyalty-hero-slide {
    display: grid;
    grid-template-columns: 1fr;
    height: 100%;
}

@media (min-width: 900px) {
    .loyalty-hero-slide {
        grid-template-columns: 1.05fr 0.95fr;
    }
}

.loyalty-hero-slide__media {
    position: relative;
    min-height: 220px;
    overflow: hidden;
}

.loyalty-hero-slide__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.loyalty-hero-slide__fade {
    display: none;
}

@media (min-width: 900px) {
    .loyalty-hero-slide__fade {
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 50%;
        width: 120px;
        transform: translateX(-50%);
        z-index: 2;
        background: linear-gradient(90deg, transparent, rgba(12, 12, 14, 0.9) 50%, transparent);
        pointer-events: none;
    }
}

.loyalty-hero-slide__copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem;
    background: #0c0c0e;
}

.loyalty-step-card,
.loyalty-tier-card,
.loyalty-faq {
    border-radius: 1.25rem !important;
}
