*{margin:0;padding:0;box-sizing:border-box}html,body,#app{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a}.home{height:100%;display:flex;align-items:center;justify-content:center;background:#fafafa}.home-content{text-align:center;max-width:520px;padding:2rem}.home-content h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.home-content p{color:#666;margin-bottom:2rem}.city-select{display:flex;gap:.75rem;justify-content:center}.city-select select{padding:.6rem 1rem;font-size:1rem;border:1px solid #ccc;border-radius:6px;background:#fff;min-width:180px}.city-select button{padding:.6rem 1.5rem;font-size:1rem;border:none;border-radius:6px;background:#1a1a1a;color:#fff;cursor:pointer;transition:opacity .15s}.city-select button:disabled{opacity:.3;cursor:default}.city-select button:not(:disabled):hover{opacity:.85}.map-view{height:100%;display:flex;flex-direction:column;position:relative}.map-container{flex:1}.map-topbar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}.back-btn{background:none;border:1px solid #ccc;border-radius:6px;padding:.3rem .6rem;font-size:1.1rem;cursor:pointer;line-height:1}.city-label{font-weight:600;font-size:1.1rem}.location-indicator{width:10px;height:10px;border-radius:50%;margin-left:auto}.location-indicator.requesting{background:#f0ad4e;animation:pulse 1.5s infinite}.location-indicator.granted{background:#4caf50}.location-indicator.denied,.location-indicator.unavailable{background:#e74c3c}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.location-banner{position:absolute;bottom:1rem;left:1rem;right:1rem;background:#fff3cd;color:#856404;padding:.75rem 1rem;border-radius:8px;text-align:center;font-size:.9rem;z-index:10}.user-dot{width:16px;height:16px;background:#4285f4;border:3px solid white;border-radius:50%;box-shadow:0 0 6px #4285f499}
