:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#eef2ff;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--bg:#f1f5f9;--sidebar-bg:#1e293b;--sidebar-text:#94a3b8;--sidebar-active:#fff;--sidebar-hover:#334155;--card-bg:#fff;--text:#1e293b;--text-secondary:#64748b;--border:#e2e8f0;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d;--transition:.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--sidebar-bg);width:240px;color:var(--sidebar-text);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-logo{color:#fff;border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:20px;font-size:18px;font-weight:700;display:flex}.sidebar-logo svg{width:28px;height:28px}.sidebar-nav{padding:8px 0}.sidebar-group{margin-top:8px;padding:8px 16px}.sidebar-group-title{text-transform:uppercase;letter-spacing:1px;color:#ffffff4d;padding:4px 0;font-size:11px;font-weight:600}.sidebar-item{color:var(--sidebar-text);cursor:pointer;transition:var(--transition);border-radius:6px;align-items:center;gap:10px;margin:2px 8px;padding:8px 16px;font-size:13px;display:flex}.sidebar-item:hover{background:var(--sidebar-hover);color:#e2e8f0}.sidebar-item.active{background:var(--primary);color:#fff}.sidebar-item svg{flex-shrink:0;width:18px;height:18px}.main-content{flex:1;min-height:100vh;margin-left:240px}.header{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.header-title{font-size:18px;font-weight:600}.header-right{align-items:center;gap:16px;display:flex}.page-content{padding:24px}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{font-size:16px;font-weight:600}.card-body{padding:20px}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}table th{text-align:left;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap;background:#f8fafc;padding:12px 16px;font-size:13px;font-weight:600}table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 16px;font-size:13px}table tr:hover td{background:#f8fafc}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 0;display:flex}.pagination-info{color:var(--text-secondary);font-size:13px}.pagination-btns{gap:4px;display:flex}.btn{cursor:pointer;transition:var(--transition);white-space:nowrap;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:var(--warning);color:#fff}.btn-outline{border-color:var(--border);color:var(--text);background:0 0}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{border:1px solid var(--border);width:100%;transition:var(--transition);color:var(--text);background:#fff;border-radius:6px;padding:8px 12px;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.form-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border-radius:12px;flex-direction:column;width:560px;max-width:90vw;max-height:85vh;animation:.2s slideUp;display:flex}.modal-lg{width:720px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:4px;padding:4px}.modal-close:hover{background:var(--bg)}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.status{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-active{color:#16a34a;background:#dcfce7}.status-inactive{color:#dc2626;background:#fee2e2}.status-pending{color:#d97706;background:#fef3c7}.status-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.search-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.search-input{border:1px solid var(--border);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") 12px no-repeat;border-radius:6px;flex:1;min-width:200px;padding:8px 12px 8px 36px;font-size:14px}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.toast{color:#fff;z-index:2000;box-shadow:var(--shadow-lg);border-radius:8px;padding:12px 20px;font-size:14px;animation:.3s slideIn;position:fixed;top:20px;right:20px}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.empty{text-align:center;color:var(--text-secondary);padding:40px 20px}.empty svg{opacity:.4;width:48px;height:48px;margin-bottom:12px}.tag{border-radius:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.tag-primary{background:var(--primary-light);color:var(--primary)}.tag-success{color:#16a34a;background:#dcfce7}.tag-danger{color:#dc2626;background:#fee2e2}.tag-warning{color:#d97706;background:#fef3c7}.login-wrapper{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:16px;width:400px;padding:40px;box-shadow:0 25px 50px #00000026}.login-title{text-align:center;margin-bottom:8px;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:32px}.login-btn{width:100%;padding:12px;font-size:15px}.avatar{object-fit:cover;background:var(--primary-light);width:36px;height:36px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.dropdown{display:inline-block;position:relative}.dropdown-menu{border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:100;background:#fff;border-radius:8px;min-width:160px;padding:4px 0;position:absolute;top:100%;right:0}.dropdown-item{cursor:pointer;color:var(--text);transition:var(--transition);align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:flex}.dropdown-item:hover{background:var(--bg)}.dropdown-item svg{width:16px;height:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.form-row,.form-row-3{grid-template-columns:1fr}}
