:root {
    --hotel-primary: #16724f;
    --hotel-primary-dark: #0f563a;
    --hotel-accent: #d39b45;
    --hotel-bg: #f6f8f5;
    --hotel-soft: #eef5ef;
    --hotel-surface: #ffffff;
    --hotel-border: #dfe7dd;
    --hotel-text: #122019;
    --hotel-muted: #66756d;
    --hotel-shadow: 0 24px 70px rgba(18, 32, 25, .14);
}

/* Luxury black glass theme memory: this project should stay dark, calm, image-led, and hotel-editorial. */
:root {
    --hotel-primary: #c6a15b;
    --hotel-primary-dark: #a78342;
    --hotel-accent: #e0c27a;
    --hotel-bg: #070807;
    --hotel-soft: #11130f;
    --hotel-surface: rgba(19, 20, 17, .72);
    --hotel-border: rgba(224, 194, 122, .18);
    --hotel-text: #f7f0df;
    --hotel-muted: #b8ad96;
    --hotel-shadow: 0 30px 90px rgba(0, 0, 0, .48);
    --hotel-glass: rgba(18, 19, 17, .64);
    --hotel-gold-soft: rgba(198, 161, 91, .16);
}

body {
    background:
        radial-gradient(circle at top left, rgba(198, 161, 91, .10), transparent 28rem),
        linear-gradient(180deg, #070807 0%, #10110e 54%, #070807 100%);
    color: var(--hotel-text);
}

.site-navbar {
    --bs-navbar-color: rgba(247, 240, 223, .70);
    --bs-navbar-hover-color: var(--hotel-accent);
    --bs-navbar-active-color: var(--hotel-accent);
    min-height: 76px;
    border-bottom: 1px solid rgba(224, 194, 122, .14);
    background: rgba(7, 8, 7, .72);
    backdrop-filter: blur(18px) saturate(150%);
}

.site-navbar .navbar-brand {
    color: var(--hotel-text);
}

.site-navbar .navbar-toggler {
    border-color: rgba(224, 194, 122, .22);
}

.site-navbar .navbar-toggler-icon {
    filter: invert(1) sepia(.2);
}

.site-navbar .btn-outline-secondary {
    --bs-btn-color: var(--hotel-text);
    --bs-btn-border-color: rgba(224, 194, 122, .30);
    --bs-btn-hover-bg: rgba(224, 194, 122, .12);
    --bs-btn-hover-border-color: rgba(224, 194, 122, .44);
}

footer {
    border-color: rgba(224, 194, 122, .14) !important;
    background: #070807;
}

footer .text-secondary,
.text-secondary {
    color: var(--hotel-muted) !important;
}

.btn-primary {
    --bs-btn-bg: linear-gradient(180deg, #d8b76b 0%, #b99045 100%);
    --bs-btn-border-color: #c6a15b;
    --bs-btn-color: #14110a;
    --bs-btn-hover-bg: #e0c27a;
    --bs-btn-hover-border-color: #e0c27a;
    --bs-btn-hover-color: #14110a;
    box-shadow: 0 16px 34px rgba(198, 161, 91, .18);
}

.btn-light,
.btn-outline-light {
    --bs-btn-color: var(--hotel-text);
    --bs-btn-bg: rgba(255, 255, 255, .08);
    --bs-btn-border-color: rgba(255, 255, 255, .22);
    --bs-btn-hover-bg: rgba(255, 255, 255, .14);
    --bs-btn-hover-border-color: rgba(224, 194, 122, .34);
    --bs-btn-hover-color: var(--hotel-text);
}

.property-hero {
    min-height: min(820px, calc(100vh - 76px));
    background: #050605;
}

.property-hero__shade {
    background:
        linear-gradient(90deg, rgba(5, 6, 5, .92) 0%, rgba(5, 6, 5, .58) 48%, rgba(5, 6, 5, .14) 100%),
        linear-gradient(180deg, rgba(5, 6, 5, .18) 0%, rgba(5, 6, 5, .52) 62%, rgba(5, 6, 5, .96) 100%);
}

.property-title-block h1 {
    color: #fff7e6;
    font-weight: 950;
    text-shadow: 0 20px 56px rgba(0, 0, 0, .64);
}

.property-title-block p {
    color: rgba(247, 240, 223, .82);
}

.property-quick-facts span,
.property-tabs a,
.content-section,
.booking-card,
.property-summary-bar,
.feedback-box,
.availability-strip div,
.amenity-grid span,
.auth-panel,
.stat-box,
.profile-avatar {
    border-color: var(--hotel-border);
    background: var(--hotel-glass);
    color: var(--hotel-text);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .28);
    backdrop-filter: blur(16px);
}

.property-summary-bar {
    gap: 1px;
    background: rgba(224, 194, 122, .12);
}

.property-summary-bar div {
    background: rgba(18, 19, 17, .78);
}

.property-summary-bar span,
.content-section p,
.booking-price span,
.booking-price small,
.booking-note,
.feedback-box footer,
.profile-list span {
    color: var(--hotel-muted);
}

.property-summary-bar strong,
.section-heading h2,
.booking-price strong,
.availability-strip span,
.booking-card__label,
.profile-list strong {
    color: var(--hotel-text);
}

.gallery-grid {
    border: 1px solid var(--hotel-border);
    background: rgba(18, 19, 17, .78);
    box-shadow: var(--hotel-shadow);
}

.gallery-grid img {
    filter: saturate(.92) contrast(1.05);
}

.gallery-more,
.rating-line {
    background: rgba(7, 8, 7, .78);
    color: var(--hotel-accent);
    border: 1px solid rgba(224, 194, 122, .26);
}

.amenity-grid i,
.profile-avatar {
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.booking-card .form-control,
.booking-card .form-select,
.auth-form-card .form-control,
.form-control,
.form-select {
    border-color: rgba(224, 194, 122, .18);
    background-color: rgba(255, 255, 255, .08);
    color: var(--hotel-text);
}

.form-control::placeholder {
    color: rgba(247, 240, 223, .48);
}

.form-control:focus,
.form-select:focus {
    border-color: rgba(224, 194, 122, .42);
    background-color: rgba(255, 255, 255, .10);
    color: var(--hotel-text);
    box-shadow: 0 0 0 .2rem rgba(198, 161, 91, .12);
}

.auth-section,
.auth-section--login {
    background:
        radial-gradient(circle at top left, rgba(198, 161, 91, .12), transparent 30rem),
        linear-gradient(180deg, #070807 0%, #11130f 100%);
}

.auth-login-panel {
    background: rgba(18, 19, 17, .72);
    border-color: var(--hotel-border);
    box-shadow: var(--hotel-shadow);
}

.auth-mobile-card {
    background: rgba(12, 13, 11, .76);
    color: var(--hotel-text);
}

.auth-mobile-card__mark,
.auth-badge {
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.auth-mobile-card__head p,
.auth-mobile-card__footer,
.auth-divider,
.auth-form-card .form-label {
    color: var(--hotel-muted);
}

.auth-input-wrap {
    border-color: rgba(224, 194, 122, .18);
    background: rgba(255, 255, 255, .07);
}

.auth-input-wrap:focus-within {
    border-color: rgba(224, 194, 122, .42);
    box-shadow: 0 0 0 .24rem rgba(198, 161, 91, .12);
}

.auth-input-wrap i,
.auth-mobile-card__footer a {
    color: var(--hotel-accent);
}

.btn-google--stacked {
    border-color: rgba(224, 194, 122, .20);
    background: rgba(255, 255, 255, .08);
    color: var(--hotel-text);
}

.btn-google--stacked:hover {
    border-color: rgba(224, 194, 122, .40);
    background: rgba(255, 255, 255, .12);
}

.btn-google__content strong {
    color: var(--hotel-text);
}

.rooms-hero {
    padding: 6rem 0 3rem;
    background:
        linear-gradient(180deg, rgba(7, 8, 7, .36), #070807),
        url("https://images.unsplash.com/photo-1566073771259-6a8506099945?auto=format&fit=crop&w=1800&q=80") center / cover;
}

.rooms-hero .container {
    max-width: 1080px;
}

.section-kicker {
    display: block;
    color: var(--hotel-accent);
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin-bottom: .8rem;
}

.rooms-hero h1 {
    color: #fff7e6;
    font-size: clamp(2.4rem, 6vw, 5rem);
    font-weight: 950;
    line-height: 1;
    margin-bottom: .8rem;
}

.rooms-hero p {
    color: rgba(247, 240, 223, .78);
    max-width: 620px;
    font-size: 1.08rem;
    line-height: 1.8;
}

.rooms-catalog {
    padding-top: 2rem;
    padding-bottom: 4rem;
}

.room-search-panel {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
    gap: .75rem;
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(18, 19, 17, .72);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .28);
    backdrop-filter: blur(18px) saturate(150%);
    margin: -4.5rem 0 1.25rem;
    padding: .85rem;
    position: relative;
    z-index: 2;
}

.room-search-panel label {
    display: grid;
    gap: .25rem;
    min-width: 0;
}

.room-search-panel span {
    color: var(--hotel-muted);
    font-size: .82rem;
    font-weight: 800;
}

.room-search-panel input,
.room-search-panel select {
    min-height: 48px;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background: rgba(255, 255, 255, .07);
    color: #fff7e6;
    padding: .55rem .7rem;
}

.room-search-panel .btn {
    align-self: end;
    min-height: 48px;
    white-space: nowrap;
}

.room-search-alert {
    border-color: rgba(224, 194, 122, .22);
    background: rgba(224, 194, 122, .12);
    color: #fff3cd;
}

.room-card-grid {
    display: grid;
    gap: 1.25rem;
}

.room-card {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(0, 1fr);
    overflow: hidden;
    border: 1px solid var(--hotel-border);
    border-radius: 8px;
    background: rgba(18, 19, 17, .74);
    box-shadow: var(--hotel-shadow);
}

.room-card img {
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: cover;
    filter: saturate(.9) contrast(1.06);
}

.room-card__content {
    display: grid;
    align-content: center;
    gap: 1rem;
    padding: 2rem;
}

.room-card__content span {
    color: var(--hotel-accent);
    font-size: .82rem;
    font-weight: 900;
    letter-spacing: .06em;
}

.room-card__content h2 {
    color: #fff7e6;
    font-size: clamp(1.7rem, 4vw, 3rem);
    font-weight: 950;
    line-height: 1.05;
    margin: .25rem 0 0;
}

.room-card__content p {
    color: var(--hotel-muted);
    line-height: 1.85;
    margin: 0;
}

.room-availability-pill {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    width: fit-content;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    color: rgba(247, 240, 223, .74);
    padding: .55rem .75rem;
}

.room-availability-pill.is-available {
    border-color: rgba(84, 214, 144, .28);
    color: #bdf7d5;
}

.room-availability-pill.is-available i {
    color: #63d89b;
}

.room-availability-pill.is-unavailable i {
    color: var(--hotel-accent);
}

.room-card__meta,
.room-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
}

.room-card__meta span {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem .75rem;
    border: 1px solid rgba(224, 194, 122, .18);
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    color: var(--hotel-text);
    letter-spacing: 0;
}

.admin-shell {
    color: var(--hotel-text);
}

.admin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.admin-panel {
    border: 1px solid var(--hotel-border);
    border-radius: 8px;
    background: var(--hotel-glass);
    box-shadow: var(--hotel-shadow);
    padding: 1.15rem;
    backdrop-filter: blur(16px);
}

.admin-panel--wide {
    grid-column: 1 / -1;
}

.admin-panel h2 {
    color: #fff7e6;
    font-size: 1.15rem;
    font-weight: 950;
    margin-bottom: .95rem;
}

.admin-form {
    display: grid;
    gap: .7rem;
    margin-bottom: 1rem;
}

.admin-form--inline {
    grid-template-columns: .75fr 1.1fr 1.4fr .7fr .9fr auto auto;
    align-items: center;
}

.admin-check {
    display: flex;
    align-items: center;
    gap: .45rem;
    color: var(--hotel-muted);
    margin: 0;
}

.admin-list {
    display: grid;
    gap: .55rem;
}

.admin-list--grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .7rem;
}

.admin-row > div {
    min-width: 0;
}

.admin-row strong,
.admin-row span {
    display: block;
}

.admin-row strong {
    color: var(--hotel-text);
    font-weight: 900;
}

.admin-row span {
    color: var(--hotel-muted);
    font-size: .86rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-row--image {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr) auto;
}

.admin-row--image img {
    width: 74px;
    height: 54px;
    object-fit: cover;
    border-radius: 8px;
}

@media (max-width: 991.98px) {
    .site-navbar {
        background: rgba(7, 8, 7, .90);
    }

    .room-search-panel {
        grid-template-columns: 1fr 1fr;
        margin-top: -2rem;
    }

    .room-search-panel .btn {
        grid-column: 1 / -1;
    }

    .room-card {
        grid-template-columns: 1fr;
    }

    .room-card img {
        min-height: 240px;
    }

    .admin-grid,
    .admin-list--grid {
        grid-template-columns: 1fr;
    }

    .admin-form--inline {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .room-search-panel {
        grid-template-columns: 1fr;
    }
}

/* Premium real-estate inspired landing */
.estate-label {
    display: inline-flex;
    align-items: center;
    color: var(--hotel-accent);
    font-size: .78rem;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.estate-hero {
    position: relative;
    min-height: calc(100vh - 76px);
    overflow: hidden;
    background: #050605;
}

.estate-hero__media,
.estate-hero__overlay {
    position: absolute;
    inset: 0;
}

.estate-hero__media {
    background-position: center;
    background-size: cover;
    transform: scale(1.02);
}

.estate-hero__overlay {
    background:
        radial-gradient(circle at 74% 34%, rgba(224, 194, 122, .18), transparent 19rem),
        linear-gradient(90deg, rgba(5, 6, 5, .96) 0%, rgba(5, 6, 5, .78) 46%, rgba(5, 6, 5, .36) 100%),
        linear-gradient(180deg, rgba(5, 6, 5, .2) 0%, #070807 100%);
}

.estate-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.06fr) minmax(340px, .58fr);
    gap: clamp(1.4rem, 4vw, 4rem);
    align-items: center;
    min-height: calc(100vh - 76px);
    padding-top: 4.5rem;
    padding-bottom: 4.5rem;
}

.estate-hero__copy h1,
.estate-section-head h2,
.estate-tour__copy h2,
.estate-contact h2 {
    color: #fff7e6;
    font-weight: 950;
    line-height: .98;
    letter-spacing: 0;
}

.estate-hero__copy h1 {
    max-width: 760px;
    font-size: clamp(2.55rem, 5.15vw, 4.65rem);
    line-height: 1.04;
    margin: .85rem 0 1rem;
}

.estate-hero__copy p {
    max-width: 640px;
    color: rgba(247, 240, 223, .78);
    font-size: 1.12rem;
    line-height: 1.85;
    margin: 0;
}

.estate-search-panel {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(300px, 1.15fr) minmax(156px, .68fr) auto;
    gap: .7rem;
    max-width: 1120px;
    border: 1px solid rgba(224, 194, 122, .18);
    border-radius: 8px;
    background: rgba(18, 19, 17, .66);
    box-shadow: 0 28px 84px rgba(0, 0, 0, .36);
    backdrop-filter: blur(20px) saturate(150%);
    margin: 2rem 0 1rem;
    padding: .72rem;
}

.estate-search-panel label {
    display: grid;
    gap: .18rem;
    min-width: 0;
    border-right: 1px solid rgba(224, 194, 122, .10);
    padding: .38rem .8rem;
}

.estate-search-panel label:nth-of-type(3) {
    border-right: 0;
}

.estate-search-panel span,
.estate-hero-card__body span,
.estate-card-meta,
.estate-agent-card span,
.estate-contact p,
.estate-tour__copy p {
    color: var(--hotel-muted);
}

.estate-search-panel strong {
    color: #fff7e6;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.estate-search-panel input,
.estate-search-panel select {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #fff7e6;
    font-weight: 850;
}

.estate-date-field {
    position: relative;
    cursor: pointer;
}

.estate-date-field input {
    padding-right: 1.95rem;
    padding-left: .25rem;
    cursor: pointer;
}

.estate-date-field i {
    position: absolute;
    top: 50%;
    right: .1rem;
    transform: translateY(-50%);
    color: var(--hotel-accent);
    font-size: 1.08rem;
    z-index: 2;
    pointer-events: none;
}

.estate-select-field {
    position: relative;
}

.estate-select-field i {
    position: absolute;
    top: 50%;
    left: .1rem;
    transform: translateY(-50%);
    color: var(--hotel-accent);
    font-size: 1.08rem;
    z-index: 2;
    pointer-events: none;
}

.estate-select-field select {
    appearance: auto;
    color-scheme: dark;
    padding-left: 1.95rem;
}

.estate-select-field select option {
    background: #121311;
    color: #fff7e6;
}

.estate-date-field input::-webkit-calendar-picker-indicator {
    cursor: pointer;
    opacity: .01;
}

.estate-date-summary {
    position: relative;
    min-height: 54px;
    padding-right: 2.9rem !important;
}

.estate-date-summary i {
    position: absolute;
    right: .9rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--hotel-accent);
    font-size: 1.16rem;
    pointer-events: none;
}

.estate-search-panel .btn {
    min-height: 54px;
    white-space: nowrap;
}

.estate-calendar-box {
    grid-column: 1 / -1;
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .035)),
        rgba(6, 8, 7, .66);
    padding: .95rem;
}

.estate-calendar-box__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: .75rem;
}

