/* =========================================
   ILNM PROPERTY SINGLE PAGE
   ========================================= */

:root{
    --ilnm-bg:#f0f2f5;
    --ilnm-card:#ffffff;
    --ilnm-border:#e8edf3;
    --ilnm-border-soft:#eef0f2;
    --ilnm-text:#1f2937;
    --ilnm-text-2:#374151;
    --ilnm-text-3:#6b7280;
    --ilnm-blue:#0088cc;
    --ilnm-green:#1abc9c;
    --ilnm-green-dark:#0f766e;
    --ilnm-purple:#8e44ad;
    --ilnm-orange:#f39c12;
    --ilnm-shadow:0 8px 30px rgba(15,23,42,.05);
    --ilnm-radius:20px;
}

/* page background */
.single-listing .container.property,
.post-type-archive-listing,
.tax-listing_category{
    background:transparent;
}

body.single-listing{
    background:var(--ilnm-bg);
}

/* left content area */
.listeo-single-listing-content{
    display:flex;
    flex-direction:column;
    gap:32px;
}

/* -----------------------------------------
   PROPERTY HEADER
   ----------------------------------------- */
.property-header{
    width:100%;
    background:var(--ilnm-card);
    padding:30px;
    border-radius:var(--ilnm-radius);
    border:1px solid var(--ilnm-border-soft);
    display:flex;
    flex-direction:column;
    gap:20px;
    box-shadow:var(--ilnm-shadow);
}

.header-top{
    display:flex;
    align-items:flex-start;
}

.price-container{
    display:flex;
    flex-direction:column;
    min-width:210px;
}

.featured-badge{
    background:var(--ilnm-purple);
    color:#fff;
    font-size:11px;
    font-weight:700;
    padding:4px 8px;
    border-radius:4px;
    width:fit-content;
    text-transform:uppercase;
    margin-bottom:8px;
    letter-spacing:.3px;
}

.main-price{
    font-size:32px;
    font-weight:800;
    color:var(--ilnm-text);
    display:flex;
    align-items:baseline;
    gap:10px;
    line-height:1.1;
}

.price-sub{
    font-size:14px;
    font-weight:500;
    color:var(--ilnm-text-3);
}

.title-container{
    flex:1;
    border-left:1px solid #eee;
    margin-left:40px;
    padding-left:40px;
}

.main-title{
    font-size:24px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0 0 6px;
    line-height:1.25;
}

.location-text{
    font-size:14px;
    color:var(--ilnm-text-3);
    margin:0 0 4px;
}

/* -----------------------------------------
   STATUS BAR
   ----------------------------------------- */
.status-bar{
    display:flex;
    align-items:center;
    gap:20px;
    flex-wrap:wrap;
    font-size:13px;
}

.rera-badge{
    background:var(--ilnm-green);
    color:#fff;
    padding:6px 12px;
    border-radius:4px;
    font-weight:700;
    display:flex;
    align-items:center;
    gap:6px;
    letter-spacing:.2px;
}

.not-available{
    color:var(--ilnm-green);
    font-weight:700;
    letter-spacing:.3px;
}

.website-link{
    color:var(--ilnm-text-3);
}

.website-link a{
    color:var(--ilnm-blue);
    text-decoration:none;
}

.website-link a:hover{
    text-decoration:underline;
}

/* -----------------------------------------
   TABS
   ----------------------------------------- */
.tabs-container{
    border-top:1px solid #eee;
    padding-top:20px;
    margin-top:10px;
    display:flex;
    gap:40px;
    background:#fff;
    transition:all .3s ease;
    overflow-x:auto;
    scrollbar-width:none;
}

.tabs-container::-webkit-scrollbar{
    display:none;
}

.tabs-container.sticky{
    position:fixed;
    top:0;
    z-index:1000;
    width:calc(100% - 48px);
    max-width:calc(66.666% - 22px);
    padding:15px 30px;
    margin-top:0;
    border-top:none;
    border-bottom:1px solid #eee;
    box-shadow:0 4px 20px rgba(0,0,0,.08);
    animation:ilnmSlideDown .35s ease;
}

@keyframes ilnmSlideDown{
    from{transform:translateY(-100%)}
    to{transform:translateY(0)}
}

.tab-item{
    font-size:16px;
    font-weight:600;
    color:#555;
    cursor:pointer;
    position:relative;
    padding-bottom:12px;
    transition:color .3s;
    text-decoration:none;
    white-space:nowrap;
}

.tab-item:hover,
.tab-item.active{
    color:var(--ilnm-blue);
}

.tab-item.active::after{
    content:"";
    position:absolute;
    bottom:-1px;
    left:0;
    width:100%;
    height:3px;
    background:var(--ilnm-blue);
    border-radius:3px 3px 0 0;
}

