*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{display:flex;flex-direction:column;height:100vh}.header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:1rem 2rem;z-index:1000}.header h1{font-size:1.8rem;font-weight:600;margin-bottom:.5rem}.header-info{align-items:center;gap:1rem;justify-content:space-between}.header-info,.stats{display:flex;flex-wrap:wrap}.stats{gap:2rem}.stat-item{align-items:center;display:flex;flex-direction:column}.stat-number{color:#fff;font-size:1.5rem;font-weight:700}.stat-label{font-size:.9rem;opacity:.9}.controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.refresh-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.refresh-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.auto-refresh{align-items:center;display:flex;gap:.5rem}.auto-refresh input[type=checkbox]{cursor:pointer;height:18px;width:18px}.auto-refresh label{cursor:pointer;font-size:.9rem}.user-info{border-left:1px solid #ffffff4d;gap:1rem;padding-left:1rem}.user-actions,.user-info{align-items:center;display:flex}.user-actions{gap:.5rem}.profile-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem .8rem;transition:all .3s ease}.profile-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.user-details{align-items:flex-end;display:flex;flex-direction:column}.user-name{color:#fff;font-size:.9rem}.user-role{color:#ffffffe6;font-size:.8rem;opacity:.8}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem .8rem;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.main-content{display:flex;flex:1 1;position:relative}.sidebar{background:#fff;border-right:1px solid #e0e0e0;box-shadow:2px 0 10px #0000001a;display:flex;flex-direction:column;width:350px;z-index:999}.sidebar-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:1rem}.sidebar-header h3{color:#333;font-size:1.1rem;margin-bottom:.5rem}.search-box{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.user-list{flex:1 1;overflow-y:auto;padding:.5rem}.user-item{border-bottom:1px solid #f0f0f0;border-radius:6px;cursor:pointer;margin-bottom:.5rem;padding:1rem;transition:all .2s ease}.user-item:hover{background:#f8f9fa;transform:translateX(2px)}.user-item.active{background:#e3f2fd;border-left:4px solid #2196f3}.user-name{color:#333;font-size:1rem;font-weight:600;margin-bottom:.3rem}.user-info{color:#666;font-size:.85rem;line-height:1.4}.user-location{margin-bottom:.2rem}.user-time{color:#999;font-style:italic}.user-time.stale{color:#ff9800;font-weight:500}.stale-indicator{font-size:.8rem;margin-left:.5rem;opacity:.7}.stale-text{color:#ff9800;font-size:.75rem;font-weight:500}.user-battery{color:#4caf50;font-size:.8rem;font-weight:500;margin-top:.2rem}.user-status{border-radius:50%;display:inline-block;height:8px;margin-right:.5rem;width:8px}.user-status.online{background:#4caf50}.user-status.offline{background:#f44336}.map-container{flex:1 1;position:relative}.leaflet-container{height:100%;width:100%}.loading{align-items:center;display:flex;height:200px;justify-content:center}.error{background:#ffebee;border-left:4px solid #f44336;border-radius:6px;color:#c62828;margin:1rem;padding:1rem}.no-users{color:#666;padding:2rem;text-align:center}.no-users h3{color:#999;margin-bottom:.5rem}@media (max-width:768px){.sidebar{left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%;z-index:1001}.sidebar.open{left:0}.header-info{align-items:flex-start;flex-direction:column}.stats{gap:1rem}.controls{justify-content:space-between;width:100%}}.user-list::-webkit-scrollbar{width:6px}.user-list::-webkit-scrollbar-track{background:#f1f1f1}.user-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.user-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:2rem;position:relative}.login-background{background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;left:0;position:absolute;right:0;top:0;z-index:-2}.login-background:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='25' cy='25' r='1' fill='rgba(255,255,255,0.1)'/%3E%3Ccircle cx='75' cy='75' r='1' fill='rgba(255,255,255,0.1)'/%3E%3Ccircle cx='50' cy='10' r='.5' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='20' cy='80' r='.5' fill='rgba(255,255,255,0.05)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");content:""}.login-background:before,.login-overlay{bottom:0;left:0;position:absolute;right:0;top:0;z-index:-1}.login-overlay{background:#0000001a}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:450px;padding:3rem;position:relative;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.login-logo{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.login-header h1,.logo-icon{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem}.login-header h1{font-weight:700;margin:0}.login-header h2{color:#333;font-size:1.5rem;font-weight:600;margin:.5rem 0}.login-header p{color:#666;font-size:1rem;margin:0}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group input{background:#fafbfc;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:.875rem 1rem;transition:all .3s ease;width:100%}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error-message{align-items:center;background:#ffebee;border-left:4px solid #f44336;border-radius:6px;color:#c62828;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.error-icon{font-size:1.1rem}.success-message{align-items:center;background:#e8f5e8;border-left:4px solid #4caf50;border-radius:6px;color:#2e7d32;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.success-icon{font-size:1.1rem}.auth-toggle{margin-top:1.5rem;text-align:center}.toggle-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;padding:.5rem;text-decoration:underline;transition:color .3s ease}.toggle-button:hover{color:#5a67d8}.toggle-button:disabled{color:#999;cursor:not-allowed;text-decoration:none}.forgot-password{margin-top:1rem;text-align:center}.forgot-password-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;padding:.5rem;text-decoration:underline;transition:color .3s ease}.forgot-password-button:hover{color:#5a6fd8}.forgot-password-button:disabled{cursor:not-allowed;opacity:.6}.back-to-login{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:1rem;padding:.75rem 1.5rem;transition:background-color .3s ease;width:100%}.back-to-login:hover{background:#5a6268}.login-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;overflow:hidden;padding:1rem;position:relative;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 8px 25px #667eea4d;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.8}.login-button.loading{pointer-events:none}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-footer{border-top:1px solid #e1e5e9;padding-top:1.5rem}.login-info h4{align-items:center;color:#666;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center}.login-info h4,.login-info p{margin-bottom:1rem;text-align:center}.login-info p{color:#555;font-size:.85rem;line-height:1.5}.info-note{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;color:#1565c0;font-size:.8rem;padding:.75rem;text-align:center}.info-note strong{color:#0d47a1;font-weight:600}@media (max-width:480px){.login-container{padding:1rem}.login-card{padding:2rem 1.5rem}.login-header h1{font-size:2rem}.login-header h2{font-size:1.25rem}.demo-accounts{gap:.25rem}.demo-account{font-size:.8rem;padding:.4rem .6rem}}.profile-overlay{align-items:center!important;-webkit-backdrop-filter:blur(5px)!important;backdrop-filter:blur(5px)!important;background:#00000080!important;bottom:0!important;display:flex!important;justify-content:center!important;left:0!important;position:fixed!important;right:0!important;top:0!important;z-index:9999!important}.profile-modal{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.profile-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.profile-header h2{font-size:1.5rem;font-weight:600;margin:0}.close-btn{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.2rem;padding:8px 12px;transition:all .2s}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.profile-content{padding:24px}.profile-section{margin-bottom:32px}.profile-section h3{border-bottom:2px solid #f0f0f0;color:#333;font-size:1.1rem;font-weight:600;margin:0 0 16px;padding-bottom:8px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.form-group input,.form-group select{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.disabled-input{background-color:#f8f9fa!important;color:#6c757d!important}.form-group small{color:#666;display:block;font-size:.8rem;font-style:italic;margin-top:4px}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;font-weight:400!important}.checkbox-label input[type=checkbox]{margin-right:10px;transform:scale(1.2);width:auto!important}.profile-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;gap:12px;padding:20px 24px}.profile-footer{border-top:1px solid #e0e0e0;padding:16px 24px;text-align:center}.btn-danger,.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;min-width:100px;padding:12px 24px;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.btn-danger:disabled,.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6;transform:none}.message{animation:slideDown .3s ease-out;border-radius:8px;font-weight:500;margin:16px 24px;padding:12px 16px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.loading{color:#666;font-size:1.1rem;padding:40px;text-align:center}@media (max-width:768px){.profile-modal{margin:20px;width:95%}.profile-header{padding:16px 20px}.profile-content{padding:20px}.profile-actions{flex-direction:column;padding:16px 20px}.btn-danger,.btn-primary,.btn-secondary{margin-bottom:8px;width:100%}.profile-footer{padding:12px 20px}}.profile-modal::-webkit-scrollbar{width:6px}.profile-modal::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.profile-modal::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.profile-modal::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
/*# sourceMappingURL=main.437bf9fd.css.map*/