:root{--vt-c-white: #ffffff;--vt-c-white-soft: #f8f9fc;--vt-c-white-mute: #f0f2f8;--vt-c-indigo-deep: #1e1f37}:root{--c-bg-app: var(--vt-c-white-soft);--c-bg-surface: var(--vt-c-white);--c-bg-sidebar: var(--vt-c-white);--c-bg-header: var(--vt-c-white);--c-bg-mute: var(--vt-c-white-mute);--c-text-primary: var(--vt-c-indigo-deep);--c-text-secondary: rgba(30, 31, 55, .58);--c-text-muted: rgba(30, 31, 55, .36);--c-text-inverse: #ffffff;--c-border: rgba(99, 102, 241, .12);--c-border-hover: rgba(99, 102, 241, .28);--c-primary: #6366F1;--c-primary-hover: #5254CC;--c-primary-dark: #3730A3;--c-primary-light: #EEF2FF;--c-primary-text: #6366F1;--c-code: #10B981;--c-code-light: rgba(16, 185, 129, .1);--c-paper: #F59E0B;--c-paper-light: rgba(245, 158, 11, .1);--c-success: #10B981;--c-success-light: rgba(16, 185, 129, .1);--c-warning: #F59E0B;--c-warning-light: rgba(245, 158, 11, .1);--c-danger: #EF4444;--c-danger-light: rgba(239, 68, 68, .1);--shadow-sm: 0 1px 2px rgba(30, 31, 55, .06);--shadow-md: 0 4px 14px rgba(99, 102, 241, .1), 0 1px 3px rgba(30,31,55,.05);--shadow-lg: 0 8px 28px rgba(99, 102, 241, .14), 0 2px 6px rgba(30,31,55,.06);--sidebar-w: 240px;--header-h: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--font-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-code: "JetBrains Mono", "Fira Code", "Consolas", "Liberation Mono", monospace}.view-container{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input:focus{border-color:var(--c-primary)}.select-input{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input:focus{border-color:var(--c-primary)}.btn{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:5px 11px;font-size:.78rem}.btn-primary{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.table-wrap{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--c-bg-mute)}.td-center{text-align:center}.td-empty{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted{color:var(--c-text-muted)}.pagination{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info{font-size:.85rem;color:var(--c-text-muted)}.status-badge{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on{background:#10b9811f;color:#10b981}.status-off{background:#ef44441a;color:#ef4444}#app .users-view,#app .roles-view,#app .user-groups-view,#app .permissions-view{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row:hover{background-color:var(--c-bg-mute)}#app .status-active{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn:hover{background:var(--c-danger);color:#fff}#app .loading-spinner{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info{color:var(--c-text-secondary)}#app .pagination-btn{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header{background:var(--c-primary)}#app .permission-code{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name{color:var(--c-text-primary)}#app .permission-desc{color:var(--c-text-secondary)}#app .loading-container,#app .empty-container{color:var(--c-text-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;font-weight:400}html{width:100%;height:100%}body{width:100%;height:100%;min-height:100vh;padding:0;margin:0;color:var(--c-text-primary);background:var(--c-bg-app);transition:color .5s,background-color .5s;line-height:1.6;font-family:var(--font-base);font-size:15px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100vw;height:100vh;overflow:hidden}a{text-decoration:none;color:var(--c-primary);transition:.4s;padding:3px}a:hover{background-color:var(--c-primary-light)}.login-page[data-v-8d5a65c1]{display:flex;width:100vw;height:100vh;overflow:hidden;font-family:var(--font-base)}.login-hero[data-v-8d5a65c1]{flex:1;background:linear-gradient(135deg,#1e1f37,#2d2f5b 40%,#3730a3);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.login-hero[data-v-8d5a65c1]:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(99,102,241,.22) 0%,transparent 55%),radial-gradient(circle at 80% 70%,rgba(16,185,129,.14) 0%,transparent 55%);pointer-events:none}.hero-inner[data-v-8d5a65c1]{position:relative;z-index:1;max-width:400px;width:100%;display:flex;flex-direction:column;gap:28px}.hero-brand[data-v-8d5a65c1]{display:flex;align-items:center;gap:12px}.hero-logo-wrap[data-v-8d5a65c1]{width:46px;height:46px;background:#6366f140;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;border:1px solid rgba(99,102,241,.35)}.hero-logo[data-v-8d5a65c1]{width:28px;height:28px;filter:brightness(10)}.hero-brand-text[data-v-8d5a65c1]{display:flex;flex-direction:column;gap:2px}.hero-brand-name[data-v-8d5a65c1]{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:-.01em}.hero-brand-sub[data-v-8d5a65c1]{font-size:.75rem;color:#ffffff8c;letter-spacing:.04em}.hero-title[data-v-8d5a65c1]{font-size:1.6rem;font-weight:800;color:#fff;line-height:1.3;letter-spacing:-.02em;margin:0}.hero-subtitle[data-v-8d5a65c1]{font-size:.9rem;color:#fff9;line-height:1.7;margin:8px 0 0}.hero-features[data-v-8d5a65c1]{display:flex;flex-wrap:wrap;gap:10px}.feature-item[data-v-8d5a65c1]{display:flex;align-items:center;gap:8px;padding:7px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);color:#fffc;font-size:.82rem;font-weight:500}.feature-icon[data-v-8d5a65c1]{width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.hero-stats[data-v-8d5a65c1]{display:flex;gap:12px;flex-wrap:wrap}.stat-chip[data-v-8d5a65c1]{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full)}.stat-dot[data-v-8d5a65c1]{width:7px;height:7px;border-radius:50%;flex-shrink:0}.stat-val[data-v-8d5a65c1]{font-size:.85rem;font-weight:700;color:#fff;font-family:var(--font-code)}.stat-label[data-v-8d5a65c1]{font-size:.78rem;color:#ffffff8c}.login-form-area[data-v-8d5a65c1]{width:440px;flex-shrink:0;background:var(--c-bg-surface);display:flex;align-items:center;justify-content:center;padding:40px 36px}.login-card[data-v-8d5a65c1]{width:100%;max-width:340px}.login-header[data-v-8d5a65c1]{margin-bottom:28px}.login-title[data-v-8d5a65c1]{font-size:1.65rem;font-weight:800;color:var(--c-text-primary);letter-spacing:-.02em;margin:0 0 6px}.login-subtitle[data-v-8d5a65c1]{font-size:.9rem;color:var(--c-text-secondary);margin:0}.login-form[data-v-8d5a65c1]{display:flex;flex-direction:column;gap:16px}.form-group[data-v-8d5a65c1]{display:flex;flex-direction:column;gap:6px}.form-label[data-v-8d5a65c1]{font-size:.82rem;font-weight:600;color:var(--c-text-secondary);letter-spacing:.01em}.input-wrap[data-v-8d5a65c1]{position:relative;display:flex;align-items:center}.input-icon[data-v-8d5a65c1]{position:absolute;left:12px;color:var(--c-text-muted);pointer-events:none;flex-shrink:0}.form-input[data-v-8d5a65c1]{width:100%;padding:10px 14px 10px 38px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);font-size:.9rem;font-family:var(--font-base);background:var(--c-bg-app);color:var(--c-text-primary);transition:border-color .18s,box-shadow .18s;outline:none}.form-input[data-v-8d5a65c1]::placeholder{color:var(--c-text-muted)}.form-input[data-v-8d5a65c1]:-webkit-autofill,.form-input[data-v-8d5a65c1]:-webkit-autofill:hover,.form-input[data-v-8d5a65c1]:-webkit-autofill:focus{-webkit-text-fill-color:var(--c-text-primary);-webkit-box-shadow:0 0 0 1000px var(--c-bg-app) inset}.form-input[data-v-8d5a65c1]:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #6366f11f;background:var(--c-bg-surface)}.form-options[data-v-8d5a65c1]{display:flex;align-items:center}.remember-label[data-v-8d5a65c1]{display:flex;align-items:center;gap:7px;font-size:.85rem;color:var(--c-text-secondary);cursor:pointer}.remember-checkbox[data-v-8d5a65c1]{width:15px;height:15px;accent-color:var(--c-primary)}.alert-error[data-v-8d5a65c1]{padding:10px 14px;border-radius:var(--radius-md);background:var(--c-danger-light);color:var(--c-danger);font-size:.85rem;border:1px solid rgba(239,68,68,.2)}.alert-success[data-v-8d5a65c1]{padding:10px 14px;border-radius:var(--radius-md);background:var(--c-success-light);color:var(--c-success);font-size:.85rem;border:1px solid rgba(16,185,129,.2)}.submit-btn[data-v-8d5a65c1]{width:100%;padding:12px 20px;background:var(--c-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;font-family:var(--font-base);cursor:pointer;box-shadow:0 4px 14px #6366f159;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.submit-btn[data-v-8d5a65c1]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 6px 18px #6366f173;transform:translateY(-1px)}.submit-btn[data-v-8d5a65c1]:disabled{opacity:.65;cursor:not-allowed;transform:none}.loading-text[data-v-8d5a65c1]{display:flex;align-items:center;gap:8px}.spinner[data-v-8d5a65c1]{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin-8d5a65c1 .8s linear infinite}@keyframes spin-8d5a65c1{to{transform:rotate(360deg)}}.login-tip[data-v-8d5a65c1]{text-align:center;font-size:.78rem;color:var(--c-text-muted);margin-top:20px}@media(max-width:768px){.login-hero[data-v-8d5a65c1]{display:none}.login-form-area[data-v-8d5a65c1]{width:100%}}.view-container[data-v-beb0b624]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-beb0b624]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-beb0b624],.toolbar-right[data-v-beb0b624]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-beb0b624]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-beb0b624]:focus{border-color:var(--c-primary)}.select-input[data-v-beb0b624]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-beb0b624]:focus{border-color:var(--c-primary)}.btn[data-v-beb0b624]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-beb0b624]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-beb0b624]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-beb0b624]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-beb0b624]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-beb0b624]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-beb0b624]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-beb0b624]{background:#10b981;color:#fff}.btn-success[data-v-beb0b624]:hover:not(:disabled){background:#059669}.btn-danger[data-v-beb0b624]{background:#ef4444;color:#fff}.btn-danger[data-v-beb0b624]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-beb0b624]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-beb0b624]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-beb0b624]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-beb0b624]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-beb0b624]{border-bottom:none}.data-table tbody tr[data-v-beb0b624]:hover{background:var(--c-bg-mute)}.td-center[data-v-beb0b624]{text-align:center}.td-empty[data-v-beb0b624]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-beb0b624]{color:var(--c-text-muted)}.pagination[data-v-beb0b624]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-beb0b624]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-beb0b624]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-beb0b624]{background:#10b9811f;color:#10b981}.status-off[data-v-beb0b624]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-beb0b624],#app .roles-view[data-v-beb0b624],#app .user-groups-view[data-v-beb0b624],#app .permissions-view[data-v-beb0b624]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-beb0b624]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-beb0b624]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-beb0b624]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-beb0b624]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-beb0b624]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-beb0b624]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-beb0b624]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-beb0b624]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-beb0b624]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-beb0b624]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-beb0b624]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-beb0b624]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-beb0b624]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-beb0b624]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-beb0b624]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-beb0b624]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-beb0b624]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-beb0b624]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-beb0b624]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-beb0b624]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-beb0b624]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-beb0b624]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-beb0b624]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-beb0b624]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-beb0b624]{background:var(--c-primary)}#app .permission-code[data-v-beb0b624]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-beb0b624]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-beb0b624]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-beb0b624]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-beb0b624]{color:var(--c-text-primary)}#app .permission-desc[data-v-beb0b624]{color:var(--c-text-secondary)}#app .loading-container[data-v-beb0b624],#app .empty-container[data-v-beb0b624]{color:var(--c-text-muted)}.pending-banner[data-v-beb0b624]{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:12px 18px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;font-size:.9rem;color:#92400e;font-weight:600;cursor:pointer;transition:background .18s}.pending-banner[data-v-beb0b624]:hover{background:#f59e0b29}.pending-arrow[data-v-beb0b624]{font-size:1.1rem}.stat-grid[data-v-beb0b624]{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}@media(max-width:1100px){.stat-grid[data-v-beb0b624]{grid-template-columns:repeat(2,1fr)}}.stat-card[data-v-beb0b624]{background:var(--c-bg-surface);border:1px solid var(--c-border);border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:box-shadow .18s,transform .18s,border-color .18s}.stat-card[data-v-beb0b624]:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--c-primary)}.stat-icon[data-v-beb0b624]{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon--users[data-v-beb0b624]{background:#6366f11f;color:#6366f1}.stat-icon--eng[data-v-beb0b624]{background:#10b9811f;color:#10b981}.stat-icon--task[data-v-beb0b624]{background:#3b82f61f;color:#3b82f6}.stat-icon--money[data-v-beb0b624]{background:#f59e0b1f;color:#f59e0b}.stat-body[data-v-beb0b624]{min-width:0}.stat-label[data-v-beb0b624]{font-size:.8rem;color:var(--c-text-muted);margin-bottom:2px}.stat-value[data-v-beb0b624]{font-size:1.5rem;font-weight:800;color:var(--c-text-primary);line-height:1.2}.stat-growth[data-v-beb0b624]{font-size:.76rem;font-weight:600;margin-top:2px}.stat-growth.up[data-v-beb0b624]{color:#10b981}.stat-growth.down[data-v-beb0b624]{color:#ef4444}.stat-growth.flat[data-v-beb0b624]{color:var(--c-text-muted)}.stat-growth-tip[data-v-beb0b624]{color:var(--c-text-muted);font-weight:400;margin-left:2px}.quick-row[data-v-beb0b624]{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}@media(max-width:1100px){.quick-row[data-v-beb0b624]{grid-template-columns:repeat(2,1fr)}}.quick-card[data-v-beb0b624]{background:var(--c-bg-surface);border:1px solid var(--c-border);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.875rem;font-weight:600;color:var(--c-text-secondary);transition:all .18s}.quick-card[data-v-beb0b624]:hover{border-color:var(--c-primary);color:var(--c-primary);transform:translateY(-1px)}.section-head[data-v-beb0b624]{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title[data-v-beb0b624]{font-size:1rem;font-weight:700;color:var(--c-text-primary)}.td-mono[data-v-beb0b624]{font-family:var(--font-code);font-size:.78rem;white-space:nowrap}.td-title[data-v-beb0b624]{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-money[data-v-beb0b624]{font-weight:600;color:#10b981;white-space:nowrap}.td-date[data-v-beb0b624]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.order-status[data-v-beb0b624]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.os-draft[data-v-beb0b624]{background:#f3f4f6;color:#6b7280}.os-matching[data-v-beb0b624]{background:#818cf81f;color:#818cf8}.os-pending_group[data-v-beb0b624]{background:#f59e0b1f;color:#d97706}.os-maintaining[data-v-beb0b624]{background:#6366f11f;color:#6366f1}.os-deposit_paid[data-v-beb0b624]{background:#10b9811f;color:#059669}.os-negotiating[data-v-beb0b624]{background:#818cf81f;color:#818cf8}.os-in_progress[data-v-beb0b624]{background:#3b82f61f;color:#3b82f6}.os-accepted[data-v-beb0b624]{background:#f59e0b1f;color:#d97706}.os-completed[data-v-beb0b624]{background:#10b98126;color:#065f46}.os-cancelled[data-v-beb0b624]{background:#ef44441a;color:#ef4444}.view-container[data-v-02d7fc7b]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-02d7fc7b]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-02d7fc7b],.toolbar-right[data-v-02d7fc7b]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-02d7fc7b]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-02d7fc7b]:focus{border-color:var(--c-primary)}.select-input[data-v-02d7fc7b]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-02d7fc7b]:focus{border-color:var(--c-primary)}.btn[data-v-02d7fc7b]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-02d7fc7b]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-02d7fc7b]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-02d7fc7b]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-02d7fc7b]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-02d7fc7b]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-02d7fc7b]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-02d7fc7b]{background:#10b981;color:#fff}.btn-success[data-v-02d7fc7b]:hover:not(:disabled){background:#059669}.btn-danger[data-v-02d7fc7b]{background:#ef4444;color:#fff}.btn-danger[data-v-02d7fc7b]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-02d7fc7b]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-02d7fc7b]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-02d7fc7b]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-02d7fc7b]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-02d7fc7b]{border-bottom:none}.data-table tbody tr[data-v-02d7fc7b]:hover{background:var(--c-bg-mute)}.td-center[data-v-02d7fc7b]{text-align:center}.td-empty[data-v-02d7fc7b]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-02d7fc7b]{color:var(--c-text-muted)}.pagination[data-v-02d7fc7b]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-02d7fc7b]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-02d7fc7b]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-02d7fc7b]{background:#10b9811f;color:#10b981}.status-off[data-v-02d7fc7b]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-02d7fc7b],#app .roles-view[data-v-02d7fc7b],#app .user-groups-view[data-v-02d7fc7b],#app .permissions-view[data-v-02d7fc7b]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-02d7fc7b]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-02d7fc7b]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-02d7fc7b]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-02d7fc7b]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-02d7fc7b]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-02d7fc7b]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-02d7fc7b]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-02d7fc7b]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-02d7fc7b]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-02d7fc7b]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-02d7fc7b]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-02d7fc7b]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-02d7fc7b]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-02d7fc7b]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-02d7fc7b]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-02d7fc7b]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-02d7fc7b]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-02d7fc7b]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-02d7fc7b]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-02d7fc7b]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-02d7fc7b]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-02d7fc7b]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-02d7fc7b]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-02d7fc7b]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-02d7fc7b]{background:var(--c-primary)}#app .permission-code[data-v-02d7fc7b]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-02d7fc7b]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-02d7fc7b]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-02d7fc7b]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-02d7fc7b]{color:var(--c-text-primary)}#app .permission-desc[data-v-02d7fc7b]{color:var(--c-text-secondary)}#app .loading-container[data-v-02d7fc7b],#app .empty-container[data-v-02d7fc7b]{color:var(--c-text-muted)}.stat-chips[data-v-02d7fc7b]{display:flex;gap:8px;flex-wrap:wrap}.stat-chip[data-v-02d7fc7b]{padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600}.chip-total[data-v-02d7fc7b]{background:#6366f11a;color:#6366f1}.chip-active[data-v-02d7fc7b]{background:#10b9811a;color:#10b981}.chip-inactive[data-v-02d7fc7b]{background:#ef44441a;color:#ef4444}.td-email[data-v-02d7fc7b]{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-openid[data-v-02d7fc7b]{font-size:.78rem;color:var(--c-text-muted);font-family:var(--font-code)}.td-date[data-v-02d7fc7b]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.td-id[data-v-02d7fc7b]{color:var(--c-text-muted);font-size:.82rem}.role-badge[data-v-02d7fc7b]{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:600;margin-right:4px}.role-customer[data-v-02d7fc7b]{background:#6366f11a;color:#6366f1}.role-engineer[data-v-02d7fc7b]{background:#f59e0b1a;color:#d97706}.role-admin[data-v-02d7fc7b]{background:#ef44441a;color:#ef4444}.view-container[data-v-6aa75044]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-6aa75044]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-6aa75044],.toolbar-right[data-v-6aa75044]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-6aa75044]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-6aa75044]:focus{border-color:var(--c-primary)}.select-input[data-v-6aa75044]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-6aa75044]:focus{border-color:var(--c-primary)}.btn[data-v-6aa75044]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-6aa75044]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-6aa75044]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-6aa75044]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-6aa75044]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-6aa75044]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-6aa75044]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-6aa75044]{background:#10b981;color:#fff}.btn-success[data-v-6aa75044]:hover:not(:disabled){background:#059669}.btn-danger[data-v-6aa75044]{background:#ef4444;color:#fff}.btn-danger[data-v-6aa75044]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-6aa75044]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-6aa75044]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-6aa75044]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-6aa75044]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-6aa75044]{border-bottom:none}.data-table tbody tr[data-v-6aa75044]:hover{background:var(--c-bg-mute)}.td-center[data-v-6aa75044]{text-align:center}.td-empty[data-v-6aa75044]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-6aa75044]{color:var(--c-text-muted)}.pagination[data-v-6aa75044]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-6aa75044]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-6aa75044]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-6aa75044]{background:#10b9811f;color:#10b981}.status-off[data-v-6aa75044]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-6aa75044],#app .roles-view[data-v-6aa75044],#app .user-groups-view[data-v-6aa75044],#app .permissions-view[data-v-6aa75044]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-6aa75044]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-6aa75044]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-6aa75044]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-6aa75044]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-6aa75044]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-6aa75044]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-6aa75044]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-6aa75044]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-6aa75044]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-6aa75044]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-6aa75044]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-6aa75044]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-6aa75044]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-6aa75044]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-6aa75044]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-6aa75044]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-6aa75044]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-6aa75044]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-6aa75044]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-6aa75044]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-6aa75044]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-6aa75044]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-6aa75044]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-6aa75044]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-6aa75044]{background:var(--c-primary)}#app .permission-code[data-v-6aa75044]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-6aa75044]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-6aa75044]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-6aa75044]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-6aa75044]{color:var(--c-text-primary)}#app .permission-desc[data-v-6aa75044]{color:var(--c-text-secondary)}#app .loading-container[data-v-6aa75044],#app .empty-container[data-v-6aa75044]{color:var(--c-text-muted)}.attach-row[data-v-6aa75044]{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.attach-thumb[data-v-6aa75044]{width:64px;height:64px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;display:inline-block}.attach-thumb img[data-v-6aa75044]{width:100%;height:100%;object-fit:cover;display:block}.attach-file[data-v-6aa75044]{display:inline-flex;align-items:center;padding:6px 12px;background:#f1f5f9;border-radius:8px;font-size:.8rem;color:#4338ca;text-decoration:none;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-file[data-v-6aa75044]:hover{background:#e0e7ff}.badge-pending[data-v-6aa75044]{background:#f59e0b26;color:#d97706;border-radius:20px;padding:4px 12px;font-size:.8rem;font-weight:600}.skill-tag[data-v-6aa75044]{display:inline-block;background:#6366f11a;color:#6366f1;border-radius:8px;padding:2px 7px;font-size:.73rem;margin-right:3px}.audit-badge[data-v-6aa75044]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.78rem;font-weight:600}.audit-pending[data-v-6aa75044]{background:#f59e0b1f;color:#d97706}.audit-approved[data-v-6aa75044]{background:#10b9811f;color:#10b981}.audit-rejected[data-v-6aa75044]{background:#ef44441f;color:#ef4444}.td-date[data-v-6aa75044]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.td-id[data-v-6aa75044]{color:var(--c-text-muted);font-size:.82rem}.modal-mask[data-v-6aa75044]{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card[data-v-6aa75044]{background:#fff;border-radius:16px;width:560px;max-width:100%;max-height:86vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040}.modal-head[data-v-6aa75044]{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 14px;border-bottom:1px solid #eef0f4}.modal-title[data-v-6aa75044]{margin:0 0 8px;font-size:1.05rem;font-weight:700}.modal-close[data-v-6aa75044]{border:none;background:none;font-size:1.6rem;line-height:1;cursor:pointer;color:#9aa3b2}.modal-body[data-v-6aa75044]{padding:16px 24px;overflow-y:auto}.detail-sec[data-v-6aa75044]{margin-bottom:18px}.sec-title[data-v-6aa75044]{margin:0 0 10px;font-size:.82rem;font-weight:700;color:#6366f1;text-transform:uppercase;letter-spacing:.03em}.kv[data-v-6aa75044]{display:flex;justify-content:space-between;gap:16px;padding:5px 0;font-size:.88rem}.kv .k[data-v-6aa75044]{color:var(--c-text-muted);flex-shrink:0}.kv .v[data-v-6aa75044]{color:#111827;font-weight:600;text-align:right}.resume-link[data-v-6aa75044]{display:inline-block;padding:8px 16px;background:#6366f11a;color:#4338ca;border-radius:8px;font-size:.86rem;font-weight:600;text-decoration:none}.tag-row[data-v-6aa75044]{display:flex;flex-wrap:wrap;gap:6px}.tag[data-v-6aa75044]{display:inline-block;background:#6366f11a;color:#6366f1;border-radius:8px;padding:3px 10px;font-size:.78rem}.tag.green[data-v-6aa75044]{background:#10b9811f;color:#059669}.case-list[data-v-6aa75044]{display:flex;flex-direction:column;gap:10px}.case-item[data-v-6aa75044]{border:1px solid #eef0f4;border-left:3px solid #10B981;border-radius:10px;padding:12px 14px}.case-head[data-v-6aa75044]{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.case-name[data-v-6aa75044]{font-weight:700;font-size:.9rem;color:#111827}.case-price[data-v-6aa75044]{font-weight:800;color:#059669;font-size:.9rem}.case-desc[data-v-6aa75044]{margin:0 0 8px;font-size:.82rem;color:#6b7280;line-height:1.6;white-space:pre-wrap}.modal-foot[data-v-6aa75044]{display:flex;justify-content:flex-end;padding:14px 24px 20px;border-top:1px solid #eef0f4}.view-container[data-v-d3ba666f]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-d3ba666f]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-d3ba666f],.toolbar-right[data-v-d3ba666f]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-d3ba666f]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.select-input[data-v-d3ba666f]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-d3ba666f]:focus{border-color:var(--c-primary)}.btn[data-v-d3ba666f]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-d3ba666f]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-d3ba666f]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-d3ba666f]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-d3ba666f]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-d3ba666f]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-d3ba666f]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-d3ba666f]{background:#10b981;color:#fff}.btn-success[data-v-d3ba666f]:hover:not(:disabled){background:#059669}.btn-danger[data-v-d3ba666f]{background:#ef4444;color:#fff}.btn-danger[data-v-d3ba666f]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-d3ba666f]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-d3ba666f]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-d3ba666f]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-d3ba666f]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-d3ba666f]{border-bottom:none}.data-table tbody tr[data-v-d3ba666f]:hover{background:var(--c-bg-mute)}.td-center[data-v-d3ba666f]{text-align:center}.td-empty[data-v-d3ba666f]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-d3ba666f]{color:var(--c-text-muted)}.pagination[data-v-d3ba666f]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-d3ba666f]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-d3ba666f]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-d3ba666f]{background:#10b9811f;color:#10b981}.status-off[data-v-d3ba666f]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-d3ba666f],#app .roles-view[data-v-d3ba666f],#app .user-groups-view[data-v-d3ba666f],#app .permissions-view[data-v-d3ba666f]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-d3ba666f]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-d3ba666f]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-d3ba666f]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-d3ba666f]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-d3ba666f]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-d3ba666f]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-d3ba666f]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-d3ba666f]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-d3ba666f]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-d3ba666f]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-d3ba666f]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-d3ba666f]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-d3ba666f]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-d3ba666f]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-d3ba666f]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-d3ba666f]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-d3ba666f]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-d3ba666f]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-d3ba666f]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-d3ba666f]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-d3ba666f]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-d3ba666f]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-d3ba666f]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-d3ba666f]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-d3ba666f]{background:var(--c-primary)}#app .permission-code[data-v-d3ba666f]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-d3ba666f]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-d3ba666f]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-d3ba666f]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-d3ba666f]{color:var(--c-text-primary)}#app .permission-desc[data-v-d3ba666f]{color:var(--c-text-secondary)}#app .loading-container[data-v-d3ba666f],#app .empty-container[data-v-d3ba666f]{color:var(--c-text-muted)}.search-input[data-v-d3ba666f]{width:280px;height:34px;padding:0 14px;border:1px solid var(--c-border);border-radius:8px;font-size:.86rem;outline:none}.search-input[data-v-d3ba666f]:focus{border-color:var(--c-primary)}.count-badge[data-v-d3ba666f]{background:#6366f11a;color:#6366f1;border-radius:20px;padding:4px 12px;font-size:.8rem;font-weight:600}.state-tip[data-v-d3ba666f]{text-align:center;padding:60px 0;color:var(--c-text-muted)}.case-grid[data-v-d3ba666f]{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:4px 2px}.case-card[data-v-d3ba666f]{background:#fff;border:1px solid #eef0f4;border-radius:14px;padding:16px;cursor:pointer;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column}.case-card[data-v-d3ba666f]:hover{box-shadow:0 8px 24px #6366f11f;transform:translateY(-2px)}.eng-row[data-v-d3ba666f]{display:flex;align-items:center;gap:10px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #f1f5f9}.eng-row.plain[data-v-d3ba666f]{padding-bottom:0;margin-bottom:0;border-bottom:none}.eng-avatar[data-v-d3ba666f]{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.eng-info[data-v-d3ba666f]{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.eng-name[data-v-d3ba666f]{font-weight:700;font-size:.86rem;color:#111827}.eng-meta[data-v-d3ba666f]{font-size:.72rem;color:var(--c-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.case-head[data-v-d3ba666f]{display:flex;justify-content:space-between;align-items:center;gap:10px}.case-name[data-v-d3ba666f]{font-weight:700;font-size:.95rem;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.case-price[data-v-d3ba666f]{font-weight:800;color:#6366f1;font-size:.95rem;flex-shrink:0}.case-desc[data-v-d3ba666f]{margin:8px 0 12px;font-size:.8rem;color:#6b7280;line-height:1.6;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden}.case-desc.full[data-v-d3ba666f]{-webkit-line-clamp:unset;line-clamp:unset;display:block;white-space:pre-wrap}.case-foot[data-v-d3ba666f]{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:auto}.attach-count[data-v-d3ba666f]{font-size:.76rem;color:#059669;flex-shrink:0}.tag-row[data-v-d3ba666f]{display:flex;flex-wrap:wrap;gap:6px}.tag[data-v-d3ba666f]{display:inline-block;background:#6366f11a;color:#6366f1;border-radius:8px;padding:3px 10px;font-size:.74rem}.audit-badge[data-v-d3ba666f]{display:inline-block;padding:2px 9px;border-radius:10px;font-size:.7rem;font-weight:600;flex-shrink:0}.audit-pending[data-v-d3ba666f]{background:#f59e0b1f;color:#d97706}.audit-approved[data-v-d3ba666f]{background:#10b9811f;color:#10b981}.audit-rejected[data-v-d3ba666f]{background:#ef44441f;color:#ef4444}.modal-mask[data-v-d3ba666f]{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card[data-v-d3ba666f]{background:#fff;border-radius:16px;width:600px;max-width:100%;max-height:86vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040}.modal-head[data-v-d3ba666f]{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 14px;border-bottom:1px solid #eef0f4}.modal-title[data-v-d3ba666f]{margin:0;font-size:1.05rem;font-weight:700}.modal-close[data-v-d3ba666f]{border:none;background:none;font-size:1.6rem;line-height:1;cursor:pointer;color:#9aa3b2}.modal-body[data-v-d3ba666f]{padding:16px 24px;overflow-y:auto}.detail-sec[data-v-d3ba666f]{margin-bottom:18px}.sec-title[data-v-d3ba666f]{margin:0 0 10px;font-size:.82rem;font-weight:700;color:#6366f1;text-transform:uppercase;letter-spacing:.03em}.kv[data-v-d3ba666f]{display:flex;justify-content:space-between;gap:16px;padding:5px 0;font-size:.88rem}.kv .k[data-v-d3ba666f]{color:var(--c-text-muted);flex-shrink:0}.kv .v[data-v-d3ba666f]{color:#111827;font-weight:600;text-align:right}.modal-foot[data-v-d3ba666f]{display:flex;justify-content:flex-end;padding:14px 24px 20px;border-top:1px solid #eef0f4}.attach-grid[data-v-d3ba666f]{display:flex;flex-wrap:wrap;gap:10px}.attach-video[data-v-d3ba666f]{width:100%;max-height:320px;border-radius:10px;background:#000}.attach-thumb[data-v-d3ba666f]{width:88px;height:88px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;display:inline-block}.attach-thumb img[data-v-d3ba666f]{width:100%;height:100%;object-fit:cover;display:block}.attach-file[data-v-d3ba666f]{display:inline-flex;align-items:center;padding:6px 12px;background:#f1f5f9;border-radius:8px;font-size:.8rem;color:#4338ca;text-decoration:none;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-file[data-v-d3ba666f]:hover{background:#e0e7ff}.view-container[data-v-156eaddd]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-156eaddd]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-156eaddd],.toolbar-right[data-v-156eaddd]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-156eaddd]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-156eaddd]:focus{border-color:var(--c-primary)}.select-input[data-v-156eaddd]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-156eaddd]:focus{border-color:var(--c-primary)}.btn[data-v-156eaddd]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-156eaddd]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-156eaddd]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-156eaddd]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-156eaddd]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-156eaddd]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-156eaddd]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-156eaddd]{background:#10b981;color:#fff}.btn-success[data-v-156eaddd]:hover:not(:disabled){background:#059669}.btn-danger[data-v-156eaddd]{background:#ef4444;color:#fff}.btn-danger[data-v-156eaddd]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-156eaddd]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-156eaddd]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-156eaddd]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-156eaddd]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-156eaddd]{border-bottom:none}.data-table tbody tr[data-v-156eaddd]:hover{background:var(--c-bg-mute)}.td-center[data-v-156eaddd]{text-align:center}.td-empty[data-v-156eaddd]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-156eaddd]{color:var(--c-text-muted)}.pagination[data-v-156eaddd]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-156eaddd]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-156eaddd]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-156eaddd]{background:#10b9811f;color:#10b981}.status-off[data-v-156eaddd]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-156eaddd],#app .roles-view[data-v-156eaddd],#app .user-groups-view[data-v-156eaddd],#app .permissions-view[data-v-156eaddd]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-156eaddd]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-156eaddd]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-156eaddd]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-156eaddd]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-156eaddd]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-156eaddd]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-156eaddd]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-156eaddd]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-156eaddd]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-156eaddd]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-156eaddd]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-156eaddd]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-156eaddd]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-156eaddd]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-156eaddd]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-156eaddd]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-156eaddd]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-156eaddd]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-156eaddd]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-156eaddd]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-156eaddd]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-156eaddd]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-156eaddd]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-156eaddd]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-156eaddd]{background:var(--c-primary)}#app .permission-code[data-v-156eaddd]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-156eaddd]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-156eaddd]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-156eaddd]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-156eaddd]{color:var(--c-text-primary)}#app .permission-desc[data-v-156eaddd]{color:var(--c-text-secondary)}#app .loading-container[data-v-156eaddd],#app .empty-container[data-v-156eaddd]{color:var(--c-text-muted)}.modal-overlay[data-v-156eaddd]{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box[data-v-156eaddd]{background:var(--c-bg-surface);border-radius:12px;width:440px;max-width:92vw;box-shadow:0 20px 60px #00000040;overflow:hidden}.modal-title[data-v-156eaddd]{font-size:1rem;font-weight:700;padding:18px 20px 14px;border-bottom:1px solid var(--c-border);color:var(--c-text-primary)}.modal-body[data-v-156eaddd]{padding:18px 20px}.modal-footer[data-v-156eaddd]{padding:12px 20px 18px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--c-border)}.form-group[data-v-156eaddd]{display:flex;flex-direction:column;gap:6px}.form-label[data-v-156eaddd]{font-size:.82rem;font-weight:600;color:var(--c-text-secondary)}.form-input[data-v-156eaddd]{padding:9px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.88rem;background:var(--c-bg-app);color:var(--c-text-primary);font-family:var(--font-base);outline:none;width:100%}.form-input[data-v-156eaddd]:focus{border-color:var(--c-primary)}.chip-group[data-v-156eaddd]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chip[data-v-156eaddd]{padding:7px 16px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.85rem;background:var(--c-bg-app);color:var(--c-text-primary);cursor:pointer;transition:border-color .18s,background .18s,color .18s}.chip[data-v-156eaddd]:hover{border-color:var(--c-primary)}.chip.active[data-v-156eaddd]{border-color:var(--c-primary);background:#6366f11a;color:var(--c-primary);font-weight:600}.chip-custom[data-v-156eaddd]{display:inline-flex;align-items:center;gap:4px;border:1.5px solid var(--c-border);border-radius:8px;padding:0 10px}.chip-custom input[data-v-156eaddd]{width:56px;border:none;outline:none;background:transparent;padding:7px 0;font-size:.85rem;color:var(--c-text-primary)}.chip-custom span[data-v-156eaddd]{color:var(--c-text-muted);font-size:.82rem}.upload-zone[data-v-156eaddd]{border:2px dashed var(--c-border);border-radius:10px;padding:24px 16px;text-align:center;cursor:pointer;transition:border-color .18s,background .18s;background:var(--c-bg-app);min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.upload-zone[data-v-156eaddd]:hover,.upload-zone--over[data-v-156eaddd]{border-color:var(--c-primary);background:#6366f10a}.upload-zone--filled[data-v-156eaddd]{padding:8px;border-style:solid;border-color:var(--c-primary)}.upload-icon[data-v-156eaddd]{font-size:2rem;line-height:1}.upload-hint[data-v-156eaddd]{font-size:.88rem;font-weight:600;color:var(--c-text-primary);margin:0}.upload-sub[data-v-156eaddd]{font-size:.76rem;color:var(--c-text-muted);margin:0}.upload-preview[data-v-156eaddd]{max-width:100%;max-height:200px;border-radius:6px;object-fit:contain}.upload-filename[data-v-156eaddd]{margin:6px 0 0;font-size:.76rem;color:var(--c-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.info-card[data-v-156eaddd]{background:var(--c-bg-app);border:1px solid var(--c-border);border-radius:10px;padding:14px 16px;margin-bottom:16px}.info-title[data-v-156eaddd]{font-size:.82rem;font-weight:700;color:var(--c-text-primary);margin-bottom:8px}.info-loading[data-v-156eaddd]{font-size:.82rem;color:var(--c-text-muted);padding:6px 0}.kv-row[data-v-156eaddd]{display:flex;justify-content:space-between;padding:5px 0;gap:12px}.kv-row .k[data-v-156eaddd]{font-size:.82rem;color:var(--c-text-muted);flex-shrink:0}.kv-row .v[data-v-156eaddd]{font-size:.82rem;color:var(--c-text-primary);font-weight:600;text-align:right;word-break:break-all}.pricing-head[data-v-156eaddd]{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ip-badge[data-v-156eaddd]{font-size:.7rem;font-weight:600;padding:2px 9px;border-radius:8px}.badge-success[data-v-156eaddd]{background:#10b9811f;color:#059669}.badge-warning[data-v-156eaddd]{background:#f59e0b24;color:#d97706}.preview[data-v-156eaddd]{margin-top:16px;background:var(--c-bg-app);border:1px solid var(--c-border);border-radius:10px;padding:12px 16px}.preview-row[data-v-156eaddd]{display:flex;justify-content:space-between;padding:4px 0}.preview-row .pl[data-v-156eaddd]{font-size:.84rem;color:var(--c-text-muted)}.preview-row .pv[data-v-156eaddd]{font-size:.95rem;font-weight:700}.preview-row .pv.success[data-v-156eaddd]{color:#10b981}.preview-row .pv.primary[data-v-156eaddd]{color:#6366f1}.view-container[data-v-c25e8fc0]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-c25e8fc0]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-c25e8fc0],.toolbar-right[data-v-c25e8fc0]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-c25e8fc0]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-c25e8fc0]:focus{border-color:var(--c-primary)}.select-input[data-v-c25e8fc0]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-c25e8fc0]:focus{border-color:var(--c-primary)}.btn[data-v-c25e8fc0]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-c25e8fc0]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-c25e8fc0]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-c25e8fc0]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-c25e8fc0]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-c25e8fc0]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-c25e8fc0]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-c25e8fc0]{background:#10b981;color:#fff}.btn-success[data-v-c25e8fc0]:hover:not(:disabled){background:#059669}.btn-danger[data-v-c25e8fc0]{background:#ef4444;color:#fff}.btn-danger[data-v-c25e8fc0]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-c25e8fc0]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-c25e8fc0]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-c25e8fc0]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-c25e8fc0]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-c25e8fc0]{border-bottom:none}.data-table tbody tr[data-v-c25e8fc0]:hover{background:var(--c-bg-mute)}.td-center[data-v-c25e8fc0]{text-align:center}.td-empty[data-v-c25e8fc0]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-c25e8fc0]{color:var(--c-text-muted)}.pagination[data-v-c25e8fc0]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-c25e8fc0]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-c25e8fc0]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-c25e8fc0]{background:#10b9811f;color:#10b981}.status-off[data-v-c25e8fc0]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-c25e8fc0],#app .roles-view[data-v-c25e8fc0],#app .user-groups-view[data-v-c25e8fc0],#app .permissions-view[data-v-c25e8fc0]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-c25e8fc0]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-c25e8fc0]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-c25e8fc0]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-c25e8fc0]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-c25e8fc0]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-c25e8fc0]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-c25e8fc0]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-c25e8fc0]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-c25e8fc0]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-c25e8fc0]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-c25e8fc0]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-c25e8fc0]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-c25e8fc0]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-c25e8fc0]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-c25e8fc0]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-c25e8fc0]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-c25e8fc0]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-c25e8fc0]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-c25e8fc0]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-c25e8fc0]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-c25e8fc0]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-c25e8fc0]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-c25e8fc0]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-c25e8fc0]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-c25e8fc0]{background:var(--c-primary)}#app .permission-code[data-v-c25e8fc0]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-c25e8fc0]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-c25e8fc0]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-c25e8fc0]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-c25e8fc0]{color:var(--c-text-primary)}#app .permission-desc[data-v-c25e8fc0]{color:var(--c-text-secondary)}#app .loading-container[data-v-c25e8fc0],#app .empty-container[data-v-c25e8fc0]{color:var(--c-text-muted)}.pending-banner[data-v-c25e8fc0]{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:10px 16px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;font-size:.88rem;color:#92400e;font-weight:500}.btn-link[data-v-c25e8fc0]{background:none;border:none;color:var(--c-text-muted);cursor:pointer;font-size:.82rem;text-decoration:underline}.td-mono[data-v-c25e8fc0]{font-family:var(--font-code);font-size:.78rem;white-space:nowrap}.td-title[data-v-c25e8fc0]{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-money[data-v-c25e8fc0]{font-weight:600;color:#10b981;white-space:nowrap}.td-date[data-v-c25e8fc0]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.td-id[data-v-c25e8fc0]{color:var(--c-text-muted);font-size:.82rem}.order-status[data-v-c25e8fc0]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.os-draft[data-v-c25e8fc0]{background:#f3f4f6;color:#6b7280}.os-pending_group[data-v-c25e8fc0]{background:#f59e0b1f;color:#d97706}.os-maintaining[data-v-c25e8fc0]{background:#6366f11f;color:#6366f1}.os-deposit_paid[data-v-c25e8fc0]{background:#10b9811f;color:#059669}.os-negotiating[data-v-c25e8fc0]{background:#818cf81f;color:#818cf8}.os-in_progress[data-v-c25e8fc0]{background:#3b82f61f;color:#3b82f6}.os-completed[data-v-c25e8fc0]{background:#10b98126;color:#065f46}.os-cancelled[data-v-c25e8fc0]{background:#ef44441a;color:#ef4444}.chip-yes[data-v-c25e8fc0]{color:#059669;font-size:.78rem;font-weight:600}.chip-no[data-v-c25e8fc0]{color:#d97706;font-size:.78rem;font-weight:600}.action-btns[data-v-c25e8fc0]{display:flex;gap:4px;flex-wrap:wrap}.btn-warning[data-v-c25e8fc0]{background:#f59e0b;color:#fff;border:none}.btn-warning[data-v-c25e8fc0]:hover{background:#d97706}.modal-overlay[data-v-c25e8fc0]{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box[data-v-c25e8fc0]{background:var(--c-bg-surface);border-radius:12px;width:440px;max-width:92vw;box-shadow:0 20px 60px #00000040;overflow:hidden}.modal-title[data-v-c25e8fc0]{font-size:1rem;font-weight:700;padding:18px 20px 14px;border-bottom:1px solid var(--c-border);color:var(--c-text-primary)}.modal-body[data-v-c25e8fc0]{padding:18px 20px}.modal-footer[data-v-c25e8fc0]{padding:12px 20px 18px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--c-border)}.form-group[data-v-c25e8fc0]{display:flex;flex-direction:column;gap:6px}.form-label[data-v-c25e8fc0]{font-size:.82rem;font-weight:600;color:var(--c-text-secondary)}.form-input[data-v-c25e8fc0]{padding:9px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.88rem;background:var(--c-bg-app);color:var(--c-text-primary);font-family:var(--font-base);outline:none;width:100%}.form-input[data-v-c25e8fc0]:focus{border-color:var(--c-primary)}.chip-group[data-v-c25e8fc0]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chip[data-v-c25e8fc0]{padding:7px 16px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.85rem;background:var(--c-bg-app);color:var(--c-text-primary);cursor:pointer;transition:border-color .18s,background .18s,color .18s}.chip[data-v-c25e8fc0]:hover{border-color:var(--c-primary)}.chip.active[data-v-c25e8fc0]{border-color:var(--c-primary);background:#6366f11a;color:var(--c-primary);font-weight:600}.chip-custom[data-v-c25e8fc0]{display:inline-flex;align-items:center;gap:4px;border:1.5px solid var(--c-border);border-radius:8px;padding:0 10px}.chip-custom input[data-v-c25e8fc0]{width:56px;border:none;outline:none;background:transparent;padding:7px 0;font-size:.85rem;color:var(--c-text-primary)}.chip-custom span[data-v-c25e8fc0]{color:var(--c-text-muted);font-size:.82rem}.upload-zone[data-v-c25e8fc0]{border:2px dashed var(--c-border);border-radius:10px;padding:24px 16px;text-align:center;cursor:pointer;transition:border-color .18s,background .18s;background:var(--c-bg-app);min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.upload-zone[data-v-c25e8fc0]:hover,.upload-zone--over[data-v-c25e8fc0]{border-color:var(--c-primary);background:#6366f10a}.upload-zone--filled[data-v-c25e8fc0]{padding:8px;border-style:solid;border-color:var(--c-primary)}.upload-icon[data-v-c25e8fc0]{font-size:2rem;line-height:1}.upload-hint[data-v-c25e8fc0]{font-size:.88rem;font-weight:600;color:var(--c-text-primary);margin:0}.upload-sub[data-v-c25e8fc0]{font-size:.76rem;color:var(--c-text-muted);margin:0}.upload-preview[data-v-c25e8fc0]{max-width:100%;max-height:200px;border-radius:6px;object-fit:contain}.upload-filename[data-v-c25e8fc0]{margin:6px 0 0;font-size:.76rem;color:var(--c-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-container[data-v-3e5fdb3c]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-3e5fdb3c]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-3e5fdb3c],.toolbar-right[data-v-3e5fdb3c]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-3e5fdb3c]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-3e5fdb3c]:focus{border-color:var(--c-primary)}.select-input[data-v-3e5fdb3c]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-3e5fdb3c]:focus{border-color:var(--c-primary)}.btn[data-v-3e5fdb3c]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-3e5fdb3c]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-3e5fdb3c]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-3e5fdb3c]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-3e5fdb3c]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-3e5fdb3c]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-3e5fdb3c]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-3e5fdb3c]{background:#10b981;color:#fff}.btn-success[data-v-3e5fdb3c]:hover:not(:disabled){background:#059669}.btn-danger[data-v-3e5fdb3c]{background:#ef4444;color:#fff}.btn-danger[data-v-3e5fdb3c]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-3e5fdb3c]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-3e5fdb3c]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-3e5fdb3c]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-3e5fdb3c]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-3e5fdb3c]{border-bottom:none}.data-table tbody tr[data-v-3e5fdb3c]:hover{background:var(--c-bg-mute)}.td-center[data-v-3e5fdb3c]{text-align:center}.td-empty[data-v-3e5fdb3c]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-3e5fdb3c]{color:var(--c-text-muted)}.pagination[data-v-3e5fdb3c]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-3e5fdb3c]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-3e5fdb3c]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-3e5fdb3c]{background:#10b9811f;color:#10b981}.status-off[data-v-3e5fdb3c]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-3e5fdb3c],#app .roles-view[data-v-3e5fdb3c],#app .user-groups-view[data-v-3e5fdb3c],#app .permissions-view[data-v-3e5fdb3c]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-3e5fdb3c]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-3e5fdb3c]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-3e5fdb3c]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-3e5fdb3c]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-3e5fdb3c]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-3e5fdb3c]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-3e5fdb3c]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-3e5fdb3c]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-3e5fdb3c]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-3e5fdb3c]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-3e5fdb3c]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-3e5fdb3c]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-3e5fdb3c]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-3e5fdb3c]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-3e5fdb3c]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-3e5fdb3c]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-3e5fdb3c]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-3e5fdb3c]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-3e5fdb3c]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-3e5fdb3c]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-3e5fdb3c]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-3e5fdb3c]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-3e5fdb3c]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-3e5fdb3c]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-3e5fdb3c]{background:var(--c-primary)}#app .permission-code[data-v-3e5fdb3c]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-3e5fdb3c]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-3e5fdb3c]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-3e5fdb3c]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-3e5fdb3c]{color:var(--c-text-primary)}#app .permission-desc[data-v-3e5fdb3c]{color:var(--c-text-secondary)}#app .loading-container[data-v-3e5fdb3c],#app .empty-container[data-v-3e5fdb3c]{color:var(--c-text-muted)}.tabs[data-v-3e5fdb3c]{display:flex;gap:6px;flex-wrap:wrap}.tab[data-v-3e5fdb3c]{padding:7px 16px;border:1.5px solid var(--c-border);border-radius:8px;background:var(--c-bg-surface);color:var(--c-text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .18s}.tab[data-v-3e5fdb3c]:hover{border-color:var(--c-primary);color:var(--c-primary)}.tab.active[data-v-3e5fdb3c]{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.tab-badge[data-v-3e5fdb3c]{background:#ef4444e6;color:#fff;border-radius:10px;font-size:.7rem;padding:0 6px;min-width:18px;text-align:center}.tab.active .tab-badge[data-v-3e5fdb3c]{background:#ffffff4d}.td-mono[data-v-3e5fdb3c]{font-family:var(--font-code);font-size:.78rem;white-space:nowrap}.td-title[data-v-3e5fdb3c]{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-money[data-v-3e5fdb3c]{font-weight:600;color:#10b981;white-space:nowrap}.td-date[data-v-3e5fdb3c]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.pt-tag[data-v-3e5fdb3c]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.pt-confirm[data-v-3e5fdb3c]{background:#818cf824;color:#6366f1}.pt-group[data-v-3e5fdb3c]{background:#f59e0b24;color:#d97706}.pt-pricing[data-v-3e5fdb3c]{background:#3b82f624;color:#3b82f6}.pt-settle[data-v-3e5fdb3c]{background:#10b98124;color:#059669}.confirm-state[data-v-3e5fdb3c]{display:flex;gap:6px;margin-top:5px}.confirm-state span[data-v-3e5fdb3c]{font-size:.68rem;padding:1px 6px;border-radius:6px}.cf-yes[data-v-3e5fdb3c]{background:#10b9811f;color:#059669}.cf-no[data-v-3e5fdb3c]{background:#ef44441a;color:#ef4444}.action-btns[data-v-3e5fdb3c]{display:flex;gap:4px;flex-wrap:wrap}.btn-warning[data-v-3e5fdb3c]{background:#f59e0b;color:#fff;border:none}.btn-warning[data-v-3e5fdb3c]:hover{background:#d97706}.view-container[data-v-910936d6]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-910936d6]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-910936d6],.toolbar-right[data-v-910936d6]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-910936d6]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-910936d6]:focus{border-color:var(--c-primary)}.select-input[data-v-910936d6]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-910936d6]:focus{border-color:var(--c-primary)}.btn[data-v-910936d6]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-910936d6]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-910936d6]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-910936d6]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-910936d6]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-910936d6]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-910936d6]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-910936d6]{background:#10b981;color:#fff}.btn-success[data-v-910936d6]:hover:not(:disabled){background:#059669}.btn-danger[data-v-910936d6]{background:#ef4444;color:#fff}.btn-danger[data-v-910936d6]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-910936d6]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-910936d6]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-910936d6]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-910936d6]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-910936d6]{border-bottom:none}.data-table tbody tr[data-v-910936d6]:hover{background:var(--c-bg-mute)}.td-center[data-v-910936d6]{text-align:center}.td-empty[data-v-910936d6]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-910936d6]{color:var(--c-text-muted)}.pagination[data-v-910936d6]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-910936d6]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-910936d6]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-910936d6]{background:#10b9811f;color:#10b981}.status-off[data-v-910936d6]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-910936d6],#app .roles-view[data-v-910936d6],#app .user-groups-view[data-v-910936d6],#app .permissions-view[data-v-910936d6]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-910936d6]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-910936d6]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-910936d6]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-910936d6]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-910936d6]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-910936d6]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-910936d6]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-910936d6]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-910936d6]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-910936d6]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-910936d6]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-910936d6]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-910936d6]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-910936d6]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-910936d6]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-910936d6]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-910936d6]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-910936d6]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-910936d6]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-910936d6]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-910936d6]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-910936d6]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-910936d6]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-910936d6]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-910936d6]{background:var(--c-primary)}#app .permission-code[data-v-910936d6]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-910936d6]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-910936d6]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-910936d6]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-910936d6]{color:var(--c-text-primary)}#app .permission-desc[data-v-910936d6]{color:var(--c-text-secondary)}#app .loading-container[data-v-910936d6],#app .empty-container[data-v-910936d6]{color:var(--c-text-muted)}.scope-switch[data-v-910936d6]{display:inline-flex;border:1.5px solid var(--c-border);border-radius:8px;overflow:hidden}.scope-switch button[data-v-910936d6]{padding:7px 18px;border:none;background:var(--c-bg-surface);color:var(--c-text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .18s}.scope-switch button.active[data-v-910936d6]{background:var(--c-primary);color:#fff}.sum-grid[data-v-910936d6]{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}@media(max-width:900px){.sum-grid[data-v-910936d6]{grid-template-columns:1fr}}.sum-card[data-v-910936d6]{border-radius:12px;padding:20px 22px;color:#fff}.sum-card--income[data-v-910936d6]{background:linear-gradient(135deg,#6366f1,#818cf8)}.sum-card--settled[data-v-910936d6]{background:linear-gradient(135deg,#10b981,#34d399)}.sum-card--pending[data-v-910936d6]{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.sum-label[data-v-910936d6]{font-size:.85rem;opacity:.9}.sum-value[data-v-910936d6]{font-size:1.7rem;font-weight:800;margin:6px 0 4px}.sum-tip[data-v-910936d6]{font-size:.74rem;opacity:.8}.section-head[data-v-910936d6]{margin-bottom:12px}.section-title[data-v-910936d6]{font-size:1rem;font-weight:700;color:var(--c-text-primary)}.td-mono[data-v-910936d6]{font-family:var(--font-code);font-size:.78rem;white-space:nowrap}.td-title[data-v-910936d6]{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-money[data-v-910936d6]{font-weight:600;color:#10b981;white-space:nowrap}.td-date[data-v-910936d6]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.cm-status[data-v-910936d6]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.cm-settled[data-v-910936d6]{background:#10b9811f;color:#059669}.cm-pending[data-v-910936d6]{background:#f59e0b1f;color:#d97706}.view-container[data-v-e103d713]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-e103d713]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-e103d713],.toolbar-right[data-v-e103d713]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-e103d713]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-e103d713]:focus{border-color:var(--c-primary)}.select-input[data-v-e103d713]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-e103d713]:focus{border-color:var(--c-primary)}.btn[data-v-e103d713]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-e103d713]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-e103d713]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-e103d713]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-e103d713]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-e103d713]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-e103d713]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-e103d713]{background:#10b981;color:#fff}.btn-success[data-v-e103d713]:hover:not(:disabled){background:#059669}.btn-danger[data-v-e103d713]{background:#ef4444;color:#fff}.btn-danger[data-v-e103d713]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-e103d713]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-e103d713]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-e103d713]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-e103d713]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-e103d713]{border-bottom:none}.data-table tbody tr[data-v-e103d713]:hover{background:var(--c-bg-mute)}.td-center[data-v-e103d713]{text-align:center}.td-empty[data-v-e103d713]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-e103d713]{color:var(--c-text-muted)}.pagination[data-v-e103d713]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-e103d713]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-e103d713]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-e103d713]{background:#10b9811f;color:#10b981}.status-off[data-v-e103d713]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-e103d713],#app .roles-view[data-v-e103d713],#app .user-groups-view[data-v-e103d713],#app .permissions-view[data-v-e103d713]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-e103d713]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-e103d713]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-e103d713]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-e103d713]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-e103d713]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-e103d713]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-e103d713]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-e103d713]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-e103d713]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-e103d713]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-e103d713]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-e103d713]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-e103d713]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-e103d713]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-e103d713]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-e103d713]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-e103d713]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-e103d713]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-e103d713]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-e103d713]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-e103d713]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-e103d713]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-e103d713]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-e103d713]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-e103d713]{background:var(--c-primary)}#app .permission-code[data-v-e103d713]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-e103d713]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-e103d713]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-e103d713]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-e103d713]{color:var(--c-text-primary)}#app .permission-desc[data-v-e103d713]{color:var(--c-text-secondary)}#app .loading-container[data-v-e103d713],#app .empty-container[data-v-e103d713]{color:var(--c-text-muted)}.stat-chips[data-v-e103d713]{display:flex;gap:8px}.stat-chip[data-v-e103d713]{padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600}.chip-total[data-v-e103d713]{background:#10b9811a;color:#059669}.chip-count[data-v-e103d713]{background:#6366f11a;color:#6366f1}.chip-paid[data-v-e103d713]{background:#10b9811a;color:#059669}.chip-pending[data-v-e103d713]{background:#f59e0b1f;color:#d97706}.cell-title[data-v-e103d713]{font-size:.85rem;color:var(--c-text-primary)}.cell-sub[data-v-e103d713]{font-family:var(--font-code);font-size:.72rem;color:var(--c-text-muted);margin-top:2px}.td-mono[data-v-e103d713]{font-family:var(--font-code);font-size:.78rem;white-space:nowrap}.td-money[data-v-e103d713]{font-weight:700;white-space:nowrap}.money-in[data-v-e103d713]{color:#10b981}.money-out[data-v-e103d713]{color:#ef4444}.money-pending[data-v-e103d713]{color:#9ca3af}.td-date[data-v-e103d713]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.td-id[data-v-e103d713]{color:var(--c-text-muted);font-size:.82rem}.dir-badge[data-v-e103d713]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.dir-in[data-v-e103d713]{background:#10b9811f;color:#059669}.dir-out[data-v-e103d713]{background:#ef44441f;color:#ef4444}.dir-ref[data-v-e103d713]{background:#f59e0b1f;color:#d97706}.status-fail[data-v-e103d713]{background:#ef44441a;color:#ef4444}.status-warn[data-v-e103d713]{background:#f59e0b1a;color:#d97706}.biz-badge[data-v-e103d713]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.biz-dev[data-v-e103d713]{background:#6366f11f;color:#6366f1}.biz-maint[data-v-e103d713]{background:#f59e0b1f;color:#d97706}.view-container[data-v-54a1ae39]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-54a1ae39]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-54a1ae39],.toolbar-right[data-v-54a1ae39]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-54a1ae39]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-54a1ae39]:focus{border-color:var(--c-primary)}.select-input[data-v-54a1ae39]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-54a1ae39]:focus{border-color:var(--c-primary)}.btn[data-v-54a1ae39]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-54a1ae39]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-54a1ae39]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-54a1ae39]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-54a1ae39]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-54a1ae39]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-54a1ae39]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-54a1ae39]{background:#10b981;color:#fff}.btn-success[data-v-54a1ae39]:hover:not(:disabled){background:#059669}.btn-danger[data-v-54a1ae39]{background:#ef4444;color:#fff}.btn-danger[data-v-54a1ae39]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-54a1ae39]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-54a1ae39]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-54a1ae39]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-54a1ae39]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-54a1ae39]{border-bottom:none}.data-table tbody tr[data-v-54a1ae39]:hover{background:var(--c-bg-mute)}.td-center[data-v-54a1ae39]{text-align:center}.td-empty[data-v-54a1ae39]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-54a1ae39]{color:var(--c-text-muted)}.pagination[data-v-54a1ae39]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-54a1ae39]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-54a1ae39]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-54a1ae39]{background:#10b9811f;color:#10b981}.status-off[data-v-54a1ae39]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-54a1ae39],#app .roles-view[data-v-54a1ae39],#app .user-groups-view[data-v-54a1ae39],#app .permissions-view[data-v-54a1ae39]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-54a1ae39]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-54a1ae39]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-54a1ae39]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-54a1ae39]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-54a1ae39]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-54a1ae39]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-54a1ae39]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-54a1ae39]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-54a1ae39]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-54a1ae39]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-54a1ae39]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-54a1ae39]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-54a1ae39]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-54a1ae39]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-54a1ae39]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-54a1ae39]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-54a1ae39]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-54a1ae39]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-54a1ae39]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-54a1ae39]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-54a1ae39]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-54a1ae39]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-54a1ae39]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-54a1ae39]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-54a1ae39]{background:var(--c-primary)}#app .permission-code[data-v-54a1ae39]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-54a1ae39]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-54a1ae39]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-54a1ae39]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-54a1ae39]{color:var(--c-text-primary)}#app .permission-desc[data-v-54a1ae39]{color:var(--c-text-secondary)}#app .loading-container[data-v-54a1ae39],#app .empty-container[data-v-54a1ae39]{color:var(--c-text-muted)}.stat-cards[data-v-54a1ae39]{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}.stat-card[data-v-54a1ae39]{background:var(--c-bg-card, #fff);border:1px solid var(--c-border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.sc-label[data-v-54a1ae39]{font-size:.74rem;color:var(--c-text-muted)}.sc-num[data-v-54a1ae39]{font-size:1.2rem;font-weight:800;color:var(--c-text-primary)}.sc-num.green[data-v-54a1ae39]{color:#10b981}.sc-num.primary[data-v-54a1ae39]{color:#6366f1}.sc-num.red[data-v-54a1ae39]{color:#ef4444}.sc-num.orange[data-v-54a1ae39]{color:#d97706}.sc-num.gray[data-v-54a1ae39]{color:#9ca3af}.filters[data-v-54a1ae39]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.filters .select-input[data-v-54a1ae39]{min-width:96px}.sep[data-v-54a1ae39]{color:var(--c-text-muted);font-size:.82rem}.td-date[data-v-54a1ae39]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.cell-no[data-v-54a1ae39]{font-family:var(--font-code);font-size:.78rem;color:#6366f1;cursor:pointer}.cell-no[data-v-54a1ae39]:hover{text-decoration:underline}.cell-title[data-v-54a1ae39]{font-size:.8rem;color:var(--c-text-primary);margin-top:2px}.td-money[data-v-54a1ae39]{font-weight:700;white-space:nowrap}.money-in[data-v-54a1ae39]{color:#10b981}.money-out[data-v-54a1ae39]{color:#ef4444}.money-pending[data-v-54a1ae39]{color:#9ca3af}.dir-badge[data-v-54a1ae39]{display:inline-block;padding:3px 9px;border-radius:10px;font-size:.75rem;font-weight:600}.dir-in[data-v-54a1ae39]{background:#10b9811f;color:#059669}.dir-out[data-v-54a1ae39]{background:#ef44441f;color:#ef4444}.dir-ref[data-v-54a1ae39]{background:#f59e0b1f;color:#d97706}.status-fail[data-v-54a1ae39]{background:#ef44441a;color:#ef4444}.status-warn[data-v-54a1ae39]{background:#f59e0b1a;color:#d97706}.view-container[data-v-e684b1ce]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-e684b1ce]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-e684b1ce],.toolbar-right[data-v-e684b1ce]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-e684b1ce]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-e684b1ce]:focus{border-color:var(--c-primary)}.select-input[data-v-e684b1ce]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-e684b1ce]:focus{border-color:var(--c-primary)}.btn[data-v-e684b1ce]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-e684b1ce]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-e684b1ce]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-e684b1ce]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-e684b1ce]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-e684b1ce]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-e684b1ce]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-e684b1ce]{background:#10b981;color:#fff}.btn-success[data-v-e684b1ce]:hover:not(:disabled){background:#059669}.btn-danger[data-v-e684b1ce]{background:#ef4444;color:#fff}.btn-danger[data-v-e684b1ce]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-e684b1ce]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-e684b1ce]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-e684b1ce]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-e684b1ce]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-e684b1ce]{border-bottom:none}.data-table tbody tr[data-v-e684b1ce]:hover{background:var(--c-bg-mute)}.td-center[data-v-e684b1ce]{text-align:center}.td-empty[data-v-e684b1ce]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-e684b1ce]{color:var(--c-text-muted)}.pagination[data-v-e684b1ce]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-e684b1ce]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-e684b1ce]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-e684b1ce]{background:#10b9811f;color:#10b981}.status-off[data-v-e684b1ce]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-e684b1ce],#app .roles-view[data-v-e684b1ce],#app .user-groups-view[data-v-e684b1ce],#app .permissions-view[data-v-e684b1ce]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-e684b1ce]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-e684b1ce]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-e684b1ce]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-e684b1ce]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-e684b1ce]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-e684b1ce]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-e684b1ce]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-e684b1ce]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-e684b1ce]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-e684b1ce]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-e684b1ce]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-e684b1ce]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-e684b1ce]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-e684b1ce]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-e684b1ce]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-e684b1ce]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-e684b1ce]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-e684b1ce]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-e684b1ce]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-e684b1ce]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-e684b1ce]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-e684b1ce]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-e684b1ce]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-e684b1ce]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-e684b1ce]{background:var(--c-primary)}#app .permission-code[data-v-e684b1ce]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-e684b1ce]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-e684b1ce]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-e684b1ce]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-e684b1ce]{color:var(--c-text-primary)}#app .permission-desc[data-v-e684b1ce]{color:var(--c-text-secondary)}#app .loading-container[data-v-e684b1ce],#app .empty-container[data-v-e684b1ce]{color:var(--c-text-muted)}.chat-layout[data-v-e684b1ce]{display:flex;height:100%;background:var(--c-bg-app)}.conv-panel[data-v-e684b1ce]{width:300px;flex-shrink:0;border-right:1px solid var(--c-border);display:flex;flex-direction:column;background:var(--c-bg-surface)}.conv-search[data-v-e684b1ce]{padding:12px;border-bottom:1px solid var(--c-border)}.conv-search .search-input[data-v-e684b1ce]{width:100%;min-width:0}.conv-list[data-v-e684b1ce]{flex:1;overflow-y:auto}.conv-empty[data-v-e684b1ce]{padding:30px 0;text-align:center;color:var(--c-text-muted);font-size:.85rem}.conv-item[data-v-e684b1ce]{display:flex;gap:10px;padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--c-border);transition:background .15s}.conv-item[data-v-e684b1ce]:hover{background:var(--c-bg-mute)}.conv-item.active[data-v-e684b1ce]{background:#6366f114}.conv-avatar[data-v-e684b1ce]{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden}.conv-avatar img[data-v-e684b1ce]{width:100%;height:100%;object-fit:cover}.conv-main[data-v-e684b1ce]{flex:1;min-width:0}.conv-top[data-v-e684b1ce]{display:flex;justify-content:space-between;align-items:center;gap:8px}.conv-name[data-v-e684b1ce]{font-size:.88rem;font-weight:600;color:var(--c-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-time[data-v-e684b1ce]{font-size:.7rem;color:var(--c-text-muted);flex-shrink:0}.conv-bottom[data-v-e684b1ce]{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:2px}.conv-last[data-v-e684b1ce]{font-size:.78rem;color:var(--c-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-badge[data-v-e684b1ce]{background:#ef4444;color:#fff;border-radius:10px;font-size:.68rem;font-weight:700;padding:0 6px;min-width:18px;text-align:center;flex-shrink:0}.conv-tags[data-v-e684b1ce]{display:flex;gap:6px;margin-top:4px}.conv-role[data-v-e684b1ce]{font-size:.66rem;padding:1px 6px;border-radius:6px}.role-customer[data-v-e684b1ce]{background:#6366f11f;color:#6366f1}.role-engineer[data-v-e684b1ce]{background:#10b9811f;color:#059669}.conv-order[data-v-e684b1ce]{font-size:.66rem;padding:1px 6px;border-radius:6px;background:var(--c-bg-mute);color:var(--c-text-muted)}.chat-panel[data-v-e684b1ce]{flex:1;display:flex;flex-direction:column;min-width:0}.chat-header[data-v-e684b1ce]{height:56px;flex-shrink:0;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:var(--c-bg-surface)}.chat-peer[data-v-e684b1ce]{display:flex;align-items:center;gap:10px}.chat-peer-name[data-v-e684b1ce]{font-size:.95rem;font-weight:700;color:var(--c-text-primary)}.chat-peer-role[data-v-e684b1ce]{font-size:.7rem;padding:1px 8px;border-radius:8px}.chat-order[data-v-e684b1ce]{font-size:.76rem;color:var(--c-text-muted)}.chat-body[data-v-e684b1ce]{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px}.chat-loading[data-v-e684b1ce]{text-align:center;color:var(--c-text-muted);font-size:.85rem}.msg-row[data-v-e684b1ce]{display:flex;flex-direction:column;max-width:70%}.msg-row.theirs[data-v-e684b1ce]{align-self:flex-start;align-items:flex-start}.msg-row.mine[data-v-e684b1ce]{align-self:flex-end;align-items:flex-end}.msg-bubble[data-v-e684b1ce]{padding:9px 13px;border-radius:12px;font-size:.88rem;line-height:1.5;word-break:break-word}.msg-row.theirs .msg-bubble[data-v-e684b1ce]{background:var(--c-bg-surface);border:1px solid var(--c-border);color:var(--c-text-primary);border-top-left-radius:4px}.msg-row.mine .msg-bubble[data-v-e684b1ce]{background:var(--c-primary);color:#fff;border-top-right-radius:4px}.msg-text[data-v-e684b1ce]{white-space:pre-wrap}.msg-image[data-v-e684b1ce]{max-width:220px;max-height:220px;border-radius:8px;cursor:pointer;display:block}.msg-order[data-v-e684b1ce]{min-width:160px}.msg-order-title[data-v-e684b1ce]{font-weight:600}.msg-order-no[data-v-e684b1ce]{font-size:.74rem;opacity:.8;margin-top:2px}.msg-time[data-v-e684b1ce]{font-size:.66rem;color:var(--c-text-muted);margin-top:4px}.chat-input[data-v-e684b1ce]{flex-shrink:0;border-top:1px solid var(--c-border);padding:12px 16px;display:flex;align-items:flex-end;gap:10px;background:var(--c-bg-surface)}.icon-btn[data-v-e684b1ce]{background:none;border:1.5px solid var(--c-border);border-radius:8px;width:38px;height:38px;font-size:1.1rem;cursor:pointer;flex-shrink:0}.icon-btn[data-v-e684b1ce]:hover{border-color:var(--c-primary)}.input-box[data-v-e684b1ce]{flex:1;resize:none;border:1.5px solid var(--c-border);border-radius:8px;padding:9px 12px;font-size:.88rem;font-family:var(--font-base);outline:none;background:var(--c-bg-app);color:var(--c-text-primary);max-height:120px}.input-box[data-v-e684b1ce]:focus{border-color:var(--c-primary)}.chat-placeholder[data-v-e684b1ce]{flex:1;display:flex;align-items:center;justify-content:center;color:var(--c-text-muted);font-size:.9rem}.img-overlay[data-v-e684b1ce]{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;cursor:zoom-out}.img-overlay img[data-v-e684b1ce]{max-width:90vw;max-height:90vh;border-radius:8px}.view-container[data-v-d9faa158]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-d9faa158]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-d9faa158],.toolbar-right[data-v-d9faa158]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-d9faa158]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-d9faa158]:focus{border-color:var(--c-primary)}.select-input[data-v-d9faa158]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-d9faa158]:focus{border-color:var(--c-primary)}.btn[data-v-d9faa158]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-d9faa158]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-d9faa158]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-d9faa158]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-d9faa158]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-d9faa158]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-d9faa158]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-d9faa158]{background:#10b981;color:#fff}.btn-success[data-v-d9faa158]:hover:not(:disabled){background:#059669}.btn-danger[data-v-d9faa158]{background:#ef4444;color:#fff}.btn-danger[data-v-d9faa158]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-d9faa158]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-d9faa158]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-d9faa158]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-d9faa158]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-d9faa158]{border-bottom:none}.data-table tbody tr[data-v-d9faa158]:hover{background:var(--c-bg-mute)}.td-center[data-v-d9faa158]{text-align:center}.td-empty[data-v-d9faa158]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-d9faa158]{color:var(--c-text-muted)}.pagination[data-v-d9faa158]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-d9faa158]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-d9faa158]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-d9faa158]{background:#10b9811f;color:#10b981}.status-off[data-v-d9faa158]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-d9faa158],#app .roles-view[data-v-d9faa158],#app .user-groups-view[data-v-d9faa158],#app .permissions-view[data-v-d9faa158]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-d9faa158]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-d9faa158]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-d9faa158]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-d9faa158]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-d9faa158]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-d9faa158]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-d9faa158]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-d9faa158]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-d9faa158]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-d9faa158]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-d9faa158]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-d9faa158]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-d9faa158]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-d9faa158]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-d9faa158]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-d9faa158]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-d9faa158]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-d9faa158]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-d9faa158]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-d9faa158]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-d9faa158]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-d9faa158]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-d9faa158]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-d9faa158]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-d9faa158]{background:var(--c-primary)}#app .permission-code[data-v-d9faa158]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-d9faa158]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-d9faa158]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-d9faa158]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-d9faa158]{color:var(--c-text-primary)}#app .permission-desc[data-v-d9faa158]{color:var(--c-text-secondary)}#app .loading-container[data-v-d9faa158],#app .empty-container[data-v-d9faa158]{color:var(--c-text-muted)}.tree-table .tree-row-l1[data-v-d9faa158]{background:#6366f10a}.tree-table .tree-row-l2[data-v-d9faa158]{background:var(--c-bg-surface)}.tree-table .row-inactive[data-v-d9faa158]{opacity:.72}.tree-table .row-inactive .cat-l1[data-v-d9faa158],.tree-table .row-inactive .cat-l2[data-v-d9faa158]{color:var(--c-text-muted);text-decoration:line-through;text-decoration-color:#94a3b899}.tree-name[data-v-d9faa158]{display:flex;align-items:center;gap:8px}.tree-name-child[data-v-d9faa158]{padding-left:18px}.tree-toggle[data-v-d9faa158],.tree-toggle-placeholder[data-v-d9faa158]{width:18px;flex-shrink:0}.tree-toggle[data-v-d9faa158]{border:none;background:transparent;color:var(--c-text-muted);cursor:pointer;padding:0;font-size:.72rem;line-height:1}.tree-branch[data-v-d9faa158]{color:var(--c-text-muted);font-family:monospace}.cat-l1[data-v-d9faa158]{font-weight:700;color:var(--c-text-primary)}.cat-l2[data-v-d9faa158]{color:var(--c-text-secondary)}.level-badge[data-v-d9faa158]{display:inline-block;padding:2px 8px;border-radius:8px;font-size:.75rem;font-weight:600}.lv1[data-v-d9faa158]{background:#6366f11f;color:#6366f1}.lv2[data-v-d9faa158]{background:#10b9811f;color:#059669}.required[data-v-d9faa158]{color:#ef4444}.check-label[data-v-d9faa158]{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--c-text-secondary);cursor:pointer}.td-date[data-v-d9faa158]{white-space:nowrap;font-size:.8rem;color:var(--c-text-muted)}.td-id[data-v-d9faa158]{color:var(--c-text-muted);font-size:.82rem}.modal-overlay[data-v-d9faa158]{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box[data-v-d9faa158]{background:var(--c-bg-surface);border-radius:12px;width:440px;max-width:92vw;box-shadow:0 20px 60px #00000040;overflow:hidden}.modal-title[data-v-d9faa158]{font-size:1rem;font-weight:700;padding:18px 20px 14px;border-bottom:1px solid var(--c-border);color:var(--c-text-primary)}.modal-body[data-v-d9faa158]{padding:18px 20px}.modal-footer[data-v-d9faa158]{padding:12px 20px 18px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--c-border)}.form-group[data-v-d9faa158]{display:flex;flex-direction:column;gap:6px}.form-label[data-v-d9faa158]{font-size:.82rem;font-weight:600;color:var(--c-text-secondary)}.form-input[data-v-d9faa158]{padding:9px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.88rem;background:var(--c-bg-app);color:var(--c-text-primary);font-family:var(--font-base);outline:none;width:100%}.form-input[data-v-d9faa158]:focus{border-color:var(--c-primary)}.settings-card[data-v-cb0557e7]{max-width:640px;margin:20px;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);overflow:hidden}.card-head[data-v-cb0557e7]{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--c-border)}.card-title[data-v-cb0557e7]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary)}.card-sub[data-v-cb0557e7]{font-size:.8rem;color:var(--c-text-muted);margin-top:4px}.status-pill[data-v-cb0557e7]{font-size:.72rem;font-weight:600;padding:3px 12px;border-radius:var(--radius-full, 999px);flex-shrink:0}.status-pill.on[data-v-cb0557e7]{background:#10b9811f;color:#059669}.status-pill.off[data-v-cb0557e7]{background:#6b72801f;color:#6b7280}.card-body[data-v-cb0557e7]{padding:24px}.form-group[data-v-cb0557e7]{margin-bottom:18px}.form-label[data-v-cb0557e7]{display:block;font-size:.82rem;font-weight:600;color:var(--c-text-secondary);margin-bottom:8px}.form-input[data-v-cb0557e7]{width:100%;box-sizing:border-box;padding:9px 12px;border:1px solid var(--c-border);border-radius:var(--radius-md, 8px);font-size:.875rem}.form-hint[data-v-cb0557e7]{font-size:.72rem;color:var(--c-text-muted);margin-top:6px}.form-hint a[data-v-cb0557e7]{color:var(--c-primary)}.check-label[data-v-cb0557e7]{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;cursor:pointer}.actions[data-v-cb0557e7]{display:flex;gap:12px;margin-top:8px}.test-result[data-v-cb0557e7]{margin-top:16px;padding:10px 14px;border-radius:var(--radius-md, 8px);font-size:.82rem}.test-result.ok[data-v-cb0557e7]{background:#10b9811a;color:#059669}.test-result.fail[data-v-cb0557e7]{background:#ef44441a;color:#dc2626}.td-center[data-v-cb0557e7]{text-align:center;color:var(--c-text-muted)}.view-container[data-v-8e8472ef]{padding:22px;background:var(--c-bg-app);min-height:100%}.toolbar[data-v-8e8472ef]{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-8e8472ef],.toolbar-right[data-v-8e8472ef]{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input[data-v-8e8472ef]{padding:8px 14px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;min-width:200px;transition:border-color .18s}.search-input[data-v-8e8472ef]:focus{border-color:var(--c-primary)}.select-input[data-v-8e8472ef]{padding:8px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.875rem;background:var(--c-bg-surface);color:var(--c-text-primary);font-family:var(--font-base);outline:none;cursor:pointer;transition:border-color .18s}.select-input[data-v-8e8472ef]:focus{border-color:var(--c-primary)}.btn[data-v-8e8472ef]{padding:8px 16px;border-radius:8px;font-size:.875rem;font-weight:600;font-family:var(--font-base);border:none;cursor:pointer;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn[data-v-8e8472ef]:disabled{opacity:.55;cursor:not-allowed}.btn-sm[data-v-8e8472ef]{padding:5px 11px;font-size:.78rem}.btn-primary[data-v-8e8472ef]{background:var(--c-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary[data-v-8e8472ef]:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.btn-default[data-v-8e8472ef]{background:var(--c-bg-surface);color:var(--c-text-secondary);border:1.5px solid var(--c-border)}.btn-default[data-v-8e8472ef]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary)}.btn-success[data-v-8e8472ef]{background:#10b981;color:#fff}.btn-success[data-v-8e8472ef]:hover:not(:disabled){background:#059669}.btn-danger[data-v-8e8472ef]{background:#ef4444;color:#fff}.btn-danger[data-v-8e8472ef]:hover:not(:disabled){background:#dc2626}.table-wrap[data-v-8e8472ef]{overflow-x:auto;border-radius:10px;border:1px solid var(--c-border);background:var(--c-bg-surface);margin-bottom:16px}.data-table[data-v-8e8472ef]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}.data-table th[data-v-8e8472ef]{background:var(--c-primary-light, rgba(99,102,241,.07));color:var(--c-text-secondary);padding:11px 12px;text-align:left;font-weight:600;font-size:.8rem;border-bottom:1.5px solid var(--c-border);white-space:nowrap}.data-table td[data-v-8e8472ef]{padding:11px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text-primary);font-size:.875rem}.data-table tr:last-child td[data-v-8e8472ef]{border-bottom:none}.data-table tbody tr[data-v-8e8472ef]:hover{background:var(--c-bg-mute)}.td-center[data-v-8e8472ef]{text-align:center}.td-empty[data-v-8e8472ef]{color:var(--c-text-muted);font-size:.875rem;padding:32px!important}.td-muted[data-v-8e8472ef]{color:var(--c-text-muted)}.pagination[data-v-8e8472ef]{display:flex;align-items:center;gap:12px;justify-content:flex-end}.page-info[data-v-8e8472ef]{font-size:.85rem;color:var(--c-text-muted)}.status-badge[data-v-8e8472ef]{display:inline-block;padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:600}.status-on[data-v-8e8472ef]{background:#10b9811f;color:#10b981}.status-off[data-v-8e8472ef]{background:#ef44441a;color:#ef4444}#app .users-view[data-v-8e8472ef],#app .roles-view[data-v-8e8472ef],#app .user-groups-view[data-v-8e8472ef],#app .permissions-view[data-v-8e8472ef]{padding:22px;background:var(--c-bg-app);min-height:100%}#app .card[data-v-8e8472ef]{background:var(--c-bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:18px;border:1px solid var(--c-border)}#app .card-header[data-v-8e8472ef]{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}#app .card-title[data-v-8e8472ef]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}#app .primary-button[data-v-8e8472ef]{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary);padding:9px 18px;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s;box-shadow:none}#app .primary-button[data-v-8e8472ef]:hover{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);transform:translateY(-1px);box-shadow:0 0 0 2px #6366f11f,0 0 12px #6366f147}#app .table-container[data-v-8e8472ef]{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--c-border)}#app .data-table[data-v-8e8472ef]{width:100%;border-collapse:collapse;background:var(--c-bg-surface)}#app .data-table th[data-v-8e8472ef]{background:var(--c-primary-light);color:var(--c-primary-text);padding:11px 10px;text-align:center;font-weight:600;font-size:.82rem;border:1px solid var(--c-border)}#app .data-table td[data-v-8e8472ef]{padding:11px 10px;border:1px solid var(--c-border);vertical-align:middle;text-align:center;color:var(--c-text-primary);font-size:.875rem}#app .data-row[data-v-8e8472ef]:hover{background-color:var(--c-bg-mute)}#app .status-active[data-v-8e8472ef]{background-color:var(--c-success-light);color:var(--c-success)}#app .status-inactive[data-v-8e8472ef]{background-color:var(--c-danger-light);color:var(--c-danger)}#app .action-btn[data-v-8e8472ef]{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;margin:0 3px;transition:all .15s}#app .edit-btn[data-v-8e8472ef]{background:var(--c-primary-light);color:var(--c-primary)}#app .edit-btn[data-v-8e8472ef]:hover{background:#6366f11a;color:var(--c-primary);border:1.5px solid var(--c-primary);box-shadow:0 0 8px #6366f140}#app .delete-btn[data-v-8e8472ef]{background:var(--c-danger-light);color:var(--c-danger)}#app .delete-btn[data-v-8e8472ef]:hover{background:var(--c-danger);color:#fff}#app .loading-spinner[data-v-8e8472ef]{border:3px solid var(--c-bg-mute);border-top-color:var(--c-primary)}#app .pagination-container[data-v-8e8472ef]{border-top:1px solid var(--c-border);padding-top:16px;margin-top:16px}#app .pagination-info[data-v-8e8472ef]{color:var(--c-text-secondary)}#app .pagination-btn[data-v-8e8472ef]{border:1px solid var(--c-border);background:var(--c-bg-surface);color:var(--c-text-secondary);border-radius:var(--radius-sm);transition:all .15s}#app .pagination-btn[data-v-8e8472ef]:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-light)}#app .pagination-btn[data-v-8e8472ef]:disabled{background:var(--c-bg-mute);color:var(--c-text-muted)}#app .pagination-btn.page-number.active[data-v-8e8472ef]{background:#6366f11a;color:var(--c-primary);border:2px solid var(--c-primary);box-shadow:0 0 0 2px #6366f11f,0 0 10px #6366f147}#app .module-header[data-v-8e8472ef]{background:var(--c-primary)}#app .permission-code[data-v-8e8472ef]{background:var(--c-primary-light);color:var(--c-primary);font-family:var(--font-code);border-radius:var(--radius-sm)}#app .permission-group-title[data-v-8e8472ef]{color:var(--c-text-primary);font-weight:600;font-size:.95rem}#app .permission-item[data-v-8e8472ef]{border:1px solid var(--c-border);background:var(--c-bg-surface);border-radius:var(--radius-md);transition:box-shadow .2s}#app .permission-item[data-v-8e8472ef]:hover{box-shadow:var(--shadow-md);border-color:var(--c-border-hover)}#app .permission-name[data-v-8e8472ef]{color:var(--c-text-primary)}#app .permission-desc[data-v-8e8472ef]{color:var(--c-text-secondary)}#app .loading-container[data-v-8e8472ef],#app .empty-container[data-v-8e8472ef]{color:var(--c-text-muted)}.profile-card[data-v-8e8472ef]{background:var(--c-bg-surface);border:1px solid var(--c-border);border-radius:12px;padding:26px 28px;max-width:540px}.card-title[data-v-8e8472ef]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);margin-bottom:22px}.form-row[data-v-8e8472ef]{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}.form-label[data-v-8e8472ef]{font-size:.82rem;font-weight:600;color:var(--c-text-secondary)}.form-input[data-v-8e8472ef]{padding:9px 12px;border:1.5px solid var(--c-border);border-radius:8px;font-size:.9rem;background:var(--c-bg-app);color:var(--c-text-primary);font-family:var(--font-base);outline:none}.form-input[data-v-8e8472ef]:focus{border-color:var(--c-primary)}.avatar-edit[data-v-8e8472ef]{display:flex;align-items:center;gap:14px}.avatar-preview[data-v-8e8472ef]{position:relative;width:78px;height:78px;border-radius:50%;overflow:hidden;cursor:pointer;background:var(--c-primary);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #6366f14d}.avatar-preview img[data-v-8e8472ef]{width:100%;height:100%;object-fit:cover}.avatar-fallback[data-v-8e8472ef]{color:#fff;font-size:1.8rem;font-weight:700}.avatar-mask[data-v-8e8472ef]{position:absolute;inset:auto 0 0;height:26px;background:#00000080;color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s}.avatar-preview:hover .avatar-mask[data-v-8e8472ef]{opacity:1}.form-actions[data-v-8e8472ef]{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.admin-layout[data-v-f80a7774]{display:flex;width:100vw;height:100vh;background:var(--c-bg-app);font-family:var(--font-base);overflow:hidden}.sidebar[data-v-f80a7774]{width:var(--sidebar-w);flex-shrink:0;background:var(--c-bg-sidebar);border-right:1px solid var(--c-border);display:flex;flex-direction:column;height:100vh;overflow:hidden}.brand[data-v-f80a7774]{display:flex;align-items:center;gap:10px;padding:20px 20px 18px}.brand-logo[data-v-f80a7774]{width:36px;height:36px;background:var(--c-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #6366f159;flex-shrink:0}.brand-icon[data-v-f80a7774]{width:22px;height:22px;filter:brightness(10)}.brand-text[data-v-f80a7774]{display:flex;flex-direction:column;gap:1px}.brand-name[data-v-f80a7774]{font-size:.95rem;font-weight:800;color:var(--c-text-primary);letter-spacing:-.01em;line-height:1.2}.brand-tag[data-v-f80a7774]{font-size:.68rem;font-weight:500;color:var(--c-primary);background:var(--c-primary-light);border-radius:var(--radius-full);padding:1px 7px;letter-spacing:.02em;display:inline-block}.sidebar-divider[data-v-f80a7774]{height:1px;background:var(--c-border);margin:0 16px 6px}.sidebar-nav[data-v-f80a7774]{flex:1;overflow-y:auto;padding:0 10px 10px}.nav-label[data-v-f80a7774]{font-size:.67rem;font-weight:600;color:var(--c-text-muted);letter-spacing:.06em;text-transform:uppercase;padding:12px 10px 6px}.nav-item[data-v-f80a7774]{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);cursor:pointer;color:var(--c-text-secondary);font-size:.875rem;font-weight:500;transition:all .18s;margin-bottom:2px}.nav-item[data-v-f80a7774]:hover{background:var(--c-bg-mute);color:var(--c-text-primary)}.nav-item.active[data-v-f80a7774]{background:#6366f11a;color:var(--c-primary);font-weight:600;border:2px solid var(--c-primary);box-shadow:0 0 0 3px #6366f11f,0 0 14px #6366f152}.nav-item.active .nav-icon[data-v-f80a7774]{color:var(--c-primary)}.nav-icon[data-v-f80a7774]{flex-shrink:0;color:var(--c-text-muted);transition:color .18s}.nav-item:hover .nav-icon[data-v-f80a7774]{color:var(--c-text-primary)}.main-area[data-v-f80a7774]{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;overflow:hidden}.topbar[data-v-f80a7774]{height:var(--header-h);background:var(--c-bg-header);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0;box-shadow:var(--shadow-sm)}.topbar-left[data-v-f80a7774]{display:flex;align-items:center;gap:12px}.page-title[data-v-f80a7774]{font-size:1.05rem;font-weight:700;color:var(--c-text-primary);letter-spacing:-.01em}.topbar-right[data-v-f80a7774]{display:flex;align-items:center;gap:12px}.topbar-avatar[data-v-f80a7774]{width:34px;height:34px;border-radius:var(--radius-full);background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;cursor:pointer;box-shadow:0 2px 8px #6366f152;transition:box-shadow .18s,transform .18s;-webkit-user-select:none;user-select:none}.topbar-avatar[data-v-f80a7774]:hover{box-shadow:0 4px 14px #6366f17a;transform:translateY(-1px)}.page-content[data-v-f80a7774]{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--c-bg-app);min-height:0}*{margin:0;padding:0;box-sizing:border-box}html,body,#app{width:100vw;height:100vh;overflow:hidden}