/* -----------------------------------------
   OVERVIEW BLOCK
   ----------------------------------------- */
.property-container{
    display:flex;
    width:100%;
    background:transparent;
    gap:0;
    align-items:stretch;
}

.media-column{
    flex:1.15;
    position:relative;
    border-radius:var(--ilnm-radius) 0 0 var(--ilnm-radius);
    overflow:hidden;
    min-height:500px;
    background:#dde3ea;
}

.media-column > a,
.media-column .mfp-gallery{
    display:block;
    width:100%;
    height:100%;
}

.media-image{
    width:100%;
    height:100%;
    min-height:500px;
    object-fit:cover;
    display:block;
}

/* right overview details */
.details-column{
    flex:1;
    background:#fff;
    padding:40px;
    border-radius:0 var(--ilnm-radius) var(--ilnm-radius) 0;
    box-shadow:var(--ilnm-shadow);
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    border:1px solid var(--ilnm-border-soft);
    border-left:none;
}

.details-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:34px 28px;
}

.detail-item{
    display:flex;
    gap:14px;
    align-items:flex-start;
}

.detail-icon{
    width:28px;
    height:28px;
    flex-shrink:0;
    margin-top:2px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
}

.detail-content{
    display:flex;
    flex-direction:column;
    gap:4px;
}

.detail-label{
    color:var(--ilnm-text-3);
    font-size:13px;
    font-weight:400;
    margin-bottom:2px;
}

.detail-value{
    color:var(--ilnm-text);
    font-size:20px;
    font-weight:700;
    display:flex;
    align-items:baseline;
    gap:6px;
    line-height:1.2;
}

.detail-value .unit{
    color:var(--ilnm-blue);
    font-weight:600;
    font-size:13px;
}

.detail-subvalue{
    color:var(--ilnm-text-3);
    font-size:11px;
    margin-top:2px;
}

.detail-desc{
    color:var(--ilnm-text);
    font-size:14px;
    line-height:1.45;
    font-weight:600;
    margin:0;
}

