@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box;font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body{margin:0;font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}.app{width:100%;height:100%;display:flex;flex-direction:column}.map-container{flex:1;position:relative}.leaflet-container{width:100%;height:100%;z-index:1}.loading-container{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;color:#666}.error-container{display:flex;align-items:center;justify-content:center;height:100%;flex-direction:column;padding:20px;text-align:center}.error-container h2{color:#e74c3c;margin-bottom:10px}.error-container p{color:#666}.property-marker{transition:transform .2s ease}.property-marker:hover{transform:scale(1.1)}.property-marker.new img{filter:drop-shadow(0 0 8px #047857) brightness(1.1)}.property-marker.week-old img{filter:drop-shadow(0 0 8px #d97706) brightness(1.05)}.property-marker.old img{filter:drop-shadow(0 0 8px #dc2626) brightness(.95)}.badges-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.listing-type-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;display:inline-block;width:fit-content}.listing-type-badge.listing-type-rent{background:#e0e7ff;color:#4338ca}.listing-type-badge.listing-type-sale{background:#fed7aa;color:#c2410c}.property-type-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px;background:#f3f4f6;color:#4b5563;display:inline-block;width:fit-content}.leaflet-popup-content-wrapper{border-radius:8px;padding:0;overflow:hidden;pointer-events:auto}.leaflet-popup-content{margin:0;width:350px!important;overflow:visible;pointer-events:auto}.popup-content{padding:15px;display:flex;flex-direction:column;overflow:visible;pointer-events:auto}.popup-header{display:flex;justify-content:space-between;align-items:center}.popup-date{font-size:12px;color:#666;font-weight:500}.popup-age-badge{font-size:11px;padding:3px 8px;border-radius:12px;font-weight:600}.popup-age-badge.new{background:#d1fae5;color:#065f46}.popup-age-badge.week-old{background:#fef3c7;color:#92400e}.popup-age-badge.old{background:#fee2e2;color:#991b1b}.popup-photo{margin:12px 0;border-radius:8px;overflow:hidden;background:#f3f4f6}.popup-photo img{width:100%;height:auto;display:block;object-fit:contain}.image-with-loader{position:relative;width:100%;min-height:150px;display:flex;align-items:center;justify-content:center}.image-loader{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:150px}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #1D3560;border-radius:50%;animation:spin 1s linear infinite}.image-error{display:flex;align-items:center;justify-content:center;width:100%;min-height:150px;color:#999;font-size:14px}.popup-text{font-size:14px;line-height:1.5;color:#333;margin-bottom:12px;word-wrap:break-word;overflow:visible;display:flex;flex-wrap:wrap;gap:8px}.popup-text-item{white-space:nowrap;display:inline-block}@media(max-width:768px){.leaflet-popup-content{width:calc(100vw - 60px)!important;max-width:350px}.popup-content{padding:12px}.leaflet-popup{pointer-events:none}.leaflet-popup-content-wrapper,.leaflet-popup-close-button{pointer-events:auto}}.popup-footer{display:flex;justify-content:space-between;align-items:center;gap:12px}.popup-footer-buttons{display:flex;gap:10px;flex:1;min-width:0}.popup-link{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;background:#1d3560;color:#fff!important;text-decoration:none;border-radius:6px;font-size:13px;font-weight:500;transition:background .2s;flex:1;text-align:center;white-space:nowrap;min-width:0;overflow:hidden}.popup-link:hover{background:#20407d}.popup-share-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:#059159;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.popup-share-btn:hover{background:#047a4a}.popup-share-btn:active{background:#036640;transform:scale(.98)}.popup-share-btn svg{flex-shrink:0}.popup-close-btn{color:#dc2626!important;background:#f3f4f6;border:none;border-radius:6px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:#666;transition:all .2s;flex-shrink:0}.popup-close-btn:hover{background:#e5e7eb;color:#333}.popup-close-btn:active{background:#d1d5db;transform:scale(.95)}.share-toast{position:absolute;bottom:-45px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:10px 16px;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap;z-index:10000;animation:slideUpFadeIn .3s ease-out;pointer-events:none}@keyframes slideUpFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:320px){.popup-link,.popup-share-btn{padding:8px 10px;font-size:12px}.popup-share-btn{gap:3px}}.info-banner{position:absolute;top:10px;right:110px;transform:translate(-50%);background:#fff;padding:10px 20px;border-radius:20px;box-shadow:0 2px 8px #0000001a;z-index:1000;font-size:14px;color:#333;display:flex;flex-direction:column;align-items:center;gap:4px}.info-banner-row{display:flex;align-items:center;gap:6px;white-space:nowrap}.info-banner .count{font-weight:700;color:#1d3560}.info-banner .filter-row{color:#1d3560;font-size:12px;font-weight:700}.marker-cluster{background:#18315f99;border:3px solid rgba(24,49,95,.8);border-radius:50%}.marker-cluster div{background:#18315fcc;color:#fff;font-weight:700;border-radius:50%}.legend{position:absolute;top:10px;right:10px;background:#fff;padding:10px;border-radius:8px;box-shadow:0 2px 8px #0000001a;z-index:1000;font-size:12px}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:5px}.legend-item:last-child{margin-bottom:0}.legend-color{width:16px;height:16px;border-radius:50%;border:2px solid rgba(0,0,0,.2)}.view-toggle-btn{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:2000;background:#1d3560;border:none;padding:12px 24px;border-radius:24px;box-shadow:0 4px 12px #00000026;font-size:14px;font-weight:600;color:#fff;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.view-toggle-btn:hover{background:#20407d;box-shadow:0 6px 16px #0003;transform:translate(-50%) translateY(-2px)}.view-toggle-btn:active{transform:translate(-50%) translateY(0);box-shadow:0 2px 8px #00000026}.view-toggle-btn svg{stroke:#fff}.view-toggle-badge{background:#ffffff4d;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.list-view{width:100%;height:100%;display:flex;flex-direction:column;background:#f3f4f6}.list-header{background:#fff;padding:16px 20px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#333;display:flex;align-items:center;justify-content:space-between;gap:10px;box-shadow:0 2px 4px #0000000d;position:relative;z-index:3001}.list-header-left{display:flex;align-items:center;gap:10px}.logo-icon{flex-shrink:0}.list-header-actions{display:flex;align-items:center;gap:8px}.filters-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#1d3560;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;position:relative}.filters-btn:hover{background:#20407d}.filters-btn svg{stroke:#fff}.filters-badge{background:#ffffff4d;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.clear-filters-btn-header{background:#f3f4f6;color:#666;border:none;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.clear-filters-btn-header:hover{background:#e5e7eb;color:#333}.dark-mode-toggle{display:flex;align-items:center;justify-content:center;padding:8px;background:#f3f4f6;color:#666;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.dark-mode-toggle:hover{background:#e5e7eb;color:#333}.dark-mode-toggle svg{stroke:currentColor}.filters-menu{position:fixed;inset:0;width:100%;height:100%;background:#fff;padding:80px 20px 100px;box-shadow:0 2px 4px #0000000d;animation:slideDown .2s ease-out;overflow-y:auto;z-index:3000}.filter-category{margin-bottom:20px}.filter-category:last-child{margin-bottom:0}.filter-category-title{font-size:15px;font-weight:600;color:#333;margin-bottom:10px}.filter-category.emphasized .filter-category-title{font-size:15px;font-weight:700;color:#1f2937}.filter-section{margin-top:12px}.filter-section-subtitle{font-size:13px;font-weight:600;color:#666;margin-bottom:8px}@keyframes slideDown{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.hashtags-grid{display:flex;justify-content:right;flex-wrap:wrap;gap:8px}.hashtag-btn{background:#f3f4f6;border:1px solid #e5e7eb;color:#666;padding:6px 12px;border-radius:16px;font-size:13px;font-weight:400;cursor:pointer;transition:all .2s}.hashtag-btn:hover{background:#e5e7eb;border-color:#d1d5db}.hashtag-btn.selected{background:#1d3560;border-color:#1d3560;color:#fff}.filter-category.emphasized .hashtag-btn{font-weight:700;font-size:13px;border-width:1.5px}.filter-category.emphasized .hashtag-btn.selected{font-weight:700}.no-hashtags{width:100%;text-align:center;color:#999;font-size:14px;padding:20px}.list-container{flex:1;overflow-y:auto;padding:16px}.list-item{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 6px #00000014;transition:transform .2s,box-shadow .2s}.list-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.list-item-date{font-size:13px;color:#666;font-weight:500}.list-item-age-badge{font-size:11px;padding:4px 10px;border-radius:12px;font-weight:600}.list-item-age-badge.new{background:#d1fae5;color:#065f46}.list-item-age-badge.week-old{background:#fef3c7;color:#92400e}.list-item-age-badge.old{background:#fee2e2;color:#991b1b}.list-item-photo{margin:12px 0;border-radius:8px;overflow:hidden;background:#f3f4f6;min-height:200px}.list-item-photo img{width:100%;height:auto;display:block;max-height:300px;object-fit:cover}.list-item-photo .image-loader{min-height:200px}.list-item-text{font-size:14px;line-height:1.6;color:#333;margin-bottom:14px;max-height:none;word-wrap:break-word;display:flex;flex-wrap:wrap;gap:8px}.list-item-text-item{white-space:nowrap;display:inline-block}.list-item-link{display:inline-flex;align-items:center;padding:10px 20px;background:#1d3560;color:#fff!important;text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;transition:background .2s}.list-item-link:hover{background:#20407d}.list-item-actions{display:flex;gap:10px;flex-wrap:wrap}.list-item-map-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#f5f5f5;color:#1d3560;text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .2s}.list-item-map-btn:hover{background:#e8e8e8}.list-item-map-btn:focus{outline:none;background:#e0e0e0}.list-item-map-btn:active{background:#d8d8d8;transform:none}.list-item-map-btn svg{width:16px;height:16px}.dark-mode .list-item-map-btn{background:#ffffff1a;color:#fff}.dark-mode .list-item-map-btn:hover{background:#ffffff26}.dark-mode .list-item-map-btn:focus{background:#ffffff2e}.dark-mode .list-item-map-btn:active{background:#fff3;transform:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#666}.empty-state-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:20px;font-weight:600;color:#333;margin:0 0 12px}.empty-state p{font-size:15px;color:#666;margin:0 0 24px;max-width:350px;line-height:1.5}.clear-filters-btn-large{background:#1d3560;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.clear-filters-btn-large:hover{background:#20407d;transform:translateY(-1px)}.filters-apply-btn{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:3002;background:#1d3560;color:#fff;border:none;padding:12px 24px;border-radius:24px;box-shadow:0 4px 12px #00000026;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.filters-apply-btn:hover{background:#20407d;box-shadow:0 6px 16px #0003;transform:translate(-50%) translateY(-2px)}.filters-apply-btn:active{transform:translate(-50%) translateY(0);box-shadow:0 2px 8px #00000026}.locate-me-btn{position:absolute;bottom:110px;right:10px;z-index:1000;background:#fff;border:none;width:48px;height:48px;border-radius:50%;box-shadow:0 2px 8px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#1d3560}.locate-me-btn:hover{background:#e8edf4;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.locate-me-btn:active{transform:translateY(0);box-shadow:0 2px 8px #00000026}.locate-me-btn:disabled{cursor:not-allowed;opacity:.6}.locate-me-btn.loading svg{animation:spin 1s linear infinite}.locate-me-btn.error{background:#fee2e2;color:#dc2626}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.location-error-toast{position:absolute;bottom:170px;right:10px;z-index:1001;background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;box-shadow:0 2px 8px #00000026;font-size:13px;font-weight:500;max-width:250px;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.user-location-marker{position:relative;display:flex;align-items:center;justify-content:center}.user-location-dot{width:14px;height:14px;background:#4285f4;border:3px solid white;border-radius:50%;box-shadow:0 2px 6px #4285f480;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.user-location-pulse{width:20px;height:20px;background:#4285f44d;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse 2s ease-out infinite;z-index:1}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(3);opacity:0}}@media(max-width:768px){.locate-me-btn{bottom:90px}.location-error-toast{bottom:150px;right:10px;left:10px;max-width:calc(100vw - 20px)}}.leaflet-control-zoom.leaflet-bar.leaflet-control{border:none;box-shadow:0 2px 8px #0000001a}.map-container.dark-mode .leaflet-control-zoom.leaflet-bar.leaflet-control{box-shadow:0 2px 8px #0000004d}.map-container.dark-mode .leaflet-control-zoom a{background:#2d2d2d;color:#e5e7eb;border-bottom:1px solid #404040}.map-container.dark-mode .leaflet-control-zoom a:hover{background:#404040;color:#fff}.map-container.dark-mode .leaflet-control-zoom a:last-child{border-bottom:none}.leaflet-control-attribution,.leaflet-container>a{display:none}.list-view.dark-mode{background:#1a1a1a}.list-view.dark-mode .list-header{background:#2d2d2d;border-bottom:1px solid #404040}.list-view.dark-mode .list-header{color:#e5e7eb}.list-view.dark-mode .logo-icon circle{fill:#3d5a8c}.list-view.dark-mode .count{color:#93b5db!important}.list-view.dark-mode .count span{color:#e5e7eb!important}.list-view.dark-mode .clear-filters-btn-header{background:#404040;color:#d1d5db}.list-view.dark-mode .clear-filters-btn-header:hover{background:#525252;color:#f3f4f6}.list-view.dark-mode .dark-mode-toggle{background:#404040;color:#e5e7eb}.list-view.dark-mode .dark-mode-toggle:hover{background:#525252}.list-view.dark-mode .filters-menu{background:#1a1a1a}.list-view.dark-mode .filter-category-title{color:#e5e7eb}.list-view.dark-mode .filter-category.emphasized .filter-category-title{color:#f3f4f6}.list-view.dark-mode .filter-section-subtitle{color:#9ca3af}.list-view.dark-mode .hashtag-btn{background:#2d2d2d;border-color:#404040;color:#d1d5db}.list-view.dark-mode .hashtag-btn:hover{background:#404040;border-color:#525252}.list-view.dark-mode .hashtag-btn.selected{background:#1d3560;border-color:#1d3560;color:#fff}.list-view.dark-mode .list-container{background:#1a1a1a}.list-view.dark-mode .list-item{background:#2d2d2d;box-shadow:0 2px 6px #0000004d}.list-view.dark-mode .list-item:hover{box-shadow:0 4px 12px #0006}.list-view.dark-mode .list-item-date{color:#9ca3af}.list-view.dark-mode .list-item-text{color:#e5e7eb}.list-view.dark-mode .list-item-photo{background:#1a1a1a}.list-view.dark-mode .property-type-badge{background:#404040;color:#d1d5db}.list-view.dark-mode .empty-state{color:#9ca3af}.list-view.dark-mode .empty-state h3{color:#e5e7eb}.list-view.dark-mode .empty-state p{color:#9ca3af}.map-container.dark-mode .info-banner{background:#2d2d2d;color:#e5e7eb;box-shadow:0 2px 8px #0000004d}.map-container.dark-mode .info-banner .count,.map-container.dark-mode .info-banner .filter-row{color:#93b5db}.map-container.dark-mode .legend,.map-container.dark-mode .locate-me-btn{background:#2d2d2d;color:#e5e7eb;box-shadow:0 2px 8px #0000004d}.map-container.dark-mode .locate-me-btn:hover{background:#404040;color:#e5e7eb;box-shadow:0 4px 12px #0006}.map-container.dark-mode .locate-me-btn.error{background:#7f1d1d;color:#fca5a5}.map-container.dark-mode .location-error-toast{background:#7f1d1d;color:#fca5a5;box-shadow:0 2px 8px #0000004d}.app.dark-mode .view-toggle-btn{background:#1d3560}.app.dark-mode .view-toggle-btn:hover{background:#20407d;box-shadow:0 6px 16px #0003}.map-container.dark-mode .leaflet-popup-content-wrapper{background:#2d2d2d;color:#e5e7eb}.map-container.dark-mode .leaflet-popup-tip{background:#2d2d2d}.map-container.dark-mode .popup-content{color:#e5e7eb}.map-container.dark-mode .popup-date{color:#9ca3af}.map-container.dark-mode .popup-text{color:#e5e7eb}.map-container.dark-mode .popup-photo{background:#1a1a1a}.map-container.dark-mode .popup-close-btn{background:#404040;color:#fca5a5}.map-container.dark-mode .popup-close-btn:hover{background:#525252}.map-container.dark-mode .property-type-badge{background:#404040;color:#d1d5db}.list-view.dark-mode .spinner,.map-container.dark-mode .spinner{border:4px solid #404040;border-top:4px solid #93b5db}.list-view.dark-mode .image-error,.map-container.dark-mode .image-error{color:#6b7280}
