/* SITE IMAGE OVERRIDES */

/* NAVBAR */

.navbar {
    height: 96px !important;
    min-height: 96px !important;
    padding: 14px 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    overflow: hidden !important;
}

.navbar .logo,
.navbar .logo-with-image {
    display: flex !important;
    align-items: center !important;
    width: auto !important;
    max-width: 260px !important;
    height: 72px !important;
    overflow: hidden !important;
    flex: 0 0 auto !important;
}

.navbar .logo img,
.navbar .logo-with-image img {
    display: block !important;
    width: auto !important;
    max-width: 250px !important;
    height: 72px !important;
    max-height: 72px !important;
    object-fit: contain !important;
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
}

.navbar .nav-links {
    margin-left: auto !important;
}

/* HERO IMAGE BACKGROUND */

.hero {
    background:
        linear-gradient(90deg, rgba(13, 13, 15, .92), rgba(13, 13, 15, .78), rgba(255, 79, 163, .18)),
        url("/images/site/IMG_8407.jpg") center / cover no-repeat !important;
}

/* COURT CAROUSEL IMAGES */

.court-slide {
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

.court-slide-main {
    background-image: url("/images/site/carousel-private.jpg") !important;
}

.court-slide-event {
    background-image: url("/images/site/carousel-events.jpg") !important;
}

.court-slide-cafe {
    background-image: url("/images/site/carousel-cafe.jpg") !important;
}

/* Readable overlay on real photos */

.court-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(0, 0, 0, .88), rgba(0, 0, 0, .52), rgba(255, 79, 163, .14)),
        radial-gradient(circle at 85% 15%, rgba(255, 79, 163, .35), transparent 30%) !important;
    z-index: 1 !important;
}

.court-slide-content {
    position: relative;
    z-index: 2;
}

/* CAFE COMING SOON IMAGE ACCENT */

.coming-soon-card {
    background:
        linear-gradient(135deg, rgba(13, 13, 15, .94), rgba(43, 16, 32, .90)),
        url("/images/site/logo-replay-dark.jpg") center / cover no-repeat !important;
}

/* RESPONSIVE */

@media (max-width: 768px) {
    .navbar {
        height: auto !important;
        min-height: 86px !important;
        padding: 14px 22px !important;
        align-items: flex-start !important;
        gap: 14px !important;
    }

    .navbar .logo,
    .navbar .logo-with-image {
        max-width: 190px !important;
        height: 58px !important;
    }

    .navbar .logo img,
    .navbar .logo-with-image img {
        max-width: 185px !important;
        height: 58px !important;
        max-height: 58px !important;
    }

    .hero {
        background:
            linear-gradient(0deg, rgba(13, 13, 15, .92), rgba(13, 13, 15, .70)),
            url("/images/site/hero-court.jpg") center / cover no-repeat !important;
    }

    .court-slide::before {
        background: linear-gradient(0deg, rgba(0, 0, 0, .92), rgba(255, 79, 163, .20)) !important;
    }
    
}
/* GUARANTEED LOGO SIZE FIX */

header.navbar {
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
    padding: 12px 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    overflow: hidden !important;
}

.brand-logo {
    display: flex !important;
    align-items: center !important;
    width: 180px !important;
    max-width: 180px !important;
    height: 64px !important;
    max-height: 64px !important;
    overflow: hidden !important;
    flex: 0 0 180px !important;
    text-decoration: none !important;
}

.brand-logo-img {
    display: block !important;
    width: 180px !important;
    max-width: 180px !important;
    height: 64px !important;
    max-height: 64px !important;
    object-fit: contain !important;
    object-position: left center !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

header.navbar .nav-links {
    margin-left: auto !important;
}

@media (max-width: 768px) {
    header.navbar {
        height: auto !important;
        min-height: 82px !important;
        max-height: none !important;
        padding: 14px 22px !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 14px !important;
    }

    .brand-logo {
        width: 150px !important;
        max-width: 150px !important;
        height: 54px !important;
        max-height: 54px !important;
        flex: 0 0 auto !important;
    }

    .brand-logo-img {
        width: 150px !important;
        max-width: 150px !important;
        height: 54px !important;
        max-height: 54px !important;
    }
}
/* FINAL HEADER + LOGO FIX */

.site-navbar {
    height: 110px !important;
    min-height: 110px !important;
    max-height: 110px !important;
    padding: 18px 64px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    overflow: hidden !important;
    background: #0d0d0f !important;
}

.site-navbar .brand-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 210px !important;
    max-width: 210px !important;
    height: 74px !important;
    max-height: 74px !important;
    overflow: hidden !important;
    flex: 0 0 210px !important;
    text-decoration: none !important;
}