.icon-area{ color:#5fb9b0; }
.icon-door{ color:#48c9b0; }
.icon-floor{ color:#1abc9c; }

/* -----------------------------------------
   BELOW SECTIONS WRAPPER
   ----------------------------------------- */
.sections-wrapper{
    width:100%;
    display:flex;
    flex-direction:column;
    gap:32px;
}

/* -----------------------------------------
   HIGHLIGHTS
   ----------------------------------------- */
.highlights-title{
    font-size:20px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0 0 14px;
}

.highlights-card{
    background:#f4fbff;
    border-radius:var(--ilnm-radius);
    display:flex;
    overflow:hidden;
    padding:28px;
    gap:34px;
    border:1px solid #dbeffd;
}

.highlights-left{
    flex:0 0 150px;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
}

.highlights-icon{
    width:44px;
    height:44px;
    margin-bottom:15px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.highlights-left h3{
    font-size:15px;
    font-weight:700;
    line-height:1.3;
    margin:0;
}

.highlights-left p{
    font-size:12px;
    color:var(--ilnm-text-3);
    margin-top:4px;
}

.highlights-right{
    flex:1;
    background:#fff;
    border-radius:16px;
    padding:24px;
    position:relative;
    border:1px solid #eef2f7;
}

.highlights-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px 28px;
}

.highlight-item{
    display:flex;
    align-items:center;
    gap:10px;
    font-size:14px;
    font-weight:500;
    color:var(--ilnm-text);
    line-height:1.35;
}

.tick-icon,
.highlight-item .fa{
    color:#27ae60;
}

/* -----------------------------------------
   FINANCIAL SUMMARY GRID
   ----------------------------------------- */
.details-summary{
    background:#fff;
    border-radius:var(--ilnm-radius);
    padding:28px;
    border:1px solid var(--ilnm-border-soft);
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
    box-shadow:var(--ilnm-shadow);
}

.summary-item{
    display:flex;
    flex-direction:column;
    gap:4px;
}

.summary-label{
    color:var(--ilnm-text-3);
    font-size:13px;
    font-weight:400;
}

.summary-value{
    color:var(--ilnm-text);
    font-size:14px;
    font-weight:600;
    line-height:1.45;
}

/* -----------------------------------------
   FACILITIES
   ----------------------------------------- */
.facilities-section{
    background:#fff;
    border-radius:var(--ilnm-radius);
    padding:30px;
    border:1px solid var(--ilnm-border-soft);
    box-shadow:var(--ilnm-shadow);
}

.facilities-title{
    font-size:20px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0 0 24px;
}

.facilities-list{
    display:flex;
    flex-wrap:wrap;
    gap:22px 34px;
}

.facility-item{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:220px;
}

.facility-icon{
    width:24px;
    height:24px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--ilnm-green);
    font-size:18px;
}

.facility-name{
    font-size:13px;
    font-weight:500;
    color:var(--ilnm-text-2);
    line-height:1.35;
}

/* -----------------------------------------
   ABOUT PROPERTY
   ----------------------------------------- */
.about-section{
    background:#fff;
    border-radius:var(--ilnm-radius);
    padding:30px;
    border:1px solid var(--ilnm-border-soft);
    box-shadow:var(--ilnm-shadow);
}

.about-title{
    font-size:20px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0 0 18px;
}

.about-content{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.about-address{
    font-size:14px;
    color:var(--ilnm-text);
    line-height:1.55;
    margin:0;
}

.about-address strong{
    font-weight:700;
    color:var(--ilnm-text-2);
}

.about-desc{
    font-size:14px;
    color:var(--ilnm-text-2);
    line-height:1.7;
    margin:0;
}

/* -----------------------------------------
   BUILDING DETAILS
   ----------------------------------------- */
.building-section{
    background:#fff;
    border-radius:var(--ilnm-radius);
    padding:30px;
    border:1px solid var(--ilnm-border-soft);
    box-shadow:var(--ilnm-shadow);
}

.building-title{
    font-size:20px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0;
}

.building-subtitle{
    font-size:14px;
    color:var(--ilnm-text-3);
    margin:8px 0 24px;
}

.building-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:28px;
    padding-top:24px;
    border-top:1px solid #f1f3f5;
}

.building-item{
    display:flex;
    flex-direction:column;
    gap:6px;
}

.building-label{
    color:var(--ilnm-text-3);
    font-size:13px;
    font-weight:400;
}

.building-value{
    color:var(--ilnm-text);
    font-size:14px;
    font-weight:600;
    line-height:1.45;
}

/* -----------------------------------------
   AMENITIES
   ----------------------------------------- */
.amenities-section{
    background:#fff;
    border-radius:var(--ilnm-radius);
    padding:30px;
    border:1px solid var(--ilnm-border-soft);
    box-shadow:var(--ilnm-shadow);
}

.amenities-title{
    font-size:20px;
    font-weight:700;
    color:var(--ilnm-text);
    margin:0 0 28px;
}

.amenities-grid{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    gap:28px 18px;
}

.amenity-item{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
}

.amenity-icon-box{
    width:28px;
    height:28px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--ilnm-blue);
    font-size:18px;
}

.amenity-name{
    font-size:12px;
    font-weight:500;
    color:var(--ilnm-text-2);
    line-height:1.35;
}

/* -----------------------------------------
   BOTTOM GALLERY GRID
   ----------------------------------------- */
.gallery-section{
    display:flex;
    gap:6px;
    background:#fff;
    padding:8px;
    border-radius:var(--ilnm-radius);
    border:1px solid var(--ilnm-border-soft);
    overflow:hidden;
    box-shadow:var(--ilnm-shadow);
}

.gallery-item{
    flex:1;
    height:160px;
    position:relative;
    cursor:pointer;
    overflow:hidden;
    border-radius:6px;
    display:block;
    background:#f1f5f9;
}

.gallery-item img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .5s ease;
    display:block;
}

.gallery-item:hover img{
    transform:scale(1.08);
}

.more-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.58);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    color:#fff;
    text-align:center;
    font-weight:700;
    font-size:14px;
    line-height:1.3;
}

/* -----------------------------------------
   PROPERTY-ONLY LOCATION CARD
   ----------------------------------------- */
.ilnm-property-location-section{
    margin-top:0;
}

.ilnm-property-location-card{
    background:#fff;
    border:1px solid var(--ilnm-border-soft);
    border-radius:var(--ilnm-radius);
    padding:24px;
    box-shadow:var(--ilnm-shadow);
}

.ilnm-property-location-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:16px;
    margin-bottom:18px;
}

.ilnm-property-section-title{
    margin:0 0 6px;
    font-size:20px;
    color:var(--ilnm-text);
}

.ilnm-property-location-address{
    font-size:15px;
    color:var(--ilnm-text-2);
    font-weight:600;
    margin-bottom:4px;
}

.ilnm-property-location-subaddress{
    font-size:14px;
    color:var(--ilnm-text-3);
}

.ilnm-property-direction-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:12px;
    background:#111827;
    color:#fff !important;
    text-decoration:none;
    font-size:13px;
    font-weight:700;
    white-space:nowrap;
}

.ilnm-property-direction-btn:hover{
    opacity:.92;
}

