/* === CUSTOM STYLES === */
.bg-gradient {
    background: linear-gradient(135deg, #FF5A5F 0%, #E00B41 100%);
}

.listing-card {
    transition: transform 0.2s, box-shadow 0.2s;
    border-radius: 16px;
    overflow: hidden;
}

.listing-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0,0,0,0.15) !important;
}

.category-item {
    min-width: 80px;
    transition: all 0.2s;
    padding: 8px;
    border-radius: 8px;
}

.category-item:hover {
    background: #f8f9fa;
    color: #222;
}

.sticky-top {
    z-index: 1020;
}

/* Auth pages */
.auth-page .card {
    border-radius: 16px;
}

/* Host pages */
.host-nav {
    background: #212529;
}

/* Booking status badges */
.badge-pending { background: #FEF3C7; color: #92400E; }
.badge-accepted { background: #D1FAE5; color: #065F46; }
.badge-rejected { background: #FEE2E2; color: #991B1B; }
.badge-cancelled { background: #F3F4F6; color: #374151; }
.badge-completed { background: #DBEAFE; color: #1E40AF; }

/* Admin */
.admin-wrapper {
    min-height: 100vh;
}

/* Message chat */
.message-bubble {
    max-width: 70%;
    padding: 12px 16px;
    border-radius: 16px;
    margin-bottom: 8px;
}

.message-sent {
    background: #FF5A5F;
    color: white;
    margin-left: auto;
    border-bottom-right-radius: 4px;
}

.message-received {
    background: #F3F4F6;
    color: #222;
    border-bottom-left-radius: 4px;
}

/* Responsive */
@media (max-width: 768px) {
    .hero-section h1 { font-size: 2rem; }
    .listing-card { margin-bottom: 1rem; }
}


/* Modern responsive fixes */
.hero-section, section.bg-gradient { border-radius: 0 0 28px 28px; }
.card-img-top { background:#f2f2f2; }
.listing-card .card-title { font-size: 1rem; }
@media (max-width: 768px) {
    main.py-4 { padding-top: 1rem !important; }
    section.bg-gradient { padding: 2.2rem 1rem !important; margin-bottom: 1.5rem !important; }
    section.bg-gradient h1 { font-size: 2rem !important; line-height: 1.15; }
    section.bg-gradient .lead { font-size: 1rem; }
    .category-item { min-width: 72px; }
    .listing-card img.card-img-top { height: 210px !important; }
    .navbar-nav { align-items: flex-start !important; padding-top: 1rem; }
    .container { max-width: 100%; }
}
@media (min-width: 992px) {
    .listing-card img.card-img-top { height: 260px !important; }
}


/* === Listing card clean responsive redesign === */
.listings-grid { align-items: stretch; }
.listing-card-link { display: block; height: 100%; }
.listing-card {
    border-radius: 20px !important;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08) !important;
    transition: transform .18s ease, box-shadow .18s ease;
    border: 1px solid rgba(15, 23, 42, 0.06) !important;
}
.listing-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.13) !important;
}
.listing-image-wrap {
    width: 100%;
    aspect-ratio: 4 / 3;
    background: #eef1f4;
    overflow: hidden;
}
.listing-card img.card-img-top,
.listing-card .listing-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block;
    transition: transform .25s ease;
}
.listing-card:hover .listing-img { transform: scale(1.035); }
.listing-card .card-body { padding: 14px 15px 16px; min-height: 148px; }
.listing-card .listing-title {
    font-size: 1.02rem;
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: .45rem;
    color: #161616;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.55em;
}
.listing-card .small { line-height: 1.35; }
.listing-price { font-size: 1.04rem; padding-top: 6px; }
.like-btn {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    border: 0 !important;
    box-shadow: 0 6px 16px rgba(0,0,0,.12);
}
.like-btn:hover { transform: scale(1.04); }

@media (min-width: 992px) {
    .listings-grid > [class*="col-"] { display: flex; }
    .listing-card { width: 100%; }
}
@media (max-width: 575.98px) {
    .listings-grid { --bs-gutter-y: 1rem; }
    .listing-card { border-radius: 18px !important; }
    .listing-image-wrap { aspect-ratio: 16 / 11; }
    .listing-card .card-body { padding: 13px 14px 15px; min-height: auto; }
    .listing-card .listing-title { font-size: 1rem; min-height: auto; }
    .listing-price { font-size: 1rem; }
}


/* === Home page compact hero/layout fix === */
main.py-4 { padding-top: 0 !important; }
.home-hero {
    background: linear-gradient(135deg, #fff5f5 0%, #ffffff 52%, #f8fafc 100%);
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    padding: 54px 0 34px;
}
.home-hero-inner {
    max-width: 1120px;
    margin: 0 auto;
}
.home-hero-text {
    text-align: center;
    max-width: 760px;
    margin: 0 auto 26px;
}
.hero-badge {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(224, 11, 65, .14);
    background: rgba(255, 90, 95, .08);
    color: #e00b41;
    padding: 7px 14px;
    border-radius: 999px;
    font-weight: 700;
    font-size: .9rem;
    margin-bottom: 14px;
}
.home-hero h1 {
    font-size: clamp(2rem, 4vw, 3.8rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
    font-weight: 800;
    color: #111827;
    margin: 0 0 12px;
}
.home-hero p {
    font-size: clamp(1rem, 1.5vw, 1.2rem);
    color: #64748b;
    margin: 0;
}
.home-search {
    display: grid;
    grid-template-columns: minmax(220px, 1.45fr) minmax(150px, .9fr) minmax(150px, .9fr) minmax(130px, .75fr) minmax(150px, .75fr);
    gap: 10px;
    align-items: stretch;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.10);
    box-shadow: 0 18px 45px rgba(15, 23, 42, .10);
    padding: 10px;
    border-radius: 22px;
}
.search-field {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 16px;
    padding: 9px 12px;
    background: #fff;
    min-width: 0;
}
.search-field label {
    display: block;
    font-size: .74rem;
    line-height: 1;
    color: #64748b;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px;
}
.search-field input,
.search-field select {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    font-size: 1rem;
    color: #111827;
    padding: 0;
    min-height: 24px;
}
.search-submit {
    border: 0;
    border-radius: 16px;
    background: #1f2937;
    color: #fff;
    font-weight: 800;
    font-size: 1rem;
    padding: 0 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 62px;
}
.search-submit:hover { background: #111827; }
.container.mb-4 { margin-top: 0 !important; }
.category-item { color: #64748b !important; }
.category-item:hover { color: #111827 !important; }
section.container.mb-5 { padding-top: 6px; }

@media (max-width: 991.98px) {
    .home-hero { padding: 34px 0 24px; }
    .home-search { grid-template-columns: 1fr 1fr; border-radius: 20px; }
    .search-city { grid-column: 1 / -1; }
    .search-submit { grid-column: 1 / -1; min-height: 54px; }
}
@media (max-width: 575.98px) {
    .home-hero { padding: 26px 0 18px; }
    .home-hero-text { text-align: left; margin-bottom: 18px; }
    .home-search { grid-template-columns: 1fr; gap: 8px; padding: 8px; border-radius: 18px; }
    .search-city, .search-submit { grid-column: auto; }
    .search-field { border-radius: 14px; padding: 10px 12px; }
    .home-hero h1 { font-size: 2.05rem; }
    .home-hero p { font-size: .98rem; }
    .hero-badge { font-size: .82rem; padding: 6px 12px; }
    .category-item { min-width: 68px; font-size: .86rem; }
    .container.mb-4 .d-flex { gap: 14px !important; }
}

/* === Mobile Airbnb-style search bar === */
.mobile-airbnb-search { display: none; }

@media (max-width: 767.98px) {
    .desktop-search { display: none !important; }
    .home-hero {
        padding: 18px 0 14px !important;
        background: linear-gradient(180deg, #ffffff 0%, #fff7f7 100%);
    }
    .home-hero-text {
        margin-bottom: 14px !important;
    }
    .home-hero-text .hero-badge,
    .home-hero-text h1,
    .home-hero-text p {
        display: none;
    }
    .mobile-airbnb-search {
        display: block;
        width: 100%;
        max-width: 520px;
        margin: 0 auto;
    }
    .mobile-search-pill {
        display: flex;
        align-items: center;
        gap: 12px;
        background: #fff;
        border: 1px solid rgba(15, 23, 42, .10);
        border-radius: 999px;
        padding: 10px 10px 10px 16px;
        box-shadow: 0 8px 28px rgba(15, 23, 42, .16);
        min-height: 64px;
    }
    .mobile-search-icon {
        width: 34px;
        height: 34px;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #111827;
        font-size: 1.08rem;
        flex: 0 0 auto;
    }
    .mobile-search-text {
        flex: 1;
        min-width: 0;
    }
    .mobile-search-text input {
        width: 100%;
        border: 0;
        outline: 0;
        background: transparent;
        padding: 0;
        font-weight: 800;
        font-size: 1rem;
        color: #111827;
    }
    .mobile-search-text input::placeholder { color: #111827; opacity: 1; }
    .mobile-search-subtitle {
        margin-top: 2px;
        color: #64748b;
        font-size: .78rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .mobile-search-button {
        width: 42px;
        height: 42px;
        border: 0;
        border-radius: 50%;
        background: #ff385c;
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.05rem;
        flex: 0 0 auto;
        box-shadow: 0 6px 14px rgba(255,56,92,.28);
    }
    .mobile-search-options {
        display: grid;
        grid-template-columns: 1fr 1fr 82px;
        gap: 8px;
        margin-top: 10px;
    }
    .mobile-search-options label {
        background: #fff;
        border: 1px solid rgba(15, 23, 42, .10);
        border-radius: 16px;
        padding: 9px 10px;
        box-shadow: 0 4px 14px rgba(15, 23, 42, .07);
        min-width: 0;
    }
    .mobile-search-options span {
        display: block;
        font-size: .68rem;
        line-height: 1;
        color: #64748b;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .03em;
        margin-bottom: 6px;
    }
    .mobile-search-options input,
    .mobile-search-options select {
        width: 100%;
        border: 0;
        outline: 0;
        background: transparent;
        padding: 0;
        font-size: .82rem;
        color: #111827;
        min-height: 22px;
    }
    .container.mb-4 { margin-top: 4px !important; }
}

@media (max-width: 374.98px) {
    .mobile-search-options { grid-template-columns: 1fr; }
    .mobile-search-subtitle { font-size: .73rem; }
}

/* === AZStay search/category modern patch === */
.search-field select,
.mobile-search-text select {
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}
.mobile-search-text select {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    padding: 0;
    font-weight: 800;
    font-size: 1rem;
    color: #111827;
}
.mobile-search-text select:invalid { color: #111827; }
.az-categories {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 6px 2px 14px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.az-categories::-webkit-scrollbar { display: none; }
.az-categories .category-item {
    min-width: 94px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 14px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    color: #334155 !important;
    text-decoration: none !important;
    box-shadow: 0 6px 18px rgba(15,23,42,.06);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, color .18s ease;
    white-space: nowrap;
}
.az-categories .category-item:hover {
    transform: translateY(-2px);
    border-color: rgba(255,56,92,.35);
    color: #111827 !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.10);
    background: #fff;
}
.category-icon {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: #f8fafc;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ff385c;
    font-size: 1.15rem;
}
.az-categories .category-item span:last-child {
    font-size: .86rem;
    font-weight: 800;
}
.filter-card {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 26px;
    box-shadow: 0 16px 46px rgba(15,23,42,.08);
    padding: 20px;
}
.filter-card-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}
.filter-eyebrow {
    display: block;
    color: #ff385c;
    font-size: .78rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 4px;
}
.filter-card h1 {
    font-size: clamp(1.3rem, 2vw, 1.8rem);
    font-weight: 900;
    letter-spacing: -.03em;
    margin: 0;
    color: #111827;
}
.filter-clear {
    color: #64748b;
    font-weight: 800;
    text-decoration: none;
    padding: 9px 12px;
    border-radius: 999px;
    background: #f8fafc;
    white-space: nowrap;
}
.filter-clear:hover { color: #111827; background: #eef2f7; }
.filter-grid {
    display: grid;
    grid-template-columns: minmax(210px, 1.3fr) minmax(150px, .9fr) minmax(120px, .65fr) minmax(120px, .65fr) minmax(120px, .65fr) minmax(124px, .55fr);
    gap: 10px;
    align-items: stretch;
}
.filter-field {
    display: block;
    margin: 0;
    background: #f8fafc;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 18px;
    padding: 10px 12px;
    min-width: 0;
}
.filter-field span {
    display: block;
    font-size: .7rem;
    line-height: 1;
    color: #64748b;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: 7px;
}
.filter-field input,
.filter-field select {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #111827;
    font-weight: 750;
    font-size: .98rem;
    padding: 0;
    min-height: 24px;
}
.filter-submit {
    border: 0;
    border-radius: 18px;
    background: #ff385c;
    color: #fff;
    font-weight: 900;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 12px 24px rgba(255,56,92,.22);
    min-height: 58px;
}
.filter-submit:hover { background: #e61e4d; }
@media (max-width: 991.98px) {
    .filter-grid { grid-template-columns: 1fr 1fr; }
    .filter-city, .filter-submit { grid-column: 1 / -1; }
}
@media (max-width: 575.98px) {
    .filter-card { margin-left: -2px; margin-right: -2px; padding: 14px; border-radius: 24px; box-shadow: 0 12px 34px rgba(15,23,42,.08); }
    .filter-card-head { align-items: flex-start; margin-bottom: 12px; }
    .filter-clear { font-size: .86rem; padding: 7px 10px; }
    .filter-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .filter-field { border-radius: 16px; padding: 9px 10px; }
    .filter-field input, .filter-field select { font-size: .9rem; }
    .filter-submit { min-height: 52px; border-radius: 16px; }
    .az-categories { gap: 10px; padding-bottom: 12px; margin-left: -2px; margin-right: -2px; }
    .az-categories .category-item { min-width: 82px; padding: 10px 11px; border-radius: 16px; box-shadow: 0 5px 14px rgba(15,23,42,.06); }
    .category-icon { width: 34px; height: 34px; font-size: 1rem; }
    .az-categories .category-item span:last-child { font-size: .78rem; }
}


/* === Clickable listing cards fix === */
.listing-card-link { cursor: pointer; color: inherit; }
.listing-card-link:focus { outline: none; }
.listing-card-link:focus .listing-card { box-shadow: 0 0 0 3px rgba(255,90,95,.22), 0 14px 34px rgba(15,23,42,.13) !important; }
.like-btn { position: relative; z-index: 5; }


/* === Final responsive polish: cards, detail page, amenities === */
@media (max-width: 575.98px) {
  .listings-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px !important; margin-left: 0 !important; margin-right: 0 !important; }
  .listings-grid > [class*="col-"] { width: auto !important; max-width: none !important; padding-left: 0 !important; padding-right: 0 !important; }
  .listing-card { border-radius: 16px !important; box-shadow: 0 6px 18px rgba(15,23,42,.08) !important; }
  .listing-img { height: 135px !important; }
  .listing-title { font-size: .88rem !important; line-height: 1.2 !important; min-height: 2.1em; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
  .listing-card .card-body { padding: 10px !important; }
  .listing-price { font-size: .9rem !important; }
  .listing-card .small { font-size: .72rem !important; }
}

.listing-gallery-desktop { grid-template-columns: 1fr 1fr; gap: 8px; height: 430px; }
.listing-gallery-desktop img { width: 100%; height: 100%; object-fit: cover; }
.gallery-main img { border-radius: 22px 0 0 22px; }
.gallery-side { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.gallery-side img:nth-child(2) { border-radius: 0 22px 0 0; }
.gallery-side img:nth-child(4) { border-radius: 0 0 22px 0; }
.listing-gallery-mobile { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; gap: 0; margin-left: -12px; margin-right: -12px; -webkit-overflow-scrolling: touch; }
.listing-gallery-mobile::-webkit-scrollbar { display: none; }
.mobile-slide { position: relative; flex: 0 0 100%; scroll-snap-align: start; }
.mobile-slide img { width: 100%; height: 260px; object-fit: cover; display: block; }
.slide-count { position: absolute; right: 12px; bottom: 12px; background: rgba(0,0,0,.68); color: #fff; border-radius: 999px; padding: 5px 10px; font-weight: 800; font-size: .78rem; }

.listing-stats-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.listing-stat { border: 1px solid rgba(15,23,42,.08); border-radius: 16px; padding: 13px 10px; display: flex; align-items: center; justify-content: center; gap: 8px; background: #fff; font-weight: 800; color: #111827; min-width: 0; }
.listing-stat i { font-size: 1.15rem; color: #ff385c; flex: 0 0 auto; }
.listing-stat span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.amenities-compact { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.amenity-chip { border: 1px solid rgba(15,23,42,.08); border-radius: 14px; padding: 10px 12px; display: flex; align-items: center; gap: 8px; background: #fff; font-weight: 700; min-width: 0; }
.amenity-chip i { color: #198754; flex: 0 0 auto; }
.amenity-chip span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.amenities-picker { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.amenity-check { border: 1px solid rgba(15,23,42,.08); border-radius: 12px; padding: 9px 10px 9px 34px; margin: 0; background: #fff; }

@media (max-width: 991.98px) {
  .listing-detail-layout { display: flex; flex-direction: column; }
  .listing-booking-col { order: 1; margin-bottom: 18px; }
  .listing-main-col { order: 2; }
  .booking-card { position: static !important; border-radius: 20px !important; }
}
@media (max-width: 575.98px) {
  .mobile-slide img { height: 235px; }
  .listing-stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
  .listing-stat { padding: 10px 8px; font-size: .82rem; border-radius: 14px; justify-content: flex-start; }
  .amenities-compact { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 7px; }
  .amenity-chip { padding: 8px 6px; border-radius: 12px; gap: 5px; font-size: .72rem; justify-content: center; text-align: center; }
  .amenity-chip i { display: none; }
  .mobile-amenities-preview + .collapse, .amenities-section .collapse:not(.show) { display: none !important; }
  .amenities-picker { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 7px; }
  .amenity-check { padding: 8px 6px 8px 28px; font-size: .74rem; border-radius: 11px; }
  .contact-actions .btn { font-size: .86rem; padding: 9px 10px; }
}

/* === CLEAN LISTING DETAIL HOTFIX === */
.listing-page{max-width:1180px}.listing-titlebar h1{font-size:1.75rem;font-weight:800;margin:0 0 6px}.listing-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#64748b;font-size:.95rem}.az-detail-gallery{position:relative;z-index:1;background:#fff}.az-gallery-desktop{display:grid;grid-template-columns:1fr 1fr;gap:8px;height:430px;overflow:hidden;border-radius:24px}.az-gallery-desktop img{width:100%;height:100%;object-fit:cover;display:block}.az-main-img{border-radius:24px 0 0 24px}.az-gallery-side{display:grid;grid-template-columns:1fr 1fr;gap:8px}.az-gallery-side img:nth-child(2){border-radius:0 24px 0 0}.az-gallery-side img:nth-child(4){border-radius:0 0 24px 0}.az-gallery-mobile{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;margin-left:-12px;margin-right:-12px;background:#fff}.az-gallery-mobile::-webkit-scrollbar{display:none}.az-mobile-slide{position:relative;flex:0 0 100%;scroll-snap-align:start}.az-mobile-slide img{width:100%;height:260px;object-fit:cover;display:block}.az-mobile-slide span{position:absolute;right:14px;bottom:14px;background:rgba(0,0,0,.7);color:#fff;border-radius:999px;padding:5px 11px;font-size:.8rem;font-weight:800}.detail-section{position:relative;z-index:2;background:#fff;padding:24px 0;border-bottom:1px solid #e5e7eb}.detail-section h2{font-size:1.35rem;font-weight:800;margin-bottom:16px}.host-section{display:flex;align-items:center;justify-content:space-between;gap:16px}.host-left{display:flex;align-items:center;gap:14px}.host-avatar{width:58px;height:58px;border-radius:50%;object-fit:cover;background:#e5e7eb}.host-left h5{font-weight:800;margin:0 0 3px}.host-left p{margin:0;color:#64748b}.host-actions{display:flex;gap:8px;flex-wrap:wrap}.host-actions .btn{border-radius:999px;font-weight:700}.az-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.az-stats-grid>div{border:1px solid #e5e7eb;border-radius:18px;padding:15px 10px;background:#fff;display:flex;align-items:center;justify-content:center;gap:7px;min-width:0}.az-stats-grid i{color:#ff385c;font-size:1.1rem}.az-stats-grid strong{font-weight:900}.az-stats-grid span{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.description-text{font-size:1rem;line-height:1.75;color:#334155}.az-amenities-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.az-amenity{border:1px solid #e5e7eb;border-radius:14px;background:#fff;padding:11px 12px;display:flex;align-items:center;gap:8px;font-weight:750;min-width:0}.az-amenity i{color:#0f9f6e;flex:0 0 auto}.az-amenity span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.more-grid{margin-top:10px}.booking-card-clean{position:sticky;top:96px;background:#fff;border:1px solid #e5e7eb;border-radius:22px;box-shadow:0 12px 32px rgba(15,23,42,.12);padding:22px;z-index:3}.price-line{display:flex;align-items:flex-end;gap:8px;margin-bottom:18px}.price-line strong{font-size:1.75rem;font-weight:900}.price-line span{color:#64748b;margin-bottom:4px}.date-box{display:grid;grid-template-columns:1fr 1fr;border:1px solid #d1d5db;border-radius:16px;overflow:hidden;margin-bottom:12px}.date-box>div{padding:11px 12px}.date-box>div:first-child{border-right:1px solid #d1d5db}.date-box label,.guest-label{display:block;font-size:.72rem;text-transform:uppercase;font-weight:900;color:#111827;margin-bottom:5px}.date-box input{border:0;outline:0;width:100%;font-weight:700}.booking-card-clean .btn{border-radius:14px;font-weight:800}.safe-note{text-align:center;color:#64748b;font-size:.88rem;margin:12px 0 0}.review-row{display:flex;gap:14px;margin-bottom:20px}.review-row img{width:48px;height:48px;border-radius:50%;object-fit:cover}.review-row h6{font-weight:800;margin-bottom:2px}.review-row small{color:#64748b}.review-row p{margin:4px 0 0}.flatpickr-day.disabled,.flatpickr-day.disabled:hover{background:#ffe1e1!important;color:#b00020!important;text-decoration:line-through}
@media(max-width:991.98px){.booking-card-clean{position:static;margin-bottom:8px}.listing-page .row>aside{order:1}.listing-page .row>main{order:2}.host-section{align-items:flex-start;flex-direction:column}.host-actions{width:100%}.host-actions .btn{flex:1}.az-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:575.98px){.listing-page{padding-left:12px!important;padding-right:12px!important}.listing-titlebar{padding-top:4px}.listing-titlebar h1{font-size:1.25rem}.listing-meta{font-size:.82rem}.az-mobile-slide img{height:240px}.detail-section{padding:18px 0}.detail-section h2{font-size:1.1rem;margin-bottom:12px}.az-stats-grid{gap:8px}.az-stats-grid>div{padding:10px 8px;border-radius:14px;justify-content:flex-start}.az-stats-grid span{font-size:.78rem}.az-amenities-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.az-amenity{padding:8px 6px;border-radius:12px;justify-content:center;text-align:center;font-size:.72rem}.az-amenity i{display:none}.booking-card-clean{border-radius:18px;padding:16px;box-shadow:0 8px 22px rgba(15,23,42,.1)}.price-line strong{font-size:1.45rem}.date-box>div{padding:9px 10px}.host-actions .btn{font-size:.86rem;padding:9px 8px}.review-row{gap:10px}.review-row img{width:42px;height:42px}}

/* Custom site date picker (prevents phone/PC default browser calendar) */
input.js-date-picker,
#checkIn,
#checkOut{
  cursor:pointer;
  background:#fff!important;
}
.flatpickr-calendar{
  border:0!important;
  border-radius:24px!important;
  box-shadow:0 18px 50px rgba(15,23,42,.18)!important;
  overflow:hidden!important;
  font-family:inherit!important;
  z-index:99999!important;
}
.flatpickr-months{
  background:#fff!important;
  padding:12px 10px 4px!important;
}
.flatpickr-current-month{font-weight:800!important;}
.flatpickr-weekdays{padding-top:6px!important;}
.flatpickr-day{
  border-radius:999px!important;
  font-weight:650!important;
}
.flatpickr-day.today{border-color:#ff385c!important;}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange{
  background:#ff385c!important;
  border-color:#ff385c!important;
  color:#fff!important;
}
.flatpickr-day:hover{background:#fff1f4!important;border-color:#fff1f4!important;}
@media (max-width: 576px){
  .flatpickr-calendar{
    width:calc(100vw - 24px)!important;
    max-width:380px!important;
    left:12px!important;
    right:12px!important;
  }
  .flatpickr-rContainer,
  .flatpickr-days,
  .dayContainer{width:100%!important;min-width:100%!important;max-width:100%!important;}
  .flatpickr-day{max-width:14.285%!important;}
}

/* Contact card on listing detail */
.contact-card-clean{background:#fff;border:1px solid #e5e7eb;border-radius:22px;box-shadow:0 10px 26px rgba(15,23,42,.08);padding:20px;position:relative;z-index:3}.contact-card-clean h5{font-weight:850;margin-bottom:6px}.contact-card-clean .btn{border-radius:14px;font-weight:800}.contact-actions .btn{display:inline-flex;align-items:center;justify-content:center;gap:5px}
@media(max-width:991.98px){.contact-card-clean{margin-bottom:18px}.contact-actions{display:grid;grid-template-columns:1fr;gap:8px}.contact-actions .btn{width:100%}}

.contact-visible-box{background:#fff;border:1px solid #eee;border-radius:18px;padding:22px;margin:18px 0;box-shadow:0 8px 24px rgba(0,0,0,.04)}
.contact-actions .btn{border-radius:12px;font-weight:700}

/* Airbnb-style listing gallery + full screen photo viewer */
.az-detail-gallery{position:relative}
.az-gallery-photo,.az-mobile-slide{border:0;padding:0;margin:0;background:transparent;display:block;cursor:pointer;overflow:hidden;text-align:left}
.az-gallery-photo img,.az-mobile-slide img{transition:transform .25s ease, filter .25s ease}
.az-gallery-photo:hover img{filter:brightness(.88);transform:scale(1.015)}
.az-main-photo{height:100%}
.az-gallery-side .az-gallery-photo{height:100%}
.az-gallery-side .az-gallery-photo:nth-child(2) img{border-radius:0 24px 0 0}
.az-gallery-side .az-gallery-photo:nth-child(4) img{border-radius:0 0 24px 0}
.az-show-all-photos{position:absolute;right:18px;bottom:18px;z-index:5;border:1px solid #111827;background:#fff;color:#111827;border-radius:12px;padding:9px 14px;font-weight:800;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.az-photo-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.96);z-index:99999;display:none;align-items:center;justify-content:center;touch-action:pan-y}
.az-photo-lightbox.active{display:flex}
.az-photo-lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:10px;user-select:none;-webkit-user-drag:none}
.az-lightbox-close{position:absolute;top:18px;right:22px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:34px;line-height:40px;z-index:2}
.az-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:0;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;font-size:46px;line-height:44px;z-index:2}
.az-lightbox-prev{left:24px}.az-lightbox-next{right:24px}
.az-lightbox-counter{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);background:rgba(255,255,255,.14);color:#fff;border-radius:999px;padding:7px 14px;font-weight:800}
@media (max-width:767.98px){
  .az-mobile-slide{position:relative;flex:0 0 100%;scroll-snap-align:start}
  .az-mobile-slide img{height:320px}
  .az-photo-lightbox img{max-width:100vw;max-height:82vh;border-radius:0}
  .az-lightbox-nav{display:none}
  .az-lightbox-close{top:14px;right:14px;background:rgba(255,255,255,.18)}
  .az-lightbox-counter{bottom:18px}
}

/* Modern PC/mobile gallery fix */
.az-gallery-desktop{grid-template-columns:2fr 1fr;height:460px;border-radius:28px;box-shadow:0 10px 30px rgba(15,23,42,.08)}
.az-gallery-photo{position:relative;background:#f3f4f6}
.az-gallery-photo:after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:.2s ease;pointer-events:none}
.az-gallery-photo:hover:after{background:rgba(0,0,0,.10)}
.az-show-all-photos{display:inline-flex;align-items:center;gap:8px;border:0!important;background:rgba(255,255,255,.96)!important;backdrop-filter:blur(12px);border-radius:999px!important;padding:12px 18px!important;font-weight:900!important;box-shadow:0 12px 34px rgba(0,0,0,.22)!important;transition:transform .18s ease, box-shadow .18s ease;cursor:pointer!important}
.az-show-all-photos:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(0,0,0,.28)!important}
.az-lightbox-open{overflow:hidden!important}
.az-photo-lightbox{background:#0b0b0c!important;flex-direction:column;padding:78px 28px 118px;gap:16px}
.az-lightbox-topbar{position:absolute;top:0;left:0;right:0;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 26px;color:#fff;background:linear-gradient(180deg,rgba(0,0,0,.72),rgba(0,0,0,0));z-index:4}
.az-lightbox-title{font-weight:900;font-size:1.05rem;display:flex;align-items:center;gap:9px}
.az-lightbox-close{position:static!important;display:inline-flex;align-items:center;justify-content:center;width:44px!important;height:44px!important;font-size:18px!important;line-height:1!important;background:rgba(255,255,255,.14)!important;transition:.18s ease}
.az-lightbox-close:hover,.az-lightbox-nav:hover{background:rgba(255,255,255,.24)!important;transform:scale(1.04)}
.az-lightbox-stage{width:100%;height:100%;display:flex;align-items:center;justify-content:center;min-height:0}
.az-photo-lightbox img#azLightboxImage{max-width:92vw!important;max-height:calc(100vh - 220px)!important;border-radius:18px!important;box-shadow:0 20px 70px rgba(0,0,0,.45)}
.az-lightbox-counter{position:static!important;transform:none!important;background:rgba(255,255,255,.14)!important;color:#fff;border-radius:999px;padding:8px 14px!important;font-weight:900;min-width:64px;text-align:center}
.az-lightbox-nav{background:rgba(255,255,255,.14)!important;border:1px solid rgba(255,255,255,.16)!important;transition:.18s ease}
.az-lightbox-thumbs{position:absolute;left:0;right:0;bottom:0;height:104px;display:flex;gap:10px;overflow-x:auto;padding:14px 24px;background:linear-gradient(0deg,rgba(0,0,0,.78),rgba(0,0,0,0));z-index:4;scrollbar-width:none}
.az-lightbox-thumbs::-webkit-scrollbar{display:none}
.az-lightbox-thumb{flex:0 0 92px;height:68px;border:2px solid transparent;border-radius:14px;padding:0;overflow:hidden;background:#222;opacity:.62;cursor:pointer;transition:.18s ease}
.az-lightbox-thumb img{width:100%;height:100%;object-fit:cover;border-radius:0!important;box-shadow:none!important;max-width:none!important;max-height:none!important}
.az-lightbox-thumb.active{opacity:1;border-color:#fff;transform:translateY(-3px)}
@media(max-width:767.98px){
  .az-photo-lightbox{padding:64px 0 78px!important}
  .az-lightbox-topbar{height:60px;padding:0 14px}.az-lightbox-title{font-size:.95rem}
  .az-photo-lightbox img#azLightboxImage{max-width:100vw!important;max-height:calc(100vh - 150px)!important;border-radius:0!important;box-shadow:none!important}
  .az-lightbox-thumbs{height:74px;padding:10px 12px}.az-lightbox-thumb{flex-basis:64px;height:48px;border-radius:10px}
}

/* Host contact actions - single visible block under host info */
.host-contact-actions{border-top:1px solid #eee;padding-top:18px;width:100%;}
.host-section{display:block;}
.host-section .host-left{display:flex;align-items:center;gap:16px;}
.host-contact-actions .btn{border-radius:14px;font-weight:700;}
@media (min-width: 992px){.host-contact-actions .d-grid{grid-template-columns:1fr 1fr 1fr;display:grid!important}.host-contact-actions .btn{font-size:15px;padding:12px}}

/* === Premium footer + host rules page === */
.stayly-footer {
    background: radial-gradient(circle at 10% 0%, rgba(255,90,95,.14), transparent 28%), linear-gradient(135deg, #07111f 0%, #0f172a 55%, #111827 100%);
    color: #e5e7eb;
    padding: 56px 0 28px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.stayly-footer .footer-brand { text-decoration: none; }
.stayly-footer .footer-brand span {
    font-size: 1.65rem;
    font-weight: 900;
    letter-spacing: -.04em;
    background: linear-gradient(135deg, #ff385c 0%, #ff7a45 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.footer-logo-img { width: 34px; height: 34px; object-fit: contain; border-radius: 9px; }
.footer-desc { color: #94a3b8; line-height: 1.7; max-width: 260px; margin-bottom: 18px; }
.stayly-footer h6 { color: #fff; font-weight: 900; margin-bottom: 16px; font-size: .98rem; }
.stayly-footer ul { list-style: none; padding: 0; margin: 0; }
.stayly-footer li { margin-bottom: 10px; }
.stayly-footer a, .stayly-footer span { color: #cbd5e1; text-decoration: none; transition: color .18s ease, transform .18s ease; }
.stayly-footer a:hover { color: #fff; }
.footer-contact i { width: 22px; display: inline-flex; color: #ff6b5f; }
.footer-socials { display: flex; gap: 10px; flex-wrap: wrap; }
.footer-socials a {
    width: 38px; height: 38px; border-radius: 999px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.08); color: #fff;
    border: 1px solid rgba(255,255,255,.08);
}
.footer-socials a:hover { background: linear-gradient(135deg, #ff385c, #ff8a3d); transform: translateY(-2px); }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,.08);
    margin-top: 36px; padding-top: 22px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
    color: #94a3b8;
}
.footer-bottom p { margin: 0; }
.footer-bottom div { display: flex; gap: 18px; }
.rules-card {
    max-width: 900px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 28px;
    box-shadow: 0 18px 50px rgba(15,23,42,.08);
    padding: clamp(24px, 4vw, 44px);
}
.rules-badge {
    display: inline-flex; align-items: center;
    background: linear-gradient(135deg, #ff385c, #ff8a3d);
    color: #fff; padding: 8px 14px; border-radius: 999px;
    font-weight: 800; margin-bottom: 16px;
}
.rules-card h1 { font-weight: 900; letter-spacing: -.04em; margin-bottom: 18px; color: #111827; }
.rules-content { color: #334155; font-size: 1.04rem; line-height: 1.85; white-space: normal; }
@media (max-width: 767.98px) {
    .stayly-footer { padding: 40px 0 22px; }
    .footer-bottom { display: block; }
    .footer-bottom div { margin-top: 12px; }
}


/* === Top header color fix: same tone as premium footer, layout unchanged === */
.stayly-topbar{
    background: radial-gradient(circle at 10% 0%, rgba(255,90,95,.14), transparent 28%), linear-gradient(135deg, #07111f 0%, #0f172a 55%, #111827 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 0 10px 30px rgba(2,6,23,.16);
}
.stayly-topbar .nav-link{ color: rgba(255,255,255,.84) !important; font-weight: 600; }
.stayly-topbar .nav-link:hover,.stayly-topbar .nav-link.active{ color:#fff !important; }
.stayly-topbar .navbar-brand span.text-danger{
    background: linear-gradient(135deg,#ff385c 0%,#ff7a45 100%);
    -webkit-background-clip:text; background-clip:text; color:transparent !important;
}
.stayly-topbar .navbar-toggler{ border-color: rgba(255,255,255,.18); }
.stayly-topbar .dropdown-menu{ border:0; box-shadow:0 18px 45px rgba(15,23,42,.16); border-radius:16px; }
.stayly-topbar .btn-danger{
    border:0;
    background: linear-gradient(135deg,#ff385c 0%,#ff7a45 100%) !important;
    box-shadow: 0 10px 24px rgba(255,56,92,.22);
}

/* === Mobile compact fix for "Niyə Stayly?" section === */
@media (max-width: 767.98px) {
    /* Keep desktop design unchanged; only reduce mobile height/spacing */
    section.bg-light.py-5 {
        padding-top: 26px !important;
        padding-bottom: 28px !important;
    }
    section.bg-light.py-5 .container {
        padding-left: 16px;
        padding-right: 16px;
    }
    section.bg-light.py-5 h2 {
        font-size: 1.25rem !important;
        margin-bottom: 14px !important;
    }
    section.bg-light.py-5 .row {
        --bs-gutter-y: .75rem !important;
        --bs-gutter-x: .75rem !important;
    }
    section.bg-light.py-5 .bg-white.p-4.rounded-4.shadow-sm {
        padding: 14px 16px !important;
        border-radius: 18px !important;
        display: flex;
        align-items: center;
        text-align: left;
        gap: 12px;
        min-height: auto !important;
    }
    section.bg-light.py-5 .fs-1 {
        font-size: 1.65rem !important;
        line-height: 1 !important;
        margin-bottom: 0 !important;
        flex: 0 0 38px;
        text-align: center;
    }
    section.bg-light.py-5 h5 {
        font-size: 1rem !important;
        margin-bottom: 3px !important;
        font-weight: 800;
    }
    section.bg-light.py-5 p {
        font-size: .86rem !important;
        line-height: 1.35 !important;
    }
}


/* === Why us page moved from homepage === */
.why-page { background: #f8fafc; }
.why-card { max-width: 1080px; }
.why-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 18px; }
.why-item { background: #fff; border: 1px solid rgba(15, 23, 42, .08); border-radius: 20px; padding: 22px; box-shadow: 0 12px 30px rgba(15,23,42,.06); }
.why-icon { width: 48px; height: 48px; border-radius: 16px; display: flex; align-items: center; justify-content: center; background: #fff5f5; font-size: 24px; margin-bottom: 12px; }
.why-item h5 { font-weight: 800; margin-bottom: 8px; }
.why-item p { color: #64748b; margin-bottom: 0; line-height: 1.6; }
@media (max-width: 768px) { .why-grid { grid-template-columns: 1fr; gap: 12px; } .why-item { padding: 16px; border-radius: 16px; } .why-icon { width: 42px; height: 42px; font-size: 21px; } }

/* === Desktop listing grid stability fix === */
@media (min-width: 992px) {
    .listings-grid {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        column-gap: 24px !important;
        row-gap: 24px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        align-items: stretch !important;
    }
    .listings-grid > [class*="col-"] {
        display: block !important;
        width: auto !important;
        max-width: none !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin: 0 !important;
        min-width: 0 !important;
    }
    .listings-grid .listing-card-link,
    .listings-grid .listing-card {
        width: 100% !important;
        height: 100% !important;
        min-width: 0 !important;
    }
    .listings-grid .listing-image-wrap {
        aspect-ratio: 4 / 3 !important;
        height: auto !important;
    }
    .listings-grid .card-body {
        min-height: 158px !important;
    }
    .listings-grid .listing-title {
        min-height: 2.55em !important;
    }
}

/* === FINAL HOTFIX: compact booking card + modern host contact buttons === */
/* Only listing detail page elements are targeted. */
.booking-card-clean{
  padding:16px!important;
  border-radius:18px!important;
  box-shadow:0 10px 26px rgba(15,23,42,.08)!important;
}
.booking-card-clean .price-line{
  margin-bottom:12px!important;
  gap:6px!important;
}
.booking-card-clean .price-line strong{
  font-size:1.48rem!important;
  letter-spacing:-.03em!important;
}
.booking-card-clean .price-line span{
  font-size:.96rem!important;
}
.booking-card-clean .date-box{
  margin-bottom:10px!important;
  border-radius:14px!important;
}
.booking-card-clean .date-box>div{
  padding:9px 11px!important;
}
.booking-card-clean .date-box label,
.booking-card-clean .guest-label{
  font-size:.66rem!important;
  margin-bottom:4px!important;
}
.booking-card-clean .date-box input,
.booking-card-clean .form-select{
  font-size:.95rem!important;
}
.booking-card-clean textarea.form-control{
  min-height:58px!important;
  max-height:70px!important;
  font-size:.95rem!important;
  border-radius:12px!important;
}
.booking-card-clean .btn.btn-lg{
  min-height:48px!important;
  padding:10px 14px!important;
  font-size:1rem!important;
  border-radius:14px!important;
}
.booking-card-clean .safe-note{
  margin:9px 0 0!important;
  font-size:.78rem!important;
}

.host-section{
  display:block!important;
  padding-top:18px!important;
  padding-bottom:18px!important;
}
.host-section .host-left{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
}
.host-avatar{
  width:52px!important;
  height:52px!important;
  border:4px solid #f1f5f9!important;
  box-shadow:0 8px 18px rgba(15,23,42,.08)!important;
}
.host-left h5{
  font-size:1.08rem!important;
  line-height:1.15!important;
  margin-bottom:2px!important;
}
.host-left p{
  font-size:.86rem!important;
  color:#64748b!important;
}
.host-contact-actions{
  margin-top:14px!important;
  padding-top:14px!important;
  border-top:1px solid rgba(15,23,42,.08)!important;
}
.host-contact-actions h5{
  font-size:.96rem!important;
  font-weight:850!important;
  margin-bottom:10px!important;
  color:#0f172a!important;
}
.host-contact-actions .d-grid{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:8px!important;
}
.host-contact-actions .btn{
  min-height:44px!important;
  padding:9px 8px!important;
  border-radius:14px!important;
  font-size:.88rem!important;
  font-weight:850!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  box-shadow:none!important;
  white-space:nowrap!important;
}
.host-contact-actions .btn i{
  margin:0!important;
  font-size:1.02rem!important;
}
.host-contact-actions .btn-success{
  background:#16a34a!important;
  border-color:#16a34a!important;
  color:#fff!important;
}
.host-contact-actions .btn-dark{
  background:#111827!important;
  border-color:#111827!important;
  color:#fff!important;
}
.host-contact-actions .btn-outline-primary{
  background:#fff!important;
  border:1px solid #0d6efd!important;
  color:#0d6efd!important;
}

@media(max-width:575.98px){
  .booking-card-clean{
    padding:14px!important;
    margin-left:0!important;
    margin-right:0!important;
    border-radius:18px!important;
  }
  .booking-card-clean .price-line strong{font-size:1.35rem!important;}
  .booking-card-clean .date-box>div{padding:8px 10px!important;}
  .booking-card-clean .form-select{margin-bottom:10px!important;}
  .booking-card-clean textarea.form-control{margin-bottom:12px!important;}
  .booking-card-clean .btn.btn-lg{min-height:46px!important;font-size:.96rem!important;}
  .host-contact-actions .d-grid{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:7px!important;
  }
  .host-contact-actions .btn{
    min-height:42px!important;
    padding:8px 4px!important;
    font-size:.78rem!important;
    border-radius:13px!important;
  }
  .host-contact-actions .btn i{font-size:.98rem!important;}
}

@media(max-width:374.98px){
  .host-contact-actions .btn{font-size:.72rem!important;gap:4px!important;}
}


/* === User profile avatar upload + global avatar display === */
.profile-avatar-card{border-radius:24px!important;overflow:hidden}.profile-avatar-img{width:126px;height:126px;border-radius:50%;object-fit:cover;background:#eef2f7;border:4px solid #fff;box-shadow:0 12px 34px rgba(15,23,42,.14)}.avatar-upload-form .btn{padding:11px 16px}.host-avatar,.review-row img{object-fit:cover!important;background:#e5e7eb!important}.review-row img{border-radius:50%!important}.host-avatar{border:3px solid #fff;box-shadow:0 8px 22px rgba(15,23,42,.12)}
@media(max-width:575.98px){.profile-avatar-img{width:104px;height:104px}.profile-avatar-card{border-radius:20px!important}}


/* === Stayly safety warning on listing detail - visible on every listing === */
.stayly-safety-warning{
    margin: 12px 0 18px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
}
.stayly-safety-warning-content{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:16px !important;
    background: linear-gradient(180deg,#fff 0%,#fff7f8 100%) !important;
    border:1px solid rgba(255,56,92,.16) !important;
    border-radius:20px !important;
    padding:18px 20px !important;
    box-shadow:0 10px 26px rgba(15,23,42,.05) !important;
}
.stayly-safety-warning-text{display:flex !important;flex-direction:column !important;gap:5px !important;min-width:0 !important;}
.stayly-safety-warning-text strong{color:#ff385c !important;font-size:1.05rem !important;font-weight:900 !important;line-height:1.1 !important;}
.stayly-safety-warning-text span{color:#1f2937 !important;font-size:1rem !important;line-height:1.35 !important;font-weight:500 !important;}
.stayly-safety-warning-icon{width:52px !important;height:52px !important;flex:0 0 52px !important;border-radius:18px !important;display:flex !important;align-items:center !important;justify-content:center !important;color:#ff385c !important;background:#fff !important;border:1px solid rgba(255,56,92,.22) !important;font-size:1.55rem !important;}
@media(max-width:575.98px){
  .stayly-safety-warning{margin:10px 0 15px !important;}
  .stayly-safety-warning-content{padding:14px 14px !important;border-radius:16px !important;gap:12px !important;}
  .stayly-safety-warning-text strong{font-size:.98rem !important;}
  .stayly-safety-warning-text span{font-size:.92rem !important;}
  .stayly-safety-warning-icon{width:42px !important;height:42px !important;flex-basis:42px !important;border-radius:14px !important;font-size:1.25rem !important;}
}
