/**
 * VWA Realworks Connector - Directorist Compatible Styles
 *
 * These styles match the Directorist plugin styling used on vsoexclusief.nl
 * to ensure visual consistency between the original and new implementation.
 *
 * @package VWA\RealworksConnector
 */

/* ==========================================================================
   CSS Variables (matching Directorist)
   ========================================================================== */

:root {
    /* VSO Exclusief color palette */
    --directorist-primary-color: #222222;
    --directorist-primary-hover: #000000;
    --directorist-primary-dark-blue: #222222;
    --directorist-primary-gold: #b89f6a;
    --directorist-secondary-color: #f5f5f5;
    --directorist-light-gray: #f7f7f7;
    --directorist-border-color: #ececec;
    --directorist-text-color: #222222;
    --directorist-text-light: #6c757d;
    --directorist-dark-text: #222222;
    --directorist-white: #ffffff;
    --directorist-success: #28a745;
    --directorist-danger: #dc3545;
    --directorist-warning: #ffc107;
    --directorist-radius: 4px;
    --directorist-radius-lg: 15px;
    --directorist-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    --directorist-shadow-hover: 0 8px 24px rgba(0, 0, 0, 0.12);
    --directorist-transition: 0.3s ease;
    --directorist-transition-fast: 0.15s ease;
}

/* ==========================================================================
   Listing Card (Grid)
   ========================================================================== */

.directorist-listing-single {
    position: relative;
    background: var(--directorist-white);
    border-radius: var(--directorist-radius-lg);
    box-shadow: var(--directorist-shadow);
    overflow: hidden;
    transition: box-shadow var(--directorist-transition), transform var(--directorist-transition);
}

.directorist-listing-single:hover {
    box-shadow: var(--directorist-shadow-hover);
    transform: translateY(-3px);
}

.directorist-listing-single--bg {
    background-color: var(--directorist-white);
}

/* Thumbnail Area */
.directorist-listing-single__thumb {
    position: relative;
    overflow: hidden;
}

.directorist-thumnail-card {
    position: relative;
    overflow: hidden;
}

.directorist-card-cover {
    height: 280px;
}

/* Image cover card */
.directorist-card-cover-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.directorist-thumnail-card-front-wrap {
    height: 100%;
}

.directorist-thumnail-card-front-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--directorist-transition);
}

.directorist-listing-single:hover .directorist-thumnail-card-front-img {
    transform: scale(1.05);
}

/* Thumbnail Overlays */
.directorist-thumb-top-left,
.directorist-thumb-top-right,
.directorist-thumb-bottom-left,
.directorist-thumb-bottom-right {
    position: absolute;
    z-index: 2;
}

.directorist-thumb-top-left {
    top: 12px;
    left: 12px;
}

.directorist-thumb-top-right {
    top: 12px;
    right: 12px;
}

.directorist-thumb-bottom-left {
    bottom: 12px;
    left: 12px;
}

.directorist-thumb-bottom-right {
    bottom: 12px;
    right: 12px;
}

/* Favorite Button */
.directorist-mark-as-favorite__btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.9);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: background var(--directorist-transition);
}

.directorist-mark-as-favorite__btn:hover {
    background: var(--directorist-white);
}

.directorist-favorite-icon {
    width: 18px;
    height: 18px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'%3E%3C/path%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
}

.directorist-mark-as-favorite__btn.active .directorist-favorite-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23dc3545' stroke='%23dc3545' stroke-width='2'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'%3E%3C/path%3E%3C/svg%3E");
}

/* Content Area */
.directorist-listing-single__content {
    padding: 16px;
}

.directorist-listing-single__info {
    margin-bottom: 12px;
}

.directorist-listing-single__info__top {
    margin-bottom: 8px;
}

.directorist-listing-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.4;
    color: var(--directorist-text-color);
}

.directorist-listing-title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--directorist-transition);
}

.directorist-listing-title a:hover {
    color: var(--directorist-primary-color);
}

/* Info List */
.directorist-listing-single__info__list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.directorist-listing-card-address {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 0.875rem;
    color: var(--directorist-text-light);
    line-height: 1.4;
}

/* Icon Mask (for SVG icons) */
.directorist-icon-mask {
    display: inline-block;
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    background-color: currentColor;
    -webkit-mask-image: var(--directorist-icon);
    mask-image: var(--directorist-icon);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
}

/* Footer Meta */
.directorist-listing-single__meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid var(--directorist-border-color);
}

.directorist-listing-single__meta__left,
.directorist-listing-single__meta__right {
    display: flex;
    align-items: center;
}

/* Pricing */
.directorist-pricing-meta {
    font-weight: 600;
}

.directorist-listing-price {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--directorist-text-color);
}

/* Category/Status */
.directorist-listing-category a {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.875rem;
    color: var(--directorist-text-light);
    text-decoration: none;
    transition: color var(--directorist-transition);
}

.directorist-listing-category a:hover {
    color: var(--directorist-primary-color);
}

.directorist-listing-category .directorist-icon-mask {
    width: 12px;
    height: 12px;
}

/* ==========================================================================
   Swiper Slider
   ========================================================================== */

.directorist-swiper {
    position: relative;
    height: 100%;
    overflow: hidden;
}

.directorist-swiper .swiper-wrapper {
    height: 100%;
}

.directorist-swiper .swiper-slide {
    height: 100%;
}

.directorist-swiper .swiper-slide figure {
    margin: 0;
    height: 100%;
}

.directorist-swiper .swiper-slide a {
    display: block;
    height: 100%;
}

/* Swiper Navigation */
.directorist-swiper__navigation {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translateY(-50%);
    z-index: 10;
    display: flex;
    justify-content: space-between;
    padding: 0 8px;
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--directorist-transition);
}

.directorist-listing-single:hover .directorist-swiper__navigation {
    opacity: 1;
}

.directorist-swiper__nav {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    cursor: pointer;
    pointer-events: auto;
    transition: background var(--directorist-transition);
}

.directorist-swiper__nav:hover {
    background: var(--directorist-white);
}

.directorist-swiper__nav .directorist-icon-mask {
    width: 16px;
    height: 16px;
    color: var(--directorist-text-color);
}

/* Swiper Pagination */
.directorist-swiper__pagination {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 6px;
}

.directorist-swiper__pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    background: rgba(255, 255, 255, 0.5);
    border-radius: 50%;
    cursor: pointer;
    transition: background var(--directorist-transition), transform var(--directorist-transition);
}

.directorist-swiper__pagination .swiper-pagination-bullet-active {
    background: var(--directorist-white);
    transform: scale(1.2);
}

/* ==========================================================================
   Listing Grid Container
   ========================================================================== */

.directorist-listings-wrapper {
    display: grid;
    gap: 24px;
}