.estate-calendar-box__head > span {
    color: #fff7e6;
    font-weight: 900;
}

.estate-calendar-box__head div {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
}

.estate-calendar-box__head em {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    color: rgba(247, 240, 223, .74);
    font-style: normal;
    font-weight: 800;
    font-size: .86rem;
}

.estate-calendar-box__head em i {
    width: .72rem;
    height: .72rem;
    border-radius: 999px;
    background: #4fb06e;
    box-shadow: 0 0 0 3px rgba(79, 176, 110, .16);
}

.estate-calendar-box__head em:last-child i {
    background: #c94b4b;
    box-shadow: 0 0 0 3px rgba(201, 75, 75, .16);
}

.estate-calendar-input {
    position: absolute;
    width: 1px !important;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.estate-calendar-box small {
    display: block;
    color: rgba(247, 240, 223, .58);
    margin-top: .75rem;
}

.estate-calendar-box .flatpickr-calendar.inline {
    width: 100%;
    max-width: 100%;
    border: 0;
    border-radius: 8px;
    background: rgba(11, 12, 10, .74);
    box-shadow: inset 0 0 0 1px rgba(224, 194, 122, .12);
    padding: .75rem;
}

.estate-calendar-box .flatpickr-months,
.estate-calendar-box .flatpickr-weekdays,
.estate-calendar-box .flatpickr-days,
.estate-calendar-box .flatpickr-rContainer,
.estate-calendar-box .dayContainer {
    width: 100%;
    max-width: none;
    min-width: 0;
}

.estate-calendar-box .flatpickr-month,
.estate-calendar-box .flatpickr-current-month,
.estate-calendar-box .flatpickr-current-month input.cur-year,
.estate-calendar-box .flatpickr-weekday {
    color: #fff7e6;
}

.estate-calendar-box .flatpickr-current-month .flatpickr-monthDropdown-months,
.estate-calendar-box .flatpickr-current-month .flatpickr-monthDropdown-months option {
    background: #11120f;
    color: #fff7e6;
}

.estate-calendar-box .flatpickr-prev-month,
.estate-calendar-box .flatpickr-next-month {
    fill: var(--hotel-accent);
    color: var(--hotel-accent);
}

.estate-calendar-box .flatpickr-day {
    max-width: none;
    height: 42px;
    line-height: 42px;
    border-radius: 8px;
    color: rgba(247, 240, 223, .72);
    border-color: transparent;
    font-weight: 850;
}

.estate-calendar-box .flatpickr-day.prevMonthDay,
.estate-calendar-box .flatpickr-day.nextMonthDay {
    color: rgba(247, 240, 223, .25);
}

.estate-calendar-box .flatpickr-day.is-available {
    background: rgba(55, 143, 84, .26);
    border-color: rgba(91, 201, 128, .42);
    color: #dcffe8;
}

.estate-calendar-box .flatpickr-day.is-unavailable {
    background: rgba(185, 47, 47, .27);
    border-color: rgba(231, 92, 92, .48);
    color: #ffd5d5;
    text-decoration: line-through;
}

.estate-calendar-box .flatpickr-day.is-unavailable:hover {
    background: rgba(185, 47, 47, .38);
}

.estate-calendar-box .flatpickr-day.selected,
.estate-calendar-box .flatpickr-day.startRange,
.estate-calendar-box .flatpickr-day.endRange,
.estate-calendar-box .flatpickr-day.inRange {
    background: var(--hotel-accent);
    border-color: var(--hotel-accent);
    color: #090a08;
    box-shadow: none;
}

.estate-trust-row {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
}

.estate-trust-row span,
.estate-feature-list span,
.estate-contact-points span {
    display: inline-flex;
    align-items: center;
    gap: .48rem;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    color: rgba(247, 240, 223, .74);
    padding: .62rem .82rem;
}

.estate-trust-row i,
.estate-feature-list i,
.estate-contact-points i {
    color: var(--hotel-accent);
}

.estate-hero-card,
.estate-property-card,
.estate-tour__visual,
.estate-agent-card,
.estate-contact {
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(18, 19, 17, .68);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .38);
    backdrop-filter: blur(18px) saturate(150%);
}

.estate-hero-card {
    overflow: hidden;
}

.estate-hero-card__image {
    position: relative;
    aspect-ratio: 4 / 4.8;
    overflow: hidden;
}

.estate-hero-card__image img,
.estate-property-card img,
.estate-tour__visual > img,
.estate-agent-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.estate-play {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: 999px;
    background: rgba(7, 8, 7, .68);
    color: #fff7e6;
    text-decoration: none;
    padding: .55rem .8rem;
    backdrop-filter: blur(14px);
}

.estate-play i {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: linear-gradient(180deg, #d8b76b, #b99045);
    color: #14110a;
}

.estate-hero-card__body {
    padding: 1.15rem;
}

.estate-hero-card__body h2 {
    color: #fff7e6;
    font-size: 1.45rem;
    font-weight: 950;
    margin: .3rem 0 .85rem;
}

.estate-hero-card__body strong {
    color: var(--hotel-accent);
    font-size: 1.7rem;
}

.estate-hero-card__body small {
    color: var(--hotel-muted);
}

.estate-section {
    padding-top: 5rem;
    padding-bottom: 2rem;
}

.estate-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.estate-section-head h2,
.estate-tour__copy h2,
.estate-contact h2 {
    font-size: clamp(2rem, 4.5vw, 4.4rem);
    margin: .35rem 0 0;
}

.estate-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.estate-property-card {
    overflow: hidden;
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.estate-property-card:hover {
    border-color: rgba(224, 194, 122, .34);
    box-shadow: 0 34px 100px rgba(0, 0, 0, .48);
    transform: translateY(-4px);
}

.estate-property-card > img {
    aspect-ratio: 1.18 / 1;
    display: block;
    height: 270px;
    filter: saturate(.94) contrast(1.05);
    object-fit: cover;
}

.estate-property-card__body {
    padding: 1rem;
}

.estate-card-meta,
.estate-card-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}

.estate-card-meta {
    font-size: .82rem;
}

.estate-property-card h3 {
    color: #fff7e6;
    font-size: 1.28rem;
    font-weight: 950;
    margin: .65rem 0 .45rem;
}

.estate-property-card p {
    color: rgba(247, 240, 223, .66);
    line-height: 1.72;
    min-height: 4.9rem;
    margin: 0 0 1rem;
}

.estate-card-bottom strong {
    color: var(--hotel-accent);
    font-size: 1.25rem;
}

.estate-tour {
    margin-top: 3rem;
    padding: 5rem 0 6rem;
    background:
        radial-gradient(circle at top right, rgba(198, 161, 91, .12), transparent 28rem),
        linear-gradient(180deg, rgba(255, 255, 255, .025), rgba(255, 255, 255, 0));
}

.estate-tour__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
    gap: clamp(1.3rem, 4vw, 4rem);
    align-items: center;
}

.estate-tour__visual {
    position: relative;
    overflow: hidden;
}

.estate-tour__visual > img {
    aspect-ratio: 16 / 10;
    display: block;
}

.estate-tour__glass {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    display: grid;
    gap: .1rem;
    min-width: 250px;
    border: 1px solid rgba(224, 194, 122, .18);
    border-radius: 8px;
    background: rgba(7, 8, 7, .68);
    color: var(--hotel-text);
    padding: 1rem;
    backdrop-filter: blur(16px);
}

.estate-tour__glass i {
    color: var(--hotel-accent);
    font-size: 1.55rem;
}

.estate-tour__glass span {
    color: var(--hotel-muted);
}

.estate-tour__copy p,
.estate-contact p {
    line-height: 1.85;
}

.estate-feature-list,
.estate-contact-points {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-top: 1.2rem;
}

.estate-agent-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.estate-agent-card {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
}

.estate-agent-card img {
    aspect-ratio: 1;
    border-radius: 8px;
}

.estate-agent-card h3 {
    color: #fff7e6;
    font-size: 1.35rem;
    font-weight: 950;
    margin: .2rem 0 .15rem;
}

.estate-agent-card p {
    color: rgba(247, 240, 223, .68);
    line-height: 1.7;
    margin: .7rem 0 0;
}

.estate-contact-wrap {
    padding-top: 3rem;
    padding-bottom: 4rem;
}

.estate-contact {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1fr);
    gap: clamp(1.2rem, 4vw, 3rem);
    padding: clamp(1rem, 3vw, 2rem);
}

.estate-contact-form {
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: 1rem;
}

.estate-contact-form .form-label {
    color: rgba(247, 240, 223, .72);
    font-weight: 750;
}

@media (max-width: 1199.98px) {
    .estate-hero__inner {
        grid-template-columns: 1fr;
    }

    .estate-hero-card {
        max-width: 560px;
    }

    .estate-hero-card__image {
        aspect-ratio: 16 / 9;
    }

    .estate-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .estate-search-panel,
    .estate-tour__grid,
    .estate-contact {
        grid-template-columns: 1fr;
    }

    .estate-search-panel label {
        border-right: 0;
        border-bottom: 1px solid rgba(224, 194, 122, .10);
        padding: .55rem .35rem;
    }

    .estate-date-summary {
        padding-right: 2.6rem !important;
    }

    .estate-search-panel .btn {
        order: 5;
        width: 100%;
    }

    .estate-calendar-box {
        order: 4;
    }

    .estate-agent-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .estate-hero {
        min-height: auto;
    }

    .estate-hero__inner {
        min-height: auto;
        padding-top: 3rem;
        padding-bottom: 2.2rem;
    }

    .estate-hero__copy h1 {
        font-size: clamp(2.08rem, 11.2vw, 3.08rem);
        line-height: 1.08;
    }

    .estate-hero__copy p {
        font-size: 1rem;
    }

    .estate-search-panel {
        margin-top: 1.25rem;
        padding: .85rem;
    }

    .estate-calendar-box {
        padding: .7rem;
    }

    .estate-calendar-box__head {
        align-items: flex-start;
        flex-direction: column;
        gap: .55rem;
    }

    .estate-calendar-box .flatpickr-calendar.inline {
        padding: .5rem;
    }

    .estate-calendar-box .flatpickr-day {
        height: 38px;
        line-height: 38px;
        font-size: .88rem;
    }

    .estate-trust-row span,
    .estate-feature-list span,
    .estate-contact-points span {
        width: 100%;
        border-radius: 8px;
    }

    .estate-card-grid {
        grid-template-columns: 1fr;
    }

    .estate-property-card > img {
        height: 230px;
    }

    .estate-section,
    .estate-tour {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }

    .estate-section-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .estate-tour__glass {
        position: static;
        min-width: 0;
        border-width: 1px 0 0;
        border-radius: 0;
    }

    .estate-agent-card {
        grid-template-columns: 96px minmax(0, 1fr);
    }
}

/* Checkout */
.checkout-page {
    min-height: calc(100vh - 76px);
    padding: clamp(2rem, 5vw, 4.5rem) 0;
    background:
        radial-gradient(circle at 16% 12%, rgba(198, 161, 91, .12), transparent 24rem),
        radial-gradient(circle at 88% 22%, rgba(224, 194, 122, .08), transparent 26rem),
        linear-gradient(180deg, #080907 0%, #10110e 58%, #070807 100%);
}

.checkout-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.checkout-hero h1,
.checkout-panel__head h2,
.checkout-success-card h1 {
    color: #fff7e6;
    font-weight: 950;
    letter-spacing: 0;
}

.checkout-hero h1 {
    font-size: clamp(2.35rem, 6vw, 5rem);
    line-height: .98;
    margin: .4rem 0 .65rem;
}

.checkout-hero p {
    max-width: 620px;
    color: rgba(247, 240, 223, .72);
    margin: 0;
}

.checkout-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, .48fr);
    gap: 1rem;
    align-items: start;
}

.checkout-panel,
.checkout-summary,
.checkout-success-card {
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(18, 19, 17, .68);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .36);
    backdrop-filter: blur(18px) saturate(150%);
}

.checkout-panel {
    padding: clamp(1rem, 2.4vw, 1.5rem);
}

.checkout-panel__head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid rgba(224, 194, 122, .12);
    margin-bottom: 1rem;
    padding-bottom: 1rem;
}

.checkout-panel__head h2 {
    font-size: clamp(1.55rem, 3vw, 2.7rem);
    margin: .25rem 0 0;
}

.checkout-panel__head > i,
.checkout-success-card__icon {
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: rgba(198, 161, 91, .14);
    color: var(--hotel-accent);
}

.checkout-panel__head > i {
    width: 54px;
    height: 54px;
    border: 1px solid rgba(224, 194, 122, .16);
}

.checkout-form .form-label {
    color: rgba(247, 240, 223, .74);
    font-weight: 780;
}

