.map-page{min-height:100vh;display:flex;flex-direction:column;background:#f8fafc}.map-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;box-shadow:0 2px 20px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;z-index:1000}.map-header h1{font-size:1.5rem;font-weight:700;color:#2d3748;margin:0}.map-info{display:flex;gap:1rem;align-items:center;font-size:.875rem}.station-count{background:#e2e8f0;color:#4a5568;padding:.25rem .75rem;border-radius:20px;font-weight:600}.last-updated{color:#666;font-weight:500}.map-legend{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.75rem 2rem;display:flex;gap:1.5rem;align-items:center;font-size:.875rem;font-weight:500;color:#4a5568;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:12px;height:12px;border-radius:50%}.legend-color.green{background-color:#22c55e}.legend-color.yellow{background-color:#eab308}.legend-color.orange{background-color:#f97316}.legend-color.red{background-color:#ef4444}.legend-color.blue{background-color:#3b82f6}.map-container{flex:1;min-height:500px;z-index:1}.loading-map{flex:1;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#666;font-weight:500}.bike-station-marker{background:transparent!important;border:none!important}.bike-marker{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;border:2px solid white;box-shadow:0 2px 8px #0003;transition:transform .2s ease}.bike-marker:hover{transform:scale(1.1)}.bike-count{text-shadow:0 1px 2px rgba(0,0,0,.3)}.user-location-marker{background:transparent!important;border:none!important}.user-location-dot{width:20px;height:20px;border-radius:50%;background-color:#3b82f6;border:3px solid white;box-shadow:0 2px 8px #0000004d;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #3b82f6b3}70%{box-shadow:0 0 0 10px #3b82f600}to{box-shadow:0 0 #3b82f600}}.station-popup{min-width:250px}.station-popup h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#2d3748;border-bottom:1px solid #e2e8f0;padding-bottom:.5rem}.station-details{display:flex;flex-direction:column;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-item .label{color:#4a5568;font-weight:500}.detail-item .value{font-weight:600}.detail-item .value.bikes{color:#16a34a}.detail-item .value.docks{color:#2563eb}.detail-item .value.operational{color:#16a34a}.detail-item .value.offline{color:#dc2626}@media (max-width: 768px){.map-header{padding:1rem;text-align:center}.map-header h1{font-size:1.25rem}.map-legend{padding:.5rem 1rem;gap:1rem;justify-content:center}.map-info{flex-direction:column;gap:.5rem}}@media (max-width: 480px){.map-legend{flex-direction:column;gap:.75rem;padding:1rem}.legend-item{justify-content:center}.station-popup{min-width:200px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;color:#333}.header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem 2rem;box-shadow:0 2px 20px #0000001a;display:flex;flex-direction:column;gap:1rem}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header h1{font-size:2rem;font-weight:700;color:#2d3748;margin:0}.navigation{display:flex;gap:.5rem}.nav-button{background:#f7fafc;border:2px solid #e2e8f0;color:#4a5568;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.nav-button:hover{background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}.nav-button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 4px 12px #667eea66}.last-updated{font-size:.9rem;color:#666;font-weight:500}.error{color:#e53e3e!important;font-weight:600}.loading{flex:1;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;font-weight:500}.stations-grid{flex:1;padding:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1400px;margin:0 auto;width:100%}.station-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px #0000001a;transition:all .3s ease;border-left:4px solid #44aa44}.station-card:hover{transform:translateY(-4px);box-shadow:0 12px 48px #00000026}.station-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.station-header h3{font-size:1.2rem;font-weight:600;color:#2d3748;line-height:1.3;flex:1}.station-id{background:#e2e8f0;color:#4a5568;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;margin-left:1rem}.station-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.stat{text-align:center;padding:1rem;background:#f7fafc;border-radius:12px;border:1px solid #e2e8f0}.stat-number{font-size:2rem;font-weight:700;color:#2d3748;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:#718096;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.station-status{min-height:2rem;display:flex;align-items:center;justify-content:center}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.offline{background:#fed7d7;color:#c53030}.status-badge.empty{background:#feebc8;color:#dd6b20}.status-badge.low{background:#fefcbf;color:#d69e2e}.footer{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;text-align:center;color:#fffc;font-size:.875rem}@media (max-width: 768px){.header{padding:1rem}.header-content{flex-direction:column;text-align:center}.header h1{font-size:1.5rem}.navigation{width:100%;justify-content:center}.nav-button{flex:1;justify-content:center}.stations-grid{padding:1rem;grid-template-columns:1fr;gap:1rem}.station-card{padding:1.25rem}.station-header{flex-direction:column;gap:.5rem;align-items:center;text-align:center}.station-id{margin-left:0}.stat-number{font-size:1.75rem}}@media (max-width: 480px){.header h1{font-size:1.25rem}.navigation{flex-direction:column}.nav-button{font-size:.8rem;padding:.6rem 1rem}.stations-grid{padding:.5rem}.station-card{padding:1rem}.station-stats{gap:.75rem}.stat{padding:.75rem}.stat-number{font-size:1.5rem}}
