*{margin:0;padding:0;box-sizing:border-box}:root{--bg-gradient: linear-gradient(135deg, #047857 0%, #065f46 100%);--text-primary: #374151;--brand-color: #065f46;--hover-bg: rgba(6, 95, 70, .08);--navbar-bg: rgba(255, 255, 255, .8);--border-color: rgba(0,0,0,.08);--card-bg: #ffffff;--button-bg: #ffffff;--button-text: #374151}[data-theme=dark]{--bg-gradient: linear-gradient(135deg, #0b1220 0%, #0b2a24 100%);--text-primary: #e5e7eb;--brand-color: #34d399;--hover-bg: rgba(255, 255, 255, .08);--navbar-bg: rgba(17, 24, 39, .7);--border-color: rgba(255,255,255,.1);--card-bg: #111827;--button-bg: #1f2937;--button-text: #e5e7eb}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-gradient);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-modern{min-height:100vh;display:flex;flex-direction:column}.main-container{display:flex;flex:1;gap:1.5rem;padding:1.5rem;max-width:1920px;margin:0 auto;width:100%;height:calc(100vh - 220px);min-height:600px;position:relative}.container-page{max-width:1100px;margin:2rem auto;padding:0 1rem}.card{background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);box-shadow:0 10px 30px #00000014}.card-header{padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.06)}.card-body{padding:1.25rem}.list{list-style:none}.list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px dashed rgba(0,0,0,.08)}.list-item:last-child{border-bottom:none}.title{font-weight:700;color:#111827}.meta{color:#6b7280;font-size:.85rem}.actions{display:flex;gap:.5rem}.map-wrapper{flex:1.5;height:calc(100vh - 220px);min-height:600px;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0003;border:3px solid white;transition:all .3s ease;position:relative}.map-wrapper:hover{transform:translateY(-4px);box-shadow:0 25px 80px #0000004d}.leaflet-container{height:100%;width:100%;font-family:inherit;background-color:#e8e8e8;position:absolute!important;top:0!important;left:0!important;bottom:0!important;right:0!important}.leaflet-pane{z-index:400}.leaflet-tile-container{opacity:1}.leaflet-popup-content-wrapper{border-radius:12px}.leaflet-popup-content{margin:1rem}.report-form{padding:2rem}.report-form h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:800}.form-group input,.form-group textarea{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:.95rem;background:white;transition:all .3s ease}@media (max-width: 1024px){.main-container{flex-direction:column;height:auto}.map-wrapper{height:500px;flex:none}}@media (max-width: 768px){.main-container{padding:1rem;gap:1rem}.map-wrapper{height:400px;border-radius:16px}.report-form{padding:1.5rem}}@media (max-width: 480px){.main-container{padding:.75rem}.map-wrapper{height:350px}.report-form{padding:1rem}.btn{padding:.875rem 1.5rem;font-size:.9rem}}@media print{.main-container{flex-direction:column}.map-wrapper{box-shadow:none;border:1px solid #ddd}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#047857 0%,#065f46 100%)}.auth-card{background:white;border-radius:16px;padding:40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:450px}.auth-header{text-align:center;margin-bottom:32px}.auth-header h2{margin:0 0 8px;color:#047857;font-size:28px}.auth-header p{margin:0;color:#666;font-size:14px}.auth-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s}.form-group input:focus{outline:none;border-color:#047857;box-shadow:0 0 0 3px #0478571a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.btn{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#047857;color:#fff}.btn-primary:hover:not(:disabled){background:#065f46;transform:translateY(-1px);box-shadow:0 4px 12px #0478574d}.btn-google{background:white;color:#333;border:2px solid #e5e7eb}.btn-google:hover:not(:disabled){border-color:#d1d5db;background:#065f46;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.btn-google svg{flex-shrink:0}.divider{display:flex;align-items:center;text-align:center;margin:24px 0}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #e5e7eb}.divider span{padding:0 16px;color:#9ca3af;font-size:13px;font-weight:500}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.auth-footer p{margin:0;color:#6b7280;font-size:14px}.auth-footer a{color:#047857;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.error-message{padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:14px;margin-bottom:20px}@media (max-width: 500px){.auth-card{padding:30px 24px}.auth-header h2{font-size:24px}}.parking-search-container{position:relative;width:100%;max-width:500px;z-index:1000}.search-input-wrapper{position:relative;display:flex;align-items:center;background:white;border-radius:8px;box-shadow:0 2px 8px #00000026;transition:box-shadow .3s ease}.search-input-wrapper:focus-within{box-shadow:0 4px 12px #0003}.search-icon{position:absolute;left:12px;font-size:18px;color:#666;pointer-events:none}.parking-search-input{width:100%;padding:12px 40px;border:2px solid transparent;border-radius:8px;font-size:15px;outline:none;transition:border-color .3s ease}.parking-search-input:focus{border-color:#10b981}.parking-search-input::placeholder{color:#999}.clear-search-btn{position:absolute;right:12px;background:#e5e7eb;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:#666;transition:background-color .2s ease}.clear-search-btn:hover{background:#d1d5db}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:400px;overflow-y:auto;z-index:1001}.suggestion-item{display:flex;align-items:flex-start;padding:12px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f3f4f6}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background-color:#f9fafb}.suggestion-icon{font-size:24px;margin-right:12px;flex-shrink:0}.suggestion-content{flex:1;min-width:0}.suggestion-name{font-weight:600;color:#111827;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-details{display:flex;flex-direction:column;gap:4px;font-size:13px}.suggestion-address{color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-status{font-size:12px;font-weight:500;padding:2px 0}.suggestion-status.available{color:#10b981}.suggestion-status.limited{color:#f59e0b}.suggestion-status.full{color:#ef4444}.no-results{padding:16px;text-align:center;color:#6b7280;font-size:14px}.search-suggestions::-webkit-scrollbar{width:8px}.search-suggestions::-webkit-scrollbar-track{background:#f3f4f6;border-radius:8px}.search-suggestions::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:8px}.search-suggestions::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 768px){.parking-search-container{max-width:100%}.parking-search-input{font-size:14px;padding:10px 35px}.search-suggestions{max-height:300px}.suggestion-item{padding:10px}.suggestion-icon{font-size:20px;margin-right:10px}}.header-modern{background:linear-gradient(135deg,#047857 0%,#065f46 100%);color:#fff;padding:1.5rem 2rem;box-shadow:0 4px 20px #04785766;position:relative;z-index:100}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header-status-group{display:flex;align-items:center;gap:1rem}.user-profile-header{display:flex;align-items:center;gap:.75rem;background:rgba(0,0,0,.4);padding:.5rem 1rem;border-radius:50px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.user-name{color:#fff;font-weight:600;font-size:.9rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout-header{background:rgba(239,68,68,.9);color:#fff;border:none;padding:.4rem .9rem;border-radius:50px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ef44444d}.btn-logout-header:hover{background:rgba(220,38,38,1);transform:translateY(-2px);box-shadow:0 4px 12px #ef444480}.data-source-badge{display:flex;align-items:center;gap:.5rem;background:rgba(0,0,0,.4);padding:.5rem 1rem;border-radius:50px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:.85rem}.data-source-badge.live{border:2px solid #10b981}.data-source-badge.simulated{border:2px solid #f59e0b}.badge-icon{font-size:1.1rem}.badge-text{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.header-title h1{font-size:2.5rem;font-weight:800;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.4);letter-spacing:-1px;color:#fff}.subtitle{font-size:.9rem;font-weight:600;letter-spacing:.5px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}.connection-status{display:flex;align-items:center;gap:.5rem;background:rgba(0,0,0,.4);padding:.5rem 1rem;border-radius:50px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-weight:600}.status-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 10px currentColor}.status-dot.live{background:#10b981;animation:pulse-green 2s infinite;color:#10b981}.status-dot.offline{background:#ef4444}@keyframes pulse-green{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.header-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-item-modern{display:flex;align-items:center;gap:1rem;background:rgba(0,0,0,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.25rem;border-radius:16px;border:1px solid rgba(255,255,255,.3);transition:all .3s ease;cursor:pointer}.stat-item-modern:hover{background:rgba(0,0,0,.4);transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.stat-emoji{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:2rem;font-weight:800;line-height:1;margin-bottom:.25rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.stat-label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}@media (max-width: 768px){.header-modern{padding:1rem}.header-top{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1rem}.header-status-group{flex-direction:column;width:100%;gap:.75rem}.data-source-badge{width:100%;justify-content:center}.header-title h1{font-size:1.75rem}.header-stats{grid-template-columns:1fr;gap:.75rem}.stat-emoji{font-size:2rem}.stat-value{font-size:1.5rem}}@media (max-width: 480px){.header-title h1{font-size:1.5rem}.stat-item-modern{padding:.75rem 1rem}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.spinner{border:3px solid #f3f3f3;border-top:3px solid #10b981;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner.small .spinner{width:20px;height:20px;border-width:2px}.loading-spinner.medium .spinner{width:40px;height:40px;border-width:3px}.loading-spinner.large .spinner{width:60px;height:60px;border-width:4px}.loading-text{margin-top:.5rem;color:#666;font-size:.9rem;text-align:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton-card{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1rem;animation:pulse 1.5s ease-in-out infinite}.skeleton-line{height:12px;background:#e9ecef;border-radius:4px;margin-bottom:.5rem}.skeleton-line.short{width:60%}.skeleton-line.medium{width:80%}.skeleton-line.long{width:100%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.report-form-content{padding:2rem}.report-form-content h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:800}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.75rem;font-weight:700;color:#374151;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:.95rem;background:white;transition:all .3s ease}.form-group select{cursor:pointer}.form-group select option{padding:.5rem}.form-group small{display:block;margin-top:.5rem;color:#6b7280;font-size:.8rem;font-style:italic}.form-group textarea{resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.btn{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:700;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d;text-transform:uppercase;letter-spacing:1px;width:100%}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b98166}.btn:active{transform:translateY(0)}.btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.success-message{background:#d1fae5;color:#065f46;margin-top:1rem;padding:1rem;border-radius:12px;font-weight:600;text-align:center;box-shadow:0 2px 8px #10b98133;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.help-text{margin-top:1.5rem;padding:1rem;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb;font-size:.85rem;color:#6b7280}.help-text ol{padding-left:1.5rem;margin:.75rem 0}.help-text li{margin:.5rem 0}.location-display{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:12px;background:#f9fafb;color:#374151;font-family:Courier New,monospace;font-size:.9rem;text-align:center;cursor:not-allowed}.image-input{padding:.5rem;border:2px dashed #d1d5db;border-radius:8px;background:#f9fafb;cursor:pointer;transition:all .2s ease}.image-input:hover{border-color:#10b981;background:#f0fdf4}.image-preview{margin-top:1rem;position:relative;display:inline-block}.image-preview img{max-width:200px;max-height:150px;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a}.remove-image-btn{position:absolute;top:-8px;right:-8px;background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.remove-image-btn:hover{background:#dc2626}@media (max-width: 768px){.report-form-content{padding:1.5rem}}.route-planner{padding:1.5rem}.route-planner h3{margin:0 0 1.5rem;color:#1f2937;font-size:1.5rem;font-weight:800}.route-planner h4{margin:1rem 0 .75rem;color:#1f2937;font-size:1.1rem;font-weight:700}.mode-selector{display:flex;flex-direction:column;gap:.5rem}.mode-selector label{font-weight:600;color:#374151;font-size:.9rem}.stat-primary{grid-column:span 2;background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.stat-primary .stat-label,.stat-primary .stat-value{color:#fff}.navigation-details{margin-top:2rem;padding:1.5rem;background:#f9fafb;border-radius:12px;border:2px solid #e5e7eb}.navigation-steps{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.nav-step{display:flex;gap:1rem;padding:1rem;background:white;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s}.nav-step:hover{border-color:#10b981;box-shadow:0 2px 4px #0000000d}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#10b981;color:#fff;border-radius:50%;font-weight:700;font-size:.9rem;flex-shrink:0}.step-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.step-instruction{font-size:.95rem;color:#1f2937;font-weight:500;line-height:1.4}.step-details{display:flex;gap:.5rem;font-size:.85rem;color:#6b7280;flex-wrap:wrap}.transit-info{color:#10b981;font-weight:600}.route-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.summary-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:white;border-radius:8px;border:1px solid #e5e7eb}.summary-label{font-size:.85rem;color:#6b7280;font-weight:500}.summary-value{font-size:1rem;color:#1f2937;font-weight:600}.route-warning{background:#fff7ed;color:#9a3412;border:1px solid #fdba74;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem}.route-inputs{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-weight:600;color:#374151;font-size:.9rem}.route-input{padding:.75rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s ease}.input-actions{margin-top:.5rem;display:flex;gap:.5rem}.sub-btn{background:#ffffff;color:#065f46;border:1px solid #d1d5db;padding:.4rem .75rem;border-radius:6px;font-size:.85rem;cursor:pointer}.sub-btn:hover{background:#f3f4f6}.modes{display:flex;gap:.5rem;flex-wrap:wrap}.mode-btn{background:#ffffff;color:#374151;border:1px solid #d1d5db;padding:.4rem .75rem;border-radius:20px;font-size:.85rem;cursor:pointer}.mode-btn.active{background:#10b981;border-color:#10b981;color:#fff}.recent{margin-bottom:1rem}.recent-list{display:flex;flex-direction:column;gap:.5rem}.recent-item{display:flex;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:#ffffff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer}.recent-item:hover{background:#f9fafb}.route-input:focus{outline:none;border-color:#10b981}.calculate-btn{background:#10b981;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.calculate-btn:hover:not(:disabled){background:#059669}.calculate-btn:disabled{background:#9ca3af;cursor:not-allowed}.routes-results h4{margin:0 0 1rem;color:#1f2937;font-size:1.2rem;font-weight:700}.routes-list{display:flex;flex-direction:column;gap:1rem}.route-card{border:2px solid #e5e7eb;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s ease;background:white}.route-card:hover{border-color:#10b981;box-shadow:0 4px 6px -1px #0000001a}.route-card.selected{border-color:#10b981;background:#f0fdf4;box-shadow:0 4px 6px -1px #10b98133}.route-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.route-header h5{margin:0;color:#1f2937;font-size:1.1rem;font-weight:700}.route-rating{color:#f59e0b;font-size:1rem}.route-details{display:flex;flex-direction:column;gap:.75rem}.route-info{display:flex;flex-direction:column;gap:.25rem}.info-item{font-size:.9rem;color:#374151}.route-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.stat{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:#f9fafb;border-radius:6px}.stat-label{font-size:.8rem;color:#6b7280;font-weight:500}.stat-value{font-size:1rem;color:#1f2937;font-weight:700}.route-description{margin:0;font-size:.9rem;color:#6b7280;font-style:italic}.selected-route{margin-top:2rem;padding:1.5rem;background:#f0fdf4;border-radius:12px;border:2px solid #10b981}.selected-route h4{margin:0 0 1rem;color:#1f2937;font-size:1.2rem;font-weight:700}.route-summary{display:flex;flex-direction:column;gap:.5rem}.route-summary p{margin:0;font-size:.9rem;color:#374151}.route-summary strong{color:#1f2937}@media (max-width: 768px){.route-stats{grid-template-columns:repeat(4,1fr)}.route-info{flex-direction:column}}.sidebar-modern{background:white;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 40px #667eea26;border:1px solid #e5e7eb}.sidebar-tabs{display:flex;background:#f9fafb;padding:.5rem;border-bottom:2px solid #e5e7eb;overflow-x:auto;scrollbar-width:none}.sidebar-tabs::-webkit-scrollbar{display:none}.tab-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem .75rem;border:none;background:transparent;cursor:pointer;border-radius:12px;transition:all .3s ease;font-weight:600;color:#6b7280;white-space:nowrap;min-width:80px}.tab-button:hover{background:#f3f4f6;color:#667eea}.tab-button.active{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;box-shadow:0 4px 12px #10b9814d}.tab-emoji{font-size:1.25rem}.tab-label{font-size:.85rem}.sidebar-content{flex:1;overflow-y:auto;padding:0}.sidebar-content::-webkit-scrollbar{width:8px}.sidebar-content::-webkit-scrollbar-track{background:#f1f1f1}.sidebar-content::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#764ba2}.data-section{padding:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h3{margin:0;font-size:1.5rem;font-weight:800;color:#1f2937}.count-badge{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff;padding:.5rem 1rem;border-radius:50px;font-size:.85rem;font-weight:700;min-width:40px;text-align:center;box-shadow:0 2px 8px #10b9814d}.card-list{display:flex;flex-direction:column;gap:1rem}.data-card{background:white;border-radius:16px;padding:1.25rem;border:2px solid #e5e7eb;transition:all .3s ease;box-shadow:0 2px 8px #0000000d}.data-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a;border-color:#667eea}.data-card.parking{border-left:4px solid #8b5cf6}.data-card.metro{border-left:4px solid #3b82f6}.data-card.bus{border-left:4px solid #f59e0b}.data-card.train{border-left:4px solid #ef4444}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h4{margin:0;font-size:1.1rem;font-weight:700;color:#1f2937}.status-badge,.vehicle-badge{padding:.4rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-badge.available{background:#d1fae5;color:#065f46}.status-badge.limited{background:#fef3c7;color:#92400e}.status-badge.full{background:#fee2e2;color:#991b1b}.vehicle-badge.metro{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff}.vehicle-badge.bus{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);color:#fff}.vehicle-badge.train{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff}.card-details{margin-bottom:1rem;color:#4b5563;line-height:1.8}.card-details p{margin:.5rem 0;font-size:.9rem}.detail-label{font-weight:600;color:#6b7280;margin-right:.5rem}.card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.stat{display:flex;flex-direction:column;text-align:center}.stat-label{font-size:.7rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stat-value{font-size:1.1rem;font-weight:700;color:#1f2937}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:50px;overflow:hidden;margin-top:1rem}.progress-fill{height:100%;transition:width .5s ease;border-radius:50px}.progress-fill.available{background:linear-gradient(90deg,#10b981 0%,#059669 100%)}.progress-fill.limited{background:linear-gradient(90deg,#f59e0b 0%,#d97706 100%)}.progress-fill.full{background:linear-gradient(90deg,#ef4444 0%,#dc2626 100%)}.empty-state{text-align:center;padding:3rem 1rem;color:#9ca3af}.empty-state p{font-size:1rem;margin:0}@media (max-width: 768px){.sidebar-tabs{padding:.25rem}.tab-button{padding:.75rem .5rem;font-size:.75rem}.tab-emoji{font-size:1rem}.tab-label{display:none}.data-section{padding:1rem}.card-stats{grid-template-columns:1fr;gap:.5rem}}.navbar{position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--navbar-bg);border-bottom:1px solid var(--border-color)}.navbar-inner{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between}.brand-link{color:var(--brand-color);text-decoration:none;font-weight:800;font-size:1.125rem}.links{display:flex;gap:1rem}.link{color:var(--text-primary);text-decoration:none;font-weight:600;padding:.5rem .75rem;border-radius:8px}.link:hover{background:var(--hover-bg)}.link.active{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.menu-btn{display:none;background:transparent;border:none;cursor:pointer;width:40px;height:40px;border-radius:8px}.menu-icon{position:relative;display:inline-block;width:20px;height:2px;background:var(--text-primary)}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--text-primary)}.menu-icon:before{top:-6px}.menu-icon:after{top:6px}.theme-toggle{background:var(--button-bg);color:var(--button-text);border:1px solid var(--border-color);font-weight:700;padding:.5rem .75rem;border-radius:8px;cursor:pointer}@media (max-width: 768px){.menu-btn{display:inline-flex;align-items:center;justify-content:center}.links{position:absolute;top:56px;right:1rem;display:none;flex-direction:column;gap:.5rem;background:var(--navbar-bg);border:1px solid var(--border-color);border-radius:12px;padding:.5rem;box-shadow:0 10px 30px #00000026}.links.open{display:flex}}.marker-cluster-small{background-color:#10b98199}.marker-cluster-medium{background-color:#f59e0b99}.marker-cluster-large{background-color:#ef444499}.marker-cluster div{background-color:#fff;font-weight:700}.map-wrapper{position:relative;overflow:hidden}.leaflet-container{height:100%;width:100%}.leaflet-container .leaflet-tile-pane{opacity:1!important}.leaflet-container .leaflet-tile-container{position:absolute;left:0;top:0}.leaflet-control-attribution{background:rgba(255,255,255,.8);border-radius:8px;padding:2px 8px}.leaflet-container img{max-width:none!important}.leaflet-container .leaflet-zoom-anim{pointer-events:none}