.checkout-static-field {
    display: flex;
    align-items: center;
    min-height: 46px;
    border: 1px solid rgba(224, 194, 122, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
    color: #fff7e6;
    font-weight: 900;
    padding: .55rem .75rem;
}

.checkout-static-field.is-danger {
    border-color: rgba(220, 53, 69, .42);
    color: #ffb4a8;
}

.checkout-addons {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
}

.checkout-addons label {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    color: var(--hotel-text);
    cursor: pointer;
    padding: .75rem;
}

.checkout-addons input {
    margin-top: .25rem;
}

.checkout-addons strong,
.checkout-addons small {
    display: block;
}

.checkout-addons small {
    color: var(--hotel-muted);
    margin-top: .1rem;
}

.checkout-summary {
    position: sticky;
    top: 96px;
    overflow: hidden;
}

.checkout-summary > img {
    width: 100%;
    height: 260px;
    display: block;
    object-fit: cover;
}

.checkout-summary__body {
    padding: 1rem;
}

.checkout-summary__body > span,
.checkout-summary__body p,
.checkout-note,
.checkout-price-list span,
.checkout-daily span,
.checkout-total span {
    color: var(--hotel-muted);
}

.checkout-summary__body h2 {
    color: #fff7e6;
    font-size: 1.45rem;
    font-weight: 950;
    margin: .25rem 0 .45rem;
}

.checkout-summary__body p {
    line-height: 1.7;
}

.checkout-price-list,
.checkout-daily {
    display: grid;
    gap: .55rem;
    border-top: 1px solid rgba(224, 194, 122, .10);
    margin-top: 1rem;
    padding-top: 1rem;
}

.checkout-price-list div,
.checkout-daily div,
.checkout-total {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
}

.checkout-price-list strong,
.checkout-daily strong,
.checkout-total strong {
    color: #fff7e6;
}

.checkout-total {
    align-items: center;
    border-top: 1px solid rgba(224, 194, 122, .14);
    margin-top: 1rem;
    padding-top: 1rem;
}

.checkout-total strong {
    color: var(--hotel-accent);
    font-size: 1.75rem;
}

.checkout-note {
    display: block;
    margin-top: .75rem;
}

.checkout-success-page {
    display: grid;
    align-items: center;
}

.checkout-success-card {
    max-width: 980px;
    margin: 0 auto;
    padding: clamp(1rem, 3vw, 2rem);
    text-align: center;
}

.checkout-success-card__icon {
    width: 84px;
    height: 84px;
    border-radius: 999px;
    margin: 0 auto 1rem;
    font-size: 2.2rem;
}

.checkout-success-card h1 {
    font-size: clamp(2rem, 5vw, 4rem);
    margin: .35rem 0 .5rem;
}

.checkout-success-card p {
    color: var(--hotel-muted);
    margin: 0 auto 1rem;
    max-width: 640px;
}

.checkout-success-detail {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .65rem;
    margin: 1rem 0;
    text-align: left;
}

.checkout-success-detail div,
.checkout-success-room {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .85rem;
}

.checkout-success-detail dt {
    color: var(--hotel-muted);
    font-size: .82rem;
}

.checkout-success-detail dd {
    color: #fff7e6;
    font-weight: 900;
    margin: .25rem 0 0;
}

.checkout-success-room {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    color: var(--hotel-text);
    margin-top: .75rem;
}

.checkout-success-room i,
.checkout-success-room strong {
    color: var(--hotel-accent);
}

.checkout-success-actions {
    display: flex;
    justify-content: center;
    gap: .65rem;
    margin-top: 1rem;
}

.payment-grid {
    display: grid;
    grid-template-columns: minmax(320px, .42fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.payment-card {
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(18, 19, 17, .68);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .36);
    backdrop-filter: blur(18px) saturate(150%);
    padding: clamp(1rem, 2.4vw, 1.5rem);
}

.payment-time-alert {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    border: 1px solid rgba(224, 194, 122, .24);
    border-radius: 8px;
    background: rgba(198, 161, 91, .12);
    color: rgba(247, 240, 223, .82);
    margin-bottom: 1rem;
    padding: .95rem 1rem;
}

.payment-time-alert i {
    color: var(--hotel-accent);
    font-size: 1.45rem;
}

.payment-time-alert strong,
.payment-time-alert span {
    display: block;
}

.payment-time-alert strong {
    color: #fff7e6;
}

.payment-time-alert b {
    color: var(--hotel-accent);
    font-weight: 950;
}

.payment-time-alert.is-expired {
    border-color: rgba(220, 53, 69, .32);
    background: rgba(220, 53, 69, .12);
}

.payment-time-alert.is-expired i {
    color: #ffb4a8;
}

.payment-card--qr {
    display: grid;
    justify-items: center;
    gap: .8rem;
    text-align: center;
}

.payment-qr-frame {
    width: min(100%, 310px);
    border: 1px solid rgba(224, 194, 122, .18);
    border-radius: 8px;
    background: #fff;
    padding: .75rem;
}

.payment-qr-frame img {
    display: block;
    width: 100%;
    aspect-ratio: 1;
    object-fit: contain;
}

.payment-qr-placeholder {
    display: grid;
    place-items: center;
    gap: .35rem;
    aspect-ratio: 1;
    background: rgba(255, 255, 255, .07);
    color: #14110a;
}

.payment-qr-placeholder i {
    color: var(--hotel-accent);
    font-size: 3rem;
}

.payment-qr-placeholder span {
    color: #fff7e6;
    font-weight: 900;
}

.payment-card--qr strong {
    color: var(--hotel-accent);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 950;
}

.payment-card--qr > span {
    color: var(--hotel-muted);
}

.payment-detail-list,
.payment-booking-box {
    display: grid;
    gap: .65rem;
}

.payment-detail-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0 0 1rem;
}

.payment-detail-list div,
.payment-booking-box {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .85rem;
}

.payment-detail-list dt,
.payment-booking-box span {
    color: var(--hotel-muted);
    font-size: .82rem;
}

.payment-detail-list dd,
.payment-booking-box strong,
.payment-booking-box h3 {
    color: #fff7e6;
}

.payment-detail-list dd {
    font-weight: 900;
    margin: .25rem 0 0;
    overflow-wrap: anywhere;
}

.payment-booking-box h3 {
    font-size: 1.25rem;
    font-weight: 950;
    margin: 0 0 .35rem;
}

.payment-booking-box div {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    border-top: 1px solid rgba(224, 194, 122, .10);
    padding-top: .6rem;
}

.payment-actions {
    justify-content: flex-start;
}

.checkout-promo-control {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .55rem;
}

.checkout-promo-message {
    display: block;
    color: var(--hotel-muted);
    margin-top: .45rem;
}

.checkout-promo-message.is-success {
    color: #187244;
    font-weight: 800;
}

.checkout-promo-message.is-error {
    color: #b42318;
    font-weight: 800;
}

.checkout-discount-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
    border-top: 1px solid rgba(30, 48, 86, .1);
    color: #187244;
    padding-top: .75rem;
}

.checkout-discount-line strong {
    font-weight: 950;
}

.payment-slip-box {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    margin-top: 1rem;
    padding: .95rem;
}

.payment-slip-box__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: .85rem;
}

.payment-slip-box__head p {
    color: var(--hotel-muted);
    margin: .25rem 0 0;
}

.payment-slip-box__head h3 {
    color: #fff7e6;
    font-size: 1.22rem;
    font-weight: 950;
    margin: .25rem 0 0;
}

.payment-slip-box__head > i {
    color: var(--hotel-accent);
    font-size: 1.4rem;
}

.payment-slip-box,
.payment-slip-form {
    display: grid;
    gap: .85rem;
}

.payment-slip-box {
    align-items: center;
    border: 1px solid rgba(224, 194, 122, .08);
    border-radius: 8px;
    background: rgba(0, 0, 0, .12);
    margin-bottom: .85rem;
    padding: .75rem;
}

.payment-slip-box span {
    color: var(--hotel-muted);
}

.payment-slip-uploader {
    align-items: stretch;
}

.payment-slip-current {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .75rem;
    border: 1px solid rgba(0, 117, 201, .16);
    border-radius: 8px;
    background: rgba(0, 117, 201, .08);
    padding: .75rem;
}

.payment-slip-current i {
    color: var(--hotel-primary);
    font-size: 1.2rem;
}

.payment-slip-locked {
    display: flex;
    align-items: center;
    gap: .65rem;
    border: 1px solid rgba(24, 114, 68, .16);
    border-radius: 8px;
    background: rgba(224, 247, 234, .86);
    color: #145c38;
    font-weight: 800;
    padding: .75rem;
}

.payment-slip-locked i {
    color: #187244;
}

.payment-slip-modal .modal-content {
    border: 1px solid rgba(0, 117, 201, .16);
    border-radius: 10px;
    background: var(--hotel-surface);
    box-shadow: 0 24px 70px rgba(3, 27, 56, .18);
    overflow: hidden;
}

.payment-slip-modal .modal-header {
    align-items: center;
    border-bottom: 1px solid rgba(12, 35, 64, .1);
    background: linear-gradient(180deg, rgba(255, 252, 245, .98), rgba(246, 241, 229, .92));
    padding: 1rem 1.15rem;
}

.payment-slip-modal .modal-title {
    color: var(--hotel-navy);
    font-size: 1.2rem;
    font-weight: 900;
    line-height: 1.2;
    margin: .15rem 0 0;
}

.payment-slip-modal .modal-body {
    background: #f7f4ec;
    padding: .75rem;
}

.payment-slip-modal iframe {
    display: block;
    width: 100%;
    min-height: min(76vh, 760px);
    border: 0;
    border-radius: 8px;
    background: #fff;
}

.payment-slip-drop {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: .85rem;
    border: 1px dashed rgba(0, 117, 201, .42);
    border-radius: 8px;
    background: rgba(0, 117, 201, .07);
    cursor: pointer;
    padding: 1rem;
}

.payment-slip-drop:hover {
    border-color: var(--hotel-primary);
    background: rgba(0, 117, 201, .1);
}

.payment-slip-drop > i {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: 8px;
    background: rgba(0, 117, 201, .12);
    color: var(--hotel-primary);
    font-size: 1.35rem;
}

.payment-slip-drop strong {
    display: block;
    color: var(--hotel-navy);
}

.payment-slip-drop small {
    color: var(--hotel-text-soft);
}

.payment-slip-drop input {
    grid-column: 1 / -1;
}

.payment-time-alert.is-success {
    border-color: rgba(24, 114, 68, .2);
    background: rgba(224, 247, 234, .92);
    color: #145c38;
}

@media (max-width: 991.98px) {
    .checkout-hero {
        align-items: flex-start;
        flex-direction: column;
    }

    .checkout-grid,
    .checkout-addons,
    .checkout-success-detail,
    .payment-grid,
    .payment-detail-list {
        grid-template-columns: 1fr;
    }

    .checkout-summary {
        position: static;
    }

    .checkout-promo-control {
        grid-template-columns: 1fr;
    }

    .payment-slip-current {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .payment-slip-modal .modal-content,
    .payment-slip-modal iframe {
        border-radius: 0;
    }

    .payment-slip-modal iframe {
        min-height: calc(100vh - 96px);
    }
}

@media (max-width: 767.98px) {
    .checkout-success-actions {
        display: grid;
    }
}

/* Member profile */
.profile-page {
    position: relative;
    min-height: calc(100vh - 76px);
    overflow: hidden;
    padding: clamp(2rem, 5vw, 5rem) 0 4rem;
    background:
        radial-gradient(circle at 18% 10%, rgba(198, 161, 91, .13), transparent 24rem),
        radial-gradient(circle at 88% 24%, rgba(224, 194, 122, .08), transparent 28rem),
        linear-gradient(180deg, #080907 0%, #10110e 52%, #070807 100%);
}

.profile-page::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(rgba(255, 255, 255, .018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .018) 1px, transparent 1px);
    background-size: 42px 42px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .9), transparent 72%);
}

.profile-page .container {
    position: relative;
    z-index: 1;
}

.profile-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.profile-hero__copy h1 {
    color: #fff7e6;
    font-size: clamp(2.35rem, 6vw, 5.2rem);
    font-weight: 950;
    line-height: .98;
    margin: .4rem 0 .65rem;
}

.profile-hero__copy p {
    max-width: 620px;
    color: rgba(247, 240, 223, .72);
    font-size: 1.04rem;
    line-height: 1.8;
    margin: 0;
}

.profile-status-card,
.profile-member-card,
.profile-panel,
.profile-mini-card {
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(18, 19, 17, .68);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .36);
    backdrop-filter: blur(18px) saturate(150%);
}

.profile-status-card {
    min-width: 260px;
    padding: 1rem;
}

.profile-status-card span,
.profile-detail-list dt,
.profile-mini-card span,
.profile-member-card p {
    color: var(--hotel-muted);
}

.profile-status-card strong {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: #fff7e6;
    font-size: 1.18rem;
    margin-top: .3rem;
}

.profile-status-card i {
    color: var(--hotel-accent);
}

.profile-grid {
    display: grid;
    grid-template-columns: minmax(300px, .38fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.profile-member-card {
    position: sticky;
    top: 100px;
    display: grid;
    gap: 1rem;
    padding: clamp(1rem, 2vw, 1.35rem);
}

.profile-avatar-xl {
    width: 86px;
    height: 86px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .26), rgba(255, 255, 255, .04)),
        linear-gradient(180deg, #d8b76b, #b99045);
    color: #14110a;
    box-shadow: 0 20px 44px rgba(198, 161, 91, .18);
    font-size: 2.1rem;
    font-weight: 950;
}

.profile-member-card h2 {
    color: #fff7e6;
    font-size: clamp(1.55rem, 3vw, 2.15rem);
    font-weight: 950;
    margin: 0 0 .25rem;
}

.profile-member-card p {
    overflow-wrap: anywhere;
    margin: 0;
}

.profile-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}

.profile-badges span {
    display: inline-flex;
    align-items: center;
    gap: .42rem;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    color: rgba(247, 240, 223, .78);
    padding: .55rem .72rem;
}

.profile-badges i,
.profile-panel__head i,
.profile-mini-card i {
    color: var(--hotel-accent);
}

.profile-actions {
    display: grid;
    gap: .65rem;
}

.profile-content {
    display: grid;
    gap: 1rem;
}

.profile-panel {
    padding: clamp(1rem, 2.5vw, 1.5rem);
}

.profile-panel__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid rgba(224, 194, 122, .12);
    margin-bottom: 1rem;
    padding-bottom: 1rem;
}

.profile-panel__head h2 {
    color: #fff7e6;
    font-size: clamp(1.65rem, 3.6vw, 3rem);
    font-weight: 950;
    margin: .25rem 0 0;
}

.profile-panel__head > i {
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    border: 1px solid rgba(224, 194, 122, .16);
    border-radius: 8px;
    background: rgba(198, 161, 91, .13);
    font-size: 1.35rem;
}

.profile-detail-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
    margin: 0;
}

.profile-detail-list div {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .9rem;
}

.profile-detail-list dt {
    font-size: .82rem;
    font-weight: 800;
    margin-bottom: .3rem;
}

.profile-detail-list dd {
    color: #fff7e6;
    font-size: 1.05rem;
    font-weight: 900;
    margin: 0;
    overflow-wrap: anywhere;
}

.profile-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.profile-mini-card {
    display: grid;
    gap: .42rem;
    padding: 1rem;
}

.profile-mini-card i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    background: rgba(198, 161, 91, .13);
}

.profile-mini-card strong {
    color: #fff7e6;
    font-size: 1.05rem;
}

.profile-mini-card span {
    line-height: 1.65;
}

.profile-booking-list {
    display: grid;
    gap: .65rem;
}

.profile-booking-list article {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .85rem;
}

.profile-booking-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
}

.profile-booking-card__actions {
    display: flex;
    gap: .55rem;
    justify-content: flex-end;
}

.profile-booking-list strong,
.profile-booking-list span,
.profile-booking-list em {
    display: block;
}

.profile-booking-list strong {
    color: #fff7e6;
}

.profile-booking-list span {
    color: var(--hotel-muted);
    margin-top: .2rem;
}

.profile-booking-list em {
    color: var(--hotel-accent);
    font-style: normal;
    font-weight: 850;
    text-align: right;
}

.booking-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .68fr);
    gap: 1rem;
    align-items: start;
}

.booking-detail-side {
    display: grid;
    gap: 1rem;
}

.booking-detail-stack {
    display: grid;
    gap: .65rem;
}

.booking-detail-row,
.booking-detail-note {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    padding: .85rem;
}

.booking-detail-row {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
}

.booking-detail-row span,
.booking-detail-note span {
    color: var(--hotel-muted);
}

.booking-detail-row strong,
.booking-detail-note p {
    color: #fff7e6;
}

.booking-detail-note p {
    margin: .45rem 0 0;
    line-height: 1.75;
}

.booking-detail-actions {
    margin-top: .85rem;
}

.payment-slip-box--stacked {
    margin-top: .85rem;
}