.site-navbar .brand-logo-img {
    display: block !important;
    width: 210px !important;
    max-width: 210px !important;
    height: 74px !important;
    max-height: 74px !important;
    object-fit: contain !important;
    object-position: left center !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
}

.site-navbar .nav-links {
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
}

@media (max-width: 768px) {
    .site-navbar {
        height: auto !important;
        min-height: 120px !important;
        max-height: none !important;
        padding: 18px 22px !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 16px !important;
    }

    .site-navbar .brand-logo {
        width: 170px !important;
        max-width: 170px !important;
        height: 62px !important;
        max-height: 62px !important;
        flex: 0 0 auto !important;
    }

    .site-navbar .brand-logo-img {
        width: 170px !important;
        max-width: 170px !important;
        height: 62px !important;
        max-height: 62px !important;
    }

    .site-navbar .nav-links {
        flex-wrap: wrap !important;
        gap: 14px !important;
        margin-left: 0 !important;
    }
}
/* HERO RIGHT-SIDE LOGO */

.hero {
    position: relative !important;
    overflow: hidden !important;
}

.hero-inner {
    position: relative !important;
    z-index: 2 !important;
}

.hero-side-logo {
    position: absolute !important;
    right: 8% !important;
    top: 26% !important;
    width: 330px !important;
    max-width: 28vw !important;
    height: auto !important;
    object-fit: contain !important;
    z-index: 2 !important;
    opacity: .92 !important;
    filter: drop-shadow(0 18px 40px rgba(0, 0, 0, .35)) !important;
    pointer-events: none !important;
}

@media (max-width: 1024px) {
    .hero-side-logo {
        width: 260px !important;
        right: 5% !important;
        top: 30% !important;
        opacity: .75 !important;
    }
}

@media (max-width: 768px) {
    .hero-side-logo {
        display: none !important;
    }
}
/* ===== Bigger top-left header logo ===== */
.brand-logo-img {
    width: 120px !important;
    max-width: none !important;
    height: auto !important;
    display: block !important;
}

.logo-with-image,
.brand-logo {
    display: flex !important;
    align-items: center !important;
}

/* ===== Bigger hero right-side logo ===== */
.hero-side-logo {
    position: absolute !important;
    right: 7% !important;
    top: 20% !important;   /* higher */
    width: 600px !important; /* bigger */
    max-width: 22vw !important;
    height: auto !important;
    object-fit: contain !important;
    z-index: 2 !important;
    opacity: 0.95 !important;
    filter: drop-shadow(0 18px 40px rgba(0, 0, 0, 0.35)) !important;
    pointer-events: none !important;
}

