/**
 * Filtered Properties Communities V2 - CSS
 * Version: 3.13 - March 2026
 * 
 * v3.13 UPDATES:
 * - Card highlight border when selected from map (brown outline)
 * - Fullscreen preview badge: pill style with colored background
 * - Fullscreen preview button: rounded (border-radius: 50px)
 * - Future phases badge: #6A8375 background, white text
 * - Specs row: View Community LEFT, Units RIGHT
 * 
 * v3.12 UPDATES:
 * - Badges row: Single line, fixed height (24px)
 * - Estimated completion: Raw value only
 * - View Community button (badge style)
 * - Cards: Equal height
 * 
 * UPDATED v3.4:
 * - Desktop map: 1200px x 250px (Figma spec)
 * - Mobile map: 100% x 384px (Figma spec, fluid width)
 * - Key modal: fully contained inside map, responsive
 * - "Contact for price" styling (12px, sentence case)
 * - Map loading placeholder
 * - Performance: GPU-accelerated transitions, will-change hints
 * - Same layout as before (no feature/logic changes)
 */

/* ============================================================
   KEYFRAME ANIMATIONS
   ============================================================ */

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

/* ============================================================
   SECTION WRAPPER
   ============================================================ */

section.filtered-communities-v2-section {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #FFFFFF !important;
    font-family: 'Afacad Flux', 'Roboto', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    box-sizing: border-box !important;
}

section.filtered-communities-v2-section *,
section.filtered-communities-v2-section *::before,
section.filtered-communities-v2-section *::after {
    box-sizing: border-box !important;
}

/* ============================================================
   HEADER
   ============================================================ */

section.filtered-communities-v2-section .fpc-header-wrapper {
    padding: 80px 50px 30px 50px !important;
    max-width: 1440px !important;
    margin: 0 auto !important;
    width: 100% !important;
}

@media (min-width: 1200px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 80px 120px 30px 120px !important;
    }
}

