/* OwlB&B Frontend — Search, Listing, Booking, Checkout, Subscription */
/* Warm amber accent, rounded cards, soft shadows, Airbnb-inspired */

/* ── Search Page ──────────────────────────────────────────── */

.owlbb-search-page {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.owlbb-search-bar {
    background: var(--owlbb-white);
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.25rem 1.5rem;
    margin: 1.5rem 0;
    box-shadow: var(--owlbb-shadow);
}

.owlbb-search-fields {
    display: flex;
    gap: 0.85rem;
    align-items: flex-end;
    flex-wrap: wrap;
}

.owlbb-search-field {
    flex: 1;
    min-width: 140px;
}

.owlbb-search-field label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--owlbb-text-muted);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.owlbb-search-field input[type="text"],
.owlbb-search-field input[type="date"],
.owlbb-search-field select {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.9rem;
    box-sizing: border-box;
    font-family: var(--owlbb-font);
    color: var(--owlbb-text);
    transition: border-color 0.2s;
}

.owlbb-search-field input:focus,
.owlbb-search-field select:focus {
    border-color: var(--owlbb-accent);
    outline: none;
    box-shadow: 0 0 0 3px rgba(232, 130, 12, 0.1);
}

.owlbb-search-field--guests { flex: 1.5; }

.owlbb-guest-inputs {
    display: flex;
    gap: 0.5rem;
}

.owlbb-guest-inputs > div { flex: 1; }

.owlbb-guest-inputs span {
    display: block;
    font-size: 0.68rem;
    color: var(--owlbb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.owlbb-stepper {
    width: 100%;
    padding: 0.5rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.85rem;
    text-align: center;
    box-sizing: border-box;
    font-family: var(--owlbb-font);
}

.owlbb-stepper-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    padding: 0.35rem 0.4rem;
}

.owlbb-stepper-minus,
.owlbb-stepper-plus {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 1.5px solid var(--owlbb-border);
    background: transparent;
    font-size: 15px;
    line-height: 1;
    color: var(--owlbb-text);
    cursor: pointer;
    padding: 0;
    transition: border-color 0.15s, opacity 0.15s;
    flex-shrink: 0;
}

.owlbb-stepper-minus:hover,
.owlbb-stepper-plus:hover {
    border-color: var(--owlbb-dark, #1A1A2E);
}

.owlbb-stepper-minus.dim,
.owlbb-stepper-plus.dim {
    opacity: 0.25;
    cursor: default;
}

.owlbb-stepper-display {
    font-size: 0.9rem;
    font-weight: 600;
    min-width: 18px;
    text-align: center;
    color: var(--owlbb-text);
}

.owlbb-search-btn {
    padding: 0.65rem 2rem;
    white-space: nowrap;
    width: auto;
    border-radius: 50px;
}

/* Filters toggle button */
.owlbb-filters-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1rem;
    border-radius: 50px;
    white-space: nowrap;
    position: relative;
}
.owlbb-filters-toggle svg { flex-shrink: 0; }
.owlbb-filters-toggle--active {
    background: var(--owlbb-dark, #1A1A2E);
    color: var(--owlbb-white, #fff);
    border-color: var(--owlbb-dark, #1A1A2E);
}

.owlbb-filters-badge {
    background: var(--owlbb-accent, #E8820C);
    color: var(--owlbb-white, #fff);
    font-size: 0.65rem; font-weight: 700;
    min-width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50px; padding: 0 5px;
    line-height: 1;
}

/* ── Filters Sidebar (Left) ───────────────────────────────── */

.owlbb-filters-sidebar {
    width: 260px;
    flex-shrink: 0;
    background: var(--owlbb-white);
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.25rem;
    position: sticky;
    top: 1rem;
    height: fit-content;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
    box-shadow: var(--owlbb-shadow);
}

.owlbb-filters-sidebar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--owlbb-border-light, #F3F4F6);
}

.owlbb-filters-sidebar-header h3 {
    font-size: 0.95rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
}

.owlbb-filters-clear-btn {
    background: none;
    border: none;
    color: var(--owlbb-accent, #E8820C);
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    padding: 0;
}
.owlbb-filters-clear-btn:hover {
    text-decoration: underline;
}

.owlbb-filters-sidebar .owlbb-filter-group {
    margin-bottom: 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--owlbb-border-light, #F3F4F6);
}

.owlbb-filters-sidebar .owlbb-filter-group:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.owlbb-filter-check--instant {
    padding-top: 0;
}

/* Mobile filters toggle (visible only on small screens) */
.owlbb-filters-mobile-toggle {
    display: none;
}
.owlbb-filters-mobile-close {
    display: none !important;
}

/* ── Search Layout ────────────────────────────────────────── */

.owlbb-search-layout {
    display: flex;
    gap: 1.5rem;
    position: relative;
    align-items: flex-start;
}

.owlbb-search-main {
    flex: 1;
    min-width: 0;
}

/* ── Map Panel ────────────────────────────────────────────── */

.owlbb-map-panel {
    display: none;
    width: 45%;
    flex-shrink: 0;
    position: sticky;
    top: 0;
    height: calc(100vh - 160px);
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
    box-shadow: var(--owlbb-shadow);
}

/* Map visible state (toggled by Show Map button) */
.owlbb-search-layout--map-open .owlbb-map-panel {
    display: block;
}

.owlbb-search-layout--map-open .owlbb-results-grid {
    grid-template-columns: 1fr;
}

.owlbb-search-map { width: 100%; height: 100%; }

.owlbb-search-area-btn {
    position: absolute;
    top: 12px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    background: var(--owlbb-white);
    box-shadow: var(--owlbb-shadow);
    border-radius: 50px;
}

.owlbb-map-toggle {
    display: none;
    position: fixed;
    bottom: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
    box-shadow: var(--owlbb-shadow-lg);
    border-radius: 50px;
    background: var(--owlbb-dark);
    color: var(--owlbb-white);
    border: none;
}

.owlbb-map-price-pin {
    position: absolute;
    background: var(--owlbb-dark);
    color: var(--owlbb-white);
    padding: 4px 10px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 700;
    white-space: nowrap;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
    transition: all 0.15s;
    font-family: var(--owlbb-font);
}

.owlbb-map-price-pin:hover {
    background: var(--owlbb-accent);
    transform: scale(1.1);
}

.owlbb-map-popup {
    display: flex;
    gap: 10px;
    max-width: 300px;
    font-family: var(--owlbb-font);
}

.owlbb-map-popup img {
    width: 90px;
    height: 65px;
    object-fit: cover;
    border-radius: 10px;
    flex-shrink: 0;
}

.owlbb-map-popup-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.owlbb-map-popup-body strong { font-size: 13px; color: var(--owlbb-dark); }
.owlbb-map-popup-body span { font-size: 11px; color: var(--owlbb-text-muted); }
.owlbb-map-popup-price { font-weight: 700; color: var(--owlbb-accent) !important; }
.owlbb-map-popup-body a { font-size: 12px; color: var(--owlbb-accent); font-weight: 600; }

/* ── Filters Panel ────────────────────────────────────────── */

/* Filters panel is now rendered inside the dropdown, not as a sidebar */

.owlbb-filter-group {
    margin-bottom: 1.35rem;
}

.owlbb-filter-group h4 {
    font-size: 0.8rem;
    margin: 0 0 0.5rem;
    color: var(--owlbb-text);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}

.owlbb-price-range {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.owlbb-input-small {
    width: 85px;
    padding: 0.4rem 0.6rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.85rem;
    font-family: var(--owlbb-font);
}

.owlbb-filter-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    max-height: 200px;
    overflow-y: auto;
}

.owlbb-filter-check {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    cursor: pointer;
    color: var(--owlbb-text-secondary);
}

.owlbb-filter-check input { accent-color: var(--owlbb-accent); }

.owlbb-stepper-row {
    display: flex;
    gap: 0.3rem;
}

.owlbb-stepper-btn {
    flex: 1;
    padding: 0.35rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    background: var(--owlbb-white);
    font-size: 0.8rem;
    cursor: pointer;
    text-align: center;
    font-family: var(--owlbb-font);
    color: var(--owlbb-text-secondary);
    transition: all 0.15s;
}

.owlbb-stepper-btn.active {
    background: var(--owlbb-accent);
    color: var(--owlbb-white);
    border-color: var(--owlbb-accent);
}

/* ── Results Grid ─────────────────────────────────────────── */

.owlbb-search-results {
    flex: 1;
    min-width: 0;
}

.owlbb-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.25rem;
}

.owlbb-results-header span {
    font-weight: 600;
    color: var(--owlbb-dark);
}

.owlbb-results-header-right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.owlbb-show-map-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
}
.owlbb-show-map-btn svg {
    flex-shrink: 0;
}
.owlbb-show-map-btn--active {
    background: var(--owlbb-dark, #1A1A2E);
    color: var(--owlbb-white, #fff);
    border-color: var(--owlbb-dark, #1A1A2E);
}

.owlbb-sort {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--owlbb-text-secondary);
}

.owlbb-sort select {
    padding: 0.4rem 0.6rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-family: var(--owlbb-font);
}

.owlbb-results-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.owlbb-loading, .owlbb-no-results {
    grid-column: 1 / -1;
    text-align: center;
    padding: 3rem;
    color: var(--owlbb-text-muted);
}

/* ── Property Card ────────────────────────────────────────── */

.owlbb-property-card {
    display: block;
    text-decoration: none;
    color: inherit;
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
    transition: all 0.3s ease;
    background: var(--owlbb-white);
}

.owlbb-property-card:hover {
    box-shadow: var(--owlbb-shadow-lg);
    transform: translateY(-4px);
}

.owlbb-card-image {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: var(--owlbb-radius-lg);
}

.owlbb-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.owlbb-property-card:hover .owlbb-card-image img {
    transform: scale(1.05);
}

.owlbb-card-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    color: var(--owlbb-dark);
    padding: 0.2rem 0.6rem;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.owlbb-card-badge--ib {
    left: auto;
    right: 10px;
    background: var(--owlbb-accent);
    color: var(--owlbb-white);
}

.owlbb-card-gallery-dots {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 5px;
}

/* Card carousel arrows */
.owlbb-card-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(4px);
    color: var(--owlbb-dark);
    font-size: 18px;
    font-weight: 300;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s, background 0.15s, transform 0.15s;
    z-index: 5;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
    padding: 0;
}

.owlbb-property-card:hover .owlbb-card-arrow { opacity: 1; }

.owlbb-card-arrow:hover {
    background: var(--owlbb-white);
    transform: translateY(-50%) scale(1.08);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}

.owlbb-card-arrow--prev { left: 8px; }
.owlbb-card-arrow--next { right: 8px; }

.owlbb-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.45);
    cursor: pointer;
    transition: all 0.2s;
}

.owlbb-dot.active {
    background: var(--owlbb-white);
    width: 8px;
    height: 8px;
}

.owlbb-dot-more {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
}

.owlbb-card-body {
    padding: 0.85rem 0.65rem;
}

.owlbb-card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.2rem;
}

.owlbb-card-location {
    font-size: 0.78rem;
    color: var(--owlbb-text-muted);
    font-weight: 500;
}

.owlbb-card-rating {
    font-size: 0.8rem;
    color: var(--owlbb-accent);
    font-weight: 600;
}

.owlbb-card-title {
    font-size: 1rem;
    margin: 0 0 0.3rem;
    font-weight: 600;
    color: var(--owlbb-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Card stats row */
.owlbb-card-stats {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
    margin-bottom: 0.35rem;
}

.owlbb-card-stat-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--owlbb-text-muted);
    background: var(--owlbb-bg);
    padding: 0.2rem 0.5rem;
    border-radius: 50px;
    white-space: nowrap;
}

.owlbb-card-stat-chip svg {
    color: var(--owlbb-accent);
    flex-shrink: 0;
}

.owlbb-card-stat-chip--pets {
    color: var(--owlbb-accent);
    background: var(--owlbb-accent-light, #FFF3E6);
}

.owlbb-card-price {
    font-weight: 700;
    color: var(--owlbb-dark);
    font-size: 1rem;
}

.owlbb-card-price small {
    font-weight: 400;
    color: var(--owlbb-text-muted);
    font-size: 0.8rem;
}

.owlbb-card-pets {
    font-size: 0.72rem;
    color: var(--owlbb-accent);
    margin-left: 0.5rem;
    font-weight: 500;
}

/* ── Pagination ───────────────────────────────────────────── */

.owlbb-pagination {
    display: flex;
    justify-content: center;
    gap: 0.3rem;
    margin: 2rem 0;
}

.owlbb-page-btn {
    padding: 0.45rem 0.85rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: 50px;
    background: var(--owlbb-white);
    cursor: pointer;
    font-size: 0.85rem;
    font-family: var(--owlbb-font);
    color: var(--owlbb-text-secondary);
    transition: all 0.15s;
}

.owlbb-page-btn:hover { border-color: var(--owlbb-accent); color: var(--owlbb-accent); }

.owlbb-page-btn--active {
    background: var(--owlbb-accent);
    color: var(--owlbb-white);
    border-color: var(--owlbb-accent);
}

/* ── Single Property Listing ──────────────────────────────── */

.owlbb-listing-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem 3rem;
}

.owlbb-gallery-hero {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 6px;
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
    margin-bottom: 2rem;
    max-height: 440px;
}

.owlbb-gallery-main img {
    width: 100%;
    height: 440px;
    object-fit: cover;
    display: block;
    cursor: pointer;
    transition: opacity 0.2s;
}

.owlbb-gallery-main img:hover { opacity: 0.92; }

.owlbb-gallery-thumbs {
    display: grid;
    grid-template-rows: repeat(2, 1fr);
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}

.owlbb-gallery-thumb-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    cursor: pointer;
    transition: opacity 0.2s;
}

.owlbb-gallery-thumb-item img:hover { opacity: 0.88; }

.owlbb-show-all-photos {
    position: absolute;
    bottom: 14px;
    right: 14px;
    border-radius: 50px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    border: 1px solid var(--owlbb-border);
}

.owlbb-listing-content {
    display: flex;
    gap: 2.5rem;
}

.owlbb-listing-main {
    flex: 1;
    min-width: 0;
}

.owlbb-listing-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.3rem;
}