@media (max-width: 991.98px) {
    .profile-hero,
    .profile-grid,
    .booking-detail-grid {
        grid-template-columns: 1fr;
    }

    .profile-hero {
        align-items: stretch;
        flex-direction: column;
    }

    .profile-member-card {
        position: static;
    }

    .profile-mini-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .profile-page {
        padding-top: 1.5rem;
    }

    .profile-status-card {
        min-width: 0;
    }

    .profile-detail-list {
        grid-template-columns: 1fr;
    }

    .profile-panel__head {
        align-items: flex-start;
    }

    .profile-panel__head > i {
        display: none;
    }

    .profile-booking-list article {
        align-items: flex-start;
        flex-direction: column;
    }

    .profile-booking-card {
        grid-template-columns: 1fr;
    }

    .profile-booking-card__actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .profile-booking-list em {
        text-align: left;
    }
}

.admin-head-actions {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
}

.admin-breadcrumbs {
    display: flex;
    align-items: center;
    gap: .45rem;
    color: rgba(247, 240, 223, .54);
    font-size: .86rem;
    margin-bottom: .9rem;
}

.admin-breadcrumbs a {
    color: rgba(247, 240, 223, .7);
    text-decoration: none;
}

.admin-breadcrumbs a:hover {
    color: var(--hotel-accent);
}

.admin-resource-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.admin-resource-card {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) auto;
    gap: .95rem;
    align-items: start;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background: linear-gradient(145deg, rgba(18, 19, 17, .88), rgba(28, 27, 23, .66));
    box-shadow: 0 24px 70px rgba(0, 0, 0, .24);
    padding: 1rem;
}

.admin-resource-card__icon,
.admin-cell-title i,
.admin-delete-panel__icon,
.admin-edit-summary i {
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.admin-resource-card__icon {
    width: 54px;
    height: 54px;
    font-size: 1.35rem;
}

.admin-resource-card h2 {
    color: #fff7e6;
    font-size: 1.02rem;
    font-weight: 950;
    margin: 0 0 .25rem;
}

.admin-resource-card p {
    color: var(--hotel-muted);
    margin: 0;
}

.admin-resource-card > strong {
    color: #fff7e6;
    font-size: 1.7rem;
    line-height: 1;
}

.admin-resource-card__actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    gap: .55rem;
    border-top: 1px solid rgba(224, 194, 122, .10);
    padding-top: .85rem;
}

.admin-table-shell,
.admin-edit-shell,
.admin-delete-panel,
.admin-detail-shell {
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background: rgba(18, 19, 17, .78);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .24);
    backdrop-filter: blur(16px);
}

.admin-table-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border-bottom: 1px solid rgba(224, 194, 122, .12);
    padding: .9rem 1rem;
}

.admin-table-toolbar strong {
    color: #fff7e6;
    font-size: 1.35rem;
    margin-right: .25rem;
}

.admin-table-toolbar span {
    color: var(--hotel-muted);
}

.admin-table-responsive {
    overflow: auto;
}

.admin-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    min-width: 860px;
}

.admin-table th,
.admin-table td {
    border-bottom: 1px solid rgba(224, 194, 122, .09);
    padding: .82rem 1rem;
    vertical-align: middle;
}

.admin-table th {
    color: rgba(247, 240, 223, .58);
    font-size: .76rem;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
    background: rgba(255, 255, 255, .035);
}

.admin-table td {
    color: rgba(247, 240, 223, .76);
}

.admin-table tbody tr {
    transition: background .18s ease;
}

.admin-table tbody tr:hover {
    background: rgba(198, 161, 91, .07);
}

.admin-id {
    display: inline-flex;
    min-width: 48px;
    justify-content: center;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    color: var(--hotel-accent);
    padding: .25rem .45rem;
}

.admin-cell-title {
    display: flex;
    align-items: center;
    gap: .7rem;
    min-width: 0;
}

.admin-cell-title i,
.admin-cell-title img {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
}

.admin-cell-title img {
    border-radius: 8px;
    object-fit: cover;
}

.admin-cell-title strong {
    color: #fff7e6;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-row-actions {
    display: flex;
    gap: .45rem;
}

.admin-row-actions .btn {
    width: 38px;
    height: 38px;
    display: inline-grid;
    place-items: center;
    padding: 0;
}

.admin-empty-state {
    display: grid;
    place-items: center;
    min-height: 260px;
    color: var(--hotel-muted);
    text-align: center;
    padding: 2rem;
}

.admin-empty-state i {
    color: var(--hotel-accent);
    font-size: 2rem;
    margin-bottom: .65rem;
}

.admin-empty-state strong {
    color: #fff7e6;
    font-size: 1.12rem;
}

.admin-form-page {
    max-width: 1040px;
}

.admin-edit-shell {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
}

.admin-edit-summary {
    border-right: 1px solid rgba(224, 194, 122, .10);
    padding: .75rem 1rem .75rem .25rem;
}

.admin-edit-summary i {
    width: 58px;
    height: 58px;
    font-size: 1.45rem;
    margin-bottom: 1rem;
}

.admin-edit-summary strong,
.admin-edit-summary span {
    display: block;
}

.admin-edit-summary strong {
    color: #fff7e6;
    font-size: 1.12rem;
    margin-bottom: .25rem;
}

.admin-edit-summary span {
    color: var(--hotel-muted);
}

.admin-edit-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.admin-field {
    display: grid;
    gap: .4rem;
}

.admin-field span {
    color: rgba(247, 240, 223, .72);
    font-size: .88rem;
    font-weight: 750;
}

.admin-field--wide,
.admin-form-actions {
    grid-column: 1 / -1;
}

.admin-field--check {
    display: flex;
    align-items: center;
    align-self: end;
    min-height: 46px;
    gap: .55rem;
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    padding: .65rem .75rem;
}

.admin-edit-form .form-control,
.admin-edit-form .form-select {
    min-height: 46px;
    border-radius: 8px;
}

.admin-form-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: .65rem;
    border-top: 1px solid rgba(224, 194, 122, .10);
    margin-top: .4rem;
    padding-top: 1rem;
}

.admin-delete-panel {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 1rem;
    padding: 1.25rem;
}

.admin-delete-panel__icon {
    width: 72px;
    height: 72px;
    color: #ffb4a8;
    background: rgba(220, 53, 69, .14);
    font-size: 1.8rem;
}

.admin-delete-panel h1 {
    color: #fff7e6;
    font-size: 1.6rem;
    font-weight: 950;
    margin: .15rem 0 .35rem;
}

.admin-delete-panel p {
    color: var(--hotel-muted);
    margin: 0;
}

.admin-delete-detail,
.admin-delete-panel .admin-form-actions {
    grid-column: 1 / -1;
}

.admin-delete-detail {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
    margin: .75rem 0 0;
}

.admin-delete-detail div {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .035);
    padding: .75rem;
}

.admin-delete-detail dt {
    color: rgba(247, 240, 223, .52);
    font-size: .78rem;
    font-weight: 700;
}

.admin-delete-detail dd {
    color: #fff7e6;
    margin: .2rem 0 0;
}

.admin-detail-shell {
    padding: 1rem;
}

.admin-detail-hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    border-bottom: 1px solid rgba(224, 194, 122, .10);
    padding-bottom: 1rem;
    margin-bottom: 1rem;
}

.admin-detail-hero i,
.admin-detail-hero img {
    width: 72px;
    height: 72px;
    flex: 0 0 72px;
    border-radius: 8px;
}

.admin-detail-hero i {
    display: grid;
    place-items: center;
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
    font-size: 1.8rem;
}

.admin-detail-hero img {
    object-fit: cover;
}

.admin-detail-hero strong,
.admin-detail-hero span {
    display: block;
}

.admin-detail-hero strong {
    color: #fff7e6;
    font-size: 1.35rem;
    font-weight: 950;
}

.admin-detail-hero span {
    color: var(--hotel-muted);
}

.admin-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
    margin: 0;
}

.admin-detail-grid div {
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .035);
    padding: .75rem;
}

.admin-detail-grid__wide {
    grid-column: 1 / -1;
}

.admin-detail-grid dt {
    color: rgba(247, 240, 223, .52);
    font-size: .78rem;
    font-weight: 700;
}

.admin-detail-grid dd {
    color: #fff7e6;
    margin: .2rem 0 0;
    overflow-wrap: anywhere;
}

@media (max-width: 1199.98px) {
    .admin-resource-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .admin-resource-grid,
    .admin-edit-shell,
    .admin-edit-form,
    .admin-delete-detail,
    .admin-detail-grid {
        grid-template-columns: 1fr;
    }

    .admin-edit-summary {
        border-right: 0;
        border-bottom: 1px solid rgba(224, 194, 122, .10);
        padding: .25rem 0 1rem;
    }

    .admin-page-head {
        align-items: stretch;
    }

    .admin-head-actions,
    .admin-resource-card__actions,
    .admin-form-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    .site-navbar {
        min-height: 62px;
    }

    .property-hero {
        min-height: 76vh;
    }

    .mobile-price-bar {
        background: rgba(7, 8, 7, .88);
        border-color: var(--hotel-border);
    }

    .room-card__content {
        padding: 1.1rem;
    }

    .room-card__actions .btn {
        flex: 1 1 100%;
    }
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--hotel-bg);
    color: var(--hotel-text);
    font-family: "Noto Sans Thai", "Tahoma", system-ui, -apple-system, sans-serif;
    overflow-x: hidden;
}

.btn {
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0;
}

.btn-primary {
    --bs-btn-bg: var(--hotel-primary);
    --bs-btn-border-color: var(--hotel-primary);
    --bs-btn-hover-bg: var(--hotel-primary-dark);
    --bs-btn-hover-border-color: var(--hotel-primary-dark);
}

.navbar {
    --bs-navbar-color: var(--hotel-muted);
    --bs-navbar-hover-color: var(--hotel-primary);
    min-height: 68px;
    backdrop-filter: saturate(180%) blur(14px);
}

.navbar-brand {
    color: var(--hotel-text);
    font-weight: 900;
    letter-spacing: 0;
}

.quick-panel,
.auth-panel,
.stat-box {
    border-radius: 8px;
}

.auth-section {
    background: linear-gradient(180deg, var(--hotel-soft), #ffffff);
    min-height: calc(100vh - 150px);
}

.auth-section--login {
    background:
        linear-gradient(90deg, rgba(22, 114, 79, .06) 0 1px, transparent 1px),
        linear-gradient(180deg, rgba(22, 114, 79, .06) 0 1px, transparent 1px),
        linear-gradient(180deg, #f2f7f2 0%, #ffffff 72%);
    background-size: 38px 38px, 38px 38px, auto;
}

.auth-mobile-stage {
    display: flex;
    justify-content: center;
}

.auth-login-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 430px;
    width: min(100%, 980px);
    max-width: 100%;
    min-height: 590px;
    margin: 0 auto;
    overflow: hidden;
    border: 1px solid rgba(18, 32, 25, .08);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 28px 74px rgba(18, 32, 25, .12);
}

.auth-login-visual {
    position: relative;
    min-height: 100%;
    background:
        linear-gradient(180deg, rgba(8, 30, 20, .08), rgba(8, 30, 20, .54)),
        url("https://images.unsplash.com/photo-1571896349842-33c89424de2d?auto=format&fit=crop&w=1200&q=80") center / cover;
}

.auth-login-visual::after {
    content: "";
    position: absolute;
    inset: auto 1.4rem 1.4rem 1.4rem;
    height: 7rem;
    border: 1px solid rgba(255, 255, 255, .24);
    border-radius: 8px;
    background: rgba(255, 255, 255, .12);
    backdrop-filter: blur(16px);
}

.auth-login-visual__label {
    position: absolute;
    left: 1.4rem;
    bottom: 3rem;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    color: #ffffff;
    font-weight: 900;
    font-size: 1.15rem;
}

.auth-login-visual__label i {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, .18);
}

.auth-mobile-card {
    border-radius: 8px;
    border: 0;
    background: #ffffff;
    box-shadow: none;
}

.auth-mobile-card {
    padding: 2.3rem;
    width: 100%;
    max-width: 100%;
}

.auth-mobile-card__brand {
    display: flex;
    align-items: center;
    gap: .75rem;
    font-size: .92rem;
    font-weight: 850;
    color: var(--hotel-text);
}

.auth-mobile-card__mark {
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: linear-gradient(180deg, #edf6f0 0%, #e3f0e7 100%);
    color: var(--hotel-primary);
    font-size: 1.2rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .7);
}

.auth-mobile-card__head {
    margin-top: 2.6rem;
}

.auth-mobile-card__head h1 {
    font-size: 2.25rem;
    line-height: 1.08;
    font-weight: 950;
    margin: 0 0 .45rem;
}

.auth-mobile-card__head p {
    color: var(--hotel-muted);
    line-height: 1.55;
    margin-bottom: 1.35rem;
}

.auth-card-head h2 {
    font-size: clamp(1.7rem, 4vw, 2.3rem);
    line-height: 1.05;
    font-weight: 950;
    margin: .65rem 0 .5rem;
}

.auth-card-head p {
    color: var(--hotel-muted);
    margin-bottom: 1.25rem;
}

.auth-badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 .8rem;
    border-radius: 999px;
    background: #edf6f0;
    color: var(--hotel-primary);
    font-size: .8rem;
    font-weight: 900;
}

.profile-avatar {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: var(--hotel-primary);
    color: #ffffff;
    font-size: 1.8rem;
    font-weight: 800;
}

.profile-list {
    display: grid;
    gap: .85rem;
}

.profile-list div {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--hotel-border);
    padding-bottom: .85rem;
}

.profile-list span {
    color: var(--hotel-muted);
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: .75rem;
    color: var(--hotel-muted);
    font-size: .9rem;
    margin: 1rem 0;
}

.auth-divider::before,
.auth-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--hotel-border);
}

.btn-google {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: .65rem;
    border: 1px solid var(--hotel-border);
    background: #ffffff;
    color: var(--hotel-text);
    min-height: 44px;
}

.btn-google:hover {
    border-color: #cbd8cf;
    background: #f9fbf8;
}

.btn-google--hero {
    justify-content: flex-start;
    gap: .95rem;
    min-height: 78px;
    padding: .95rem 1rem;
    border: 1px solid rgba(18, 32, 25, .10);
    border-radius: 8px;
    background:
        linear-gradient(180deg, #ffffff 0%, #f8fbf8 100%);
    box-shadow: 0 16px 40px rgba(18, 32, 25, .08);
    text-decoration: none;
}

.btn-google--hero:hover {
    color: var(--hotel-text);
    border-color: rgba(22, 114, 79, .28);
    transform: translateY(-1px);
    box-shadow: 0 20px 42px rgba(18, 32, 25, .11);
}

.btn-google--stacked {
    justify-content: center;
    gap: .95rem;
    min-height: 56px;
    padding: .8rem .95rem;
    border-radius: 8px;
    border-color: #dfe7dd;
    background: #ffffff;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(18, 32, 25, .05);
}

.btn-google--stacked:hover {
    color: var(--hotel-text);
    border-color: rgba(22, 114, 79, .28);
    background: #f9fbf8;
}

.btn-google__content {
    display: flex;
    flex: 0 1 auto;
    align-items: center;
}

.btn-google__content strong {
    color: var(--hotel-text);
    font-size: 1rem;
    font-weight: 900;
}

.btn-google__content small {
    color: var(--hotel-muted);
    font-size: .86rem;
    margin-top: .1rem;
}

.btn-google__arrow {
    font-size: 1.35rem;
    color: var(--hotel-primary);
}

.google-mark {
    width: 22px;
    height: 22px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: #ffffff;
    border: 0;
}

.google-mark svg {
    width: 100%;
    height: 100%;
    display: block;
}

.auth-form-card {
    padding: 1rem;
    border: 1px solid #e4ebe1;
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(247, 250, 246, .96), rgba(255, 255, 255, .98));
}

