.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:1rem}.login-card{background:#fff;border-radius:14px;padding:2.5rem 2rem;width:100%;max-width:380px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.8rem;font-weight:700;color:#1a1a2e;margin-bottom:.3rem}.login-header p{color:#888;font-size:.9rem}.login-btn{width:100%;margin-top:.75rem;padding:.75rem;font-size:1rem}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:#1a1a2e;color:#fff;padding:0 2rem;height:60px;display:flex;align-items:center;gap:2rem;box-shadow:0 2px 8px #0003}.navbar-brand{font-size:1.2rem;font-weight:700;letter-spacing:.5px;color:#4fc3f7;white-space:nowrap}.navbar-links{display:flex;gap:.5rem;flex:1}.nav-link{padding:.4rem .9rem;border-radius:6px;color:#cdd2e0;font-size:.9rem;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff14;color:#fff}.nav-link.active{background:#4fc3f72e;color:#4fc3f7}.navbar-user{display:flex;align-items:center;gap:.75rem;white-space:nowrap}.user-badge{background:#4fc3f7;color:#1a1a2e;font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.username{font-size:.9rem;color:#e0e0e0}.main-content{flex:1;padding:2rem;max-width:1100px;width:100%;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:6px;border:none;font-size:.9rem;font-weight:500;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#4fc3f7;color:#1a1a2e}.btn-primary:hover:not(:disabled){background:#29b6f6}.btn-danger{background:#ef5350;color:#fff}.btn-danger:hover:not(:disabled){background:#e53935}.btn-warning{background:#ffa726;color:#fff}.btn-warning:hover:not(:disabled){background:#fb8c00}.btn-outline{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff}.btn-outline:hover:not(:disabled){background:#ffffff1a}.btn-sm{padding:.3rem .75rem;font-size:.8rem}.card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000012;padding:1.75rem;margin-bottom:1.5rem}.card-title{font-size:1.15rem;font-weight:600;margin-bottom:1rem;color:#1a1a2e}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.1rem;color:#666}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.85rem;font-weight:500;color:#444;margin-bottom:.35rem}.form-input{width:100%;padding:.6rem .85rem;border:1.5px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit;transition:border-color .15s;outline:none}.form-input:focus{border-color:#4fc3f7}.form-select{width:100%;padding:.6rem .85rem;border:1.5px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit;background:#fff;outline:none}.form-select:focus{border-color:#4fc3f7}.error-msg{color:#e53935;font-size:.85rem;margin-top:.5rem}.success-msg{color:#43a047;font-size:.85rem;margin-top:.5rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th{text-align:left;padding:.65rem 1rem;background:#f5f7fa;font-weight:600;color:#555;border-bottom:2px solid #e0e0e0}td{padding:.65rem 1rem;border-bottom:1px solid #f0f0f0;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#fafbfc}.badge{display:inline-block;padding:.2rem .55rem;border-radius:20px;font-size:.75rem;font-weight:600}.badge-admin{background:#e3f2fd;color:#1565c0}.badge-member{background:#e8f5e9;color:#2e7d32}.badge-inactive{background:#fce4ec;color:#c62828}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.cooldown-throbber{display:inline-block;animation:cooldown-flip 1.5s ease-in-out infinite}@keyframes cooldown-flip{0%{transform:rotate(0)}50%{transform:rotate(180deg)}to{transform:rotate(360deg)}}