.owlbb-listing-type {
    font-size: 0.75rem;
    color: var(--owlbb-accent);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

.owlbb-listing-location {
    font-size: 0.85rem;
    color: var(--owlbb-text-secondary);
}

.owlbb-listing-badges {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.owlbb-badge {
    padding: 0.25rem 0.7rem;
    border-radius: 50px;
    font-size: 0.72rem;
    font-weight: 600;
}

.owlbb-badge--superhost {
    background: var(--owlbb-dark);
    color: var(--owlbb-white);
}

.owlbb-badge--instant {
    background: var(--owlbb-accent-light);
    color: var(--owlbb-accent);
}

.owlbb-badge-rating {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--owlbb-accent);
}

.owlbb-listing-title {
    font-family: var(--owlbb-font);
    font-size: 2rem;
    font-weight: 700;
    margin: 0.3rem 0 1rem;
    color: var(--owlbb-dark);
    letter-spacing: -0.02em;
}

.owlbb-stats-bar {
    display: flex;
    gap: 0.6rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--owlbb-border-light);
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}

.owlbb-stat-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    background: var(--owlbb-bg);
    border: 1px solid var(--owlbb-border);
    border-radius: 50px;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--owlbb-text-secondary);
    white-space: nowrap;
}

.owlbb-stat-chip svg {
    color: var(--owlbb-accent);
    flex-shrink: 0;
}

.owlbb-host-bar {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--owlbb-border-light);
    margin-bottom: 1.25rem;
}

.owlbb-host-bar img { border-radius: 50%; border: 2px solid var(--owlbb-accent-light); }
.owlbb-host-bar strong { display: block; color: var(--owlbb-dark); }
.owlbb-host-bar a { font-size: 0.85rem; color: var(--owlbb-accent); font-weight: 500; }

.owlbb-listing-section {
    padding: 1.5rem 0;
    border-bottom: 1px solid var(--owlbb-border-light);
}

.owlbb-listing-section h2 {
    font-size: 1.2rem;
    margin: 0 0 0.85rem;
    color: var(--owlbb-dark);
    font-weight: 700;
}

.owlbb-review-avg {
    font-weight: 500;
    font-size: 0.9rem;
    color: var(--owlbb-accent);
}

.owlbb-amenities-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0.65rem;
}

.owlbb-amenity-item {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.65rem 0.85rem;
    background: var(--owlbb-white);
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.85rem;
    color: var(--owlbb-text);
    font-weight: 500;
    transition: border-color 0.15s, background 0.15s;
}

