:root{--primary-gradient: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--secondary-gradient: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);--accent-gradient: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);--dishub-blue: #1e3c72;--dishub-accent: #3b82f6}body{background-color:#f8fafc;margin:0;padding:0}.maps-header{background:var(--primary-gradient);color:#fff;padding:2rem 0 1rem;box-shadow:0 4px 20px #1e3c724d}.maps-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.maps-header p{font-size:1.1rem;opacity:.9;margin-bottom:0}.stats-bar{background:white;padding:1.5rem 0;box-shadow:0 2px 10px #0000001a;border-bottom:1px solid #e2e8f0}.stat-item{text-align:center;padding:0 1rem}.stat-number{font-size:2rem;font-weight:700;color:var(--dishub-blue);display:block}.stat-label{font-size:.9rem;color:#6b7280;font-weight:500}.stat-available .stat-number{color:#059669}.stat-rented .stat-number{color:#dc2626}.map-container{height:calc(100vh - 280px);min-height:600px;position:relative;margin:0;padding:0}#map{height:100%;width:100%;border:none;border-radius:0;box-shadow:none}.map-search-container{position:absolute;top:20px;left:20px;z-index:1000;background:white;border-radius:12px;box-shadow:0 8px 25px #00000026;padding:12px;min-width:350px}.map-search-input{border:2px solid #e5e7eb;outline:none;width:100%;padding:12px 45px 12px 15px;font-size:14px;border-radius:10px;background-color:#f9fafb;transition:all .3s ease}.map-search-input:focus{background-color:#fff;border-color:var(--dishub-accent);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;font-size:16px}.clear-search{position:absolute;right:50px;top:50%;transform:translateY(-50%);background:none;border:none;color:#9ca3af;cursor:pointer;font-size:16px;display:none;padding:5px;border-radius:4px;transition:all .2s ease}.clear-search:hover{color:#6b7280;background-color:#f3f4f6}.search-results{position:absolute;top:100%;left:0;right:0;background:white;border-radius:10px;box-shadow:0 8px 25px #00000026;max-height:300px;overflow-y:auto;z-index:1001;display:none;margin-top:5px}.search-result-item{padding:15px 18px;cursor:pointer;border-bottom:1px solid #f1f5f9;font-size:14px;transition:all .2s ease}.search-result-item:hover{background-color:#f8fafc}.search-result-item:last-child{border-bottom:none;border-radius:0 0 10px 10px}.search-result-item:first-child{border-radius:10px 10px 0 0}.search-result-item.active{background-color:#eff6ff;border-left:4px solid var(--dishub-accent)}.search-result-name{font-weight:600;color:#1f2937;margin-bottom:4px}.search-result-info{font-size:12px;color:#6b7280}.no-results{padding:20px;text-align:center;color:#9ca3af;font-style:italic;font-size:14px}.map-legend{position:absolute;bottom:20px;right:20px;background:white;padding:20px;border-radius:15px;box-shadow:0 8px 25px #00000026;z-index:1000;min-width:200px}.legend-title{font-weight:700;color:#1f2937;margin-bottom:15px;font-size:16px}.legend-item{display:flex;align-items:center;margin-bottom:10px;font-size:14px}.legend-item:last-child{margin-bottom:0}.legend-color{width:20px;height:20px;border-radius:50%;margin-right:12px;border:3px solid white;box-shadow:0 0 5px #0003}.legend-available{background-color:#059669}.legend-rented{background-color:#dc2626}.legend-user{background-color:#2563eb}.leaflet-popup-content{width:380px!important;margin:0!important}.leaflet-popup-content-wrapper{padding:0!important;border-radius:15px!important}.popup-photo-container{position:relative;width:100%;height:220px;margin-bottom:15px;border-radius:15px 15px 0 0;overflow:hidden;background:#f8f9fa}.popup-photo{width:100%;height:220px;object-fit:cover;display:none}.popup-photo.active{display:block}.popup-photo-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.6);color:#fff;border:none;width:35px;height:35px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .2s ease}.popup-photo-nav:hover{background:rgba(0,0,0,.8);transform:translateY(-50%) scale(1.1)}.popup-photo-nav.prev{left:15px}.popup-photo-nav.next{right:15px}.popup-photo-counter{position:absolute;bottom:15px;right:15px;background:rgba(0,0,0,.7);color:#fff;padding:6px 12px;border-radius:15px;font-size:12px;font-weight:600}.no-photos{display:flex;align-items:center;justify-content:center;color:#9ca3af;font-style:italic;height:100%;flex-direction:column}.no-photos i{font-size:3rem;margin-bottom:10px;opacity:.5}.popup-content{padding:0}.popup-info{padding:20px}.popup-title{font-size:1.2em;font-weight:700;margin-bottom:10px;color:#1f2937}.popup-status{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8em;font-weight:700;margin-bottom:15px;text-transform:uppercase;letter-spacing:.5px}.status-available{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.status-rented{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.popup-details{font-size:.9em;line-height:1.6}.info-row{margin-bottom:8px;display:flex;align-items:flex-start}.info-label{font-weight:600;color:#4b5563;min-width:100px;margin-right:10px}.info-value{color:#1f2937;flex:1}.popup-actions{padding:15px 20px;background-color:#f8fafc;border-top:1px solid #e5e7eb;text-align:center;border-radius:0 0 15px 15px}.btn-detail{background:var(--accent-gradient);color:#fff;border:none;padding:12px 28px;border-radius:25px;font-size:.9em;font-weight:600;text-decoration:none;transition:all .3s ease;display:inline-block;cursor:pointer;box-shadow:0 4px 15px #3b82f64d}.btn-detail:hover{transform:translateY(-2px);color:#fff;box-shadow:0 8px 25px #3b82f666}.btn-detail.disabled{background:linear-gradient(135deg,#94a3b8 0%,#cbd5e1 100%);cursor:not-allowed;opacity:.7;box-shadow:0 4px 15px #94a3b833}.btn-detail.disabled:hover{transform:none;box-shadow:0 4px 15px #94a3b833}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(248,250,252,.95);display:flex;align-items:center;justify-content:center;z-index:2000}.loading-content{text-align:center;color:var(--dishub-blue)}.loading-content .spinner-border{width:3rem;height:3rem;margin-bottom:1rem}.highlighted-marker{animation:pulse 1.5s ease-in-out 3}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}to{transform:scale(1);opacity:1}}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.leaflet-popup{margin-bottom:20px!important}.leaflet-popup-tip-container{pointer-events:none}.leaflet-popup-content-wrapper{border-radius:15px!important;box-shadow:0 8px 25px #00000026!important}@media (max-width: 768px){.maps-header h1{font-size:2rem}.maps-header p{font-size:1rem}.map-search-container{left:10px;right:10px;min-width:auto;max-width:calc(100vw - 20px)}.map-legend{bottom:10px;right:10px;left:10px;padding:15px}.map-container{height:calc(100vh - 320px)}.stat-item{padding:0 .5rem}.stat-number{font-size:1.5rem}.leaflet-popup-content{width:300px!important}}.modal-content{border-radius:20px;border:none;box-shadow:0 15px 35px #0000004d}.modal-header{border-bottom:1px solid #e5e7eb;background:var(--primary-gradient);color:#fff;border-radius:20px 20px 0 0;padding:1.5rem 2rem}.modal-header .btn-close{filter:invert(1)}.modal-body{padding:2.5rem;text-align:center}.modal-icon{font-size:4rem;color:#f59e0b;margin-bottom:1.5rem}.modal-title-custom{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.modal-text{color:#6b7280;font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.modal-footer{border-top:1px solid #e5e7eb;padding:1.5rem 2rem;background-color:#f8fafc;border-radius:0 0 20px 20px}.btn-login-modal{background:var(--secondary-gradient);border:none;padding:12px 30px;border-radius:30px;color:#fff;font-weight:600;text-decoration:none;transition:all .3s ease;box-shadow:0 6px 20px #1d4ed84d}.btn-login-modal:hover{transform:translateY(-3px);box-shadow:0 10px 25px #1d4ed866;color:#fff}.btn-understand{background:var(--accent-gradient);border:none;padding:12px 30px;border-radius:30px;color:#fff;font-weight:600;transition:all .3s ease;box-shadow:0 6px 20px #3b82f64d}.btn-understand:hover{transform:translateY(-3px);box-shadow:0 10px 25px #3b82f666}.fullscreen-toggle{position:absolute;top:20px;right:20px;z-index:1000;background:white;border:none;padding:12px;border-radius:10px;box-shadow:0 4px 15px #00000026;cursor:pointer;transition:all .3s ease;color:var(--dishub-blue)}.fullscreen-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003;background:var(--dishub-blue);color:#fff}.fullscreen-map{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:9999!important}.fullscreen-map #map{height:100vh!important}
