*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:20px;padding:40px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:30px}.login-logo img{max-width:200px;height:auto}.login-box h2{text-align:center;color:#333;margin-bottom:30px;font-size:28px;font-weight:600}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#555;font-size:14px}.form-group input{padding:12px 16px;border:1.8px solid #808080;border-radius:15px;font-size:16px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#0a0a23;border-width:1.8px}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center}.login-button{padding:14px;background-color:#0a0a23;color:#fff;border:none;border-radius:15px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s ease;margin-top:10px}.login-button:hover:not(:disabled){background-color:#1a1a3a}.login-button:disabled{opacity:.6;cursor:not-allowed}.map-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.map-modal-content{background-color:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.map-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background-color:#c62828;color:#fff;border-radius:12px 12px 0 0}.map-header h3{margin:0;font-size:20px}.close-button{background:none;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease}.close-button:hover{background-color:#fff3}.map-container{padding:20px;position:relative}.map-loading{display:flex;justify-content:center;align-items:center;height:400px;color:#666;font-size:16px}.map-error{padding:40px;text-align:center;color:#dc3545;font-size:16px}.map-actions{display:flex;gap:12px;padding:0 20px 16px}.copy-location-btn,.open-maps-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none}.copy-location-btn{background-color:#f0f0f0;color:#333}.copy-location-btn:hover{background-color:#e0e0e0}.copy-location-btn.copied{background-color:#d4edda;color:#155724}.open-maps-btn{background-color:#4285f4;color:#fff}.open-maps-btn:hover{background-color:#3367d6}.map-details{padding:20px;border-top:1px solid #e0e0e0}.map-details h4{margin:0 0 15px;font-size:18px;color:#333}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.detail-item{padding:12px;background-color:#f9f9f9;border-radius:8px;font-size:16px}.detail-item strong{color:#333;margin-right:8px}@media(max-width:768px){.details-grid{grid-template-columns:1fr}.map-modal-content{margin:10px;max-height:95vh}.map-actions{flex-direction:column}.copy-location-btn,.open-maps-btn{justify-content:center}}.alerts-container{background-color:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.alerts-empty{text-align:center;padding:60px 20px;color:#999;font-size:18px}.alerts-list{display:flex;flex-direction:column;gap:20px}.date-group{margin-bottom:30px}.date-header{color:#c62828;font-size:18px;font-weight:700;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #f0f0f0}.alert-card{background-color:#fff;border:1px solid #e0e0e0;border-radius:15px;padding:16px;margin-bottom:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.alert-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px);border-color:#c62828}.alert-content{display:flex;justify-content:space-between;align-items:center}.alert-title{color:#c62828;font-size:18px;font-weight:600;margin:0;flex:1}.alert-time{color:#999;font-size:14px;white-space:nowrap;margin-left:20px}.users-container{background-color:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.users-header h2{margin:0;color:#333;font-size:24px}.download-button{padding:10px 20px;background-color:#28a745;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .3s ease}.download-button:hover{background-color:#218838}.users-loading{text-align:center;padding:60px 20px}.users-loading .spinner{border:4px solid #f3f3f3;border-top:4px solid #0A0A23;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}.search-bar-container{display:flex;align-items:center;gap:15px;margin-bottom:20px}.search-input-wrapper{position:relative;flex:1;max-width:500px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#999;pointer-events:none}.search-input{width:100%;padding:10px 36px 10px 40px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;color:#333;background-color:#f8f9fa;transition:all .3s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:#0a0a23;background-color:#fff;box-shadow:0 0 0 3px #0a0a231a}.search-input::placeholder{color:#aaa}.search-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:2px 6px;line-height:1;border-radius:50%;transition:all .2s ease}.search-clear-btn:hover{background-color:#e0e0e0;color:#333}.search-results-count{font-size:13px;color:#888;white-space:nowrap}.users-empty{text-align:center;padding:60px 20px;color:#999;font-size:18px}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table thead{background-color:#f8f9fa}.users-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.users-table td{padding:12px;border-bottom:1px solid #dee2e6;color:#555}.users-table tbody tr:hover{background-color:#f8f9fa}.users-table tbody tr:last-child td{border-bottom:none}.edit-input{width:100%;padding:6px;border:1px solid #ddd;border-radius:4px;font-size:14px}.edit-input:focus{outline:none;border-color:#0a0a23}.action-buttons{display:flex;gap:8px}.edit-button,.save-button,.cancel-button{padding:6px 12px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .3s ease}.edit-button{background-color:#007bff;color:#fff}.edit-button:hover{background-color:#0056b3}.save-button{background-color:#28a745;color:#fff}.save-button:hover{background-color:#218838}.cancel-button{background-color:#dc3545;color:#fff}.cancel-button:hover{background-color:#c82333}@media(max-width:768px){.users-header{flex-direction:column;gap:15px;align-items:flex-start}.search-bar-container{flex-direction:column;align-items:flex-start}.search-input-wrapper{max-width:100%;width:100%}.users-table{font-size:12px}.users-table th,.users-table td{padding:8px}.action-buttons{flex-direction:column}}.dashboard-container{min-height:100vh;background-color:#f5f5f5}.dashboard-header{background-color:#fff;box-shadow:0 2px 8px #0000001a;padding:15px 0;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.header-logo{height:69px;width:auto}.dashboard-nav{display:flex;gap:15px;align-items:center}.nav-button{padding:10px 20px;border:none;background-color:transparent;color:#666;font-size:16px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .3s ease}.nav-button:hover{background-color:#f0f0f0;color:#333}.nav-button.active{background-color:#0a0a23;color:#fff}.logout-button{background-color:#dc3545;color:#fff}.logout-button:hover{background-color:#c82333}.dashboard-main{max-width:1400px;margin:0 auto;padding:30px 20px}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.spinner{border:4px solid #f3f3f3;border-top:4px solid #0A0A23;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notif-status{position:relative;display:flex;align-items:center;justify-content:center;padding:8px;color:#666;cursor:default}.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background-color:#ccc}.notif-dot.active{background-color:#28a745;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.notification-toast{position:fixed;top:20px;right:20px;z-index:9999;display:flex;align-items:flex-start;gap:12px;background:#fff;border-left:4px solid #dc3545;border-radius:8px;padding:16px 20px;box-shadow:0 8px 32px #0000002e;max-width:400px;min-width:300px;animation:toast-slide-in .4s ease-out}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.notification-toast-icon{color:#dc3545;flex-shrink:0;margin-top:2px}.notification-toast-content{flex:1}.notification-toast-content strong{display:block;font-size:15px;color:#333;margin-bottom:4px}.notification-toast-content p{margin:0;font-size:13px;color:#666;line-height:1.4}.notification-toast-close{background:none;border:none;font-size:22px;color:#999;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0;transition:color .2s}.notification-toast-close:hover{color:#333}@media(max-width:768px){.notification-toast{left:10px;right:10px;max-width:unset;min-width:unset}.notif-status{display:none}}