.owlbb-amenity-item:hover {
    border-color: var(--owlbb-accent);
    background: var(--owlbb-accent-subtle);
}

.owlbb-amenity-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    color: var(--owlbb-accent);
}

.owlbb-amenity-icon svg {
    width: 20px;
    height: 20px;
}

.owlbb-amenity-icon--sm {
    width: 16px;
    height: 16px;
}

.owlbb-amenity-icon--sm svg {
    width: 16px;
    height: 16px;
}

.owlbb-reviews-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.owlbb-review-card {
    padding: 1.25rem;
    background: var(--owlbb-bg);
    border-radius: var(--owlbb-radius);
    border: 1px solid var(--owlbb-border-light);
}

.owlbb-review-header {
    display: flex;
    gap: 0.6rem;
    align-items: center;
    margin-bottom: 0.5rem;
}

.owlbb-review-header img { border-radius: 50%; }
.owlbb-review-header strong { margin-right: 0.5rem; color: var(--owlbb-dark); }
.owlbb-review-header small { color: var(--owlbb-text-muted); margin-left: 0.5rem; }

.owlbb-host-response {
    margin-top: 0.75rem;
    padding: 0.75rem 1rem;
    background: var(--owlbb-white);
    border-left: 3px solid var(--owlbb-accent);
    border-radius: 0 var(--owlbb-radius-sm) var(--owlbb-radius-sm) 0;
}

/* ── Property / Wizard Maps ───────────────────────────────── */

.owlbb-property-map {
    width: 100%;
    height: 320px;
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
}

.owlbb-wizard-map {
    width: 100%;
    height: 360px;
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
    border: 1.5px solid var(--owlbb-border);
    margin-top: 0.5rem;
}

/* ── Booking Widget ───────────────────────────────────────── */

.owlbb-booking-widget {
    width: 380px;
    flex-shrink: 0;
    background: var(--owlbb-white);
    border: 1px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.75rem;
    align-self: flex-start;
    position: sticky;
    top: 1.5rem;
    box-shadow: var(--owlbb-shadow-lg);
}

.owlbb-bw-price { margin-bottom: 1.25rem; }

.owlbb-bw-price strong {
    font-size: 1.75rem;
    color: var(--owlbb-dark);
    letter-spacing: -0.02em;
}

.owlbb-bw-price span { color: var(--owlbb-text-muted); }

/* Combined date picker row */
.owlbb-bw-dates {
    display: flex;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    overflow: hidden;
    margin-bottom: 0.85rem;
    transition: border-color 0.2s;
}

.owlbb-bw-dates:focus-within {
    border-color: var(--owlbb-accent);
    box-shadow: 0 0 0 3px rgba(232, 130, 12, 0.1);
}

.owlbb-bw-date-field {
    flex: 1;
    padding: 0.6rem 0.75rem;
    cursor: pointer;
    transition: background 0.15s;
    position: relative;
}

.owlbb-bw-date-field:hover {
    background: var(--owlbb-accent-subtle);
}

.owlbb-bw-date-field--active {
    background: var(--owlbb-accent-light) !important;
}

.owlbb-bw-date-field label {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--owlbb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.15rem;
    pointer-events: none;
}

.owlbb-bw-date-field input[type="date"] {
    width: 100%;
    border: none;
    padding: 0;
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--owlbb-dark);
    background: transparent;
    font-family: var(--owlbb-font);
    cursor: pointer;
    outline: none;
}

.owlbb-bw-date-field input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0.4;
    cursor: pointer;
}

.owlbb-bw-date-field input[type="date"]:focus::-webkit-calendar-picker-indicator {
    opacity: 0.7;
}

.owlbb-bw-date-divider {
    width: 1.5px;
    background: var(--owlbb-border);
    flex-shrink: 0;
    align-self: stretch;
}

/* Display text in the trigger */
.owlbb-dp-display {
    display: block;
    font-size: 0.9rem;
    color: var(--owlbb-text-muted);
    font-weight: 400;
    cursor: pointer;
}

.owlbb-dp-display--filled {
    color: var(--owlbb-dark);
    font-weight: 600;
}

/* ── Dual-Month Date Picker Modal ─────────────────────────── */

.owlbb-dp-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 10000;
    align-items: center;
    justify-content: center;
}

.owlbb-dp-overlay--open {
    display: flex;
}

.owlbb-dp-modal {
    background: var(--owlbb-white);
    border-radius: var(--owlbb-radius-lg);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.18);
    padding: 1.75rem 2rem;
    position: relative;
    animation: owlbb-dp-in 0.25s ease-out;
}

@keyframes owlbb-dp-in {
    from { opacity: 0; transform: scale(0.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

.owlbb-dp-modal-close {
    position: absolute;
    top: 0.85rem;
    right: 0.85rem;
    width: 34px;
    height: 34px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 1.4rem;
    color: var(--owlbb-text-muted);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
}

.owlbb-dp-modal-close:hover {
    background: var(--owlbb-bg);
    color: var(--owlbb-dark);
}

.owlbb-dp-modal-header {
    text-align: center;
    margin-bottom: 1.25rem;
}

.owlbb-dp-modal-header h3 {
    margin: 0 0 0.15rem;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--owlbb-dark);
}

.owlbb-dp-modal-header p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--owlbb-accent);
    font-weight: 600;
    min-height: 1.2em;
}

/* Two months side by side */
.owlbb-dp-months {
    display: flex;
    gap: 1.5rem;
}

.owlbb-dp-month {
    width: 260px;
}

/* Month header (nav + title) */
.owlbb-dp-month-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.owlbb-dp-month-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--owlbb-dark);
    text-align: center;
    flex: 1;
}

.owlbb-dp-nav {
    width: 32px;
    height: 32px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 1.25rem;
    color: var(--owlbb-text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
    flex-shrink: 0;
}

.owlbb-dp-nav:hover {
    background: var(--owlbb-bg);
    color: var(--owlbb-dark);
}

/* Weekday labels */
.owlbb-dp-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    margin-bottom: 0.25rem;
}

.owlbb-dp-weekdays span {
    text-align: center;
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--owlbb-text-muted);
    padding: 0.25rem 0;
}

/* Day grid */
.owlbb-dp-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.owlbb-dp-day {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--owlbb-text);
    cursor: default;
    border-radius: 50%;
    transition: all 0.12s;
    position: relative;
    user-select: none;
    -webkit-user-select: none;
}

.owlbb-dp-day--empty {
    cursor: default;
}

.owlbb-dp-day--disabled {
    color: var(--owlbb-border);
    cursor: not-allowed;
}

.owlbb-dp-day--pickable {
    cursor: pointer;
}

.owlbb-dp-day--pickable:hover {
    background: var(--owlbb-bg);
}

/* Selected check-in / check-out */
.owlbb-dp-day--selected {
    background: var(--owlbb-accent) !important;
    color: var(--owlbb-white) !important;
}

/* In-range (between check-in and check-out) */
.owlbb-dp-day--inrange {
    background: var(--owlbb-accent-light);
    border-radius: 0;
    color: var(--owlbb-accent);
}

/* Check-in gets right-side flat for range connection */
.owlbb-dp-day--checkin {
    border-radius: 50% 0 0 50%;
}

/* Check-out gets left-side flat */
.owlbb-dp-day--checkout {
    border-radius: 0 50% 50% 0;
}

/* ── Price Heatmap in Datepicker ──────────────────────────── */

.owlbb-dp-day-num {
    display: block;
    line-height: 1;
}

.owlbb-dp-day-price {
    display: block;
    font-size: 0.55rem;
    font-weight: 600;
    line-height: 1;
    margin-top: 1px;
    opacity: 0.8;
}

/* Price-level colour coding */
.owlbb-dp-day--price-low {
    background: rgba(52, 199, 89, 0.08);
}

.owlbb-dp-day--price-mid {
    background: rgba(255, 159, 10, 0.08);
}

.owlbb-dp-day--price-high {
    background: rgba(255, 69, 58, 0.08);
}

.owlbb-dp-day--price-low .owlbb-dp-day-price {
    color: #34c759;
}

.owlbb-dp-day--price-mid .owlbb-dp-day-price {
    color: #ff9f0a;
}

.owlbb-dp-day--price-high .owlbb-dp-day-price {
    color: #ff453a;
}

