.hotels-index-hero-section {
    background:
        radial-gradient(circle at top left, rgba(214, 231, 226, 0.68), transparent 34%),
        linear-gradient(180deg, #f8f2e8 0%, #f7f9f7 48%, #ffffff 100%);
}

.hotels-index-hero-shell {
    overflow: hidden;
    border: 1px solid rgba(23, 49, 58, 0.08);
    border-radius: 2rem !important;
    background:
        radial-gradient(circle at top right, rgba(217, 111, 50, 0.16), transparent 30%),
        linear-gradient(135deg, #f5eee3 0%, #fffdf8 44%, #eef5f4 100%);
    box-shadow: 0 28px 64px rgba(15, 34, 30, 0.08);
}

.hotels-index-hero-copy {
    display: grid;
    gap: 0.9rem;
    text-align: left;
}

.hotels-index-hero-title {
    margin: 0;
    color: #17313a;
    font-size: clamp(2.2rem, 3.4vw, 3.8rem);
    font-weight: 800;
    line-height: 1.02;
    letter-spacing: -0.05em;
}

.hotels-index-hero-lead {
    color: #5f7278;
    font-size: clamp(1.06rem, 1.01rem + 0.24vw, 1.23rem);
    line-height: 1.8;
}

.hotels-index-listing-section {
    background:
        radial-gradient(circle at top left, rgba(230, 241, 238, 0.85), transparent 28%),
        linear-gradient(180deg, #f8fbfa 0%, #ffffff 100%);
}

.hotels-index-listing-shell {
    display: grid;
    grid-template-columns: minmax(17rem, 19rem) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
}

.hotels-index-listing-sidebar,
.hotels-index-listing-main {
    min-width: 0;
}

.hotels-index-pagination-row {
    grid-column: 1 / -1;
    padding-top: 2rem;
}

.hotels-index-listing-sidebar-stack {
    position: sticky;
    top: 1.5rem;
    display: grid;
    gap: 1rem;
}

.hotels-index-listing-card {
    padding: 1.4rem;
    border: 1px solid rgba(23, 49, 58, 0.08);
    border-radius: 1.6rem;
    background:
        radial-gradient(circle at top right, rgba(221, 238, 232, 0.74), transparent 34%),
        linear-gradient(180deg, #ffffff 0%, #f9fcfb 100%);
    box-shadow: 0 18px 42px rgba(23, 49, 58, 0.08);
}

.hotels-index-listing-card section,
.hotels-index-listing-main section {
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
}

.hotels-index-listing-card .container,
.hotels-index-listing-main .container {
    max-width: none;
    padding-right: 0;
    padding-left: 0;
}

.hotels-index-listing-card .text-center.text-muted.small.mb-2 {
    margin-bottom: 0.85rem !important;
    color: #4c666f !important;
    font-size: 0.84375rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-align: left !important;
    text-transform: uppercase;
}

.hotels-index-listing-card .d-flex.flex-wrap.gap-2.justify-content-center,
.hotels-index-listing-card .collapse .d-flex.flex-wrap.gap-2.justify-content-center {
    justify-content: flex-start !important;
    gap: 0.65rem !important;
}

.hotels-index-listing-card .btn,
.hotels-index-listing-card .badge {
    min-height: 2.45rem;
    border-radius: 999px;
    font-size: 0.84375rem;
    font-weight: 700;
    line-height: 1.2;
}

.hotels-index-listing-main .text-center.mb-5 {
    margin-bottom: 1.5rem !important;
    padding: 1.9rem 1.75rem 1.35rem;
    border: 1px solid rgba(23, 49, 58, 0.08);
    border-radius: 1.75rem;
    background:
        radial-gradient(circle at top right, rgba(221, 238, 232, 0.9), transparent 33%),
        linear-gradient(180deg, #ffffff 0%, #f7fbfa 100%);
    box-shadow: 0 18px 38px rgba(23, 49, 58, 0.08);
    text-align: left !important;
}

.hotels-index-listing-main h2 {
    color: #17313a;
    font-size: clamp(1.6rem, 1.35rem + 0.95vw, 2.3rem);
    letter-spacing: -0.04em;
    text-transform: none !important;
}

.hotels-index-listing-main .text-muted {
    color: #587078 !important;
    font-size: 1rem;
    line-height: 1.7;
}

.hotels-index-listing-main .hotel-list-grid {
    margin-top: 0.25rem;
    justify-content: flex-start !important;
}

.hotels-index-listing-main .hotel-list-card {
    border-color: rgba(23, 49, 58, 0.08);
    box-shadow: 0 16px 30px rgba(23, 49, 58, 0.06);
}

.hotels-index-listing-main .hotel-list-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 36px rgba(23, 49, 58, 0.1);
}

.hotels-index-listing-main .mt-5 {
    margin-top: 2rem !important;
}

@media (max-width: 1199.98px) {
    .hotels-index-listing-shell {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .hotels-index-listing-sidebar-stack {
        position: static;
    }
}

@media (max-width: 991.98px) {
    .hotels-index-listing-card {
        padding: 1.25rem;
    }

    .hotels-index-listing-main .text-center.mb-5 {
        padding: 1.6rem 1.35rem 1.15rem;
    }
}

@media (max-width: 767.98px) {
    .hotels-index-hero-shell {
        border-radius: 1.5rem !important;
        padding: 1.5rem !important;
    }

    .hotels-index-hero-title {
        font-size: 2.2rem;
        line-height: 1.03;
    }

    .hotels-index-hero-lead {
        font-size: 1rem;
        line-height: 1.72;
    }

    .hotels-index-listing-card {
        padding: 1rem;
        border-radius: 1.35rem;
    }

    .hotels-index-listing-main .text-center.mb-5 {
        padding: 1.35rem 1.1rem 1rem;
        border-radius: 1.35rem;
    }

    .hotels-index-listing-main .text-muted {
        font-size: 0.95rem;
        line-height: 1.65;
    }

    .hotels-index-pagination-row {
        padding-top: 1.4rem;
    }
}