.ilnm-property-map-wrap{
    overflow:hidden;
    border-radius:16px;
    border:1px solid #e5e7eb;
}

.ilnm-property-map-wrap #singleListingMap{
    min-height:420px;
}

/* -----------------------------------------
   HIDE OLD PROPERTY-ONLY PARTIAL UI BLOCKS
   because single-listing.php now renders
   the master property layout
   ----------------------------------------- */
.single-listing .property .ilnm-property-main-details,
.single-listing .property .ilnm-property-pricing-section,
.single-listing .property .ilnm-property-features-section,
.single-listing .property .ilnm-property-gallery-section,
.single-listing .property .ilnm-property-top-gallery{
    display:none !important;
}

/* -----------------------------------------
   DEFAULT LISTEO CLEANUP FOR PROPERTY PAGE
   ----------------------------------------- */
.single-listing .container.property .listing-nav-container,
.single-listing .container.property #listing-nav{
    display:none !important;
}

.single-listing .container.property #titlebar{
    display:none !important;
}

.single-listing .container.property #listing-overview.listing-section{
    padding:0 !important;
    margin:0 !important;
    border:none !important;
    background:transparent !important;
    box-shadow:none !important;
}

.single-listing .container.property .single-listing-page-titlebar{
    display:none !important;
}

.single-listing .container.property .listing-desc-headline{
    margin-top:0 !important;
}

/* -----------------------------------------
   SIDEBAR ALIGNMENT
   ----------------------------------------- */
.listeo-single-listing-sidebar.sticky{
    align-self:flex-start;
}

.listeo-single-listing-sidebar .widget,
.listeo-single-listing-sidebar .boxed-widget{
    border-radius:18px;
    overflow:hidden;
}

/* -----------------------------------------
   RESPONSIVE
   ----------------------------------------- */
@media (max-width: 1199px){
    .details-summary{
        grid-template-columns:repeat(3,1fr);
    }

    .building-grid{
        grid-template-columns:repeat(3,1fr);
    }

    .amenities-grid{
        grid-template-columns:repeat(4,1fr);
    }
}

@media (max-width: 991px){
    .property-container{
        flex-direction:column;
    }

    .media-column{
        border-radius:var(--ilnm-radius) var(--ilnm-radius) 0 0;
        min-height:320px;
    }

    .media-image{
        min-height:320px;
    }

    .details-column{
        border-radius:0 0 var(--ilnm-radius) var(--ilnm-radius);
        border-left:1px solid var(--ilnm-border-soft);
        border-top:none;
        padding:30px 20px;
    }

    .details-summary{
        grid-template-columns:repeat(2,1fr);
    }

    .building-grid{
        grid-template-columns:1fr 1fr;
    }

    .amenities-grid{
        grid-template-columns:repeat(3,1fr);
    }

    .tabs-container.sticky{
        max-width:100%;
        width:calc(100% - 30px);
        left:15px;
    }
}

@media (max-width: 850px){
    .header-top{
        flex-direction:column;
        gap:20px;
    }

    .title-container{
        border-left:none;
        margin-left:0;
        padding-left:0;
    }

    .highlights-card{
        flex-direction:column;
        gap:20px;
        padding:20px;
    }

    .highlights-left{
        flex:none;
        flex-direction:row;
        text-align:left;
        gap:15px;
        align-items:center;
    }

    .highlights-grid{
        grid-template-columns:1fr;
    }

    .gallery-section{
        flex-wrap:wrap;
    }

    .gallery-item{
        flex:1 1 calc(33.333% - 4px);
    }

    .facilities-list{
        gap:18px;
    }
}

@media (max-width: 767px){
    .property-header,
    .facilities-section,
    .about-section,
    .building-section,
    .amenities-section,
    .ilnm-property-location-card{
        padding:22px 18px;
    }

    .main-title{
        font-size:20px;
    }

    .main-price{
        font-size:26px;
    }

    .details-grid{
        grid-template-columns:1fr;
        gap:22px;
    }

    .details-summary{
        grid-template-columns:1fr;
    }

    .building-grid{
        grid-template-columns:1fr;
    }

    .amenities-grid{
        grid-template-columns:1fr 1fr;
    }

    .ilnm-property-location-header{
        flex-direction:column;
        align-items:stretch;
    }

    .ilnm-property-direction-btn{
        width:100%;
    }

    .ilnm-property-map-wrap #singleListingMap{
        min-height:320px;
    }

    .tabs-container{
        gap:24px;
    }
}

body.single-listing .container.property {
    padding-top: 28px;
}

@media (max-width: 767px) {
    body.single-listing .container.property {
        padding-top: 18px;
    }
}