xto-fronted 0.4.104 → 0.4.106
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{index-j1GPEQjY.js → index-01f4mTJg.js} +1 -1
- package/dist/{index-C2zTmROz.js → index-BSyHGMA5.js} +652 -647
- package/dist/{index-x7bKZmey.js → index-BnkXUVuB.js} +1 -1
- package/dist/{index-Ci9SM-gg.js → index-Nz8stCJl.js} +1 -1
- package/dist/{index-HtulbTHk.js → index-ddj4tPtc.js} +1 -1
- package/dist/index.js +1 -1
- package/dist/style.css +1 -1
- package/package.json +1 -1
- package/src/router/guards.ts +22 -10
- package/src/views/login/index.vue +9 -4
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { defineComponent as g, ref as l, resolveComponent as b, openBlock as a, createElementBlock as o, createElementVNode as s, Fragment as n, renderList as c, normalizeStyle as r, toDisplayString as i, normalizeClass as d, createBlock as w, withCtx as U, createVNode as u, unref as v } from "vue";
|
|
2
2
|
import { Progress as _ } from "@xto/data";
|
|
3
|
-
import { _ as q } from "./index-
|
|
3
|
+
import { _ as q } from "./index-BSyHGMA5.js";
|
|
4
4
|
const x = { class: "dashboard" }, C = { class: "stats-section" }, B = { class: "stat-content" }, M = { class: "stat-title" }, I = {
|
|
5
5
|
key: 0,
|
|
6
6
|
viewBox: "0 0 24 24",
|
|
@@ -3,7 +3,7 @@ import { Form as S, FormItem as c, Input as x, Select as W, Switch as U } from "
|
|
|
3
3
|
import { Tag as X, Pagination as Y } from "@xto/data";
|
|
4
4
|
import { Popconfirm as Z, Modal as ee, Message as C } from "@xto/feedback";
|
|
5
5
|
import { Space as D, Button as g } from "@xto/base";
|
|
6
|
-
import { S as d, a as te, _ as le } from "./index-
|
|
6
|
+
import { S as d, a as te, _ as le } from "./index-BSyHGMA5.js";
|
|
7
7
|
const se = { class: "user-page" }, ae = { class: "search-section" }, oe = { class: "table-section" }, ne = { class: "table-toolbar" }, ie = { class: "toolbar-left" }, de = { class: "toolbar-right" }, re = { class: "table-count" }, ue = { class: "table-wrapper" }, me = { class: "data-table" }, ce = { key: 0 }, pe = { key: 1 }, ve = { class: "col-id" }, fe = { class: "id-badge" }, he = { class: "col-user" }, ge = { class: "user-info" }, ke = { class: "user-avatar" }, _e = { class: "user-detail" }, ye = { class: "user-nickname" }, xe = { class: "user-username" }, Ve = { class: "col-contact" }, be = { class: "contact-info" }, Ee = { class: "contact-email" }, Be = { class: "contact-phone" }, Ce = { class: "col-roles" }, De = { class: "role-tags" }, Le = { class: "col-status" }, we = { class: "status-switch" }, ze = { class: "col-time" }, Ae = { class: "time-text" }, Ne = { class: "col-actions" }, Se = { class: "pagination-wrapper" }, Ue = { class: "status-field" }, Me = { class: "status-label" }, Te = /* @__PURE__ */ R({
|
|
8
8
|
__name: "index",
|
|
9
9
|
setup(Ie) {
|
|
@@ -3,7 +3,7 @@ import { Form as Y, FormItem as p, Input as _, Select as j, InputNumber as G, Sw
|
|
|
3
3
|
import { Tag as E } from "@xto/data";
|
|
4
4
|
import { Modal as J, Message as K } from "@xto/feedback";
|
|
5
5
|
import { Button as h, Space as N } from "@xto/base";
|
|
6
|
-
import { S as r, M as c, b as P, _ as Q } from "./index-
|
|
6
|
+
import { S as r, M as c, b as P, _ as Q } from "./index-BSyHGMA5.js";
|
|
7
7
|
const W = { class: "menu-page" }, X = { class: "table-section" }, Z = { class: "table-toolbar" }, ee = { class: "toolbar-left" }, te = { class: "toolbar-right" }, se = { class: "table-count" }, le = { class: "table-wrapper" }, oe = { class: "data-table" }, ae = { key: 0 }, ne = { key: 1 }, de = { class: "data-row tree-row--level-0" }, ie = { class: "col-name" }, re = { class: "menu-info" }, ue = { class: "menu-icon-wrapper" }, pe = ["onClick"], ce = { class: "col-icon" }, me = { class: "icon-text" }, fe = { class: "col-path" }, ve = { class: "path-code" }, ye = { class: "col-type" }, _e = { class: "col-sort" }, he = { class: "sort-badge" }, ke = { class: "col-status" }, be = { class: "col-actions" }, ge = { class: "col-name" }, Ve = { class: "menu-info" }, Ee = { class: "menu-icon-wrapper" }, xe = ["onClick"], Ce = { class: "col-icon" }, Me = { class: "icon-text" }, Ne = { class: "col-path" }, we = { class: "path-code" }, Ae = { class: "col-type" }, Be = { class: "col-sort" }, De = { class: "sort-badge" }, Le = { class: "col-status" }, Ue = { class: "col-actions" }, Ie = { class: "form-grid" }, Te = { class: "status-field" }, Se = { class: "status-label" }, ze = { class: "status-field" }, Re = { class: "status-label" }, $e = { class: "status-field" }, Oe = { class: "status-label" }, He = /* @__PURE__ */ $({
|
|
8
8
|
__name: "index",
|
|
9
9
|
setup(qe) {
|
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { F as a, c as t, G as o, d as r, e as u, H as n, L as i, i as p, M as l, b as T, f as d, g, h as R, S as c, a as k, j as S, T as f, k as h, l as U, m, n as A, o as M, p as y, q as x, r as L, s as D, t as b, u as C, v as I, w as F, x as G, y as E, z as B, A as O, B as v, C as w, D as H, E as N, I as P, J as j, K as q, N as z } from "./index-
|
|
1
|
+
import { F as a, c as t, G as o, d as r, e as u, H as n, L as i, i as p, M as l, b as T, f as d, g, h as R, S as c, a as k, j as S, T as f, k as h, l as U, m, n as A, o as M, p as y, q as x, r as L, s as D, t as b, u as C, v as I, w as F, x as G, y as E, z as B, A as O, B as v, C as w, D as H, E as N, I as P, J as j, K as q, N as z } from "./index-BSyHGMA5.js";
|
|
2
2
|
import { G as K, b as X, A as Q, c as V, a as W, d as Y, e as Z, f as _, g as $, F as ee, D as se, C as ae, H as te, h as oe, i as re, I as ue, J as ne, j as ie, k as pe, y as le, K as Te, L as de, l as ge, m as Re, n as ce, z as ke, M as Se, E as fe, N as he, x as Ue, O as me, o as Ae, p as Me, r as ye, q as xe, P as Le, Q as De, R as be, S as Ce, T as Ie, U as Fe, V as Ge, W as Ee, B as Be, X as Oe, u as ve, s as we, t as He, v as Ne, w as Pe } from "./user-Qd_jMBaH.js";
|
|
3
3
|
export {
|
|
4
4
|
a as Footer,
|
package/dist/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
@charset "UTF-8";:root{--color-primary: #1677ff;--color-primary-light-1: #4096ff;--color-primary-light-2: #69b1ff;--color-primary-light-3: #91caff;--color-primary-light-4: #bae0ff;--color-primary-light-5: #e6f4ff;--color-primary-light-6: #f0f8ff;--color-primary-dark-1: #0958d9;--color-primary-dark-2: #003eb3;--color-primary-dark-3: #002c8c;--color-success: #52c41a;--color-success-light: #b7eb8f;--color-success-lighter: #f6ffed;--color-success-dark: #389e0d;--color-warning: #faad14;--color-warning-light: #ffe58f;--color-warning-lighter: #fffbe6;--color-warning-dark: #d48806;--color-danger: #ff4d4f;--color-danger-light: #ffa39e;--color-danger-lighter: #fff2f0;--color-danger-dark: #cf1322;--color-info: #1677ff;--color-info-light: #91caff;--color-info-lighter: #e6f4ff;--color-info-dark: #0958d9;--color-text-primary: #1f1f1f;--color-text-regular: #424242;--color-text-secondary: #757575;--color-text-placeholder: #9e9e9e;--color-text-disabled: #bdbdbd;--color-border: #d9d9d9;--color-border-light: #e8e8e8;--color-border-lighter: #f0f0f0;--color-border-extra-light: #f5f5f5;--color-border-dark: #bfbfbf;--color-fill: #f5f5f5;--color-fill-light: #fafafa;--color-fill-lighter: #ffffff;--color-fill-blank: #ffffff;--color-fill-dark: #e8e8e8;--bg-color: #ffffff;--bg-color-page: #f0f2f5;--bg-color-component: #ffffff;--bg-color-overlay: #ffffff;--bg-color-spotlight: #e6f4ff;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .08), 0 3px 6px -4px rgba(0, 0, 0, .12), 0 9px 28px 8px rgba(0, 0, 0, .05);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .03), 0 1px 6px -1px rgba(0, 0, 0, .02), 0 2px 4px 0 rgba(0, 0, 0, .02);--box-shadow-lighter: 0 1px 4px rgba(0, 0, 0, .04);--box-shadow-dark: 0 6px 16px -8px rgba(0, 0, 0, .08), 0 9px 28px 8px rgba(0, 0, 0, .05), 0 12px 48px 16px rgba(0, 0, 0, .03);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .1);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .12);--font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-family-code: "IBM Plex Mono", "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-base: 14px;--font-size-small: 12px;--font-size-large: 16px;--font-size-extra-large: 20px;--font-size-title: 24px;--font-size-hero: 38px;--font-line-height: 1.5714285714285714;--border-radius-base: 6px;--border-radius-small: 4px;--border-radius-large: 8px;--border-radius-extra-large: 12px;--border-radius-round: 24px;--border-radius-circle: 50%;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--component-size-large: 40px;--component-size-default: 32px;--component-size-small: 24px;--transition-duration: .2s;--transition-duration-fast: .1s;--transition-duration-slow: .3s;--transition-easing: cubic-bezier(.645, .045, .355, 1);--transition-easing-bounce: cubic-bezier(.68, -.55, .265, 1.55);--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070;--sidebar-width: 220px;--sidebar-collapsed-width: 64px;--header-height: 56px;--tabs-height: 40px;--footer-height: 32px;--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #1677ff 50%, #4096ff 100%);--gradient-card: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .8) 100%);--gradient-mask: linear-gradient(180deg, rgba(0, 44, 140, .03) 0%, rgba(0, 0, 0, 0) 100%)}.dark{--color-text-primary: #ffffff;--color-text-regular: #e0e0e0;--color-text-secondary: #a6a6a6;--color-text-placeholder: #737373;--color-text-disabled: #5c5c5c;--color-border: #434343;--color-border-light: #363636;--color-border-lighter: #2a2a2a;--color-border-extra-light: #1f1f1f;--color-border-dark: #5c5c5c;--color-fill: #262626;--color-fill-light: #1f1f1f;--color-fill-lighter: #141414;--color-fill-blank: #141414;--color-fill-dark: #363636;--bg-color: #141414;--bg-color-page: #0a0a0a;--bg-color-component: #1f1f1f;--bg-color-overlay: #1f1f1f;--bg-color-spotlight: #111d2c;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .32), 0 3px 6px -4px rgba(0, 0, 0, .48), 0 9px 28px 8px rgba(0, 0, 0, .2);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .16), 0 1px 6px -1px rgba(0, 0, 0, .12), 0 2px 4px 0 rgba(0, 0, 0, .08);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .32);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .48);--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #0958d9 50%, #1677ff 100%);--gradient-card: linear-gradient(180deg, rgba(20, 20, 20, 0) 0%, rgba(20, 20, 20, .8) 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;height:100%;font-size:var(--font-size-base);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{width:100%;height:100%;font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--bg-color-page)}#app{width:100%;height:100%}a{color:var(--color-primary);text-decoration:none;cursor:pointer;transition:color var(--transition-duration-fast)}a:hover{color:var(--color-primary-light-3)}ul,ol{list-style:none}img{max-width:100%;height:auto;vertical-align:middle}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none;outline:none}button:disabled{cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500;color:var(--color-text-primary)}p{margin:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background-color:var(--color-fill-light);border-radius:3px}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-secondary)}::selection{background-color:var(--color-primary-light-8);color:var(--color-primary)}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-duration)}.fade-enter-from,.fade-leave-to{opacity:0}.fade-scale-enter-active,.fade-scale-leave-active{transition:all var(--transition-duration)}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:scale(.9)}.fade-transform-enter-active,.fade-transform-leave-active{transition:all var(--transition-duration-fast)}.fade-transform-enter-from{opacity:0;transform:translate(-10px)}.fade-transform-leave-to{opacity:0;transform:translate(10px)}.slide-down-enter-active,.slide-down-leave-active{transition:all var(--transition-duration)}.slide-down-enter-from,.slide-down-leave-to{opacity:0;transform:translateY(-20px)}.slide-up-enter-active,.slide-up-leave-active{transition:all var(--transition-duration)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(20px)}.slide-left-enter-active,.slide-left-leave-active{transition:all var(--transition-duration)}.slide-left-enter-from,.slide-left-leave-to{opacity:0;transform:translate(20px)}.slide-right-enter-active,.slide-right-leave-active{transition:all var(--transition-duration)}.slide-right-enter-from,.slide-right-leave-to{opacity:0;transform:translate(-20px)}.zoom-enter-active,.zoom-leave-active{transition:all var(--transition-duration)}.zoom-enter-from,.zoom-leave-to{opacity:0;transform:scale(.5)}.list-enter-active,.list-leave-active{transition:all var(--transition-duration)}.list-enter-from,.list-leave-to{opacity:0;transform:translateY(30px)}.collapse-transition{transition:width var(--transition-duration),padding var(--transition-duration)}.dark .sidebar,.dark .layout__aside{background-color:#1d1e1f}.dark .sidebar{border-right:1px solid #363637}.dark .sidebar__search-results{background-color:#1d1e1f;border-color:#363637}.dark .sidebar__search-item:hover{background-color:#262727}.dark .sidebar__search-item-title{color:#cfd3dc}.dark .sidebar__search-item-parent{color:#a3a6ad}.dark .sidebar__logo{border-bottom-color:#363637}.dark .sidebar__user{border-top-color:#363637}.dark .sidebar__user-name{color:#cfd3dc}.dark .sidebar__user-role{color:#a3a6ad}.dark .x-menu{background-color:#1d1e1f!important;border-color:#363637;color:#cfd3dc}.dark .x-menu.x-menu--vertical{border-right-color:#363637}.dark .x-menu.x-menu--horizontal{border-bottom-color:#363637;background-color:#1d1e1f!important}.dark .x-menu-item{color:#cfd3dc!important;background-color:transparent!important}.dark .x-menu-item:hover{background-color:#262727!important}.dark .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-menu-item.is-active:before{background-color:#409eff}.dark .x-menu-item.is-horizontal:hover{background-color:transparent!important}.dark .x-menu-item.is-horizontal.is-active{background-color:transparent!important;border-bottom-color:#409eff}.dark .x-sub-menu__title{color:#cfd3dc!important;background-color:transparent!important}.dark .x-sub-menu__title:hover{background-color:#262727!important}.dark .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .x-sub-menu__menu .x-menu-item{background-color:transparent!important;color:#cfd3dc!important}.dark .x-sub-menu__menu .x-menu-item:hover{background-color:#262727!important}.dark .x-sub-menu__menu .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-sub-menu__arrow{color:#a3a6ad}.dark .x-sub-menu.is-active>.x-sub-menu__title{color:#409eff!important}.dark .x-sub-menu--horizontal .x-sub-menu__title:hover{background-color:transparent!important}.dark .x-sub-menu--horizontal .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .x-sub-menu.is-collapse>.x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .header{background-color:#1d1e1f;border-bottom-color:#363637}.dark .header__collapse{color:#cfd3dc}.dark .header__breadcrumb{color:#a3a6ad}.dark .header__user-name{color:#cfd3dc}.dark .header__user-arrow{color:#a3a6ad}.dark .header__action:hover,.dark .header__user-trigger:hover{background-color:#262727}.dark .header__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .header__dropdown-name{color:#e5eaf3}.dark .header__dropdown-role{color:#a3a6ad}.dark .header__dropdown-divider{background-color:#363637}.dark .header__dropdown-item{color:#cfd3dc}.dark .header__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .top-menu{background-color:#1d1e1f}.dark .top-menu__menu{background-color:#1d1e1f!important}.dark .top-menu__menu-char{background-color:#409eff33;color:#79bbff}.dark .top-menu__action{color:#cfd3dc}.dark .top-menu__action:hover{background-color:#262727;color:#409eff}.dark .top-menu__user-trigger:hover{background-color:#262727}.dark .top-menu__user-name{color:#cfd3dc}.dark .top-menu__user-arrow{color:#a3a6ad}.dark .top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .top-menu__dropdown-name{color:#e5eaf3}.dark .top-menu__dropdown-role{color:#a3a6ad}.dark .top-menu__dropdown-divider{background-color:#363637}.dark .top-menu__dropdown-item{color:#cfd3dc}.dark .top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .x-button.x-button--default{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-button.x-button--default:hover{border-color:#409eff;color:#409eff}.dark .x-button.x-button--text{color:#409eff}.dark .x-form-item__label{color:#cfd3dc}.dark .x-form-item__error{color:#f56c6c}.dark .x-input{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-input.is-focus{border-color:#409eff}.dark .x-input .x-input__inner{background-color:transparent;color:#e5eaf3}.dark .x-input .x-input__inner::placeholder{color:#6c6e72}.dark .x-input .x-input__suffix,.dark .x-input .x-input__prefix{color:#a3a6ad}.dark .x-select{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-card{background-color:#1d1e1f;border-color:#363637}.dark .x-card__header{border-bottom-color:#363637;color:#e5eaf3}.dark .data-table th{background-color:#262727;color:#cfd3dc;border-bottom-color:#363637}.dark .data-table td{border-bottom-color:#363637;color:#cfd3dc}.dark .data-table tr:hover td{background-color:#262727}.dark .x-modal__wrapper{background-color:#000000b3}.dark .x-modal__container{background-color:#1d1e1f;border:1px solid #363637}.dark .x-modal__header{border-bottom-color:#363637;color:#e5eaf3}.dark .x-modal__footer{border-top-color:#363637}.dark .x-message{background-color:#1d1e1f;border:1px solid #363637}.dark .x-tag.x-tag--primary{background-color:#409eff33;color:#79bbff;border-color:#409eff4d}.dark .x-tag.x-tag--success{background-color:#67c23a33;color:#95d475;border-color:#67c23a4d}.dark .x-tag.x-tag--warning{background-color:#e6a23c33;color:#eebe77;border-color:#e6a23c4d}.dark .x-tag.x-tag--danger{background-color:#f56c6c33;color:#fab6b6;border-color:#f56c6c4d}.dark .x-tag.x-tag--info{background-color:#90939933;color:#c0c4cc;border-color:#9093994d}.dark .x-switch{background-color:#4c4d4f}.dark .x-switch.is-checked{background-color:#409eff}.dark .x-pagination{color:#cfd3dc}.dark .x-pagination__item{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-pagination__item:hover{color:#409eff}.dark .x-pagination__item.is-active{background-color:#409eff;border-color:#409eff;color:#fff}.dark .login{background:linear-gradient(135deg,#1a1a2e,#16213e)}.dark .login__container{background-color:#1d1e1f;border:1px solid #363637}.dark .login__title{color:#409eff}.dark .login__subtitle{color:#a3a6ad}.dark .login__footer{color:#6c6e72}.dark .stat-card__title{color:#a3a6ad}.dark .quick-link{background-color:#262727}.dark .quick-link:hover{background-color:#409eff1a}.dark .quick-link__title{color:#cfd3dc}.dark .activity-item{border-bottom-color:#363637}.dark .activity-item__action{color:#cfd3dc}.dark .search-card,.dark .table-card,.dark .x-popconfirm{background-color:#1d1e1f;border:1px solid #363637}.dark .x-drawer{background-color:#1d1e1f}.dark .x-drawer__header{background-color:#1d1e1f;border-bottom-color:#363637;color:#e5eaf3}.dark .x-drawer__body{background-color:#1d1e1f;color:#cfd3dc}.dark .x-drawer__footer{background-color:#1d1e1f;border-top-color:#363637}.dark .settings-drawer .settings-title{color:#e5eaf3}.dark .settings-drawer .settings-section{background-color:transparent}.dark .settings-drawer .layout-option{border-color:#4c4d4f;background-color:transparent}.dark .settings-drawer .layout-option:hover{border-color:#409eff}.dark .settings-drawer .layout-option.is-active{border-color:#409eff;background-color:#409eff1a}.dark .settings-drawer .layout-option__label,.dark .settings-drawer .settings-switch-item span{color:#cfd3dc}.dark .mix-top-menu{background-color:#1d1e1f;border-bottom-color:#363637}.dark .mix-top-menu__logo-text{color:#409eff}.dark .mix-top-menu__menu{background-color:#1d1e1f!important}.dark .mix-top-menu__menu-char{color:#79bbff;background-color:#409eff33}.dark .mix-top-menu__action{color:#cfd3dc}.dark .mix-top-menu__action:hover{background-color:#262727;color:#409eff}.dark .mix-top-menu__user-trigger:hover{background-color:#262727}.dark .mix-top-menu__user-name{color:#cfd3dc}.dark .mix-top-menu__user-arrow{color:#a3a6ad}.dark .mix-top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .mix-top-menu__dropdown-name{color:#e5eaf3}.dark .mix-top-menu__dropdown-role{color:#a3a6ad}.dark .mix-top-menu__dropdown-divider{background-color:#363637}.dark .mix-top-menu__dropdown-item{color:#cfd3dc}.dark .mix-top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-ellipsis-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-ellipsis-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-start{display:flex;align-items:center;justify-content:flex-start}.flex-end{display:flex;align-items:center;justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.flex-col{display:flex;flex-direction:column}.flex-col-center{display:flex;flex-direction:column;align-items:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-32{gap:32px}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.text-secondary{color:var(--color-text-secondary)}.text-placeholder{color:var(--color-text-placeholder)}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-danger{background-color:var(--color-danger)}.bg-page{background-color:var(--bg-color-page)}.bg-card{background-color:var(--bg-color)}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.ml-4{margin-left:4px}.ml-8{margin-left:8px}.ml-12{margin-left:12px}.ml-16{margin-left:16px}.mr-4{margin-right:4px}.mr-8{margin-right:8px}.mr-12{margin-right:12px}.mr-16{margin-right:16px}.p-4{padding:4px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.p-32{padding:32px}.px-4{padding-left:4px;padding-right:4px}.px-8{padding-left:8px;padding-right:8px}.px-12{padding-left:12px;padding-right:12px}.px-16{padding-left:16px;padding-right:16px}.px-24{padding-left:24px;padding-right:24px}.py-4{padding-top:4px;padding-bottom:4px}.py-8{padding-top:8px;padding-bottom:8px}.py-12{padding-top:12px;padding-bottom:12px}.py-16{padding-top:16px;padding-bottom:16px}.py-24{padding-top:24px;padding-bottom:24px}.card{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);padding:var(--spacing-lg);transition:box-shadow .3s ease}.card:hover{box-shadow:var(--box-shadow-card-hover)}.card-flat{background-color:var(--bg-color);border-radius:var(--border-radius-large);padding:var(--spacing-lg);border:1px solid var(--color-border-lighter)}.page-container{padding:12px;min-height:100%;background:var(--bg-color-page)}.search-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:12px;padding:12px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--color-border-lighter)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.table-container{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.pagination-container{display:flex;justify-content:flex-end;padding:12px;border-top:1px solid var(--color-border-lighter)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:12px;font-weight:500;border-radius:10px;background:var(--color-fill);color:var(--color-text-secondary)}.badge-primary{background:var(--color-primary-light-6);color:var(--color-primary)}.badge-success{background:var(--color-success-lighter);color:var(--color-success)}.badge-warning{background:var(--color-warning-lighter);color:var(--color-warning)}.badge-danger{background:var(--color-danger-lighter);color:var(--color-danger)}.divider{height:1px;background:var(--color-border-lighter);margin:var(--spacing-md) 0}.divider-vertical{width:1px;height:100%;background:var(--color-border-lighter);margin:0 var(--spacing-md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-placeholder)}.empty-state .empty-icon{width:64px;height:64px;margin-bottom:16px;opacity:.5}.empty-state .empty-text{font-size:14px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-state .loading-spinner{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-state .loading-text{margin-top:16px;font-size:14px;color:var(--color-text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.link{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.link:hover{color:var(--color-primary-dark-1)}.link-underline{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.link-underline:hover{color:var(--color-primary-dark-1)}.x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}.x-sub-menu__menu .x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-sub-menu__menu .x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}html.grey-mode{filter:grayscale(100%);-webkit-filter:grayscale(100%)}:root{--bg-color: #ffffff;--bg-color-page: #f5f7fa;--color-border-lighter: #e4e7ed}.menu-item__content[data-v-f5865e28]{display:inline-flex;align-items:center;line-height:1}.menu-item__text[data-v-f5865e28]{flex:1;line-height:1}.menu-item__icon[data-v-f5865e28]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.menu-item__char[data-v-f5865e28]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.sidebar[data-v-2ecab012]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);border-right:1px solid var(--color-border-lighter)}.sidebar--collapsed .sidebar__logo[data-v-2ecab012]{justify-content:center;padding:0}.sidebar__logo[data-v-2ecab012]{height:50px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-2ecab012]{width:32px;height:32px}.sidebar__logo-text[data-v-2ecab012]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-2ecab012]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-2ecab012]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-2ecab012]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-2ecab012]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-2ecab012]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-cf67ace4]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.header__left[data-v-cf67ace4]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-cf67ace4]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-regular);transition:color .2s}.header__collapse[data-v-cf67ace4]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-cf67ace4]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-cf67ace4]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-cf67ace4]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-cf67ace4]{display:flex;align-items:center;gap:8px}.header__search[data-v-cf67ace4]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.header__search-icon[data-v-cf67ace4]{color:var(--color-text-secondary)}.header__search-input[data-v-cf67ace4]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.header__search-input[data-v-cf67ace4]::placeholder{color:var(--color-text-placeholder)}.header__search-dropdown[data-v-cf67ace4]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.header__search-results[data-v-cf67ace4]{padding:8px 0}.header__search-item[data-v-cf67ace4]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-cf67ace4]:hover{background-color:var(--color-fill)}.header__search-item-title[data-v-cf67ace4]{font-size:14px;color:var(--color-text-primary)}.header__search-item-parent[data-v-cf67ace4]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.header__search-icon[data-v-cf67ace4]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.header__search-char[data-v-cf67ace4]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.header__search-empty[data-v-cf67ace4]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.header__action[data-v-cf67ace4]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.header__action[data-v-cf67ace4]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-cf67ace4]{position:relative;margin-left:8px}.header__user-trigger[data-v-cf67ace4]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-cf67ace4]:hover{background-color:var(--color-fill)}.header__user-name[data-v-cf67ace4]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-cf67ace4]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-cf67ace4]{transform:rotate(180deg)}.header__avatar[data-v-cf67ace4]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-cf67ace4]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-cf67ace4]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-cf67ace4]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-cf67ace4]{flex:1}.header__dropdown-name[data-v-cf67ace4]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-cf67ace4]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-cf67ace4]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-cf67ace4]{padding:8px 0}.header__dropdown-item[data-v-cf67ace4]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-cf67ace4]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-cf67ace4]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-cf67ace4]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-cf67ace4]{margin-bottom:24px}.settings-drawer .settings-title[data-v-cf67ace4]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-cf67ace4]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-cf67ace4]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-cf67ace4]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-cf67ace4]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-cf67ace4]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-cf67ace4]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-cf67ace4]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-cf67ace4]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-cf67ace4]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-cf67ace4]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-cf67ace4]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-cf67ace4]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-cf67ace4]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-cf67ace4]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-cf67ace4]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-cf67ace4]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-cf67ace4]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-cf67ace4]{display:flex;gap:12px}.settings-drawer .color-option[data-v-cf67ace4]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-cf67ace4]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-cf67ace4]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-cf67ace4]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-cf67ace4]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-cf67ace4]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-cf67ace4]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-cf67ace4]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-cf67ace4]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-cf67ace4]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-cf67ace4]:after{left:24px}.dropdown-enter-active[data-v-cf67ace4],.dropdown-leave-active[data-v-cf67ace4]{transition:all .2s ease}.dropdown-enter-from[data-v-cf67ace4],.dropdown-leave-to[data-v-cf67ace4]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-cf67ace4],.search-dropdown-leave-active[data-v-cf67ace4]{transition:all .2s ease}.search-dropdown-enter-from[data-v-cf67ace4],.search-dropdown-leave-to[data-v-cf67ace4]{opacity:0;transform:translateY(-4px)}.top-menu[data-v-15f7b516]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-15f7b516]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-15f7b516]{width:32px;height:32px}.top-menu__logo-text[data-v-15f7b516]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-15f7b516]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu{height:49px;line-height:49px;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-menu-item.is-horizontal{height:49px;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu-item__content{height:49px}.top-menu__menu[data-v-15f7b516] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-sub-menu--horizontal{height:49px}.top-menu__menu[data-v-15f7b516] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-sub-menu__content{height:49px}.top-menu__menu-content[data-v-15f7b516]{align-items:center;line-height:1}.top-menu__menu-text[data-v-15f7b516]{line-height:1}.top-menu__menu-icon[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.top-menu__menu-char[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__actions[data-v-15f7b516]{display:flex;align-items:center;gap:8px}.top-menu__search[data-v-15f7b516]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.top-menu__search-icon[data-v-15f7b516]{color:var(--color-text-secondary)}.top-menu__search-input[data-v-15f7b516]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.top-menu__search-input[data-v-15f7b516]::placeholder{color:var(--color-text-placeholder)}.top-menu__search-dropdown[data-v-15f7b516]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.top-menu__search-results[data-v-15f7b516]{padding:8px 0}.top-menu__search-item[data-v-15f7b516]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.top-menu__search-item[data-v-15f7b516]:hover{background-color:var(--color-fill)}.top-menu__search-item-title[data-v-15f7b516]{font-size:14px;color:var(--color-text-primary)}.top-menu__search-item-parent[data-v-15f7b516]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.top-menu__search-icon-item[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.top-menu__search-char[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__search-empty[data-v-15f7b516]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.top-menu__action[data-v-15f7b516]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.top-menu__action[data-v-15f7b516]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-15f7b516]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-15f7b516]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.top-menu__user-trigger[data-v-15f7b516]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-15f7b516]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-menu__user-arrow[data-v-15f7b516]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-15f7b516]{transform:rotate(180deg)}.top-menu__avatar[data-v-15f7b516]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.top-menu__dropdown[data-v-15f7b516]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.top-menu__dropdown-header[data-v-15f7b516]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-15f7b516]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.top-menu__dropdown-info[data-v-15f7b516]{flex:1}.top-menu__dropdown-name[data-v-15f7b516]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-15f7b516]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-15f7b516]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-15f7b516]{padding:8px 0}.top-menu__dropdown-item[data-v-15f7b516]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.top-menu__dropdown-item[data-v-15f7b516]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-15f7b516]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-15f7b516]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-15f7b516]{margin-bottom:24px}.settings-drawer .settings-title[data-v-15f7b516]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-15f7b516]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-15f7b516]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-15f7b516]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-15f7b516]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-15f7b516]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-15f7b516]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-15f7b516]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-15f7b516]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-15f7b516]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-15f7b516]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-15f7b516]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-15f7b516]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-15f7b516]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-15f7b516]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-15f7b516]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-15f7b516]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-15f7b516]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-15f7b516]{display:flex;gap:12px}.settings-drawer .color-option[data-v-15f7b516]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-15f7b516]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-15f7b516]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-15f7b516]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-15f7b516]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-15f7b516]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-15f7b516]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-15f7b516]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-15f7b516]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-15f7b516]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-15f7b516]:after{left:24px}.dropdown-enter-active[data-v-15f7b516],.dropdown-leave-active[data-v-15f7b516]{transition:all .2s ease}.dropdown-enter-from[data-v-15f7b516],.dropdown-leave-to[data-v-15f7b516]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-15f7b516],.search-dropdown-leave-active[data-v-15f7b516]{transition:all .2s ease}.search-dropdown-enter-from[data-v-15f7b516],.search-dropdown-leave-to[data-v-15f7b516]{opacity:0;transform:translateY(-4px)}.mix-top-menu[data-v-d5fb6d2a]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.mix-top-menu__logo[data-v-d5fb6d2a]{display:flex;align-items:center;gap:10px;margin-right:20px}.mix-top-menu__logo-img[data-v-d5fb6d2a]{width:32px;height:32px}.mix-top-menu__logo-text[data-v-d5fb6d2a]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-d5fb6d2a]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu{height:49px;line-height:49px;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item.is-horizontal{height:49px;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item__content{height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu--horizontal{height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu__content{height:49px}.mix-top-menu__menu-content[data-v-d5fb6d2a]{align-items:center;line-height:1}.mix-top-menu__menu-text[data-v-d5fb6d2a]{line-height:1}.mix-top-menu__menu-icon[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.mix-top-menu__menu-char[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__actions[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px}.mix-top-menu__search[data-v-d5fb6d2a]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.mix-top-menu__search-icon[data-v-d5fb6d2a]{color:var(--color-text-secondary)}.mix-top-menu__search-input[data-v-d5fb6d2a]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.mix-top-menu__search-input[data-v-d5fb6d2a]::placeholder{color:var(--color-text-placeholder)}.mix-top-menu__search-dropdown[data-v-d5fb6d2a]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.mix-top-menu__search-results[data-v-d5fb6d2a]{padding:8px 0}.mix-top-menu__search-item[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.mix-top-menu__search-item[data-v-d5fb6d2a]:hover{background-color:var(--color-fill)}.mix-top-menu__search-item-title[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-primary)}.mix-top-menu__search-item-parent[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.mix-top-menu__search-icon-item[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.mix-top-menu__search-char[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__search-empty[data-v-d5fb6d2a]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.mix-top-menu__action[data-v-d5fb6d2a]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.mix-top-menu__action[data-v-d5fb6d2a]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-d5fb6d2a]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.mix-top-menu__user-trigger[data-v-d5fb6d2a]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mix-top-menu__user-arrow[data-v-d5fb6d2a]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-d5fb6d2a]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-d5fb6d2a]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.mix-top-menu__dropdown[data-v-d5fb6d2a]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.mix-top-menu__dropdown-header[data-v-d5fb6d2a]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-d5fb6d2a]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.mix-top-menu__dropdown-info[data-v-d5fb6d2a]{flex:1}.mix-top-menu__dropdown-name[data-v-d5fb6d2a]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-d5fb6d2a]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-d5fb6d2a]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-d5fb6d2a]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.mix-top-menu__dropdown-item[data-v-d5fb6d2a]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-d5fb6d2a]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-d5fb6d2a]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-d5fb6d2a]{margin-bottom:24px}.settings-drawer .settings-title[data-v-d5fb6d2a]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-d5fb6d2a]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-d5fb6d2a]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-d5fb6d2a]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-d5fb6d2a]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-d5fb6d2a]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-d5fb6d2a]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-d5fb6d2a]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-d5fb6d2a]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-d5fb6d2a]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-d5fb6d2a]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-d5fb6d2a]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-d5fb6d2a]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-d5fb6d2a]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-d5fb6d2a]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-d5fb6d2a]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-d5fb6d2a]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-d5fb6d2a]{display:flex;gap:12px}.settings-drawer .color-option[data-v-d5fb6d2a]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-d5fb6d2a]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-d5fb6d2a]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-d5fb6d2a]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-d5fb6d2a]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-d5fb6d2a]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-d5fb6d2a]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-d5fb6d2a]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-d5fb6d2a]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-d5fb6d2a]:after{left:24px}.dropdown-enter-active[data-v-d5fb6d2a],.dropdown-leave-active[data-v-d5fb6d2a]{transition:all .2s ease}.dropdown-enter-from[data-v-d5fb6d2a],.dropdown-leave-to[data-v-d5fb6d2a]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-d5fb6d2a],.search-dropdown-leave-active[data-v-d5fb6d2a]{transition:all .2s ease}.search-dropdown-enter-from[data-v-d5fb6d2a],.search-dropdown-leave-to[data-v-d5fb6d2a]{opacity:0;transform:translateY(-4px)}.layout[data-v-38f2fc61]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-38f2fc61]{flex-direction:row}.layout--sidebar .layout__aside[data-v-38f2fc61]{height:100%}.layout--sidebar .layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;height:100%}.layout--top[data-v-38f2fc61]{flex-direction:column}.layout--top .layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;height:calc(100% - 50px)}.layout--top .layout__content[data-v-38f2fc61]{flex:1}.layout--mix[data-v-38f2fc61]{flex-direction:column}.layout--mix .layout__mix-top-menu[data-v-38f2fc61]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout--mix .layout__mix-body[data-v-38f2fc61]{flex:1;display:flex;flex-direction:row;height:calc(100% - 50px)}.layout__aside[data-v-38f2fc61]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-38f2fc61]{width:100%;height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__mix-top-menu[data-v-38f2fc61]{width:100%;height:50px;box-sizing:border-box;flex-shrink:0}.layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-38f2fc61]{height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-38f2fc61]{flex:1;overflow:auto;background-color:var(--bg-color-page);padding:0}.tabs-wrapper[data-v-9156d8cd]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-9156d8cd] .t-tabs{height:100%}.tabs-wrapper[data-v-9156d8cd] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__nav{border:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-9156d8cd]{display:flex;align-items:center;gap:5px}.tab-close[data-v-9156d8cd]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-9156d8cd]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-4852826a]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login-page[data-v-102cb5d3]{width:100%;min-height:100vh;display:flex;background:var(--bg-color-page)}.login-brand[data-v-102cb5d3]{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#002c8c,#0958d9,#1677ff);overflow:hidden}@media (max-width: 992px){.login-brand[data-v-102cb5d3]{display:none}}.login-brand .brand-content[data-v-102cb5d3]{position:relative;z-index:2;padding:60px;max-width:520px;color:#fff}.login-brand .brand-logo[data-v-102cb5d3]{display:flex;align-items:center;gap:12px;margin-bottom:48px}.login-brand .brand-logo .logo-icon[data-v-102cb5d3]{width:48px;height:48px;color:#fff}.login-brand .brand-logo .logo-text[data-v-102cb5d3]{font-size:28px;font-weight:700;letter-spacing:2px}.login-brand .brand-slogan[data-v-102cb5d3]{margin-bottom:48px}.login-brand .brand-slogan h1[data-v-102cb5d3]{font-size:32px;font-weight:600;line-height:1.3;margin-bottom:12px}.login-brand .brand-slogan p[data-v-102cb5d3]{font-size:16px;opacity:.8;line-height:1.6}.login-brand .brand-features[data-v-102cb5d3]{display:flex;flex-direction:column;gap:24px}.login-brand .brand-features .feature-item[data-v-102cb5d3]{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#ffffff1a;border-radius:var(--border-radius-large);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.login-brand .brand-features .feature-item[data-v-102cb5d3]:hover{background:#ffffff26;transform:translate(8px)}.login-brand .brand-features .feature-icon[data-v-102cb5d3]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:var(--border-radius-base);flex-shrink:0}.login-brand .brand-features .feature-icon svg[data-v-102cb5d3]{width:20px;height:20px}.login-brand .brand-features .feature-text h4[data-v-102cb5d3]{font-size:15px;font-weight:600;margin-bottom:4px}.login-brand .brand-features .feature-text p[data-v-102cb5d3]{font-size:13px;opacity:.8}.login-brand .brand-decoration[data-v-102cb5d3]{position:absolute;bottom:60px;left:60px;right:60px;display:flex;align-items:center;gap:16px}.login-brand .brand-decoration .decoration-line[data-v-102cb5d3]{flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.3),transparent)}.login-brand .brand-decoration .decoration-dots[data-v-102cb5d3]{display:flex;gap:8px}.login-brand .brand-decoration .decoration-dots span[data-v-102cb5d3]{width:6px;height:6px;background:#ffffff80;border-radius:50%}.login-brand .brand-bg[data-v-102cb5d3]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.login-brand .brand-bg .bg-grid[data-v-102cb5d3]{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}.login-brand .brand-bg .bg-glow[data-v-102cb5d3]{position:absolute;top:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:glow-pulse-102cb5d3 8s ease-in-out infinite}.login-brand .brand-bg .bg-pattern[data-v-102cb5d3]{position:absolute;bottom:-10%;left:-10%;width:40%;height:40%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 60%)}@keyframes glow-pulse-102cb5d3{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.login-form-section[data-v-102cb5d3]{width:500px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:60px 80px;background:var(--bg-color)}@media (max-width: 768px){.login-form-section[data-v-102cb5d3]{width:100%;padding:40px 24px}}.login-form-section .form-container[data-v-102cb5d3]{width:100%;max-width:360px;margin:0 auto}.login-form-section .form-header[data-v-102cb5d3]{margin-bottom:40px}.login-form-section .form-header h2[data-v-102cb5d3]{font-size:28px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.login-form-section .form-header p[data-v-102cb5d3]{font-size:14px;color:var(--color-text-secondary)}.login-form-section .login-form .input-wrapper[data-v-102cb5d3]{margin-bottom:4px}.login-form-section .login-form .input-label[data-v-102cb5d3]{display:block;font-size:14px;font-weight:500;color:var(--color-text-regular);margin-bottom:8px}.login-form-section .login-form[data-v-102cb5d3] .x-form-item{margin-bottom:24px}.login-form-section .login-form[data-v-102cb5d3] .x-input{--x-input-border-radius: 8px}.login-form-section .login-form[data-v-102cb5d3] .x-input__prefix{margin-right:12px;color:var(--color-text-placeholder)}.login-form-section .form-options[data-v-102cb5d3]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.login-form-section .form-options .forgot-link[data-v-102cb5d3]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.login-form-section .form-options .forgot-link[data-v-102cb5d3]:hover{color:var(--color-primary-dark-1)}.login-form-section .login-btn[data-v-102cb5d3]{width:100%;height:44px;font-size:16px;font-weight:500;border-radius:8px;letter-spacing:4px;transition:all .3s ease}.login-form-section .login-btn[data-v-102cb5d3]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1677ff66}.login-form-section .login-btn[data-v-102cb5d3]:active:not(:disabled){transform:translateY(0)}.login-form-section .form-footer[data-v-102cb5d3]{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border-lighter);text-align:center}.login-form-section .form-footer p[data-v-102cb5d3]{font-size:13px;color:var(--color-text-placeholder);margin-bottom:16px}.login-form-section .form-footer .social-login[data-v-102cb5d3]{display:flex;justify-content:center;gap:16px}.login-form-section .form-footer .social-btn[data-v-102cb5d3]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-fill);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary)}.login-form-section .form-footer .social-btn svg[data-v-102cb5d3]{width:20px;height:20px}.login-form-section .form-footer .social-btn[data-v-102cb5d3]:hover{background:var(--color-primary-light-6);color:var(--color-primary);transform:translateY(-2px)}.login-form-section .copyright[data-v-102cb5d3]{margin-top:48px;text-align:center}.login-form-section .copyright p[data-v-102cb5d3]{font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-1b083153]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-1b083153]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-1b083153]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-1b083153]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-1b083153]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-primary)}.error-bg .bg-circle.circle-2[data-v-1b083153]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-info)}.error-bg .bg-circle.circle-3[data-v-1b083153]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-primary-light-3)}.error-content[data-v-1b083153]{text-align:center}.error-code[data-v-1b083153]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-1b083153]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-1b083153]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-1b083153]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-1b083153]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-1b083153]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-1b083153]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-1b083153]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-1b083153] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-1b083153] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-1b083153]{padding:20px;background:var(--color-fill-light);border-radius:var(--border-radius-large)}.error-tip p[data-v-1b083153]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-1b083153]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-1b083153]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-1b083153]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-primary);border-radius:50%;opacity:.6}.error-page[data-v-d167f981]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-d167f981]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-d167f981]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-d167f981]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-d167f981]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-warning)}.error-bg .bg-circle.circle-2[data-v-d167f981]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-warning)}.error-bg .bg-circle.circle-3[data-v-d167f981]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-warning-light)}.error-content[data-v-d167f981]{text-align:center}.error-code[data-v-d167f981]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-d167f981]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-d167f981]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-light) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-d167f981]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-d167f981]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-d167f981]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-d167f981]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-d167f981]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-d167f981] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-d167f981] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-d167f981]{padding:20px;background:var(--color-warning-lighter);border-radius:var(--border-radius-large)}.error-tip p[data-v-d167f981]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-d167f981]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-d167f981]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-d167f981]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-warning);border-radius:50%;opacity:.6}.dashboard[data-v-545d4c27]{padding:24px;background:var(--bg-color-page);min-height:100%}.stats-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}@media (max-width: 1200px){.stats-section[data-v-545d4c27]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-section[data-v-545d4c27]{grid-template-columns:1fr}}.stat-card[data-v-545d4c27]{position:relative;display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);transition:all .3s ease;overflow:hidden}.stat-card[data-v-545d4c27]:hover{box-shadow:var(--box-shadow-card-hover);transform:translateY(-4px)}.stat-card:hover .stat-decoration[data-v-545d4c27]{opacity:1}.stat-card .stat-icon[data-v-545d4c27]{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-large);flex-shrink:0}.stat-card .stat-icon span[data-v-545d4c27]{font-size:26px}.stat-card .stat-content[data-v-545d4c27]{flex:1;min-width:0}.stat-card .stat-title[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary);margin-bottom:8px}.stat-card .stat-value[data-v-545d4c27]{font-size:28px;font-weight:600;line-height:1.2;margin-bottom:8px}.stat-card .stat-trend[data-v-545d4c27]{display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:2px 8px;border-radius:12px}.stat-card .stat-trend svg[data-v-545d4c27]{width:14px;height:14px}.stat-card .stat-trend.up[data-v-545d4c27]{color:var(--color-success);background:var(--color-success-lighter)}.stat-card .stat-trend.down[data-v-545d4c27]{color:var(--color-danger);background:var(--color-danger-lighter)}.stat-card .stat-decoration[data-v-545d4c27]{position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:0;transition:opacity .3s ease}.main-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}@media (max-width: 992px){.main-section[data-v-545d4c27]{grid-template-columns:1fr}}.section-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3[data-v-545d4c27]{font-size:16px;font-weight:600;color:var(--color-text-primary)}.section-header .section-badge[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder);background:var(--color-fill);padding:4px 10px;border-radius:12px}.section-header .section-link[data-v-545d4c27]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.section-header .section-link[data-v-545d4c27]:hover{color:var(--color-primary-dark-1)}.quick-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.quick-grid[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.quick-card[data-v-545d4c27]{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-fill-light);border-radius:var(--border-radius-base);text-decoration:none;transition:all .2s ease}.quick-card[data-v-545d4c27]:hover{background:var(--color-primary-light-6);transform:translate(4px)}.quick-card:hover .quick-arrow[data-v-545d4c27]{color:var(--color-primary);transform:translate(4px)}.quick-card .quick-icon[data-v-545d4c27]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-color);border-radius:var(--border-radius-base);font-size:22px;flex-shrink:0}.quick-card .quick-info[data-v-545d4c27]{flex:1;min-width:0}.quick-card .quick-title[data-v-545d4c27]{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.quick-card .quick-desc[data-v-545d4c27]{font-size:13px;color:var(--color-text-secondary)}.quick-card .quick-arrow[data-v-545d4c27]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-placeholder);transition:all .2s ease}.quick-card .quick-arrow svg[data-v-545d4c27]{width:16px;height:16px}.activity-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.activity-list[data-v-545d4c27]{display:flex;flex-direction:column}.activity-item[data-v-545d4c27]{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-border-lighter);position:relative}.activity-item[data-v-545d4c27]:last-child{border-bottom:none}.activity-avatar[data-v-545d4c27]{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;font-weight:500;flex-shrink:0}.activity-avatar.success[data-v-545d4c27]{background:var(--color-success-lighter);color:var(--color-success)}.activity-avatar.warning[data-v-545d4c27]{background:var(--color-warning-lighter);color:var(--color-warning)}.activity-avatar.info[data-v-545d4c27]{background:var(--color-info-lighter);color:var(--color-info)}.activity-avatar.danger[data-v-545d4c27]{background:var(--color-danger-lighter);color:var(--color-danger)}.activity-avatar.primary[data-v-545d4c27]{background:var(--color-primary-light-6);color:var(--color-primary)}.activity-content[data-v-545d4c27]{flex:1;min-width:0}.activity-main[data-v-545d4c27]{margin-bottom:4px}.activity-user[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-right:8px}.activity-action[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.activity-time[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder)}.activity-dot[data-v-545d4c27]{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;opacity:.6}.activity-dot.success[data-v-545d4c27]{background:var(--color-success)}.activity-dot.warning[data-v-545d4c27]{background:var(--color-warning)}.activity-dot.info[data-v-545d4c27]{background:var(--color-info)}.activity-dot.danger[data-v-545d4c27]{background:var(--color-danger)}.activity-dot.primary[data-v-545d4c27]{background:var(--color-primary)}.system-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.system-grid[data-v-545d4c27]{display:grid;grid-template-columns:1fr 1.5fr;gap:24px}@media (max-width: 768px){.system-grid[data-v-545d4c27]{grid-template-columns:1fr}}.system-info-list[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.info-item[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-fill-light);border-radius:var(--border-radius-base)}.info-item .info-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.info-item .info-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.system-status[data-v-545d4c27]{display:flex;flex-direction:column;gap:16px}.status-item .status-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.status-item .status-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.status-item .status-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-page[data-v-5d3ed390]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-5d3ed390]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-5d3ed390] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-5d3ed390] .x-input,.search-section .search-form[data-v-5d3ed390] .x-select{width:200px}.table-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-5d3ed390]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-5d3ed390]{display:flex;gap:12px}.table-toolbar .table-count[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-5d3ed390]{overflow-x:auto}.data-table[data-v-5d3ed390]{width:100%;border-collapse:collapse}.data-table th[data-v-5d3ed390],.data-table td[data-v-5d3ed390]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-5d3ed390]{transition:background-color .2s}.data-table .data-row[data-v-5d3ed390]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-5d3ed390]{vertical-align:middle}.data-table .loading-cell[data-v-5d3ed390],.data-table .empty-cell[data-v-5d3ed390]{padding:60px 20px}.data-table .loading-content[data-v-5d3ed390],.data-table .empty-content[data-v-5d3ed390]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-5d3ed390],.data-table .empty-content svg[data-v-5d3ed390]{width:64px;height:41px}.data-table .loading-spinner[data-v-5d3ed390]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-5d3ed390 .8s linear infinite}@keyframes spin-5d3ed390{to{transform:rotate(360deg)}}.col-id[data-v-5d3ed390]{width:80px}.id-badge[data-v-5d3ed390]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-user[data-v-5d3ed390]{min-width:180px}.user-info[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-avatar[data-v-5d3ed390]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%;font-size:16px;font-weight:500;color:#fff;flex-shrink:0}.user-detail[data-v-5d3ed390]{display:flex;flex-direction:column;gap:2px}.user-nickname[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-username[data-v-5d3ed390]{font-size:12px;color:var(--color-text-placeholder)}.col-contact[data-v-5d3ed390]{min-width:180px}.contact-info[data-v-5d3ed390]{display:flex;flex-direction:column;gap:4px}.contact-email[data-v-5d3ed390],.contact-phone[data-v-5d3ed390]{font-size:13px;color:var(--color-text-regular)}.contact-phone[data-v-5d3ed390]{color:var(--color-text-secondary)}.col-roles[data-v-5d3ed390]{min-width:100px}.role-tags[data-v-5d3ed390]{display:flex;gap:6px}.col-status[data-v-5d3ed390]{min-width:120px}.status-switch[data-v-5d3ed390]{display:flex;align-items:center;gap:8px}.status-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-5d3ed390]{color:var(--color-success)}.col-time[data-v-5d3ed390]{min-width:160px}.time-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-5d3ed390]{min-width:140px}.action-buttons[data-v-5d3ed390] .x-button{padding:4px 8px}.action-buttons[data-v-5d3ed390] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-5d3ed390]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.user-form[data-v-5d3ed390]{padding:16px 0}.user-form .status-field[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-form .status-label[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.role-page[data-v-de354764]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-de354764]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-de354764] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-de354764] .x-input,.search-section .search-form[data-v-de354764] .x-select{width:200px}.table-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-de354764]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-de354764]{display:flex;gap:12px}.table-toolbar .table-count[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-de354764]{overflow-x:auto}.data-table[data-v-de354764]{width:100%;border-collapse:collapse}.data-table th[data-v-de354764],.data-table td[data-v-de354764]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-de354764]{transition:background-color .2s}.data-table .data-row[data-v-de354764]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-de354764]{vertical-align:middle}.data-table .loading-cell[data-v-de354764],.data-table .empty-cell[data-v-de354764]{padding:60px 20px}.data-table .loading-content[data-v-de354764],.data-table .empty-content[data-v-de354764]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-de354764],.data-table .empty-content svg[data-v-de354764]{width:64px;height:41px}.data-table .loading-spinner[data-v-de354764]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-de354764 .8s linear infinite}@keyframes spin-de354764{to{transform:rotate(360deg)}}.col-id[data-v-de354764]{width:80px}.id-badge[data-v-de354764]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-name[data-v-de354764]{min-width:120px}.role-name[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.col-code[data-v-de354764]{min-width:100px}.col-desc[data-v-de354764]{min-width:150px}.desc-text[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.col-status[data-v-de354764]{min-width:120px}.status-switch[data-v-de354764]{display:flex;align-items:center;gap:8px}.status-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-de354764]{color:var(--color-success)}.col-time[data-v-de354764]{min-width:160px}.time-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-de354764]{min-width:140px}.action-buttons[data-v-de354764] .x-button{padding:4px 8px}.action-buttons[data-v-de354764] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-de354764]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.role-form[data-v-de354764]{padding:16px 0}.role-form .status-field[data-v-de354764]{display:flex;align-items:center;gap:12px}.role-form .status-label[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.menu-page[data-v-e7cc9235]{padding:24px;background:var(--bg-color-page);min-height:100%}.table-section[data-v-e7cc9235]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-e7cc9235]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-e7cc9235]{display:flex;gap:12px}.table-toolbar .table-count[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-e7cc9235]{overflow-x:auto}.data-table[data-v-e7cc9235]{width:100%;border-collapse:collapse}.data-table th[data-v-e7cc9235],.data-table td[data-v-e7cc9235]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-e7cc9235]{transition:background-color .2s}.data-table .data-row[data-v-e7cc9235]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-e7cc9235]{vertical-align:middle}.data-table .loading-cell[data-v-e7cc9235],.data-table .empty-cell[data-v-e7cc9235]{padding:60px 20px}.data-table .loading-content[data-v-e7cc9235],.data-table .empty-content[data-v-e7cc9235]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-e7cc9235],.data-table .empty-content svg[data-v-e7cc9235]{width:64px;height:41px}.data-table .loading-spinner[data-v-e7cc9235]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-e7cc9235 .8s linear infinite}@keyframes spin-e7cc9235{to{transform:rotate(360deg)}}.tree-row--level-1 .col-name[data-v-e7cc9235]{padding-left:40px}.tree-indent[data-v-e7cc9235]{display:inline-block;width:24px}.tree-line[data-v-e7cc9235]{position:relative;display:inline-block;width:16px;height:1px;background:var(--color-border-light);margin-right:8px;vertical-align:middle}.col-name[data-v-e7cc9235]{min-width:200px}.menu-info[data-v-e7cc9235]{display:flex;align-items:center;gap:8px}.menu-icon-wrapper[data-v-e7cc9235]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-fill-light);border-radius:6px;font-size:14px}.menu-title[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:color .2s}.menu-title[data-v-e7cc9235]:hover{color:var(--color-primary)}.col-icon[data-v-e7cc9235]{width:80px}.icon-text[data-v-e7cc9235]{font-size:16px}.col-path[data-v-e7cc9235]{min-width:140px}.path-code[data-v-e7cc9235]{font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:4px 8px;background:var(--color-fill-light);border-radius:4px;color:var(--color-text-secondary)}.col-type[data-v-e7cc9235]{width:80px}.col-sort[data-v-e7cc9235]{width:60px}.sort-badge[data-v-e7cc9235]{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--color-fill);border-radius:12px;font-size:12px;color:var(--color-text-secondary)}.col-status[data-v-e7cc9235]{width:80px}.col-actions[data-v-e7cc9235]{min-width:140px}.action-buttons[data-v-e7cc9235] .x-button{padding:4px 8px}.action-buttons[data-v-e7cc9235] .x-button svg{width:14px;height:14px;margin-right:4px}.menu-form[data-v-e7cc9235]{padding:16px 0}.menu-form .form-grid[data-v-e7cc9235]{display:grid;grid-template-columns:repeat(2,1fr);gap:0 24px}.menu-form .form-item-full[data-v-e7cc9235]{grid-column:span 2}.menu-form .status-field[data-v-e7cc9235]{display:flex;align-items:center;gap:12px}.menu-form .status-label[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}
|
|
1
|
+
@charset "UTF-8";:root{--color-primary: #1677ff;--color-primary-light-1: #4096ff;--color-primary-light-2: #69b1ff;--color-primary-light-3: #91caff;--color-primary-light-4: #bae0ff;--color-primary-light-5: #e6f4ff;--color-primary-light-6: #f0f8ff;--color-primary-dark-1: #0958d9;--color-primary-dark-2: #003eb3;--color-primary-dark-3: #002c8c;--color-success: #52c41a;--color-success-light: #b7eb8f;--color-success-lighter: #f6ffed;--color-success-dark: #389e0d;--color-warning: #faad14;--color-warning-light: #ffe58f;--color-warning-lighter: #fffbe6;--color-warning-dark: #d48806;--color-danger: #ff4d4f;--color-danger-light: #ffa39e;--color-danger-lighter: #fff2f0;--color-danger-dark: #cf1322;--color-info: #1677ff;--color-info-light: #91caff;--color-info-lighter: #e6f4ff;--color-info-dark: #0958d9;--color-text-primary: #1f1f1f;--color-text-regular: #424242;--color-text-secondary: #757575;--color-text-placeholder: #9e9e9e;--color-text-disabled: #bdbdbd;--color-border: #d9d9d9;--color-border-light: #e8e8e8;--color-border-lighter: #f0f0f0;--color-border-extra-light: #f5f5f5;--color-border-dark: #bfbfbf;--color-fill: #f5f5f5;--color-fill-light: #fafafa;--color-fill-lighter: #ffffff;--color-fill-blank: #ffffff;--color-fill-dark: #e8e8e8;--bg-color: #ffffff;--bg-color-page: #f0f2f5;--bg-color-component: #ffffff;--bg-color-overlay: #ffffff;--bg-color-spotlight: #e6f4ff;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .08), 0 3px 6px -4px rgba(0, 0, 0, .12), 0 9px 28px 8px rgba(0, 0, 0, .05);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .03), 0 1px 6px -1px rgba(0, 0, 0, .02), 0 2px 4px 0 rgba(0, 0, 0, .02);--box-shadow-lighter: 0 1px 4px rgba(0, 0, 0, .04);--box-shadow-dark: 0 6px 16px -8px rgba(0, 0, 0, .08), 0 9px 28px 8px rgba(0, 0, 0, .05), 0 12px 48px 16px rgba(0, 0, 0, .03);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .1);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .12);--font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-family-code: "IBM Plex Mono", "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-base: 14px;--font-size-small: 12px;--font-size-large: 16px;--font-size-extra-large: 20px;--font-size-title: 24px;--font-size-hero: 38px;--font-line-height: 1.5714285714285714;--border-radius-base: 6px;--border-radius-small: 4px;--border-radius-large: 8px;--border-radius-extra-large: 12px;--border-radius-round: 24px;--border-radius-circle: 50%;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--component-size-large: 40px;--component-size-default: 32px;--component-size-small: 24px;--transition-duration: .2s;--transition-duration-fast: .1s;--transition-duration-slow: .3s;--transition-easing: cubic-bezier(.645, .045, .355, 1);--transition-easing-bounce: cubic-bezier(.68, -.55, .265, 1.55);--z-index-dropdown: 1000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070;--sidebar-width: 220px;--sidebar-collapsed-width: 64px;--header-height: 56px;--tabs-height: 40px;--footer-height: 32px;--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #1677ff 50%, #4096ff 100%);--gradient-card: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .8) 100%);--gradient-mask: linear-gradient(180deg, rgba(0, 44, 140, .03) 0%, rgba(0, 0, 0, 0) 100%)}.dark{--color-text-primary: #ffffff;--color-text-regular: #e0e0e0;--color-text-secondary: #a6a6a6;--color-text-placeholder: #737373;--color-text-disabled: #5c5c5c;--color-border: #434343;--color-border-light: #363636;--color-border-lighter: #2a2a2a;--color-border-extra-light: #1f1f1f;--color-border-dark: #5c5c5c;--color-fill: #262626;--color-fill-light: #1f1f1f;--color-fill-lighter: #141414;--color-fill-blank: #141414;--color-fill-dark: #363636;--bg-color: #141414;--bg-color-page: #0a0a0a;--bg-color-component: #1f1f1f;--bg-color-overlay: #1f1f1f;--bg-color-spotlight: #111d2c;--box-shadow: 0 6px 16px 0 rgba(0, 0, 0, .32), 0 3px 6px -4px rgba(0, 0, 0, .48), 0 9px 28px 8px rgba(0, 0, 0, .2);--box-shadow-light: 0 1px 2px 0 rgba(0, 0, 0, .16), 0 1px 6px -1px rgba(0, 0, 0, .12), 0 2px 4px 0 rgba(0, 0, 0, .08);--box-shadow-card: 0 1px 10px -6px rgba(0, 0, 0, .32);--box-shadow-card-hover: 0 6px 16px -8px rgba(0, 0, 0, .48);--gradient-primary: linear-gradient(135deg, #1677ff 0%, #4096ff 100%);--gradient-hero: linear-gradient(135deg, #002c8c 0%, #0958d9 50%, #1677ff 100%);--gradient-card: linear-gradient(180deg, rgba(20, 20, 20, 0) 0%, rgba(20, 20, 20, .8) 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;height:100%;font-size:var(--font-size-base);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{width:100%;height:100%;font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--bg-color-page)}#app{width:100%;height:100%}a{color:var(--color-primary);text-decoration:none;cursor:pointer;transition:color var(--transition-duration-fast)}a:hover{color:var(--color-primary-light-3)}ul,ol{list-style:none}img{max-width:100%;height:auto;vertical-align:middle}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none;outline:none}button:disabled{cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500;color:var(--color-text-primary)}p{margin:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background-color:var(--color-fill-light);border-radius:3px}::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-secondary)}::selection{background-color:var(--color-primary-light-8);color:var(--color-primary)}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-duration)}.fade-enter-from,.fade-leave-to{opacity:0}.fade-scale-enter-active,.fade-scale-leave-active{transition:all var(--transition-duration)}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:scale(.9)}.fade-transform-enter-active,.fade-transform-leave-active{transition:all var(--transition-duration-fast)}.fade-transform-enter-from{opacity:0;transform:translate(-10px)}.fade-transform-leave-to{opacity:0;transform:translate(10px)}.slide-down-enter-active,.slide-down-leave-active{transition:all var(--transition-duration)}.slide-down-enter-from,.slide-down-leave-to{opacity:0;transform:translateY(-20px)}.slide-up-enter-active,.slide-up-leave-active{transition:all var(--transition-duration)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(20px)}.slide-left-enter-active,.slide-left-leave-active{transition:all var(--transition-duration)}.slide-left-enter-from,.slide-left-leave-to{opacity:0;transform:translate(20px)}.slide-right-enter-active,.slide-right-leave-active{transition:all var(--transition-duration)}.slide-right-enter-from,.slide-right-leave-to{opacity:0;transform:translate(-20px)}.zoom-enter-active,.zoom-leave-active{transition:all var(--transition-duration)}.zoom-enter-from,.zoom-leave-to{opacity:0;transform:scale(.5)}.list-enter-active,.list-leave-active{transition:all var(--transition-duration)}.list-enter-from,.list-leave-to{opacity:0;transform:translateY(30px)}.collapse-transition{transition:width var(--transition-duration),padding var(--transition-duration)}.dark .sidebar,.dark .layout__aside{background-color:#1d1e1f}.dark .sidebar{border-right:1px solid #363637}.dark .sidebar__search-results{background-color:#1d1e1f;border-color:#363637}.dark .sidebar__search-item:hover{background-color:#262727}.dark .sidebar__search-item-title{color:#cfd3dc}.dark .sidebar__search-item-parent{color:#a3a6ad}.dark .sidebar__logo{border-bottom-color:#363637}.dark .sidebar__user{border-top-color:#363637}.dark .sidebar__user-name{color:#cfd3dc}.dark .sidebar__user-role{color:#a3a6ad}.dark .x-menu{background-color:#1d1e1f!important;border-color:#363637;color:#cfd3dc}.dark .x-menu.x-menu--vertical{border-right-color:#363637}.dark .x-menu.x-menu--horizontal{border-bottom-color:#363637;background-color:#1d1e1f!important}.dark .x-menu-item{color:#cfd3dc!important;background-color:transparent!important}.dark .x-menu-item:hover{background-color:#262727!important}.dark .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-menu-item.is-active:before{background-color:#409eff}.dark .x-menu-item.is-horizontal:hover{background-color:transparent!important}.dark .x-menu-item.is-horizontal.is-active{background-color:transparent!important;border-bottom-color:#409eff}.dark .x-sub-menu__title{color:#cfd3dc!important;background-color:transparent!important}.dark .x-sub-menu__title:hover{background-color:#262727!important}.dark .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .x-sub-menu__menu .x-menu-item{background-color:transparent!important;color:#cfd3dc!important}.dark .x-sub-menu__menu .x-menu-item:hover{background-color:#262727!important}.dark .x-sub-menu__menu .x-menu-item.is-active{color:#409eff!important;background-color:#409eff1a!important}.dark .x-sub-menu__arrow{color:#a3a6ad}.dark .x-sub-menu.is-active>.x-sub-menu__title{color:#409eff!important}.dark .x-sub-menu--horizontal .x-sub-menu__title:hover{background-color:transparent!important}.dark .x-sub-menu--horizontal .x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .x-sub-menu.is-collapse>.x-sub-menu__menu{background-color:#1d1e1f!important;border:1px solid #363637}.dark .header{background-color:#1d1e1f;border-bottom-color:#363637}.dark .header__collapse{color:#cfd3dc}.dark .header__breadcrumb{color:#a3a6ad}.dark .header__user-name{color:#cfd3dc}.dark .header__user-arrow{color:#a3a6ad}.dark .header__action:hover,.dark .header__user-trigger:hover{background-color:#262727}.dark .header__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .header__dropdown-name{color:#e5eaf3}.dark .header__dropdown-role{color:#a3a6ad}.dark .header__dropdown-divider{background-color:#363637}.dark .header__dropdown-item{color:#cfd3dc}.dark .header__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .top-menu{background-color:#1d1e1f}.dark .top-menu__menu{background-color:#1d1e1f!important}.dark .top-menu__menu-char{background-color:#409eff33;color:#79bbff}.dark .top-menu__action{color:#cfd3dc}.dark .top-menu__action:hover{background-color:#262727;color:#409eff}.dark .top-menu__user-trigger:hover{background-color:#262727}.dark .top-menu__user-name{color:#cfd3dc}.dark .top-menu__user-arrow{color:#a3a6ad}.dark .top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .top-menu__dropdown-name{color:#e5eaf3}.dark .top-menu__dropdown-role{color:#a3a6ad}.dark .top-menu__dropdown-divider{background-color:#363637}.dark .top-menu__dropdown-item{color:#cfd3dc}.dark .top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.dark .x-button.x-button--default{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-button.x-button--default:hover{border-color:#409eff;color:#409eff}.dark .x-button.x-button--text{color:#409eff}.dark .x-form-item__label{color:#cfd3dc}.dark .x-form-item__error{color:#f56c6c}.dark .x-input{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-input.is-focus{border-color:#409eff}.dark .x-input .x-input__inner{background-color:transparent;color:#e5eaf3}.dark .x-input .x-input__inner::placeholder{color:#6c6e72}.dark .x-input .x-input__suffix,.dark .x-input .x-input__prefix{color:#a3a6ad}.dark .x-select{background-color:#1d1e1f;border-color:#4c4d4f}.dark .x-card{background-color:#1d1e1f;border-color:#363637}.dark .x-card__header{border-bottom-color:#363637;color:#e5eaf3}.dark .data-table th{background-color:#262727;color:#cfd3dc;border-bottom-color:#363637}.dark .data-table td{border-bottom-color:#363637;color:#cfd3dc}.dark .data-table tr:hover td{background-color:#262727}.dark .x-modal__wrapper{background-color:#000000b3}.dark .x-modal__container{background-color:#1d1e1f;border:1px solid #363637}.dark .x-modal__header{border-bottom-color:#363637;color:#e5eaf3}.dark .x-modal__footer{border-top-color:#363637}.dark .x-message{background-color:#1d1e1f;border:1px solid #363637}.dark .x-tag.x-tag--primary{background-color:#409eff33;color:#79bbff;border-color:#409eff4d}.dark .x-tag.x-tag--success{background-color:#67c23a33;color:#95d475;border-color:#67c23a4d}.dark .x-tag.x-tag--warning{background-color:#e6a23c33;color:#eebe77;border-color:#e6a23c4d}.dark .x-tag.x-tag--danger{background-color:#f56c6c33;color:#fab6b6;border-color:#f56c6c4d}.dark .x-tag.x-tag--info{background-color:#90939933;color:#c0c4cc;border-color:#9093994d}.dark .x-switch{background-color:#4c4d4f}.dark .x-switch.is-checked{background-color:#409eff}.dark .x-pagination{color:#cfd3dc}.dark .x-pagination__item{background-color:#1d1e1f;border-color:#4c4d4f;color:#cfd3dc}.dark .x-pagination__item:hover{color:#409eff}.dark .x-pagination__item.is-active{background-color:#409eff;border-color:#409eff;color:#fff}.dark .login{background:linear-gradient(135deg,#1a1a2e,#16213e)}.dark .login__container{background-color:#1d1e1f;border:1px solid #363637}.dark .login__title{color:#409eff}.dark .login__subtitle{color:#a3a6ad}.dark .login__footer{color:#6c6e72}.dark .stat-card__title{color:#a3a6ad}.dark .quick-link{background-color:#262727}.dark .quick-link:hover{background-color:#409eff1a}.dark .quick-link__title{color:#cfd3dc}.dark .activity-item{border-bottom-color:#363637}.dark .activity-item__action{color:#cfd3dc}.dark .search-card,.dark .table-card,.dark .x-popconfirm{background-color:#1d1e1f;border:1px solid #363637}.dark .x-drawer{background-color:#1d1e1f}.dark .x-drawer__header{background-color:#1d1e1f;border-bottom-color:#363637;color:#e5eaf3}.dark .x-drawer__body{background-color:#1d1e1f;color:#cfd3dc}.dark .x-drawer__footer{background-color:#1d1e1f;border-top-color:#363637}.dark .settings-drawer .settings-title{color:#e5eaf3}.dark .settings-drawer .settings-section{background-color:transparent}.dark .settings-drawer .layout-option{border-color:#4c4d4f;background-color:transparent}.dark .settings-drawer .layout-option:hover{border-color:#409eff}.dark .settings-drawer .layout-option.is-active{border-color:#409eff;background-color:#409eff1a}.dark .settings-drawer .layout-option__label,.dark .settings-drawer .settings-switch-item span{color:#cfd3dc}.dark .mix-top-menu{background-color:#1d1e1f;border-bottom-color:#363637}.dark .mix-top-menu__logo-text{color:#409eff}.dark .mix-top-menu__menu{background-color:#1d1e1f!important}.dark .mix-top-menu__menu-char{color:#79bbff;background-color:#409eff33}.dark .mix-top-menu__action{color:#cfd3dc}.dark .mix-top-menu__action:hover{background-color:#262727;color:#409eff}.dark .mix-top-menu__user-trigger:hover{background-color:#262727}.dark .mix-top-menu__user-name{color:#cfd3dc}.dark .mix-top-menu__user-arrow{color:#a3a6ad}.dark .mix-top-menu__dropdown{background-color:#1d1e1f;border:1px solid #363637;box-shadow:0 2px 12px #00000080}.dark .mix-top-menu__dropdown-name{color:#e5eaf3}.dark .mix-top-menu__dropdown-role{color:#a3a6ad}.dark .mix-top-menu__dropdown-divider{background-color:#363637}.dark .mix-top-menu__dropdown-item{color:#cfd3dc}.dark .mix-top-menu__dropdown-item:hover{background-color:#262727;color:#e5eaf3}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-ellipsis-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-ellipsis-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-start{display:flex;align-items:center;justify-content:flex-start}.flex-end{display:flex;align-items:center;justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.flex-col{display:flex;flex-direction:column}.flex-col-center{display:flex;flex-direction:column;align-items:center}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.gap-32{gap:32px}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.text-secondary{color:var(--color-text-secondary)}.text-placeholder{color:var(--color-text-placeholder)}.bg-primary{background-color:var(--color-primary)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-danger{background-color:var(--color-danger)}.bg-page{background-color:var(--bg-color-page)}.bg-card{background-color:var(--bg-color)}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.ml-4{margin-left:4px}.ml-8{margin-left:8px}.ml-12{margin-left:12px}.ml-16{margin-left:16px}.mr-4{margin-right:4px}.mr-8{margin-right:8px}.mr-12{margin-right:12px}.mr-16{margin-right:16px}.p-4{padding:4px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-20{padding:20px}.p-24{padding:24px}.p-32{padding:32px}.px-4{padding-left:4px;padding-right:4px}.px-8{padding-left:8px;padding-right:8px}.px-12{padding-left:12px;padding-right:12px}.px-16{padding-left:16px;padding-right:16px}.px-24{padding-left:24px;padding-right:24px}.py-4{padding-top:4px;padding-bottom:4px}.py-8{padding-top:8px;padding-bottom:8px}.py-12{padding-top:12px;padding-bottom:12px}.py-16{padding-top:16px;padding-bottom:16px}.py-24{padding-top:24px;padding-bottom:24px}.card{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);padding:var(--spacing-lg);transition:box-shadow .3s ease}.card:hover{box-shadow:var(--box-shadow-card-hover)}.card-flat{background-color:var(--bg-color);border-radius:var(--border-radius-large);padding:var(--spacing-lg);border:1px solid var(--color-border-lighter)}.page-container{padding:12px;min-height:100%;background:var(--bg-color-page)}.search-bar{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:12px;padding:12px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--color-border-lighter)}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.table-container{background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.pagination-container{display:flex;justify-content:flex-end;padding:12px;border-top:1px solid var(--color-border-lighter)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:12px;font-weight:500;border-radius:10px;background:var(--color-fill);color:var(--color-text-secondary)}.badge-primary{background:var(--color-primary-light-6);color:var(--color-primary)}.badge-success{background:var(--color-success-lighter);color:var(--color-success)}.badge-warning{background:var(--color-warning-lighter);color:var(--color-warning)}.badge-danger{background:var(--color-danger-lighter);color:var(--color-danger)}.divider{height:1px;background:var(--color-border-lighter);margin:var(--spacing-md) 0}.divider-vertical{width:1px;height:100%;background:var(--color-border-lighter);margin:0 var(--spacing-md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--color-text-placeholder)}.empty-state .empty-icon{width:64px;height:64px;margin-bottom:16px;opacity:.5}.empty-state .empty-text{font-size:14px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-state .loading-spinner{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-state .loading-text{margin-top:16px;font-size:14px;color:var(--color-text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.link{color:var(--color-primary);text-decoration:none;transition:color .2s ease}.link:hover{color:var(--color-primary-dark-1)}.link-underline{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.link-underline:hover{color:var(--color-primary-dark-1)}.x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}.x-sub-menu__menu .x-menu-item.is-active{color:var(--color-primary)!important;background-color:var(--color-primary-light-9)!important;position:relative}.x-sub-menu__menu .x-menu-item.is-active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--color-primary);border-radius:0 2px 2px 0}html.grey-mode{filter:grayscale(100%);-webkit-filter:grayscale(100%)}:root{--bg-color: #ffffff;--bg-color-page: #f5f7fa;--color-border-lighter: #e4e7ed}.menu-item__content[data-v-f5865e28]{display:inline-flex;align-items:center;line-height:1}.menu-item__text[data-v-f5865e28]{flex:1;line-height:1}.menu-item__icon[data-v-f5865e28]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.menu-item__char[data-v-f5865e28]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.sidebar[data-v-2ecab012]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color);border-right:1px solid var(--color-border-lighter)}.sidebar--collapsed .sidebar__logo[data-v-2ecab012]{justify-content:center;padding:0}.sidebar__logo[data-v-2ecab012]{height:50px;display:flex;align-items:center;padding:0 20px;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-2ecab012]{width:32px;height:32px}.sidebar__logo-text[data-v-2ecab012]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__menu[data-v-2ecab012]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-2ecab012]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-2ecab012]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-2ecab012]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-2ecab012]{font-size:12px;color:var(--color-text-secondary)}.header[data-v-cf67ace4]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter)}.header__left[data-v-cf67ace4]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-cf67ace4]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-regular);transition:color .2s}.header__collapse[data-v-cf67ace4]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-cf67ace4]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .breadcrumb-separator[data-v-cf67ace4]{margin:0 8px;color:var(--color-text-placeholder)}.header__breadcrumb .is-current[data-v-cf67ace4]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-cf67ace4]{display:flex;align-items:center;gap:8px}.header__search[data-v-cf67ace4]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.header__search-icon[data-v-cf67ace4]{color:var(--color-text-secondary)}.header__search-input[data-v-cf67ace4]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.header__search-input[data-v-cf67ace4]::placeholder{color:var(--color-text-placeholder)}.header__search-dropdown[data-v-cf67ace4]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.header__search-results[data-v-cf67ace4]{padding:8px 0}.header__search-item[data-v-cf67ace4]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.header__search-item[data-v-cf67ace4]:hover{background-color:var(--color-fill)}.header__search-item-title[data-v-cf67ace4]{font-size:14px;color:var(--color-text-primary)}.header__search-item-parent[data-v-cf67ace4]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.header__search-icon[data-v-cf67ace4]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.header__search-char[data-v-cf67ace4]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.header__search-empty[data-v-cf67ace4]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.header__action[data-v-cf67ace4]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.header__action[data-v-cf67ace4]:hover{background-color:var(--color-fill);color:var(--color-primary)}.header__user[data-v-cf67ace4]{position:relative;margin-left:8px}.header__user-trigger[data-v-cf67ace4]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-cf67ace4]:hover{background-color:var(--color-fill)}.header__user-name[data-v-cf67ace4]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__user-arrow[data-v-cf67ace4]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-cf67ace4]{transform:rotate(180deg)}.header__avatar[data-v-cf67ace4]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-cf67ace4]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-cf67ace4]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-cf67ace4]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-cf67ace4]{flex:1}.header__dropdown-name[data-v-cf67ace4]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-cf67ace4]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-cf67ace4]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-cf67ace4]{padding:8px 0}.header__dropdown-item[data-v-cf67ace4]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-cf67ace4]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-cf67ace4]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-cf67ace4]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-cf67ace4]{margin-bottom:24px}.settings-drawer .settings-title[data-v-cf67ace4]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-cf67ace4]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-cf67ace4]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-cf67ace4]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-cf67ace4]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-cf67ace4]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-cf67ace4]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-cf67ace4]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-cf67ace4]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-cf67ace4]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-cf67ace4]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-cf67ace4]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-cf67ace4]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-cf67ace4]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-cf67ace4]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-cf67ace4]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-cf67ace4]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-cf67ace4]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-cf67ace4]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-cf67ace4]{display:flex;gap:12px}.settings-drawer .color-option[data-v-cf67ace4]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-cf67ace4]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-cf67ace4]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-cf67ace4]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-cf67ace4]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-cf67ace4]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-cf67ace4]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-cf67ace4]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-cf67ace4]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-cf67ace4]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-cf67ace4]:after{left:24px}.dropdown-enter-active[data-v-cf67ace4],.dropdown-leave-active[data-v-cf67ace4]{transition:all .2s ease}.dropdown-enter-from[data-v-cf67ace4],.dropdown-leave-to[data-v-cf67ace4]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-cf67ace4],.search-dropdown-leave-active[data-v-cf67ace4]{transition:all .2s ease}.search-dropdown-enter-from[data-v-cf67ace4],.search-dropdown-leave-to[data-v-cf67ace4]{opacity:0;transform:translateY(-4px)}.top-menu[data-v-15f7b516]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.top-menu__logo[data-v-15f7b516]{display:flex;align-items:center;gap:10px;margin-right:20px}.top-menu__logo-img[data-v-15f7b516]{width:32px;height:32px}.top-menu__logo-text[data-v-15f7b516]{font-size:16px;font-weight:600;color:var(--color-primary)}.top-menu__menu[data-v-15f7b516]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu{height:49px;line-height:49px;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-menu-item.is-horizontal{height:49px;line-height:49px}.top-menu__menu[data-v-15f7b516] .x-menu-item__content{height:49px}.top-menu__menu[data-v-15f7b516] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-sub-menu--horizontal{height:49px}.top-menu__menu[data-v-15f7b516] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.top-menu__menu[data-v-15f7b516] .x-sub-menu__content{height:49px}.top-menu__menu-content[data-v-15f7b516]{align-items:center;line-height:1}.top-menu__menu-text[data-v-15f7b516]{line-height:1}.top-menu__menu-icon[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.top-menu__menu-char[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__actions[data-v-15f7b516]{display:flex;align-items:center;gap:8px}.top-menu__search[data-v-15f7b516]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.top-menu__search-icon[data-v-15f7b516]{color:var(--color-text-secondary)}.top-menu__search-input[data-v-15f7b516]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.top-menu__search-input[data-v-15f7b516]::placeholder{color:var(--color-text-placeholder)}.top-menu__search-dropdown[data-v-15f7b516]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.top-menu__search-results[data-v-15f7b516]{padding:8px 0}.top-menu__search-item[data-v-15f7b516]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.top-menu__search-item[data-v-15f7b516]:hover{background-color:var(--color-fill)}.top-menu__search-item-title[data-v-15f7b516]{font-size:14px;color:var(--color-text-primary)}.top-menu__search-item-parent[data-v-15f7b516]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.top-menu__search-icon-item[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.top-menu__search-char[data-v-15f7b516]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.top-menu__search-empty[data-v-15f7b516]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.top-menu__action[data-v-15f7b516]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.top-menu__action[data-v-15f7b516]:hover{background-color:var(--color-fill);color:var(--color-primary)}.top-menu__user[data-v-15f7b516]{position:relative;margin-left:8px}.top-menu__user-trigger[data-v-15f7b516]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.top-menu__user-trigger[data-v-15f7b516]:hover{background-color:var(--color-fill)}.top-menu__user-name[data-v-15f7b516]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-menu__user-arrow[data-v-15f7b516]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.top-menu__user-arrow.is-active[data-v-15f7b516]{transform:rotate(180deg)}.top-menu__avatar[data-v-15f7b516]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.top-menu__dropdown[data-v-15f7b516]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.top-menu__dropdown-header[data-v-15f7b516]{display:flex;align-items:center;gap:12px;padding:16px}.top-menu__dropdown-avatar[data-v-15f7b516]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.top-menu__dropdown-info[data-v-15f7b516]{flex:1}.top-menu__dropdown-name[data-v-15f7b516]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.top-menu__dropdown-role[data-v-15f7b516]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.top-menu__dropdown-divider[data-v-15f7b516]{height:1px;background-color:var(--color-border-lighter)}.top-menu__dropdown-menu[data-v-15f7b516]{padding:8px 0}.top-menu__dropdown-item[data-v-15f7b516]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.top-menu__dropdown-item[data-v-15f7b516]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.top-menu__dropdown-item--danger[data-v-15f7b516]{color:var(--color-danger)}.top-menu__dropdown-item--danger[data-v-15f7b516]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-15f7b516]{margin-bottom:24px}.settings-drawer .settings-title[data-v-15f7b516]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-15f7b516]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-15f7b516]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-15f7b516]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-15f7b516]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-15f7b516]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-15f7b516]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-15f7b516]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-15f7b516]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-15f7b516]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-15f7b516]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-15f7b516]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-15f7b516]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-15f7b516]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-15f7b516]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-15f7b516]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-15f7b516]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-15f7b516]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-15f7b516]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-15f7b516]{display:flex;gap:12px}.settings-drawer .color-option[data-v-15f7b516]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-15f7b516]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-15f7b516]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-15f7b516]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-15f7b516]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-15f7b516]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-15f7b516]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-15f7b516]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-15f7b516]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-15f7b516]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-15f7b516]:after{left:24px}.dropdown-enter-active[data-v-15f7b516],.dropdown-leave-active[data-v-15f7b516]{transition:all .2s ease}.dropdown-enter-from[data-v-15f7b516],.dropdown-leave-to[data-v-15f7b516]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-15f7b516],.search-dropdown-leave-active[data-v-15f7b516]{transition:all .2s ease}.search-dropdown-enter-from[data-v-15f7b516],.search-dropdown-leave-to[data-v-15f7b516]{opacity:0;transform:translateY(-4px)}.mix-top-menu[data-v-d5fb6d2a]{width:100%;height:100%;display:flex;align-items:center;padding:0 20px}.mix-top-menu__logo[data-v-d5fb6d2a]{display:flex;align-items:center;gap:10px;margin-right:20px}.mix-top-menu__logo-img[data-v-d5fb6d2a]{width:32px;height:32px}.mix-top-menu__logo-text[data-v-d5fb6d2a]{font-size:16px;font-weight:600;color:var(--color-primary)}.mix-top-menu__menu[data-v-d5fb6d2a]{flex:1;border-bottom:none;height:49px;display:flex;align-items:center;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu{height:49px;line-height:49px;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu--horizontal{height:49px;display:flex;align-items:center;border-bottom:none;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item.is-horizontal{height:49px;line-height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-menu-item__content{height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu--horizontal{height:49px}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu__title{height:49px;line-height:49px;box-sizing:border-box;border-bottom:none}.mix-top-menu__menu[data-v-d5fb6d2a] .x-sub-menu__content{height:49px}.mix-top-menu__menu-content[data-v-d5fb6d2a]{align-items:center;line-height:1}.mix-top-menu__menu-text[data-v-d5fb6d2a]{line-height:1}.mix-top-menu__menu-icon[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:8px;flex-shrink:0}.mix-top-menu__menu-char[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__actions[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px}.mix-top-menu__search[data-v-d5fb6d2a]{position:relative;display:flex;align-items:center;background-color:var(--color-fill-light);border-radius:var(--border-radius-base);padding:0 12px;height:32px;width:200px}.mix-top-menu__search-icon[data-v-d5fb6d2a]{color:var(--color-text-secondary)}.mix-top-menu__search-input[data-v-d5fb6d2a]{flex:1;height:100%;font-size:14px;color:var(--color-text-primary);background:transparent;border:none;outline:none;padding-left:8px}.mix-top-menu__search-input[data-v-d5fb6d2a]::placeholder{color:var(--color-text-placeholder)}.mix-top-menu__search-dropdown[data-v-d5fb6d2a]{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;max-height:300px;overflow-y:auto;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);z-index:100}.mix-top-menu__search-results[data-v-d5fb6d2a]{padding:8px 0}.mix-top-menu__search-item[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s}.mix-top-menu__search-item[data-v-d5fb6d2a]:hover{background-color:var(--color-fill)}.mix-top-menu__search-item-title[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-primary)}.mix-top-menu__search-item-parent[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-secondary);margin-left:auto}.mix-top-menu__search-icon-item[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.mix-top-menu__search-char[data-v-d5fb6d2a]{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-light-8);border-radius:4px}.mix-top-menu__search-empty[data-v-d5fb6d2a]{padding:16px 12px;text-align:center;color:var(--color-text-secondary);font-size:14px}.mix-top-menu__action[data-v-d5fb6d2a]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);color:var(--color-text-regular);transition:all .2s}.mix-top-menu__action[data-v-d5fb6d2a]:hover{background-color:var(--color-fill);color:var(--color-primary)}.mix-top-menu__user[data-v-d5fb6d2a]{position:relative;margin-left:8px}.mix-top-menu__user-trigger[data-v-d5fb6d2a]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.mix-top-menu__user-trigger[data-v-d5fb6d2a]:hover{background-color:var(--color-fill)}.mix-top-menu__user-name[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mix-top-menu__user-arrow[data-v-d5fb6d2a]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.mix-top-menu__user-arrow.is-active[data-v-d5fb6d2a]{transform:rotate(180deg)}.mix-top-menu__avatar[data-v-d5fb6d2a]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.mix-top-menu__dropdown[data-v-d5fb6d2a]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.mix-top-menu__dropdown-header[data-v-d5fb6d2a]{display:flex;align-items:center;gap:12px;padding:16px}.mix-top-menu__dropdown-avatar[data-v-d5fb6d2a]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.mix-top-menu__dropdown-info[data-v-d5fb6d2a]{flex:1}.mix-top-menu__dropdown-name[data-v-d5fb6d2a]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.mix-top-menu__dropdown-role[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.mix-top-menu__dropdown-divider[data-v-d5fb6d2a]{height:1px;background-color:var(--color-border-lighter)}.mix-top-menu__dropdown-menu[data-v-d5fb6d2a]{padding:8px 0}.mix-top-menu__dropdown-item[data-v-d5fb6d2a]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.mix-top-menu__dropdown-item[data-v-d5fb6d2a]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.mix-top-menu__dropdown-item--danger[data-v-d5fb6d2a]{color:var(--color-danger)}.mix-top-menu__dropdown-item--danger[data-v-d5fb6d2a]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.settings-drawer .settings-section[data-v-d5fb6d2a]{margin-bottom:24px}.settings-drawer .settings-title[data-v-d5fb6d2a]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.settings-drawer .settings-layout-options[data-v-d5fb6d2a]{display:flex;gap:12px}.settings-drawer .layout-option[data-v-d5fb6d2a]{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-base);cursor:pointer;transition:all .2s}.settings-drawer .layout-option[data-v-d5fb6d2a]:hover{border-color:var(--color-primary-light-5)}.settings-drawer .layout-option.is-active[data-v-d5fb6d2a]{border-color:var(--color-primary);background-color:var(--color-primary-light-9)}.settings-drawer .layout-option__preview[data-v-d5fb6d2a]{width:48px;height:36px;border:1px solid var(--color-border-light);border-radius:2px;overflow:hidden}.settings-drawer .layout-option__label[data-v-d5fb6d2a]{font-size:12px;color:var(--color-text-regular)}.settings-drawer .layout-preview-sidebar[data-v-d5fb6d2a]{display:flex;height:100%}.settings-drawer .layout-preview-sidebar .preview-aside[data-v-d5fb6d2a]{width:25%;height:100%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-sidebar .preview-main[data-v-d5fb6d2a]{flex:1;display:flex;flex-direction:column}.settings-drawer .layout-preview-sidebar .preview-main .preview-header[data-v-d5fb6d2a]{height:20%;background-color:var(--color-border-light)}.settings-drawer .layout-preview-sidebar .preview-main .preview-content[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-top[data-v-d5fb6d2a]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-top .preview-header-full[data-v-d5fb6d2a]{height:25%;background-color:var(--color-primary-light-7)}.settings-drawer .layout-preview-top .preview-content-full[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .layout-preview-mix[data-v-d5fb6d2a]{display:flex;flex-direction:column;height:100%}.settings-drawer .layout-preview-mix .preview-header-mix[data-v-d5fb6d2a]{height:25%;background-color:var(--color-primary-light-7);display:flex}.settings-drawer .layout-preview-mix .preview-header-mix .preview-mix-left[data-v-d5fb6d2a]{width:30%;background-color:var(--color-primary)}.settings-drawer .layout-preview-mix .preview-mix-body[data-v-d5fb6d2a]{flex:1;display:flex}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-aside[data-v-d5fb6d2a]{width:25%;background-color:var(--color-primary-light-8)}.settings-drawer .layout-preview-mix .preview-mix-body .preview-mix-content[data-v-d5fb6d2a]{flex:1;background-color:var(--bg-color-page)}.settings-drawer .settings-color-options[data-v-d5fb6d2a]{display:flex;gap:12px}.settings-drawer .color-option[data-v-d5fb6d2a]{width:24px;height:24px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.settings-drawer .color-option[data-v-d5fb6d2a]:hover{transform:scale(1.1)}.settings-drawer .color-option.is-active[data-v-d5fb6d2a]{box-shadow:0 0 0 2px var(--bg-color),0 0 0 4px var(--color-primary)}.settings-drawer .settings-switch-list[data-v-d5fb6d2a]{display:flex;flex-direction:column;gap:12px}.settings-drawer .settings-switch-item[data-v-d5fb6d2a]{display:flex;align-items:center;justify-content:space-between}.settings-drawer .settings-switch-item span[data-v-d5fb6d2a]{font-size:14px;color:var(--color-text-regular)}.settings-drawer .switch-wrapper[data-v-d5fb6d2a]{width:44px;height:22px;display:flex;align-items:center;cursor:pointer}.settings-drawer .switch-wrapper .switch-core[data-v-d5fb6d2a]{width:100%;height:100%;border-radius:11px;background-color:var(--color-border);position:relative;transition:background-color .2s}.settings-drawer .switch-wrapper .switch-core[data-v-d5fb6d2a]:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:left .2s}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-d5fb6d2a]{background-color:var(--color-primary)}.settings-drawer .switch-wrapper.is-checked .switch-core[data-v-d5fb6d2a]:after{left:24px}.dropdown-enter-active[data-v-d5fb6d2a],.dropdown-leave-active[data-v-d5fb6d2a]{transition:all .2s ease}.dropdown-enter-from[data-v-d5fb6d2a],.dropdown-leave-to[data-v-d5fb6d2a]{opacity:0;transform:translateY(-10px)}.search-dropdown-enter-active[data-v-d5fb6d2a],.search-dropdown-leave-active[data-v-d5fb6d2a]{transition:all .2s ease}.search-dropdown-enter-from[data-v-d5fb6d2a],.search-dropdown-leave-to[data-v-d5fb6d2a]{opacity:0;transform:translateY(-4px)}.layout[data-v-38f2fc61]{display:flex;width:100%;height:100%}.layout--sidebar[data-v-38f2fc61]{flex-direction:row}.layout--sidebar .layout__aside[data-v-38f2fc61]{height:100%}.layout--sidebar .layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;height:100%}.layout--top[data-v-38f2fc61]{flex-direction:column}.layout--top .layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;height:calc(100% - 50px)}.layout--top .layout__content[data-v-38f2fc61]{flex:1}.layout--mix[data-v-38f2fc61]{flex-direction:column}.layout--mix .layout__mix-top-menu[data-v-38f2fc61]{width:100%;height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout--mix .layout__mix-body[data-v-38f2fc61]{flex:1;display:flex;flex-direction:row;height:calc(100% - 50px)}.layout__aside[data-v-38f2fc61]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__top-menu[data-v-38f2fc61]{width:100%;height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__mix-top-menu[data-v-38f2fc61]{width:100%;height:50px;box-sizing:border-box;flex-shrink:0}.layout__main[data-v-38f2fc61]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-38f2fc61]{height:50px;box-sizing:border-box;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-38f2fc61]{flex:1;overflow:auto;background-color:var(--bg-color-page);padding:0}.tabs-wrapper[data-v-9156d8cd]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-9156d8cd] .t-tabs{height:100%}.tabs-wrapper[data-v-9156d8cd] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__nav{border:none}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-9156d8cd] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-9156d8cd]{display:flex;align-items:center;gap:5px}.tab-close[data-v-9156d8cd]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-9156d8cd]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-4852826a]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login-page[data-v-ef91e533]{width:100%;min-height:100vh;display:flex;background:var(--bg-color-page)}.login-brand[data-v-ef91e533]{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#002c8c,#0958d9,#1677ff);overflow:hidden}@media (max-width: 992px){.login-brand[data-v-ef91e533]{display:none}}.login-brand .brand-content[data-v-ef91e533]{position:relative;z-index:2;padding:60px;max-width:520px;color:#fff}.login-brand .brand-logo[data-v-ef91e533]{display:flex;align-items:center;gap:12px;margin-bottom:48px}.login-brand .brand-logo .logo-icon[data-v-ef91e533]{width:48px;height:48px;color:#fff}.login-brand .brand-logo .logo-text[data-v-ef91e533]{font-size:28px;font-weight:700;letter-spacing:2px}.login-brand .brand-slogan[data-v-ef91e533]{margin-bottom:48px}.login-brand .brand-slogan h1[data-v-ef91e533]{font-size:32px;font-weight:600;line-height:1.3;margin-bottom:12px}.login-brand .brand-slogan p[data-v-ef91e533]{font-size:16px;opacity:.8;line-height:1.6}.login-brand .brand-features[data-v-ef91e533]{display:flex;flex-direction:column;gap:24px}.login-brand .brand-features .feature-item[data-v-ef91e533]{display:flex;align-items:flex-start;gap:16px;padding:16px;background:#ffffff1a;border-radius:var(--border-radius-large);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.login-brand .brand-features .feature-item[data-v-ef91e533]:hover{background:#ffffff26;transform:translate(8px)}.login-brand .brand-features .feature-icon[data-v-ef91e533]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:var(--border-radius-base);flex-shrink:0}.login-brand .brand-features .feature-icon svg[data-v-ef91e533]{width:20px;height:20px}.login-brand .brand-features .feature-text h4[data-v-ef91e533]{font-size:15px;font-weight:600;margin-bottom:4px}.login-brand .brand-features .feature-text p[data-v-ef91e533]{font-size:13px;opacity:.8}.login-brand .brand-decoration[data-v-ef91e533]{position:absolute;bottom:60px;left:60px;right:60px;display:flex;align-items:center;gap:16px}.login-brand .brand-decoration .decoration-line[data-v-ef91e533]{flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.3),transparent)}.login-brand .brand-decoration .decoration-dots[data-v-ef91e533]{display:flex;gap:8px}.login-brand .brand-decoration .decoration-dots span[data-v-ef91e533]{width:6px;height:6px;background:#ffffff80;border-radius:50%}.login-brand .brand-bg[data-v-ef91e533]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.login-brand .brand-bg .bg-grid[data-v-ef91e533]{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}.login-brand .brand-bg .bg-glow[data-v-ef91e533]{position:absolute;top:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:glow-pulse-ef91e533 8s ease-in-out infinite}.login-brand .brand-bg .bg-pattern[data-v-ef91e533]{position:absolute;bottom:-10%;left:-10%;width:40%;height:40%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 60%)}@keyframes glow-pulse-ef91e533{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.login-form-section[data-v-ef91e533]{width:500px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:60px 80px;background:var(--bg-color)}@media (max-width: 768px){.login-form-section[data-v-ef91e533]{width:100%;padding:40px 24px}}.login-form-section .form-container[data-v-ef91e533]{width:100%;max-width:360px;margin:0 auto}.login-form-section .form-header[data-v-ef91e533]{margin-bottom:40px}.login-form-section .form-header h2[data-v-ef91e533]{font-size:28px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.login-form-section .form-header p[data-v-ef91e533]{font-size:14px;color:var(--color-text-secondary)}.login-form-section .login-form .input-wrapper[data-v-ef91e533]{margin-bottom:4px}.login-form-section .login-form .input-label[data-v-ef91e533]{display:block;font-size:14px;font-weight:500;color:var(--color-text-regular);margin-bottom:8px}.login-form-section .login-form[data-v-ef91e533] .x-form-item{margin-bottom:24px}.login-form-section .login-form[data-v-ef91e533] .x-input{--x-input-border-radius: 8px}.login-form-section .login-form[data-v-ef91e533] .x-input__prefix{margin-right:12px;color:var(--color-text-placeholder)}.login-form-section .form-options[data-v-ef91e533]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.login-form-section .form-options .forgot-link[data-v-ef91e533]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.login-form-section .form-options .forgot-link[data-v-ef91e533]:hover{color:var(--color-primary-dark-1)}.login-form-section .login-btn[data-v-ef91e533]{width:100%;height:44px;font-size:16px;font-weight:500;border-radius:8px;letter-spacing:4px;transition:all .3s ease}.login-form-section .login-btn[data-v-ef91e533]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1677ff66}.login-form-section .login-btn[data-v-ef91e533]:active:not(:disabled){transform:translateY(0)}.login-form-section .form-footer[data-v-ef91e533]{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border-lighter);text-align:center}.login-form-section .form-footer p[data-v-ef91e533]{font-size:13px;color:var(--color-text-placeholder);margin-bottom:16px}.login-form-section .form-footer .social-login[data-v-ef91e533]{display:flex;justify-content:center;gap:16px}.login-form-section .form-footer .social-btn[data-v-ef91e533]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-fill);border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary)}.login-form-section .form-footer .social-btn svg[data-v-ef91e533]{width:20px;height:20px}.login-form-section .form-footer .social-btn[data-v-ef91e533]:hover{background:var(--color-primary-light-6);color:var(--color-primary);transform:translateY(-2px)}.login-form-section .copyright[data-v-ef91e533]{margin-top:48px;text-align:center}.login-form-section .copyright p[data-v-ef91e533]{font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-1b083153]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-1b083153]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-1b083153]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-1b083153]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-1b083153]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-primary)}.error-bg .bg-circle.circle-2[data-v-1b083153]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-info)}.error-bg .bg-circle.circle-3[data-v-1b083153]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-primary-light-3)}.error-content[data-v-1b083153]{text-align:center}.error-code[data-v-1b083153]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-1b083153]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-1b083153]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-1b083153]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-1b083153]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-1b083153]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-1b083153]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-1b083153]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-1b083153] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-1b083153] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-1b083153]{padding:20px;background:var(--color-fill-light);border-radius:var(--border-radius-large)}.error-tip p[data-v-1b083153]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-1b083153]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-1b083153]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-1b083153]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-primary);border-radius:50%;opacity:.6}.error-page[data-v-d167f981]{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-color-page);position:relative;overflow:hidden}.error-container[data-v-d167f981]{position:relative;z-index:2;max-width:600px;padding:40px}.error-bg[data-v-d167f981]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden}.error-bg .bg-circle[data-v-d167f981]{position:absolute;border-radius:50%;opacity:.1}.error-bg .bg-circle.circle-1[data-v-d167f981]{width:400px;height:400px;top:-100px;right:-100px;background:var(--color-warning)}.error-bg .bg-circle.circle-2[data-v-d167f981]{width:300px;height:300px;bottom:-50px;left:-50px;background:var(--color-warning)}.error-bg .bg-circle.circle-3[data-v-d167f981]{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-warning-light)}.error-content[data-v-d167f981]{text-align:center}.error-code[data-v-d167f981]{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:32px}.error-code .code-digit[data-v-d167f981]{font-size:80px;font-weight:700;color:var(--color-text-primary);line-height:1}.error-code .code-zero[data-v-d167f981]{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-warning) 0%,var(--color-warning-light) 100%);border-radius:50%}.error-code .code-zero .zero-inner[data-v-d167f981]{font-size:48px;font-weight:700;color:#fff}.error-illustration[data-v-d167f981]{width:200px;height:120px;margin:0 auto 24px}.error-title[data-v-d167f981]{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.error-desc[data-v-d167f981]{font-size:14px;color:var(--color-text-secondary);margin-bottom:32px}.error-actions[data-v-d167f981]{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.error-actions[data-v-d167f981] .x-button{padding:12px 24px;border-radius:8px}.error-actions[data-v-d167f981] .x-button svg{width:18px;height:18px;margin-right:8px}.error-tip[data-v-d167f981]{padding:20px;background:var(--color-warning-lighter);border-radius:var(--border-radius-large)}.error-tip p[data-v-d167f981]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:12px}.error-tip ul[data-v-d167f981]{list-style:none;padding:0;margin:0}.error-tip ul li[data-v-d167f981]{font-size:13px;color:var(--color-text-secondary);position:relative;padding:4px 0 4px 16px}.error-tip ul li[data-v-d167f981]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-warning);border-radius:50%;opacity:.6}.dashboard[data-v-545d4c27]{padding:24px;background:var(--bg-color-page);min-height:100%}.stats-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}@media (max-width: 1200px){.stats-section[data-v-545d4c27]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-section[data-v-545d4c27]{grid-template-columns:1fr}}.stat-card[data-v-545d4c27]{position:relative;display:flex;align-items:flex-start;gap:16px;padding:20px;background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);transition:all .3s ease;overflow:hidden}.stat-card[data-v-545d4c27]:hover{box-shadow:var(--box-shadow-card-hover);transform:translateY(-4px)}.stat-card:hover .stat-decoration[data-v-545d4c27]{opacity:1}.stat-card .stat-icon[data-v-545d4c27]{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-large);flex-shrink:0}.stat-card .stat-icon span[data-v-545d4c27]{font-size:26px}.stat-card .stat-content[data-v-545d4c27]{flex:1;min-width:0}.stat-card .stat-title[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary);margin-bottom:8px}.stat-card .stat-value[data-v-545d4c27]{font-size:28px;font-weight:600;line-height:1.2;margin-bottom:8px}.stat-card .stat-trend[data-v-545d4c27]{display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:2px 8px;border-radius:12px}.stat-card .stat-trend svg[data-v-545d4c27]{width:14px;height:14px}.stat-card .stat-trend.up[data-v-545d4c27]{color:var(--color-success);background:var(--color-success-lighter)}.stat-card .stat-trend.down[data-v-545d4c27]{color:var(--color-danger);background:var(--color-danger-lighter)}.stat-card .stat-decoration[data-v-545d4c27]{position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:0;transition:opacity .3s ease}.main-section[data-v-545d4c27]{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}@media (max-width: 992px){.main-section[data-v-545d4c27]{grid-template-columns:1fr}}.section-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3[data-v-545d4c27]{font-size:16px;font-weight:600;color:var(--color-text-primary)}.section-header .section-badge[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder);background:var(--color-fill);padding:4px 10px;border-radius:12px}.section-header .section-link[data-v-545d4c27]{font-size:14px;color:var(--color-primary);text-decoration:none;transition:color .2s}.section-header .section-link[data-v-545d4c27]:hover{color:var(--color-primary-dark-1)}.quick-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.quick-grid[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.quick-card[data-v-545d4c27]{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-fill-light);border-radius:var(--border-radius-base);text-decoration:none;transition:all .2s ease}.quick-card[data-v-545d4c27]:hover{background:var(--color-primary-light-6);transform:translate(4px)}.quick-card:hover .quick-arrow[data-v-545d4c27]{color:var(--color-primary);transform:translate(4px)}.quick-card .quick-icon[data-v-545d4c27]{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-color);border-radius:var(--border-radius-base);font-size:22px;flex-shrink:0}.quick-card .quick-info[data-v-545d4c27]{flex:1;min-width:0}.quick-card .quick-title[data-v-545d4c27]{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-bottom:4px}.quick-card .quick-desc[data-v-545d4c27]{font-size:13px;color:var(--color-text-secondary)}.quick-card .quick-arrow[data-v-545d4c27]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-placeholder);transition:all .2s ease}.quick-card .quick-arrow svg[data-v-545d4c27]{width:16px;height:16px}.activity-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.activity-list[data-v-545d4c27]{display:flex;flex-direction:column}.activity-item[data-v-545d4c27]{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-border-lighter);position:relative}.activity-item[data-v-545d4c27]:last-child{border-bottom:none}.activity-avatar[data-v-545d4c27]{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;font-weight:500;flex-shrink:0}.activity-avatar.success[data-v-545d4c27]{background:var(--color-success-lighter);color:var(--color-success)}.activity-avatar.warning[data-v-545d4c27]{background:var(--color-warning-lighter);color:var(--color-warning)}.activity-avatar.info[data-v-545d4c27]{background:var(--color-info-lighter);color:var(--color-info)}.activity-avatar.danger[data-v-545d4c27]{background:var(--color-danger-lighter);color:var(--color-danger)}.activity-avatar.primary[data-v-545d4c27]{background:var(--color-primary-light-6);color:var(--color-primary)}.activity-content[data-v-545d4c27]{flex:1;min-width:0}.activity-main[data-v-545d4c27]{margin-bottom:4px}.activity-user[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-right:8px}.activity-action[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.activity-time[data-v-545d4c27]{font-size:12px;color:var(--color-text-placeholder)}.activity-dot[data-v-545d4c27]{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;opacity:.6}.activity-dot.success[data-v-545d4c27]{background:var(--color-success)}.activity-dot.warning[data-v-545d4c27]{background:var(--color-warning)}.activity-dot.info[data-v-545d4c27]{background:var(--color-info)}.activity-dot.danger[data-v-545d4c27]{background:var(--color-danger)}.activity-dot.primary[data-v-545d4c27]{background:var(--color-primary)}.system-section[data-v-545d4c27]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px;box-shadow:var(--box-shadow-card)}.system-grid[data-v-545d4c27]{display:grid;grid-template-columns:1fr 1.5fr;gap:24px}@media (max-width: 768px){.system-grid[data-v-545d4c27]{grid-template-columns:1fr}}.system-info-list[data-v-545d4c27]{display:flex;flex-direction:column;gap:12px}.info-item[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-fill-light);border-radius:var(--border-radius-base)}.info-item .info-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.info-item .info-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.system-status[data-v-545d4c27]{display:flex;flex-direction:column;gap:16px}.status-item .status-header[data-v-545d4c27]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.status-item .status-label[data-v-545d4c27]{font-size:14px;color:var(--color-text-secondary)}.status-item .status-value[data-v-545d4c27]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-page[data-v-5d3ed390]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-5d3ed390]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-5d3ed390] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-5d3ed390] .x-input,.search-section .search-form[data-v-5d3ed390] .x-select{width:200px}.table-section[data-v-5d3ed390]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-5d3ed390]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-5d3ed390]{display:flex;gap:12px}.table-toolbar .table-count[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-5d3ed390]{overflow-x:auto}.data-table[data-v-5d3ed390]{width:100%;border-collapse:collapse}.data-table th[data-v-5d3ed390],.data-table td[data-v-5d3ed390]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-5d3ed390]{transition:background-color .2s}.data-table .data-row[data-v-5d3ed390]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-5d3ed390]{vertical-align:middle}.data-table .loading-cell[data-v-5d3ed390],.data-table .empty-cell[data-v-5d3ed390]{padding:60px 20px}.data-table .loading-content[data-v-5d3ed390],.data-table .empty-content[data-v-5d3ed390]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-5d3ed390],.data-table .empty-content svg[data-v-5d3ed390]{width:64px;height:41px}.data-table .loading-spinner[data-v-5d3ed390]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-5d3ed390 .8s linear infinite}@keyframes spin-5d3ed390{to{transform:rotate(360deg)}}.col-id[data-v-5d3ed390]{width:80px}.id-badge[data-v-5d3ed390]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-user[data-v-5d3ed390]{min-width:180px}.user-info[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-avatar[data-v-5d3ed390]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light-1) 100%);border-radius:50%;font-size:16px;font-weight:500;color:#fff;flex-shrink:0}.user-detail[data-v-5d3ed390]{display:flex;flex-direction:column;gap:2px}.user-nickname[data-v-5d3ed390]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.user-username[data-v-5d3ed390]{font-size:12px;color:var(--color-text-placeholder)}.col-contact[data-v-5d3ed390]{min-width:180px}.contact-info[data-v-5d3ed390]{display:flex;flex-direction:column;gap:4px}.contact-email[data-v-5d3ed390],.contact-phone[data-v-5d3ed390]{font-size:13px;color:var(--color-text-regular)}.contact-phone[data-v-5d3ed390]{color:var(--color-text-secondary)}.col-roles[data-v-5d3ed390]{min-width:100px}.role-tags[data-v-5d3ed390]{display:flex;gap:6px}.col-status[data-v-5d3ed390]{min-width:120px}.status-switch[data-v-5d3ed390]{display:flex;align-items:center;gap:8px}.status-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-5d3ed390]{color:var(--color-success)}.col-time[data-v-5d3ed390]{min-width:160px}.time-text[data-v-5d3ed390]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-5d3ed390]{min-width:140px}.action-buttons[data-v-5d3ed390] .x-button{padding:4px 8px}.action-buttons[data-v-5d3ed390] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-5d3ed390]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.user-form[data-v-5d3ed390]{padding:16px 0}.user-form .status-field[data-v-5d3ed390]{display:flex;align-items:center;gap:12px}.user-form .status-label[data-v-5d3ed390]{font-size:14px;color:var(--color-text-secondary)}.role-page[data-v-de354764]{padding:24px;background:var(--bg-color-page);min-height:100%}.search-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);padding:20px 24px;margin-bottom:16px;box-shadow:var(--box-shadow-card)}.search-section .search-form[data-v-de354764]{display:flex;flex-wrap:wrap;gap:16px}.search-section .search-form[data-v-de354764] .x-form-item{margin-bottom:0}.search-section .search-form[data-v-de354764] .x-input,.search-section .search-form[data-v-de354764] .x-select{width:200px}.table-section[data-v-de354764]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-de354764]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-de354764]{display:flex;gap:12px}.table-toolbar .table-count[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-de354764]{overflow-x:auto}.data-table[data-v-de354764]{width:100%;border-collapse:collapse}.data-table th[data-v-de354764],.data-table td[data-v-de354764]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-de354764]{transition:background-color .2s}.data-table .data-row[data-v-de354764]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-de354764]{vertical-align:middle}.data-table .loading-cell[data-v-de354764],.data-table .empty-cell[data-v-de354764]{padding:60px 20px}.data-table .loading-content[data-v-de354764],.data-table .empty-content[data-v-de354764]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-de354764],.data-table .empty-content svg[data-v-de354764]{width:64px;height:41px}.data-table .loading-spinner[data-v-de354764]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-de354764 .8s linear infinite}@keyframes spin-de354764{to{transform:rotate(360deg)}}.col-id[data-v-de354764]{width:80px}.id-badge[data-v-de354764]{display:inline-block;min-width:32px;padding:4px 10px;background:var(--color-fill);border-radius:12px;font-size:12px;font-weight:500;color:var(--color-text-secondary);text-align:center}.col-name[data-v-de354764]{min-width:120px}.role-name[data-v-de354764]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.col-code[data-v-de354764]{min-width:100px}.col-desc[data-v-de354764]{min-width:150px}.desc-text[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.col-status[data-v-de354764]{min-width:120px}.status-switch[data-v-de354764]{display:flex;align-items:center;gap:8px}.status-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.status-text.enabled[data-v-de354764]{color:var(--color-success)}.col-time[data-v-de354764]{min-width:160px}.time-text[data-v-de354764]{font-size:13px;color:var(--color-text-secondary)}.col-actions[data-v-de354764]{min-width:140px}.action-buttons[data-v-de354764] .x-button{padding:4px 8px}.action-buttons[data-v-de354764] .x-button svg{width:14px;height:14px;margin-right:4px}.pagination-wrapper[data-v-de354764]{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--color-border-lighter)}.role-form[data-v-de354764]{padding:16px 0}.role-form .status-field[data-v-de354764]{display:flex;align-items:center;gap:12px}.role-form .status-label[data-v-de354764]{font-size:14px;color:var(--color-text-secondary)}.menu-page[data-v-e7cc9235]{padding:24px;background:var(--bg-color-page);min-height:100%}.table-section[data-v-e7cc9235]{background:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-card);overflow:hidden}.table-toolbar[data-v-e7cc9235]{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--color-border-lighter)}.table-toolbar .toolbar-left[data-v-e7cc9235]{display:flex;gap:12px}.table-toolbar .table-count[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}.table-wrapper[data-v-e7cc9235]{overflow-x:auto}.data-table[data-v-e7cc9235]{width:100%;border-collapse:collapse}.data-table th[data-v-e7cc9235],.data-table td[data-v-e7cc9235]{padding:14px 16px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-secondary);background:var(--color-fill-light);white-space:nowrap}.data-table .data-row[data-v-e7cc9235]{transition:background-color .2s}.data-table .data-row[data-v-e7cc9235]:hover{background:var(--color-primary-light-6)}.data-table td[data-v-e7cc9235]{vertical-align:middle}.data-table .loading-cell[data-v-e7cc9235],.data-table .empty-cell[data-v-e7cc9235]{padding:60px 20px}.data-table .loading-content[data-v-e7cc9235],.data-table .empty-content[data-v-e7cc9235]{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--color-text-placeholder)}.data-table .loading-content svg[data-v-e7cc9235],.data-table .empty-content svg[data-v-e7cc9235]{width:64px;height:41px}.data-table .loading-spinner[data-v-e7cc9235]{width:32px;height:32px;border:3px solid var(--color-border-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin-e7cc9235 .8s linear infinite}@keyframes spin-e7cc9235{to{transform:rotate(360deg)}}.tree-row--level-1 .col-name[data-v-e7cc9235]{padding-left:40px}.tree-indent[data-v-e7cc9235]{display:inline-block;width:24px}.tree-line[data-v-e7cc9235]{position:relative;display:inline-block;width:16px;height:1px;background:var(--color-border-light);margin-right:8px;vertical-align:middle}.col-name[data-v-e7cc9235]{min-width:200px}.menu-info[data-v-e7cc9235]{display:flex;align-items:center;gap:8px}.menu-icon-wrapper[data-v-e7cc9235]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-fill-light);border-radius:6px;font-size:14px}.menu-title[data-v-e7cc9235]{font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:color .2s}.menu-title[data-v-e7cc9235]:hover{color:var(--color-primary)}.col-icon[data-v-e7cc9235]{width:80px}.icon-text[data-v-e7cc9235]{font-size:16px}.col-path[data-v-e7cc9235]{min-width:140px}.path-code[data-v-e7cc9235]{font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:4px 8px;background:var(--color-fill-light);border-radius:4px;color:var(--color-text-secondary)}.col-type[data-v-e7cc9235]{width:80px}.col-sort[data-v-e7cc9235]{width:60px}.sort-badge[data-v-e7cc9235]{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--color-fill);border-radius:12px;font-size:12px;color:var(--color-text-secondary)}.col-status[data-v-e7cc9235]{width:80px}.col-actions[data-v-e7cc9235]{min-width:140px}.action-buttons[data-v-e7cc9235] .x-button{padding:4px 8px}.action-buttons[data-v-e7cc9235] .x-button svg{width:14px;height:14px;margin-right:4px}.menu-form[data-v-e7cc9235]{padding:16px 0}.menu-form .form-grid[data-v-e7cc9235]{display:grid;grid-template-columns:repeat(2,1fr);gap:0 24px}.menu-form .form-item-full[data-v-e7cc9235]{grid-column:span 2}.menu-form .status-field[data-v-e7cc9235]{display:flex;align-items:center;gap:12px}.menu-form .status-label[data-v-e7cc9235]{font-size:14px;color:var(--color-text-secondary)}
|
package/package.json
CHANGED
package/src/router/guards.ts
CHANGED
|
@@ -10,8 +10,8 @@ import { useAppStore } from '@/stores/app'
|
|
|
10
10
|
import { getUserInfo } from '@/api/auth'
|
|
11
11
|
import { getMenuTree } from '@/api/system'
|
|
12
12
|
|
|
13
|
-
//
|
|
14
|
-
const defaultWhiteList = ['/login', '/404', '/403']
|
|
13
|
+
// 白名单路由路径(相对路径,不带前导斜杠)
|
|
14
|
+
const defaultWhiteList = ['login', '404', '403', '/login', '/404', '/403']
|
|
15
15
|
|
|
16
16
|
interface RouterGuardOptions {
|
|
17
17
|
// 白名单路由
|
|
@@ -30,6 +30,19 @@ interface RouterGuardOptions {
|
|
|
30
30
|
onLoginSuccess?: () => void
|
|
31
31
|
}
|
|
32
32
|
|
|
33
|
+
/**
|
|
34
|
+
* 检查路径是否在白名单中
|
|
35
|
+
* @param path 当前路径
|
|
36
|
+
* @param whiteList 白名单列表
|
|
37
|
+
*/
|
|
38
|
+
function isInWhiteList(path: string, whiteList: string[]): boolean {
|
|
39
|
+
// 检查完整路径
|
|
40
|
+
if (whiteList.includes(path)) return true
|
|
41
|
+
// 检查路径名称(去掉前导斜杠)
|
|
42
|
+
const pathName = path.startsWith('/') ? path.slice(1) : path
|
|
43
|
+
return whiteList.includes(pathName)
|
|
44
|
+
}
|
|
45
|
+
|
|
33
46
|
/**
|
|
34
47
|
* 设置路由守卫
|
|
35
48
|
* @param router 路由实例
|
|
@@ -45,7 +58,6 @@ export function setupRouterGuards(router: Router, options: RouterGuardOptions =
|
|
|
45
58
|
|
|
46
59
|
// 从 store 获取路径配置(createXtoApp 已设置)
|
|
47
60
|
const loginPath = appStore.loginPath || options.loginPath || '/login'
|
|
48
|
-
const homePath = appStore.indexPath || options.homePath || '/dashboard'
|
|
49
61
|
|
|
50
62
|
// 初始化主题
|
|
51
63
|
appStore.initTheme()
|
|
@@ -55,9 +67,9 @@ export function setupRouterGuards(router: Router, options: RouterGuardOptions =
|
|
|
55
67
|
|
|
56
68
|
if (token) {
|
|
57
69
|
// 已登录
|
|
58
|
-
if (to.path === loginPath) {
|
|
59
|
-
//
|
|
60
|
-
next({
|
|
70
|
+
if (to.path === loginPath || to.name === 'Login') {
|
|
71
|
+
// 已登录访问登录页,跳转到首页(使用路由名称)
|
|
72
|
+
next({ name: 'Dashboard' })
|
|
61
73
|
} else {
|
|
62
74
|
// 检查是否已获取用户信息
|
|
63
75
|
if (userStore.isLoggedIn) {
|
|
@@ -107,18 +119,18 @@ export function setupRouterGuards(router: Router, options: RouterGuardOptions =
|
|
|
107
119
|
menuStore.clearMenu()
|
|
108
120
|
// 使用 clearToken 清除所有 token 相关数据(包括 expires_time、refresh_time 等)
|
|
109
121
|
clearToken()
|
|
110
|
-
next({
|
|
122
|
+
next({ name: 'Login', query: { redirect: to.fullPath } })
|
|
111
123
|
}
|
|
112
124
|
}
|
|
113
125
|
}
|
|
114
126
|
} else {
|
|
115
127
|
// 未登录
|
|
116
|
-
if (
|
|
128
|
+
if (isInWhiteList(to.path, whiteList) || to.name === 'Login' || to.name === 'NotFound' || to.name === 'Forbidden') {
|
|
117
129
|
// 在白名单中,直接放行
|
|
118
130
|
next()
|
|
119
131
|
} else {
|
|
120
|
-
//
|
|
121
|
-
next({
|
|
132
|
+
// 不在白名单中,跳转到登录页(使用路由名称)
|
|
133
|
+
next({ name: 'Login', query: { redirect: to.fullPath } })
|
|
122
134
|
}
|
|
123
135
|
}
|
|
124
136
|
})
|
|
@@ -52,10 +52,15 @@ const handleLogin = async () => {
|
|
|
52
52
|
Message.success('登录成功')
|
|
53
53
|
|
|
54
54
|
// 获取重定向地址
|
|
55
|
-
const redirect = route.query.redirect as string
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
55
|
+
const redirect = route.query.redirect as string
|
|
56
|
+
|
|
57
|
+
if (redirect) {
|
|
58
|
+
// 有重定向地址,直接跳转
|
|
59
|
+
router.push(redirect)
|
|
60
|
+
} else {
|
|
61
|
+
// 没有重定向地址,跳转到首页(使用路由名称避免 base 路径问题)
|
|
62
|
+
router.push({ name: 'Dashboard' })
|
|
63
|
+
}
|
|
59
64
|
} catch (error) {
|
|
60
65
|
console.error('登录失败:', error)
|
|
61
66
|
} finally {
|