.auth-form-card--floating {
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.auth-form-card .form-label {
    color: var(--hotel-text);
    font-size: .92rem;
    font-weight: 850;
}

.auth-form-card .form-control {
    min-height: 50px;
    border: 0;
    border-radius: 18px;
    background: transparent;
    box-shadow: none;
    padding-left: 0;
}

.auth-form-card .form-control:focus {
    box-shadow: none;
}

.auth-submit-btn {
    min-height: 50px;
}

.auth-submit-btn--coral {
    --bs-btn-bg: var(--hotel-primary);
    --bs-btn-border-color: var(--hotel-primary);
    --bs-btn-hover-bg: var(--hotel-primary-dark);
    --bs-btn-hover-border-color: var(--hotel-primary-dark);
    min-height: 54px;
    border-radius: 8px;
    box-shadow: 0 18px 32px rgba(22, 114, 79, .22);
}

.auth-input-wrap {
    display: flex;
    align-items: center;
    gap: .75rem;
    min-height: 54px;
    padding: 0 1rem;
    border: 1px solid #dfe7dd;
    border-radius: 8px;
    background: #ffffff;
}

.auth-input-wrap:focus-within {
    border-color: rgba(22, 114, 79, .35);
    box-shadow: 0 0 0 .24rem rgba(22, 114, 79, .10);
}

.auth-input-wrap i {
    color: #87a193;
    font-size: 1rem;
}

.auth-terms-note {
    color: var(--hotel-muted);
    font-size: .78rem;
    line-height: 1.6;
    margin: .2rem 0 1rem;
}

.auth-foot-note {
    text-align: center;
    color: var(--hotel-muted);
    font-size: .94rem;
    margin-top: 1rem;
}

.auth-foot-note a {
    color: var(--hotel-primary);
    font-weight: 850;
    text-decoration: none;
}

.auth-mobile-card__footer {
    text-align: center;
    color: var(--hotel-muted);
    font-size: .93rem;
    margin-top: 1.15rem;
}

.auth-mobile-card__footer a {
    color: var(--hotel-primary);
    font-weight: 850;
    text-decoration: none;
}

.auth-divider--tight {
    margin: .9rem 0;
}

.property-hero {
    min-height: min(790px, calc(100vh - 68px));
    position: relative;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    color: #ffffff;
    background: #102018;
}

.property-hero__image,
.property-hero__shade {
    position: absolute;
    inset: 0;
}

.property-hero__image {
    background-position: center;
    background-size: cover;
    transform: scale(1.025);
}

.property-hero__shade {
    background:
        linear-gradient(90deg, rgba(6, 16, 12, .80) 0%, rgba(6, 16, 12, .42) 46%, rgba(6, 16, 12, .10) 100%),
        linear-gradient(180deg, rgba(6, 16, 12, .04) 0%, rgba(6, 16, 12, .26) 50%, rgba(6, 16, 12, .78) 100%);
}

.property-hero__content {
    position: relative;
    z-index: 1;
    padding-top: 7rem;
    padding-bottom: 3.4rem;
}

.property-title-block {
    max-width: 780px;
}

.property-title-block h1 {
    font-size: clamp(3rem, 7vw, 6.2rem);
    line-height: .98;
    font-weight: 950;
    margin-bottom: 1rem;
    text-wrap: balance;
    text-shadow: 0 14px 44px rgba(0, 0, 0, .36);
}

.property-title-block p {
    max-width: 680px;
    color: rgba(255, 255, 255, .92);
    font-size: 1.13rem;
    line-height: 1.8;
    margin-bottom: 0;
}

.property-quick-facts,
.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
}

.property-quick-facts {
    margin-top: 1.35rem;
}

.property-quick-facts span {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255, 255, 255, .13);
    border: 1px solid rgba(255, 255, 255, .28);
    border-radius: 999px;
    padding: .6rem .9rem;
    font-weight: 800;
    backdrop-filter: blur(16px);
}

.hero-actions {
    margin-top: 1.55rem;
}

.hero-actions .btn {
    padding: .8rem 1.2rem;
}

.property-shell {
    margin-top: -3rem;
    position: relative;
    z-index: 2;
}

.property-summary-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: var(--hotel-border);
    border: 1px solid var(--hotel-border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--hotel-shadow);
    margin-bottom: .9rem;
}

.property-summary-bar div {
    background: rgba(255, 255, 255, .96);
    padding: 1rem 1.15rem;
}

.property-summary-bar span {
    display: block;
    color: var(--hotel-muted);
    font-size: .86rem;
    margin-bottom: .2rem;
}

.property-summary-bar strong {
    display: block;
    color: var(--hotel-text);
    font-size: 1.03rem;
}

.gallery-grid {
    display: grid;
    grid-template-columns: 1.1fr .95fr .95fr;
    gap: .55rem;
    border-radius: 8px;
    overflow: hidden;
    background: var(--hotel-surface);
    box-shadow: var(--hotel-shadow);
    position: relative;
}

.gallery-grid img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    display: block;
    transition: transform .35s ease;
}

.gallery-grid img:hover {
    transform: scale(1.025);
}

.gallery-more {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    border: 0;
    background: rgba(255, 255, 255, .94);
    color: var(--hotel-text);
    padding: .65rem .95rem;
    border-radius: 999px;
    font-weight: 900;
    box-shadow: 0 12px 32px rgba(0, 0, 0, .18);
}

.property-tabs {
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    padding: 1.15rem 0;
    margin: .85rem 0 1.35rem;
    scrollbar-width: none;
}

.property-tabs::-webkit-scrollbar {
    display: none;
}

.property-tabs a {
    color: var(--hotel-muted);
    background: rgba(255, 255, 255, .78);
    border: 1px solid var(--hotel-border);
    border-radius: 999px;
    text-decoration: none;
    white-space: nowrap;
    font-weight: 900;
    font-size: .92rem;
    padding: .58rem .9rem;
}

.property-tabs a:hover {
    color: var(--hotel-primary);
    border-color: rgba(22, 114, 79, .35);
}

.content-section {
    background: rgba(255, 255, 255, .78);
    border: 1px solid var(--hotel-border);
    border-radius: 8px;
    padding: 1.35rem;
    margin-bottom: 1rem;
}

.content-section p {
    color: var(--hotel-muted);
    line-height: 1.9;
    font-size: 1.03rem;
}

.content-section p:last-child {
    margin-bottom: 0;
}

.section-heading {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: .9rem;
}

.section-heading h2 {
    font-size: 1.5rem;
    font-weight: 950;
    margin: 0;
}

.rating-line {
    color: #b66f16;
    background: #fff7e9;
    border-radius: 999px;
    padding: .38rem .7rem;
    font-weight: 900;
    font-size: .9rem;
    white-space: nowrap;
}

.amenity-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}

.amenity-grid span {
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .95rem;
    background: #f7faf6;
    border: 1px solid #e8eee5;
    border-radius: 8px;
    color: var(--hotel-text);
    font-weight: 750;
}

.amenity-grid i {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--hotel-primary);
    background: #e7f3eb;
}

.availability-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .75rem;
}