/* Override price bg when selected or in-range */
.owlbb-dp-day--selected .owlbb-dp-day-price {
    color: var(--owlbb-white);
}

.owlbb-dp-day--inrange .owlbb-dp-day-price {
    color: var(--owlbb-accent);
}

/* Unavailable overlay */
.owlbb-dp-day--unavailable {
    text-decoration: line-through;
    opacity: 0.4;
}

/* Taller cells to fit price text */
.owlbb-dp-days .owlbb-dp-day {
    height: 44px;
    width: 40px;
    flex-direction: column;
    border-radius: 8px;
    font-size: 0.82rem;
    gap: 0;
}

.owlbb-dp-day--selected {
    border-radius: 8px !important;
}

.owlbb-dp-day--checkin {
    border-radius: 8px 0 0 8px !important;
}

.owlbb-dp-day--checkout {
    border-radius: 0 8px 8px 0 !important;
}

/* ── Flexible Dates Search UI ────────────────────────────── */

.owlbb-search-field--dates {
    flex: 2;
    min-width: 280px;
}

.owlbb-date-mode-toggle {
    display: inline-flex;
    gap: 0;
    background: var(--owlbb-bg);
    border-radius: 999px;
    padding: 2px;
    margin-bottom: 0.5rem;
}

.owlbb-date-mode-btn {
    padding: 0.3rem 0.85rem;
    font-size: 0.75rem;
    font-weight: 600;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: var(--owlbb-text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.owlbb-date-mode-btn--active {
    background: var(--owlbb-white);
    color: var(--owlbb-text);
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.owlbb-date-pair {
    display: flex;
    gap: 0.5rem;
}

.owlbb-date-pair > div {
    flex: 1;
}

.owlbb-date-pair label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--owlbb-text-muted);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.owlbb-date-pair input[type="date"] {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.9rem;
}

.owlbb-date-pair--picker {
    align-items: center;
    cursor: pointer;
    padding: 0.5rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    transition: border-color 0.2s;
}

.owlbb-date-pair--picker:hover {
    border-color: var(--owlbb-accent);
}

.owlbb-date-pair-arrow {
    flex-shrink: 0;
    color: var(--owlbb-text-muted);
    font-size: 0.85rem;
    padding: 0 0.25rem;
}

.owlbb-flex-btns {
    display: flex;
    gap: 0.5rem;
}

.owlbb-flex-btn {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.15rem;
    padding: 0.6rem 0.5rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    background: var(--owlbb-white);
    cursor: pointer;
    transition: all 0.15s;
    text-align: center;
}

.owlbb-flex-btn svg {
    color: var(--owlbb-text-muted);
}

.owlbb-flex-btn span {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--owlbb-text);
}

.owlbb-flex-btn small {
    font-size: 0.65rem;
    color: var(--owlbb-text-muted);
    font-weight: 400;
}

.owlbb-flex-btn:hover {
    border-color: var(--owlbb-accent);
}

.owlbb-flex-btn--active {
    border-color: var(--owlbb-accent);
    background: var(--owlbb-accent-light);
}

.owlbb-flex-btn--active svg {
    color: var(--owlbb-accent);
}

/* When both check-in and check-out are the same (min 1 night won't happen, but safe) */
.owlbb-dp-day--checkin.owlbb-dp-day--checkout {
    border-radius: 50%;
}

/* Hover range preview */
.owlbb-dp-day--hover-range {
    background: var(--owlbb-accent-light);
    border-radius: 0;
    color: var(--owlbb-accent);
}

/* Footer with selected dates + confirm */
.owlbb-dp-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--owlbb-border-light);
    gap: 1rem;
}

.owlbb-dp-selected {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.owlbb-dp-sel-label {
    display: block;
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--owlbb-text-muted);
}

.owlbb-dp-sel-value {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--owlbb-dark);
}

.owlbb-dp-sel-arrow {
    color: var(--owlbb-accent);
    font-size: 1rem;
}

#owlbb-dp-confirm:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Mobile: stack months vertically, bottom sheet style */
@media (max-width: 620px) {
    .owlbb-dp-modal {
        width: 95%;
        padding: 1.25rem;
        max-height: 90vh;
        overflow-y: auto;
    }

    .owlbb-dp-months {
        flex-direction: column;
        gap: 1rem;
    }

    .owlbb-dp-month {
        width: 100%;
    }

    .owlbb-dp-footer {
        flex-direction: column;
        gap: 0.75rem;
    }

    .owlbb-dp-selected {
        width: 100%;
        justify-content: center;
    }
}

.owlbb-bw-field { margin-bottom: 0.85rem; }

.owlbb-bw-field label {
    display: block;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--owlbb-text-muted);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.owlbb-bw-field input,
.owlbb-bw-field select,
.owlbb-bw-field textarea {
    width: 100%;
    padding: 0.6rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.9rem;
    box-sizing: border-box;
    font-family: var(--owlbb-font);
    transition: border-color 0.2s;
}

.owlbb-bw-field input:focus,
.owlbb-bw-field select:focus,
.owlbb-bw-field textarea:focus {
    border-color: var(--owlbb-accent);
    outline: none;
}

.owlbb-bw-guests-row {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
}

.owlbb-bw-guests-row .owlbb-bw-field { flex: 1; margin-bottom: 0; }

.owlbb-bw-breakdown {
    margin: 1.25rem 0;
    padding-top: 1rem;
    border-top: 1px solid var(--owlbb-border-light);
}

.owlbb-bw-line {
    display: flex;
    justify-content: space-between;
    font-size: 0.88rem;
    padding: 0.3rem 0;
    color: var(--owlbb-text-secondary);
}

.owlbb-bw-total {
    display: flex;
    justify-content: space-between;
    font-size: 1.05rem;
    font-weight: 700;
    padding: 0.65rem 0 0;
    margin-top: 0.35rem;
    border-top: 1.5px solid var(--owlbb-dark);
    color: var(--owlbb-dark);
}

.owlbb-bw-note {
    text-align: center;
    font-size: 0.78rem;
    color: var(--owlbb-text-muted);
    margin: 0.6rem 0 0;
}

.owlbb-bw-meta {
    text-align: center;
    font-size: 0.72rem;
    color: var(--owlbb-text-muted);
    margin-top: 0.5rem;
}

/* ── Lightbox ─────────────────────────────────────────────── */

.owlbb-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.92);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.owlbb-lightbox img {
    max-width: 90vw;
    max-height: 85vh;
    object-fit: contain;
    border-radius: var(--owlbb-radius);
}

.owlbb-lightbox-close,
.owlbb-lightbox-prev,
.owlbb-lightbox-next {
    position: absolute;
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(4px);
    color: #fff;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0.6rem 0.85rem;
    border-radius: 50px;
    transition: background 0.2s;
}

.owlbb-lightbox-close:hover,
.owlbb-lightbox-prev:hover,
.owlbb-lightbox-next:hover { background: rgba(255, 255, 255, 0.25); }

.owlbb-lightbox-close { top: 1.5rem; right: 1.5rem; }
.owlbb-lightbox-prev  { left: 1.5rem; top: 50%; transform: translateY(-50%); }
.owlbb-lightbox-next  { right: 1.5rem; top: 50%; transform: translateY(-50%); }

#owlbb-lightbox-counter {
    position: absolute;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.9rem;
}

/* ── Booking Detail ───────────────────────────────────────── */

.owlbb-booking-page {
    max-width: 940px;
    margin: 2.5rem auto;
    padding: 0 1.5rem;
}

.owlbb-booking-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.75rem;
}

.owlbb-booking-header h1 {
    margin: 0;
    font-size: 1.5rem;
    color: var(--owlbb-dark);
}

.owlbb-status {
    display: inline-block;
    padding: 0.2rem 0.65rem;
    border-radius: 50px;
    font-size: 0.72rem;
    font-weight: 600;
}