.directorist-listings-wrapper.directorist-grid-2 {
    grid-template-columns: repeat(2, 1fr);
}

.directorist-listings-wrapper.directorist-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.directorist-listings-wrapper.directorist-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Responsive Grid */
@media (max-width: 1200px) {
    .directorist-listings-wrapper.directorist-grid-4 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 992px) {
    .directorist-listings-wrapper.directorist-grid-3,
    .directorist-listings-wrapper.directorist-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .directorist-listings-wrapper {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Container
   ========================================================================== */

.directorist-container {
    max-width: 100%;
    margin: 0 auto;
    padding: 0 15px;
}

/* ==========================================================================
   Featured Badge
   ========================================================================== */

.directorist-listing-featured::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 40px 40px 0 0;
    border-color: var(--directorist-warning) transparent transparent transparent;
    z-index: 3;
}

.directorist-listing-featured::after {
    content: '★';
    position: absolute;
    top: 6px;
    left: 6px;
    font-size: 12px;
    color: var(--directorist-white);
    z-index: 4;
}

/* ==========================================================================
   No Results
   ========================================================================== */

.directorist-no-results {
    text-align: center;
    padding: 60px 20px;
    background: var(--directorist-secondary-color);
    border-radius: var(--directorist-radius-lg);
}

.directorist-no-results__icon {
    font-size: 48px;
    margin-bottom: 16px;
    color: var(--directorist-text-light);
}

.directorist-no-results__title {
    margin: 0 0 8px;
    font-size: 1.5rem;
    color: var(--directorist-text-color);
}

.directorist-no-results__text {
    margin: 0;
    color: var(--directorist-text-light);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.directorist-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: 32px;
}

.directorist-pagination a,
.directorist-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    background: var(--directorist-white);
    border: 1px solid var(--directorist-border-color);
    border-radius: var(--directorist-radius);
    font-size: 0.875rem;
    text-decoration: none;
    color: var(--directorist-text-color);
    transition: all var(--directorist-transition);
}

.directorist-pagination a:hover {
    background: var(--directorist-primary-color);
    border-color: var(--directorist-primary-color);
    color: var(--directorist-white);
}

.directorist-pagination .current {
    background: var(--directorist-primary-color);
    border-color: var(--directorist-primary-color);
    color: var(--directorist-white);
}

/* ==========================================================================
   Single Listing Page
   ========================================================================== */

.directorist-single-wrapper {
    padding: 0;
}

.directorist-single-contents-area {
    margin-top: 0;
}

.directorist-single-listing-top {
    display: none;
}

/* Single Header */
.directorist-single-listing-header {
    margin-bottom: 24px;
}

.directorist-listing-details__listing-title {
    display: block;
    margin: 0 0 8px;
    font-size: 2rem;
    font-weight: 700;
    color: var(--directorist-text-color);
}

.directorist-listing-details {
    display: block;
}

/* Gallery */
.directorist-single-gallery {
    margin-bottom: 24px;
}

.directorist-single-gallery-wrapper {
    position: relative;
    border-radius: var(--directorist-radius-lg);
    overflow: hidden;
}

.directorist-single-gallery-img {
    width: 100%;
    height: auto;
    display: block;
}

/* Thumbs Gallery */
.directorist-gallery-thumbs {
    display: flex;
    gap: 8px;
    margin-top: 8px;
    overflow-x: auto;
}

.directorist-gallery-thumb {
    flex-shrink: 0;
    width: 80px;
    height: 60px;
    border-radius: var(--directorist-radius);
    overflow: hidden;
    cursor: pointer;
    opacity: 0.6;
    transition: opacity var(--directorist-transition);
}

.directorist-gallery-thumb.active,
.directorist-gallery-thumb:hover {
    opacity: 1;
}

.directorist-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Description */
.directorist-single-info-content {
    margin-bottom: 24px;
}

.directorist-single-info-content h3 {
    margin: 0 0 16px;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--directorist-text-color);
}

.directorist-single-description {
    line-height: 1.7;
    color: var(--directorist-text-color);
}

/* Details/Specs */
.directorist-single-details-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

@media (max-width: 576px) {
    .directorist-single-details-list {
        grid-template-columns: 1fr;
    }
}

.directorist-single-detail-item {
    display: flex;
    justify-content: space-between;
    padding: 12px;
    background: var(--directorist-secondary-color);
    border-radius: var(--directorist-radius);
}

.directorist-single-detail-label {
    font-weight: 500;
    color: var(--directorist-text-light);
}

.directorist-single-detail-value {
    font-weight: 600;
    color: var(--directorist-text-color);
}

/* Contact Sidebar */
.directorist-single-sidebar {
    position: sticky;
    top: 24px;
}

.directorist-single-contact-owner {
    background: var(--directorist-secondary-color);
    padding: 24px;
    border-radius: var(--directorist-radius-lg);
}

.directorist-single-contact-owner h3 {
    margin: 0 0 16px;
    font-size: 1.125rem;
    font-weight: 600;
}

.directorist-single-contact-form .form-group {
    margin-bottom: 16px;
}

.directorist-single-contact-form label {
    display: block;
    margin-bottom: 6px;
    font-size: 0.875rem;
    font-weight: 500;
}

.directorist-single-contact-form input,
.directorist-single-contact-form textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--directorist-border-color);
    border-radius: var(--directorist-radius);
    font-size: 1rem;
    transition: border-color var(--directorist-transition);
}

.directorist-single-contact-form input:focus,
.directorist-single-contact-form textarea:focus {
    outline: none;
    border-color: var(--directorist-primary-color);
}

.directorist-single-contact-form button {
    width: 100%;
    padding: 12px 24px;
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
    border: none;
    border-radius: var(--directorist-radius);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--directorist-transition);
}

.directorist-single-contact-form button:hover {
    background: var(--directorist-primary-hover);
}

/* Map */
.directorist-single-map {
    height: 300px;
    border-radius: var(--directorist-radius-lg);
    overflow: hidden;
    margin-bottom: 24px;
}

/* ==========================================================================
   Filter/Header Bar
   ========================================================================== */

.directorist-instant-search-wrapper {
    margin-bottom: 24px;
}

.directorist-listings-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: var(--directorist-secondary-color);
    border-radius: var(--directorist-radius-lg);
    gap: 16px;
    flex-wrap: wrap;
}

.directorist-listings-header__left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.directorist-listings-header__right {
    display: flex;
    align-items: center;
    gap: 16px;
}

/* Filter Button */
.directorist-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
    border: none;
    border-radius: var(--directorist-radius);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--directorist-transition);
}

.directorist-filter-btn:hover {
    background: var(--directorist-primary-hover);
}

.directorist-filter-btn .directorist-icon-mask {
    width: 14px;
    height: 14px;
}

