        :root {
            --primary: #00d4aa;
            --primary-dark: #00a88a;
            --accent: #ff6b35;
            --dark: #0d1117;
            --darker: #010409;
            --card: #161b22;
            --card-hover: #1c2128;
            --border: #30363d;
            --text: #e6edf3;
            --text-muted: #8b949e;
            --success: #3fb950;
            --warning: #d29922;
            --error: #f85149;
        }

        * { margin: 0; padding: 0; box-sizing: border-box; }

        body {
            font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
            background: var(--darker);
            color: var(--text);
            overflow: hidden;
        }

        /* Accessibility - Skip Link */
        .skip-link {
            position: absolute;
            top: -40px;
            left: 0;
            background: var(--primary);
            color: var(--dark);
            padding: 8px 16px;
            z-index: 10000;
            font-weight: 600;
            text-decoration: none;
            border-radius: 0 0 8px 0;
            transition: top 0.2s;
        }

        .skip-link:focus {
            top: 0;
        }

        /* Accessibility - Focus Styles */
        *:focus {
            outline: none;
        }

        *:focus-visible {
            outline: 2px solid var(--primary);
            outline-offset: 2px;
        }

        button:focus-visible,
        a:focus-visible,
        input:focus-visible,
        select:focus-visible,
        textarea:focus-visible {
            outline: 2px solid var(--primary);
            outline-offset: 2px;
            box-shadow: 0 0 0 4px rgba(0, 212, 170, 0.2);
        }

        /* Screen reader only */
        .sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
            border: 0;
        }

        /* Header */
        .header {
            background: linear-gradient(180deg, var(--dark) 0%, var(--darker) 100%);
            border-bottom: 1px solid var(--border);
            padding: 12px 20px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            position: relative;
            z-index: 9999;
        }

        .logo {
            display: flex;
            align-items: center;
            gap: 12px;
        }

        .logo-icon {
            width: 42px;
            height: 42px;
            background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 22px;
            box-shadow: 0 4px 15px rgba(0, 212, 170, 0.3);
        }

        .logo-text {
            font-family: 'Space Mono', monospace;
            font-size: 24px;
            font-weight: 700;
            background: linear-gradient(90deg, var(--primary), var(--accent));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            letter-spacing: -1px;
        }

        .header-actions {
            display: flex;
            gap: 8px;
            align-items: center;
        }

        /* Header Dropdowns */
        .header-dropdown {
            position: relative;
            z-index: 9999;
        }

        .header-dropdown-btn {
            padding: 8px 14px !important;
            font-size: 13px !important;
        }

        .header-dropdown-menu {
            position: absolute;
            top: 100%;
            right: 0;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            min-width: 180px;
            padding: 6px 0;
            z-index: 2000;
            display: none;
            box-shadow: 0 8px 24px rgba(0,0,0,0.4);
            max-height: calc(100vh - 80px);
            overflow-y: auto;
        }

        .header-dropdown-menu.active {
            display: block;
        }

        .header-dropdown-menu button {
            display: block;
            width: 100%;
            text-align: left;
            padding: 10px 16px;
            background: none;
            border: none;
            color: var(--text);
            font-size: 13px;
            cursor: pointer;
            transition: all 0.15s;
        }

        .header-dropdown-menu button:hover {
            background: var(--primary);
            color: var(--dark);
        }

        .dropdown-divider {
            height: 1px;
            background: var(--border);
            margin: 6px 0;
        }

        .search-box {
            display: flex;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            overflow: hidden;
        }

        .search-box input {
            background: transparent;
            border: none;
            padding: 10px 15px;
            color: var(--text);
            font-size: 14px;
            width: 280px;
            outline: none;
        }

        .search-box input::placeholder { color: var(--text-muted); }

        .search-box button {
            background: var(--primary);
            border: none;
            padding: 10px 16px;
            color: var(--dark);
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }

        .search-box button:hover { background: var(--primary-dark); }

        .btn {
            padding: 10px 18px;
            border-radius: 8px;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            border: none;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .btn-primary { background: var(--primary); color: var(--dark); }
        .btn-primary:hover { background: var(--primary-dark); transform: translateY(-1px); }
        .btn-ghost { background: transparent; color: var(--text); border: 1px solid var(--border); }
        .btn-ghost:hover { background: var(--card); border-color: var(--primary); }

        .list-count {
            background: var(--accent);
            color: white;
            font-size: 11px;
            padding: 2px 7px;
            border-radius: 10px;
            font-weight: 700;
        }

        /* Main Layout */
        .main { display: flex; height: calc(100vh - 66px - 110px); overflow: hidden; }

        /* Map */
        .map-container { flex: 1; position: relative; height: 100%; overflow: hidden; }
        #map { width: 100%; height: 100%; background: var(--darker); position: absolute; top: 0; left: 0; }

        .map-overlay {
            position: absolute;
            bottom: 10px;
            right: 10px;
            z-index: 2000;
            display: flex;
            flex-direction: column;
            gap: 6px;
        }

        .map-overlay.minimized .map-btn:not(.map-overlay-toggle) {
            display: none;
        }

        .map-overlay-toggle {
            background: var(--primary) !important;
            color: var(--dark) !important;
            padding: 8px 12px !important;
            font-size: 12px !important;
        }

        /* Pegman - Street View Draggable */
        .pegman {
            width: 40px;
            height: 40px;
            background: #fff;
            border: 1px solid #ddd;
            border-radius: 8px;
            box-shadow: 0 2px 6px rgba(0,0,0,0.15);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            cursor: grab;
            transition: all 0.2s;
            user-select: none;
        }

        .pegman:hover {
            background: #f0f0f0;
            border-color: var(--primary);
        }

        .pegman.dragging {
            cursor: grabbing;
            transform: scale(1.2);
            box-shadow: 0 6px 16px rgba(0,0,0,0.5);
            opacity: 0.9;
        }

        .pegman-ghost {
            position: fixed;
            font-size: 28px;
            pointer-events: none;
            z-index: 9999;
            filter: drop-shadow(0 3px 5px rgba(0,0,0,0.4));
            transform: translate(-50%, -100%);
        }

        /* Map Tools Bottom (horizontal layout) */
        .map-tools-bottom {
            position: absolute;
            bottom: 8px;
            left: 270px;
            display: flex;
            flex-direction: row;
            gap: 6px;
            z-index: 2000;
        }

        .map-tool-btn {
            width: 40px;
            height: 40px;
            background: white;
            border: 1px solid #ddd;
            border-radius: 8px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            transition: all 0.2s;
            box-shadow: 0 2px 6px rgba(0,0,0,0.15);
        }

        .map-tool-btn:hover {
            background: #f0f0f0;
            border-color: var(--primary);
        }

        .map-tool-btn.active {
            background: var(--primary);
            color: white;
            border-color: var(--primary);
        }

        .map-tool-btn-group {
            background: white;
            border-radius: 8px;
            overflow: hidden;
            box-shadow: 0 2px 6px rgba(0,0,0,0.15);
            display: flex;
            flex-direction: row;
        }

        .map-tool-btn-group .map-tool-btn {
            border-radius: 0;
            box-shadow: none;
            border: none;
            border-right: 1px solid #eee;
        }

        .map-tool-btn-group .map-tool-btn:last-child {
            border-right: none;
        }

        /* Measure tooltip on map */
        .measure-tooltip {
            background: var(--dark);
            color: white;
            padding: 6px 10px;
            border-radius: 6px;
            font-size: 12px;
            font-weight: 500;
            white-space: nowrap;
            box-shadow: 0 2px 8px rgba(0,0,0,0.3);
        }

        .measure-tooltip-temp {
            opacity: 0.8;
        }

        .measure-result {
            position: absolute;
            bottom: 75px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--dark);
            color: white;
            padding: 12px 20px;
            border-radius: 10px;
            font-size: 14px;
            z-index: 1001;
            box-shadow: 0 4px 15px rgba(0,0,0,0.3);
            display: none;
        }

        .measure-result.active {
            display: flex;
            align-items: center;
            gap: 15px;
        }

        .measure-result-value {
            font-weight: 600;
            color: var(--primary);
            font-size: 16px;
        }

        .measure-result-close {
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            font-size: 18px;
            padding: 0 5px;
        }

        .measure-result-close:hover {
            color: white;
        }

        /* Street View coverage overlay */
        .streetview-coverage {
            pointer-events: none;
        }

        .streetview-highlight {
            stroke: #4285f4;
            stroke-width: 4;
            stroke-opacity: 0.8;
            fill: none;
        }

        .map-btn {
            background: var(--card);
            border: 1px solid var(--border);
            color: var(--text);
            padding: 10px 14px;
            border-radius: 8px;
            cursor: pointer;
            font-size: 13px;
            font-weight: 500;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .map-btn:hover { background: var(--card-hover); border-color: var(--primary); }
        .map-btn.active { background: var(--primary); color: var(--dark); border-color: var(--primary); }

        /* Sidebar */
        .sidebar {
            width: 420px;
            background: var(--dark);
            border-left: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            overflow: hidden;
            z-index: 100;
            position: relative;
            transition: width 0.3s ease, min-width 0.3s ease;
        }

        .sidebar-collapse-btn {
            position: absolute;
            top: 8px;
            left: 8px;
            width: 28px;
            height: 28px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-muted);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 14px;
            z-index: 10;
            transition: all 0.2s;
        }
        .sidebar-collapse-btn:hover {
            background: var(--card-hover);
            color: var(--text);
            border-color: var(--primary);
        }

        @media (min-width: 769px) {
            .sidebar.collapsed {
                width: 48px;
                min-width: 48px;
            }
            .sidebar.collapsed .sidebar-tabs,
            .sidebar.collapsed .sidebar-content {
                display: none;
            }
            .sidebar.collapsed .sidebar-collapse-btn {
                left: 50%;
                transform: translateX(-50%);
            }
        }

        .sidebar-tabs {
            display: flex;
            border-bottom: 1px solid var(--border);
        }

        .sidebar-tab {
            flex: 1;
            padding: 14px;
            background: transparent;
            border: none;
            color: var(--text-muted);
            font-size: 13px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            border-bottom: 2px solid transparent;
        }

        .sidebar-tab:hover { color: var(--text); background: var(--card); }
        .sidebar-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
        
        /* Leads System Styles */
        .lead-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px;
            margin: 8px;
            cursor: pointer;
            transition: all 0.2s;
        }
        .lead-card:hover { border-color: var(--primary); transform: translateY(-1px); }
        .lead-card.stage-new { border-left: 4px solid #3b82f6; }
        .lead-card.stage-contacted { border-left: 4px solid #8b5cf6; }
        .lead-card.stage-interested { border-left: 4px solid #f59e0b; }
        .lead-card.stage-negotiating { border-left: 4px solid #ec4899; }
        .lead-card.stage-offer_made { border-left: 4px solid #f97316; }
        .lead-card.stage-under_contract { border-left: 4px solid #14b8a6; }
        .lead-card.stage-closed { border-left: 4px solid #22c55e; }
        .lead-card.stage-dead { border-left: 4px solid #666; opacity: 0.7; }
        
        .lead-stage-badge {
            display: inline-block;
            padding: 2px 8px;
            border-radius: 12px;
            font-size: 10px;
            font-weight: bold;
        }
        .lead-stage-badge.new { background: #3b82f6; color: #fff; }
        .lead-stage-badge.contacted { background: #8b5cf6; color: #fff; }
        .lead-stage-badge.interested { background: #f59e0b; color: #000; }
        .lead-stage-badge.negotiating { background: #ec4899; color: #fff; }
        .lead-stage-badge.offer_made { background: #f97316; color: #000; }
        .lead-stage-badge.under_contract { background: #14b8a6; color: #fff; }
        .lead-stage-badge.closed { background: #22c55e; color: #fff; }
        .lead-stage-badge.dead { background: #666; color: #fff; }
        
        .pipeline-badge { color: #fff; cursor: pointer; transition: transform 0.2s, box-shadow 0.2s; }
        .pipeline-badge:hover { transform: scale(1.1); }
        .pipeline-badge.drag-over { transform: scale(1.3); box-shadow: 0 0 10px rgba(255,255,255,0.5); }

        /* Drag and Drop Styles */
        .lead-card { cursor: grab; transition: transform 0.2s, opacity 0.2s, box-shadow 0.2s; }
        .lead-card:active { cursor: grabbing; }
        .lead-card.dragging { opacity: 0.5; transform: rotate(2deg) scale(1.02); box-shadow: 0 10px 30px rgba(0,0,0,0.3); }
        .lead-card.drag-preview { position: fixed; pointer-events: none; z-index: 10000; }

        /* Stage Drop Zones */
        .stage-drop-zone {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 6px 12px;
            border-radius: 16px;
            font-size: 10px;
            transition: all 0.2s;
            cursor: pointer;
            border: 2px solid transparent;
        }
        .stage-drop-zone:hover { filter: brightness(1.2); }
        .stage-drop-zone.drag-over {
            transform: scale(1.1);
            border: 2px dashed white;
            box-shadow: 0 0 15px currentColor;
        }
        .stage-drop-zone .stage-count {
            background: rgba(0,0,0,0.3);
            padding: 1px 6px;
            border-radius: 10px;
            font-weight: bold;
        }
        
        .activity-item {
            padding: 8px;
            border-left: 2px solid #444;
            margin-left: 8px;
            margin-bottom: 8px;
            font-size: 11px;
        }
        .activity-item.call { border-left-color: #3b82f6; }
        .activity-item.email { border-left-color: #22c55e; }
        .activity-item.text { border-left-color: #f59e0b; }
        .activity-item.note { border-left-color: #8b5cf6; }
        .activity-item.offer { border-left-color: #ec4899; }

        .sidebar-content { flex: 1; overflow-y: auto; padding: 15px; }

        .sidebar-panel { display: none; }
        .sidebar-panel.active { display: block; }
        #listPanel { margin: -15px -15px 0 -15px; }
        #listPanel #savedList { margin: 0; }

        /* Property Card */
        .property-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 12px;
            overflow: hidden;
            margin-bottom: 12px;
            transition: all 0.2s;
        }

        .property-card:hover { border-color: var(--primary); transform: translateY(-2px); }

        .property-header {
            padding: 15px;
            border-bottom: 1px solid var(--border);
        }

        .property-address { font-size: 20px; font-weight: 700; margin-bottom: 6px; color: #fff; }
        .property-city { font-size: 13px; color: var(--text-muted); }
        .property-body { padding: 15px; }

        .property-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 12px;
        }

        .property-stat {
            background: var(--darker);
            padding: 10px 12px;
            border-radius: 8px;
        }

        .property-stat-label {
            font-size: 11px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 4px;
        }

        .property-stat-value { font-size: 15px; font-weight: 600; color: var(--primary); }

        .property-actions {
            display: flex;
            gap: 8px;
            padding: 15px;
            border-top: 1px solid var(--border);
            flex-wrap: wrap;
        }

        .property-actions .btn { flex: 1; justify-content: center; font-size: 12px; padding: 8px; min-width: 120px; }

        /* Street View Modal */
        .modal-overlay {
            display: none;
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0,0,0,0.85);
            z-index: 10000;
            align-items: center;
            justify-content: center;
        }

        .modal-overlay.active { display: flex; }
        
        /* Lead modal positioning - at top */
        #leadModal.active {
            align-items: flex-start;
            padding-top: 5px;
            z-index: 10000;
        }
        #leadModal .lead-modal-content {
            margin-bottom: 280px; /* Leave room for Call Mode panel */
        }

        .modal {
            background: var(--dark);
            border: 1px solid var(--border);
            border-radius: 16px;
            width: 90%;
            max-width: 1000px;
            max-height: 85vh;
            overflow: hidden;
            box-shadow: 0 25px 50px rgba(0,0,0,0.5);
        }

        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 15px 20px;
            border-bottom: 1px solid var(--border);
        }

        .modal-title { font-size: 16px; font-weight: 600; }

        .modal-close {
            background: transparent;
            border: none;
            color: var(--text-muted);
            font-size: 24px;
            cursor: pointer;
            padding: 5px 10px;
        }

        .modal-close:hover { color: var(--accent); }
        .streetview-frame { width: 100%; height: 500px; border: none; }

        /* Empty state */
        .empty-state {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-muted);
        }

        .empty-state-icon { font-size: 48px; margin-bottom: 15px; opacity: 0.5; }
        .empty-state h3 { font-size: 16px; color: var(--text); margin-bottom: 8px; }
        .empty-state p { font-size: 13px; }

        /* List Item */
        .list-item {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 10px;
            padding: 12px 15px;
            margin-bottom: 10px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            transition: all 0.2s;
        }

        .list-item:hover { border-color: var(--primary); }
        .list-item-info h4 { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
        .list-item-info p { font-size: 12px; color: var(--text-muted); }
        .list-item-actions { display: flex; gap: 6px; }

        .list-item-btn {
            background: var(--darker);
            border: none;
            color: var(--text-muted);
            padding: 6px 10px;
            border-radius: 6px;
            cursor: pointer;
            font-size: 12px;
            transition: all 0.2s;
        }

        .list-item-btn:hover { background: var(--primary); color: var(--dark); }
        .list-item-btn.delete:hover { background: var(--error); color: white; }

        /* Instructions */
        .instructions {
            background: linear-gradient(135deg, rgba(0,212,170,0.1) 0%, rgba(255,107,53,0.1) 100%);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 20px;
            margin-bottom: 15px;
        }

        .instructions h3 { font-size: 15px; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
        .instructions ol { padding-left: 20px; font-size: 13px; color: var(--text-muted); line-height: 1.8; }
        .instructions li { margin-bottom: 5px; }

        /* Toast notification */
        .toast {
            position: fixed;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%) translateY(100px);
            background: var(--card);
            border: 1px solid var(--border);
            padding: 12px 20px;
            border-radius: 10px;
            font-size: 14px;
            z-index: 3000;
            transition: transform 0.3s ease;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .toast.show { transform: translateX(-50%) translateY(0); }
        .toast.success { border-color: var(--success); background: linear-gradient(135deg, rgba(63, 185, 80, 0.15), var(--card)); }
        .toast.error { border-color: var(--error); background: linear-gradient(135deg, rgba(248, 81, 73, 0.15), var(--card)); }
        .toast.warning { border-color: var(--warning); background: linear-gradient(135deg, rgba(210, 153, 34, 0.15), var(--card)); }
        .toast.info { border-color: var(--primary); background: linear-gradient(135deg, rgba(0, 212, 170, 0.15), var(--card)); }

        /* Coords display */
        .coords-display {
            position: absolute;
            bottom: 60px;
            left: 50px;
            background: var(--card);
            border: 1px solid var(--border);
            padding: 6px 10px;
            border-radius: 6px;
            font-size: 11px;
            font-family: 'Space Mono', monospace;
            z-index: 400;
        }

        .coords-display span { color: var(--primary); }

        /* Loading spinner */
        .loading {
            display: inline-block;
            width: 16px;
            height: 16px;
            border: 2px solid var(--text-muted);
            border-radius: 50%;
            border-top-color: var(--primary);
            animation: spin 0.8s linear infinite;
        }

        @keyframes spin { to { transform: rotate(360deg); } }

        /* Loading spinner for popups */
        .loading-spinner {
            width: 24px;
            height: 24px;
            margin: 0 auto;
            border: 3px solid #e0e0e0;
            border-radius: 50%;
            border-top-color: #2d5a27;
            animation: spin 0.8s linear infinite;
        }

        /* Parcel hover tooltip */
        .parcel-tooltip {
            background: rgba(0, 0, 0, 0.85);
            border: 1px solid #00FF00;
            border-radius: 4px;
            color: #00FF00;
            font-size: 12px;
            font-weight: 600;
            padding: 4px 8px;
            box-shadow: 0 2px 8px rgba(0, 255, 0, 0.3);
        }
        .parcel-tooltip::before {
            border-top-color: #00FF00 !important;
        }
        .parcel-polygon {
            cursor: pointer;
            transition: all 0.15s ease;
        }

        /* Loading skeleton */
        .skeleton {
            background: linear-gradient(90deg, var(--card) 25%, var(--card-hover) 50%, var(--card) 75%);
            background-size: 200% 100%;
            animation: skeleton-loading 1.5s infinite;
            border-radius: 4px;
        }

        .skeleton-text {
            height: 14px;
            width: 100%;
            margin-bottom: 8px;
        }

        .skeleton-text-sm {
            height: 12px;
            width: 60%;
        }

        .skeleton-card {
            padding: 12px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            margin-bottom: 8px;
        }

        @keyframes skeleton-loading {
            0% { background-position: 200% 0; }
            100% { background-position: -200% 0; }
        }

        /* Empty state */
        .empty-state {
            text-align: center;
            padding: 40px 20px;
            color: var(--text-muted);
        }

        .empty-state-icon {
            font-size: 48px;
            margin-bottom: 16px;
            opacity: 0.5;
        }

        .empty-state-title {
            font-size: 16px;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 8px;
        }

        .empty-state-text {
            font-size: 13px;
            margin-bottom: 16px;
        }

        /* Error state */
        .error-state {
            text-align: center;
            padding: 30px 20px;
            background: rgba(248, 81, 73, 0.1);
            border: 1px solid rgba(248, 81, 73, 0.3);
            border-radius: 8px;
            margin: 10px;
        }

        .error-state-icon {
            font-size: 32px;
            margin-bottom: 12px;
        }

        .error-state-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--error);
            margin-bottom: 8px;
        }

        .error-state-text {
            font-size: 12px;
            color: var(--text-muted);
            margin-bottom: 12px;
        }

        .retry-btn {
            background: var(--error);
            color: white;
            border: none;
            padding: 8px 16px;
            border-radius: 6px;
            font-size: 12px;
            cursor: pointer;
            font-weight: 500;
        }

        .retry-btn:hover {
            background: #d73a49;
        }

        /* Progress bar */
        .progress-bar {
            height: 4px;
            background: var(--border);
            border-radius: 2px;
            overflow: hidden;
        }

        .progress-bar-fill {
            height: 100%;
            background: var(--primary);
            border-radius: 2px;
            transition: width 0.3s ease;
        }

        .progress-bar-indeterminate .progress-bar-fill {
            width: 30%;
            animation: progress-indeterminate 1.5s infinite;
        }

        @keyframes progress-indeterminate {
            0% { transform: translateX(-100%); }
            100% { transform: translateX(400%); }
        }

        /* Export Modal Styles */
        .export-group {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            margin-bottom: 10px;
            overflow: hidden;
        }

        .export-group-header {
            padding: 12px 15px;
            background: var(--card-hover);
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-weight: 600;
            font-size: 14px;
            transition: background 0.2s;
        }

        .export-group-header:hover { background: var(--border); }

        .export-group-toggle { font-size: 12px; color: var(--text-muted); }

        .export-group-content {
            padding: 12px 15px;
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 8px;
        }

        .export-group-content.collapsed { display: none; }

        .export-checkbox {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 13px;
            color: var(--text);
            cursor: pointer;
            padding: 4px 0;
        }

        .export-checkbox input[type="checkbox"],
        .export-checkbox input[type="radio"] {
            width: 16px;
            height: 16px;
            accent-color: var(--primary);
            cursor: pointer;
        }

        .export-checkbox:hover { color: var(--primary); }

        /* Zoom Controls - Top Right */
        .map-zoom-controls {
            position: absolute;
            top: 5px;
            right: 10px;
            display: flex;
            flex-direction: column;
            gap: 2px;
            z-index: 2000;
        }

        .map-zoom-controls .map-tool-btn {
            width: 36px;
            height: 36px;
            font-size: 20px;
            font-weight: bold;
        }

        .layer-toggle input {
            width: 14px;
            height: 14px;
            accent-color: var(--primary);
        }

        /* Floating Amenities Panel - Compact horizontal strip */
        .map-amenities-panel {
            position: absolute;
            bottom: 10px;
            left: 50px;
            background: var(--dark);
            border: 1px solid var(--border);
            border-radius: 6px;
            padding: 4px 6px;
            z-index: 500;
            box-shadow: 0 2px 8px rgba(0,0,0,0.3);
        }

        .amenities-title {
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: 9px;
            font-weight: 600;
            color: var(--text);
            padding-bottom: 3px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 4px;
            cursor: pointer;
        }

        .amenities-toggle-icon {
            font-size: 8px;
            transition: transform 0.2s;
        }

        .map-amenities-panel.collapsed .amenities-toggle-icon {
            transform: rotate(-90deg);
        }

        .map-amenities-panel.collapsed .amenities-buttons {
            display: none;
        }

        .map-amenities-panel.collapsed {
            min-width: auto;
        }

        .amenities-buttons {
            display: flex;
            gap: 3px;
        }

        .amenity-btn {
            display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: center;
            padding: 3px 6px;
            border: none;
            border-radius: 4px;
            gap: 2px;
            cursor: pointer;
            transition: all 0.2s;
            font-size: 10px;
        }

        .amenity-btn .amenity-icon {
            font-size: 12px;
        }

        .amenity-btn .amenity-label {
            font-size: 8px;
            font-weight: 600;
        }

        .amenity-btn.walmart {
            background: #0071ce;
            color: white;
        }
        .amenity-btn.walmart:hover {
            background: #005ea6;
        }
        .amenity-btn.walmart.active {
            box-shadow: 0 0 0 2px #ffc220;
        }

        .amenity-btn.gas {
            background: #dc2626;
            color: white;
        }
        .amenity-btn.gas:hover {
            background: #b91c1c;
        }
        .amenity-btn.gas.active {
            box-shadow: 0 0 0 2px #fbbf24;
        }

        .amenity-btn.grocery {
            background: #16a34a;
            color: white;
        }
        .amenity-btn.grocery:hover {
            background: #15803d;
        }
        .amenity-btn.grocery.active {
            box-shadow: 0 0 0 2px #86efac;
        }

        .amenity-btn.clear {
            background: #444;
            color: #ccc;
            grid-column: span 2;
        }
        .amenity-btn.clear:hover {
            background: #555;
        }

        /* Soil Legend */
        .soil-legend {
            position: fixed;
            top: 60px;
            left: 0;
            background: rgba(20, 20, 30, 0.95);
            border: 2px solid #14b8a6;
            border-left: none;
            border-radius: 0 10px 10px 0;
            padding: 12px;
            z-index: 2500;
            max-width: 155px;
            max-height: calc(100vh - 120px);
            overflow-y: auto;
            box-shadow: 4px 4px 20px rgba(0,0,0,0.5);
            display: none;
            backdrop-filter: blur(5px);
        }

        .soil-legend.active { display: block; }

        .soil-legend-title {
            font-weight: 600;
            font-size: 13px;
            margin-bottom: 10px;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .soil-legend-item {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 5px 6px;
            font-size: 11px;
            border-radius: 4px;
            margin-bottom: 3px;
            background: rgba(255,255,255,0.05);
        }

        .soil-legend-color, .soil-color {
            width: 24px;
            height: 18px;
            border-radius: 4px;
            flex-shrink: 0;
            border: 1px solid rgba(255,255,255,0.3);
        }

        /* Search Results Left Panel */
        .results-panel {
            position: fixed;
            left: 0;
            top: 60px;
            width: 350px;
            height: calc(100vh - 60px);
            background: var(--dark);
            border-right: 1px solid var(--border);
            z-index: 2000;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
        }

        .results-panel.active {
            transform: translateX(0);
        }

        .results-panel.minimized {
            width: 50px;
        }

        .results-panel.minimized .results-content,
        .results-panel.minimized .results-header-title,
        .results-panel.minimized .results-sort,
        .results-panel.minimized .results-count {
            display: none;
        }

        .results-header {
            padding: 15px;
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: var(--card);
        }

        .results-header-title {
            font-weight: 600;
            font-size: 14px;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .results-header-actions {
            display: flex;
            gap: 8px;
        }

        .results-header-btn {
            background: var(--border);
            border: none;
            color: var(--text);
            width: 28px;
            height: 28px;
            border-radius: 6px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 14px;
        }

        .results-header-btn:hover {
            background: var(--primary);
            color: var(--dark);
        }

        .results-sort {
            padding: 10px 15px;
            border-bottom: 1px solid var(--border);
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
        }

        .sort-btn {
            background: var(--card);
            border: 1px solid var(--border);
            color: var(--text-muted);
            padding: 5px 10px;
            border-radius: 15px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .sort-btn:hover, .sort-btn.active {
            background: var(--primary);
            color: var(--dark);
            border-color: var(--primary);
        }

        .results-count {
            padding: 8px 15px;
            font-size: 11px;
            color: var(--text-muted);
            border-bottom: 1px solid var(--border);
        }

        .results-content {
            flex: 1;
            overflow-y: auto;
            padding: 10px;
        }

        .result-item {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px;
            margin-bottom: 10px;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
        }

        .result-item:hover {
            border-color: var(--primary);
            background: var(--card-hover);
        }

        .result-item.selected {
            border-color: var(--primary);
            box-shadow: 0 0 0 2px rgba(0, 212, 170, 0.2);
        }

        .result-item-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 8px;
        }

        .result-item-title {
            font-weight: 600;
            font-size: 13px;
            color: var(--text);
        }

        .result-item-delete {
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            padding: 2px 6px;
            border-radius: 4px;
            font-size: 12px;
        }

        .result-item-delete:hover {
            background: var(--error);
            color: white;
        }

        .result-item-stats {
            display: flex;
            gap: 12px;
            flex-wrap: wrap;
        }

        .result-stat {
            font-size: 11px;
            color: var(--text-muted);
        }

        .result-stat-value {
            font-weight: 600;
            color: var(--text);
        }

        .result-septic-badge {
            display: inline-block;
            padding: 2px 8px;
            border-radius: 10px;
            font-size: 10px;
            font-weight: 600;
            color: white;
        }

        /* AI Scan Badge Styles */
        .ai-badge {
            display: inline-block;
            margin-right: 6px;
            font-size: 12px;
        }

        .ai-badge-vacant {
            color: var(--success);
        }

        .ai-badge-structure {
            color: var(--accent);
        }

        .result-item.has-structure {
            opacity: 0.6;
            border-color: var(--accent);
            background: rgba(255, 107, 53, 0.05);
        }

        .result-item.has-structure:hover {
            opacity: 0.8;
        }

        .results-toggle-btn {
            position: fixed;
            left: 0;
            top: 50%;
            transform: translateY(-50%);
            background: var(--primary);
            color: var(--dark);
            border: none;
            padding: 15px 8px;
            border-radius: 0 8px 8px 0;
            cursor: pointer;
            z-index: 1001;
            font-weight: bold;
            writing-mode: vertical-rl;
            text-orientation: mixed;
            display: none;
        }

        .results-toggle-btn.active {
            display: block;
        }

        .results-panel.active + .results-toggle-btn {
            left: 350px;
        }

        .results-panel.minimized + .results-toggle-btn {
            left: 50px;
        }

        /* Found Parcels Panel (Left Side) */
        .found-parcels-panel {
            position: fixed;
            left: 0;
            top: 70px; /* Below header */
            width: 380px;
            height: calc(100vh - 70px);
            background: var(--dark);
            border-right: 1px solid var(--border);
            z-index: 1500;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
        }

        .found-parcels-panel.active {
            transform: translateX(0);
        }

        .found-parcels-panel.minimized {
            width: 48px;
        }
        .found-parcels-panel.minimized .found-parcels-title,
        .found-parcels-panel.minimized .found-parcels-actions button:not(#minimizeFoundBtn),
        .found-parcels-panel.minimized .found-parcels-content,
        .found-parcels-panel.minimized #foundParcelsSettings,
        .found-parcels-panel.minimized > div:not(.found-parcels-header) {
            display: none !important;
        }
        .found-parcels-panel.minimized .found-parcels-header {
            flex-direction: column;
            padding: 8px;
        }
        .found-parcels-panel.minimized .found-parcels-actions {
            margin-top: 0;
        }

        /* Tax Delinquent Panel (Left Side - Red Theme) */
        .tax-panel {
            position: fixed;
            left: 0;
            top: 70px;
            width: 280px;
            height: calc(100vh - 70px);
            background: linear-gradient(180deg, #1a0a0a 0%, #0d0d0d 100%);
            border-right: 2px solid #ef4444;
            z-index: 1501;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
            overflow: hidden;
        }

        .tax-panel.active {
            transform: translateX(0);
        }

        .tax-panel-header {
            padding: 10px 15px;
            border-bottom: 2px solid #ef4444;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, #7f1d1d 0%, #450a0a 100%);
        }

        .tax-panel-header .title {
            font-size: 14px;
            font-weight: 700;
            color: #fca5a5;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .tax-panel-header .actions {
            display: flex;
            gap: 6px;
        }

        .tax-panel-header .actions button {
            padding: 4px 8px;
            font-size: 11px;
            background: rgba(239, 68, 68, 0.2);
            border: 1px solid #ef4444;
            border-radius: 4px;
            color: #fca5a5;
            cursor: pointer;
            transition: all 0.2s;
        }

        .tax-panel-header .actions button:hover {
            background: rgba(239, 68, 68, 0.4);
        }

        /* Active state for tax panel toggle buttons */
        #taxFiltersToggle.active,
        #taxViewToggle.active {
            background: rgba(239, 68, 68, 0.5) !important;
            border-color: #f87171 !important;
        }

        /* Quick filter buttons for land flippers */
        .tax-quick-filter {
            padding: 2px 6px;
            font-size: 9px;
            background: rgba(100, 100, 100, 0.2);
            border: 1px solid #555;
            border-radius: 3px;
            color: #aaa;
            cursor: pointer;
            transition: all 0.15s;
        }
        .tax-quick-filter:hover {
            background: rgba(239, 68, 68, 0.2);
            border-color: #ef4444;
            color: #fca5a5;
        }
        .tax-quick-filter.active {
            background: rgba(34, 197, 94, 0.3);
            border-color: #22c55e;
            color: #86efac;
        }

        .tax-panel-nav {
            padding: 8px 12px;
            background: rgba(127, 29, 29, 0.3);
            border-bottom: 1px solid rgba(239, 68, 68, 0.3);
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
        }

        .tax-panel-nav button {
            padding: 6px 16px;
            font-size: 12px;
            background: linear-gradient(135deg, #dc2626, #b91c1c);
            border: none;
            border-radius: 6px;
            color: #fff;
            cursor: pointer;
            font-weight: bold;
            transition: all 0.2s;
        }

        .tax-panel-nav button:hover {
            background: linear-gradient(135deg, #ef4444, #dc2626);
            transform: scale(1.02);
        }

        .tax-panel-nav .position {
            font-size: 13px;
            color: #fca5a5;
            min-width: 80px;
            text-align: center;
            font-weight: bold;
        }

        .tax-panel-body {
            flex: 1;
            overflow-y: auto;
            padding: 10px;
        }

        .tax-property-card {
            background: rgba(127, 29, 29, 0.2);
            border: 1px solid rgba(239, 68, 68, 0.3);
            border-radius: 8px;
            padding: 12px;
            padding-right: 36px;
            margin-bottom: 8px;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
        }

        .tax-add-to-list-btn {
            position: absolute;
            right: 8px;
            top: 50%;
            transform: translateY(-50%);
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background: rgba(34, 197, 94, 0.2);
            border: 1px solid #22c55e;
            color: #22c55e;
            font-size: 16px;
            font-weight: bold;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.2s;
            line-height: 1;
        }

        .tax-add-to-list-btn:hover {
            background: rgba(34, 197, 94, 0.4);
            transform: translateY(-50%) scale(1.1);
        }

        .tax-add-to-list-btn.in-list {
            background: rgba(239, 68, 68, 0.2);
            border: 1px solid #ef4444;
            color: #ef4444;
        }

        .tax-add-to-list-btn.in-list:hover {
            background: rgba(239, 68, 68, 0.4);
        }

        .tax-property-card:hover {
            background: rgba(127, 29, 29, 0.4);
            border-color: #ef4444;
        }

        .tax-property-card.active {
            background: rgba(239, 68, 68, 0.3);
            border-color: #ef4444;
            box-shadow: 0 0 10px rgba(239, 68, 68, 0.3);
        }

        .tax-property-card .address {
            font-size: 13px;
            font-weight: 600;
            color: #fca5a5;
            margin-bottom: 4px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .tax-property-card .location {
            font-size: 11px;
            color: #f87171;
            margin-bottom: 6px;
        }

        .tax-property-card .details {
            display: flex;
            gap: 12px;
            font-size: 10px;
        }

        .tax-property-card .details .due {
            color: #fca5a5;
            font-weight: 700;
        }

        .tax-property-card .details .years {
            color: #f87171;
        }

        .tax-property-card .details .acres {
            color: #fb923c;
        }

        /* Tax Sale Panel (Left Side - Blue Theme) */
        .tax-sale-panel {
            position: fixed;
            left: 0;
            top: 70px;
            width: 280px;
            height: calc(100vh - 70px);
            background: linear-gradient(180deg, #0a1628 0%, #0d0d0d 100%);
            border-right: 2px solid #3b82f6;
            z-index: 1502;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
            overflow: hidden;
        }

        .tax-sale-panel.active {
            transform: translateX(0);
        }

        .tax-sale-panel-header {
            padding: 10px 15px;
            border-bottom: 2px solid #3b82f6;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, #1e3a8a 0%, #1e40af 100%);
        }

        .tax-sale-panel-header .title {
            font-size: 14px;
            font-weight: 700;
            color: #93c5fd;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .tax-sale-panel-header .actions {
            display: flex;
            gap: 6px;
        }

        .tax-sale-panel-header .actions button {
            padding: 4px 8px;
            font-size: 11px;
            background: rgba(59, 130, 246, 0.2);
            border: 1px solid #3b82f6;
            border-radius: 4px;
            color: #93c5fd;
            cursor: pointer;
            transition: all 0.2s;
        }

        .tax-sale-panel-header .actions button:hover {
            background: rgba(59, 130, 246, 0.4);
        }

        /* Quick filter buttons for tax sale */
        .tax-sale-quick-filter {
            padding: 2px 6px;
            font-size: 9px;
            background: rgba(100, 100, 100, 0.2);
            border: 1px solid #555;
            border-radius: 3px;
            color: #aaa;
            cursor: pointer;
            transition: all 0.15s;
        }
        .tax-sale-quick-filter:hover {
            background: rgba(59, 130, 246, 0.2);
            border-color: #3b82f6;
            color: #93c5fd;
        }
        .tax-sale-quick-filter.active {
            background: rgba(34, 197, 94, 0.3);
            border-color: #22c55e;
            color: #86efac;
        }

        .tax-sale-panel-nav {
            padding: 8px 12px;
            background: rgba(30, 58, 138, 0.3);
            border-bottom: 1px solid rgba(59, 130, 246, 0.3);
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
        }

        .tax-sale-panel-nav button {
            padding: 6px 16px;
            font-size: 12px;
            background: linear-gradient(135deg, #2563eb, #1d4ed8);
            border: none;
            border-radius: 6px;
            color: #fff;
            cursor: pointer;
            font-weight: bold;
            transition: all 0.2s;
        }

        .tax-sale-panel-nav button:hover {
            background: linear-gradient(135deg, #3b82f6, #2563eb);
            transform: scale(1.02);
        }

        .tax-sale-panel-nav .position {
            font-size: 13px;
            color: #93c5fd;
            min-width: 80px;
            text-align: center;
            font-weight: bold;
        }

        .tax-sale-panel-body {
            flex: 1;
            overflow-y: auto;
            padding: 10px;
        }

        .tax-sale-property-card {
            background: rgba(30, 58, 138, 0.2);
            border: 1px solid rgba(59, 130, 246, 0.3);
            border-radius: 8px;
            padding: 12px;
            margin-bottom: 8px;
            cursor: pointer;
            transition: all 0.2s;
            position: relative;
        }

        .tax-sale-property-card:hover {
            background: rgba(30, 58, 138, 0.4);
            border-color: #3b82f6;
        }

        .tax-sale-property-card.active {
            background: rgba(59, 130, 246, 0.3);
            border-color: #3b82f6;
            box-shadow: 0 0 10px rgba(59, 130, 246, 0.3);
        }

        .tax-sale-property-card .address {
            font-size: 13px;
            font-weight: 600;
            color: #93c5fd;
            margin-bottom: 4px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .tax-sale-property-card .location {
            font-size: 11px;
            color: #60a5fa;
            margin-bottom: 6px;
        }

        .tax-sale-property-card .details {
            display: flex;
            gap: 12px;
            font-size: 10px;
        }

        .tax-sale-property-card .details .due {
            color: #fbbf24;
            font-weight: 700;
        }

        .tax-sale-property-card .details .parcel {
            color: #60a5fa;
        }

        .tax-sale-property-card .details .source {
            color: #34d399;
        }

        .tax-sale-property-card .details .sale-year {
            color: #f472b6;
            font-weight: 600;
        }

        /* Multi-Owner Panel (Left Side - Orange Theme) */
        .multi-owner-panel {
            position: fixed;
            left: 0;
            top: 70px;
            width: 320px;
            height: calc(100vh - 70px);
            background: linear-gradient(180deg, #1a0f00 0%, #0d0d0d 100%);
            border-right: 2px solid #f59e0b;
            z-index: 9000;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
            overflow: hidden;
        }

        .multi-owner-panel.active {
            transform: translateX(0);
        }

        .multi-owner-panel.minimized {
            width: 48px;
        }
        .multi-owner-panel.minimized .multi-owner-panel-header .title,
        .multi-owner-panel.minimized .multi-owner-panel-header .actions button:not(#minimizeMultiOwnerBtn),
        .multi-owner-panel.minimized .multi-owner-panel-body,
        .multi-owner-panel.minimized > div:not(.multi-owner-panel-header) {
            display: none;
        }
        .multi-owner-panel.minimized .multi-owner-panel-header {
            flex-direction: column;
            padding: 8px;
        }
        .multi-owner-panel.minimized .multi-owner-panel-header .actions {
            margin-top: 0;
        }

        .multi-owner-panel-header {
            padding: 10px 15px;
            border-bottom: 2px solid #f59e0b;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, #92400e 0%, #78350f 100%);
        }

        .multi-owner-panel-header .title {
            font-size: 14px;
            font-weight: 700;
            color: #fcd34d;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .multi-owner-panel-header .actions {
            display: flex;
            gap: 6px;
        }

        .multi-owner-panel-header .actions button {
            padding: 4px 8px;
            font-size: 11px;
            background: rgba(245, 158, 11, 0.2);
            border: 1px solid #f59e0b;
            border-radius: 4px;
            color: #fcd34d;
            cursor: pointer;
            transition: all 0.2s;
        }

        .multi-owner-panel-header .actions button:hover {
            background: rgba(245, 158, 11, 0.4);
        }

        .multi-owner-panel-body {
            flex: 1;
            overflow-y: auto;
            padding: 10px;
        }

        .multi-owner-card {
            background: rgba(146, 64, 14, 0.2);
            border: 1px solid rgba(245, 158, 11, 0.3);
            border-radius: 8px;
            margin-bottom: 10px;
            overflow: hidden;
        }

        .multi-owner-card-header {
            background: rgba(0, 0, 0, 0.4);
            padding: 10px 12px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            border-bottom: 1px solid rgba(245, 158, 11, 0.2);
        }

        .multi-owner-card-header .owner-name {
            font-size: 13px;
            font-weight: 600;
            color: #fff;
        }

        .multi-owner-card-header .owner-phone {
            font-size: 11px;
            color: #ec4899;
            font-family: monospace;
        }

        .multi-owner-card-props {
            padding: 8px;
        }

        .multi-owner-prop-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 10px;
            margin-bottom: 4px;
            background: rgba(0, 0, 0, 0.3);
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .multi-owner-prop-item:hover {
            background: rgba(245, 158, 11, 0.2);
        }

        .multi-owner-prop-item .prop-address {
            font-size: 12px;
            color: #fff;
            font-weight: 500;
        }

        .multi-owner-prop-item .prop-city {
            font-size: 10px;
            color: var(--text-muted);
        }

        .multi-owner-prop-item .prop-acres {
            font-size: 11px;
            color: var(--primary);
        }

        .multi-owner-prop-item .prop-value {
            font-size: 10px;
            color: #888;
        }

        /* Live Terminal Panel (Bottom Left) */
        .terminal-panel {
            position: fixed;
            left: 0;
            top: 70px; /* Below header */
            width: 380px;
            height: calc(100vh - 70px);
            background: var(--dark);
            border-right: 1px solid var(--border);
            z-index: 1500;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
        }

        .terminal-panel.active {
            transform: translateX(0);
        }

        .terminal-header {
            padding: 10px 15px;
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: var(--card);
        }

        .terminal-title {
            font-weight: 600;
            font-size: 13px;
            display: flex;
            align-items: center;
            gap: 8px;
            color: var(--primary);
        }

        .terminal-actions {
            display: flex;
            gap: 5px;
        }

        .terminal-actions button {
            background: var(--border);
            border: none;
            color: var(--text);
            width: 26px;
            height: 26px;
            border-radius: 6px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            transition: all 0.2s;
        }

        .terminal-actions button:hover {
            background: var(--primary);
            color: var(--dark);
        }

        .terminal-body {
            flex: 1;
            overflow-y: auto;
            padding: 10px 12px;
            font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
            font-size: 11px;
            line-height: 1.6;
            color: #888;
            background: #0a0a12;
        }

        .terminal-body::-webkit-scrollbar {
            width: 6px;
        }

        .terminal-body::-webkit-scrollbar-track {
            background: transparent;
        }

        .terminal-body::-webkit-scrollbar-thumb {
            background: var(--border);
            border-radius: 3px;
        }

        .terminal-toggle-btn-old {
            display: none; /* Replaced by grouped buttons */
        }

        .terminal-toggle-btn.hidden {
            display: none;
        }
        
        /* AI Comps Panel (Above Terminal) */
        .ai-comps-panel {
            position: fixed;
            left: 0;
            top: 70px;
            width: 380px;
            height: calc(100vh - 70px);
            background: var(--dark);
            border-right: 2px solid #f97316;
            z-index: 2000;
            display: flex;
            flex-direction: column;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
            box-shadow: 5px 0 20px rgba(0,0,0,0.5);
        }
        
        .ai-comps-panel.active {
            transform: translateX(0);
        }
        
        .ai-comps-header {
            padding: 10px 15px;
            border-bottom: 1px solid #f97316;
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: linear-gradient(135deg, rgba(249, 115, 22, 0.2) 0%, var(--card) 100%);
            flex-shrink: 0;
            min-height: 46px;
        }
        
        .ai-comps-title {
            font-weight: 600;
            font-size: 13px;
            display: flex;
            align-items: center;
            gap: 8px;
            color: #f97316;
        }
        
        .ai-comps-actions {
            display: flex;
            gap: 5px;
        }
        
        .ai-comps-actions button {
            background: var(--border);
            border: none;
            color: var(--text);
            width: 26px;
            height: 26px;
            border-radius: 6px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            transition: all 0.2s;
        }
        
        .ai-comps-actions button:hover {
            background: #f97316;
            color: var(--dark);
        }
        
        .ai-comps-stats {
            padding: 10px 15px;
            background: linear-gradient(135deg, rgba(249, 115, 22, 0.1) 0%, transparent 100%);
            border-bottom: 1px solid var(--border);
            display: flex;
            gap: 15px;
            flex-wrap: wrap;
            flex-shrink: 0;
        }
        
        .ai-stat-box {
            flex: 1;
            min-width: 80px;
            text-align: center;
        }
        
        .ai-stat-value {
            font-size: 18px;
            font-weight: bold;
            color: #f97316;
        }
        
        .ai-stat-label {
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
        }
        
        .ai-comps-body {
            flex: 1;
            overflow-y: auto;
            padding: 0;
        }
        
        .ai-comp-item {
            padding: 10px 15px;
            border-bottom: 1px solid var(--border);
            cursor: pointer;
            transition: background 0.2s;
        }
        
        .ai-comp-item:hover {
            background: rgba(249, 115, 22, 0.1);
        }
        
        .ai-comp-item.selected {
            background: rgba(249, 115, 22, 0.2);
            border-left: 3px solid #f97316;
        }
        
        .ai-comp-address {
            font-size: 12px;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 4px;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        
        .ai-comp-details {
            display: flex;
            gap: 10px;
            font-size: 11px;
            color: var(--text-muted);
        }
        
        .ai-comp-price {
            color: #22c55e;
            font-weight: bold;
        }
        
        .ai-comp-ppa {
            color: #f97316;
            font-weight: bold;
        }
        
        .ai-comp-source {
            font-size: 9px;
            padding: 2px 5px;
            border-radius: 3px;
            background: var(--border);
        }
        
        .ai-comp-source.sale {
            background: rgba(34, 197, 94, 0.2);
            color: #22c55e;
        }
        
        .ai-comp-source.assessed {
            background: rgba(249, 115, 22, 0.2);
            color: #f97316;
        }
        
        .ai-sort-btn {
            background: var(--border);
            border: none;
            color: var(--text-muted);
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .ai-sort-btn:hover {
            background: rgba(249, 115, 22, 0.3);
            color: #f97316;
        }
        
        .ai-sort-btn.active {
            background: #f97316;
            color: #000;
            font-weight: bold;
        }
        
        .ai-comps-toggle-btn-old {
            display: none; /* Replaced by grouped buttons */
        }
        
        .ai-comps-toggle-btn {
            display: none; /* Replaced by grouped buttons in left-toggle-container */
        }

        .found-parcels-header {
            padding: 12px 15px;
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-between;
            align-items: center;
            background: var(--card);
        }

        .found-parcels-title {
            font-weight: 600;
            font-size: 14px;
            display: flex;
            align-items: center;
            gap: 8px;
            color: #00aaff;
        }

        .found-parcels-count {
            color: var(--text-muted);
            font-weight: normal;
        }

        .found-parcels-actions {
            display: flex;
            gap: 5px;
        }

        .found-parcels-actions button {
            background: var(--border);
            border: none;
            color: var(--text);
            width: 28px;
            height: 28px;
            border-radius: 6px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
        }

        .found-parcels-actions button:hover {
            background: var(--primary);
            color: var(--dark);
        }

        .found-parcels-body {
            flex: 1;
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }

        .found-parcels-list {
            flex: 1;
            overflow-y: auto;
        }

        .found-parcels-empty {
            padding: 30px;
            text-align: center;
            color: var(--text-muted);
            font-size: 12px;
        }

        .found-parcel-item {
            padding: 10px 15px;
            border-bottom: 1px solid var(--border);
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 10px;
            transition: all 0.2s;
        }

        .found-parcel-item:hover {
            background: var(--card);
        }

        .found-parcel-item.selected {
            background: rgba(0, 170, 255, 0.15);
            border-left: 3px solid #00aaff;
        }

        .found-parcel-item.already-saved {
            background: rgba(0, 212, 170, 0.08);
            border-left: 3px solid #00d4aa;
        }

        .found-parcel-item.already-saved.selected {
            background: rgba(0, 212, 170, 0.2);
        }

        .saved-badge {
            font-size: 10px;
            margin-right: 2px;
        }

        .found-parcel-item input[type="checkbox"] {
            flex-shrink: 0;
        }

        .found-parcel-item-info {
            flex: 1;
            min-width: 0;
        }

        .found-parcel-item-address {
            font-size: 12px;
            font-weight: 500;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .found-parcel-item-meta {
            font-size: 10px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        .found-parcel-item-delete {
            background: #ef4444;
            border: none;
            color: #fff;
            cursor: pointer;
            padding: 4px 8px;
            border-radius: 4px;
            font-size: 12px;
            transition: all 0.2s;
            flex-shrink: 0;
        }

        .found-parcel-item-delete:hover {
            background: #dc2626;
        }
        
        .found-parcel-quick-save {
            background: #00d4aa;
            border: none;
            color: #000;
            cursor: pointer;
            padding: 4px 8px;
            font-size: 12px;
            border-radius: 4px;
            font-weight: bold;
            transition: all 0.2s;
            flex-shrink: 0;
        }
        
        .found-parcel-quick-save:hover {
            background: #00ffcc;
            transform: scale(1.05);
        }

        .found-parcels-details {
            height: 55%;
            overflow-y: auto;
            padding: 15px;
            background: var(--darker);
        }

        .found-details-empty {
            text-align: center;
            color: var(--text-muted);
            font-size: 12px;
            padding: 20px;
        }

        .found-details-section {
            margin-bottom: 15px;
        }

        .found-details-section-title {
            font-size: 11px;
            font-weight: 600;
            color: var(--primary);
            text-transform: uppercase;
            margin-bottom: 8px;
            padding-bottom: 5px;
            border-bottom: 1px solid var(--border);
        }

        .found-details-row {
            display: flex;
            justify-content: space-between;
            padding: 4px 0;
            font-size: 12px;
        }

        .found-details-label {
            color: var(--text-muted);
        }

        .found-details-value {
            font-weight: 500;
            text-align: right;
        }

        .found-details-actions {
            display: flex;
            gap: 8px;
            margin-top: 15px;
        }

        .found-details-btn {
            flex: 1;
            padding: 10px;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            font-size: 12px;
            font-weight: 500;
            transition: all 0.2s;
        }

        .found-details-btn-primary {
            background: var(--primary);
            color: var(--dark);
        }

        .found-details-btn-secondary {
            background: var(--card);
            color: var(--text);
            border: 1px solid var(--border);
        }

        .found-details-btn:hover {
            transform: translateY(-1px);
        }

        .found-parcels-toggle-btn {
            background: #00aaff;
            color: white;
            border: none;
            padding: 10px 8px;
            cursor: pointer;
            font-weight: bold;
            font-size: 11px;
            writing-mode: vertical-rl;
            text-orientation: mixed;
            border-bottom: 1px solid rgba(255,255,255,0.2);
        }

        .found-parcels-toggle-btn:hover {
            background: #0088cc;
        }
        
        /* Left Panel Toggle Buttons Container */
        .left-toggle-container {
            position: fixed;
            left: 0;
            top: 70px;
            display: flex;
            flex-direction: column;
            z-index: 1900;
            border-radius: 0 8px 8px 0;
            overflow: hidden;
            box-shadow: 2px 0 10px rgba(0,0,0,0.3);
            transition: left 0.3s ease, top 0.3s ease;
        }

        .left-toggle-container.panel-open {
            left: 380px;
        }

        .left-toggle-container.tax-panel-open {
            left: 280px;
        }

        /* Shift buttons down when soil legend is visible - position right below the legend */
        .left-toggle-container.soil-legend-open {
            top: 320px;
        }
        
        .left-toggle-container button {
            border: none;
            padding: 12px 8px;
            cursor: pointer;
            font-weight: bold;
            font-size: 11px;
            writing-mode: vertical-rl;
            text-orientation: mixed;
            border-bottom: 1px solid rgba(0,0,0,0.2);
            transition: background 0.2s;
        }
        
        .left-toggle-container button:last-child {
            border-bottom: none;
        }
        
        .left-toggle-btn-tax {
            background: #dc2626;
            color: white;
        }

        .left-toggle-btn-tax:hover {
            background: #b91c1c;
        }

        .left-toggle-btn-tax.active {
            background: #991b1b;
        }

        .left-toggle-btn-taxsale {
            background: #2563eb;
            color: white;
        }

        .left-toggle-btn-taxsale:hover {
            background: #1d4ed8;
        }

        .left-toggle-btn-taxsale.active {
            background: #1e40af;
        }

        .left-toggle-btn-found {
            background: #00aaff;
            color: white;
        }

        .left-toggle-btn-found:hover {
            background: #0088cc;
        }

        .left-toggle-btn-found.active {
            background: #0077aa;
        }
        
        .left-toggle-btn-ai {
            background: #f97316;
            color: white;
        }
        
        .left-toggle-btn-ai:hover {
            background: #ea580c;
        }
        
        .left-toggle-btn-ai.active {
            background: #c2410c;
        }
        
        .left-toggle-btn-terminal {
            background: #00d4aa;
            color: #000;
        }
        
        .left-toggle-btn-terminal:hover {
            background: #00b894;
        }
        
        .left-toggle-btn-terminal.active {
            background: #00a884;
        }

        /* Deal Analyzer Modal - Compact */
        .deal-section {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px;
            margin-bottom: 12px;
        }

        .deal-section-header {
            font-weight: 600;
            font-size: 13px;
            margin-bottom: 10px;
            padding-bottom: 6px;
            border-bottom: 1px solid var(--border);
        }

        .deal-label {
            display: block;
            font-size: 11px;
            color: var(--text-muted);
            margin-bottom: 3px;
        }

        .deal-input-group {
            display: flex;
            align-items: center;
            background: var(--darker);
            border: 1px solid var(--border);
            border-radius: 6px;
            overflow: hidden;
        }

        .deal-input-group span {
            padding: 6px 8px;
            background: var(--border);
            color: var(--text-muted);
            font-size: 11px;
        }

        .deal-input-group input {
            flex: 1;
            border: none;
            background: transparent;
            padding: 6px 8px;
            color: var(--text);
            font-size: 12px;
            min-width: 50px;
        }

        .deal-input-group input:focus {
            outline: none;
        }

        .deal-result-box {
            background: var(--darker);
            border-radius: 6px;
            padding: 8px;
            text-align: center;
        }

        .deal-result-label {
            font-size: 10px;
            color: var(--text-muted);
            margin-bottom: 2px;
        }

        .deal-result-value {
            font-size: 18px;
            font-weight: 700;
            color: var(--text);
        }

        .deal-result-sub {
            font-size: 10px;
            color: var(--text-muted);
        }

        .deal-result-highlight {
            background: linear-gradient(135deg, rgba(0, 212, 170, 0.2) 0%, rgba(0, 212, 170, 0.05) 100%);
            border: 1px solid var(--primary);
        }

        .deal-details {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
        }

        .deal-summary {
            padding: 10px 12px;
            cursor: pointer;
            font-weight: 600;
            font-size: 12px;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }

        .deal-summary::-webkit-details-marker {
            display: none;
        }

        .deal-summary::before {
            content: '▶';
            margin-right: 8px;
            font-size: 10px;
            transition: transform 0.2s;
        }

        details[open] .deal-summary::before {
            transform: rotate(90deg);
        }

        .deal-cost-box {
            background: var(--darker);
            border-radius: 6px;
            padding: 10px;
        }

        .deal-cost-title {
            font-weight: 600;
            font-size: 11px;
            margin-bottom: 8px;
            color: var(--primary);
        }

        .deal-cost-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 6px;
        }

        .deal-cost-grid label {
            display: flex;
            flex-direction: column;
            font-size: 10px;
            color: var(--text-muted);
        }

        .deal-cost-grid input {
            margin-top: 2px;
            padding: 4px 6px;
            border: 1px solid var(--border);
            border-radius: 4px;
            background: var(--card);
            color: var(--text);
            font-size: 11px;
            width: 100%;
        }

        .deal-cost-subtotal {
            margin-top: 8px;
            padding-top: 6px;
            border-top: 1px solid var(--border);
            font-size: 11px;
            font-weight: 600;
            text-align: right;
        }

        .deal-inline-label {
            display: flex;
            flex-direction: column;
            font-size: 10px;
            color: var(--text-muted);
        }

        .deal-inline-label input {
            margin-top: 2px;
            padding: 4px 6px;
            border: 1px solid var(--border);
            border-radius: 4px;
            background: var(--card);
            color: var(--text);
            font-size: 11px;
        }

        /* Advanced Search Modal */
        .search-section {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 10px;
            margin-bottom: 15px;
            overflow: hidden;
        }

        .search-section-header {
            padding: 12px 15px;
            background: var(--card-hover);
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-weight: 600;
            font-size: 14px;
        }

        .search-section-content {
            padding: 15px;
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
        }

        .search-section-content.collapsed { display: none; }

        .search-type-btn {
            flex: 1;
            padding: 10px 15px;
            background: var(--darker);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-muted);
            font-size: 13px;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .search-type-btn:hover {
            border-color: var(--primary);
            color: var(--text);
        }
        
        .search-type-btn.active {
            background: rgba(0, 212, 170, 0.15);
            border-color: var(--primary);
            color: var(--primary);
        }

        .search-field {
            display: flex;
            flex-direction: column;
            gap: 5px;
        }

        .search-field.full-width {
            grid-column: span 2;
        }

        .search-field label {
            font-size: 12px;
            color: var(--text-muted);
            font-weight: 500;
        }

        .search-field input,
        .search-field select {
            background: var(--darker);
            border: 1px solid var(--border);
            border-radius: 6px;
            padding: 8px 12px;
            color: var(--text);
            font-size: 13px;
            outline: none;
            transition: border-color 0.2s;
        }

        .search-field input:focus,
        .search-field select:focus {
            border-color: var(--primary);
        }

        .search-field-row {
            display: flex;
            gap: 10px;
        }

        .search-field-row input {
            flex: 1;
        }

        .search-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            grid-column: span 2;
        }

        .search-chip {
            background: var(--darker);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 6px 12px;
            font-size: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .search-chip:hover,
        .search-chip.active {
            border-color: var(--primary);
            background: rgba(0, 212, 170, 0.1);
            color: var(--primary);
        }

        .search-results-info {
            background: linear-gradient(135deg, rgba(0, 212, 170, 0.1) 0%, rgba(255, 107, 53, 0.1) 100%);
            border: 1px solid var(--border);
            border-radius: 10px;
            padding: 15px;
            margin-top: 15px;
            text-align: center;
        }

        .search-results-count {
            font-size: 24px;
            font-weight: 700;
            color: var(--primary);
        }

        /* Hide Leaflet attribution */
        .leaflet-control-attribution {
            display: none !important;
        }

        /* Leaflet popup override */
        .leaflet-popup-content-wrapper {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 12px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.4);
        }

        .leaflet-popup-content { margin: 0; color: var(--text); min-width: 260px; }
        .soil-popup .leaflet-popup-content { min-width: auto !important; max-width: 120px !important; }
        .soil-popup .leaflet-popup-content-wrapper { padding: 8px !important; }
        .leaflet-popup-tip { background: var(--card); border: 1px solid var(--border); }
        
        /* Left-positioned popup - tip points right */
        .left-side-popup .leaflet-popup-tip-container {
            left: auto;
            right: -20px;
            margin-left: 0;
            width: 20px;
        }
        .left-side-popup .leaflet-popup-tip {
            margin: 0;
            transform: rotate(90deg);
            margin-top: 10px;
        }

        .popup-content { padding: 15px; }
        .popup-title { font-weight: 700; font-size: 14px; margin-bottom: 10px; color: var(--primary); }
        .popup-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 12px; border-bottom: 1px solid var(--border); }
        .popup-row:last-of-type { border: none; }
        .popup-label { color: var(--text-muted); }
        .popup-value { font-weight: 600; text-align: right; max-width: 60%; }
        .popup-actions { display: flex; gap: 6px; margin-top: 12px; }
        .popup-btn { flex: 1; padding: 8px; border: none; border-radius: 6px; font-size: 11px; font-weight: 600; cursor: pointer; }
        .popup-btn-primary { background: var(--primary); color: var(--dark); }
        .popup-btn-ghost { background: var(--darker); color: var(--text); }

        /* Smart Filters Toolbar */
        /* Compact Toolbar */
        .compact-toolbar {
            background: var(--dark);
            border-bottom: 1px solid var(--border);
            padding: 8px 15px;
            display: flex;
            align-items: center;
            gap: 10px;
            flex-wrap: wrap;
            z-index: 99;
        }

        .toolbar-section {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .toolbar-label {
            font-size: 12px;
            font-weight: 600;
            color: var(--primary);
            white-space: nowrap;
        }

        .toolbar-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
        }

        .toolbar-chip {
            display: flex;
            align-items: center;
            gap: 4px;
            padding: 4px 8px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 12px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
            white-space: nowrap;
        }

        .toolbar-chip:hover {
            border-color: var(--primary);
        }

        .toolbar-chip input {
            display: none;
        }

        .toolbar-chip:has(input:checked) {
            background: rgba(0, 212, 170, 0.2);
            border-color: var(--primary);
            color: var(--primary);
        }

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

        .filter-dropdown-btn {
            background: var(--card) !important;
            border: 1px solid var(--border) !important;
            padding: 6px 12px !important;
        }

        .filter-dropdown-btn:hover {
            border-color: var(--primary) !important;
        }

        .filter-dropdown-menu {
            position: absolute;
            top: 100%;
            left: 0;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 10px;
            min-width: 260px;
            z-index: 2000;
            display: none;
            box-shadow: 0 8px 24px rgba(0,0,0,0.4);
            margin-top: 4px;
        }

        .filter-dropdown-menu.active {
            display: block;
        }

        .filter-menu-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px 15px;
            border-bottom: 1px solid var(--border);
            font-weight: 600;
            font-size: 13px;
        }

        .filter-clear-btn {
            background: none;
            border: none;
            color: var(--error);
            font-size: 11px;
            cursor: pointer;
        }

        .filter-clear-btn:hover {
            text-decoration: underline;
        }

        .filter-menu-items {
            padding: 8px 0;
            max-height: 300px;
            overflow-y: auto;
        }

        .filter-menu-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 15px;
            cursor: pointer;
            transition: background 0.15s;
            font-size: 13px;
        }

        .filter-menu-item:hover {
            background: rgba(0, 212, 170, 0.1);
        }

        .filter-menu-item input[type="checkbox"] {
            width: 16px;
            height: 16px;
            accent-color: var(--primary);
        }

        .filter-menu-footer {
            display: flex;
            gap: 8px;
            padding: 12px 15px;
            border-top: 1px solid var(--border);
            justify-content: flex-end;
        }

        .toolbar-btn {
            padding: 5px 10px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text);
            font-size: 11px;
            cursor: pointer;
            transition: all 0.2s;
            white-space: nowrap;
        }

        .toolbar-btn:hover {
            border-color: var(--primary);
        }

        .toolbar-btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        .toolbar-btn-apply {
            background: var(--primary);
            border-color: var(--primary);
            color: var(--dark);
            font-weight: 600;
        }

        .toolbar-btn-clear {
            color: var(--text-muted);
        }

        .toolbar-btn-start {
            background: var(--primary);
            border-color: var(--primary);
            color: var(--dark);
        }

        .toolbar-btn-stop {
            background: var(--accent);
            border-color: var(--accent);
            color: white;
        }

        .toolbar-btn-icon {
            padding: 5px 8px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 6px;
            cursor: pointer;
            font-size: 12px;
        }

        .toolbar-btn-icon:hover {
            border-color: var(--primary);
        }

        .toolbar-divider {
            width: 1px;
            height: 24px;
            background: var(--border);
        }

        .toolbar-results, .toolbar-status {
            font-size: 11px;
            color: var(--text-muted);
        }

        .ai-inline-progress, .ai-inline-results {
            font-size: 11px;
            color: var(--text-muted);
        }

        /* Scanner Settings Popup */
        .scanner-settings-popup {
            position: absolute;
            top: 120px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--dark);
            border: 1px solid var(--border);
            border-radius: 10px;
            z-index: 2000;
            min-width: 320px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.5);
        }

        .popup-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 10px 15px;
            border-bottom: 1px solid var(--border);
            font-weight: 600;
            font-size: 13px;
        }

        .popup-header button {
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            font-size: 16px;
        }

        .popup-body {
            padding: 15px;
        }

        .settings-row {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 10px;
        }

        .settings-row label {
            font-size: 12px;
            color: var(--text-muted);
            min-width: 80px;
        }

        .settings-row input {
            padding: 5px 8px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 5px;
            color: var(--text);
            font-size: 12px;
        }

        .settings-checks {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin: 10px 0;
        }

        .settings-checks label {
            font-size: 11px;
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 4px;
        }

        .settings-presets {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid var(--border);
        }

        .preset-btn {
            padding: 4px 8px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 10px;
            font-size: 10px;
            cursor: pointer;
        }

        .preset-btn:hover {
            border-color: var(--primary);
        }

        /* Live scan indicator */
        .live-scan-indicator {
            display: flex;
            align-items: center;
            gap: 5px;
            font-size: 11px;
            color: var(--success);
        }

        .scan-pulse {
            width: 8px;
            height: 8px;
            background: var(--success);
            border-radius: 50%;
            animation: pulse 1.2s infinite;
        }

        @keyframes pulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.5; transform: scale(0.8); }
        }

        @keyframes gps-pulse {
            0% { box-shadow: 0 0 0 0 rgba(66, 133, 244, 0.7); }
            70% { box-shadow: 0 0 0 15px rgba(66, 133, 244, 0); }
            100% { box-shadow: 0 0 0 0 rgba(66, 133, 244, 0); }
        }
        .gps-marker-pulse {
            animation: gps-pulse 2s infinite;
        }

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

        .filter-divider {
            width: 1px;
            height: 35px;
            background: var(--border);
            margin: 0 5px;
        }

        .smart-filter {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 8px 12px;
            background: var(--darker);
            border: 1px solid var(--border);
            border-radius: 20px;
            cursor: pointer;
            transition: all 0.2s;
            font-size: 12px;
            position: relative;
        }

        .smart-filter:hover {
            border-color: var(--primary);
            background: var(--card);
        }

        .smart-filter:has(input:checked) {
            background: rgba(0, 212, 170, 0.15);
            border-color: var(--primary);
        }

        .smart-filter input[type="checkbox"] {
            display: none;
        }

        .filter-icon {
            font-size: 14px;
        }

        .filter-label {
            font-weight: 500;
            color: var(--text);
        }

        .smart-filter:has(input:checked) .filter-label {
            color: var(--primary);
        }

        .filter-tooltip {
            display: none;
            position: absolute;
            bottom: 100%;
            left: 50%;
            transform: translateX(-50%);
            background: var(--darker);
            color: var(--text-muted);
            font-size: 11px;
            padding: 5px 10px;
            border-radius: 5px;
            white-space: nowrap;
            margin-bottom: 5px;
            border: 1px solid var(--border);
            z-index: 100;
        }

        .smart-filter:hover .filter-tooltip {
            display: block;
        }

        .proximity-filter {
            display: flex;
            flex-direction: column;
            gap: 5px;
        }

        .proximity-slider {
            display: none;
            align-items: center;
            gap: 8px;
            padding: 5px 10px;
            background: var(--darker);
            border-radius: 15px;
            margin-left: 20px;
        }

        .proximity-filter:has(input:checked) .proximity-slider {
            display: flex;
        }

        .slider {
            width: 80px;
            height: 4px;
            -webkit-appearance: none;
            appearance: none;
            background: var(--border);
            border-radius: 2px;
            cursor: pointer;
        }

        .slider::-webkit-slider-thumb {
            -webkit-appearance: none;
            appearance: none;
            width: 14px;
            height: 14px;
            background: var(--primary);
            border-radius: 50%;
            cursor: pointer;
        }

        .slider::-moz-range-thumb {
            width: 14px;
            height: 14px;
            background: var(--primary);
            border-radius: 50%;
            cursor: pointer;
            border: none;
        }

        .slider-value {
            font-size: 11px;
            font-weight: 600;
            color: var(--primary);
            min-width: 45px;
        }

        .filter-actions {
            display: flex;
            gap: 10px;
            align-items: center;
            margin-left: auto;
        }

        .filter-btn {
            padding: 8px 16px;
            border-radius: 20px;
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            border: none;
        }

        .filter-btn-apply {
            background: var(--primary);
            color: var(--dark);
        }

        .filter-btn-apply:hover {
            background: var(--primary-dark);
            transform: scale(1.02);
        }

        .filter-btn-clear {
            background: transparent;
            color: var(--text-muted);
            border: 1px solid var(--border);
        }

        .filter-btn-clear:hover {
            border-color: var(--error);
            color: var(--error);
        }

        .filter-btn-hide {
            background: var(--accent);
            color: white;
        }

        .filter-btn-hide:hover {
            background: #e85d04;
        }

        .filter-btn-hide.showing-all {
            background: #6c757d;
        }

        .filter-results {
            font-size: 12px;
            color: var(--text-muted);
            padding: 5px 10px;
            background: var(--darker);
            border-radius: 10px;
        }

        .filter-results.has-results {
            color: var(--success);
            background: rgba(63, 185, 80, 0.1);
        }

        .filter-results.filtering {
            color: var(--warning);
        }

        /* AI Structure Scanner - Compact Inline Styles */
        .ai-scanner-compact {
            display: flex;
            align-items: center;
        }

        .ai-scanner-row {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 6px 12px;
            background: linear-gradient(135deg, rgba(138, 43, 226, 0.15) 0%, rgba(138, 43, 226, 0.05) 100%);
            border: 1px solid rgba(138, 43, 226, 0.3);
            border-radius: 20px;
        }

        .ai-scanner-label {
            font-size: 12px;
            font-weight: 600;
            color: #a855f7;
            white-space: nowrap;
        }

        .ai-scan-btn-compact {
            padding: 5px 12px;
            border: none;
            border-radius: 15px;
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            background: linear-gradient(135deg, #a855f7 0%, #7c3aed 100%);
            color: white;
        }

        .ai-scan-btn-compact:disabled {
            background: var(--darker);
            color: var(--text-muted);
            cursor: not-allowed;
        }

        .ai-scan-btn-compact:not(:disabled):hover {
            transform: scale(1.05);
            box-shadow: 0 2px 10px rgba(138, 43, 226, 0.4);
        }

        .ai-scan-btn-compact.ai-scan-stop {
            background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
            padding: 5px 8px;
        }

        .ai-scan-inline-progress {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .ai-mini-progress-bar {
            width: 60px;
            height: 4px;
            background: var(--border);
            border-radius: 2px;
            overflow: hidden;
        }

        .ai-mini-progress-fill {
            height: 100%;
            background: linear-gradient(90deg, #a855f7, #00d4aa);
            width: 0%;
            transition: width 0.3s;
        }

        .ai-scan-inline-stats {
            font-size: 10px;
            color: var(--text-muted);
            font-weight: 600;
            min-width: 35px;
        }

        .ai-scan-inline-results {
            display: flex;
            gap: 8px;
            font-size: 11px;
            font-weight: 600;
        }

        .ai-result-good {
            color: var(--success);
        }

        .ai-result-bad {
            color: var(--accent);
        }

        /* Live Map Scanner Styles */
        .live-scanner-section {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        .live-scanner-row {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 6px 12px;
            background: linear-gradient(135deg, rgba(0, 212, 170, 0.15) 0%, rgba(0, 212, 170, 0.05) 100%);
            border: 1px solid rgba(0, 212, 170, 0.3);
            border-radius: 20px;
        }

        .live-scanner-label {
            font-size: 12px;
            font-weight: 600;
            color: var(--primary);
            white-space: nowrap;
        }

        .live-scan-btn {
            padding: 5px 12px;
            border: none;
            border-radius: 15px;
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            background: linear-gradient(135deg, #00d4aa 0%, #00b894 100%);
            color: var(--dark);
        }

        .live-scan-btn:hover {
            transform: scale(1.05);
            box-shadow: 0 2px 10px rgba(0, 212, 170, 0.4);
        }

        .live-scan-btn.live-scan-stop {
            background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
            color: white;
        }

        .live-scan-btn.scanning {
            animation: pulse-green 1.5s infinite;
        }

        @keyframes pulse-green {
            0%, 100% { box-shadow: 0 0 5px rgba(0, 212, 170, 0.5); }
            50% { box-shadow: 0 0 15px rgba(0, 212, 170, 0.8); }
        }

        .live-scan-settings-btn {
            padding: 5px 8px;
            border: none;
            border-radius: 10px;
            background: var(--darker);
            color: var(--text-muted);
            cursor: pointer;
            font-size: 12px;
        }

        .live-scan-settings-btn:hover {
            background: var(--border);
            color: var(--text);
        }

        .live-scan-status {
            font-size: 11px;
            color: var(--text-muted);
            margin-left: auto;
        }

        .live-scan-status.active {
            color: var(--success);
        }

        .live-scan-settings {
            background: var(--darker);
            border-radius: 10px;
            padding: 12px;
            margin-top: 5px;
        }

        .live-scan-settings-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 12px;
            margin-bottom: 10px;
        }

        .live-scan-setting label {
            display: block;
            font-size: 10px;
            color: var(--text-muted);
            margin-bottom: 4px;
        }

        .live-scan-setting input {
            width: 100%;
            padding: 6px 8px;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: var(--card);
            color: var(--text);
            font-size: 12px;
        }

        .range-inputs {
            display: flex;
            align-items: center;
            gap: 5px;
        }

        .range-inputs input {
            width: 60px;
        }

        .range-inputs span {
            font-size: 10px;
            color: var(--text-muted);
        }

        .live-scan-checkboxes {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-bottom: 10px;
        }

        .live-scan-check {
            display: flex;
            align-items: center;
            gap: 5px;
            font-size: 11px;
            color: var(--text);
            cursor: pointer;
        }

        .live-scan-check input {
            width: 14px;
            height: 14px;
        }

        .live-scan-presets {
            display: flex;
            gap: 8px;
        }

        .preset-btn {
            padding: 5px 10px;
            border: 1px solid var(--border);
            border-radius: 12px;
            background: var(--card);
            color: var(--text-muted);
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .preset-btn:hover {
            border-color: var(--primary);
            color: var(--primary);
        }

        /* Live Scan Status Indicator */
        .live-scan-indicator {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 4px 10px;
            background: rgba(0, 212, 170, 0.15);
            border-radius: 12px;
            margin-left: 5px;
        }

        .scan-pulse {
            width: 8px;
            height: 8px;
            background: var(--success);
            border-radius: 50%;
            animation: scan-pulse 1.2s infinite;
        }

        @keyframes scan-pulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.5; transform: scale(0.8); }
        }

        .scan-text {
            font-size: 10px;
            font-weight: 600;
            color: var(--success);
        }

        /* Presets Section */
        .live-scan-presets-section {
            border-top: 1px solid var(--border);
            padding-top: 10px;
            margin-top: 5px;
        }

        .presets-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 8px;
        }

        .presets-header span {
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .save-preset-btn {
            padding: 4px 10px;
            border: 1px solid var(--primary);
            border-radius: 10px;
            background: transparent;
            color: var(--primary);
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .save-preset-btn:hover {
            background: var(--primary);
            color: var(--dark);
        }

        .saved-presets {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-top: 8px;
        }

        .saved-preset-btn {
            display: flex;
            align-items: center;
            gap: 4px;
            padding: 4px 8px;
            border: 1px solid var(--accent);
            border-radius: 10px;
            background: rgba(255, 107, 53, 0.1);
            color: var(--accent);
            font-size: 10px;
            cursor: pointer;
            transition: all 0.2s;
        }

        .saved-preset-btn:hover {
            background: var(--accent);
            color: white;
        }

        .saved-preset-btn .delete-preset {
            margin-left: 4px;
            opacity: 0.6;
        }

        .saved-preset-btn .delete-preset:hover {
            opacity: 1;
        }

        /* Scan Legend */
        .scan-legend {
            position: absolute;
            top: 10px;
            left: 10px;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 8px 12px;
            font-size: 11px;
            z-index: 500;
            display: none;
        }

        .scan-legend.visible {
            display: block;
        }

        .scan-legend-title {
            font-weight: 600;
            margin-bottom: 6px;
            color: var(--text);
        }

        .scan-legend-item {
            display: flex;
            align-items: center;
            gap: 8px;
            margin: 4px 0;
            color: var(--text-muted);
        }

        .scan-legend-color {
            width: 16px;
            height: 16px;
            border-radius: 3px;
            border: 1px solid;
        }

        .scan-legend-color.has-data {
            background: rgba(0, 212, 170, 0.3);
            border-color: #00d4aa;
        }

        .scan-legend-color.no-data {
            background: rgba(102, 102, 102, 0.2);
            border-color: #666;
            border-style: dashed;
        }

        /* Live Scan List Items */
        .live-scan-item {
            display: flex;
            align-items: center;
            padding: 8px 12px;
            border-bottom: 1px solid #333;
            cursor: pointer;
            transition: background 0.2s;
        }

        .live-scan-item:hover {
            background: rgba(0, 170, 255, 0.1);
        }

        .live-scan-item.selected {
            background: rgba(0, 212, 170, 0.1);
        }

        .live-scan-item input[type="checkbox"] {
            margin-right: 10px;
            cursor: pointer;
        }

        .live-scan-item-info {
            flex: 1;
            min-width: 0;
        }

        .live-scan-item-address {
            font-size: 12px;
            font-weight: 500;
            color: var(--text);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .live-scan-item-details {
            font-size: 10px;
            color: var(--text-muted);
            margin-top: 2px;
        }

        .live-scan-item-delete {
            background: none;
            border: none;
            color: #666;
            cursor: pointer;
            padding: 4px;
            font-size: 12px;
            opacity: 0;
            transition: opacity 0.2s;
        }

        .live-scan-item:hover .live-scan-item-delete {
            opacity: 1;
        }

        .live-scan-item-delete:hover {
            color: #ff6b6b;
        }

        /* Adjust main height for compact toolbar (header 66px + toolbar ~45px) */
        .main { display: flex; height: calc(100vh - 66px - 50px); overflow: hidden; }
        
        .map-container { flex: 1; position: relative; height: 100%; overflow: hidden; }
        
        /* Elevation tooltip styling */
        .elev-tooltip {
            background: rgba(0, 0, 0, 0.8) !important;
            border: 1px solid #00aaff !important;
            color: #fff !important;
            font-weight: bold !important;
            padding: 4px 8px !important;
            border-radius: 4px !important;
            font-size: 11px !important;
        }
        .elev-tooltip::before {
            border-top-color: #00aaff !important;
        }
        
        /* Call Mode Panel - Bottom Bar */
        .call-mode-panel {
            position: fixed;
            bottom: 10px;
            left: 0;
            right: 0;
            background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
            border-top: 3px solid #22c55e;
            border-radius: 0 0 8px 8px;
            box-shadow: 0 -5px 30px rgba(0, 0, 0, 0.5);
            z-index: 10000;
            font-family: system-ui, -apple-system, sans-serif;
        }
        .call-mode-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px 16px;
            background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
            border-radius: 14px 14px 0 0;
            color: #fff;
        }
        .call-mode-nav-btn {
            background: rgba(255,255,255,0.2);
            border: none;
            color: #fff;
            padding: 6px 12px;
            border-radius: 6px;
            cursor: pointer;
            font-weight: 600;
            font-size: 12px;
            transition: background 0.2s;
        }
        .call-mode-nav-btn:hover {
            background: rgba(255,255,255,0.3);
        }
        .call-mode-close-btn {
            background: rgba(255,255,255,0.2);
            border: none;
            color: #fff;
            width: 28px;
            height: 28px;
            border-radius: 50%;
            cursor: pointer;
            font-size: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .call-mode-close-btn:hover {
            background: #ef4444;
        }
        .call-mode-body {
            padding: 16px;
        }
        .call-mode-property-info {
            background: rgba(255,255,255,0.05);
            padding: 12px;
            border-radius: 10px;
            margin-bottom: 12px;
            border-left: 4px solid #22c55e;
        }
        .call-mode-phones {
            margin-bottom: 12px;
        }
        .call-mode-phone-row {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 12px;
            background: rgba(255,255,255,0.05);
            border-radius: 8px;
            margin-bottom: 6px;
        }
        .call-mode-phone-row:hover {
            background: rgba(255,255,255,0.1);
        }
        .call-mode-phone-number {
            font-size: 18px;
            font-weight: 700;
            color: #fff;
            font-family: monospace;
            flex: 1;
        }
        .call-mode-phone-btn {
            padding: 6px 10px;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            font-weight: 600;
            font-size: 11px;
            transition: transform 0.1s, opacity 0.2s;
        }
        .call-mode-phone-btn:hover {
            transform: scale(1.05);
        }
        .call-mode-phone-btn:active {
            transform: scale(0.95);
        }
        .call-mode-call-count {
            background: #22c55e;
            color: #000;
            padding: 4px 10px;
            border-radius: 12px;
            font-weight: 700;
            font-size: 12px;
            min-width: 24px;
            text-align: center;
        }
        .call-mode-call-count.zero {
            background: #374151;
            color: #9ca3af;
        }
        .call-mode-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 12px;
        }
        .call-action-btn {
            padding: 8px 12px;
            border: none;
            border-radius: 6px;
            cursor: pointer;
            font-weight: 600;
            font-size: 11px;
            color: #fff;
            transition: transform 0.1s, filter 0.2s;
        }
        .call-action-btn:hover {
            filter: brightness(1.2);
            transform: scale(1.02);
        }
        .call-mode-notes textarea {
            width: 100%;
            height: 60px;
            background: rgba(255,255,255,0.05);
            border: 1px solid rgba(255,255,255,0.1);
            border-radius: 8px;
            color: #fff;
            padding: 10px;
            font-size: 13px;
            resize: none;
        }
        .call-mode-notes textarea:focus {
            outline: none;
            border-color: #22c55e;
        }
        .call-mode-notes textarea::placeholder {
            color: #6b7280;
        }
        
        /* Call Mode active indicator on button */
        #callModeBtn.active {
            background: linear-gradient(135deg, #ef4444, #dc2626) !important;
            animation: pulse-call 1.5s infinite;
        }
        @keyframes pulse-call {
            0%, 100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.4); }
            50% { box-shadow: 0 0 0 8px rgba(34, 197, 94, 0); }
        }
        
        /* Call Mode filter buttons */
        .cm-filter-btn {
            padding: 4px 10px;
            border: 1px solid #4b5563;
            background: transparent;
            color: #9ca3af;
            border-radius: 12px;
            cursor: pointer;
            font-size: 10px;
            font-weight: 600;
            transition: all 0.2s;
        }
        .cm-filter-btn:hover {
            background: rgba(255,255,255,0.1);
            color: #fff;
        }
        .cm-filter-btn.active {
            background: #22c55e;
            color: #000;
            border-color: #22c55e;
        }

        /* Mobile Responsiveness */
        @media (max-width: 1024px) {
            .header { flex-wrap: wrap; gap: 8px; padding: 8px 12px; }
            .search-box { order: 3; width: 100%; max-width: none; }
            .action-bar { flex-wrap: wrap; }
            .sidebar { width: 320px; }
        }

        /* ========== MOBILE STYLES ========== */
        @media (max-width: 768px) {
            /* Hide desktop elements */
            .action-bar, .sidebar-collapse-btn, .map-amenities-panel, .pegman { display: none !important; }
            .found-parcels-panel, .tax-panel, .multi-owner-panel, .results-panel { display: none !important; }
            .map-overlay { display: none !important; }
            .left-toggle-container, .terminal-panel, .ai-comps-panel { display: none !important; }
            .leaflet-popup, .soil-popup { display: none !important; }
            .map-zoom-controls, .measure-result, .leaflet-control-zoom, .leaflet-control-attribution, .map-tools-bottom { display: none !important; }

            /* Hide soil legend completely on mobile - map overlay still shows */
            .soil-legend {
                display: none !important;
            }
            #soilLegend, #farmlandLegend, #terrainLegend {
                display: none !important;
            }

            /* Simple header */
            .header {
                position: fixed;
                top: 0; left: 0; right: 0;
                height: 50px;
                padding: 6px 10px;
                z-index: 2000;
                flex-wrap: nowrap;
                gap: 8px;
            }
            .logo img { height: 28px; }
            .logo span { display: none; }
            .search-box { flex: 1; }
            .search-box input { font-size: 16px; height: 38px; }

            /* Main area - full screen map */
            .main {
                margin-top: 50px;
                height: calc(100vh - 50px - 50px);
                height: calc(100dvh - 50px - 50px);
                flex-direction: column;
            }
            .map-container { width: 100% !important; height: 100% !important; }

            /* Hide sidebar */
            .sidebar { display: none !important; }

            /* Modals */
            .modal { width: 95vw !important; max-height: 85vh !important; margin: auto !important; }

            /* Touch targets */
            button, .btn, input, select { min-height: 44px; }
            input, select { font-size: 16px; }
        }

        /* Mobile bottom bar with map tools */
        .mobile-bottom-bar {
            display: none;
            position: fixed;
            bottom: 0; left: 0; right: 0;
            height: 50px;
            background: var(--dark);
            border-top: 1px solid var(--border);
            z-index: 3000;
            padding-bottom: env(safe-area-inset-bottom);
        }
        @media (max-width: 768px) {
            .mobile-bottom-bar { display: flex !important; }
        }
        .mobile-bottom-bar .mobile-tools {
            display: flex;
            justify-content: space-around;
            align-items: center;
            width: 100%;
            height: 100%;
        }
        .mobile-tool-btn {
            display: flex;
            align-items: center;
            justify-content: center;
            background: none;
            border: none;
            color: var(--text-muted);
            font-size: 24px;
            padding: 8px 12px;
            cursor: pointer;
            min-height: auto;
            border-radius: 8px;
        }
        .mobile-tool-btn.active { color: var(--primary); background: rgba(0,212,170,0.15); }

        /* Mobile panel (list/property) */
        .mobile-panel {
            display: none;
            position: fixed;
            left: 0; right: 0;
            bottom: 50px;
            max-height: 60vh;
            background: var(--dark);
            border-top: 2px solid var(--primary);
            border-radius: 16px 16px 0 0;
            z-index: 2500;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
            padding-bottom: env(safe-area-inset-bottom);
        }
        .mobile-panel.active { display: block; }
        .mobile-panel-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
            position: sticky;
            top: 0;
            background: var(--dark);
        }
        .mobile-panel-header h3 { margin: 0; font-size: 16px; color: var(--primary); }
        .mobile-panel-close {
            background: none;
            border: none;
            color: var(--text);
            font-size: 24px;
            cursor: pointer;
            padding: 4px 8px;
            min-height: auto;
        }
        @media (min-width: 769px) {
            .mobile-panel, .mobile-bottom-bar { display: none !important; }
        }

        /* Desktop sidebar visibility fix */
        @media (min-width: 769px) {
            .mobile-sidebar-toggle { display: none; }
        }

        /* Reward Banner Styles */
        .reward-banner {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 10000;
            background: linear-gradient(90deg, #8b5cf6 0%, #6366f1 50%, #8b5cf6 100%);
            background-size: 200% 100%;
            animation: bannerGlow 3s ease infinite;
            padding: 10px 20px;
            display: flex;
            justify-content: center;
            align-items: center;
        }
        @keyframes bannerGlow {
            0%, 100% { background-position: 0% 50%; }
            50% { background-position: 100% 50%; }
        }
        .reward-banner-content {
            display: flex;
            align-items: center;
            gap: 15px;
            color: white;
            font-weight: 500;
        }
        .reward-timer-icon {
            font-size: 20px;
            animation: pulse 1.5s ease infinite;
        }
        @keyframes pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.15); }
        }
        .reward-action-btn {
            background: #22c55e;
            color: white;
            border: none;
            padding: 6px 16px;
            border-radius: 20px;
            font-weight: 600;
            cursor: pointer;
            transition: transform 0.2s;
            font-size: 13px;
        }
        .reward-action-btn:hover { transform: scale(1.05); }
        .reward-close-btn {
            background: transparent;
            border: none;
            color: white;
            font-size: 20px;
            cursor: pointer;
            opacity: 0.7;
        }
        .reward-close-btn:hover { opacity: 1; }
        .banner-days-count {
            font-weight: 700;
            font-size: 18px;
            color: #fbbf24;
        }
        @media (max-width: 768px) {
            .reward-banner { padding: 8px 12px; }
            .reward-banner-content { gap: 8px; font-size: 12px; }
            .reward-action-btn { padding: 4px 10px; font-size: 11px; }
            .banner-days-count { font-size: 14px; }
        }