.owlbb-status--pending   { background: var(--owlbb-accent-light, #FFF3E6); color: var(--owlbb-accent, #E8820C); }
.owlbb-status--confirmed { background: var(--owlbb-success-bg); color: var(--owlbb-success); }
.owlbb-status--paid      { background: var(--owlbb-success-bg); color: var(--owlbb-success); }
.owlbb-status--cancelled_guest,
.owlbb-status--cancelled_host { background: var(--owlbb-error-bg); color: var(--owlbb-error); }
.owlbb-status--completed { background: #EEF2FF; color: #4F46E5; }
.owlbb-status--disputed  { background: var(--owlbb-error-bg); color: var(--owlbb-error); }
.owlbb-status--published, .owlbb-status--publish { background: var(--owlbb-success-bg); color: var(--owlbb-success); }
.owlbb-status--draft     { background: var(--owlbb-accent-light, #FFF3E6); color: var(--owlbb-accent, #E8820C); }
.owlbb-status--suspended { background: var(--owlbb-error-bg); color: var(--owlbb-error); }
.owlbb-status--failed    { background: var(--owlbb-error-bg); color: var(--owlbb-error); }
.owlbb-status--active    { background: var(--owlbb-success-bg); color: var(--owlbb-success); }

.owlbb-booking-layout { display: flex; gap: 2rem; }
.owlbb-booking-main { flex: 1; min-width: 0; }

.owlbb-booking-property {
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--owlbb-bg);
    border-radius: var(--owlbb-radius);
    margin-bottom: 1.75rem;
    border: 1px solid var(--owlbb-border-light);
}

.owlbb-booking-property img {
    width: 170px;
    height: 110px;
    object-fit: cover;
    border-radius: var(--owlbb-radius-sm);
}

.owlbb-booking-property h3 { margin: 0 0 0.3rem; color: var(--owlbb-dark); }
.owlbb-booking-property a { color: var(--owlbb-dark); }

.owlbb-booking-section { margin-bottom: 1.75rem; }

.owlbb-booking-section h2 {
    font-size: 1.1rem;
    margin: 0 0 0.85rem;
    color: var(--owlbb-dark);
}

.owlbb-detail-table { width: 100%; border-collapse: collapse; }

.owlbb-detail-table th,
.owlbb-detail-table td {
    padding: 0.45rem 0;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--owlbb-border-light);
}

.owlbb-detail-table th {
    text-align: left;
    color: var(--owlbb-text-muted);
    font-weight: 500;
    width: 180px;
}

.owlbb-detail-total th,
.owlbb-detail-total td {
    font-weight: 700;
    font-size: 1.05rem;
    border-top: 2px solid var(--owlbb-dark);
    padding-top: 0.6rem;
    color: var(--owlbb-dark);
}

.owlbb-booking-actions {
    width: 290px;
    flex-shrink: 0;
}

.owlbb-booking-actions h3 {
    font-size: 1rem;
    margin: 0 0 0.5rem;
    color: var(--owlbb-dark);
}

.owlbb-booking-actions .owlbb-btn {
    display: block;
    width: 100%;
    margin-bottom: 0.5rem;
}

.owlbb-textarea-full {
    width: 100%;
    padding: 0.6rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    margin-bottom: 0.5rem;
    box-sizing: border-box;
    font-family: var(--owlbb-font);
}

.owlbb-booking-confirmed-info {
    padding: 1.25rem;
    background: var(--owlbb-success-bg);
    border-radius: var(--owlbb-radius);
    margin-bottom: 1rem;
    border: 1px solid #A7F3D0;
}

/* ── Inline Messaging on Booking Detail ───────────────────── */

.owlbb-booking-messages {
    margin-top: 2.5rem;
    border: 1px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    overflow: hidden;
    background: var(--owlbb-white);
    box-shadow: var(--owlbb-shadow);
}

.owlbb-booking-messages-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.1rem 1.5rem;
    cursor: pointer;
    transition: background 0.15s;
    user-select: none;
}

.owlbb-booking-messages-header:hover {
    background: var(--owlbb-bg);
}

.owlbb-booking-messages-header h2 {
    margin: 0;
    font-size: 1.05rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--owlbb-dark);
}

.owlbb-msg-toggle-icon {
    font-size: 0.8rem;
    color: var(--owlbb-text-muted);
    transition: transform 0.2s;
}

.owlbb-msg-unread-badge {
    font-size: 0.68rem;
    font-weight: 700;
    background: var(--owlbb-accent);
    color: var(--owlbb-white);
    padding: 0.15rem 0.55rem;
    border-radius: 50px;
}

.owlbb-booking-messages-body {
    border-top: 1px solid var(--owlbb-border-light);
}

.owlbb-msg-thread-inline {
    max-height: 440px;
    overflow-y: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    background: var(--owlbb-bg);
}

.owlbb-msg-empty-inline {
    text-align: center;
    color: var(--owlbb-text-muted);
    font-size: 0.9rem;
    padding: 2.5rem 0;
    margin: 0;
}

.owlbb-msg-form-inline {
    display: block;
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--owlbb-border-light);
    background: var(--owlbb-white);
}

.owlbb-msg-form-inline textarea {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: 14px;
    resize: vertical;
    font-size: 0.92rem;
    font-family: var(--owlbb-font);
    line-height: 1.45;
    min-height: 80px;
    max-height: 200px;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
    margin-bottom: 0.65rem;
}

.owlbb-msg-form-inline textarea:focus {
    border-color: var(--owlbb-accent);
    outline: none;
    box-shadow: 0 0 0 3px rgba(232, 130, 12, 0.08);
}

.owlbb-msg-form-inline .owlbb-btn {
    display: block;
    width: 100%;
}

/* ── Checkout ─────────────────────────────────────────────── */

.owlbb-checkout-page { max-width: 1040px; margin: 2.5rem auto; padding: 0 1.5rem; }
.owlbb-checkout-layout { display: flex; gap: 2.5rem; }
.owlbb-checkout-main { flex: 1; min-width: 0; }
.owlbb-checkout-main h1 { font-size: 1.75rem; margin: 0 0 1.75rem; color: var(--owlbb-dark); letter-spacing: -0.02em; }

.owlbb-checkout-section { margin-bottom: 1.75rem; }
.owlbb-checkout-section h2 { font-size: 1.1rem; margin: 0 0 0.85rem; color: var(--owlbb-dark); }

.owlbb-stripe-element {
    padding: 1.25rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius);
    background: var(--owlbb-bg);
    min-height: 60px;
}

.owlbb-pay-btn {
    margin-top: 1.25rem;
    font-size: 1.1rem;
    padding: 1rem 2rem;
    border-radius: 50px;
}

.owlbb-checkout-note { text-align: center; font-size: 0.78rem; color: var(--owlbb-text-muted); margin-top: 0.6rem; }

.owlbb-installment-info {
    background: var(--owlbb-accent-light);
    border: 1px solid #FDDCB0;
    border-radius: var(--owlbb-radius);
    padding: 1.25rem;
}

.owlbb-installment-steps { display: flex; align-items: center; gap: 1rem; }
.owlbb-installment-step { flex: 1; text-align: center; }
.owlbb-installment-step strong { display: block; font-size: 0.82rem; margin-bottom: 0.2rem; color: var(--owlbb-text-secondary); }
.owlbb-installment-step span { display: block; font-size: 1.35rem; font-weight: 700; color: var(--owlbb-dark); }
.owlbb-installment-step small { color: var(--owlbb-text-muted); }
.owlbb-installment-arrow { font-size: 1.5rem; color: var(--owlbb-accent); }

.owlbb-checkout-summary {
    width: 350px;
    flex-shrink: 0;
    background: var(--owlbb-white);
    border: 1px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.5rem;
    align-self: flex-start;
    position: sticky;
    top: 1.5rem;
    box-shadow: var(--owlbb-shadow-card);
}

.owlbb-checkout-property {
    display: flex;
    gap: 0.85rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--owlbb-border-light);
}

.owlbb-checkout-property img { width: 85px; height: 65px; object-fit: cover; border-radius: var(--owlbb-radius-sm); }
.owlbb-checkout-property h3 { font-size: 0.92rem; margin: 0 0 0.15rem; color: var(--owlbb-dark); }
.owlbb-checkout-property p { font-size: 0.8rem; color: var(--owlbb-text-muted); margin: 0; }

.owlbb-checkout-dates { margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: 1px solid var(--owlbb-border-light); }
.owlbb-checkout-dates > div { display: flex; justify-content: space-between; font-size: 0.85rem; padding: 0.2rem 0; color: var(--owlbb-text-secondary); }

/* ── Subscription ─────────────────────────────────────────── */

.owlbb-sub-current { margin-bottom: 2rem; }