/* Total Listings Count */
.directorist-total-listings {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--directorist-text-color);
}

/* View Switcher */
.directorist-view-as {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px;
    background: var(--directorist-white);
    border-radius: var(--directorist-radius);
    border: 1px solid var(--directorist-border-color);
}

.directorist-view-as a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 32px;
    border-radius: 3px;
    color: var(--directorist-text-light);
    text-decoration: none;
    transition: all var(--directorist-transition);
}

.directorist-view-as a:hover {
    color: var(--directorist-text-color);
}

.directorist-view-as a.active {
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
}

.directorist-view-as a .directorist-icon-mask {
    width: 16px;
    height: 16px;
}

/* Dropdown */
.directorist-dropdown {
    position: relative;
}

.directorist-dropdown__toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--directorist-white);
    border: 1px solid var(--directorist-border-color);
    border-radius: var(--directorist-radius);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--directorist-text-color);
    cursor: pointer;
    transition: all var(--directorist-transition);
}

.directorist-dropdown__toggle:hover {
    border-color: var(--directorist-primary-color);
}

.directorist-dropdown__toggle .directorist-icon-mask {
    width: 12px;
    height: 12px;
}

.directorist-dropdown__menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    min-width: 180px;
    background: var(--directorist-white);
    border: 1px solid var(--directorist-border-color);
    border-radius: var(--directorist-radius);
    box-shadow: var(--directorist-shadow-hover);
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all var(--directorist-transition);
}

.directorist-dropdown.open .directorist-dropdown__menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.directorist-dropdown__item {
    display: block;
    padding: 10px 16px;
    font-size: 0.875rem;
    color: var(--directorist-text-color);
    text-decoration: none;
    transition: background var(--directorist-transition);
}

.directorist-dropdown__item:hover {
    background: var(--directorist-secondary-color);
}

.directorist-dropdown__item.active {
    color: var(--directorist-primary-color);
    font-weight: 500;
}

/* ==========================================================================
   General Button Styles
   ========================================================================== */

.directorist-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    border-radius: var(--directorist-radius);
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--directorist-transition);
}

.directorist-btn-sm {
    padding: 8px 16px;
    font-size: 0.875rem;
}

.directorist-btn-primary {
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
    border: none;
}

.directorist-btn-primary:hover {
    background: var(--directorist-primary-hover);
}

.directorist-btn-icon-left .directorist-icon-mask {
    order: -1;
}

.directorist-btn-icon-right .directorist-icon-mask {
    order: 1;
}

/* ==========================================================================
   Width Utilities
   ========================================================================== */

.directorist-w-100 {
    width: 100%;
}

/* ==========================================================================
   Responsive adjustments
   ========================================================================== */

@media (max-width: 980px) {
    .directorist-single-content {
        display: block;
    }

    .directorist-single-sidebar {
        position: static;
        margin-top: 24px;
    }
}

@media (max-width: 768px) {
    .directorist-listings-header {
        flex-direction: column;
        align-items: stretch;
    }

    .directorist-listings-header__left,
    .directorist-listings-header__right {
        justify-content: space-between;
    }
}

@media (max-width: 480px) {
    .directorist-filter-btn span:not(.directorist-icon-mask) {
        display: none;
    }

    .directorist-dropdown__toggle-label {
        max-width: 100px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}

/* ==========================================================================
   Single Page - Enhanced Layout
   ========================================================================== */

.directorist-single-wrapper {
    padding: 0;
}

/* Single Gallery Section */
.directorist-single-gallery-section {
    margin-bottom: 32px;
}

.directorist-single-gallery-main {
    position: relative;
    border-radius: var(--directorist-radius-lg);
    overflow: hidden;
    background: var(--directorist-secondary-color);
}

.directorist-swiper-single {
    height: 500px;
}

.directorist-swiper-single .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
}

.directorist-single-gallery-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.directorist-swiper__navigation--single {
    opacity: 1;
    padding: 0 16px;
}

.directorist-swiper__navigation--single .directorist-swiper__nav {
    width: 44px;
    height: 44px;
}

.directorist-swiper__pagination--single {
    bottom: 16px;
}

/* Gallery Counter */
.directorist-gallery-counter {
    position: absolute;
    bottom: 16px;
    right: 16px;
    z-index: 10;
    padding: 6px 12px;
    background: rgba(0, 0, 0, 0.6);
    color: var(--directorist-white);
    border-radius: var(--directorist-radius);
    font-size: 0.875rem;
    font-weight: 500;
}

/* Gallery Thumbnails */
.directorist-single-gallery-thumbs {
    margin-top: 12px;
}

.directorist-swiper-thumbs {
    height: 80px;
}

.directorist-swiper-thumbs .swiper-slide {
    width: 120px !important;
    height: 80px;
    border-radius: var(--directorist-radius);
    overflow: hidden;
    cursor: pointer;
    opacity: 0.5;
    transition: opacity var(--directorist-transition);
}

.directorist-swiper-thumbs .swiper-slide-thumb-active,
.directorist-swiper-thumbs .swiper-slide:hover {
    opacity: 1;
}

.directorist-swiper-thumbs .swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Single Container */
.directorist-single-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Single Header */
.directorist-single-listing-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--directorist-border-color);
}

.directorist-single-listing-header__left {
    flex: 1;
    min-width: 300px;
}

.directorist-single-listing-header__right {
    text-align: right;
}

/* Badges */
.directorist-badges {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
}

.directorist-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--directorist-radius);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--directorist-white);
    background: var(--directorist-success);
}

.directorist-badge--verkocht { background: var(--directorist-danger); }
.directorist-badge--verhuurd { background: var(--directorist-text-light); }
.directorist-badge--onder-optie { background: var(--directorist-warning); color: var(--directorist-text-color); }

/* Address */
.directorist-listing-details__address {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
    font-size: 1rem;
    color: var(--directorist-text-light);
}

.directorist-listing-details__address .directorist-icon-mask {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Single Price */
.directorist-single-price {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.directorist-single-price__amount {
    font-size: 2rem;
    font-weight: 700;
    color: var(--directorist-text-color);
}

.directorist-single-price__suffix {
    font-size: 0.9375rem;
    color: var(--directorist-text-light);
}

/* Content Wrap */
.directorist-single-content-wrap {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 40px;
}

@media (max-width: 980px) {
    .directorist-single-content-wrap {
        grid-template-columns: 1fr;
    }

    .directorist-single-sidebar {
        order: -1;
    }
}

/* Quick Specs */
.directorist-single-quick-specs {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 32px;
    padding: 20px;
    background: var(--directorist-secondary-color);
    border-radius: var(--directorist-radius-lg);
}

.directorist-quick-spec {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--directorist-white);
    border-radius: var(--directorist-radius);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--directorist-text-color);
}