/* Tablet */
@media (max-width: 1024px) {
    .brand-logo-img {
        width: 100px !important;
    }

    .hero-side-logo {
        width: 220px !important;
        right: 5% !important;
        top: 20% !important;
        max-width: 26vw !important;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .brand-logo-img {
        width: 88px !important;
    }

    .hero-side-logo {
        display: none !important;
    }
}
/* FINAL HERO LOGO POSITIONING */

.site-navbar .brand-logo-img {
    width: 135px !important;
    max-width: 10005px !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
}

.hero {
    position: relative !important;
    overflow: hidden !important;
}

.hero-inner {
    position: relative !important;
    z-index: 3 !important;
}

.hero-side-logo {
    position: absolute !important;
    right: 1% !important;
    width: 480px !important;
    top: .5% !important;
    max-width: 600px !important;
    height: auto !important;
    object-fit: contain !important;
    z-index: 3 !important;
    opacity: .98 !important;
    filter: drop-shadow(0 16px 36px rgba(0, 0, 0, .35)) !important;
    pointer-events: none !important;
}

@media (max-width: 1100px) {
    .hero-side-logo {
        width: 260px !important;
        right: 6% !important;
        top: 28% !important;
    }
}

@media (max-width: 768px) {
    .site-navbar .brand-logo-img {
        width: 105px !important;
        max-width: 105px !important;
    }

    .hero-side-logo {
        display: none !important;
    }
}
/* FINAL CAFE COMING SOON DESKTOP FIX */

.cafe-coming-soon {
    background:
        radial-gradient(circle at 12% 8%, rgba(255, 79, 163, .16), transparent 30%),
        #fff !important;
    padding: 90px 48px !important;
}

.cafe-coming-soon .container {
    max-width: 1100px !important;
    margin: 0 auto !important;
}

.cafe-coming-soon .coming-soon-card {
    width: 100% !important;
    min-height: 390px !important;
    padding: 64px !important;
    border-radius: 34px !important;
    background:
        linear-gradient(135deg, rgba(13, 13, 15, .94), rgba(43, 16, 32, .92)) !important;
    color: #fff !important;
    border: 1px solid rgba(255, 79, 163, .28) !important;
    box-shadow: 0 28px 80px rgba(255, 79, 163, .16) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    position: relative !important;
    overflow: hidden !important;
}

.cafe-coming-soon .coming-soon-card::after {
    content: "SOON" !important;
    position: absolute !important;
    right: -22px !important;
    bottom: -28px !important;
    font-size: clamp(90px, 18vw, 210px) !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    color: rgba(255, 255, 255, .06) !important;
    pointer-events: none !important;
}

.cafe-coming-soon .eyebrow,
.cafe-coming-soon .eyebrow.dark {
    color: #ff4fa3 !important;
    text-transform: uppercase !important;
    letter-spacing: .18em !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    margin-bottom: 18px !important;
}

.cafe-coming-soon .section-title {
    color: #fff !important;
    font-size: clamp(42px, 7vw, 82px) !important;
    line-height: .95 !important;
    max-width: 780px !important;
    margin: 0 0 20px !important;
}

.cafe-coming-soon .section-subtitle {
    color: #f7edf4 !important;
    max-width: 760px !important;
    font-size: 18px !important;
    line-height: 1.7 !important;
    margin: 0 0 30px !important;
}

.cafe-coming-soon .coming-soon-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    position: relative !important;
    z-index: 2 !important;
}

.cafe-coming-soon .coming-soon-badges span {
    display: inline-flex !important;
    align-items: center !important;
    border: 1px solid rgba(255, 255, 255, .28) !important;
    background: rgba(255, 79, 163, .18) !important;
    color: #ffd1e8 !important;
    padding: 10px 14px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .12em !important;
}

@media (max-width: 768px) {
    .cafe-coming-soon {
        padding: 56px 22px !important;
    }

    .cafe-coming-soon .coming-soon-card {
        padding: 34px 24px !important;
        border-radius: 24px !important;
        min-height: 320px !important;
    }

    .cafe-coming-soon .section-subtitle {
        font-size: 16px !important;
    }
    
}
/* CENTER RESERVATION SCREEN */

.form-page {
    min-height: calc(100vh - 90px) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    padding: 56px 24px !important;
    background:
        radial-gradient(circle at 10% 10%, rgba(255, 79, 163, .12), transparent 28%),
        #f7f4f6 !important;
}

.form-card,
.success-card {
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto !important;
}

/* Optional: center it vertically on taller desktop screens */
@media (min-width: 1000px) {
    .form-page {
        align-items: center !important;
    }
}

/* Mobile */
@media (max-width: 600px) {
    .form-page {
        padding: 28px 14px !important;
        align-items: flex-start !important;
    }

    .form-card,
    .success-card {
        border-radius: 18px !important;
        padding: 24px !important;
    }
}
/* FIX RESERVATION PAGE CENTERING */

.form-page {
    min-height: 100vh !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;
    padding: 48px 24px !important;
    background:
        radial-gradient(circle at 10% 10%, rgba(255, 79, 163, .12), transparent 28%),
        #f7f4f6 !important;
}

.form-page .form-link {
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto 24px !important;
    display: block !important;
    align-self: center !important;
}

.form-page .form-card,
.form-page .success-card {
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto !important;
}

/* Keep long forms from being vertically centered/cut off */
@media (min-width: 1000px) {
    .form-page {
        justify-content: flex-start !important;
        align-items: center !important;
    }
}

@media (max-width: 600px) {
    .form-page {
        padding: 28px 14px !important;
    }

    .form-page .form-card,
    .form-page .success-card {
        padding: 24px !important;
        border-radius: 18px !important;
    }
}

/* REPLAY CLIENT REVISIONS 2026-06-19 */

/* Revision 1 + 2: court-photo hero with cleaner copy */
.hero {
    min-height: 620px !important;
    display: flex !important;
    align-items: center !important;
    background:
        linear-gradient(90deg, rgba(8, 8, 10, .90) 0%, rgba(8, 8, 10, .68) 48%, rgba(255, 79, 163, .18) 100%),
        url("/images/site/IMG_8452.jpg") center center / cover no-repeat !important;
}