.owlbb-sub-current-card {
    background: linear-gradient(135deg, var(--owlbb-accent-light), #FFF8F0);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid #FDDCB0;
}

.owlbb-sub-tier-name { font-size: 1.35rem; margin-right: 0.5rem; color: var(--owlbb-dark); }

.owlbb-sub-stats {
    display: flex;
    gap: 1.5rem;
    font-size: 0.85rem;
    color: var(--owlbb-text-secondary);
}

.owlbb-sub-section { margin-bottom: 2.5rem; }
.owlbb-sub-section h2 { font-size: 1.2rem; margin: 0 0 1.25rem; color: var(--owlbb-dark); }

.owlbb-tier-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 1rem;
}

.owlbb-tier-card {
    border: 2px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-lg);
    padding: 1.5rem;
    text-align: center;
    transition: all 0.2s;
}

.owlbb-tier-card:hover { border-color: var(--owlbb-accent); box-shadow: var(--owlbb-shadow); }

.owlbb-tier-card--active {
    border-color: var(--owlbb-accent);
    background: var(--owlbb-accent-subtle);
}

.owlbb-tier-card h3 { margin: 0 0 0.5rem; font-size: 1.1rem; color: var(--owlbb-dark); }

.owlbb-tier-price { margin-bottom: 1rem; }
.owlbb-tier-price strong { font-size: 2rem; color: var(--owlbb-dark); letter-spacing: -0.02em; }
.owlbb-tier-price span { color: var(--owlbb-text-muted); }

.owlbb-tier-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
    font-size: 0.85rem;
    color: var(--owlbb-text-secondary);
}

.owlbb-tier-features li { padding: 0.25rem 0; }

/* ── Button Variants ──────────────────────────────────────── */

.owlbb-btn--small {
    padding: 0.45rem 1rem;
    font-size: 0.82rem;
    width: auto;
    border-radius: 50px;
}

.owlbb-btn--outline {
    background: var(--owlbb-white);
    color: var(--owlbb-text);
    border: 1.5px solid var(--owlbb-border);
    box-shadow: none;
}

.owlbb-btn--outline:hover {
    border-color: var(--owlbb-accent);
    color: var(--owlbb-accent);
    background: var(--owlbb-accent-subtle);
}

/* ── No Image Placeholder ─────────────────────────────────── */

.owlbb-no-image {
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--owlbb-border-light);
    color: var(--owlbb-text-muted);
    font-size: 0.85rem;
    border-radius: var(--owlbb-radius);
}

/* ── Booking Summary Page ─────────────────────────────────── */

.owlbb-summary-page {
    max-width: 1100px; margin: 0 auto;
    padding: 2rem 1.5rem;
}

.owlbb-summary-back {
    display: inline-flex; align-items: center; gap: 0.3rem;
    font-size: 0.85rem; color: var(--owlbb-text-muted); text-decoration: none;
    margin-bottom: 0.75rem;
}
.owlbb-summary-back:hover { color: var(--owlbb-accent); }

.owlbb-summary-page h1 {
    font-size: 1.5rem; color: var(--owlbb-dark);
    margin: 0 0 1.5rem;
}

.owlbb-summary-layout {
    display: flex; gap: 2.5rem; align-items: flex-start;
}

.owlbb-summary-main { flex: 1; min-width: 0; }