section.filtered-communities-v2-section .fpc-header {
    width: auto !important;
    max-width: 600px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

section.filtered-communities-v2-section .fpc-title {
    color: #2A2A2A !important;
    font-size: 36px !important;
    font-family: 'Sofia Pro', 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
    margin: 0 !important;
}

section.filtered-communities-v2-section .fpc-subtitle {
    color: #666666 !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 300 !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

/* ============================================================
   HEADER DIVIDER
   ============================================================ */

section.filtered-communities-v2-section .fpc-header-divider {
    max-width: 1440px !important;
    width: 100% !important;
    margin: 0 auto 30px auto !important;
    padding: 0 50px !important;
    box-sizing: border-box !important;
}

section.filtered-communities-v2-section .fpc-header-divider::after {
    content: '' !important;
    display: block !important;
    width: 100% !important;
    height: 1px !important;
    background: #CCC8C0 !important;
}

@media (min-width: 1200px) {
    section.filtered-communities-v2-section .fpc-header-divider {
        padding: 0 120px !important;
    }
}

/* ============================================================
   MAP - v3.4: Desktop 1200x250, Mobile 100%x384
   ============================================================ */

section.filtered-communities-v2-section .fpc-map-container {
    width: 100% !important;
    max-width: 1440px !important;
    margin: 0 auto !important;
    padding: 0 50px !important;
}

@media (min-width: 1200px) {
    section.filtered-communities-v2-section .fpc-map-container {
        padding: 0 120px !important;
    }
}

section.filtered-communities-v2-section .fpc-map-inner {
    width: 100% !important;
    max-width: 1200px !important;
    height: 250px !important;
    position: relative !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    background: #F5F3F0 !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
    margin: 0 auto !important;
}

/* v3.4: Leaflet container - match parent, GPU-accelerated */
section.filtered-communities-v2-section .fpc-leaflet-map {
    width: 100% !important;
    height: 100% !important;
    will-change: transform !important;
    contain: layout style paint !important;
}

/* Leaflet overrides for instant rendering */
section.filtered-communities-v2-section .fpc-leaflet-map.leaflet-container {
    width: 100% !important;
    height: 100% !important;
    background: #F5F3F0 !important;
}

section.filtered-communities-v2-section .fpc-leaflet-map.leaflet-container .leaflet-tile-pane {
    will-change: transform !important;
}

section.filtered-communities-v2-section .fpc-leaflet-map.leaflet-container .leaflet-tile {
    will-change: transform, opacity !important;
}

/* v3.4: Map Loading Placeholder */
section.filtered-communities-v2-section .fpc-leaflet-map.fpc-map-loading {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #f5f3f0 !important;
    color: #766C61 !important;
    font-size: 14px !important;
}

section.filtered-communities-v2-section .fpc-leaflet-map.fpc-map-loading::after {
    content: 'Loading map...' !important;
}

/* Map Toggle */
section.filtered-communities-v2-section .fpc-map-toggle {
    position: absolute !important;
    top: 14px !important;
    left: 9px !important;
    display: flex !important;
    z-index: 1000 !important;
}

section.filtered-communities-v2-section .fpc-map-toggle-btn {
    height: 40px !important;
    background: white !important;
    border: none !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    cursor: pointer !important;
    box-shadow: 0px 1px 4px -1px rgba(0, 0, 0, 0.30) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    color: #565656 !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-map-toggle-btn:first-child {
    width: 64px !important;
    padding: 0 17px !important;
    border-radius: 2px 30px 30px 2px !important;
}

section.filtered-communities-v2-section .fpc-map-toggle-btn:last-child {
    width: 96px !important;
    padding: 0 17px !important;
    border-radius: 30px 2px 2px 30px !important;
}

section.filtered-communities-v2-section .fpc-map-toggle-btn.active {
    font-weight: 500 !important;
    color: black !important;
}

/* Fullscreen button */
section.filtered-communities-v2-section .fpc-map-fullscreen {
    position: absolute !important;
    top: 14px !important;
    right: 10px !important;
    width: 36px !important;
    height: 40px !important;
    background: white !important;
    border: none !important;
    border-radius: 2px !important;
    font-size: 16px !important;
    cursor: pointer !important;
    box-shadow: 0px 1px 4px -1px rgba(0, 0, 0, 0.30) !important;
    z-index: 1000 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #78716C !important;
}

/* Zoom controls */
section.filtered-communities-v2-section .fpc-map-zoom-controls {
    position: absolute !important;
    bottom: 66px !important;
    right: 10px !important;
    display: flex !important;
    flex-direction: column !important;
    background: white !important;
    border-radius: 20px !important;
    box-shadow: 0px 1px 4px -1px rgba(0, 0, 0, 0.30) !important;
    z-index: 1000 !important;
    overflow: hidden !important;
}

section.filtered-communities-v2-section .fpc-zoom-btn {
    width: 36px !important;
    height: 40px !important;
    border: none !important;
    background: white !important;
    font-size: 20px !important;
    cursor: pointer !important;
    color: #78716C !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

section.filtered-communities-v2-section .fpc-zoom-btn:hover {
    background: #f5f5f5 !important;
}

section.filtered-communities-v2-section .fpc-zoom-separator {
    height: 1px !important;
    background: #e0e0e0 !important;
}

/* Map Markers */
section.filtered-communities-v2-section .fpc-city-cluster-marker {
    background: transparent !important;
}

section.filtered-communities-v2-section .fpc-cluster-dot {
    width: 40px !important;
    height: 40px !important;
    background: #6A8375 !important;
    border: 3px solid white !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.3) !important;
    cursor: pointer !important;
}

section.filtered-communities-v2-section .fpc-cluster-dot:hover {
    transform: scale(1.1) !important;
}

section.filtered-communities-v2-section .fpc-property-marker {
    background: transparent !important;
}

section.filtered-communities-v2-section .fpc-marker-dot {
    width: 20px !important;
    height: 20px !important;
    background: #78716C !important;
    border: 2px solid white !important;
    border-radius: 50% !important;
    box-shadow: 3px 5px 6px 2px rgba(0, 0, 0, 0.40) !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

section.filtered-communities-v2-section .fpc-marker-dot:hover {
    transform: scale(1.2) !important;
}

/* Fullscreen Mode */
section.filtered-communities-v2-section .fpc-map-inner.fullscreen {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    max-width: 100vw !important;
    z-index: 999999 !important;
    border-radius: 0 !important;
}

/* ============================================================
   FILTERS + SEARCH ROW
   ============================================================ */

section.filtered-communities-v2-section .fpc-filters-search-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 20px !important;
    max-width: 1440px !important;
    margin: 30px auto 30px auto !important;
    padding: 0 50px !important;
}

@media (min-width: 1200px) {
    section.filtered-communities-v2-section .fpc-filters-search-row {
        padding: 0 120px !important;
    }
}

section.filtered-communities-v2-section .fpc-filters-left {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    flex: 1 !important;
    min-width: 0 !important;
}

section.filtered-communities-v2-section .fpc-search-right {
    flex-shrink: 0 !important;
}

/* Search Bar */
section.filtered-communities-v2-section .fpc-search-wrapper {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    width: 320px !important;
    padding: 6px 6px 6px 20px !important;
    background: #FFFFFF !important;
    border-radius: 50px !important;
    border: 1px solid #CCC8C0 !important;
    flex-shrink: 0 !important;
}

section.filtered-communities-v2-section .fpc-search-input {
    flex: 1 !important;
    border: none !important;
    outline: none !important;
    background: transparent !important;
    font-size: 16px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 300 !important;
    color: #2A2A2A !important;
    min-width: 0 !important;
}

section.filtered-communities-v2-section .fpc-search-input::placeholder {
    color: #A3A3A3 !important;
}

section.filtered-communities-v2-section .fpc-search-btn {
    position: relative !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    padding: 0 !important;
    background: #5A4F42 !important;
    border: none !important;
    border-radius: 32px !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    transition: background 0.3s ease !important;
}

section.filtered-communities-v2-section .fpc-search-btn:hover {
    background: #928572 !important;
}

section.filtered-communities-v2-section .fpc-search-btn svg {
    width: 14px !important;
    height: 14px !important;
    flex-shrink: 0 !important;
}

/* ============================================================
   FILTER PILLS
   ============================================================ */

section.filtered-communities-v2-section .fpc-filter-wrapper {
    position: relative !important;
    display: inline-block !important;
}

section.filtered-communities-v2-section button.fpc-filter-pill,
section.filtered-communities-v2-section .fpc-filter-pill {
    padding: 7px 12px 7px 16px !important;
    background: white !important;
    border-radius: 50px !important;
    border: none !important;
    outline: 1px #2A2A2A solid !important;
    outline-offset: -1px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    white-space: nowrap !important;
    min-height: 32px !important;
    line-height: 1 !important;
}

section.filtered-communities-v2-section .fpc-filter-pill:hover {
    background: #5A4F42 !important;
    outline-color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-filter-pill:hover .fpc-pill-label {
    color: #FFFFFF !important;
}

section.filtered-communities-v2-section .fpc-filter-pill:hover .fpc-pill-arrow::after {
    border-top-color: #FFFFFF !important;
}

section.filtered-communities-v2-section .fpc-filter-pill.active {
    background: #5A4F42 !important;
    outline-color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-filter-pill.active .fpc-pill-label {
    color: #FFFFFF !important;
}

section.filtered-communities-v2-section .fpc-filter-pill.active .fpc-pill-arrow::after {
    border-top-color: #FFFFFF !important;
}

section.filtered-communities-v2-section .fpc-pill-label {
    color: #2A2A2A !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    transition: color 0.3s ease !important;
}

section.filtered-communities-v2-section .fpc-pill-arrow {
    width: 14px !important;
    height: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

section.filtered-communities-v2-section .fpc-pill-arrow::after {
    content: '' !important;
    border-left: 3px solid transparent !important;
    border-right: 3px solid transparent !important;
    border-top: 3px solid #2A2A2A !important;
    transition: border-top-color 0.3s ease !important;
}

/* ============================================================
   DROPDOWNS
   ============================================================ */

section.filtered-communities-v2-section .fpc-dropdown {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: 0 !important;
    background: #FFFFFF !important;
    border-radius: 5px !important;
    border: 1px solid #E8E5DF !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    padding: 15px !important;
    min-width: 165px !important;
    z-index: 99999 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    transition: all 0.2s ease !important;
}

section.filtered-communities-v2-section .fpc-dropdown.show {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

section.filtered-communities-v2-section .fpc-dropdown-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

section.filtered-communities-v2-section .fpc-dropdown-option {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-direction: row-reverse !important;
    gap: 10px !important;
    cursor: pointer !important;
    padding: 5px 0 !important;
}

section.filtered-communities-v2-section .fpc-dropdown-option:hover .fpc-option-text {
    font-weight: 500 !important;
}

section.filtered-communities-v2-section .fpc-check-box {
    width: 12px !important;
    height: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

section.filtered-communities-v2-section .fpc-checkmark {
    width: 10px !important;
    height: 7px !important;
    background: #5A4F42 !important;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%) !important;
    opacity: 0 !important;
    transition: opacity 0.2s ease !important;
}

section.filtered-communities-v2-section .fpc-dropdown-option.selected .fpc-checkmark {
    opacity: 1 !important;
}

section.filtered-communities-v2-section .fpc-option-text {
    color: #5A4F42 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-dropdown-divider {
    width: 100% !important;
    height: 1px !important;
    background: #E8E5DF !important;
    margin: 2px 0 !important;
}

/* Price/Lot Size Dropdown */
section.filtered-communities-v2-section .fpc-dropdown-price,
section.filtered-communities-v2-section .fpc-dropdown-lotsize {
    min-width: 320px !important;
}

section.filtered-communities-v2-section .fpc-price-inputs,
section.filtered-communities-v2-section .fpc-lotsize-inputs {
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
}

section.filtered-communities-v2-section .fpc-input-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
}

section.filtered-communities-v2-section .fpc-input-group label {
    color: #2A2A2A !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-select-wrapper select {
    width: 130px !important;
    padding: 10px !important;
    background: #FFFFFF !important;
    border-radius: 3px !important;
    border: 1px solid #CCC8C0 !important;
    outline: none !important;
    color: #2A2A2A !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    cursor: pointer !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%232A2A2A' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    padding-right: 30px !important;
}

section.filtered-communities-v2-section .fpc-input-separator {
    color: #5A4F42 !important;
    font-size: 16px !important;
    padding-top: 20px !important;
}

/* Beds/Baths Dropdown */
section.filtered-communities-v2-section .fpc-dropdown-bedsbaths {
    min-width: 340px !important;
}

section.filtered-communities-v2-section .fpc-bedsbaths-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
}

section.filtered-communities-v2-section .fpc-bedsbaths-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

section.filtered-communities-v2-section .fpc-bedsbaths-group label {
    color: #5A4F42 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

section.filtered-communities-v2-section .fpc-bedsbaths-grid {
    display: flex !important;
    gap: 5px !important;
}

section.filtered-communities-v2-section .fpc-bb-btn {
    min-width: 55px !important;
    padding: 10px 16px !important;
    background: #FFFFFF !important;
    border-radius: 3px !important;
    border: 1px solid #CCC8C0 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    color: #928A80 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

section.filtered-communities-v2-section .fpc-bb-btn:hover {
    border-color: #5A4F42 !important;
    color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-bb-btn.active {
    background: #5A4F42 !important;
    border-color: #5A4F42 !important;
    color: #FFFFFF !important;
}

/* ============================================================
   PROPERTIES GRID - 3 COLUMNS
   ============================================================ */

section.filtered-communities-v2-section .fpc-properties-wrapper {
    max-width: 1440px !important;
    margin: 0 auto !important;
    padding: 0 50px 80px 50px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

@media (min-width: 1200px) {
    section.filtered-communities-v2-section .fpc-properties-wrapper {
        padding: 0 120px 80px 120px !important;
    }
}

section.filtered-communities-v2-section .fpc-properties-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

section.filtered-communities-v2-section .fpc-no-results {
    grid-column: 1 / -1 !important;
    padding: 60px 20px !important;
    text-align: center !important;
}

section.filtered-communities-v2-section .fpc-no-results p {
    color: #666666 !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

/* ============================================================
   PROPERTY CARD - v3.12: Equal Height + GPU hints
   ============================================================ */

section.filtered-communities-v2-section .fpc-property-card {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    background: transparent !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    max-width: 100% !important;
    overflow: hidden !important;
    will-change: transform !important;
    contain: layout style !important;
    height: 100% !important;
}

section.filtered-communities-v2-section .fpc-property-card:hover {
    transform: translateY(-2px) !important;
}

/* v3.13: Card highlight when selected from map */
section.filtered-communities-v2-section .fpc-property-card.fpc-card-highlighted {
    outline: 3px solid #5A4F42 !important;
    outline-offset: -3px !important;
    box-shadow: 0 4px 20px rgba(90, 79, 66, 0.3) !important;
}

section.filtered-communities-v2-section .fpc-property-card.fpc-card-highlighted .fpc-card-image {
    border-color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-card-link {
    display: flex !important;
    flex-direction: column !important;
    text-decoration: none !important;
    color: inherit !important;
    width: 100% !important;
    height: 100% !important;
}

/* Image */
section.filtered-communities-v2-section .fpc-card-image {
    width: 100% !important;
    aspect-ratio: 310 / 169 !important;
    overflow: hidden !important;
    background: #f5f3f0 !important;
    position: relative !important;
}

section.filtered-communities-v2-section .fpc-card-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.4s ease !important;
}

section.filtered-communities-v2-section .fpc-property-card:hover .fpc-card-image img {
    transform: scale(1.05) !important;
}

/* Placeholder */
section.filtered-communities-v2-section .fpc-card-placeholder {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #F5F3F0 !important;
}

section.filtered-communities-v2-section .fpc-card-placeholder svg {
    width: 48px !important;
    height: 48px !important;
    opacity: 0.4 !important;
}

/* Card Content - v3.12: flex-grow for equal height */
section.filtered-communities-v2-section .fpc-card-content {
    align-self: stretch !important;
    padding: 20px 10px !important;
    background: #FFFFFF !important;
    border-left: 1px solid #CCC8C0 !important;
    border-right: 1px solid #CCC8C0 !important;
    border-bottom: 1px solid #CCC8C0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    gap: 14px !important;
    flex-grow: 1 !important;
}

/* ============================================================
   BADGES - v3.12: Single Line, Fixed Height (24px)
   ============================================================ */

section.filtered-communities-v2-section .fpc-badges-row {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 5px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    overflow: hidden !important;
    flex-wrap: nowrap !important;
    align-self: stretch !important;
}

section.filtered-communities-v2-section .fpc-badge-pill {
    padding: 5px 14px !important;
    border-radius: 50px !important;
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 5px !important;
    white-space: nowrap !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
}

/* Badge Colors */
section.filtered-communities-v2-section .fpc-badge-in-contract { background: #666666 !important; }
section.filtered-communities-v2-section .fpc-badge-under-contract { background: #666666 !important; }
section.filtered-communities-v2-section .fpc-badge-plan-ready-lot { background: #606E76 !important; }
section.filtered-communities-v2-section .fpc-badge-under-construction { background: #928572 !important; }
section.filtered-communities-v2-section .fpc-badge-for-sale { background: #6A8375 !important; }
section.filtered-communities-v2-section .fpc-badge-sold { background: #EEEEEE !important; }
section.filtered-communities-v2-section .fpc-badge-coming-soon { background: transparent !important; border: 1px solid #2A2A2A !important; }
section.filtered-communities-v2-section .fpc-badge-estimated { background: #5A4F42 !important; }
section.filtered-communities-v2-section .fpc-badge-reserved { background: #C47D3F !important; }

/* v3.14: New badges */
section.filtered-communities-v2-section .fpc-badge-near-completion { background: #928572 !important; }
section.filtered-communities-v2-section .fpc-badge-off-market-lot { background: #928572 !important; }
section.filtered-communities-v2-section .fpc-badge-move-in-ready { background: #928572 !important; }

/* v3.13: Future phases badge */
section.filtered-communities-v2-section .fpc-badge-future-phases { 
    background: #6A8375 !important; 
}

section.filtered-communities-v2-section .fpc-badge-future-phases .fpc-badge-text-white {
    color: #FFFFFF !important;
    font-family: "Afacad Flux", 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: normal !important;
}

/* v3.14: Near Completion badge */
section.filtered-communities-v2-section .fpc-badge-near-completion { 
    background: #666666 !important; 
}

section.filtered-communities-v2-section .fpc-badge-near-completion .fpc-badge-text-white {
    color: #FFFFFF !important;
    font-family: "Afacad Flux", 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: normal !important;
}

/* v3.14: Off Market Lot badge */
section.filtered-communities-v2-section .fpc-badge-off-market-lot { 
    background: #666666 !important; 
}

section.filtered-communities-v2-section .fpc-badge-off-market-lot .fpc-badge-text-white {
    color: #FFFFFF !important;
    font-family: "Afacad Flux", 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: normal !important;
}

/* v3.14: Under Contract badge */
section.filtered-communities-v2-section .fpc-badge-under-contract { 
    background: #666666 !important; 
}

section.filtered-communities-v2-section .fpc-badge-under-contract .fpc-badge-text-white {
    color: #FFFFFF !important;
    font-family: "Afacad Flux", 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: normal !important;
}

/* v3.14: Move in Ready badge */
section.filtered-communities-v2-section .fpc-badge-move-in-ready { 
    background: #666666 !important; 
}

section.filtered-communities-v2-section .fpc-badge-move-in-ready .fpc-badge-text-white {
    color: #FFFFFF !important;
    font-family: "Afacad Flux", 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 400 !important;
    line-height: normal !important;
}

/* Badge Text */
section.filtered-communities-v2-section .fpc-badge-text-white { color: #FFFFFF !important; font-size: 12px !important; font-family: 'Afacad Flux', 'Roboto', sans-serif !important; font-weight: 400 !important; }
section.filtered-communities-v2-section .fpc-badge-text-dark { color: #2A2A2A !important; font-size: 12px !important; font-family: 'Afacad Flux', 'Roboto', sans-serif !important; font-weight: 400 !important; }
section.filtered-communities-v2-section .fpc-badge-text-light { color: #FFFFFF !important; font-size: 12px !important; font-family: 'Afacad Flux', 'Roboto', sans-serif !important; font-weight: 400 !important; }
section.filtered-communities-v2-section .fpc-badge-text-bold { color: #FFFFFF !important; font-size: 12px !important; font-family: 'Afacad Flux', 'Roboto', sans-serif !important; font-weight: 500 !important; }

/* ============================================================
   TITLE + PRICE ROW
   ============================================================ */

section.filtered-communities-v2-section .fpc-card-title-price-row {
    align-self: stretch !important;
    display: inline-flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 14px !important;
}

section.filtered-communities-v2-section .fpc-card-title-container {
    min-width: 0 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    gap: 4px !important;
    flex: 1 !important;
}

section.filtered-communities-v2-section .fpc-card-title {
    align-self: stretch !important;
    color: #2A2A2A !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    margin: 0 !important;
}

section.filtered-communities-v2-section .fpc-card-address {
    align-self: stretch !important;
    color: #666666 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    margin: 0 !important;
}

section.filtered-communities-v2-section .fpc-card-vertical-divider {
    width: 1px !important;
    height: 48px !important;
    background: #CCC8C0 !important;
    flex-shrink: 0 !important;
}

section.filtered-communities-v2-section .fpc-card-price-container {
    width: 128px !important;
    min-width: 128px !important;
    height: 44px !important;
    display: inline-flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-end !important;
    flex-shrink: 0 !important;
}

section.filtered-communities-v2-section .fpc-card-price-label {
    width: 128px !important;
    text-align: right !important;
    color: #666666 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-card-price-value {
    align-self: stretch !important;
    text-align: right !important;
    color: #2A2A2A !important;
    font-size: 20px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
}

/* ============================================================
   v3.3: CONTACT FOR PRICE - 12px, sentence case
   ============================================================ */

section.filtered-communities-v2-section .fpc-card-price-container .fpc-card-price-value.fpc-contact-price {
    font-size: 12px !important;
    text-transform: none !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    line-height: 1.3 !important;
}

/* ============================================================
   HORIZONTAL DIVIDER
   ============================================================ */

section.filtered-communities-v2-section .fpc-card-horizontal-divider {
    align-self: stretch !important;
    height: 0 !important;
    outline: 1px solid #CCC8C0 !important;
    outline-offset: -0.5px !important;
}

/* ============================================================
   SPECS ROW - v3.13: View Community LEFT, Units RIGHT
   ============================================================ */

section.filtered-communities-v2-section .fpc-specs-row {
    align-self: stretch !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    margin-top: auto !important;
}

section.filtered-communities-v2-section .fpc-spec-item {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}

/* v3.13: Units stays on the right */
section.filtered-communities-v2-section .fpc-spec-units {
    margin-left: auto !important;
}

section.filtered-communities-v2-section .fpc-spec-icon {
    font-size: 20px !important;
    color: #CCC8C0 !important;
    line-height: 1 !important;
}

section.filtered-communities-v2-section .fpc-spec-text-group {
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 5px !important;
}

section.filtered-communities-v2-section .fpc-spec-value {
    text-align: center !important;
    color: #2A2A2A !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-spec-label {
    color: #666666 !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

/* ============================================================
   v3.12: VIEW COMMUNITY BUTTON - Badge Style
   ============================================================ */

section.filtered-communities-v2-section .fpc-view-community-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 5px 14px !important;
    background: #5A4F42 !important;
    border-radius: 50px !important;
    border: none !important;
    color: #FFFFFF !important;
    font-size: 12px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    text-transform: capitalize !important;
}

section.filtered-communities-v2-section .fpc-view-community-btn:hover {
    background: #928572 !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */

section.filtered-communities-v2-section .fpc-pagination {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    margin-top: 60px !important;
}

section.filtered-communities-v2-section .fpc-pagination-prev,
section.filtered-communities-v2-section .fpc-pagination-next {
    width: 40px !important;
    height: 40px !important;
    background: #FFFFFF !important;
    border: 1px solid #CCC8C0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    cursor: pointer !important;
    color: #5A4F42 !important;
    font-size: 18px !important;
}

section.filtered-communities-v2-section .fpc-pagination-prev:hover:not(:disabled),
section.filtered-communities-v2-section .fpc-pagination-next:hover:not(:disabled) {
    border-color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-pagination-prev:disabled,
section.filtered-communities-v2-section .fpc-pagination-next:disabled {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
}

section.filtered-communities-v2-section .fpc-pagination-numbers {
    display: flex !important;
    gap: 10px !important;
}

section.filtered-communities-v2-section .fpc-page-num {
    width: 40px !important;
    height: 40px !important;
    background: #FFFFFF !important;
    border: 1px solid #CCC8C0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    cursor: pointer !important;
    color: #5A4F42 !important;
    font-size: 18px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

section.filtered-communities-v2-section .fpc-page-num:hover {
    border-color: #5A4F42 !important;
}

section.filtered-communities-v2-section .fpc-page-num.active {
    background: #5A4F42 !important;
    border-color: #5A4F42 !important;
    color: #FFFFFF !important;
}

/* ============================================================
   KEY BUTTON + MODAL - v3.4: Fully contained inside map
   ============================================================ */

section.filtered-communities-v2-section .fpc-map-key-btn {
    position: absolute !important;
    bottom: 20px !important;
    left: 10px !important;
    padding: 10px 24px !important;
    background: #FFFFFF !important;
    border: 1px solid #2A2A2A !important;
    border-radius: 50px !important;
    font-size: 16px !important;
    font-family: 'Afacad Flux', sans-serif !important;
    font-weight: 400 !important;
    color: #2A2A2A !important;
    cursor: pointer !important;
    z-index: 1000 !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
}

section.filtered-communities-v2-section .fpc-map-key-btn:hover {
    background: #F5F3F0 !important;
}

/* v3.4: Key modal - anchored to BOTTOM-LEFT, grows upward, always inside map */
section.filtered-communities-v2-section .fpc-key-modal {
    display: none !important;
    position: absolute !important;
    bottom: 60px !important;
    left: 10px !important;
    background: #FFFFFF !important;
    border-radius: 8px !important;
    padding: 16px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
    z-index: 1001 !important;
    min-width: 200px !important;
    max-width: calc(100% - 20px) !important;
    max-height: calc(100% - 80px) !important;
    overflow-y: auto !important;
}

section.filtered-communities-v2-section .fpc-key-modal.show {
    display: block !important;
}

section.filtered-communities-v2-section .fpc-key-modal-content h4 {
    margin: 0 0 12px 0 !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #2A2A2A !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

section.filtered-communities-v2-section .fpc-key-item {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
}

section.filtered-communities-v2-section .fpc-key-item:last-of-type {
    margin-bottom: 12px !important;
}

section.filtered-communities-v2-section .fpc-key-dot {
    width: 16px !important;
    height: 16px !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
}

section.filtered-communities-v2-section .fpc-key-dot.city-cluster {
    background: #6A8375 !important;
    border: 2px solid #FFFFFF !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

section.filtered-communities-v2-section .fpc-key-dot.property {
    background: #78716C !important;
    border: 2px solid #FFFFFF !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

section.filtered-communities-v2-section .fpc-key-dot.selected {
    background: #5A4F42 !important;
    border: 2px solid #FFFFFF !important;
    box-shadow: 0 0 0 3px rgba(90, 79, 66, 0.3), 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

section.filtered-communities-v2-section .fpc-key-text {
    font-size: 13px !important;
    color: #5A4F42 !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
}

section.filtered-communities-v2-section .fpc-key-close {
    width: 100% !important;
    padding: 8px 14px !important;
    background: #F5F3F0 !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    color: #5A4F42 !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
}

section.filtered-communities-v2-section .fpc-key-close:hover {
    background: #E8E5DF !important;
}

/* ============================================================
   LEAFLET POPUP TOOLTIP (marker click)
   Shows property name + price on dot click
   ============================================================ */

section.filtered-communities-v2-section .leaflet-popup-content-wrapper {
    border-radius: 8px !important;
    padding: 0 !important;
    box-shadow: 0 3px 12px rgba(0, 0, 0, 0.2) !important;
    overflow: hidden !important;
}

section.filtered-communities-v2-section .leaflet-popup-content {
    margin: 10px 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    color: #2A2A2A !important;
    min-width: 120px !important;
}

section.filtered-communities-v2-section .leaflet-popup-tip {
    background: white !important;
    box-shadow: 0 3px 12px rgba(0, 0, 0, 0.2) !important;
}

section.filtered-communities-v2-section .fpc-popup-name {
    font-weight: 500 !important;
    font-size: 14px !important;
    color: #2A2A2A !important;
    margin: 0 0 2px 0 !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

section.filtered-communities-v2-section .fpc-popup-price {
    font-weight: 400 !important;
    font-size: 13px !important;
    color: #6A8375 !important;
    margin: 0 !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
}

/* Popup close button */
section.filtered-communities-v2-section .leaflet-popup-close-button {
    width: 20px !important;
    height: 20px !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #999 !important;
    top: 4px !important;
    right: 4px !important;
}

section.filtered-communities-v2-section .leaflet-popup-close-button:hover {
    color: #2A2A2A !important;
}

/* ============================================================
   SELECTED MARKER STATE (active/clicked dot)
   ============================================================ */

section.filtered-communities-v2-section .fpc-marker-dot.selected,
section.filtered-communities-v2-section .fpc-marker-dot.active,
section.filtered-communities-v2-section .fpc-marker-dot.fpc-marker-selected {
    background: #5A4F42 !important;
    box-shadow: 0 0 0 4px rgba(90, 79, 66, 0.3), 3px 5px 6px 2px rgba(0, 0, 0, 0.40) !important;
    transform: scale(1.25) !important;
}

/* ============================================================
   FULLSCREEN PREVIEW CARD - v3.13 FIXED
   Lower-right corner card when marker clicked in fullscreen
   ============================================================ */

section.filtered-communities-v2-section .fpc-fullscreen-preview {
    display: none !important;
    position: absolute !important;
    bottom: 20px !important;
    right: 20px !important;
    width: 280px !important;
    background: #FFFFFF !important;
    border-radius: 10px !important;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.18) !important;
    z-index: 1002 !important;
    overflow: hidden !important;
    animation: fpcFadeIn 0.25s ease-out !important;
}

section.filtered-communities-v2-section .fpc-fullscreen-preview.show {
    display: block !important;
}

/* Preview close button */
section.filtered-communities-v2-section .fpc-preview-close {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    width: 28px !important;
    height: 28px !important;
    background: rgba(0, 0, 0, 0.45) !important;
    border: none !important;
    border-radius: 50% !important;
    color: white !important;
    font-size: 14px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    transition: background 0.2s ease !important;
    line-height: 1 !important;
}

section.filtered-communities-v2-section .fpc-preview-close:hover {
    background: rgba(0, 0, 0, 0.65) !important;
}

/* Preview image */
section.filtered-communities-v2-section .fpc-preview-image {
    width: 100% !important;
    height: 140px !important;
    overflow: hidden !important;
    background: #F5F3F0 !important;
    position: relative !important;
}

section.filtered-communities-v2-section .fpc-preview-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* Preview content area */
section.filtered-communities-v2-section .fpc-preview-content {
    padding: 14px 16px 16px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

/* v3.13: Preview badge - PILL STYLE with colored background */
section.filtered-communities-v2-section .fpc-preview-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 5px 14px !important;
    border-radius: 50px !important;
    background: #5A4F42 !important;
    width: fit-content !important;
    margin-bottom: 5px !important;
}

section.filtered-communities-v2-section .fpc-preview-badge span {
    color: #FFFFFF !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

/* Preview title */
section.filtered-communities-v2-section .fpc-preview-title {
    color: #2A2A2A !important;
    font-size: 16px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

/* Preview address */
section.filtered-communities-v2-section .fpc-preview-address {
    color: #666666 !important;
    font-size: 12px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

/* Preview specs row */
section.filtered-communities-v2-section .fpc-preview-specs {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 8px !important;
    padding-top: 8px !important;
    border-top: 1px solid #E8E5DF !important;
}

section.filtered-communities-v2-section .fpc-preview-spec {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    flex: 1 !important;
}

section.filtered-communities-v2-section .fpc-preview-spec-label {
    font-size: 10px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    color: #999 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

section.filtered-communities-v2-section .fpc-preview-spec-value {
    font-size: 13px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 500 !important;
    color: #2A2A2A !important;
}

/* v3.13: Preview CTA button - ROUNDED (border-radius: 50px) */
section.filtered-communities-v2-section .fpc-preview-btn {
    display: block !important;
    width: 100% !important;
    padding: 10px 16px !important;
    background: #5A4F42 !important;
    color: #FFFFFF !important;
    text-align: center !important;
    text-decoration: none !important;
    border-radius: 50px !important;
    font-size: 14px !important;
    font-family: 'Afacad Flux', 'Roboto', sans-serif !important;
    font-weight: 400 !important;
    transition: background 0.2s ease !important;
    margin-top: 4px !important;
}

section.filtered-communities-v2-section .fpc-preview-btn:hover {
    background: #928572 !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
}

/* ============================================================
   RESPONSIVE - TABLET
   ============================================================ */

@media (max-width: 1199px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 60px 40px 20px 40px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-search-row {
        flex-wrap: wrap !important;
    }
    
    section.filtered-communities-v2-section .fpc-search-right {
        width: 100% !important;
    }
    
    section.filtered-communities-v2-section .fpc-search-wrapper {
        width: 100% !important;
        max-width: 400px !important;
    }
}

/* ============================================================
   RESPONSIVE - MOBILE (768px and below)
   v3.4: Map height 384px, key modal compact
   ============================================================ */

@media (max-width: 767px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 40px 30px 15px 30px !important;
    }
    
    section.filtered-communities-v2-section .fpc-title {
        font-size: 28px !important;
        white-space: normal !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-container {
        padding: 0 30px !important;
    }
    
    /* v3.4: Mobile map - 100% width, 384px height (Figma) */
    section.filtered-communities-v2-section .fpc-map-inner {
        max-width: 100% !important;
        width: 100% !important;
        height: 384px !important;
    }
    
    /* v3.4: Key modal - fits inside taller mobile map */
    section.filtered-communities-v2-section .fpc-map-key-btn {
        bottom: 15px !important;
        left: 8px !important;
        padding: 8px 20px !important;
        font-size: 14px !important;
    }
    
    section.filtered-communities-v2-section .fpc-key-modal {
        bottom: 55px !important;
        left: 8px !important;
        right: auto !important;
        min-width: 190px !important;
        max-width: calc(100% - 16px) !important;
        max-height: calc(100% - 70px) !important;
        padding: 14px !important;
    }
    
    /* Zoom controls - reposition for taller map */
    section.filtered-communities-v2-section .fpc-map-zoom-controls {
        bottom: 80px !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-search-row {
        padding: 0 30px !important;
        gap: 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-left {
        gap: 8px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-wrapper {
        padding: 0 30px 40px 30px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-grid {
        grid-template-columns: 1fr !important;
        gap: 30px !important;
    }
    
    /* Card title+price row - stack on mobile */
    section.filtered-communities-v2-section .fpc-card-title-price-row {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-title-container {
        width: 100% !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-vertical-divider {
        display: none !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-price-container {
        width: 100% !important;
        align-items: flex-start !important;
        min-width: auto !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-price-label,
    section.filtered-communities-v2-section .fpc-card-price-value {
        text-align: left !important;
        width: auto !important;
    }
    
    /* SPECS ROW - FIXED POSITION ON MOBILE */
    section.filtered-communities-v2-section .fpc-specs-row {
        flex-wrap: nowrap !important;
        justify-content: space-between !important;
        gap: 0 !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-value {
        font-size: 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-label {
        font-size: 13px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-icon {
        font-size: 18px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-item {
        gap: 6px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-text-group {
        gap: 4px !important;
    }
    
    /* View Community Button - Mobile */
    section.filtered-communities-v2-section .fpc-view-community-btn {
        padding: 5px 12px !important;
        font-size: 11px !important;
    }
    
    /* DROPDOWN FIX - Bottom sheet on mobile */
    section.filtered-communities-v2-section .fpc-filter-wrapper {
        position: static !important;
    }
    
    section.filtered-communities-v2-section .fpc-dropdown {
        position: fixed !important;
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100vw !important;
        min-width: 100vw !important;
        max-width: 100vw !important;
        border-radius: 16px 16px 0 0 !important;
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15) !important;
        padding: 24px 20px 32px 20px !important;
        max-height: 70vh !important;
        overflow-y: auto !important;
        z-index: 999999 !important;
        transform: translateY(100%) !important;
    }
    
    section.filtered-communities-v2-section .fpc-dropdown.show {
        transform: translateY(0) !important;
    }
    
    /* Fullscreen Preview - Mobile */
    section.filtered-communities-v2-section .fpc-fullscreen-preview {
        bottom: 12px !important;
        right: 12px !important;
        left: 12px !important;
        width: auto !important;
        max-width: 100% !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-image {
        height: 120px !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-content {
        padding: 12px 14px 14px 14px !important;
    }
}

/* ============================================================
   RESPONSIVE - SMALL MOBILE (480px and below)
   ============================================================ */

@media (max-width: 480px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 30px 20px 10px 20px !important;
    }
    
    section.filtered-communities-v2-section .fpc-title {
        font-size: 24px !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-container {
        padding: 0 20px !important;
    }
    
    /* v3.4: Keep 384px on small mobile too */
    section.filtered-communities-v2-section .fpc-map-inner {
        height: 384px !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-key-btn {
        bottom: 12px !important;
        left: 6px !important;
        padding: 6px 16px !important;
        font-size: 13px !important;
    }
    
    section.filtered-communities-v2-section .fpc-key-modal {
        bottom: 48px !important;
        left: 6px !important;
        right: 6px !important;
        min-width: auto !important;
        max-height: calc(100% - 65px) !important;
        padding: 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-search-row {
        padding: 0 20px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-wrapper {
        padding: 0 20px 30px 20px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-value {
        font-size: 15px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-label {
        font-size: 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-icon {
        font-size: 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-item {
        gap: 4px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-text-group {
        gap: 3px !important;
    }
    
    /* View Community Button - Small Mobile */
    section.filtered-communities-v2-section .fpc-view-community-btn {
        padding: 4px 10px !important;
        font-size: 11px !important;
        height: 22px !important;
        min-height: 22px !important;
        max-height: 22px !important;
    }
    
    /* Fullscreen Preview - Small Mobile */
    section.filtered-communities-v2-section .fpc-fullscreen-preview {
        bottom: 8px !important;
        right: 8px !important;
        left: 8px !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-image {
        height: 100px !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-title {
        font-size: 15px !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-content {
        padding: 10px 12px 12px 12px !important;
        gap: 6px !important;
    }
    
    section.filtered-communities-v2-section .fpc-preview-btn {
        padding: 9px 14px !important;
        font-size: 13px !important;
    }
}

/* ============================================================
   RESPONSIVE - IPHONE SE (375px and below)
   ============================================================ */

@media (max-width: 375px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 25px 16px 10px 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-title {
        font-size: 22px !important;
    }
    
    section.filtered-communities-v2-section .fpc-subtitle {
        font-size: 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-container {
        padding: 0 16px !important;
    }
    
    /* v3.4: 384px maintained even on iPhone SE */
    section.filtered-communities-v2-section .fpc-map-inner {
        height: 384px !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-search-row {
        padding: 0 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-wrapper {
        padding: 0 16px 25px 16px !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-content {
        padding: 16px 8px !important;
        gap: 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-specs-row {
        flex-wrap: nowrap !important;
        justify-content: space-between !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-value {
        font-size: 14px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-label {
        font-size: 11px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-icon {
        font-size: 14px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-item {
        gap: 3px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-text-group {
        gap: 2px !important;
    }
    
    /* View Community Button - iPhone SE */
    section.filtered-communities-v2-section .fpc-view-community-btn {
        padding: 4px 8px !important;
        font-size: 10px !important;
        height: 20px !important;
        min-height: 20px !important;
        max-height: 20px !important;
    }
}

/* ============================================================
   RESPONSIVE - VERY SMALL (320px)
   ============================================================ */

@media (max-width: 320px) {
    section.filtered-communities-v2-section .fpc-header-wrapper {
        padding: 20px 12px 8px 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-title {
        font-size: 20px !important;
    }
    
    section.filtered-communities-v2-section .fpc-subtitle {
        font-size: 14px !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-container {
        padding: 0 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-map-inner {
        height: 384px !important;
    }
    
    section.filtered-communities-v2-section .fpc-filters-search-row {
        padding: 0 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-properties-wrapper {
        padding: 0 12px 20px 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-card-content {
        padding: 14px 6px !important;
        gap: 10px !important;
    }
    
    section.filtered-communities-v2-section .fpc-specs-row {
        flex-wrap: nowrap !important;
        justify-content: space-between !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-value {
        font-size: 13px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-label {
        font-size: 10px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-icon {
        font-size: 12px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-item {
        gap: 2px !important;
    }
    
    section.filtered-communities-v2-section .fpc-spec-text-group {
        gap: 2px !important;
    }
    
    /* View Community Button - Very Small */
    section.filtered-communities-v2-section .fpc-view-community-btn {
        padding: 3px 6px !important;
        font-size: 10px !important;
        height: 18px !important;
        min-height: 18px !important;
        max-height: 18px !important;
    }
}

/* ============================================================
   MOBILE OVERLAY (for dropdown backdrop)
   ============================================================ */

section.filtered-communities-v2-section .fpc-mobile-overlay {
    display: none !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background: rgba(0, 0, 0, 0.4) !important;
    z-index: 99998 !important;
}

section.filtered-communities-v2-section .fpc-mobile-overlay.show {
    display: block !important;
}