.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:600px;padding:40px 50px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;font-size:28px;margin-bottom:8px}.login-header p{color:#666;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#333;font-weight:500;font-size:16px}.form-group input{padding:16px 20px;border:2px solid #e0e0e0;border-radius:8px;font-size:18px;transition:border-color .3s;height:56px;width:100%;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px;height:56px;width:100%}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;font-size:14px;border:1px solid #fcc}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center;font-size:13px;color:#666}.login-footer p{margin:4px 0}.login-footer strong{color:#333}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.drivers-table{width:100%;border-collapse:collapse;font-size:14px}.drivers-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.drivers-table th{padding:16px 12px;text-align:left;font-weight:600;white-space:nowrap}.drivers-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .2s}.drivers-table tbody tr:hover{background-color:#f8f9fa}.drivers-table tbody tr.editing-row{background-color:#fff8e1}.drivers-table td{padding:14px 12px;vertical-align:middle;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:14px;color:#333}.drivers-table td.editable-field{min-width:200px}.drivers-table td.readonly-field{background-color:#f5f5f5}.monospace{font-family:Monaco,Courier New,monospace;font-size:13px}.actions-cell{text-align:center;white-space:nowrap}.action-buttons{display:flex;flex-direction:column;gap:8px;justify-content:center;align-items:center}.btn-edit,.btn-save,.btn-cancel{padding:6px 12px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;min-width:100px}.btn-edit{background-color:#2196f3;color:#fff}.btn-edit:hover{background-color:#1976d2;transform:translateY(-1px)}.btn-save{background-color:#4caf50;color:#fff}.btn-save:hover:not(:disabled){background-color:#388e3c;transform:translateY(-1px)}.btn-cancel{background-color:#f44336;color:#fff}.btn-cancel:hover:not(:disabled){background-color:#d32f2f;transform:translateY(-1px)}.btn-save:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.edit-input{width:100%;min-width:200px;padding:10px 14px;border:2px solid #667eea;border-radius:4px;font-size:15px;font-family:inherit;box-sizing:border-box}.edit-input:focus{outline:none;border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a}.no-data{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.no-data p{color:#666;font-size:16px;margin:0}@media(max-width:1200px){.table-container{overflow-x:auto}.drivers-table{min-width:1200px}}.dashboard-container{min-height:100vh;background-color:#f5f7fa}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;box-shadow:0 2px 10px #0000001a}.header-content{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{margin:0;font-size:28px;font-weight:600}.user-info{display:flex;align-items:center;gap:15px}.username{font-weight:500}.role-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;background-color:#fff3}.role-badge.admin{background-color:#4caf50}.role-badge.viewer{background-color:#2196f3}.sync-button{padding:8px 16px;background-color:#ffffffe6;color:#667eea;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s}.sync-button:hover:not(:disabled){background-color:#fff;transform:translateY(-1px)}.sync-button:disabled{opacity:.6;cursor:not-allowed}.logout-button{padding:8px 16px;background-color:#fff3;color:#fff;border:2px solid white;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s}.logout-button:hover{background-color:#ffffff4d;transform:translateY(-1px)}.dashboard-main{max-width:1400px;margin:30px auto;padding:0 20px}.error-banner{background-color:#fee;color:#c33;padding:15px 20px;border-radius:8px;margin-bottom:20px;border:1px solid #fcc}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{margin-top:20px;color:#666;font-size:16px}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}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