/* Property card */
.owlbb-summary-property {
    display: flex; gap: 1rem; align-items: center;
    background: var(--owlbb-bg, #F7F8FA);
    border-radius: 12px; padding: 1rem;
    margin-bottom: 2rem;
}
.owlbb-summary-property-img {
    width: 120px; height: 85px; border-radius: 8px; object-fit: cover; flex-shrink: 0;
}
.owlbb-summary-property-info h2 {
    font-size: 1.05rem; margin: 0 0 0.2rem; color: var(--owlbb-dark);
}
.owlbb-summary-location {
    font-size: 0.85rem; color: var(--owlbb-text-muted);
}
.owlbb-summary-host {
    display: flex; align-items: center; gap: 0.4rem;
    margin-top: 0.4rem; font-size: 0.82rem; color: var(--owlbb-text-secondary);
}
.owlbb-summary-host img {
    width: 24px; height: 24px; border-radius: 50%; object-fit: cover;
}

/* Sections */
.owlbb-summary-section {
    margin-bottom: 1.75rem;
    padding-bottom: 1.75rem;
    border-bottom: 1px solid var(--owlbb-border-light, #F3F4F6);
}
.owlbb-summary-section:last-of-type { border-bottom: none; }
.owlbb-summary-section h3 {
    font-size: 1rem; margin: 0 0 0.75rem; color: var(--owlbb-dark);
}
.owlbb-summary-section h3 small {
    font-weight: 400; color: var(--owlbb-text-muted); font-size: 0.82rem;
}

/* Details grid */
.owlbb-summary-details {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem 2rem;
}
.owlbb-summary-detail strong {
    display: block; font-size: 0.78rem; text-transform: uppercase;
    letter-spacing: 0.04em; color: var(--owlbb-text-muted); margin-bottom: 0.15rem;
}
.owlbb-summary-detail span {
    font-size: 0.92rem; color: var(--owlbb-dark);
}

.owlbb-summary-policy, .owlbb-summary-rules {
    font-size: 0.9rem; color: var(--owlbb-text-secondary); line-height: 1.6; margin: 0;
}

.owlbb-summary-textarea {
    width: 100%; padding: 0.75rem; box-sizing: border-box;
    border: 1.5px solid var(--owlbb-border); border-radius: 10px;
    font-size: 0.9rem; font-family: var(--owlbb-font);
    resize: vertical; min-height: 80px;
    transition: border-color 0.15s;
}
.owlbb-summary-textarea:focus {
    border-color: var(--owlbb-accent); outline: none;
}

/* Booking type notice */
.owlbb-summary-notice {
    display: flex; align-items: center; gap: 0.6rem;
    background: var(--owlbb-bg, #F7F8FA); border-radius: 10px;
    padding: 0.85rem 1rem; font-size: 0.88rem;
    color: var(--owlbb-text-secondary);
}
.owlbb-summary-notice svg { flex-shrink: 0; color: var(--owlbb-accent); }

/* Sidebar */
.owlbb-summary-sidebar {
    width: 380px; flex-shrink: 0;
    position: sticky; top: 2rem;
}

.owlbb-summary-price-card {
    background: var(--owlbb-white); border: 1.5px solid var(--owlbb-border);
    border-radius: 16px; padding: 1.5rem;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.owlbb-summary-price-card h3 {
    font-size: 1.05rem; margin: 0 0 1rem; color: var(--owlbb-dark);
}

.owlbb-summary-price-lines { margin-bottom: 1rem; }
.owlbb-summary-price-line {
    display: flex; justify-content: space-between;
    font-size: 0.9rem; color: var(--owlbb-text-secondary);
    padding: 0.35rem 0;
}

.owlbb-summary-price-total {
    display: flex; justify-content: space-between;
    font-size: 1.05rem; font-weight: 700; color: var(--owlbb-dark);
    padding: 0.85rem 0; margin-bottom: 0.5rem;
    border-top: 1.5px solid var(--owlbb-border);
}

.owlbb-summary-installment {
    background: var(--owlbb-bg, #F7F8FA); border-radius: 8px;
    padding: 0.75rem; margin-bottom: 1rem; font-size: 0.85rem;
}
.owlbb-summary-installment div {
    display: flex; justify-content: space-between; padding: 0.2rem 0;
    color: var(--owlbb-text-secondary);
}

/* Payment method section */
.owlbb-summary-payment {
    margin-bottom: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--owlbb-border-light, #F3F4F6);
}

.owlbb-summary-payment h4 {
    font-size: 0.88rem; font-weight: 700; color: var(--owlbb-dark);
    margin: 0 0 0.75rem;
}

.owlbb-payment-saved-cards {
    display: flex; flex-direction: column; gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.owlbb-payment-card-option {
    display: block; cursor: pointer;
}
.owlbb-payment-card-option input { display: none; }

.owlbb-payment-card-row {
    display: flex; align-items: center; gap: 0.75rem;
    padding: 0.7rem 0.85rem;
    border: 1.5px solid var(--owlbb-border, #E5E7EB);
    border-radius: 10px;
    transition: all 0.15s;
    background: var(--owlbb-white, #fff);
}
.owlbb-payment-card-row:hover {
    border-color: var(--owlbb-accent, #E8820C);
}

.owlbb-payment-card-option--selected .owlbb-payment-card-row {
    border-color: var(--owlbb-accent, #E8820C);
    background: var(--owlbb-accent-light, #FFF7ED);
    box-shadow: 0 0 0 1px var(--owlbb-accent, #E8820C);
}

.owlbb-payment-card-brand {
    flex-shrink: 0;
}

.owlbb-payment-card-info {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column; gap: 0.05rem;
}

.owlbb-payment-card-number {
    font-size: 0.85rem; font-weight: 600; color: var(--owlbb-dark);
    letter-spacing: 0.02em;
}

.owlbb-payment-card-expiry {
    font-size: 0.75rem; color: var(--owlbb-text-muted);
}

.owlbb-payment-card-check {
    flex-shrink: 0; color: var(--owlbb-accent, #E8820C);
    opacity: 0; transition: opacity 0.15s;
}

.owlbb-payment-card-option--selected .owlbb-payment-card-check {
    opacity: 1;
}

/* Add new card option */
.owlbb-payment-card-option--new .owlbb-payment-card-row {
    gap: 0.5rem;
    font-size: 0.85rem; font-weight: 500;
    color: var(--owlbb-text-secondary);
    border-style: dashed;
}
.owlbb-payment-card-option--new svg {
    color: var(--owlbb-text-muted);
}

/* New card form */
.owlbb-payment-new-card-form {
    margin-top: 0.6rem;
    padding: 1rem;
    background: var(--owlbb-bg, #F7F8FA);
    border-radius: 10px;
}

.owlbb-payment-field {
    margin-bottom: 0.65rem;
}
.owlbb-payment-field:last-child { margin-bottom: 0; }

.owlbb-payment-field label {
    display: block; font-size: 0.72rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.04em;
    color: var(--owlbb-text-muted); margin-bottom: 0.25rem;
}

.owlbb-stripe-input {
    display: flex; align-items: center; gap: 0.5rem;
    padding: 0.6rem 0.75rem;
    background: var(--owlbb-white, #fff);
    border: 1.5px solid var(--owlbb-border, #E5E7EB);
    border-radius: 8px;
    transition: border-color 0.15s;
}
.owlbb-stripe-input:focus-within {
    border-color: var(--owlbb-accent, #E8820C);
}
.owlbb-stripe-input svg {
    flex-shrink: 0; color: var(--owlbb-text-muted);
}
.owlbb-stripe-input input {
    flex: 1; border: none; outline: none; background: transparent;
    font-size: 0.88rem; font-family: var(--owlbb-font);
    color: var(--owlbb-text, #2D2D3A);
}
.owlbb-stripe-input input::placeholder {
    color: var(--owlbb-text-muted, #9CA3AF);
}

.owlbb-payment-field-row {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0.65rem;
}

/* Secure badge */
.owlbb-payment-secure {
    display: flex; align-items: center; gap: 0.4rem;
    font-size: 0.75rem; color: var(--owlbb-text-muted);
    margin-top: 0.75rem;
}
.owlbb-payment-secure svg { flex-shrink: 0; }

.owlbb-summary-confirm-btn {
    padding: 0.85rem; font-size: 1rem; border-radius: 12px;
    margin-bottom: 0.5rem;
}

.owlbb-summary-confirm-note {
    text-align: center; font-size: 0.78rem; color: var(--owlbb-text-muted);
}

/* ── Booking Confirmed Page ──────────────────────────────── */

.owlbb-confirmed-page {
    max-width: 680px; margin: 0 auto;
    padding: 3rem 1.5rem;
}

.owlbb-confirmed-card {
    text-align: center;
}

.owlbb-confirmed-icon {
    margin-bottom: 1rem;
}

.owlbb-confirmed-page h1 {
    font-size: 1.75rem; color: var(--owlbb-dark); margin: 0 0 0.5rem;
}

.owlbb-confirmed-subtitle {
    font-size: 1rem; color: var(--owlbb-text-secondary);
    margin: 0 0 2rem; line-height: 1.6;
}

.owlbb-confirmed-summary {
    display: flex; gap: 1.25rem; text-align: left;
    background: var(--owlbb-bg, #F7F8FA); border-radius: 16px;
    padding: 1.25rem; margin-bottom: 2rem;
}

.owlbb-confirmed-thumb {
    width: 140px; height: 100px; border-radius: 10px;
    object-fit: cover; flex-shrink: 0;
}

.owlbb-confirmed-details { flex: 1; min-width: 0; }
.owlbb-confirmed-details h3 {
    font-size: 1rem; margin: 0 0 0.2rem; color: var(--owlbb-dark);
}
.owlbb-confirmed-location {
    font-size: 0.82rem; color: var(--owlbb-text-muted); display: block; margin-bottom: 0.6rem;
}

.owlbb-confirmed-meta {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem 1.5rem;
}
.owlbb-confirmed-meta div strong {
    display: block; font-size: 0.7rem; text-transform: uppercase;
    letter-spacing: 0.04em; color: var(--owlbb-text-muted);
}
.owlbb-confirmed-meta div span {
    font-size: 0.85rem; color: var(--owlbb-dark);
}

.owlbb-confirmed-next {
    text-align: left; margin-bottom: 2rem;
}
.owlbb-confirmed-next h3 {
    font-size: 1rem; margin: 0 0 0.6rem; color: var(--owlbb-dark);
}
.owlbb-confirmed-next ul {
    list-style: none; padding: 0; margin: 0;
}
.owlbb-confirmed-next li {
    font-size: 0.9rem; color: var(--owlbb-text-secondary);
    padding: 0.4rem 0 0.4rem 1.5rem; position: relative; line-height: 1.5;
}
.owlbb-confirmed-next li::before {
    content: ''; position: absolute; left: 0; top: 0.7rem;
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--owlbb-accent);
}

.owlbb-confirmed-actions {
    display: flex; gap: 0.75rem; justify-content: center;
    margin-bottom: 1.5rem;
}

.owlbb-confirmed-ref {
    font-size: 0.82rem; color: var(--owlbb-text-muted);
}

/* ── Responsive ───────────────────────────────────────────── */

@media (max-width: 1024px) {
    .owlbb-results-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .owlbb-search-fields { flex-direction: column; }

    /* Sidebar becomes a slide-out overlay on mobile */
    .owlbb-filters-sidebar {
        display: none;
        position: fixed;
        top: 0; left: 0; bottom: 0;
        width: 300px; max-width: 85vw;
        z-index: 1000;
        border-radius: 0;
        border: none;
        border-right: 1px solid var(--owlbb-border);
        max-height: 100vh;
        box-shadow: 4px 0 20px rgba(0,0,0,0.15);
        padding-bottom: 5rem;
    }
    .owlbb-filters-sidebar--mobile-open {
        display: block;
    }
    .owlbb-filters-mobile-toggle { display: inline-flex !important; }
    .owlbb-filters-mobile-close { display: block !important; position: sticky; bottom: 0; margin-top: 1rem; }

    .owlbb-results-grid { grid-template-columns: 1fr; }

    .owlbb-show-map-btn { display: none; }

    .owlbb-map-panel {
        display: none;
        width: 100%;
        height: 50vh;
        position: fixed;
        top: 0; left: 0; right: 0;
        z-index: 99;
        border-radius: 0;
    }

    .owlbb-search-layout--map-open .owlbb-map-panel { display: none; }
    .owlbb-map-panel--visible { display: block; }
    .owlbb-map-toggle { display: block; }

    .owlbb-listing-content { flex-direction: column; }

    .owlbb-booking-widget {
        width: 100%;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        border-radius: var(--owlbb-radius-lg) var(--owlbb-radius-lg) 0 0;
        z-index: 100;
        max-height: 80vh;
        overflow-y: auto;
    }

    .owlbb-gallery-hero { grid-template-columns: 1fr; max-height: 300px; }
    .owlbb-gallery-thumbs { display: none; }
    .owlbb-booking-layout { flex-direction: column; }
    .owlbb-booking-actions { width: 100%; }
    .owlbb-checkout-layout { flex-direction: column; }
    .owlbb-checkout-summary { width: 100%; position: static; }
    .owlbb-sub-current-card { flex-direction: column; gap: 0.75rem; text-align: center; }
    .owlbb-sub-stats { flex-direction: column; gap: 0.25rem; }
    .owlbb-listing-title { font-size: 1.5rem; }
    .owlbb-summary-layout { flex-direction: column; }
    .owlbb-summary-sidebar { width: 100%; position: static; }
    .owlbb-summary-details { grid-template-columns: 1fr; }
    .owlbb-summary-property { flex-direction: column; text-align: center; }
    .owlbb-summary-property-img { width: 100%; height: 160px; }
    .owlbb-confirmed-summary { flex-direction: column; }
    .owlbb-confirmed-thumb { width: 100%; height: 160px; }
    .owlbb-confirmed-meta { grid-template-columns: 1fr; }
    .owlbb-confirmed-actions { flex-direction: column; }
}

/* ── Modal Overlay ───────────────────────────────────────── */

.owlbb-modal-overlay {
    display: none;
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 10000;
    align-items: center; justify-content: center;
}
.owlbb-modal-overlay--open {
    display: flex;
}

.owlbb-modal {
    background: var(--owlbb-white, #fff);
    border-radius: 16px;
    width: 90%; max-width: 440px;
    padding: 2rem;
    position: relative;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    animation: owlbb-modal-in 0.2s ease-out;
}

@keyframes owlbb-modal-in {
    from { opacity: 0; transform: scale(0.95) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.owlbb-modal h2 {
    margin: 0 0 1.25rem; font-size: 1.15rem;
    color: var(--owlbb-dark, #1A1A2E);
}

.owlbb-modal-close {
    position: absolute; top: 1rem; right: 1rem;
    background: none; border: none; cursor: pointer;
    font-size: 1.5rem; line-height: 1; color: var(--owlbb-text-muted, #9CA3AF);
    width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
    border-radius: 50%; transition: background 0.15s;
}
.owlbb-modal-close:hover { background: rgba(0,0,0,0.06); color: var(--owlbb-dark); }

.owlbb-modal-field {
    display: flex; flex-direction: column; gap: 0.3rem;
    margin-bottom: 1rem;
}
.owlbb-modal-field label {
    font-size: 0.85rem; font-weight: 600; color: var(--owlbb-dark, #1A1A2E);
}
.owlbb-modal-field label small { font-weight: 400; color: var(--owlbb-text-muted); }

.owlbb-modal-field input,
.owlbb-modal-field textarea {
    width: 100%; padding: 0.65rem 0.75rem;
    border: 1.5px solid var(--owlbb-border, #E5E7EB);
    border-radius: 8px; font-size: 0.9rem;
    font-family: var(--owlbb-font); box-sizing: border-box;
    transition: border-color 0.15s;
}
.owlbb-modal-field input:focus,
.owlbb-modal-field textarea:focus {
    outline: none; border-color: var(--owlbb-accent, #E8820C);
}
.owlbb-modal-field textarea { resize: vertical; }

.owlbb-modal-actions {
    display: flex; gap: 0.75rem; justify-content: flex-end;
    margin-top: 1.25rem;
}

.owlbb-modal-error {
    font-size: 0.82rem; color: var(--owlbb-error, #DC2626);
    min-height: 1.2em;
}

/* ── Wishlist Picker ─────────────────────────────────────── */

.owlbb-picker-lists {
    display: flex; flex-direction: column; gap: 0;
    max-height: 260px; overflow-y: auto;
    margin-bottom: 1rem;
}

.owlbb-picker-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0.75rem 0.85rem;
    background: none; border: none; border-bottom: 1px solid var(--owlbb-border, #F3F4F6);
    cursor: pointer; text-align: left; width: 100%;
    transition: background 0.12s;
    font-family: var(--owlbb-font);
}
.owlbb-picker-item:last-child { border-bottom: none; }
.owlbb-picker-item:hover { background: #F9FAFB; }
.owlbb-picker-item--saving { opacity: 0.5; pointer-events: none; }

.owlbb-picker-item-name { font-weight: 600; font-size: 0.88rem; color: var(--owlbb-dark); }
.owlbb-picker-item-count { font-size: 0.78rem; color: var(--owlbb-text-muted); }

.owlbb-picker-divider {
    display: flex; align-items: center; gap: 0.75rem;
    margin-bottom: 1rem; color: var(--owlbb-text-muted); font-size: 0.8rem;
}
.owlbb-picker-divider::before,
.owlbb-picker-divider::after {
    content: ''; flex: 1; height: 1px; background: var(--owlbb-border, #E5E7EB);
}

.owlbb-picker-loading,
.owlbb-picker-empty {
    padding: 1.5rem; text-align: center;
    font-size: 0.85rem; color: var(--owlbb-text-muted);
}

.owlbb-btn--full { width: 100%; }

/* ── Share Modal ──────────────────────────────────────────── */

.owlbb-modal--share {
    max-width: 480px;
}

.owlbb-share-modal-header {
    text-align: center;
    margin-bottom: 1.5rem;
}

.owlbb-share-modal-header svg {
    margin-bottom: 0.5rem;
}

.owlbb-share-modal-header h2 {
    margin: 0 0 0.25rem;
    font-size: 1.25rem;
}

.owlbb-share-modal-header p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--owlbb-text-muted);
}

.owlbb-share-section {
    margin-bottom: 0.75rem;
}

.owlbb-share-section label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--owlbb-text-muted);
    margin-bottom: 0.35rem;
}

.owlbb-share-section label small {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}

.owlbb-share-copy-row {
    display: flex;
    gap: 0.5rem;
}

.owlbb-share-url-input {
    flex: 1;
    padding: 0.6rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.85rem;
    font-family: var(--owlbb-font);
    color: var(--owlbb-text-secondary);
    background: var(--owlbb-bg);
    box-sizing: border-box;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.owlbb-share-url-input:focus {
    outline: none;
    border-color: var(--owlbb-accent);
}

.owlbb-share-copied {
    display: block;
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--owlbb-success);
    margin-top: 0.35rem;
}

.owlbb-share-divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 1.25rem 0;
    color: var(--owlbb-text-muted);
    font-size: 0.78rem;
}

.owlbb-share-divider::before,
.owlbb-share-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--owlbb-border);
}

.owlbb-share-section input[type="email"],
.owlbb-share-section textarea {
    width: 100%;
    padding: 0.65rem 0.75rem;
    border: 1.5px solid var(--owlbb-border);
    border-radius: var(--owlbb-radius-sm);
    font-size: 0.9rem;
    font-family: var(--owlbb-font);
    box-sizing: border-box;
    transition: border-color 0.15s;
}

.owlbb-share-section input[type="email"]:focus,
.owlbb-share-section textarea:focus {
    outline: none;
    border-color: var(--owlbb-accent);
}

.owlbb-share-section textarea {
    resize: vertical;
    min-height: 50px;
}

.owlbb-share-email-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.75rem;
}

.owlbb-share-email-status {
    font-size: 0.82rem;
    font-weight: 500;
}

/* ── Save Heart Button ───────────────────────────────────── */

.owlbb-save-heart {
    display: inline-flex; align-items: center; gap: 0.35rem;
    background: none; border: 1px solid var(--owlbb-border, #E5E7EB);
    border-radius: 50px; padding: 0.4rem 0.85rem;
    cursor: pointer; font-size: 0.82rem; font-weight: 500;
    color: var(--owlbb-text-muted, #6B7280);
    transition: all 0.2s; font-family: var(--owlbb-font);
}
.owlbb-save-heart:hover {
    border-color: var(--owlbb-dark); color: var(--owlbb-dark);
}
.owlbb-save-heart--saved {
    color: #EF4444; border-color: #FCA5A5;
}
.owlbb-save-heart--saved:hover {
    color: #DC2626; border-color: #EF4444;
}

/* Heart overlay on property cards */
.owlbb-property-card-wrap {
    position: relative;
}

.owlbb-save-heart--overlay {
    position: absolute; top: 10px; right: 10px;
    z-index: 10;
    background: rgba(255,255,255,0.9); border: none;
    border-radius: 50%; width: 36px; height: 36px;
    padding: 0; display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    color: var(--owlbb-dark, #333);
    transition: all 0.2s;
}
.owlbb-save-heart--overlay:hover {
    background: #fff; transform: scale(1.1);
}
.owlbb-save-heart--overlay.owlbb-save-heart--saved {
    color: #EF4444;
}

/* Wishlist description on detail view */
.owlbb-wishlist-description {
    font-size: 0.88rem; color: var(--owlbb-text-muted);
    margin: 0.25rem 0 0;
}

.owlbb-wishlist-card-desc {
    font-size: 0.78rem; color: var(--owlbb-text-muted);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

@media (max-width: 480px) {
    .owlbb-modal { width: 95%; padding: 1.5rem; }
}
