*{margin:0;padding:0;box-sizing:border-box}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;background:#f5f5f5}.app{min-height:100vh}.full-page-center{min-height:100vh;display:flex;align-items:center;justify-content:center}.spinner{width:32px;height:32px;border-radius:50%;border:3px solid #ccc;border-top-color:#667eea;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.navbar{background:#2c3e50;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.navbar h1{font-size:1.5rem;font-weight:600}.nav-links{display:flex;gap:1.5rem;list-style:none}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background .2s}.nav-links a:hover{background:#ffffff1a}.nav-links a.active{background:#fff3}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.logout-btn:hover{background:#c0392b}.container{max-width:1200px;margin:2rem auto;padding:0 2rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h2{margin-bottom:1.5rem;color:#2c3e50;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#34495e;font-weight:500}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.btn-primary{background:#667eea;color:#fff;width:100%}.btn-primary:hover{background:#5568d3}.btn-success{background:#27ae60;color:#fff}.btn-success:hover{background:#229954}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-warning{background:#f39c12;color:#fff}.btn-warning:hover{background:#e67e22}.btn-info{background:#3498db;color:#fff}.btn-info:hover{background:#2980b9}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.error{color:#e74c3c;margin-top:.5rem;font-size:.9rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h2{color:#2c3e50}table{width:100%;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}thead{background:#34495e;color:#fff}th,td{padding:1rem;text-align:left}tbody tr:hover{background:#f8f9fa}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.badge-success{background:#d4edda;color:#155724}.badge-danger{background:#f8d7da;color:#721c24}.badge-warning{background:#fff3cd;color:#856404}.badge-info{background:#d1ecf1;color:#0c5460}.actions{display:flex;gap:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:90%;max-width:500px}.modal h3{margin-bottom:1.5rem;color:#2c3e50}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem;justify-content:flex-end}.settings-grid{display:grid;gap:1.5rem;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.toggle-switch{display:flex;align-items:center;gap:1rem}.toggle-switch input[type=checkbox]{width:50px;height:26px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ccc;border-radius:13px;position:relative;cursor:pointer;transition:background .2s}.toggle-switch input[type=checkbox]:checked{background:#27ae60}.toggle-switch input[type=checkbox]:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .2s}.toggle-switch input[type=checkbox]:checked:before{transform:translate(24px)}.danger-modal{border-top:4px solid #e74c3c}.modal-description{margin-top:.5rem;color:#555}.toast-viewport{position:fixed;right:1.5rem;bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem;z-index:1100}.toast{min-width:260px;max-width:360px;background:#2c3e50;color:#fff;padding:.75rem 1rem;border-radius:4px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 8px 20px #00000040;font-size:.9rem}.toast-success{background:#27ae60}.toast-error{background:#e74c3c}.toast-info{background:#3498db}.toast-message{margin-right:.75rem}.toast-close{background:transparent;border:none;color:inherit;cursor:pointer;font-size:1.1rem;line-height:1}.not-found{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.not-found h2{margin-bottom:.75rem}.not-found p{margin-bottom:1.5rem;color:#555}