.availability-strip div {
    border: 1px solid var(--hotel-border);
    border-radius: 8px;
    padding: 1rem;
    background: linear-gradient(180deg, #ffffff, #f7faf6);
}

.availability-strip strong,
.availability-strip span {
    display: block;
}

.availability-strip span {
    color: var(--hotel-primary);
    font-weight: 950;
    margin-top: .3rem;
    font-size: 1.08rem;
}

.feedback-box {
    border: 1px solid #dce8dd;
    border-left: 4px solid var(--hotel-primary);
    background: linear-gradient(180deg, #ffffff, #f4f8f3);
    border-radius: 8px;
    margin: 0;
    padding: 1.1rem;
}

.feedback-box p {
    color: var(--hotel-text);
    margin-bottom: .75rem;
}

.feedback-box footer {
    color: var(--hotel-muted);
    font-size: .92rem;
}

.booking-card {
    position: sticky;
    top: 5.5rem;
    border: 1px solid #d9e5dc;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 22px 60px rgba(18, 32, 25, .13);
    padding: 1.25rem;
}

.booking-card__label {
    color: var(--hotel-primary);
    font-weight: 950;
    margin-bottom: .65rem;
}

.booking-price {
    display: flex;
    align-items: baseline;
    gap: .35rem;
    margin-bottom: 1.05rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--hotel-border);
}

.booking-price span,
.booking-price small {
    color: var(--hotel-muted);
}

.booking-price strong {
    color: var(--hotel-primary);
    font-size: 2.25rem;
    line-height: 1;
    font-weight: 950;
}

.booking-card .form-label {
    font-weight: 800;
    color: var(--hotel-text);
    font-size: .92rem;
}

.booking-card .form-control,
.booking-card .form-select {
    border-radius: 8px;
    min-height: 46px;
    border-color: #d9e3db;
}

.booking-note {
    display: flex;
    gap: .55rem;
    color: var(--hotel-muted);
    font-size: .9rem;
    margin-top: .9rem;
}

.mobile-price-bar {
    display: none;
}

@media (max-width: 991.98px) {
    .auth-login-panel {
        grid-template-columns: 1fr;
        width: min(100%, 480px);
        min-height: auto;
    }

    .auth-login-visual {
        display: none;
    }

    .property-hero {
        min-height: 74vh;
    }

    .property-summary-bar {
        grid-template-columns: 1fr;
    }

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

    .gallery-grid img {
        height: 190px;
    }

    .gallery-grid img:first-child {
        grid-column: 1 / -1;
    }

    .booking-card {
        position: static;
        margin-top: .5rem;
    }
}

@media (max-width: 575.98px) {
    .auth-section--login .container {
        padding-left: .8rem;
        padding-right: .8rem;
    }

    .auth-section--login {
        background:
            linear-gradient(180deg, #eef5ef 0%, #ffffff 76%);
    }

    .auth-login-panel {
        border: 0;
        box-shadow: none;
        background: transparent;
        display: block;
        width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .auth-mobile-card,
    .auth-login-card {
        width: calc(100vw - 2.5rem);
        max-width: calc(100vw - 2.5rem);
    }

    .auth-input-wrap .form-control {
        min-width: 0;
    }

    .auth-mobile-card {
        border-radius: 28px;
        border: 1px solid rgba(18, 32, 25, .08);
        box-shadow: 0 22px 56px rgba(18, 32, 25, .10);
    }

    .auth-mobile-card {
        padding: 1.1rem;
    }

    .auth-mobile-card__head {
        margin-top: 1.35rem;
    }

    .auth-mobile-card__head h1 {
        font-size: 2rem;
    }

    .auth-mobile-card__head p,
    .btn-google__content small {
        font-size: .9rem;
        line-height: 1.6;
    }

    body {
        padding-bottom: 78px;
    }

    .navbar {
        min-height: 58px;
    }

    .navbar .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .property-hero {
        min-height: 75vh;
        align-items: flex-end;
    }

    .property-hero__shade {
        background:
            linear-gradient(180deg, rgba(6, 16, 12, .04) 0%, rgba(6, 16, 12, .30) 36%, rgba(6, 16, 12, .86) 100%);
    }

    .property-hero__content {
        padding-top: 4rem;
        padding-bottom: 1.6rem;
    }

    .property-title-block h1 {
        font-size: clamp(2.35rem, 13vw, 3.65rem);
        line-height: 1.02;
        margin-bottom: .75rem;
    }

    .property-title-block p {
        font-size: 1rem;
        line-height: 1.68;
    }

    .property-quick-facts {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .5rem;
        margin-top: 1rem;
    }

    .property-quick-facts span {
        justify-content: center;
        font-size: .84rem;
        padding: .55rem .6rem;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .property-quick-facts span:nth-child(3) {
        grid-column: 1 / -1;
    }

    .hero-actions {
        margin-top: 1rem;
    }

    .hero-actions .btn {
        flex: 1 1 auto;
        padding: .72rem .9rem;
        font-size: .92rem;
    }

    .property-shell {
        margin-top: 0;
        padding-top: 1rem;
        padding-bottom: 1.2rem;
    }

    .property-summary-bar {
        display: none;
    }

    .gallery-grid {
        display: flex;
        gap: .6rem;
        overflow-x: auto;
        border-radius: 8px;
        box-shadow: none;
        background: transparent;
        scrollbar-width: none;
    }

    .gallery-grid::-webkit-scrollbar {
        display: none;
    }

    .gallery-grid img,
    .gallery-grid img:first-child {
        width: 78%;
        min-width: 78%;
        height: 164px;
        border-radius: 8px;
        grid-column: auto;
    }

    .gallery-more {
        display: none;
    }

    .property-tabs {
        gap: .45rem;
        margin-top: .75rem;
        padding: .5rem 0 1rem;
    }

    .property-tabs a {
        font-size: .86rem;
        padding: .52rem .72rem;
    }

    .content-section {
        padding: 1.1rem;
        margin-bottom: .8rem;
    }

    .section-heading {
        display: block;
    }

    .section-heading h2 {
        font-size: 1.35rem;
    }

    .rating-line {
        display: inline-block;
        margin-top: .55rem;
    }

    .amenity-grid,
    .availability-strip {
        grid-template-columns: 1fr;
    }

    .booking-card {
        padding: 1rem;
    }

    .mobile-price-bar {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1030;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        background: rgba(255, 255, 255, .96);
        border-top: 1px solid var(--hotel-border);
        padding: .75rem 1rem;
        box-shadow: 0 -10px 30px rgba(18, 35, 27, .12);
        backdrop-filter: blur(14px);
    }

    .mobile-price-bar span,
    .mobile-price-bar strong {
        display: block;
    }

    .mobile-price-bar span {
        color: var(--hotel-muted);
        font-size: .78rem;
    }

    .mobile-price-bar strong {
        color: var(--hotel-primary);
        font-size: 1.28rem;
        line-height: 1.1;
        font-weight: 950;
    }
}

/* Final luxury overrides: keep this block last so older green theme rules cannot win. */
body {
    background:
        radial-gradient(circle at top left, rgba(198, 161, 91, .10), transparent 28rem),
        linear-gradient(180deg, #070807 0%, #10110e 54%, #070807 100%);
    color: var(--hotel-text);
    overflow-x: hidden;
}

.site-navbar {
    --bs-navbar-color: rgba(247, 240, 223, .70);
    --bs-navbar-hover-color: var(--hotel-accent);
    min-height: 76px;
    border-bottom: 1px solid rgba(224, 194, 122, .14);
    background: rgba(7, 8, 7, .78);
    backdrop-filter: blur(18px) saturate(150%);
}

.site-navbar .navbar-brand,
.site-navbar .nav-link {
    color: rgba(247, 240, 223, .82);
}

.site-navbar .navbar-brand:hover,
.site-navbar .nav-link:hover {
    color: var(--hotel-accent);
}

.btn-primary {
    background: linear-gradient(180deg, #d8b76b 0%, #b99045 100%);
    border-color: #c6a15b;
    color: #14110a;
    box-shadow: 0 16px 34px rgba(198, 161, 91, .18);
}

.btn-primary:hover,
.btn-primary:focus {
    background: linear-gradient(180deg, #e0c27a 0%, #c6a15b 100%);
    border-color: #e0c27a;
    color: #14110a;
}

.auth-section,
.auth-section--login {
    background:
        radial-gradient(circle at top left, rgba(198, 161, 91, .12), transparent 30rem),
        linear-gradient(180deg, #070807 0%, #11130f 100%);
}

.auth-login-panel {
    background: rgba(18, 19, 17, .72);
    border-color: var(--hotel-border);
    box-shadow: var(--hotel-shadow);
}

.auth-mobile-card {
    background: rgba(12, 13, 11, .78);
    color: var(--hotel-text);
}

.auth-mobile-card__mark,
.auth-badge {
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.auth-mobile-card__head p,
.auth-mobile-card__footer,
.auth-divider,
.auth-form-card .form-label {
    color: var(--hotel-muted);
}

.auth-input-wrap {
    border-color: rgba(224, 194, 122, .18);
    background: rgba(255, 255, 255, .07);
}

.auth-input-wrap:focus-within {
    border-color: rgba(224, 194, 122, .42);
    box-shadow: 0 0 0 .24rem rgba(198, 161, 91, .12);
}

.auth-input-wrap i,
.auth-mobile-card__footer a {
    color: var(--hotel-accent);
}

.btn-google--stacked {
    border-color: rgba(224, 194, 122, .20);
    background: rgba(255, 255, 255, .08);
    color: var(--hotel-text);
}

.btn-google__content strong {
    color: var(--hotel-text);
}

.property-quick-facts span,
.property-tabs a,
.content-section,
.booking-card,
.property-summary-bar,
.feedback-box,
.availability-strip div,
.amenity-grid span,
.auth-panel,
.stat-box {
    border-color: var(--hotel-border);
    background: var(--hotel-glass);
    color: var(--hotel-text);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .28);
    backdrop-filter: blur(16px);
}

.property-summary-bar div {
    background: rgba(18, 19, 17, .78);
}

.content-section p,
.booking-note,
.feedback-box footer,
.property-summary-bar span,
.booking-price span,
.booking-price small {
    color: var(--hotel-muted);
}

.property-summary-bar strong,
.section-heading h2,
.booking-price strong,
.booking-card__label,
.availability-strip span {
    color: var(--hotel-text);
}

.amenity-grid i,
.profile-avatar {
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.mobile-price-bar {
    background: rgba(7, 8, 7, .88);
    border-color: var(--hotel-border);
}

@media (max-width: 575.98px) {
    .auth-section--login {
        background:
            radial-gradient(circle at top left, rgba(198, 161, 91, .10), transparent 18rem),
            linear-gradient(180deg, #070807 0%, #11130f 100%);
    }

    .auth-mobile-card {
        border-color: var(--hotel-border);
        box-shadow: 0 22px 56px rgba(0, 0, 0, .35);
    }

    .site-navbar .container {
        max-width: 100%;
    }

    .site-navbar .navbar-toggler {
        flex: 0 0 auto;
        margin-left: auto;
        margin-right: .25rem;
    }

    .property-title-block h1 {
        font-size: clamp(1.85rem, 9vw, 2.25rem);
        overflow-wrap: anywhere;
        word-break: break-all;
    }

    .property-title-block {
        max-width: calc(100vw - 2rem);
    }

    .property-title-block p {
        max-width: min(20rem, calc(100vw - 2rem));
        font-size: .9rem;
        overflow-wrap: anywhere;
        word-break: break-all;
    }

    .property-quick-facts {
        grid-template-columns: 1fr;
    }

    .property-quick-facts span,
    .property-quick-facts span:nth-child(3) {
        grid-column: auto;
        justify-content: flex-start;
        white-space: normal;
        text-overflow: clip;
    }

    .hero-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .mobile-price-bar {
        min-width: 0;
        padding-right: 2rem;
    }

    .mobile-price-bar > div {
        min-width: 0;
    }

    .mobile-price-bar .btn {
        flex: 0 0 auto;
        max-width: 42%;
        white-space: nowrap;
    }
}

/* Production admin shell */
.admin-body {
    background:
        radial-gradient(circle at top right, rgba(198, 161, 91, .08), transparent 26rem),
        linear-gradient(180deg, #0b0c0a 0%, #070807 100%);
}

.admin-app-shell {
    display: grid;
    grid-template-columns: 304px minmax(0, 1fr);
    min-height: 100vh;
}

.admin-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    border-right: 1px solid rgba(224, 194, 122, .12);
    background:
        linear-gradient(180deg, rgba(18, 18, 15, .98), rgba(7, 8, 7, .96)),
        radial-gradient(circle at top left, rgba(198, 161, 91, .14), transparent 18rem);
    box-shadow: 18px 0 70px rgba(0, 0, 0, .25);
    padding: 1.35rem;
    overflow-y: auto;
}

.admin-brand {
    display: flex;
    align-items: center;
    gap: .85rem;
    color: var(--hotel-text);
    text-decoration: none;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
    margin-bottom: 1.25rem;
    padding: .85rem;
}

.admin-brand__mark {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: linear-gradient(180deg, #d8b76b, #a98239);
    color: #14110a;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .24);
}

.admin-brand strong {
    display: block;
    color: #fff7e6;
    font-size: 1.06rem;
    font-weight: 950;
    line-height: 1.1;
}

.admin-brand small {
    display: block;
    color: rgba(247, 240, 223, .48);
    font-size: .74rem;
    font-weight: 700;
    margin-top: .22rem;
}

.admin-nav {
    display: grid;
    gap: .4rem;
}

.admin-nav-label {
    color: rgba(247, 240, 223, .38);
    font-size: .68rem;
    font-weight: 900;
    letter-spacing: .08em;
    margin: .65rem .55rem .15rem;
    text-transform: uppercase;
}

.admin-nav a,
.admin-nav-parent {
    display: flex;
    align-items: center;
    gap: .72rem;
    min-height: 44px;
    border: 1px solid transparent;
    border-radius: 8px;
    color: rgba(247, 240, 223, .66);
    text-decoration: none;
    padding: 0 .72rem;
    font-weight: 850;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.admin-nav a:hover,
.admin-nav a.is-active,
.admin-nav-parent.is-active {
    border-color: rgba(224, 194, 122, .18);
    background: rgba(255, 255, 255, .07);
    color: var(--hotel-accent);
}

.admin-nav a:hover,
.admin-nav-parent:hover {
    transform: translateX(2px);
}

.admin-nav i {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(224, 194, 122, .10);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    color: rgba(198, 161, 91, .78);
    text-align: center;
}

.admin-nav a.is-active i,
.admin-nav-parent.is-active i {
    border-color: rgba(198, 161, 91, .32);
    background: rgba(198, 161, 91, .18);
    color: var(--hotel-accent);
}

.admin-nav-group {
    display: grid;
    gap: .35rem;
}

.admin-nav-card {
    position: relative;
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .035);
    padding: .38rem;
}

.admin-nav-card::before {
    content: "";
    position: absolute;
    top: .65rem;
    bottom: .65rem;
    left: -1px;
    width: 2px;
    border-radius: 999px;
    background: transparent;
}

.admin-nav-card.is-open::before {
    background: linear-gradient(180deg, #dec477, rgba(198, 161, 91, .2));
}

.admin-nav-parent {
    position: relative;
    min-height: 56px;
}

.admin-nav-parent span {
    display: grid;
    gap: .16rem;
    flex: 1 1 auto;
    min-width: 0;
}

.admin-nav-parent strong {
    color: inherit;
    font-size: .93rem;
    line-height: 1.05;
}

.admin-nav-parent em {
    color: rgba(247, 240, 223, .42);
    font-size: .7rem;
    font-style: normal;
    font-weight: 750;
}

.admin-nav-parent small {
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 999px;
    color: rgba(247, 240, 223, .52);
    font-size: .68rem;
    font-weight: 800;
    line-height: 1;
    padding: .24rem .45rem;
}

.admin-nav-group.is-open .admin-nav-parent small {
    border-color: rgba(198, 161, 91, .35);
    color: var(--hotel-accent);
}

.admin-subnav {
    display: grid;
    gap: .18rem;
    margin: .15rem 0 .1rem;
    padding: .25rem .15rem .15rem 2.55rem;
}

.admin-subnav a {
    position: relative;
    min-height: 36px;
    border-radius: 8px;
    color: rgba(247, 240, 223, .56);
    font-size: .86rem;
    font-weight: 750;
    padding: 0 .65rem 0 .55rem;
}

.admin-subnav a i {
    width: 26px;
    height: 26px;
    flex-basis: 26px;
    border: 0;
    background: transparent;
    color: rgba(198, 161, 91, .62);
    font-size: .82rem;
}

.admin-subnav a:hover,
.admin-subnav a.is-active {
    border-color: rgba(224, 194, 122, .14);
    background: rgba(198, 161, 91, .105);
    color: #fff7e6;
    transform: none;
}

.admin-subnav a.is-active::before {
    content: "";
    position: absolute;
    left: -.4rem;
    width: 5px;
    height: 5px;
    border-radius: 999px;
    background: var(--hotel-accent);
    box-shadow: 0 0 0 4px rgba(198, 161, 91, .12);
}

.admin-sidebar__user {
    display: flex;
    align-items: center;
    gap: .8rem;
    margin-top: auto;
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .035));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
    padding: .85rem;
}

.admin-sidebar__user > span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: linear-gradient(180deg, #d8b76b, #b99045);
    color: #14110a;
    font-weight: 950;
}

.admin-sidebar__user strong,
.admin-sidebar__user small {
    display: block;
}

.admin-sidebar__user strong {
    color: var(--hotel-text);
    font-size: .95rem;
}

.admin-sidebar__user small {
    color: var(--hotel-muted);
}

.admin-main {
    min-width: 0;
}

.admin-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 72px;
    border-bottom: 1px solid rgba(224, 194, 122, .12);
    background: rgba(11, 12, 10, .78);
    padding: 0 1.6rem;
    backdrop-filter: blur(18px) saturate(150%);
}

.admin-topbar span,
.admin-topbar strong {
    display: block;
}

.admin-topbar span {
    color: var(--hotel-muted);
    font-size: .82rem;
}

.admin-topbar strong {
    color: var(--hotel-text);
}

.admin-topbar__actions {
    display: flex;
    gap: .6rem;
}

.admin-page {
    padding: 1.6rem;
}

.admin-page-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.admin-page-head h1 {
    color: #fff7e6;
    font-size: clamp(2rem, 4vw, 3.1rem);
    font-weight: 950;
    line-height: 1.04;
    margin: 0 0 .45rem;
}

.admin-page-head p {
    color: var(--hotel-muted);
    margin: 0;
}

.admin-metric-grid,
.admin-summary-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: .85rem;
    margin-bottom: 1rem;
}

.admin-metric-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-metric-card,
.admin-summary-strip div,
.admin-work-panel,
.admin-panel {
    border: 1px solid rgba(224, 194, 122, .14);
    border-radius: 8px;
    background: rgba(18, 19, 17, .74);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .22);
    backdrop-filter: blur(16px);
}

.admin-metric-card,
.admin-summary-strip div {
    padding: 1rem;
}

.admin-metric-card span,
.admin-summary-strip span {
    display: block;
    color: var(--hotel-muted);
    font-size: .84rem;
}

.admin-metric-card strong,
.admin-summary-strip strong {
    display: block;
    color: #fff7e6;
    font-size: 2.1rem;
    font-weight: 950;
    line-height: 1;
    margin: .45rem 0;
}

.admin-metric-card small {
    color: rgba(247, 240, 223, .56);
}

.admin-dashboard-grid {
    display: grid;
    grid-template-columns: 1.25fr .75fr;
    gap: 1rem;
}

.admin-work-panel {
    padding: 1.15rem;
}

.admin-section-title {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-section-title h2 {
    color: #fff7e6;
    font-size: 1.15rem;
    font-weight: 950;
    margin: 0 0 .2rem;
}

.admin-section-title p {
    color: var(--hotel-muted);
    margin: 0;
}

.admin-action-list,
.admin-timeline {
    display: grid;
    gap: .65rem;
}

.admin-action-list a {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    align-items: center;
    gap: .8rem;
    border: 1px solid rgba(224, 194, 122, .12);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    color: var(--hotel-text);
    text-decoration: none;
    padding: .8rem;
}

.admin-action-list i {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: rgba(198, 161, 91, .16);
    color: var(--hotel-accent);
}

.admin-action-list strong {
    color: var(--hotel-accent);
}

.admin-timeline div {
    display: grid;
    grid-template-columns: 12px minmax(0, 1fr);
    gap: .75rem;
    border-bottom: 1px solid rgba(224, 194, 122, .10);
    padding-bottom: .75rem;
}

.admin-timeline div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.admin-timeline span {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: var(--hotel-accent);
    margin-top: .35rem;
}

.admin-timeline strong,
.admin-timeline small {
    grid-column: 2;
}

.admin-timeline strong {
    color: var(--hotel-text);
}

.admin-timeline small {
    color: var(--hotel-muted);
}

.admin-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    align-items: start;
}

.admin-panel {
    grid-column: span 6;
    padding: 1rem;
}

.admin-panel--wide {
    grid-column: 1 / -1;
}

.admin-panel h2 {
    display: flex;
    align-items: center;
    min-height: 34px;
    border-bottom: 1px solid rgba(224, 194, 122, .12);
    padding-bottom: .7rem;
}

.admin-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
}

.admin-form textarea,
.admin-form .row,
.admin-form button,
.admin-form .admin-check {
    grid-column: 1 / -1;
}

.admin-form--inline {
    grid-template-columns: .75fr 1.1fr 1.4fr .8fr .9fr auto auto;
}

.admin-form--inline button,
.admin-form--inline .admin-check {
    grid-column: auto;
}

.admin-form .form-control,
.admin-form .form-select {
    min-height: 44px;
    border-radius: 8px;
}

.admin-list {
    max-height: 430px;
    overflow: auto;
    padding-right: .15rem;
}

.admin-list--grid {
    max-height: none;
}

.admin-row {
    min-height: 58px;
}

.admin-row form {
    flex: 0 0 auto;
}

@media (max-width: 1199.98px) {
    .admin-app-shell {
        grid-template-columns: 270px minmax(0, 1fr);
    }

    .admin-summary-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .admin-app-shell {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        position: static;
        height: auto;
    }

    .admin-nav {
        grid-template-columns: 1fr;
    }

    .admin-subnav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        border-left: 0;
        margin: .25rem 0 .65rem;
        padding-left: .15rem;
    }

    .admin-main,
    .admin-page {
        min-width: 0;
    }

    .admin-dashboard-grid,
    .admin-metric-grid,
    .admin-summary-strip,
    .admin-grid,
    .admin-form,
    .admin-form--inline {
        grid-template-columns: 1fr;
    }

    .admin-panel,
    .admin-panel--wide {
        grid-column: auto;
    }
}

/* Final OZO Light theme overrides: keep this block last so older black/gold rules cannot win. */
:root {
    --hotel-primary: oklch(34% .17 262);
    --hotel-primary-dark: oklch(27% .145 262);
    --hotel-accent: oklch(82% .16 85);
    --hotel-bg: oklch(97.5% .018 86);
    --hotel-soft: oklch(94.5% .035 84);
    --hotel-surface: oklch(99% .007 86);
    --hotel-border: oklch(87% .035 82);
    --hotel-text: oklch(22% .038 260);
    --hotel-muted: oklch(48% .032 260);
    --hotel-shadow: 0 22px 54px rgba(36, 47, 74, .11);
    --hotel-glass: rgba(255, 252, 243, .88);
    --hotel-gold-soft: rgba(244, 191, 65, .18);
    --hotel-navy: oklch(23% .095 262);
    --hotel-ivory: oklch(98% .018 86);
    --hotel-blue-soft: rgba(18, 62, 154, .08);
    --hotel-yellow-soft: rgba(244, 191, 65, .24);
}

html,
body {
    background: var(--hotel-bg);
}

body {
    color: var(--hotel-text);
    background:
        radial-gradient(circle at 10% 0%, rgba(244, 191, 65, .18), transparent 26rem),
        linear-gradient(180deg, var(--hotel-bg) 0%, #f4ead3 58%, var(--hotel-bg) 100%);
}

.site-navbar,
.navbar {
    --bs-navbar-color: rgba(24, 38, 72, .78);
    --bs-navbar-hover-color: var(--hotel-primary);
    --bs-navbar-active-color: var(--hotel-primary);
    min-height: 76px;
    border-bottom: 1px solid rgba(30, 48, 86, .09);
    background: rgba(255, 250, 238, .9);
    box-shadow: 0 10px 30px rgba(25, 45, 80, .06);
    backdrop-filter: blur(16px) saturate(160%);
}

.site-navbar .navbar-brand,
.site-navbar .nav-link,
.navbar-brand {
    color: var(--hotel-navy);
}

.site-navbar .navbar-brand:hover,
.site-navbar .nav-link:hover {
    color: var(--hotel-primary);
}

.site-navbar .navbar-toggler {
    border-color: rgba(24, 38, 72, .18);
}

.site-navbar .navbar-toggler-icon {
    filter: none;
}

.site-navbar .btn-outline-secondary,
.btn-outline-secondary,
.btn-outline-light {
    --bs-btn-color: var(--hotel-primary);
    --bs-btn-border-color: rgba(18, 62, 154, .22);
    --bs-btn-hover-bg: rgba(18, 62, 154, .08);
    --bs-btn-hover-border-color: rgba(18, 62, 154, .38);
    --bs-btn-hover-color: var(--hotel-primary-dark);
}

.btn-primary,
.auth-submit-btn--coral {
    background: var(--hotel-primary);
    border-color: var(--hotel-primary);
    color: #fffaf0;
    box-shadow: 0 16px 34px rgba(18, 62, 154, .18);
}

.btn-primary:hover,
.btn-primary:focus,
.auth-submit-btn--coral:hover,
.auth-submit-btn--coral:focus {
    background: var(--hotel-primary-dark);
    border-color: var(--hotel-primary-dark);
    color: #fffaf0;
}

.btn-light {
    --bs-btn-color: var(--hotel-navy);
    --bs-btn-bg: rgba(255, 250, 238, .92);
    --bs-btn-border-color: rgba(30, 48, 86, .12);
    --bs-btn-hover-bg: #f3e5bf;
    --bs-btn-hover-border-color: rgba(30, 48, 86, .16);
    --bs-btn-hover-color: var(--hotel-navy);
}

footer {
    border-color: rgba(30, 48, 86, .12) !important;
    background: var(--hotel-navy);
    color: #fffaf0;
}

footer .text-secondary,
footer span,
.text-secondary {
    color: rgba(255, 250, 238, .7) !important;
}

.estate-label,
.section-kicker,
.booking-card__label,
.admin-empty-state i,
.admin-breadcrumbs a:hover {
    color: var(--hotel-primary);
}

.estate-hero__copy .estate-label {
    color: var(--hotel-accent);
    text-shadow: 0 10px 26px rgba(10, 28, 70, .32);
}

.estate-hero,
.property-hero {
    background: #d8c59e;
}

.estate-hero__media,
.property-hero__image,
.rooms-hero {
    filter: saturate(1.02) contrast(.96) brightness(1.08);
}

.estate-hero__overlay {
    background:
        linear-gradient(90deg, rgba(14, 25, 48, .62) 0%, rgba(14, 25, 48, .36) 45%, rgba(14, 25, 48, .06) 100%),
        linear-gradient(180deg, rgba(14, 25, 48, .04) 0%, rgba(14, 25, 48, .2) 54%, rgba(247, 238, 218, .94) 100%);
}

.property-hero__shade {
    background:
        linear-gradient(90deg, rgba(14, 25, 48, .66) 0%, rgba(14, 25, 48, .35) 48%, rgba(14, 25, 48, .08) 100%),
        linear-gradient(180deg, rgba(14, 25, 48, .04) 0%, rgba(14, 25, 48, .24) 58%, rgba(247, 238, 218, .86) 100%);
}

.estate-hero__copy h1,
.property-title-block h1,
.rooms-hero h1 {
    color: #fffaf0;
    text-shadow: 0 18px 44px rgba(10, 28, 70, .35);
}

.estate-hero__copy p,
.property-title-block p,
.rooms-hero p {
    color: rgba(255, 250, 238, .86);
}

.estate-section-head h2,
.estate-tour__copy h2,
.estate-contact h2,
.section-heading h2,
.checkout-hero h1,
.checkout-panel__head h2,
.checkout-success-card h1,
.profile-hero__copy h1,
.profile-panel__head h2,
.admin-page-head h1,
.admin-panel h2,
.admin-section-title h2,
.admin-table-toolbar strong,
.admin-delete-panel h1 {
    color: var(--hotel-navy);
}

.estate-search-panel,
.room-search-panel {
    border: 1px solid rgba(30, 48, 86, .12);
    background: rgba(255, 250, 238, .92);
    box-shadow: 0 24px 58px rgba(36, 47, 74, .15);
    backdrop-filter: blur(14px) saturate(150%);
}

.estate-hero__inner {
    grid-template-columns: minmax(0, 1.26fr) minmax(300px, .48fr);
    gap: clamp(1.1rem, 3vw, 2.6rem);
}

.estate-search-panel {
    grid-template-columns: minmax(170px, .92fr) minmax(230px, 1fr) minmax(120px, .56fr) auto;
    max-width: 100%;
}

.estate-search-panel .btn {
    padding-left: 1rem;
    padding-right: 1rem;
}

.estate-search-panel label {
    border-right-color: rgba(30, 48, 86, .1);
}

.estate-search-panel span,
.room-search-panel span,
.checkout-hero p,
.profile-hero__copy p,
.admin-page-head p {
    color: var(--hotel-muted);
}

.estate-search-panel strong,
.estate-search-panel input,
.estate-search-panel select,
.room-search-panel input,
.room-search-panel select {
    color: var(--hotel-navy);
}

.estate-select-field select {
    color-scheme: light;
}

.estate-select-field select option,
.room-search-panel select option,
.form-select option {
    background: #fffaf0;
    color: var(--hotel-navy);
}

.estate-date-field i,
.estate-select-field i,
.estate-date-summary i,
.estate-trust-row i,
.estate-feature-list i,
.estate-contact-points i,
.checkout-panel__head > i,
.checkout-success-card__icon,
.profile-badges i,
.profile-panel__head i,
.profile-mini-card i,
.payment-time-alert i,
.payment-slip-box__head > i {
    color: var(--hotel-primary);
}

.estate-calendar-box {
    border-color: rgba(30, 48, 86, .12);
    background: rgba(255, 250, 238, .86);
}

.estate-calendar-box__head > span,
.estate-calendar-box__head em,
.estate-calendar-box small {
    color: var(--hotel-muted);
}

.estate-calendar-box__head > span {
    color: var(--hotel-navy);
}

.estate-calendar-box .flatpickr-calendar.inline {
    background: #fffaf0;
    box-shadow: inset 0 0 0 1px rgba(30, 48, 86, .1);
}

.estate-calendar-box .flatpickr-month,
.estate-calendar-box .flatpickr-current-month,
.estate-calendar-box .flatpickr-current-month input.cur-year,
.estate-calendar-box .flatpickr-weekday,
.estate-calendar-box .flatpickr-day {
    color: var(--hotel-navy);
}

.estate-calendar-box .flatpickr-current-month .flatpickr-monthDropdown-months,
.estate-calendar-box .flatpickr-current-month .flatpickr-monthDropdown-months option {
    background: #fffaf0;
    color: var(--hotel-navy);
}

.estate-calendar-box .flatpickr-prev-month,
.estate-calendar-box .flatpickr-next-month {
    fill: var(--hotel-primary);
    color: var(--hotel-primary);
}

.estate-calendar-box .flatpickr-day.prevMonthDay,
.estate-calendar-box .flatpickr-day.nextMonthDay {
    color: rgba(24, 38, 72, .32);
}

.estate-calendar-box .flatpickr-day.is-available {
    background: rgba(47, 151, 91, .16);
    border-color: rgba(47, 151, 91, .38);
    color: #17643b;
}

.estate-calendar-box .flatpickr-day.is-unavailable {
    background: rgba(201, 75, 75, .14);
    border-color: rgba(201, 75, 75, .36);
    color: #9a2f2f;
}

.estate-calendar-box .flatpickr-day.selected,
.estate-calendar-box .flatpickr-day.startRange,
.estate-calendar-box .flatpickr-day.endRange,
.estate-calendar-box .flatpickr-day.inRange {
    background: var(--hotel-primary);
    border-color: var(--hotel-primary);
    color: #fffaf0;
}

.estate-trust-row span,
.estate-feature-list span,
.estate-contact-points span,
.room-availability-pill,
.profile-badges span {
    border-color: rgba(30, 48, 86, .12);
    background: rgba(255, 250, 238, .72);
    color: var(--hotel-muted);
}

.estate-hero-card,
.estate-property-card,
.estate-tour__visual,
.estate-agent-card,
.estate-contact,
.estate-contact-form,
.property-summary-bar,
.property-summary-bar div,
.property-tabs a,
.content-section,
.booking-card,
.feedback-box,
.availability-strip div,
.amenity-grid span,
.room-card,
.checkout-panel,
.checkout-summary,
.checkout-success-card,
.payment-card,
.profile-status-card,
.profile-member-card,
.profile-panel,
.profile-mini-card,
.admin-resource-card,
.admin-table-shell,
.admin-edit-shell,
.admin-delete-panel,
.admin-detail-shell,
.admin-metric-card,
.admin-summary-strip div,
.admin-work-panel,
.admin-panel,
.auth-login-panel,
.auth-mobile-card,
.auth-panel,
.stat-box {
    border-color: rgba(30, 48, 86, .12);
    background: var(--hotel-surface);
    color: var(--hotel-text);
    box-shadow: var(--hotel-shadow);
    backdrop-filter: none;
}

.estate-hero-card__body h2,
.estate-property-card h3,
.estate-agent-card h3,
.room-card__content h2,
.checkout-summary__body h2,
.checkout-price-list strong,
.checkout-daily strong,
.checkout-total strong,
.checkout-success-detail dd,
.checkout-success-room,
.payment-time-alert strong,
.payment-detail-list dd,
.payment-booking-box strong,
.payment-booking-box h3,
.payment-slip-box__head h3,
.profile-status-card strong,
.profile-member-card h2,
.profile-detail-list dd,
.profile-mini-card strong,
.profile-booking-list strong,
.booking-detail-row strong,
.booking-detail-note p,
.admin-resource-card h2,
.admin-resource-card > strong,
.admin-cell-title strong,
.admin-empty-state strong,
.admin-edit-summary strong,
.admin-delete-detail dd,
.admin-detail-hero strong,
.admin-detail-grid dd,
.admin-metric-card strong,
.admin-summary-strip strong,
.admin-action-list strong,
.admin-topbar strong {
    color: var(--hotel-navy);
}

.estate-hero-card__body strong,
.estate-card-bottom strong,
.room-card__content span,
.room-card__meta i,
.booking-price strong,
.availability-strip span,
.checkout-total strong,
.payment-card--qr strong,
.profile-booking-list em,
.booking-detail-note strong,
.checkout-success-room i,
.checkout-success-room strong {
    color: var(--hotel-primary);
}

.estate-property-card p,
.estate-card-meta,
.estate-hero-card__body span,
.estate-hero-card__body small,
.estate-tour__copy p,
.estate-contact p,
.room-card__content p,
.checkout-summary__body > span,
.checkout-summary__body p,
.checkout-note,
.checkout-price-list span,
.checkout-daily span,
.checkout-total span,
.checkout-success-card p,
.payment-card--qr > span,
.payment-detail-list dt,
.payment-booking-box span,
.payment-slip-box span,
.profile-status-card span,
.profile-detail-list dt,
.profile-mini-card span,
.profile-member-card p,
.profile-booking-list span,
.booking-detail-row span,
.booking-detail-note span,
.admin-resource-card p,
.admin-table-toolbar span,
.admin-edit-summary span,
.admin-delete-panel p,
.admin-detail-hero span,
.admin-metric-card span,
.admin-summary-strip span,
.admin-section-title p,
.admin-timeline small,
.admin-topbar span,
.content-section p,
.booking-note,
.feedback-box footer,
.property-summary-bar span,
.booking-price span,
.booking-price small,
.profile-list span {
    color: var(--hotel-muted);
}

.estate-play {
    border-color: rgba(255, 250, 238, .38);
    background: rgba(24, 38, 72, .68);
    color: #fffaf0;
}

.estate-play i,
.admin-brand__mark,
.admin-sidebar__user > span,
.profile-avatar-xl {
    background: var(--hotel-accent);
    color: var(--hotel-navy);
}

.estate-tour {
    background:
        radial-gradient(circle at top right, rgba(18, 62, 154, .08), transparent 28rem),
        linear-gradient(180deg, rgba(244, 191, 65, .13), rgba(255, 250, 238, 0));
}

.estate-tour__glass,
.mobile-price-bar {
    border-color: rgba(30, 48, 86, .12);
    background: rgba(255, 250, 238, .9);
    color: var(--hotel-navy);
}

.gallery-more,
.rating-line,
.auth-badge,
.profile-mini-card i,
.profile-panel__head > i,
.checkout-panel__head > i,
.checkout-success-card__icon,
.admin-resource-card__icon,
.admin-cell-title i,
.admin-edit-summary i,
.admin-detail-hero i,
.admin-action-list i {
    background: var(--hotel-yellow-soft);
    color: var(--hotel-navy);
    border-color: rgba(244, 191, 65, .34);
}

.rooms-hero {
    background:
        linear-gradient(180deg, rgba(14, 25, 48, .28), rgba(247, 238, 218, .92)),
        url("https://images.unsplash.com/photo-1566073771259-6a8506099945?auto=format&fit=crop&w=1800&q=80") center / cover;
}

.room-search-panel input,
.room-search-panel select,
.booking-card .form-control,
.booking-card .form-select,
.auth-form-card .form-control,
.form-control,
.form-select,
.checkout-static-field,
.auth-input-wrap {
    border-color: rgba(30, 48, 86, .14);
    background-color: rgba(255, 250, 238, .9);
    color: var(--hotel-navy);
}

.form-label,
.booking-card .form-label,
.checkout-form .form-label,
.auth-form-card .form-label,
.estate-contact-form .form-label,
.admin-field span {
    color: var(--hotel-muted);
}

.form-control::placeholder {
    color: rgba(24, 38, 72, .42);
}

.form-control:focus,
.form-select:focus,
.auth-input-wrap:focus-within {
    border-color: rgba(18, 62, 154, .34);
    background-color: #fffaf0;
    color: var(--hotel-navy);
    box-shadow: 0 0 0 .2rem rgba(18, 62, 154, .11);
}

.checkout-page,
.checkout-success-page,
.profile-page,
.auth-section,
.auth-section--login {
    background:
        radial-gradient(circle at 12% 8%, rgba(244, 191, 65, .18), transparent 26rem),
        radial-gradient(circle at 88% 18%, rgba(18, 62, 154, .08), transparent 26rem),
        linear-gradient(180deg, var(--hotel-bg) 0%, #f6edd6 100%);
}

.profile-page::before {
    background:
        linear-gradient(rgba(30, 48, 86, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(30, 48, 86, .035) 1px, transparent 1px);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, .45), transparent 72%);
}

.checkout-panel__head,
.profile-panel__head,
.admin-form-actions,
.admin-table-toolbar,
.admin-detail-hero,
.checkout-price-list,
.checkout-daily,
.checkout-total,
.payment-booking-box div,
.admin-resource-card__actions,
.admin-panel h2 {
    border-color: rgba(30, 48, 86, .1);
}

.checkout-addons label,
.checkout-success-detail div,
.checkout-success-room,
.payment-detail-list div,
.payment-booking-box,
.payment-slip-box,
.payment-slip-box,
.profile-detail-list div,
.profile-booking-list article,
.booking-detail-row,
.booking-detail-note,
.admin-row,
.admin-delete-detail div,
.admin-detail-grid div,
.admin-action-list a,
.admin-field--check {
    border-color: rgba(30, 48, 86, .1);
    background: rgba(255, 250, 238, .72);
    color: var(--hotel-text);
}

.payment-time-alert,
.room-search-alert {
    border-color: rgba(244, 191, 65, .36);
    background: rgba(244, 191, 65, .18);
    color: var(--hotel-navy);
}

.payment-time-alert b {
    color: var(--hotel-primary);
}

.payment-time-alert.is-expired {
    border-color: rgba(201, 75, 75, .28);
    background: rgba(201, 75, 75, .1);
}

.payment-time-alert.is-expired i,
.checkout-static-field.is-danger,
.admin-delete-panel__icon {
    color: #a13535;
}

.payment-qr-frame {
    border-color: rgba(30, 48, 86, .12);
    background: #fffaf0;
}

.payment-qr-placeholder {
    background: #f3ead4;
    color: var(--hotel-navy);
}

.payment-qr-placeholder span {
    color: var(--hotel-navy);
}

.room-availability-pill.is-available {
    border-color: rgba(47, 151, 91, .32);
    background: rgba(47, 151, 91, .1);
    color: #17643b;
}

.room-availability-pill.is-unavailable {
    border-color: rgba(201, 75, 75, .28);
    color: #9a2f2f;
}

.admin-body {
    background: #f6edd6;
}

.admin-sidebar {
    border-right-color: rgba(255, 250, 238, .16);
    background:
        linear-gradient(180deg, rgba(8, 28, 68, .98), rgba(5, 18, 46, .98)),
        radial-gradient(circle at top left, rgba(244, 191, 65, .18), transparent 18rem);
    box-shadow: 18px 0 54px rgba(10, 28, 60, .18);
}

.admin-brand,
.admin-sidebar__user,
.admin-nav-card {
    border-color: rgba(255, 250, 238, .14);
    background: rgba(255, 250, 238, .06);
}

.admin-brand,
.admin-brand strong,
.admin-sidebar__user strong,
.admin-nav a,
.admin-nav-parent {
    color: rgba(255, 250, 238, .86);
}

.admin-brand small,
.admin-nav-label,
.admin-nav-parent em,
.admin-nav-parent small,
.admin-subnav a,
.admin-sidebar__user small {
    color: rgba(255, 250, 238, .52);
}

.admin-nav a:hover,
.admin-nav a.is-active,
.admin-nav-parent.is-active,
.admin-subnav a:hover,
.admin-subnav a.is-active {
    border-color: rgba(244, 191, 65, .28);
    background: rgba(244, 191, 65, .12);
    color: #fffaf0;
}

.admin-nav i,
.admin-subnav a i {
    border-color: rgba(255, 250, 238, .12);
    background: rgba(255, 250, 238, .08);
    color: var(--hotel-accent);
}

.admin-topbar {
    border-bottom-color: rgba(30, 48, 86, .1);
    background: rgba(255, 250, 238, .86);
}

.admin-page {
    background:
        radial-gradient(circle at 92% 0%, rgba(18, 62, 154, .07), transparent 24rem),
        linear-gradient(180deg, var(--hotel-bg), #f6edd6);
}

.admin-breadcrumbs,
.admin-breadcrumbs a {
    color: rgba(24, 38, 72, .58);
}

.admin-table th,
.admin-table td {
    border-bottom-color: rgba(30, 48, 86, .08);
}

.admin-table th {
    background: rgba(18, 62, 154, .05);
    color: rgba(24, 38, 72, .58);
}

.admin-table td {
    color: rgba(24, 38, 72, .78);
}

.admin-table tbody tr:hover {
    background: rgba(18, 62, 154, .045);
}

.admin-table-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .35rem;
    min-width: 270px;
}

.admin-table-actions form {
    display: inline-flex;
    margin: 0;
}

.admin-table-actions .btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    min-height: 34px;
    white-space: nowrap;
}

.admin-table-actions .btn i {
    font-size: .95rem;
}

.admin-table-actions .btn-outline-danger {
    --bs-btn-color: #a13535;
    --bs-btn-border-color: rgba(201, 75, 75, .28);
    --bs-btn-hover-bg: rgba(201, 75, 75, .1);
    --bs-btn-hover-border-color: rgba(201, 75, 75, .42);
    --bs-btn-hover-color: #8f2020;
}

.admin-id {
    border-color: rgba(18, 62, 154, .16);
    color: var(--hotel-primary);
}

.admin-delete-panel__icon {
    background: rgba(201, 75, 75, .1);
}

@media (max-width: 991.98px) {
    .site-navbar {
        background: rgba(255, 250, 238, .94);
    }

    .estate-search-panel label {
        border-bottom-color: rgba(30, 48, 86, .1);
    }
}

@media (max-width: 575.98px) {
    body {
        background: var(--hotel-bg);
    }

    .auth-section--login {
        background:
            radial-gradient(circle at 12% 0%, rgba(244, 191, 65, .16), transparent 18rem),
            linear-gradient(180deg, var(--hotel-bg), #f6edd6);
    }

    .auth-mobile-card {
        border-color: rgba(30, 48, 86, .12);
        box-shadow: var(--hotel-shadow);
    }

    .mobile-price-bar {
        background: rgba(255, 250, 238, .94);
    }
}

/* Home hero title/layout polish */
.estate-hero__inner {
    min-height: clamp(760px, calc(100vh - 76px), 980px);
    padding-top: clamp(3.2rem, 6vw, 5.6rem);
    padding-bottom: clamp(2.6rem, 5vw, 4.4rem);
}

.estate-hero__copy {
    max-width: 860px;
}

.estate-hero__copy h1 {
    max-width: 820px;
    margin: .8rem 0 1rem;
    font-size: clamp(3.35rem, 5.8vw, 5.9rem);
    line-height: .94;
    text-wrap: balance;
}

.estate-hero__copy h1 span {
    display: block;
}

.hero-title-brand {
    color: #fffaf0;
}

.hero-title-promise {
    max-width: 760px;
    margin-top: .32rem;
    color: rgba(255, 250, 238, .94);
    font-size: .56em;
    font-weight: 850;
    line-height: 1.08;
}

.estate-hero__copy p {
    max-width: 720px;
    font-size: clamp(1.02rem, 1.25vw, 1.22rem);
    line-height: 1.7;
}

.estate-search-panel {
    margin-top: clamp(1.35rem, 2.5vw, 2rem);
}

.estate-hero-card {
    align-self: center;
}

@media (max-width: 1199.98px) {
    .estate-hero__inner {
        grid-template-columns: 1fr;
        min-height: auto;
        gap: 1.6rem;
    }

    .estate-hero-card {
        max-width: 560px;
    }
}

@media (max-width: 991.98px) {
    .estate-search-panel {
        grid-template-columns: 1fr;
    }

    .estate-search-panel label {
        border-right: 0;
        border-bottom: 1px solid rgba(30, 48, 86, .1);
        padding: .58rem .35rem;
    }

    .estate-search-panel .btn {
        order: 5;
        width: 100%;
    }

    .estate-calendar-box {
        order: 4;
    }
}

@media (max-width: 767.98px) {
    .estate-hero {
        min-height: auto;
    }

    .estate-hero__media {
        background-position: center top;
    }

    .estate-hero__overlay {
        background:
            linear-gradient(180deg, rgba(14, 25, 48, .28) 0%, rgba(14, 25, 48, .62) 34%, rgba(247, 238, 218, .92) 100%);
    }

    .estate-hero__inner {
        width: 100%;
        padding-top: clamp(2.1rem, 8vw, 3rem);
        padding-bottom: 2rem;
    }

    .estate-hero__copy {
        width: 100%;
        max-width: none;
    }

    .estate-hero__copy .estate-label {
        max-width: 100%;
        font-size: .82rem;
        line-height: 1.35;
    }

    .estate-hero__copy h1 {
        max-width: 100%;
        margin-top: .7rem;
        font-size: clamp(2.32rem, 11.2vw, 3.05rem);
        line-height: .98;
        text-wrap: balance;
    }

    .hero-title-promise {
        max-width: 12ch;
        margin-top: .4rem;
        font-size: .55em;
        line-height: 1.13;
    }

    .estate-hero__copy p {
        max-width: 31ch;
        font-size: 1rem;
        line-height: 1.58;
    }

    .estate-search-panel {
        width: 100%;
        margin-top: 1.2rem;
    }

    .estate-hero-card {
        display: none;
    }
}

/* Admin booking operations */
.admin-table-toolbar {
    align-items: flex-start;
    flex-wrap: wrap;
}

.admin-table-toolbar > div:first-child {
    flex: 0 0 auto;
    padding-top: .22rem;
}

.admin-toolbar-controls {
    display: grid;
    grid-template-columns: minmax(230px, 1.35fr) repeat(3, minmax(140px, .72fr)) repeat(3, minmax(145px, .72fr)) auto auto;
    align-items: center;
    gap: .65rem;
    flex: 1 1 860px;
    width: min(1180px, 100%);
}

.admin-toolbar-controls .form-control,
.admin-toolbar-controls .form-select,
.admin-toolbar-controls .btn {
    min-height: 42px;
}

.admin-toolbar-search {
    min-width: 0;
}

.admin-toolbar-date {
    min-width: 145px;
}

.admin-status {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: .2rem .55rem;
    border: 1px solid rgba(30, 48, 86, .1);
    border-radius: 999px;
    background: rgba(255, 250, 238, .72);
    color: var(--hotel-navy);
    font-size: .82rem;
    font-weight: 850;
}

.admin-status--pending {
    border-color: rgba(210, 157, 41, .28);
    background: rgba(255, 235, 178, .72);
    color: #705014;
}

.hotel-swal-popup,
.hotel-swal-toast {
    border: 1px solid rgba(30, 48, 86, .12);
    border-radius: 10px;
    background: #fffaf0;
    box-shadow: 0 24px 70px rgba(24, 38, 72, .18);
    color: var(--hotel-navy);
    font-family: inherit;
}

.hotel-swal-popup {
    padding: 1.15rem;
}

.hotel-swal-popup .swal2-title {
    color: var(--hotel-navy);
    font-size: 1.35rem;
    font-weight: 950;
    letter-spacing: 0;
}

.hotel-swal-popup .swal2-html-container {
    color: rgba(24, 38, 72, .7);
    font-size: .98rem;
    line-height: 1.55;
}

.hotel-swal-popup .swal2-actions {
    gap: .6rem;
}

.hotel-swal-popup .swal2-icon {
    margin-top: .65rem;
}

.hotel-swal-toast {
    padding: .8rem .95rem;
}

.hotel-swal-toast .swal2-title {
    color: var(--hotel-navy);
    font-size: .98rem;
    font-weight: 850;
    line-height: 1.4;
}

.swal2-container {
    z-index: 20000;
}

.admin-report-panel {
    margin-bottom: 1rem;
}

.admin-status-report-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: .75rem;
}

.admin-status-report-card {
    display: block;
    min-height: 92px;
    border: 1px solid rgba(30, 48, 86, .1);
    border-radius: 8px;
    background: rgba(255, 250, 238, .72);
    color: var(--hotel-text);
    padding: .9rem;
    text-decoration: none;
}

.admin-status-report-card:hover {
    border-color: rgba(18, 62, 154, .28);
    background: #fff;
}

.admin-status-report-card span {
    display: block;
    color: rgba(24, 38, 72, .62);
    font-size: .86rem;
}

.admin-status-report-card strong {
    display: block;
    color: var(--hotel-navy);
    font-size: 2rem;
    font-weight: 950;
    line-height: 1;
    margin-top: .45rem;
}

.admin-metric-card--money strong {
    font-size: clamp(1.7rem, 2.4vw, 2.1rem);
}

@media (max-width: 1199.98px) {
    .admin-status-report-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .admin-status-report-grid {
        grid-template-columns: 1fr;
    }
}

.pending-payment-banner {
    position: sticky;
    top: 76px;
    z-index: 1010;
    border-bottom: 1px solid rgba(244, 191, 65, .36);
    background: rgba(255, 248, 224, .96);
    box-shadow: 0 12px 30px rgba(24, 38, 72, .08);
    color: var(--hotel-navy);
}

.pending-payment-banner__inner {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .78rem 0;
}

.pending-payment-banner__inner > i {
    display: grid;
    place-items: center;
    width: 40px;
    height: 40px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: rgba(244, 191, 65, .28);
    color: #9a6a09;
    font-size: 1.2rem;
}

.pending-payment-banner strong,
.pending-payment-banner span {
    display: block;
}

.pending-payment-banner strong {
    color: var(--hotel-navy);
    font-weight: 900;
}

.pending-payment-banner span {
    color: rgba(24, 38, 72, .72);
    font-size: .92rem;
}

.pending-payment-banner b {
    color: var(--hotel-primary);
    font-weight: 950;
}

.pending-payment-banner .btn {
    flex: 0 0 auto;
    margin-left: auto;
    white-space: nowrap;
}

@media (max-width: 575.98px) {
    .pending-payment-banner {
        top: 62px;
    }

    .pending-payment-banner__inner {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .pending-payment-banner .btn {
        width: 100%;
        margin-left: 0;
    }
}

.admin-status--checking {
    border-color: rgba(0, 117, 201, .28);
    background: rgba(226, 243, 255, .86);
    color: #075985;
}

.admin-status--confirmed,
.admin-status--completed,
.admin-status--checked-in {
    border-color: rgba(34, 145, 78, .25);
    background: rgba(223, 247, 231, .86);
    color: #126b35;
}

.admin-status--checked-out,
.admin-status--refunded {
    border-color: rgba(79, 96, 122, .18);
    background: rgba(239, 243, 247, .9);
    color: #3b4b64;
}

.admin-status--cancelled,
.admin-status--failed {
    border-color: rgba(197, 64, 64, .24);
    background: rgba(255, 232, 232, .88);
    color: #9b1c1c;
}

.admin-status--neutral {
    border-color: rgba(30, 48, 86, .12);
    background: rgba(255, 250, 238, .78);
    color: var(--hotel-navy);
}

.admin-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border-top: 1px solid rgba(30, 48, 86, .1);
}

.admin-pagination > span {
    color: var(--hotel-text-soft);
    font-size: .92rem;
}

.admin-pagination > div {
    display: flex;
    align-items: center;
    gap: .35rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.admin-relation-panel {
    margin-top: 1.15rem;
}

.admin-relation-form {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) auto;
    gap: .75rem;
    margin-bottom: 1rem;
}

.admin-empty-state--compact {
    min-height: 150px;
}

.admin-recent-list a span {
    display: grid;
    gap: .18rem;
}

.admin-recent-list a span strong {
    color: var(--hotel-navy);
}

.admin-recent-list a span small {
    color: var(--hotel-text-soft);
}

.admin-recent-list a em {
    color: var(--hotel-primary);
    font-style: normal;
    font-weight: 900;
}

.admin-booking-room-row {
    gap: 1rem;
}

.admin-booking-room-row form,
.admin-inline-form,
.admin-form-actions form {
    display: flex;
    align-items: center;
    gap: .55rem;
}

.admin-booking-room-row .form-select {
    min-width: 180px;
}

.admin-inline-form {
    flex-wrap: wrap;
}

.admin-inline-form .form-control,
.admin-form-actions .form-control {
    min-width: min(260px, 100%);
}

@media (max-width: 991.98px) {
    .admin-toolbar-controls {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
    }

    .admin-toolbar-search {
        grid-column: 1 / -1;
    }

    .admin-booking-room-row,
    .admin-booking-room-row form,
    .admin-form-actions form {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-booking-room-row .form-select,
    .admin-booking-room-row .btn {
        width: 100%;
    }

    .admin-pagination,
    .admin-relation-form {
        align-items: stretch;
        grid-template-columns: 1fr;
    }

    .admin-pagination {
        flex-direction: column;
    }

    .admin-pagination > div {
        justify-content: center;
    }
}

@media (max-width: 575.98px) {
    .admin-table-toolbar {
        padding: .85rem;
    }

    .admin-table-toolbar > div:first-child,
    .admin-toolbar-controls {
        width: 100%;
    }

    .admin-toolbar-controls {
        grid-template-columns: 1fr;
        gap: .5rem;
    }

    .admin-toolbar-controls .btn {
        width: 100%;
    }
}
