/**
 * property-card-overlay.css - Simple Property Cards with Click-based Information Display
 * 
 * Clean, simple card design:
 * - Image carousel (always visible, scrollable)
 * - Information appears on click (both desktop and mobile)
 * - First click shows info, second click navigates
 * - Compact overlay that doesn't occupy too much space
 * - Centered indicators
 * - Optimized progressive image loading
 */

/* ==========================================================================
   Base Card Structure - Fixed Dimensions
   ========================================================================== */

.property-card--overlay,
.property-card--hover {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    background: var(--color-background, #fff);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    height: 100%;
    min-height: 450px;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

.property-card--overlay:hover,
.property-card--hover:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

/* ==========================================================================
   Image Container - Fixed Aspect Ratio, Centered Images
   ========================================================================== */

.property-card--overlay .property-card-image,
.property-card--hover .property-card-image {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 450px;
    overflow: hidden;
    background: var(--color-background-secondary, #1a1a1a);
    aspect-ratio: 16/9;
}

@media (min-width: 1400px) {
    .property-card--overlay .property-card-image,
    .property-card--hover .property-card-image {
        aspect-ratio: 21/9;
        min-height: 500px;
    }
}

@media (max-width: 768px) {
    .property-card--overlay .property-card-image,
    .property-card--hover .property-card-image {
        aspect-ratio: 16/9;
        min-height: 380px;
    }
}

/* Images: Always same dimensions, centered, cover entire area */
.property-card--overlay .property-card-image img,
.property-card--hover .property-card-image img,
.property-card--overlay .card-image,
.property-card--hover .card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    display: block;
}

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

/* ==========================================================================
   Carousel Styles - Scrollable, Working Properly
   ========================================================================== */

.property-card--overlay .property-carousel,
.property-card--hover .property-carousel {
    position: relative;
    width: 100%;
    height: 100%;
}

.property-card--overlay .carousel-inner,
.property-card--hover .carousel-inner {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.property-card--overlay .carousel-slide,
.property-card--hover .carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    z-index: 1;
}

.property-card--overlay .carousel-slide.active,
.property-card--hover .carousel-slide.active {
    opacity: 1;
    z-index: 2;
}

.property-card--overlay .carousel-slide img,
.property-card--hover .carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* Carousel Navigation Buttons */
.property-card--overlay .carousel-nav,
.property-card--hover .carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 15; /* Higher than info overlay to ensure clickability */
    opacity: 0;
    transition: opacity 0.3s ease, background 0.3s ease, transform 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    pointer-events: auto; /* Ensure buttons are always clickable */
}

.property-card--overlay:hover .carousel-nav,
.property-card--hover:hover .carousel-nav {
    opacity: 1;
}

.property-card--overlay .carousel-nav:hover,
.property-card--hover .carousel-nav:hover {
    background: rgba(255, 255, 255, 1);
    transform: translateY(-50%) scale(1.1);
}

.property-card--overlay .carousel-prev,
.property-card--hover .carousel-prev {
    left: 1rem;
}

.property-card--overlay .carousel-next,
.property-card--hover .carousel-next {
    right: 1rem;
}

.property-card--overlay .carousel-nav i,
.property-card--hover .carousel-nav i {
    font-size: 0.9rem;
    color: var(--primary-color, #0c2340);
}

/* Carousel Indicators - Centered */
.property-card--overlay .carousel-indicators,
.property-card--hover .carousel-indicators {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.5rem;
    z-index: 15; /* Higher than info overlay to ensure clickability */
    margin: 0;
    padding: 0;
    list-style: none;
    justify-content: center;
    align-items: center;
    width: auto;
    pointer-events: auto; /* Ensure indicators are always clickable */
}

.property-card--overlay .carousel-indicator,
.property-card--hover .carousel-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
    margin: 0;
    flex-shrink: 0;
}

.property-card--overlay .carousel-indicator:hover,
.property-card--hover .carousel-indicator:hover {
    background: rgba(255, 255, 255, 0.8);
}

.property-card--overlay .carousel-indicator.active,
.property-card--hover .carousel-indicator.active {
    background: rgba(255, 255, 255, 1);
    width: 24px;
    border-radius: 4px;
}

/* Mobile: Always show navigation */
@media (max-width: 991px) {
    .property-card--overlay .carousel-nav,
    .property-card--hover .carousel-nav {
        opacity: 1;
        background: rgba(255, 255, 255, 0.85);
    }
}

/* ==========================================================================
   Badges and Favorite Button (Always Visible)
   ========================================================================== */

.property-card--overlay .property-card-badges,
.property-card--hover .property-card-badges {
    position: absolute;
    top: 1rem;
    left: 1rem;
    z-index: 5;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.property-card--overlay .property-badge,
.property-card--hover .property-badge {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 0.4rem 0.75rem;
    border-radius: 8px;
    font-size: 0.75rem;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--primary-color, #0c2340);
}

.property-card--overlay .property-badge.featured,
.property-card--hover .property-badge.featured {
    background: linear-gradient(135deg, var(--accent-color, #d4af37), #f4d03f);
    color: white;
}

.property-card--overlay .property-badge i,
.property-card--hover .property-badge i {
    font-size: 0.7rem;
}

/* Favorite Button */
.property-card--overlay .favorite-btn,
.property-card--hover .favorite-btn {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    z-index: 5;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.property-card--overlay .favorite-btn:hover,
.property-card--hover .favorite-btn:hover {
    transform: scale(1.1);
    background: rgba(255, 255, 255, 1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.property-card--overlay .favorite-btn i,
.property-card--hover .favorite-btn i {
    font-size: 1.1rem;
    color: var(--accent-color, #d4af37);
    transition: all 0.2s ease;
}

.property-card--overlay .favorite-btn.favorited i,
.property-card--hover .favorite-btn.favorited i {
    color: #ef4444;
}

/* ==========================================================================
   Information Overlay - Compact, Shows on Hover (Desktop) / Click (Mobile)
   ========================================================================== */

/* CRITICAL: Maximum specificity to override ALL other styles - Must match featured properties exactly */
.property-card.property-card--overlay .property-card-info-overlay,
.property-card.property-card--hover .property-card-info-overlay,
div.property-card.property-card--hover .property-card-info-overlay,
div.property-card.property-card--overlay .property-card-info-overlay,
.property-list-section .property-card.property-card--hover .property-card-info-overlay,
.property-list-section .property-card.property-card--overlay .property-card-info-overlay,
.property-cards-grid .property-card.property-card--hover .property-card-info-overlay,
.property-cards-grid .property-card.property-card--overlay .property-card-info-overlay {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 1.25rem 1.5rem 1.5rem !important; /* Compact padding - matching featured properties style */
    /* Liquid Glass Background - Apple-style (matching featured properties) */
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.92) 0%,
        rgba(0, 0, 0, 0.82) 25%,
        rgba(0, 0, 0, 0.65) 55%,
        rgba(0, 0, 0, 0.35) 80%,
        rgba(0, 0, 0, 0) 100%
    ) !important;
    /* Enhanced glassmorphism - matching featured properties */
    backdrop-filter: blur(30px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(30px) saturate(200%) !important;
    z-index: 3 !important;
    opacity: 0 !important;
    transform: translateY(20px) !important;
    transition: opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.45s cubic-bezier(0.4, 0, 0.2, 1) !important;
    pointer-events: none !important;
    max-height: 40% !important; /* Compact - max 40% of card (matching featured properties) */
    overflow: hidden !important;
    display: flex !important; /* Ensure flex display */
    flex-direction: column !important;
    gap: 0.5rem !important; /* Tight spacing (matching featured properties) */
    justify-content: flex-end !important; /* Align content to bottom */
    visibility: hidden !important; /* Hidden by default, shown on click */
    /* Border for definition - matching featured properties */
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    /* Shadow for depth - matching featured properties */
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.3) !important;
    /* Reset any conflicting styles from property-listing.css */
    background-color: transparent !important;
    color: inherit !important;
}

/* When overlay is visible (click-based), ensure all content is visible */
.property-card--overlay.info-visible .property-card-info-overlay,
.property-card--hover.info-visible .property-card-info-overlay,
div.property-card.property-card--hover.info-visible .property-card-info-overlay,
div.property-card.property-card--overlay.info-visible .property-card-info-overlay {
    visibility: visible !important;
}

/* Ensure all overlay content is visible when overlay is shown (click-based only) */
/* CRITICAL: Make sure title and all content is visible when overlay is shown */
.property-card--overlay.info-visible .property-card-info-overlay,
.property-card--hover.info-visible .property-card-info-overlay {
    visibility: visible !important;
    opacity: 1 !important;
}

.property-card--overlay.info-visible .property-card-info-overlay .property-title,
.property-card--hover.info-visible .property-card-info-overlay .property-title,
.property-card--overlay.info-visible .property-card-info-overlay .property-location,
.property-card--hover.info-visible .property-card-info-overlay .property-location,
.property-card--overlay.info-visible .property-card-info-overlay .property-features,
.property-card--hover.info-visible .property-card-info-overlay .property-features,
.property-card--overlay.info-visible .property-card-info-overlay .price-display,
.property-card--hover.info-visible .property-card-info-overlay .price-display {
    visibility: visible !important;
    opacity: 1 !important;
}

/* Ensure title is always visible when overlay is visible */
.property-card--overlay.info-visible .property-card-info-overlay h3.property-title,
.property-card--hover.info-visible .property-card-info-overlay h3.property-title,
.property-card--overlay.info-visible .property-card-info-overlay .property-title,
.property-card--hover.info-visible .property-card-info-overlay .property-title {
    display: -webkit-box !important; /* Keep line clamp functionality */
    visibility: visible !important;
    opacity: 1 !important;
    color: white !important;
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.6) !important;
    z-index: 10 !important;
}

/* Click-based display ONLY (works for both mobile and desktop - no hover) */
/* Matching featured properties liquid glass style exactly */
/* CRITICAL: Maximum specificity to override ALL other styles */
.property-card.property-card--overlay.info-visible .property-card-info-overlay,
.property-card.property-card--hover.info-visible .property-card-info-overlay,
div.property-card.property-card--hover.info-visible .property-card-info-overlay,
div.property-card.property-card--overlay.info-visible .property-card-info-overlay,
.property-list-section .property-card.property-card--hover.info-visible .property-card-info-overlay,
.property-list-section .property-card.property-card--overlay.info-visible .property-card-info-overlay,
.property-cards-grid .property-card.property-card--hover.info-visible .property-card-info-overlay,
.property-cards-grid .property-card.property-card--overlay.info-visible .property-card-info-overlay {
    opacity: 1 !important;
    transform: translateY(0) !important;
    pointer-events: auto !important;
    visibility: visible !important;
    /* Liquid Glass Background - Apple-style (matching featured properties exactly) */
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.92) 0%,
        rgba(0, 0, 0, 0.82) 25%,
        rgba(0, 0, 0, 0.65) 55%,
        rgba(0, 0, 0, 0.35) 80%,
        rgba(0, 0, 0, 0) 100%
    ) !important;
    /* Enhanced glassmorphism - matching featured properties exactly */
    backdrop-filter: blur(30px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(30px) saturate(200%) !important;
    /* Reset any conflicting styles from property-listing.css */
    background-color: transparent !important;
}

/* Prevent info overlay from showing during carousel interaction */
.property-card--hover[data-carousel-interacting="true"] .property-card-info-overlay,
.property-carousel[data-carousel-interacting="true"] ~ .property-card-info-overlay {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

/* Prevent click effects during carousel interaction */
.property-card--hover[data-carousel-interacting="true"].info-visible .property-card-info-overlay {
    opacity: 0;
    visibility: hidden;
}

/* Title - Compact, Clickable - EXACT MATCH with featured properties (.glass-overlay-title) */
.property-card--overlay .property-card-info-overlay .property-title,
.property-card--hover .property-card-info-overlay .property-title {
    color: white !important;
    font-size: 1.35rem !important; /* EXACT MATCH: glass-overlay-title */
    font-weight: 700 !important;
    margin: 0 !important; /* EXACT MATCH: glass-overlay-title */
    line-height: 1.25 !important; /* EXACT MATCH: glass-overlay-title */
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.6) !important; /* EXACT MATCH: glass-overlay-title */
    letter-spacing: -0.02em !important; /* EXACT MATCH: glass-overlay-title */
    cursor: pointer;
    transition: opacity 0.2s ease;
    opacity: 1 !important;
    visibility: visible !important;
    /* Use -webkit-box for line clamping, but ensure visibility */
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    position: relative;
    z-index: 10 !important;
}

.property-card--hover .property-card-info-overlay .property-title:hover {
    opacity: 0.9 !important;
}

/* Remove link styling from title when inside overlay */
.property-card--overlay .property-card-info-overlay .property-title a,
.property-card--hover .property-card-info-overlay .property-title a {
    color: white !important;
    text-decoration: none;
}

/* Location - Compact - EXACT MATCH with featured properties (.glass-overlay-location) */
.property-card--overlay .property-card-info-overlay .property-location,
.property-card--hover .property-card-info-overlay .property-location {
    display: flex !important;
    align-items: center !important;
    gap: 0.35rem !important; /* EXACT MATCH: glass-overlay-location */
    color: rgba(255, 255, 255, 0.9) !important; /* EXACT MATCH: glass-overlay-location */
    font-size: 0.8rem !important; /* EXACT MATCH: glass-overlay-location */
    margin: 0 !important; /* EXACT MATCH: glass-overlay-location */
    font-weight: 500 !important; /* EXACT MATCH: glass-overlay-location */
    text-shadow: 0 1px 5px rgba(0, 0, 0, 0.5) !important; /* EXACT MATCH: glass-overlay-location */
    opacity: 1 !important;
    visibility: visible !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    position: relative;
    z-index: 1;
}

.property-card--overlay .property-card-info-overlay .property-location i,
.property-card--hover .property-card-info-overlay .property-location i {
    color: var(--color-accent, #d4af37) !important; /* EXACT MATCH: glass-overlay-location i */
    font-size: 0.75rem !important; /* EXACT MATCH: glass-overlay-location i */
}

/* Main Features - Compact Row - EXACT MATCH with featured properties (.glass-overlay-features) */
.property-card--overlay .property-card-info-overlay .property-features,
.property-card--hover .property-card-info-overlay .property-features {
    display: flex !important;
    gap: 0.5rem !important; /* EXACT MATCH: glass-overlay-features */
    flex-wrap: wrap !important; /* EXACT MATCH: glass-overlay-features */
    margin: 0 !important; /* EXACT MATCH: glass-overlay-features */
    align-items: center !important; /* EXACT MATCH: glass-overlay-features */
    opacity: 1 !important;
    visibility: visible !important;
}

.property-card--overlay .property-card-info-overlay .property-feature,
.property-card--hover .property-card-info-overlay .property-feature {
    display: flex !important;
    align-items: center !important;
    gap: 0.35rem !important; /* EXACT MATCH: glass-overlay-feature */
    color: rgba(255, 255, 255, 0.95) !important; /* EXACT MATCH: glass-overlay-feature */
    font-size: 0.8rem !important; /* EXACT MATCH: glass-overlay-feature */
    font-weight: 600 !important; /* EXACT MATCH: glass-overlay-feature */
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5) !important; /* EXACT MATCH: glass-overlay-feature */
    opacity: 1 !important;
    visibility: visible !important;
}

.property-card--overlay .property-card-info-overlay .property-feature i,
.property-card--hover .property-card-info-overlay .property-feature i {
    color: var(--color-accent, #d4af37) !important; /* EXACT MATCH: glass-overlay-feature i */
    font-size: 0.85rem !important; /* EXACT MATCH: glass-overlay-feature i */
}

/* Price Display - Compact and Inline - EXACT MATCH with featured properties (.glass-overlay-price) */
.property-card--overlay .property-card-info-overlay .price-display,
.property-card--hover .property-card-info-overlay .price-display {
    display: flex !important;
    align-items: baseline !important; /* EXACT MATCH: glass-overlay-price */
    gap: 0.5rem !important; /* EXACT MATCH: glass-overlay-price */
    flex-wrap: wrap !important; /* EXACT MATCH: glass-overlay-price */
    margin: 0 !important; /* EXACT MATCH: glass-overlay-price */
    margin-top: 0.25rem !important; /* EXACT MATCH: glass-overlay-price */
    width: 100% !important; /* EXACT MATCH: glass-overlay-price */
    opacity: 1 !important;
    visibility: visible !important;
}

/* Single Price Item - EXACT MATCH with featured properties structure */
.property-card--hover .price-display .price-item,
.property-card--overlay .price-display .price-item {
    display: inline-flex !important;
    align-items: baseline !important; /* EXACT MATCH: glass-overlay-price (baseline alignment) */
    gap: 0.5rem !important; /* EXACT MATCH: glass-overlay-price gap */
    flex-wrap: nowrap;
    opacity: 1 !important;
    visibility: visible !important;
    margin: 0 !important; /* EXACT MATCH: no margin */
}

/* Single Price - EXACT MATCH with featured properties (.price-amount-large and .price-type-small) */
.property-card--overlay .property-card-info-overlay .price-display .price-amount,
.property-card--hover .property-card-info-overlay .price-display .price-amount,
.property-card--overlay .property-card-info-overlay .price-display .price-item .price-amount,
.property-card--hover .property-card-info-overlay .price-display .price-item .price-amount {
    font-size: 1.6rem !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    font-weight: 800 !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    color: white !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7) !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    letter-spacing: -0.03em !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    line-height: 1 !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    white-space: nowrap !important; /* EXACT MATCH: glass-overlay-price .price-amount-large */
    opacity: 1 !important;
    visibility: visible !important;
}

.property-card--overlay .property-card-info-overlay .price-display .price-type,
.property-card--hover .property-card-info-overlay .price-display .price-type,
.property-card--overlay .property-card-info-overlay .price-display .price-item .price-type,
.property-card--hover .property-card-info-overlay .price-display .price-item .price-type {
    font-size: 0.75rem !important; /* EXACT MATCH: glass-overlay-price .price-type-small */
    color: rgba(255, 255, 255, 0.85) !important; /* EXACT MATCH: glass-overlay-price .price-type-small */
    font-weight: 500 !important; /* EXACT MATCH: glass-overlay-price .price-type-small */
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5) !important; /* EXACT MATCH: glass-overlay-price .price-type-small */
    white-space: nowrap !important; /* EXACT MATCH: glass-overlay-price .price-type-small */
    opacity: 1 !important;
    visibility: visible !important;
}

/* Multiple Offers - EXACT MATCH with featured properties (.multiple-offers-glass) */
.property-card--hover .multiple-offers-compact,
.property-card--overlay .multiple-offers-compact {
    display: flex !important; /* EXACT MATCH: multiple-offers-glass */
    flex-wrap: wrap !important; /* EXACT MATCH: multiple-offers-glass */
    gap: 0.35rem !important; /* EXACT MATCH: multiple-offers-glass */
    align-items: center !important; /* EXACT MATCH: multiple-offers-glass */
    width: 100% !important; /* EXACT MATCH: multiple-offers-glass */
}

/* Small Price Items - EXACT MATCH with featured properties (.glass-price-item) */
.property-card--hover .price-item-small,
.property-card--overlay .price-item-small {
    display: inline-flex !important; /* EXACT MATCH: glass-price-item */
    align-items: center !important; /* EXACT MATCH: glass-price-item */
    gap: 0.3rem !important; /* EXACT MATCH: glass-price-item */
    padding: 0.25rem 0.5rem !important; /* EXACT MATCH: glass-price-item */
    background: rgba(255, 255, 255, 0.15) !important; /* EXACT MATCH: glass-price-item */
    backdrop-filter: blur(10px) !important; /* EXACT MATCH: glass-price-item */
    -webkit-backdrop-filter: blur(10px) !important; /* EXACT MATCH: glass-price-item */
    border-radius: 6px !important; /* EXACT MATCH: glass-price-item */
    border: 1px solid rgba(255, 255, 255, 0.2) !important; /* EXACT MATCH: glass-price-item */
    flex-shrink: 0 !important; /* EXACT MATCH: glass-price-item */
}

.property-card--hover .price-item-small .price-amount,
.property-card--overlay .price-item-small .price-amount {
    font-size: 1rem !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
    font-weight: 700 !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
    color: white !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5) !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
    letter-spacing: -0.01em !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
    white-space: nowrap !important; /* EXACT MATCH: glass-price-item .price-amount-glass */
}

/* Price Type Badges - EXACT MATCH with featured properties (.glass-badge) */
.property-card--hover .price-type-badge,
.property-card--overlay .price-type-badge {
    font-size: 0.6rem !important; /* EXACT MATCH: glass-badge */
    font-weight: 700 !important; /* EXACT MATCH: glass-badge */
    padding: 0.1rem 0.35rem !important; /* EXACT MATCH: glass-badge */
    border-radius: 4px !important; /* EXACT MATCH: glass-badge */
    text-transform: uppercase !important; /* EXACT MATCH: glass-badge */
    letter-spacing: 0.02em !important; /* EXACT MATCH: glass-badge */
    white-space: nowrap !important; /* EXACT MATCH: glass-badge */
    line-height: 1.2 !important; /* EXACT MATCH: glass-badge */
}

/* Price Badge Colors - EXACT MATCH with featured properties (.glass-badge) */
.property-card--hover .price-type-badge.sale-badge,
.property-card--overlay .price-type-badge.sale-badge {
    background: rgba(239, 68, 68, 0.3) !important; /* EXACT MATCH: glass-badge.sale */
    color: rgba(255, 255, 255, 0.95) !important; /* EXACT MATCH: glass-badge.sale */
    border: 1px solid rgba(239, 68, 68, 0.5) !important; /* EXACT MATCH: glass-badge.sale */
}

.property-card--hover .price-type-badge.rent-badge,
.property-card--overlay .price-type-badge.rent-badge {
    background: rgba(59, 130, 246, 0.3) !important; /* EXACT MATCH: glass-badge.rent */
    color: rgba(255, 255, 255, 0.95) !important; /* EXACT MATCH: glass-badge.rent */
    border: 1px solid rgba(59, 130, 246, 0.5) !important; /* EXACT MATCH: glass-badge.rent */
}

.property-card--hover .price-type-badge.short-badge,
.property-card--overlay .price-type-badge.short-badge {
    background: rgba(16, 185, 129, 0.3) !important; /* EXACT MATCH: glass-badge.short */
    color: rgba(255, 255, 255, 0.95) !important; /* EXACT MATCH: glass-badge.short */
    border: 1px solid rgba(16, 185, 129, 0.5) !important; /* EXACT MATCH: glass-badge.short */
}

/* ==========================================================================
   Content Area (Hidden - info only on hover/click)
   ========================================================================== */

.property-card--overlay .property-card-content,
.property-card--hover .property-card-content {
    display: none;
}

/* ==========================================================================
   Responsive: More Compact on Larger Screens
   ========================================================================== */

/* Larger screens - more compact overlay */
@media (min-width: 1400px) {
    .property-card--overlay .property-card-info-overlay,
    .property-card--hover .property-card-info-overlay {
        padding: 1rem 0.875rem 0.875rem; /* More compact on large screens */
        max-height: 38%; /* Even more compact on large screens */
        gap: 0.35rem; /* Tighter spacing */
    }
    
    .property-card--overlay .property-card-info-overlay .property-title,
    .property-card--hover .property-card-info-overlay .property-title {
        font-size: 1.2rem !important; /* More compact on large screens */
    }
    
    /* Ensure title visibility on large screens */
    .property-card--overlay.info-visible .property-card-info-overlay .property-title,
    .property-card--hover.info-visible .property-card-info-overlay .property-title {
        font-size: 1.2rem !important;
        display: -webkit-box !important;
        visibility: visible !important;
        opacity: 1 !important;
        color: white !important;
    }
    
    .property-card--overlay .property-card-info-overlay .property-location,
    .property-card--hover .property-card-info-overlay .property-location {
        font-size: 0.75rem; /* More compact */
    }
    
    .property-card--overlay .property-card-info-overlay .property-feature,
    .property-card--hover .property-card-info-overlay .property-feature {
        font-size: 0.75rem; /* More compact */
    }
    
    .property-card--overlay .property-card-info-overlay .price-display .price-amount,
    .property-card--hover .property-card-info-overlay .price-display .price-amount {
        font-size: 1.2rem !important; /* More compact on large screens */
    }
    
    .property-card--overlay .property-card-info-overlay .price-display .price-type,
    .property-card--hover .property-card-info-overlay .price-display .price-type {
        font-size: 0.65rem !important; /* More compact on large screens */
    }
}

/* ==========================================================================
   Mobile: Click/Tap to Show Info
   ========================================================================== */

@media (max-width: 991px) {
    /* Hide overlay by default on mobile */
    .property-card--overlay .property-card-info-overlay,
    .property-card--hover .property-card-info-overlay {
        opacity: 0 !important;
        transform: translateY(15px) !important;
        pointer-events: none !important;
        visibility: hidden;
    }
    
    /* Show on touch - handled by JS class 'info-visible' */
    .property-card--overlay.info-visible .property-card-info-overlay,
    .property-card--hover.info-visible .property-card-info-overlay {
        opacity: 1 !important;
        transform: translateY(0) !important;
        pointer-events: auto !important;
        visibility: visible !important;
    }
    
    /* More compact on mobile */
    .property-card--overlay .property-card-info-overlay,
    .property-card--hover .property-card-info-overlay {
        padding: 1rem 0.875rem 0.875rem; /* Even more compact on mobile */
        max-height: 45%; /* More compact - reduced from 50% */
        gap: 0.35rem; /* Tighter spacing on mobile */
    }
    
    .property-card--overlay .property-card-info-overlay .property-title,
    .property-card--hover .property-card-info-overlay .property-title {
        font-size: 1.15rem !important; /* More compact on mobile */
        margin-bottom: 0.15rem;
        line-height: 1.2;
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8), 0 1px 3px rgba(0, 0, 0, 0.9) !important; /* Stronger shadow for visibility */
    }
    
    /* Ensure title visibility on mobile */
    .property-card--overlay.info-visible .property-card-info-overlay .property-title,
    .property-card--hover.info-visible .property-card-info-overlay .property-title {
        font-size: 1.15rem !important;
        display: -webkit-box !important;
        visibility: visible !important;
        opacity: 1 !important;
        color: white !important;
    }
    
    .property-card--overlay .property-card-info-overlay .property-location,
    .property-card--hover .property-card-info-overlay .property-location {
        font-size: 0.75rem; /* More compact on mobile */
        margin-bottom: 0.3rem;
        text-shadow: 0 1px 4px rgba(0, 0, 0, 0.7), 0 1px 2px rgba(0, 0, 0, 0.8); /* Stronger shadow for visibility */
    }
    
    .property-card--overlay .property-card-info-overlay .property-features,
    .property-card--hover .property-card-info-overlay .property-features {
        gap: 0.45rem; /* Tighter gap on mobile */
        margin-bottom: 0.35rem;
    }
    
    .property-card--overlay .property-card-info-overlay .property-feature,
    .property-card--hover .property-card-info-overlay .property-feature {
        font-size: 0.75rem; /* More compact on mobile */
        gap: 0.25rem;
    }
    
    .property-card--overlay .property-card-info-overlay .price-display .price-amount,
    .property-card--hover .property-card-info-overlay .price-display .price-amount {
        font-size: 1.2rem; /* More compact on mobile */
    }
    
    .property-card--overlay .property-card-info-overlay .price-display .price-type,
    .property-card--hover .property-card-info-overlay .price-display .price-type {
        font-size: 0.7rem; /* More compact on mobile */
    }
}

/* ==========================================================================
   Dark Mode Support
   ========================================================================== */

[data-theme="dark"] .property-card--overlay,
[data-theme="dark"] .property-card--hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .property-card--overlay .property-badge,
[data-theme="dark"] .property-card--hover .property-badge,
[data-theme="dark"] .property-card--overlay .favorite-btn,
[data-theme="dark"] .property-card--hover .favorite-btn {
    background: rgba(30, 30, 30, 0.95);
}
