#app{width:100%;height:100%}[data-v-c801f2bb] .el-dialog__body{padding:20px}.role-assignment-container[data-v-4caa9a19]{display:grid;grid-template-columns:1fr 1fr;gap:24px}.role-assignment-left h3[data-v-4caa9a19],.role-assignment-right h3[data-v-4caa9a19]{font-size:16px;font-weight:600;margin:0 0 16px}.role-count[data-v-4caa9a19]{font-size:14px;color:var(--el-text-color-secondary);font-weight:400}.role-tree-node[data-v-4caa9a19]{display:flex;align-items:center;gap:8px}.role-name[data-v-4caa9a19]{font-weight:500}.role-code[data-v-4caa9a19]{font-size:12px;color:var(--el-text-color-placeholder)}.assigned-roles-container[data-v-4caa9a19]{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;padding:12px;background:var(--el-fill-color-lighter);border-radius:8px}.assigned-role-item[data-v-4caa9a19]{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--el-bg-color);border:1px solid var(--el-border-color);border-radius:8px}.role-item-name[data-v-4caa9a19]{font-weight:500}.no-roles-text[data-v-4caa9a19]{text-align:center;color:var(--el-text-color-placeholder);padding:24px;font-style:italic}.batch-edit-info[data-v-417bc46b],.batch-role-info[data-v-181e6190]{margin-bottom:20px}.mfa-table-container[data-v-8988c5e7]{min-height:200px}.user-info-card[data-v-31f66b18]{background:#f8f9fa}.toolbar[data-v-31f66b18]{display:flex;justify-content:space-between;align-items:center}.toolbar-left[data-v-31f66b18]{display:flex;gap:12px;align-items:center}.toolbar-right[data-v-31f66b18]{display:flex;gap:12px}.log-card[data-v-31f66b18]{min-height:400px}.pagination-wrapper[data-v-31f66b18]{display:flex;justify-content:flex-end}.user-info-card[data-v-453f2996]{background:#f8f9fa}.toolbar[data-v-453f2996]{display:flex;justify-content:space-between;align-items:center}.toolbar-left[data-v-453f2996]{display:flex;gap:12px;align-items:center}.log-card[data-v-453f2996]{min-height:400px}.pagination-wrapper[data-v-453f2996]{display:flex;justify-content:flex-end}.user-management-dialog[data-v-8f784e5e]{--dialog-padding: 20px}[data-v-8f784e5e] .el-dialog__body{padding:var(--dialog-padding);max-height:calc(100vh - 200px);overflow-y:auto}.stats-cards[data-v-8f784e5e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.stat-card[data-v-8f784e5e]{border-radius:12px;transition:all .3s}.stat-card[data-v-8f784e5e]:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.stat-content[data-v-8f784e5e]{display:flex;align-items:center;justify-content:space-between;padding:8px}.stat-info[data-v-8f784e5e]{flex:1}.stat-value[data-v-8f784e5e]{font-size:28px;font-weight:700;color:var(--el-color-primary);line-height:1.2;margin-bottom:4px}.stat-label[data-v-8f784e5e]{font-size:14px;color:var(--el-text-color-secondary)}.stat-icon[data-v-8f784e5e]{color:var(--el-color-primary)}.stat-icon-success[data-v-8f784e5e]{color:var(--el-color-success)}.stat-icon-danger[data-v-8f784e5e]{color:var(--el-color-danger)}.toolbar-card[data-v-8f784e5e]{margin-bottom:16px;border-radius:8px}.toolbar[data-v-8f784e5e]{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.toolbar-left[data-v-8f784e5e],.toolbar-right[data-v-8f784e5e]{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.table-card[data-v-8f784e5e]{border-radius:8px}.import-status[data-v-8f784e5e]{margin:12px 0}.import-progress-row[data-v-8f784e5e]{display:flex;align-items:center;gap:12px}.error-row[data-v-8f784e5e]{display:flex;gap:8px;align-items:center}.error-index[data-v-8f784e5e]{color:var(--el-color-danger);font-weight:600}.pagination-wrapper[data-v-8f784e5e]{display:flex;justify-content:flex-end;margin-top:16px}.empty-text[data-v-8f784e5e]{color:var(--el-text-color-placeholder);font-size:12px}.app-layout[data-v-6ab25d9d]{display:flex;flex-direction:column;min-height:100vh;background-color:var(--color-bg-base)}.app-main-content[data-v-6ab25d9d]{flex-grow:1;padding-top:var(--space-8);padding-bottom:var(--space-8)}.container[data-v-6ab25d9d]{max-width:var(--max-width-container, 1400px);margin:0 auto;padding:0 var(--space-6)}.container.is-fluid[data-v-6ab25d9d]{max-width:100%}/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-slate-50:oklch(98.4% .003 247.858);--color-slate-100:oklch(96.8% .007 247.896);--color-neutral-50:oklch(98.5% 0 0);--color-neutral-100:oklch(97% 0 0);--color-neutral-200:oklch(92.2% 0 0);--color-neutral-300:oklch(87% 0 0);--color-neutral-400:oklch(70.8% 0 0);--color-neutral-900:oklch(20.5% 0 0);--spacing:.25rem;--text-xs:.75rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--font-weight-black:900;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-2xl:0 25px 50px -12px #00000040;--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:rgba(0,0,0,0);border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:rgba(0,0,0,0);border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mt-6{margin-top:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.mr-1{margin-right:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.table{display:table}.table-column{display:table-column}.size-9{width:calc(var(--spacing)*9);height:calc(var(--spacing)*9)}.size-11{width:calc(var(--spacing)*11);height:calc(var(--spacing)*11)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-11{height:calc(var(--spacing)*11)}.h-full{height:100%}.w-10{width:calc(var(--spacing)*10)}.w-full{width:100%}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-x-8{column-gap:calc(var(--spacing)*8)}.gap-y-1\.5{row-gap:calc(var(--spacing)*1.5)}.gap-y-6{row-gap:calc(var(--spacing)*6)}.overflow-hidden{overflow:hidden}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-slate-100{border-color:var(--color-slate-100)}.bg-slate-50{background-color:var(--color-slate-50)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-2{padding-block:calc(var(--spacing)*2)}.pt-0{padding-top:calc(var(--spacing)*0)}.pt-4{padding-top:calc(var(--spacing)*4)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.whitespace-nowrap{white-space:nowrap}.uppercase{text-transform:uppercase}.underline-offset-4{text-underline-offset:4px}.shadow,.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media(hover:hover){.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}}:root{--color-brand-50:#eff6ff;--color-brand-100:#dbeafe;--color-brand-200:#bfdbfe;--color-brand-300:#93c5fd;--color-brand-400:#60a5fa;--color-brand-500:#3b82f6;--color-brand-600:#2563eb;--color-brand-700:#1d4ed8;--color-brand-800:#1e40af;--color-brand-900:#1e3a8a;--color-accent-50:#f0f9ff;--color-accent-100:#e0f2fe;--color-accent-200:#bae6fd;--color-accent-300:#7dd3fc;--color-accent-400:#38bdf8;--color-accent-500:#0ea5e9;--color-accent-600:#0284c7;--color-accent-700:#0369a1;--color-accent-800:#075985;--color-accent-900:#0c4a6e;--color-neutral-50:#f8fafc;--color-neutral-100:#f1f5f9;--color-neutral-200:#e2e8f0;--color-neutral-300:#cbd5e1;--color-neutral-400:#94a3b8;--color-neutral-500:#64748b;--color-neutral-600:#475569;--color-neutral-700:#334155;--color-neutral-800:#1e293b;--color-neutral-900:#0f172a;--color-success-50:#ecfdf5;--color-success-100:#d1fae5;--color-success-500:#10b981;--color-success-600:#059669;--color-success-color:#10b981;--color-success-light:#d1fae5;--color-warning-50:#fffbeb;--color-warning-100:#fef3c7;--color-warning-500:#f59e0b;--color-warning-600:#d97706;--color-warning-color:#f59e0b;--color-warning-light:#fef3c7;--color-danger-50:#fef2f2;--color-danger-100:#fee2e2;--color-danger-500:#ef4444;--color-danger-600:#dc2626;--color-danger-color:#ef4444;--color-danger-light:#fee2e2;--color-info-50:#f0f9ff;--color-info-100:#e0f2fe;--color-info-500:#0ea5e9;--color-info-color:#0ea5e9;--color-info-light:#e0f2fe;--color-bg-base:#f8fafc;--color-bg-surface:#fffc;--color-bg-elevated:#fff;--color-bg-muted:#f1f5f9;--color-bg-card:#fffc;--color-bg-light:#f8fafc;--color-bg-glass:#ffffff80;--color-bg-overlay:#0f172a66;--color-bg-hover:#2563eb0a;--color-text-primary:#0f172a;--color-text-secondary:#334155;--color-text-muted:#64748b;--color-text-inverse:#fff;--color-text-brand:#2563eb;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-border-focus:var(--color-brand-500);--color-border-brand:var(--color-brand-500);--glass-blur:8px;--glass-border:1px solid #e2e8f0cc;--glass-shadow:0 4px 6px -1px #0f172a0d,0 2px 4px -1px #0f172a08;--glass-highlight:inset 0 1px 0 0 #fff9;--primary-color:var(--color-brand-600);--primary-hover:var(--color-brand-700);--primary-light:var(--color-brand-100);--success-color:var(--color-accent-500);--success-light:var(--color-accent-100);--warning-color:var(--color-warning-500);--warning-light:var(--color-warning-100);--danger-color:var(--color-danger-500);--danger-light:var(--color-danger-100);--info-color:var(--color-brand-500);--info-light:var(--color-brand-100);--bg-base:var(--color-bg-base);--bg-surface:var(--color-bg-surface);--text-primary:var(--color-text-primary);--text-secondary:var(--color-text-secondary);--text-muted:var(--color-text-muted);--border-color:var(--color-border);--font-family-sans:"PingFang SC","Microsoft YaHei","Heiti SC","Helvetica Neue",Helvetica,Arial,sans-serif;--font-family-serif:"Songti SC","SimSun","STSong","Times New Roman",serif;--font-family-mono:"Courier New",Courier,monospace;--font-family-base:var(--font-family-sans);--font-family-heading:var(--font-family-sans);--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.2;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--tracking-tight:-.025em;--tracking-normal:0;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--space-0:0;--space-1:.125rem;--space-2:.25rem;--space-3:.5rem;--space-4:.75rem;--space-5:1rem;--space-6:1.25rem;--space-8:1.5rem;--space-10:2rem;--space-12:2.5rem;--space-16:3rem;--space-20:4rem;--space-24:5rem;--space-32:6rem;--shadow-none:0 0 #0000;--shadow-xs:0 1px 2px 0 #0f172a0a;--shadow-sm:0 1px 3px 0 #0f172a0f,0 1px 2px -1px #0f172a0f;--shadow-md:0 4px 6px -1px #0f172a14,0 2px 4px -2px #0f172a0d;--shadow-lg:0 10px 15px -3px #0f172a1a,0 4px 6px -4px #0f172a0d;--shadow-xl:0 20px 25px -5px #0f172a1f,0 8px 10px -6px #0f172a0a;--shadow-2xl:0 25px 50px -12px #0f172a40;--shadow-glow:0 0 20px #3b82f626;--radius-none:0;--radius-xs:.25rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-3xl:1.5rem;--radius-4xl:2rem;--radius-full:9999px;--ease-out:cubic-bezier(.33,1,.68,1);--ease-in-out:cubic-bezier(.65,0,.35,1);--transition-fast:.12s var(--ease-out);--transition-base:.2s var(--ease-out);--transition-slow:.32s var(--ease-in-out);--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px;--breakpoint-3xl:1920px;--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;--max-width-container:1400px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body,#app{width:100%;min-height:100vh;font-family:var(--font-family-base);font-feature-settings:"cv02","cv03","cv04","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-base);color:var(--color-text-primary);line-height:var(--leading-relaxed)}a{color:var(--color-text-brand);transition:color var(--transition-base);text-decoration:none}a:hover{color:var(--color-brand-700);text-decoration:underline}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--leading-tight);color:var(--color-text-primary);margin:0}p{margin:0 0 var(--space-4)}.app-footer{text-align:center;padding:var(--space-6)var(--space-6);font-size:var(--text-sm);color:var(--color-text-muted)}.app-footer p{line-height:var(--leading-relaxed);margin:0}.app-footer a{color:var(--color-text-brand);font-weight:var(--font-weight-medium)}.app-footer a:hover{color:var(--color-text-primary);text-decoration:underline}img,svg,video{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:var(--radius-full);background-clip:content-box;border:2px solid #0000}::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-400);background-clip:content-box}@supports (scrollbar-width:thin){*{scrollbar-width:thin;scrollbar-color:var(--color-neutral-300)transparent}}.text-eyebrow{font-size:var(--text-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin:0}.text-heading-1{margin:0 0 var(--space-6);font-size:var(--text-4xl);font-weight:var(--font-weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-primary)}.text-heading-2{margin:0 0 var(--space-5);font-size:var(--text-3xl);font-weight:var(--font-weight-bold);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);color:var(--color-text-primary)}.text-heading-3{margin:0 0 var(--space-4);font-size:var(--text-2xl);font-weight:var(--font-weight-semibold);line-height:var(--leading-snug);color:var(--color-text-primary)}.text-body{margin:0 0 var(--space-4);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text-primary)}.text-caption{margin:0 0 var(--space-2);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--color-text-secondary)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.p-2{padding:var(--space-2)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.card{background:var(--color-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur));border:var(--glass-border);box-shadow:var(--glass-shadow),var(--glass-highlight);border-radius:var(--radius-xl);transition:all var(--transition-base);position:relative;overflow:hidden}.card:hover{box-shadow:0 10px 25px -5px rgba(0,51,102,.15),var(--glass-highlight);background:rgba(255,255,255,.75);border-color:rgba(255,255,255,.8);transform:translateY(-2px)}.card__header{padding:var(--space-4)var(--space-5);border-bottom:1px solid var(--color-border-light);font-weight:var(--font-weight-semibold);color:var(--color-brand-800);background:rgba(255,255,255,.3)}.card__body{padding:var(--space-5)}.card__footer{padding:var(--space-4)var(--space-5);border-top:1px solid var(--color-border-light);background:rgba(240,244,248,.4)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-5);font-size:var(--text-sm);font-weight:var(--font-weight-semibold);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-user-select:none;user-select:none;border:1px solid #0000;line-height:1.5;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(rgba(255,255,255,.2),rgba(0,0,0,0));height:40%;position:absolute;top:0;left:0;right:0}.btn:focus-visible{outline:2px solid var(--color-brand-400);outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed;background:var(--color-neutral-200);color:var(--color-text-muted)}.btn--primary{background:linear-gradient(135deg,var(--color-brand-500),var(--color-brand-700));color:#fff;border:1px solid #ffffff1a;box-shadow:0 4px 6px rgba(0,51,102,.2),inset 0 1px rgba(255,255,255,.2)}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-brand-400),var(--color-brand-600));transform:translateY(-1px);box-shadow:0 6px 12px rgba(0,51,102,.25),inset 0 1px rgba(255,255,255,.3)}.btn--secondary{color:var(--color-brand-700);background:rgba(255,255,255,.6);border:1px solid #0033661a}.btn--secondary:hover:not(:disabled){border-color:var(--color-brand-300);color:var(--color-brand-600);background:rgba(255,255,255,.9);box-shadow:0 2px 4px rgba(0,0,0,.05)}.btn--ghost{color:var(--color-text-secondary);background:0 0;border-color:rgba(0,0,0,0)}.btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn--danger{background:var(--color-danger-500);color:var(--color-text-inverse);border-color:var(--color-danger-500)}.btn--danger:hover:not(:disabled){background:var(--color-danger-600);border-color:var(--color-danger-600)}.btn--sm{padding:var(--space-1)var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-md)}.btn--lg{padding:var(--space-3)var(--space-6);font-size:var(--text-base)}.chip{align-items:center;gap:var(--space-1);padding:var(--space-1)var(--space-3);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);white-space:nowrap;display:inline-flex}.chip--brand{color:var(--color-brand-600);background:rgba(59,130,246,.12)}.chip--success{color:var(--color-accent-600);background:rgba(16,185,129,.12)}.chip--warning{color:var(--color-warning-600);background:rgba(245,158,11,.12)}.chip--neutral{background:var(--color-bg-light);color:var(--color-text-secondary)}@media(max-width:768px){.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}.container{width:100%;max-width:var(--max-width-container);padding-left:var(--space-4);padding-right:var(--space-4);margin-left:auto;margin-right:auto}@media(min-width:640px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}@media(min-width:1024px){.container{padding-left:var(--space-8);padding-right:var(--space-8)}}.el-button{font-weight:var(--font-weight-semibold);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.el-button--primary{--el-button-bg-color:var(--color-brand-500);--el-button-border-color:var(--color-brand-500);--el-button-hover-bg-color:var(--color-brand-600);--el-button-hover-border-color:var(--color-brand-600)}.el-card{border-radius:var(--radius-2xl);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.el-card__header{padding:var(--space-4)var(--space-5);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-light)}.el-card__body{padding:var(--space-5)}.el-dialog{border-radius:var(--radius-3xl);box-shadow:var(--shadow-2xl);overflow:hidden}.el-dialog__header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-surface);margin-right:0}.el-dialog__title{font-weight:var(--font-weight-bold);font-size:var(--text-lg);color:var(--color-text-primary)}.el-dialog__body{padding:var(--space-6)!important}.el-dialog__footer{padding:var(--space-4)var(--space-6);border-top:1px solid var(--color-border-light);background:var(--color-bg-light)}.el-input__wrapper{border-radius:var(--radius-lg);transition:all var(--transition-fast)}.el-input__wrapper:hover{box-shadow:0 0 0 1px var(--color-neutral-300) inset}.el-input__wrapper.is-focus{box-shadow:0 0 0 2px var(--color-brand-200) inset}.el-select .el-input__wrapper{border-radius:var(--radius-lg)}.el-table{--el-table-border-color:#0033661a;--el-table-header-bg-color:#f1f5f999;--el-table-row-hover-bg-color:#e3f2fd80;--el-table-bg-color:#fff6;--el-table-tr-bg-color:transparent;--el-table-text-color:var(--color-text-primary);--el-table-header-text-color:var(--color-text-secondary);border-radius:var(--radius-lg);font-size:var(--text-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #ffffff80;overflow:hidden}.el-table th.el-table__cell{font-weight:var(--font-weight-semibold);color:var(--color-brand-800);background-color:var(--el-table-header-bg-color);text-transform:none;font-size:var(--text-sm);padding:var(--space-3)0;border-bottom:1px solid #0033661a}.el-table td.el-table__cell{padding:var(--space-3)0;border-bottom:1px solid #0033660d}.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell{background-color:var(--el-table-row-hover-bg-color)}.el-checkbox{--el-checkbox-border-radius:var(--radius-sm)}.el-tag{border-radius:var(--radius-full);font-weight:var(--font-weight-semibold)}.el-alert{border-radius:var(--radius-xl)}.el-message-box{border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl)}.el-overlay-message-box{justify-content:center;align-items:center;z-index:9999!important;display:flex!important}.el-overlay-message-box .el-message-box{max-width:min(520px,90vw);margin:0!important}@media(max-height:520px){.el-overlay-message-box{align-items:flex-start}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-base)ease-out}.animate-slide-up{animation:slideUp var(--transition-slow)ease-out}.animate-slide-down{animation:slideDown var(--transition-slow)ease-out}.animate-scale-in{animation:scaleIn var(--transition-base)ease-out}.animate-pulse{animation:2s ease-in-out infinite pulse}.skeleton{background:linear-gradient(90deg,var(--color-neutral-200)25%,var(--color-neutral-100)50%,var(--color-neutral-200)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton--text{height:1em;margin-bottom:var(--space-2)}.skeleton--heading{width:60%;height:1.5em}.skeleton--box{border-radius:var(--radius-xl);height:80px}:focus-visible{outline:2px solid var(--color-brand-400);outline-offset:2px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media print{body{background:#fff}.no-print{display:none!important}.card{box-shadow:none;border:1px solid #ddd}}.el-table__empty-block{width:100%!important;max-width:100%!important}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}:root{--glass-bg: rgba(255, 255, 255, .72);--glass-bg-light: rgba(255, 255, 255, .85);--glass-bg-dark: rgba(255, 255, 255, .6);--glass-border: rgba(255, 255, 255, .4);--glass-shadow: 0 8px 32px rgba(15, 23, 42, .08);--gradient-brand: linear-gradient(135deg, var(--color-brand-500) 0%, var(--color-brand-600) 100%);--gradient-brand-light: linear-gradient(135deg, var(--color-brand-50) 0%, var(--color-brand-100) 100%);--gradient-accent: linear-gradient(135deg, var(--color-accent-500) 0%, var(--color-accent-600) 100%);--gradient-accent-light: linear-gradient(135deg, var(--color-accent-50) 0%, var(--color-accent-100) 100%);--gradient-warm: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);--gradient-cool: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-surface: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);--gradient-page: linear-gradient(180deg, #e8f0fe 0%, #f1f5f9 40%, #ffffff 100%);--shadow-brand: 0 4px 14px rgba(59, 130, 246, .25);--shadow-brand-lg: 0 8px 24px rgba(59, 130, 246, .3);--shadow-accent: 0 4px 14px rgba(16, 185, 129, .25);--shadow-card-hover: 0 20px 40px rgba(15, 23, 42, .12);--shadow-float: 0 12px 28px rgba(15, 23, 42, .15);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55)}.card-glass{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);transition:all .3s var(--ease-smooth)}.card-glass:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card-elevated{background:var(--color-bg-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.8);transition:all .3s var(--ease-smooth)}.card-elevated:hover{box-shadow:var(--shadow-float);transform:translateY(-4px)}.card-gradient{background:var(--gradient-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-md)}.btn-gradient{background:var(--gradient-brand);color:#fff;border:none;border-radius:var(--radius-xl);padding:var(--space-3) var(--space-6);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-brand);transition:all .3s var(--ease-smooth);position:relative;overflow:hidden}.btn-gradient:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-gradient:hover{box-shadow:var(--shadow-brand-lg);transform:translateY(-2px)}.btn-gradient:hover:before{left:100%}.btn-gradient:active{transform:translateY(0);box-shadow:var(--shadow-brand)}.btn-glass{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-6);font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:all .3s var(--ease-smooth)}.btn-glass:hover{background:var(--glass-bg-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.input-modern{border:2px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);background:var(--color-bg-surface);transition:all .3s var(--ease-smooth);font-size:var(--text-base)}.input-modern:hover{border-color:var(--color-brand-300);background:var(--color-bg-light)}.input-modern:focus{border-color:var(--color-brand-500);box-shadow:0 0 0 4px rgba(59,130,246,.1);outline:none}.input-glass{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);transition:all .3s var(--ease-smooth)}.input-glass:focus{background:var(--glass-bg-light);border-color:var(--color-brand-400);box-shadow:0 0 0 4px rgba(59,130,246,.15)}.badge-gradient{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);background:var(--gradient-brand-light);color:var(--color-brand-700);border:1px solid rgba(59,130,246,.2)}.badge-success{background:var(--gradient-accent-light);color:var(--color-accent-700);border-color:rgba(16,185,129,.2)}.badge-glow{position:relative;animation:badgeGlow 2s ease-in-out infinite}@keyframes badgeGlow{0%,to{box-shadow:0 0 5px rgba(59,130,246,.3)}50%{box-shadow:0 0 15px rgba(59,130,246,.5)}}.list-modern{list-style:none;padding:0;margin:0}.list-modern li{padding:var(--space-4);border-radius:var(--radius-xl);margin-bottom:var(--space-2);background:var(--color-bg-light);border:1px solid transparent;transition:all .3s var(--ease-smooth);cursor:pointer}.list-modern li:hover{background:var(--color-brand-50);border-color:var(--color-brand-200);transform:translate(4px);box-shadow:var(--shadow-sm)}.list-modern li.active{background:var(--gradient-brand-light);border-color:var(--color-brand-300);box-shadow:var(--shadow-brand)}.table-modern{width:100%;border-collapse:separate;border-spacing:0;background:var(--color-bg-surface);border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-md)}.table-modern thead{background:var(--gradient-brand-light)}.table-modern th{padding:var(--space-4) var(--space-5);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-brand-800);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-brand-200)}.table-modern td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);transition:background .2s ease}.table-modern tbody tr:hover td{background:var(--color-brand-50)}.table-modern tbody tr:last-child td{border-bottom:none}.progress-modern{height:8px;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-modern-fill{height:100%;background:var(--gradient-brand);border-radius:var(--radius-full);transition:width .5s var(--ease-smooth);position:relative}.progress-modern-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressShine 2s infinite}@keyframes progressShine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.tooltip-modern{position:relative}.tooltip-modern:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);padding:var(--space-2) var(--space-3);background:var(--color-neutral-900);color:#fff;font-size:var(--text-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s var(--ease-smooth);z-index:1000;box-shadow:var(--shadow-lg)}.tooltip-modern:before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--color-neutral-900);opacity:0;visibility:hidden;transition:all .2s var(--ease-smooth)}.tooltip-modern:hover:after,.tooltip-modern:hover:before{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.loading-shimmer{background:linear-gradient(90deg,var(--color-neutral-200) 25%,var(--color-neutral-100) 50%,var(--color-neutral-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}.loading-pulse{animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.5}}.loading-dots{display:inline-flex;gap:4px}.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--color-brand-500);animation:loadingDots 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes loadingDots{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.notification-modern{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--glass-bg-light);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);animation:slideInRight .3s var(--ease-spring)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.modal-glass{background:var(--glass-bg-light);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-3xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-2xl);animation:modalFadeIn .3s var(--ease-smooth)}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-overlay{background:rgba(15,23,42,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.sidebar-modern{background:var(--gradient-surface);border-right:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:all .2s var(--ease-smooth);cursor:pointer;margin:var(--space-1) var(--space-2)}.sidebar-item:hover{background:var(--color-brand-50);color:var(--color-brand-600);transform:translate(2px)}.sidebar-item.active{background:var(--gradient-brand);color:#fff;box-shadow:var(--shadow-brand)}.sidebar-item.active:hover{transform:translate(0)}.header-glass{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);box-shadow:0 1px 3px rgba(0,0,0,.05)}.header-gradient{background:var(--gradient-brand);color:#fff;box-shadow:var(--shadow-brand)}.form-group-modern{display:flex;flex-direction:column;gap:var(--space-2)}.form-label-modern{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-2)}.form-label-modern .required{color:var(--color-danger-500)}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.stat-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);background:var(--color-bg-surface);border-radius:var(--radius-2xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all .3s var(--ease-smooth)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);background:var(--gradient-brand-light);color:var(--color-brand-600)}.stat-card-value{font-size:var(--text-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-card-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-card-trend{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-weight-semibold);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.stat-card-trend.up{background:var(--color-accent-100);color:var(--color-accent-700)}.stat-card-trend.down{background:var(--color-danger-100);color:var(--color-danger-700)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-neutral-100);color:var(--color-neutral-400);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--color-text-secondary);max-width:320px;margin-bottom:var(--space-6)}.divider{height:1px;background:var(--color-border-light);margin:var(--space-4) 0}.divider-gradient{height:2px;background:linear-gradient(90deg,transparent,var(--color-brand-300),transparent);margin:var(--space-6) 0}.divider-text{display:flex;align-items:center;gap:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm)}.divider-text:before,.divider-text:after{content:"";flex:1;height:1px;background:var(--color-border-light)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--gradient-brand);color:#fff;font-weight:var(--font-weight-semibold);overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:var(--text-sm)}.avatar-md{width:40px;height:40px;font-size:var(--text-base)}.avatar-lg{width:56px;height:56px;font-size:var(--text-xl)}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--color-bg-surface);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.animate-float{animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.animate-bounce-in{animation:bounceIn .5s var(--ease-spring)}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-slide-up-fade{animation:slideUpFade .4s var(--ease-smooth)}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.focus-ring:focus{outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.3)}.focus-ring:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.5)}.scrollbar-thin::-webkit-scrollbar{width:6px;height:6px}.scrollbar-thin::-webkit-scrollbar-track{background:transparent}.scrollbar-thin::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:var(--radius-full)}.scrollbar-thin::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-400)}.scrollbar-hidden::-webkit-scrollbar{display:none}.scrollbar-hidden{-ms-overflow-style:none;scrollbar-width:none}:root,body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Helvetica Neue,Arial,sans-serif}
