*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#1a1a2e;color:#fff;height:100vh;overflow:hidden}.screen{height:100vh;width:100vw}.hidden{display:none!important}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:20px}.login-container h1{font-size:3rem;margin-bottom:.5rem;color:#fff}.login-container p{color:#888;margin-bottom:2rem}.login-btn{display:flex;align-items:center;gap:12px;padding:14px 28px;font-size:1rem;font-weight:500;background:#fff;color:#333;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.login-btn:disabled{opacity:.7;cursor:wait}.domain-note{margin-top:1.5rem;font-size:.85rem;color:#666}.error-message{color:#ff6b6b;font-weight:500}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#16213e;border-bottom:1px solid #0f3460}.header h1{font-size:1.5rem;font-weight:600}.header-center{flex:1;max-width:400px;margin:0 20px}.header-right{display:flex;align-items:center;gap:12px}#user-email{font-size:.85rem;color:#888}.logout-btn{padding:8px 16px;font-size:.85rem;background:transparent;color:#888;border:1px solid #444;border-radius:6px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#333;color:#fff}.search-container{position:relative}#search-input{width:100%;padding:10px 16px;font-size:.95rem;background:#1a1a2e;color:#fff;border:1px solid #0f3460;border-radius:8px;outline:none;transition:border-color .2s}#search-input:focus{border-color:#e94560}#search-input::placeholder{color:#666}.search-results{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:#16213e;border:1px solid #0f3460;border-top:none;border-radius:0 0 8px 8px;z-index:1000}.search-result-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #0f3460;transition:background .2s}.search-result-item:hover{background:#1a1a2e}.search-result-item:last-child{border-bottom:none}.search-result-name{font-weight:500}.search-result-address{font-size:.85rem;color:#888;margin-top:2px}.search-result-status{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.filter-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#16213e;border-bottom:1px solid #0f3460}.filter-group{display:flex;gap:12px}.filter-toggle{display:flex;align-items:center;gap:6px;cursor:pointer}.filter-toggle input{display:none}.filter-chip{padding:6px 12px;font-size:.85rem;font-weight:500;border-radius:20px;opacity:.5;transition:opacity .2s}.filter-toggle input:checked+.filter-chip{opacity:1}.filter-chip.red{background:#e94560;color:#fff}.filter-chip.yellow{background:#f0c929;color:#1a1a2e}.filter-chip.blue{background:#4a90d9;color:#fff}.count{font-size:.8rem;color:#888}.filter-bar-right{display:flex;align-items:center;gap:16px}.locate-me-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0f3460;color:#fff;border:1px solid #1a4a7a;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.locate-me-btn:hover{background:#1a4a7a}.locate-me-btn:disabled{opacity:.5;cursor:not-allowed}.locate-me-btn.locating{animation:pulse-btn 1s ease-in-out infinite}@keyframes pulse-btn{0%,to{opacity:1}50%{opacity:.6}}.locate-me-text{display:none}@media (min-width: 500px){.locate-me-text{display:inline}}.last-updated{font-size:.85rem;color:#666}.last-updated.stale{color:#f0c929}.stale-warning{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 20px;background:linear-gradient(90deg,#e94560,#ff6b6b);color:#fff;font-size:.9rem;font-weight:500}.stale-warning-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#fff;color:#e94560;border-radius:50%;font-weight:700;font-size:.85rem}.stale-warning-text{flex:1;text-align:center}.dismiss-warning{background:transparent;border:none;color:#fff;font-size:1.3rem;cursor:pointer;padding:0 5px;opacity:.8;transition:opacity .2s}.dismiss-warning:hover{opacity:1}#map{height:calc(100vh - 110px);width:100%}.mapboxgl-popup-content{background:#16213e;color:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #0000004d}.mapboxgl-popup-close-button{color:#888;font-size:1.2rem}.mapboxgl-popup-close-button:hover{color:#fff}.hover-popup .mapboxgl-popup-content{background:#16213e;color:#fff;border-radius:8px;padding:10px 14px;box-shadow:0 4px 16px #0006;min-width:150px}.hover-popup .mapboxgl-popup-tip{border-top-color:#16213e}.popup-content{text-align:left}.popup-name{font-weight:600;font-size:.95rem;margin-bottom:2px}.popup-account{font-size:.8rem;color:#888;margin-bottom:6px}.popup-status{font-weight:500;font-size:.85rem}.popup-urgency{font-size:.8rem;color:#aaa;margin-top:4px}.user-location-marker{width:20px;height:20px;background:#4285f4;border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #4285f4,0 2px 8px #0006;animation:user-pulse 2s ease-in-out infinite}@keyframes user-pulse{0%,to{box-shadow:0 0 0 2px #4285f4,0 2px 8px #0006}50%{box-shadow:0 0 0 6px #4285f44d,0 2px 8px #0006}}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.modal-content{background:#16213e;border-radius:12px;padding:24px;max-width:340px;width:100%;text-align:center}.modal-content h3{margin:0 0 16px;font-size:1.2rem;color:#fff}#location-modal-message{text-align:left;font-size:.9rem;line-height:1.6;color:#ccc;white-space:pre-line;margin-bottom:20px}.modal-close-btn{padding:10px 32px;font-size:1rem;font-weight:500;background:#e94560;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.modal-close-btn:hover{background:#ff6b6b}.customer-panel{position:fixed;right:20px;top:130px;width:320px;max-height:calc(100vh - 160px);overflow-y:auto;background:#16213e;border-radius:12px;padding:20px;box-shadow:0 4px 20px #0006;z-index:100}.close-panel{position:absolute;top:12px;right:12px;width:28px;height:28px;background:transparent;border:none;color:#888;font-size:1.5rem;cursor:pointer;transition:color .2s}.close-panel:hover{color:#fff}.customer-panel h2{font-size:1.2rem;margin-bottom:16px;padding-right:30px}.panel-details{display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;justify-content:space-between;font-size:.9rem}.detail-row .label{color:#888}.loading{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a1a2ee6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000}.spinner{width:50px;height:50px;border:4px solid #0f3460;border-top-color:#e94560;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.marker{width:18px;height:18px;border-radius:50%;border:3px solid #fff;cursor:pointer;box-shadow:0 2px 8px #0006;transition:transform .2s ease,box-shadow .2s ease}.marker:hover{transform:scale(1.3)}.marker-red{background-color:#dc3545!important}.marker-yellow{background-color:#ffc107!important}.marker-blue{background-color:#0d6efd!important}.marker.highlighted{transform:scale(1.5);border-width:4px;box-shadow:0 0 0 4px #fffc,0 0 20px 8px #00000080;animation:pulse-ring 1.5s ease-in-out infinite}.mapboxgl-marker:has(.marker.highlighted){z-index:9999!important}@keyframes pulse-ring{0%,to{box-shadow:0 0 0 4px #fffc,0 0 20px 8px #00000080}50%{box-shadow:0 0 0 6px #fff,0 0 30px 12px #0009}}@media (max-width: 768px){.header{flex-wrap:wrap;gap:10px}.header-center{order:3;max-width:none;width:100%;margin:10px 0 0}.header-right{margin-left:auto}#user-email{display:none}.filter-bar{flex-wrap:wrap;gap:10px}.mapboxgl-ctrl-top-left{left:10px}.customer-panel{left:10px;right:10px;width:auto;top:auto;bottom:calc(10px + env(safe-area-inset-bottom,0px));max-height:35vh;padding:14px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px))}.customer-panel h2{font-size:1.1rem;margin-bottom:10px}.panel-details{gap:6px}.detail-row{font-size:.8rem}#map{height:calc(100vh - 160px)}}
