/* Woodsway rentals: listings (sidebar filter + grid) and property detail.
   Loaded on top of app.css and site.css via pageStyles on those routes. */

.rentals { max-width: var(--maxw); margin: 0 auto; padding: 2.25rem clamp(1rem, 4vw, 2rem) 3.5rem; }
.rentals__head { margin-bottom: 1.5rem; }
.rentals__head h1 { font-size: clamp(1.8rem, 4vw, 2.4rem); margin: 0 0 0.25rem; }
.rentals__head p { color: var(--muted); margin: 0; }

.listings-layout { display: grid; grid-template-columns: 280px 1fr; gap: 2rem; align-items: start; }

.filters {
    background: #fff;
    border: 1px solid var(--hairline);
    border-radius: var(--radius);
    padding: 1.25rem;
    position: sticky;
    top: 1rem;
}
.filters > summary { display: none; }
.filter-group { margin-bottom: 1rem; }
.filter-group > label {
    display: block;
    font-size: 0.78rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--muted); margin-bottom: 0.4rem;
}
.filters input, .filters select {
    width: 100%;
    padding: 0.6rem 0.7rem;
    font-size: 0.95rem;
    color: var(--color-ink);
    background: #fff;
    border: 1px solid var(--hairline);
    border-radius: 10px;
}
.filters input:focus, .filters select:focus { outline: none; border-color: var(--color-primary); }
.price-row { display: flex; gap: 0.5rem; }
.filter-actions { margin-top: 1rem; }
.filter-actions .btn { width: 100%; text-align: center; }

.results__bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.results__bar .count { color: var(--muted); font-size: 0.95rem; }

.listings-layout .listings-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

.pagination { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-top: 2.5rem; }
.pagination .pg { color: var(--muted); font-size: 0.95rem; }
.pagination a, .pagination span.disabled {
    display: inline-flex; align-items: center;
    padding: 0.55rem 1.1rem;
    border: 1px solid var(--hairline);
    border-radius: 999px; font-weight: 600; font-size: 0.9rem;
}
.pagination a { color: var(--color-ink); }
.pagination a:hover { border-color: var(--color-ink); text-decoration: none; }
.pagination span.disabled { color: #aab4b6; }

/* Property detail */
.property { max-width: var(--maxw); margin: 0 auto; padding: 2rem clamp(1rem, 4vw, 2rem) 3.5rem; }
.property__back { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--muted); margin-bottom: 1rem; }
.property__top { display: flex; justify-content: space-between; gap: 1rem; align-items: flex-start; flex-wrap: wrap; margin-bottom: 1.25rem; }
.property__title h1 { font-size: clamp(1.6rem, 3.5vw, 2.2rem); margin: 0 0 0.25rem; }
.property__title p { color: var(--muted); margin: 0; }
.property__price { font-size: 1.6rem; font-weight: 700; color: var(--color-primary); white-space: nowrap; }
.property__price span { font-size: 0.9rem; font-weight: 500; color: var(--muted); }

.gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-auto-rows: 1fr; gap: 0.6rem; margin-bottom: 2rem; }
.gallery__item {
    position: relative; border: 0; padding: 0; cursor: pointer;
    border-radius: 12px; overflow: hidden; aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, var(--color-secondary), var(--color-primary));
}
.gallery__item.hero { grid-row: span 2; aspect-ratio: auto; }
.gallery__item img { width: 100%; height: 100%; object-fit: cover; }
.gallery__more {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(12, 39, 48, 0.55); color: #fff; font-weight: 700; font-size: 1.1rem;
}

.property__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 2.5rem; align-items: start; }
.spec-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.9rem 1.5rem;
    margin: 0 0 1.5rem; padding: 1.25rem;
    background: #fff; border: 1px solid var(--hairline); border-radius: var(--radius);
}
.spec { display: flex; flex-direction: column; }
.spec .k { font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); }
.spec .v { font-size: 1.05rem; font-weight: 600; color: var(--color-ink); }
.property__desc h2 { font-size: 1.3rem; margin: 1.5rem 0 0.6rem; }
.property__desc p { color: #42565c; margin: 0 0 1rem; }

.property__aside { position: sticky; top: 1rem; background: #fff; border: 1px solid var(--hairline); border-radius: var(--radius); padding: 1.5rem; }
.property__aside h3 { margin: 0 0 1rem; font-size: 1.15rem; }
.property__aside .btn { width: 100%; text-align: center; margin-bottom: 0.6rem; }
.property__aside .contact-line { color: var(--muted); font-size: 0.95rem; margin: 0.75rem 0 0; }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; background: rgba(8, 28, 35, 0.92); }
.lightbox.open { display: flex; }
.lightbox img { max-width: 92vw; max-height: 80vh; border-radius: 8px; }
.lightbox__close, .lightbox__nav {
    position: absolute; background: rgba(255, 255, 255, 0.14); color: #fff; border: 0;
    width: 46px; height: 46px; border-radius: 50%; font-size: 1.4rem; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}
.lightbox__close { top: 1.25rem; right: 1.25rem; }
.lightbox__nav.prev { left: 1.25rem; top: 50%; transform: translateY(-50%); }
.lightbox__nav.next { right: 1.25rem; top: 50%; transform: translateY(-50%); }
.lightbox__count { position: absolute; bottom: 1.25rem; left: 50%; transform: translateX(-50%); color: rgba(255, 255, 255, 0.85); font-size: 0.9rem; }

/* Property modal: a card opens the property here without leaving the page. */
.modal { position: fixed; inset: 0; z-index: 150; display: none; align-items: flex-start; justify-content: center; background: rgba(8, 28, 35, 0.55); overflow: auto; padding: 3vh 1rem; }
.modal.open { display: flex; }
.modal__panel { position: relative; width: 100%; max-width: 1000px; margin: auto; background: var(--color-bg); border-radius: 16px; box-shadow: 0 30px 60px rgba(8, 28, 35, 0.35); }
.modal__close { position: absolute; top: 0.75rem; right: 0.75rem; z-index: 2; width: 40px; height: 40px; border: 0; border-radius: 50%; background: #fff; color: var(--color-ink); font-size: 1.4rem; cursor: pointer; box-shadow: 0 4px 12px rgba(8, 28, 35, 0.18); }
.modal__loading { padding: 4rem; text-align: center; color: var(--muted); }
.modal__body .property { padding-top: 1.5rem; }
.modal__body .property__back { display: none; }

@media (max-width: 860px) {
    .listings-layout { grid-template-columns: 1fr; }
    .filters { position: static; }
    .filters > summary {
        display: flex; align-items: center; gap: 0.5rem;
        font-weight: 700; cursor: pointer; list-style: none;
    }
    .filters > summary::-webkit-details-marker { display: none; }
    .property__grid { grid-template-columns: 1fr; }
    .property__aside { position: static; }
    .gallery { grid-template-columns: 1fr 1fr; }
    .gallery__item.hero { grid-column: span 2; grid-row: auto; aspect-ratio: 16 / 9; }
}