.hero .eyebrow {
    color: #ffd1e8 !important;
    text-transform: none !important;
    letter-spacing: .08em !important;
    font-size: clamp(15px, 2vw, 20px) !important;
    font-weight: 900 !important;
}

.hero h1 {
    max-width: 980px !important;
    font-size: clamp(54px, 9vw, 118px) !important;
    line-height: .90 !important;
    letter-spacing: -.06em !important;
    text-shadow: 0 18px 45px rgba(0, 0, 0, .45) !important;
}

.hero p {
    max-width: 900px !important;
    font-size: clamp(20px, 2.4vw, 30px) !important;
    color: #ffffff !important;
    text-shadow: 0 10px 28px rgba(0, 0, 0, .55) !important;
}

.hero-side-logo {
    display: none !important;
}

/* Revision 3: balance the two number cards with The Replay Lounge card */
.stats-section {
    padding-top: 42px !important;
}

.stats-grid {
    align-items: stretch !important;
}

.stat-card {
    justify-content: space-between !important;
    min-height: 190px !important;
}

.stat-card.stat-number h3 {
    font-size: clamp(82px, 11vw, 130px) !important;
    letter-spacing: -.06em !important;
    line-height: .78 !important;
    margin-bottom: 18px !important;
}

.stat-card.stat-lounge h3 {
    font-size: clamp(38px, 4.8vw, 58px) !important;
    line-height: .92 !important;
    letter-spacing: -.04em !important;
}

.stat-card p {
    font-size: 14px !important;
    line-height: 1.35 !important;
    letter-spacing: .16em !important;
    color: #ffe4f2 !important;
}

/* Revision 4: one-line showcase headline and highlighted peso price */
.showcase-heading {
    max-width: 100% !important;
}

.showcase-heading h2 {
    white-space: nowrap !important;
    font-size: clamp(40px, 7.4vw, 88px) !important;
}

.package-price {
    display: inline-flex !important;
    align-items: center !important;
    width: max-content !important;
    margin-top: 14px !important;
    padding: 10px 18px !important;
    border-radius: 999px !important;
    background: #ff4fa3 !important;
    color: #ffffff !important;
    font-size: clamp(22px, 3vw, 38px) !important;
    line-height: 1 !important;
    letter-spacing: -.02em !important;
    box-shadow: 0 16px 36px rgba(255, 79, 163, .35) !important;
}

.court-slide-content h3 {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 2px !important;
}

/* Revision 6: separate and highlight Booking Notes / House Rules */
.booking-notes-section {
    background:
        radial-gradient(circle at 85% 15%, rgba(255, 79, 163, .24), transparent 32%),
        linear-gradient(135deg, #08080a 0%, #17171b 52%, #2b1020 100%) !important;
    padding: 90px 48px !important;
}

.booking-notes-section .container {
    max-width: 1180px !important;
}

.rules-layout {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 28px !important;
    align-items: start !important;
}

.rules-panel {
    border: 1px solid rgba(255, 79, 163, .32) !important;
    border-radius: 30px !important;
    padding: 34px !important;
    background: rgba(255, 255, 255, .055) !important;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .28) !important;
    backdrop-filter: blur(8px) !important;
}

.booking-notes-panel {
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 79, 163, .20), transparent 28%),
        rgba(255, 255, 255, .07) !important;
}

.rules-panel .eyebrow,
.rules-panel .eyebrow.dark {
    color: #ff7fbd !important;
    margin-bottom: 12px !important;
}

.rules-panel .section-title {
    color: #ffffff !important;
    font-size: clamp(34px, 4vw, 54px) !important;
    line-height: .95 !important;
}

.rules-panel .section-subtitle {
    color: #f7ddea !important;
    margin-bottom: 22px !important;
}

.rules-panel .rules-list {
    max-width: none !important;
    gap: 12px !important;
}

.rules-panel .rule-item {
    background: rgba(8, 8, 10, .64) !important;
    border-color: rgba(255, 79, 163, .25) !important;
    color: #fff !important;
    padding: 15px 17px !important;
}

/* Revision 7: footer hours update display */
.footer p {
    color: #f1e7ee !important;
}

@media (max-width: 900px) {
    .rules-layout {
        grid-template-columns: 1fr !important;
    }

    .hero {
        min-height: 560px !important;
    }

    .showcase-heading h2 {
        white-space: normal !important;
    }
}

