:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}#app{text-align:center;max-width:1280px;margin:0 auto;padding:2rem}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container[data-v-4a13065c]{background-color:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box[data-v-4a13065c]{background:#fff;border-radius:8px;width:360px;padding:40px;box-shadow:0 2px 12px #0000001a}h2[data-v-4a13065c]{text-align:center;color:#333;margin-bottom:30px;font-size:22px}.form-item[data-v-4a13065c]{margin-bottom:20px}.form-item label[data-v-4a13065c]{color:#555;margin-bottom:6px;font-size:14px;display:block}.form-item input[data-v-4a13065c]{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-item input[data-v-4a13065c]:focus{border-color:#007bff;outline:none}.error-msg[data-v-4a13065c]{color:#dc3545;text-align:center;margin-bottom:12px;font-size:13px}button[type=submit][data-v-4a13065c]{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;width:100%;padding:11px;font-size:15px;transition:background-color .2s}button[type=submit][data-v-4a13065c]:hover:not(:disabled){background-color:#0056b3}button[type=submit][data-v-4a13065c]:disabled{cursor:not-allowed;background-color:#aaa}.footer-link[data-v-4a13065c]{text-align:center;color:#888;margin-top:20px;font-size:13px}.link[data-v-4a13065c]{color:#007bff;cursor:pointer}.link[data-v-4a13065c]:hover{text-decoration:underline}.register-container[data-v-469481da]{background-color:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;display:flex}.register-box[data-v-469481da]{background:#fff;border-radius:8px;width:360px;padding:40px;box-shadow:0 2px 12px #0000001a}h2[data-v-469481da]{text-align:center;color:#333;margin-bottom:30px;font-size:22px}.form-item[data-v-469481da]{margin-bottom:20px}.form-item label[data-v-469481da]{color:#555;margin-bottom:6px;font-size:14px;display:block}.form-item input[data-v-469481da]{box-sizing:border-box;border:1px solid #ddd;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-item input[data-v-469481da]:focus{border-color:#007bff;outline:none}.error-msg[data-v-469481da]{color:#dc3545;text-align:center;margin-bottom:12px;font-size:13px}.success-msg[data-v-469481da]{color:#28a745;text-align:center;margin-bottom:12px;font-size:13px}button[type=submit][data-v-469481da]{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:4px;width:100%;padding:11px;font-size:15px;transition:background-color .2s}button[type=submit][data-v-469481da]:hover:not(:disabled){background-color:#0056b3}button[type=submit][data-v-469481da]:disabled{cursor:not-allowed;background-color:#aaa}.footer-link[data-v-469481da]{text-align:center;color:#888;margin-top:20px;font-size:13px}.link[data-v-469481da]{color:#007bff;cursor:pointer}.link[data-v-469481da]:hover{text-decoration:underline}.users-container[data-v-033c1afb]{background-color:#f5f7fa;min-height:calc(100vh - 40px);padding:20px}.page-header[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;margin-bottom:20px;padding:24px;box-shadow:0 4px 12px #667eea4d}.page-header h1[data-v-033c1afb]{letter-spacing:.5px;margin:0;font-size:26px;font-weight:700}.add-user-section[data-v-033c1afb]{background:#fff;border-radius:12px;margin-bottom:16px;padding:16px 20px;box-shadow:0 2px 12px #00000014}.add-user-section .add-user-box[data-v-033c1afb]{align-items:center;gap:12px;display:flex}.add-input[data-v-033c1afb]{border:2px solid #e9ecef;border-radius:8px;outline:none;flex:1;padding:10px 16px;font-size:14px;transition:all .2s}.add-input[data-v-033c1afb]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.table-container[data-v-033c1afb]{background:#fff;border-radius:12px;max-height:470px;margin-bottom:16px;overflow:hidden auto;box-shadow:0 2px 12px #00000014}.table-container[data-v-033c1afb]::-webkit-scrollbar{width:6px}.table-container[data-v-033c1afb]::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.table-container[data-v-033c1afb]::-webkit-scrollbar-thumb{background:#667eea66;border-radius:3px}.table-container[data-v-033c1afb]::-webkit-scrollbar-thumb:hover{background:#667eeab3}.data-table[data-v-033c1afb]{border-collapse:collapse;width:100%}.data-table thead[data-v-033c1afb]{color:#fff;z-index:2;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);position:sticky;top:0}.data-table thead th[data-v-033c1afb]{text-align:left;letter-spacing:.3px;padding:14px 16px;font-size:14px;font-weight:600}.data-table td[data-v-033c1afb]{border-bottom:1px solid #e8eaef;padding:14px 16px;font-size:14px}.data-table tbody tr[data-v-033c1afb]{transition:all .2s}.data-table tbody tr[data-v-033c1afb]:hover{background-color:#f8f9ff}.data-table tbody tr.editing-row[data-v-033c1afb]{background-color:#fffbea}.data-table tbody tr:last-child td[data-v-033c1afb]{border-bottom:none}.th-id[data-v-033c1afb]{width:70px}.th-role[data-v-033c1afb]{width:130px}.th-actions[data-v-033c1afb]{width:260px}.cell-id[data-v-033c1afb]{color:#aaa;font-family:Courier New,monospace;font-size:13px;font-weight:500}.cell-username[data-v-033c1afb]{align-items:center;gap:10px;font-weight:500;display:flex}.cell-actions[data-v-033c1afb]{white-space:nowrap}.cell-actions .action-group[data-v-033c1afb]{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.user-avatar[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:inline-flex}.username-text[data-v-033c1afb]{color:#333;font-size:14px}.edit-input[data-v-033c1afb]{border:2px solid #667eea;border-radius:6px;outline:none;width:100%;padding:8px 12px;font-size:14px;transition:all .2s}.edit-input[data-v-033c1afb]:focus{border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a}.role-tag[data-v-033c1afb]{border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex}.role-tag .role-dot[data-v-033c1afb]{border-radius:50%;width:7px;height:7px;display:inline-block}.role-tag.role-admin[data-v-033c1afb]{color:#c62828;background:linear-gradient(135deg,#ffe6e6,#ffcdd2);border:1px solid #ef9a9a}.role-tag.role-admin .role-dot[data-v-033c1afb]{background:#dc3545}.role-tag.role-editor[data-v-033c1afb]{color:#1565c0;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9}.role-tag.role-editor .role-dot[data-v-033c1afb]{background:#007bff}.role-tag.role-user[data-v-033c1afb]{color:#424242;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border:1px solid #bdbdbd}.role-tag.role-user .role-dot[data-v-033c1afb]{background:#6c757d}.role-select-edit[data-v-033c1afb]{color:#333;cursor:pointer;appearance:auto;background:#fff;border:2px solid #667eea;border-radius:6px;outline:none;min-width:100px;height:34px;padding:6px 10px;font-size:13px;font-weight:500}.role-select-edit[data-v-033c1afb]:focus{border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a}.btn[data-v-033c1afb]{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:7px 14px;font-size:12px;font-weight:600;line-height:1;transition:all .2s;display:inline-flex}.btn[data-v-033c1afb]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn[data-v-033c1afb]:active:not(:disabled){transform:translateY(0)}.btn.btn-edit[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#28a745,#20c997)}.btn.btn-edit[data-v-033c1afb]:hover{background:linear-gradient(135deg,#23923d,#1aa179)}.btn.btn-save[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#007bff,#0056b3)}.btn.btn-save[data-v-033c1afb]:hover{background:linear-gradient(135deg,#0069d9,#004a99)}.btn.btn-cancel[data-v-033c1afb]{color:#fff;background:#6c757d}.btn.btn-cancel[data-v-033c1afb]:hover{background:#596167}.btn.btn-role[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#17a2b8,#138496)}.btn.btn-role[data-v-033c1afb]:hover{background:linear-gradient(135deg,#148ea1,#0f6674)}.btn.btn-delete[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#dc3545,#c82333)}.btn.btn-delete[data-v-033c1afb]:hover{background:linear-gradient(135deg,#d32535,#a71d2a)}.btn.btn-add[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:10px 22px;font-size:14px}.btn.btn-add[data-v-033c1afb]:hover{background:linear-gradient(135deg,#506be7,#694391);box-shadow:0 6px 16px #667eea66}.pagination-container[data-v-033c1afb]{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 20px;display:flex;box-shadow:0 2px 12px #00000014}.pagination-container .pagination[data-v-033c1afb]{align-items:center;gap:6px;display:flex}.pagination-container .pagination-info[data-v-033c1afb]{align-items:center;gap:12px;display:flex}.page-btn[data-v-033c1afb]{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:6px;align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.page-btn[data-v-033c1afb]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.page-btn[data-v-033c1afb]:disabled{opacity:.4;cursor:not-allowed}.page-num[data-v-033c1afb]{color:#333;cursor:pointer;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;min-width:36px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s}.page-num[data-v-033c1afb]:hover{background-color:#e9ecef;border-color:#adb5bd}.page-num.active[data-v-033c1afb]{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.page-info[data-v-033c1afb]{color:#6c757d;font-size:13px}.page-size-select[data-v-033c1afb]{color:#333;cursor:pointer;appearance:auto;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;outline:none;min-width:90px;height:36px;padding:7px 10px;font-size:13px;font-weight:500}.page-size-select[data-v-033c1afb]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.empty-data[data-v-033c1afb]{text-align:center;color:#bbb;padding:60px 20px;font-size:14px}.sidebar[data-v-bf836a75]{color:#fff;z-index:1000;background:linear-gradient(#667eea 0%,#764ba2 100%);flex-direction:column;width:260px;height:100vh;display:flex;position:fixed;top:0;left:0;box-shadow:2px 0 12px #0000001a}.logo[data-v-bf836a75]{border-bottom:1px solid #ffffff1a;padding:24px 20px}.logo h2[data-v-bf836a75]{letter-spacing:1px;text-align:center;margin:0;font-size:20px;font-weight:700}.user-info[data-v-bf836a75]{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding:20px;display:flex}.user-info .avatar[data-v-bf836a75]{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:700;display:flex}.user-info .user-detail[data-v-bf836a75]{flex:1;overflow:hidden}.user-info .user-detail .username[data-v-bf836a75]{white-space:nowrap;margin-bottom:6px;font-size:15px;font-weight:600;overflow:hidden}.user-info .user-detail .role-tag[data-v-bf836a75]{border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.user-info .user-detail .role-tag.role-admin[data-v-bf836a75]{color:#fff;background:#ffffff40}.user-info .user-detail .role-tag.role-editor[data-v-bf836a75]{color:#e0e7ff;background:#fff3}.user-info .user-detail .role-tag.role-user[data-v-bf836a75]{color:#d0d9ff;background:#ffffff26}.menu[data-v-bf836a75]{flex:1;padding:16px 0;overflow-y:auto}.menu[data-v-bf836a75]::-webkit-scrollbar{width:6px}.menu[data-v-bf836a75]::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.menu-item[data-v-bf836a75]{color:#ffffffd9;cursor:pointer;border-radius:8px;align-items:center;gap:12px;margin:4px 12px;padding:14px 20px;text-decoration:none;transition:all .2s;display:flex}.menu-item[data-v-bf836a75]:hover{color:#fff;background:#ffffff1a}.menu-item.active[data-v-bf836a75]{color:#fff;background:#fff3;font-weight:600}.menu-item .menu-icon[data-v-bf836a75]{text-align:center;width:24px;font-size:18px}.menu-item .menu-title[data-v-bf836a75]{flex:1;font-size:14px}.parent-item[data-v-bf836a75]{justify-content:space-between}.parent-item .arrow[data-v-bf836a75]{font-size:18px;transition:transform .3s}.parent-item .arrow.expanded[data-v-bf836a75]{transform:rotate(90deg)}.child-item[data-v-bf836a75]{padding-left:52px;font-size:13px}.menu-group[data-v-bf836a75]{margin-bottom:4px}.submenu[data-v-bf836a75]{overflow:hidden}.slide-enter-active[data-v-bf836a75],.slide-leave-active[data-v-bf836a75]{opacity:1;max-height:500px;transition:all .3s}.slide-enter-from[data-v-bf836a75],.slide-leave-to[data-v-bf836a75]{opacity:0;max-height:0}.logout-section[data-v-bf836a75]{border-top:1px solid #ffffff1a;padding:20px}.logout-section .logout-btn[data-v-bf836a75]{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff3;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.logout-section .logout-btn[data-v-bf836a75]:hover{background:#ffffff40;transform:translateY(-2px)}.logout-section .logout-btn .icon[data-v-bf836a75]{font-size:16px}.layout-container[data-v-881d5eae]{width:100%;min-height:100vh;display:flex}.main-content[data-v-881d5eae]{background-color:#f5f7fa;flex:1;min-height:100vh;margin-left:260px}#app{box-sizing:border-box;text-align:left;width:100%;max-width:100%;height:100%;max-height:100%;margin:0;padding:0}