.directorist-quick-spec .directorist-icon-mask {
    width: 18px;
    height: 18px;
    color: var(--directorist-text-light);
}

/* Energy Labels */
.directorist-energy-label {
    display: inline-block;
    padding: 4px 10px;
    border-radius: var(--directorist-radius);
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--directorist-white);
}

.directorist-energy-a, .directorist-energy-a\+ { background: #00a651; }
.directorist-energy-b { background: #50b848; }
.directorist-energy-c { background: #bdd62e; color: var(--directorist-text-color); }
.directorist-energy-d { background: #fff200; color: var(--directorist-text-color); }
.directorist-energy-e { background: #fdb913; }
.directorist-energy-f { background: #f37021; }
.directorist-energy-g { background: #ed1c24; }

/* Brochure Card */
.directorist-single-brochure-card {
    margin-top: 24px;
    padding: 20px;
    background: var(--directorist-secondary-color);
    border-radius: var(--directorist-radius-lg);
}

.directorist-single-brochure-card h3 {
    margin: 0 0 12px;
    font-size: 1rem;
    font-weight: 600;
}

.directorist-btn-outline {
    background: transparent;
    border: 2px solid var(--directorist-primary-color);
    color: var(--directorist-primary-color);
}

.directorist-btn-outline:hover {
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
}

.directorist-btn-block {
    width: 100%;
    justify-content: center;
}

/* Contact Intro */
.directorist-contact-intro {
    margin: 0 0 20px;
    font-size: 0.9375rem;
    color: var(--directorist-text-light);
}

/* Address Details */
.directorist-single-address-details {
    margin-bottom: 16px;
}

.directorist-single-address-details p {
    margin: 0 0 8px;
    font-size: 0.9375rem;
}

/* Responsive Single Page */
@media (max-width: 768px) {
    .directorist-swiper-single {
        height: 350px;
    }

    .directorist-single-listing-header {
        flex-direction: column;
    }

    .directorist-single-listing-header__right {
        text-align: left;
    }

    .directorist-single-price {
        flex-direction: row;
        align-items: baseline;
        gap: 8px;
    }

    .directorist-single-quick-specs {
        flex-direction: column;
    }
}

@media (max-width: 480px) {
    .directorist-swiper-single {
        height: 280px;
    }

    .directorist-single-price__amount {
        font-size: 1.5rem;
    }
}

/* ==========================================================================
   VSO Exclusief Specific Styling
   ========================================================================== */

/* Archive/Collectie Page */
.vso-archive-intro {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 48px;
    padding: 48px 20px;
}

.vso-archive-intro h1 {
    font-size: 2.5rem;
    font-weight: 400;
    letter-spacing: 0.5px;
    color: var(--directorist-text-color);
    margin: 0 0 16px;
}

.vso-archive-intro p {
    font-size: 1.125rem;
    line-height: 1.75;
    color: var(--directorist-text-light);
    margin: 0;
}

/* VSO Card enhancements */
.directorist-listing-single {
    border: 1px solid var(--directorist-border-color);
    box-shadow: none;
}

.directorist-listing-single:hover {
    border-color: transparent;
    box-shadow: var(--directorist-shadow-hover);
}

/* Card content */
.directorist-listing-single__content {
    padding: 20px;
}

/* Title styling */
.directorist-listing-title {
    font-size: 1.125rem;
    font-weight: 500;
    letter-spacing: 0.22px;
    margin-bottom: 8px;
}

/* Property features in card */
.directorist-listing-features {
    display: flex;
    gap: 16px;
    margin: 12px 0;
    font-size: 0.875rem;
    color: var(--directorist-text-light);
}

.directorist-listing-feature {
    display: flex;
    align-items: center;
    gap: 6px;
}

.directorist-listing-feature .directorist-icon-mask {
    width: 14px;
    height: 14px;
}

/* Card price styling */
.directorist-listing-price {
    font-size: 1.375rem;
    font-weight: 600;
    color: var(--directorist-text-color);
}

.directorist-listing-price-suffix {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--directorist-text-light);
    margin-left: 4px;
}

/* Status badges in cards */
.directorist-card-badge {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 5;
    padding: 6px 14px;
    border-radius: var(--directorist-radius);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--directorist-primary-color);
    color: var(--directorist-white);
}

.directorist-card-badge--sold {
    background: var(--directorist-danger);
}

.directorist-card-badge--under-option {
    background: var(--directorist-warning);
    color: var(--directorist-text-color);
}

/* Photo counter in card */
.directorist-card-photo-count {
    position: absolute;
    bottom: 12px;
    left: 12px;
    z-index: 5;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(0, 0, 0, 0.6);
    border-radius: var(--directorist-radius);
    color: var(--directorist-white);
    font-size: 0.8125rem;
    font-weight: 500;
}

.directorist-card-photo-count .directorist-icon-mask {
    width: 14px;
    height: 14px;
}

/* ==========================================================================
   Single Page - VSO Exclusief Enhanced
   ========================================================================== */

/* Full width gallery on single page */
.directorist-single-gallery-section {
    margin: 0 0 40px;
}

.directorist-single-gallery-main {
    border-radius: 0;
    background: var(--directorist-dark-text);
}

.directorist-swiper-single {
    height: 600px;
}

@media (max-width: 1200px) {
    .directorist-swiper-single {
        height: 500px;
    }
}

@media (max-width: 768px) {
    .directorist-swiper-single {
        height: 400px;
    }
}

@media (max-width: 480px) {
    .directorist-swiper-single {
        height: 300px;
    }
}

/* Single page title */
.directorist-listing-details__listing-title {
    font-size: 2.25rem;
    font-weight: 400;
    letter-spacing: 0.5px;
    line-height: 1.3;
}

/* Single page container */
.directorist-single-container {
    max-width: 1400px;
    padding: 0 40px;
}

@media (max-width: 768px) {
    .directorist-single-container {
        padding: 0 20px;
    }
}

/* Quick specs bar enhanced */
.directorist-single-quick-specs {
    background: var(--directorist-light-gray);
    padding: 24px;
    border-radius: var(--directorist-radius-lg);
    gap: 12px;
}

.directorist-quick-spec {
    background: var(--directorist-white);
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 0.9375rem;
    border: 1px solid var(--directorist-border-color);
}

/* Description section */
.directorist-single-description {
    font-size: 1rem;
    line-height: 1.85;
    color: var(--directorist-dark-text);
}

.directorist-single-description p {
    margin-bottom: 1.25em;
}

.directorist-single-description p:last-child {
    margin-bottom: 0;
}

/* Kenmerken grid enhanced */
.directorist-single-details-list {
    gap: 1px;
    background: var(--directorist-border-color);
    border-radius: var(--directorist-radius-lg);
    overflow: hidden;
}

.directorist-single-detail-item {
    background: var(--directorist-white);
    border-radius: 0;
    padding: 16px 20px;
}

.directorist-single-detail-label {
    font-size: 0.9375rem;
}

.directorist-single-detail-value {
    font-size: 0.9375rem;
}

/* Contact sidebar enhanced */
.directorist-single-contact-owner {
    background: var(--directorist-light-gray);
    padding: 32px;
    border-radius: var(--directorist-radius-lg);
    border: 1px solid var(--directorist-border-color);
}

.directorist-single-contact-owner h3 {
    font-size: 1.25rem;
    font-weight: 500;
    margin-bottom: 8px;
}

.directorist-contact-intro {
    margin-bottom: 24px;
}

/* Form inputs enhanced */
.directorist-single-contact-form input,
.directorist-single-contact-form textarea {
    padding: 14px 18px;
    border-radius: 8px;
    font-size: 0.9375rem;
    border: 1px solid var(--directorist-border-color);
    background: var(--directorist-white);
}

.directorist-single-contact-form input:focus,
.directorist-single-contact-form textarea:focus {
    border-color: var(--directorist-primary-color);
    box-shadow: 0 0 0 3px rgba(34, 34, 34, 0.1);
}

.directorist-single-contact-form label {
    font-size: 0.9375rem;
    font-weight: 500;
    margin-bottom: 8px;
}

/* Submit button */
.directorist-single-contact-form button,
.directorist-btn-primary {
    background: var(--directorist-primary-color);
    padding: 16px 28px;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.3px;
    transition: all var(--directorist-transition);
}

.directorist-single-contact-form button:hover,
.directorist-btn-primary:hover {
    background: var(--directorist-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Brochure card */
.directorist-single-brochure-card {
    background: var(--directorist-white);
    border: 1px solid var(--directorist-border-color);
    padding: 24px;
}

.directorist-single-brochure-card h3 {
    font-weight: 500;
}

/* ==========================================================================
   Header Bar / Filter Bar Enhanced
   ========================================================================== */

.directorist-listings-header {
    background: var(--directorist-white);
    border: 1px solid var(--directorist-border-color);
    padding: 16px 24px;
}

.directorist-filter-btn {
    background: var(--directorist-primary-color);
    padding: 12px 24px;
    border-radius: 8px;
    font-size: 0.9375rem;
    font-weight: 500;
}

.directorist-total-listings {
    font-size: 1rem;
    color: var(--directorist-text-light);
}

.directorist-total-listings strong {
    color: var(--directorist-text-color);
    font-weight: 600;
}

/* ==========================================================================
   Animations
   ========================================================================== */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.directorist-listing-single {
    animation: fadeInUp 0.4s ease forwards;
}

.directorist-listings-wrapper .directorist-listing-single:nth-child(1) { animation-delay: 0s; }
.directorist-listings-wrapper .directorist-listing-single:nth-child(2) { animation-delay: 0.1s; }
.directorist-listings-wrapper .directorist-listing-single:nth-child(3) { animation-delay: 0.2s; }
.directorist-listings-wrapper .directorist-listing-single:nth-child(4) { animation-delay: 0.3s; }
.directorist-listings-wrapper .directorist-listing-single:nth-child(5) { animation-delay: 0.4s; }
.directorist-listings-wrapper .directorist-listing-single:nth-child(6) { animation-delay: 0.5s; }

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    .directorist-single-sidebar,
    .directorist-swiper__navigation,
    .directorist-swiper__pagination,
    .directorist-gallery-counter {
        display: none !important;
    }

    .directorist-single-content-wrap {
        grid-template-columns: 1fr;
    }

    .directorist-single-gallery-main {
        page-break-inside: avoid;
    }
}

/* ==========================================================================
   VSO Card - vsomakelaars.nl Style
   ========================================================================== */

.vso-card {
    position: relative;
    background: var(--directorist-white);
    border-radius: 0;
    overflow: hidden;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.vso-card:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
    transform: translateY(-4px);
}

.vso-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

/* Card Image */
.vso-card__image {
    position: relative;
    height: 220px;
    overflow: hidden;
    background: #f0f0f0;
}

.vso-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.vso-card:hover .vso-card__img {
    transform: scale(1.05);
}

.vso-card__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: #e8e8e8;
    color: #aaa;
}

/* Badge */
.vso-card__badge {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5;
    padding: 8px 16px;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--directorist-white);
}

.vso-card__badge--sold {
    background: #c41e3a;
}

/* Card Content */
.vso-card__content {
    padding: 16px 20px 20px;
}

.vso-card__address {
    margin: 0 0 4px;
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.3;
    color: #222;
}

.vso-card__location {
    margin: 0 0 12px;
    font-size: 0.9375rem;
    color: #666;
    font-weight: 400;
}

.vso-card__price {
    display: flex;
    align-items: baseline;
    gap: 6px;
}

.vso-card__price-amount {
    font-size: 1.125rem;
    font-weight: 600;
    color: #222;
}

.vso-card__price-suffix {
    font-size: 0.875rem;
    font-weight: 400;
    color: #666;
}

/* ==========================================================================
   VSO Grid - vsomakelaars.nl Style
   ========================================================================== */

.vso-grid {
    display: grid;
    gap: 24px;
}

.vso-grid--cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.vso-grid--cols-3 {
    grid-template-columns: repeat(3, 1fr);
}

.vso-grid--cols-4 {
    grid-template-columns: repeat(4, 1fr);
}

/* Responsive Grid */
@media (max-width: 1200px) {
    .vso-grid--cols-4 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 992px) {
    .vso-grid--cols-3,
    .vso-grid--cols-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .vso-grid {
        grid-template-columns: 1fr;
    }

    .vso-card__image {
        height: 200px;
    }
}

/* ==========================================================================
   VSO Header Bar - vsomakelaars.nl Style
   ========================================================================== */

.vso-header-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
    padding: 16px 0;
    border-bottom: 1px solid #e5e5e5;
}

.vso-header-bar__left {
    display: flex;
    align-items: center;
    gap: 24px;
}

.vso-header-bar__right {
    display: flex;
    align-items: center;
    gap: 16px;
}

.vso-result-count {
    font-size: 1rem;
    color: #666;
}

.vso-result-count strong {
    color: #222;
    font-weight: 600;
}

/* Sort Dropdown */
.vso-sort-select {
    padding: 10px 36px 10px 14px;
    font-size: 0.9375rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
    background-size: 16px;
    appearance: none;
    cursor: pointer;
    min-width: 180px;
}

.vso-sort-select:focus {
    outline: none;
    border-color: #222;
}

/* Per Page Dropdown */
.vso-per-page-select {
    padding: 10px 36px 10px 14px;
    font-size: 0.9375rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
    background-size: 16px;
    appearance: none;
    cursor: pointer;
}

.vso-per-page-select:focus {
    outline: none;
    border-color: #222;
}

/* ==========================================================================
   VSO Pagination - vsomakelaars.nl Style
   ========================================================================== */

.vso-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid #e5e5e5;
}

.vso-pagination__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    color: #222;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.vso-pagination__item:hover {
    background: #f5f5f5;
    border-color: #222;
}

.vso-pagination__item--current {
    background: #222;
    border-color: #222;
    color: #fff;
}

.vso-pagination__item--disabled {
    opacity: 0.5;
    pointer-events: none;
}

/* ==========================================================================
   VSO CTA Card (Marketing Tiles)
   ========================================================================== */

.vso-cta-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px 24px;
    background: linear-gradient(135deg, #f8f8f8 0%, #e8e8e8 100%);
    text-align: center;
    height: 100%;
    min-height: 300px;
}

.vso-cta-card__title {
    margin: 0 0 12px;
    font-size: 1.25rem;
    font-weight: 600;
    color: #222;
}

.vso-cta-card__text {
    margin: 0 0 20px;
    font-size: 0.9375rem;
    color: #666;
    line-height: 1.6;
}

.vso-cta-card__btn {
    display: inline-block;
    padding: 12px 28px;
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    color: #fff;
    background: #222;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.vso-cta-card__btn:hover {
    background: #000;
}

/* Magazine CTA Card */
.vso-cta-card--magazine {
    background: linear-gradient(135deg, #2c3e50 0%, #1a252f 100%);
}

.vso-cta-card--magazine .vso-cta-card__title,
.vso-cta-card--magazine .vso-cta-card__text {
    color: #fff;
}

.vso-cta-card--magazine .vso-cta-card__btn {
    background: #fff;
    color: #222;
}

.vso-cta-card--magazine .vso-cta-card__btn:hover {
    background: #f0f0f0;
}

/* ==========================================================================
   VSO No Results
   ========================================================================== */

.vso-no-results {
    text-align: center;
    padding: 60px 20px;
    background: #f8f8f8;
}

.vso-no-results__icon {
    margin-bottom: 16px;
    color: #aaa;
}

.vso-no-results__title {
    margin: 0 0 8px;
    font-size: 1.5rem;
    font-weight: 600;
    color: #222;
}

.vso-no-results__text {
    margin: 0;
    font-size: 1rem;
    color: #666;
}

/* ==========================================================================
   VSO Single Page - vsomakelaars.nl Style
   ========================================================================== */

.vso-single {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0;
}

/* ==========================================================================
   VSO Hero Gallery - 4 Photo Grid
   ========================================================================== */

.vso-hero-gallery {
    position: relative;
    width: 100%;
    margin-bottom: 0;
}

.vso-hero-gallery__grid {
    display: grid;
    gap: 4px;
    height: 500px;
}

/* 1 image */
.vso-hero-gallery__grid--1 {
    grid-template-columns: 1fr;
}

/* 2 images */
.vso-hero-gallery__grid--2 {
    grid-template-columns: 1fr 1fr;
}

/* 3 images */
.vso-hero-gallery__grid--3 {
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
}

.vso-hero-gallery__grid--3 .vso-hero-gallery__item:first-child {
    grid-row: span 2;
}

/* 4 images (main layout) */
.vso-hero-gallery__grid--4 {
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}

.vso-hero-gallery__grid--4 .vso-hero-gallery__item:first-child {
    grid-row: span 2;
}

.vso-hero-gallery__item {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    background: #f0f0f0;
}

.vso-hero-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.vso-hero-gallery__item:hover img {
    transform: scale(1.03);
}

/* +X more indicator */
.vso-hero-gallery__more {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    font-size: 1.5rem;
    font-weight: 600;
}

/* Responsive Hero Gallery */
@media (max-width: 992px) {
    .vso-hero-gallery__grid {
        height: 400px;
    }

    .vso-hero-gallery__grid--4 {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr;
    }

    .vso-hero-gallery__grid--4 .vso-hero-gallery__item:first-child {
        grid-row: auto;
    }
}

@media (max-width: 576px) {
    .vso-hero-gallery__grid {
        height: 280px;
        grid-template-columns: 1fr !important;
        grid-template-rows: 1fr !important;
    }

    .vso-hero-gallery__grid .vso-hero-gallery__item:not(:first-child) {
        display: none;
    }

    .vso-hero-gallery__grid .vso-hero-gallery__item:first-child {
        grid-row: auto !important;
    }

    /* Show photo count on mobile */
    .vso-hero-gallery__item:first-child .vso-hero-gallery__more {
        display: flex;
    }
}

/* ==========================================================================
   VSO Single Navigation (Anchor Links)
   ========================================================================== */

.vso-single__nav {
    position: sticky;
    top: 0;
    z-index: 100;
    display: flex;
    gap: 0;
    background: #fff;
    border-bottom: 1px solid #e5e5e5;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.vso-single__nav-item {
    display: inline-block;
    padding: 16px 24px;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    color: #666;
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    transition: all 0.2s ease;
}

.vso-single__nav-item:hover {
    color: #222;
    background: #f8f8f8;
}

.vso-single__nav-item.active,
.vso-single__nav-item:focus {
    color: #222;
    border-bottom-color: #222;
}

/* ==========================================================================
   VSO Single Content Layout
   ========================================================================== */

.vso-single__content {
    padding: 40px;
}

@media (max-width: 768px) {
    .vso-single__content {
        padding: 24px 16px;
    }
}

/* ==========================================================================
   VSO Single Header
   ========================================================================== */

.vso-single__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 24px;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid #e5e5e5;
}

.vso-single__header-left {
    flex: 1;
    min-width: 280px;
}

.vso-single__header-right {
    text-align: right;
}

.vso-single__status {
    display: inline-block;
    margin-bottom: 8px;
    padding: 6px 14px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #fff;
    background: #27ae60;
    border-radius: 2px;
}

.vso-single__status--verkocht { background: #c41e3a; }
.vso-single__status--verhuurd { background: #7f8c8d; }
.vso-single__status--onder-optie { background: #f39c12; color: #222; }

.vso-single__title {
    margin: 0 0 8px;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.25;
    color: #222;
}

.vso-single__location {
    margin: 0;
    font-size: 1.125rem;
    color: #666;
}

.vso-single__price {
    font-size: 2rem;
    font-weight: 700;
    color: #222;
}

.vso-single__price-suffix {
    display: block;
    margin-top: 4px;
    font-size: 0.9375rem;
    font-weight: 400;
    color: #666;
}

@media (max-width: 768px) {
    .vso-single__header {
        flex-direction: column;
        gap: 16px;
    }

    .vso-single__header-right {
        text-align: left;
    }

    .vso-single__title {
        font-size: 1.5rem;
    }

    .vso-single__price {
        font-size: 1.5rem;
    }
}

/* ==========================================================================
   VSO Quick Specs Bar
   ========================================================================== */

.vso-single__specs {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 40px;
    padding: 20px;
    background: #f8f8f8;
}

.vso-spec-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    background: #fff;
    border: 1px solid #e5e5e5;
}

.vso-spec-item__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: #666;
}

.vso-spec-item__icon svg {
    width: 100%;
    height: 100%;
}

.vso-spec-item__value {
    font-size: 0.9375rem;
    font-weight: 500;
    color: #222;
}

.vso-spec-item__label {
    font-size: 0.9375rem;
    color: #666;
}

/* Energy Label */
.vso-energy-label {
    display: inline-block;
    padding: 4px 10px;
    font-weight: 700;
    font-size: 0.875rem;
    color: #fff;
    border-radius: 2px;
}

.vso-energy-label--a\+\+\+,
.vso-energy-label--a\+\+,
.vso-energy-label--a\+,
.vso-energy-label--a { background: #00a651; }
.vso-energy-label--b { background: #50b848; }
.vso-energy-label--c { background: #bdd62e; color: #222; }
.vso-energy-label--d { background: #fff200; color: #222; }
.vso-energy-label--e { background: #fdb913; }
.vso-energy-label--f { background: #f37021; }
.vso-energy-label--g { background: #ed1c24; }

@media (max-width: 576px) {
    .vso-single__specs {
        flex-direction: column;
        gap: 8px;
    }

    .vso-spec-item {
        width: 100%;
    }
}

/* ==========================================================================
   VSO Single Sections (Description, Kenmerken, etc.)
   ========================================================================== */

.vso-single__section {
    margin-bottom: 48px;
    scroll-margin-top: 70px;
}

.vso-single__section-title {
    margin: 0 0 24px;
    font-size: 1.375rem;
    font-weight: 600;
    color: #222;
}

/* ==========================================================================
   VSO Description Toggle
   ========================================================================== */

.vso-description {
    position: relative;
}

.vso-description__content {
    font-size: 1rem;
    line-height: 1.8;
    color: #444;
}

.vso-description__content p {
    margin: 0 0 1.25em;
}

.vso-description__content p:last-child {
    margin-bottom: 0;
}

.vso-description--collapsed .vso-description__content {
    max-height: 200px;
    overflow: hidden;
    position: relative;
}

.vso-description--collapsed .vso-description__content::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);
    pointer-events: none;
}

.vso-description__toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 16px;
    padding: 0;
    font-size: 0.9375rem;
    font-weight: 500;
    color: #222;
    background: none;
    border: none;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.vso-description__toggle:hover {
    color: #666;
}

.vso-description__toggle svg {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.vso-description--expanded .vso-description__toggle svg {
    transform: rotate(180deg);
}

/* ==========================================================================
   VSO Kenmerken Grid (Collapsible Columns)
   ========================================================================== */

.vso-kenmerken {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
}

@media (max-width: 768px) {
    .vso-kenmerken {
        grid-template-columns: 1fr;
    }
}

.vso-kenmerken__column {
    /* Column styling */
}

.vso-kenmerken__group {
    margin-bottom: 24px;
}

.vso-kenmerken__group:last-child {
    margin-bottom: 0;
}

.vso-kenmerken__group-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 0 12px;
    padding-bottom: 8px;
    font-size: 1rem;
    font-weight: 600;
    color: #222;
    border-bottom: 1px solid #e5e5e5;
    cursor: pointer;
}

.vso-kenmerken__group-title svg {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.vso-kenmerken__group.collapsed .vso-kenmerken__group-title svg {
    transform: rotate(-90deg);
}

.vso-kenmerken__group.collapsed .vso-kenmerken__list {
    display: none;
}

.vso-kenmerken__list {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.vso-kenmerken__item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid #f0f0f0;
}

.vso-kenmerken__item:last-child {
    border-bottom: none;
}

.vso-kenmerken__label {
    font-size: 0.9375rem;
    color: #666;
    flex-shrink: 0;
    width: 45%;
}

.vso-kenmerken__value {
    font-size: 0.9375rem;
    font-weight: 500;
    color: #222;
    text-align: right;
    flex: 1;
}

/* Toggle button for kenmerken */
.vso-kenmerken__toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 24px;
    padding: 12px 24px;
    font-size: 0.9375rem;
    font-weight: 500;
    color: #222;
    background: #fff;
    border: 1px solid #222;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vso-kenmerken__toggle:hover {
    background: #222;
    color: #fff;
}

.vso-kenmerken__toggle svg {
    width: 16px;
    height: 16px;
}

/* ==========================================================================
   VSO Media Grid (Gallery Section)
   ========================================================================== */

.vso-media-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
}

@media (max-width: 992px) {
    .vso-media-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

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

.vso-media-grid__item {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    cursor: pointer;
    background: #f0f0f0;
}

.vso-media-grid__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.vso-media-grid__item:hover img {
    transform: scale(1.05);
}

/* Initially hidden items */
.vso-media-grid__item--hidden {
    display: none;
}

.vso-media-grid.expanded .vso-media-grid__item--hidden {
    display: block;
}

/* More photos button */
.vso-media-grid__more {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #f0f0f0;
    color: #222;
    font-size: 0.9375rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s ease;
}

.vso-media-grid__more:hover {
    background: #e0e0e0;
}

.vso-media-grid__more-icon {
    width: 24px;
    height: 24px;
}

/* Button to expand gallery */
.vso-media-grid__btn {
    grid-column: 1 / -1;
    margin-top: 16px;
    padding: 14px 28px;
    font-size: 0.9375rem;
    font-weight: 500;
    text-align: center;
    color: #222;
    background: #fff;
    border: 1px solid #222;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vso-media-grid__btn:hover {
    background: #222;
    color: #fff;
}

.vso-media-grid.expanded .vso-media-grid__btn {
    display: none;
}

/* ==========================================================================
   VSO Lightbox
   ========================================================================== */

.vso-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.95);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.vso-lightbox.active {
    display: flex;
    opacity: 1;
}

.vso-lightbox__close {
    position: absolute;
    top: 20px;
    right: 20px;
    z-index: 10;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background 0.2s ease;
}

.vso-lightbox__close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.vso-lightbox__close svg {
    width: 24px;
    height: 24px;
}

.vso-lightbox__container {
    position: relative;
    max-width: 90vw;
    max-height: 90vh;
}

.vso-lightbox__image {
    max-width: 100%;
    max-height: 85vh;
    object-fit: contain;
}

.vso-lightbox__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    transition: background 0.2s ease;
}

.vso-lightbox__nav:hover {
    background: rgba(255, 255, 255, 0.2);
}

.vso-lightbox__nav--prev {
    left: 20px;
}

.vso-lightbox__nav--next {
    right: 20px;
}

.vso-lightbox__nav svg {
    width: 24px;
    height: 24px;
}

.vso-lightbox__counter {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    padding: 8px 16px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 4px;
    color: #fff;
    font-size: 0.9375rem;
}

/* Thumbnails in lightbox */
.vso-lightbox__thumbs {
    position: absolute;
    bottom: 60px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    max-width: 90vw;
    overflow-x: auto;
    padding: 10px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 4px;
}

.vso-lightbox__thumb {
    flex-shrink: 0;
    width: 60px;
    height: 45px;
    overflow: hidden;
    border-radius: 2px;
    cursor: pointer;
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

.vso-lightbox__thumb:hover,
.vso-lightbox__thumb.active {
    opacity: 1;
}

.vso-lightbox__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ==========================================================================
   VSO Modal (Contact Form)
   ========================================================================== */

.vso-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(0, 0, 0, 0.6);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.vso-modal-overlay.active {
    display: flex;
    opacity: 1;
}

.vso-modal {
    position: relative;
    width: 100%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
    background: #fff;
    border-radius: 0;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.vso-modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f0f0f0;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: background 0.2s ease;
}

.vso-modal__close:hover {
    background: #e0e0e0;
}

.vso-modal__close svg {
    width: 20px;
    height: 20px;
}

.vso-modal__header {
    padding: 32px 32px 0;
}

.vso-modal__title {
    margin: 0 0 8px;
    font-size: 1.5rem;
    font-weight: 600;
    color: #222;
}

.vso-modal__subtitle {
    margin: 0;
    font-size: 1rem;
    color: #666;
}

.vso-modal__body {
    padding: 24px 32px 32px;
}

/* ==========================================================================
   VSO Contact Form
   ========================================================================== */

.vso-contact-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.vso-contact-form__group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.vso-contact-form__label {
    font-size: 0.9375rem;
    font-weight: 500;
    color: #222;
}

.vso-contact-form__label--required::after {
    content: ' *';
    color: #c41e3a;
}

.vso-contact-form__input,
.vso-contact-form__textarea {
    width: 100%;
    padding: 14px 16px;
    font-size: 1rem;
    font-family: inherit;
    color: #222;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 0;
    transition: border-color 0.2s ease;
}

.vso-contact-form__input:focus,
.vso-contact-form__textarea:focus {
    outline: none;
    border-color: #222;
}

.vso-contact-form__input::placeholder,
.vso-contact-form__textarea::placeholder {
    color: #999;
}

.vso-contact-form__textarea {
    min-height: 120px;
    resize: vertical;
}

.vso-contact-form__checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.vso-contact-form__checkbox {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: #222;
}

.vso-contact-form__checkbox-label {
    font-size: 0.875rem;
    color: #666;
    line-height: 1.5;
}

.vso-contact-form__checkbox-label a {
    color: #222;
    text-decoration: underline;
}

.vso-contact-form__submit {
    margin-top: 8px;
    padding: 16px 32px;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background: #222;
    border: none;
    cursor: pointer;
    transition: background 0.2s ease;
}

.vso-contact-form__submit:hover {
    background: #000;
}

.vso-contact-form__submit:disabled {
    background: #ccc;
    cursor: not-allowed;
}

/* ==========================================================================
   VSO Contact Bar (Sticky Bottom)
   ========================================================================== */

.vso-contact-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 16px 24px;
    background: #fff;
    border-top: 1px solid #e5e5e5;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
}

.vso-contact-bar__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 32px;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 0;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vso-contact-bar__btn--primary {
    color: #fff;
    background: #222;
    border: 2px solid #222;
}

.vso-contact-bar__btn--primary:hover {
    background: #000;
    border-color: #000;
}

.vso-contact-bar__btn--secondary {
    color: #222;
    background: #fff;
    border: 2px solid #222;
}

.vso-contact-bar__btn--secondary:hover {
    background: #f8f8f8;
}

.vso-contact-bar__btn svg {
    width: 20px;
    height: 20px;
}

@media (max-width: 576px) {
    .vso-contact-bar {
        flex-direction: column;
        gap: 8px;
    }

    .vso-contact-bar__btn {
        width: 100%;
    }
}

/* ==========================================================================
   VSO Share/Social Links
   ========================================================================== */

.vso-share {
    display: flex;
    align-items: center;
    gap: 16px;
}

.vso-share__label {
    font-size: 0.9375rem;
    font-weight: 500;
    color: #666;
}

.vso-share__links {
    display: flex;
    gap: 8px;
}

.vso-share__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    color: #666;
    background: #f0f0f0;
    border-radius: 50%;
    text-decoration: none;
    transition: all 0.2s ease;
}

.vso-share__link:hover {
    color: #fff;
}

.vso-share__link--facebook:hover { background: #1877f2; }
.vso-share__link--twitter:hover { background: #1da1f2; }
.vso-share__link--whatsapp:hover { background: #25d366; }
.vso-share__link--email:hover { background: #666; }
.vso-share__link--copy:hover { background: #222; }

.vso-share__link svg {
    width: 18px;
    height: 18px;
}

/* Copy link tooltip */
.vso-share__link--copy.copied::after {
    content: 'Gekopieerd!';
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    padding: 6px 12px;
    font-size: 0.75rem;
    color: #fff;
    background: #222;
    border-radius: 4px;
    white-space: nowrap;
}

/* ==========================================================================
   VSO Downloads Section
   ========================================================================== */

.vso-downloads {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.vso-download-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 20px;
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
    color: #222;
    background: #f8f8f8;
    border: 1px solid #e5e5e5;
    transition: all 0.2s ease;
}

.vso-download-item:hover {
    background: #fff;
    border-color: #222;
}

.vso-download-item svg {
    width: 20px;
    height: 20px;
    color: #666;
}

/* ==========================================================================
   VSO Map Section
   ========================================================================== */

.vso-map {
    height: 400px;
    background: #f0f0f0;
    border: 1px solid #e5e5e5;
}

.vso-map iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

/* ==========================================================================
   Print Styles - Single Page
   ========================================================================== */

@media print {
    .vso-single__nav,
    .vso-contact-bar,
    .vso-share,
    .vso-lightbox,
    .vso-modal-overlay {
        display: none !important;
    }

    .vso-hero-gallery__grid {
        height: auto;
    }

    .vso-description--collapsed .vso-description__content {
        max-height: none;
    }

    .vso-description--collapsed .vso-description__content::after {
        display: none;
    }

    .vso-kenmerken__group.collapsed .vso-kenmerken__list {
        display: flex;
    }
}