@media (max-width: 600px) {
    .hero h1 {
        font-size: 50px !important;
    }

    .hero p {
        font-size: 18px !important;
    }

    .stat-card.stat-number h3 {
        font-size: 86px !important;
    }

    .package-price {
        font-size: 24px !important;
    }

    .rules-panel {
        padding: 24px !important;
        border-radius: 22px !important;
    }
}

/* COURT-FOCUSED IMAGE UPDATE */

.hero {
    background:
        linear-gradient(90deg, rgba(13, 13, 15, .90), rgba(13, 13, 15, .68), rgba(255, 79, 163, .14)),
        url("/images/site/image-hero.png") center / cover no-repeat !important;
}

.court-slide-main {
    background-image: url("/images/site/carousel-private.jpg") !important;
}

.court-slide-event {
    background-image: url("/images/site/replay-court-ready.jpg") !important;
}

.court-slide-cafe {
    background-image: url("/images/site/replay-court-training.jpg") !important;
}

.cafe-coming-soon .coming-soon-card {
    background:
        linear-gradient(135deg, rgba(13, 13, 15, .92), rgba(43, 16, 32, .84)),
        url("/images/site/replay-court-lounge.jpg") center / cover no-repeat !important;
}

.service-gallery {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 18px !important;
    margin-top: 46px !important;
}

.service-gallery-card {
    position: relative !important;
    min-height: 290px !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    background: #0d0d0f !important;
    box-shadow: 0 22px 55px rgba(18, 18, 24, .14) !important;
}

.service-gallery-card.service-gallery-wide {
    grid-column: span 2 !important;
}

.service-gallery-card img {
    width: 100% !important;
    height: 100% !important;
    min-height: 290px !important;
    object-fit: cover !important;
    display: block !important;
    transform: scale(1.02) !important;
}

.service-gallery-card::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
        linear-gradient(0deg, rgba(0, 0, 0, .78), rgba(0, 0, 0, .14) 58%, rgba(255, 79, 163, .08)) !important;
    z-index: 1 !important;
}

.service-gallery-card > div {
    position: absolute !important;
    left: 22px !important;
    right: 22px !important;
    bottom: 22px !important;
    z-index: 2 !important;
    color: #fff !important;
}

.service-gallery-card span {
    display: inline-flex !important;
    margin-bottom: 10px !important;
    color: #ffd1e8 !important;
    background: rgba(255, 79, 163, .22) !important;
    border: 1px solid rgba(255, 255, 255, .26) !important;
    border-radius: 999px !important;
    padding: 7px 11px !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
}

.service-gallery-card h3 {
    color: #fff !important;
    font-size: clamp(24px, 3vw, 38px) !important;
    line-height: 1 !important;
    margin: 0 !important;
    max-width: 560px !important;
}

@media (max-width: 992px) {
    .service-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .service-gallery-card.service-gallery-wide {
        grid-column: span 2 !important;
    }
}

@media (max-width: 600px) {
    .hero {
        background:
            linear-gradient(0deg, rgba(13, 13, 15, .92), rgba(13, 13, 15, .62)),
            url("/images/site/image-hero.png") center / cover no-repeat !important;
    }

    .service-gallery {
        grid-template-columns: 1fr !important;
    }

    .service-gallery-card,
    .service-gallery-card.service-gallery-wide {
        grid-column: span 1 !important;
    }
}

/* EVENTS AND PARTIES CAROUSEL */

.service-carousel {
    --events-carousel-height: 520px;
    margin-top: 46px !important;
    height: var(--events-carousel-height) !important;
    border-radius: 34px !important;
    overflow: hidden !important;
    background: #0d0d0f !important;
    box-shadow: 0 26px 65px rgba(18, 18, 24, .18) !important;
}

.service-carousel .carousel-inner,
.service-carousel .carousel-item {
    height: 100% !important;
    border-radius: 34px !important;
    overflow: hidden !important;
}

.service-carousel .service-carousel-card {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.service-carousel .service-carousel-card img {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    object-fit: cover !important;
    object-position: center !important;
}

.service-carousel .service-carousel-card::after {
    background:
        linear-gradient(90deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .34), rgba(255, 79, 163, .08)),
        linear-gradient(0deg, rgba(0, 0, 0, .78), transparent 58%) !important;
}

.service-carousel .service-carousel-card > div {
    left: clamp(24px, 6vw, 62px) !important;
    right: clamp(24px, 6vw, 62px) !important;
    bottom: clamp(34px, 7vw, 72px) !important;
}

.service-carousel .service-carousel-card h3 {
    font-size: clamp(34px, 6vw, 72px) !important;
    max-width: 700px !important;
}

.service-carousel .carousel-control-prev,
.service-carousel .carousel-control-next {
    width: 9% !important;
}

.service-carousel .carousel-indicators {
    margin-bottom: 22px !important;
}

.service-carousel .carousel-indicators button {
    width: 34px !important;
    height: 5px !important;
    border-radius: 999px !important;
    border: 0 !important;
}

@media (max-width: 992px) {
    .service-carousel {
        --events-carousel-height: 460px;
    }
}

@media (max-width: 768px) {
    .service-carousel {
        --events-carousel-height: 390px;
    }

    .service-carousel .carousel-control-prev,
    .service-carousel .carousel-control-next {
        width: 14% !important;
    }
}

@media (max-width: 480px) {
    .service-carousel {
        --events-carousel-height: 350px;
    }
}

/* Booking notes inside reservation calendar modal */
.modal-booking-notes {
    margin-bottom: 22px !important;
    padding: 22px 24px !important;
    border-radius: 24px !important;
    border: 1px solid rgba(255, 79, 163, .32) !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 79, 163, .20), transparent 28%),
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(255, 244, 250, .96)) !important;
    box-shadow: 0 18px 45px rgba(18, 18, 24, .10) !important;
}

.modal-booking-notes-heading {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    margin-bottom: 14px !important;
}

.modal-booking-notes-heading span {
    color: #ff4fa3 !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.modal-booking-notes-heading strong {
    color: #16161a !important;
    font-size: clamp(20px, 3vw, 28px) !important;
    line-height: 1.1 !important;
}

.modal-booking-notes ul {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px 18px !important;
    margin: 0 !important;
    padding-left: 18px !important;
}

.modal-booking-notes li {
    color: #3d3540 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
}

@media (max-width: 768px) {
    .modal-booking-notes {
        padding: 18px !important;
    }

    .modal-booking-notes ul {
        grid-template-columns: 1fr !important;
    }
}

/* House rules on successful reservation page */
.success-house-rules {
    width: 100% !important;
    margin: 24px 0 28px !important;
    padding: 22px 24px !important;
    border-radius: 24px !important;
    border: 1px solid rgba(255, 79, 163, .32) !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 79, 163, .18), transparent 30%),
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(255, 244, 250, .96)) !important;
    box-shadow: 0 18px 45px rgba(18, 18, 24, .10) !important;
}

.success-house-rules-heading {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    margin-bottom: 14px !important;
}

.success-house-rules-heading span {
    color: #ff4fa3 !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .16em !important;
    text-transform: uppercase !important;
}

.success-house-rules-heading strong {
    color: #16161a !important;
    font-size: clamp(20px, 3vw, 26px) !important;
    line-height: 1.1 !important;
}

.success-house-rules ul {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px 18px !important;
    margin: 0 !important;
    padding-left: 18px !important;
}

.success-house-rules li {
    color: #3d3540 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
}

@media (max-width: 768px) {
    .success-house-rules {
        padding: 18px !important;
    }

    .success-house-rules ul {
        grid-template-columns: 1fr !important;
    }
}



/* Final navbar logo + hero image update */
.site-navbar .brand-logo {
    width: 230px !important;
    max-width: 230px !important;
    height: 82px !important;
    max-height: 82px !important;
    flex: 0 0 230px !important;
}

.site-navbar .brand-logo-img {
    width: 210px !important;
    max-width: 210px !important;
    height: auto !important;
    max-height: 78px !important;
    object-fit: contain !important;
    object-position: left center !important;
    background: transparent !important;
}

.hero {
    background:
        linear-gradient(90deg, rgba(13, 13, 15, .92), rgba(13, 13, 15, .72), rgba(255, 143, 196, .18)),
        url("/images/site/image-hero.png") center / cover no-repeat !important;
}

@media (max-width: 768px) {
    .site-navbar .brand-logo {
        width: 170px !important;
        max-width: 170px !important;
        height: 64px !important;
        max-height: 64px !important;
        flex: 0 0 auto !important;
    }

    .site-navbar .brand-logo-img {
        width: 155px !important;
        max-width: 155px !important;
        max-height: 58px !important;
    }

    .hero {
        background:
            linear-gradient(0deg, rgba(13, 13, 15, .92), rgba(13, 13, 15, .72)),
            url("/images/site/image-hero.png") center / cover no-repeat !important;
    }
}
