*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.right-1{right:.25rem}.top-1\/2{top:50%}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-28{height:7rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-8{height:2rem}.min-h-20{min-height:5rem}.min-h-24{min-height:6rem}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.cursor-zoom-in{cursor:zoom-in}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-5{gap:1.25rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-\[var\(--border\)\]{border-color:var(--border)}.border-\[var\(--border-color\)\]{border-color:var(--border-color)}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.stroke-current{stroke:currentColor}.object-cover{-o-object-fit:cover;object-fit:cover}.p-3{padding:.75rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.pb-2{padding-bottom:.5rem}.pr-10{padding-right:2.5rem}.text-center{text-align:center}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.outline{outline-style:solid}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{font-family:Avenir Next,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Segoe UI,sans-serif}@media(min-width:768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:col-span-4{grid-column:span 4 / span 4}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}@media(min-width:1024px){.lg\:block{display:block}.lg\:hidden{display:none}}:root,[data-theme=ocean]{--app-bg: #e7edf1;--app-bg-spot-1: rgba(47, 125, 140, .2);--app-bg-spot-2: rgba(121, 155, 188, .18);--surface: #fdfefe;--surface-soft: #f5f8fb;--surface-subtle: #eef3f7;--border: #d2dee8;--text-primary: #102335;--text-secondary: #5a6b7e;--text-muted: #7d8d9d;--accent: #2f7d8c;--accent-strong: #245f6b;--accent-soft: #d9ebef;--accent-contrast: #ffffff;--success: #2f8c63;--danger: #be4b4b;--sidebar-bg: #95bdd0;--sidebar-bg-2: #89b3c8;--sidebar-text: #eaf2fb;--sidebar-muted: #b8ccdd;--sidebar-hover: rgba(255, 255, 255, .14);--sidebar-active: rgba(95, 204, 230, .23);--shadow-lg: 0 24px 50px rgba(16, 35, 53, .14);--shadow-md: 0 10px 28px rgba(16, 35, 53, .1)}[data-theme=sand]{--app-bg: #f3efe8;--app-bg-spot-1: rgba(183, 106, 45, .18);--app-bg-spot-2: rgba(199, 149, 105, .18);--surface: #fffdf9;--surface-soft: #f8f3ec;--surface-subtle: #efe7db;--border: #e1d5c4;--text-primary: #2f241b;--text-secondary: #6a5747;--text-muted: #907d6e;--accent: #b76a2d;--accent-strong: #945122;--accent-soft: #f3e1d3;--accent-contrast: #ffffff;--success: #4b8759;--danger: #b65050;--sidebar-bg: #d5c1ad;--sidebar-bg-2: #c9b49f;--sidebar-text: #f4ebdf;--sidebar-muted: #dbcab8;--sidebar-hover: rgba(255, 255, 255, .12);--sidebar-active: rgba(255, 192, 120, .2);--shadow-lg: 0 24px 50px rgba(55, 37, 23, .16);--shadow-md: 0 10px 28px rgba(55, 37, 23, .11)}[data-theme=forest]{--app-bg: #e6ede9;--app-bg-spot-1: rgba(45, 122, 87, .2);--app-bg-spot-2: rgba(94, 140, 116, .2);--surface: #fbfdfc;--surface-soft: #f2f7f4;--surface-subtle: #e7efe9;--border: #cfddd4;--text-primary: #123027;--text-secondary: #4f6f61;--text-muted: #6e8a7d;--accent: #2d7a57;--accent-strong: #215d42;--accent-soft: #d7ebdf;--accent-contrast: #ffffff;--success: #2f8c63;--danger: #b94b56;--sidebar-bg: #93c7b5;--sidebar-bg-2: #85bcab;--sidebar-text: #e9f4ef;--sidebar-muted: #bdd6c9;--sidebar-hover: rgba(255, 255, 255, .13);--sidebar-active: rgba(118, 221, 174, .18);--shadow-lg: 0 24px 50px rgba(18, 48, 39, .15);--shadow-md: 0 10px 28px rgba(18, 48, 39, .1)}[data-theme=light]{--app-bg: #eef2f6;--app-bg-spot-1: rgba(148, 163, 184, .2);--app-bg-spot-2: rgba(125, 141, 166, .16);--surface: #ffffff;--surface-soft: #f7f9fc;--surface-subtle: #eff3f8;--border: #d8e1ec;--text-primary: #1e293b;--text-secondary: #516175;--text-muted: #738296;--accent: #64748b;--accent-strong: #475569;--accent-soft: #e3ebf6;--accent-contrast: #ffffff;--success: #2f8c63;--danger: #c05353;--sidebar-bg: #e7edf5;--sidebar-bg-2: #dde6f1;--sidebar-text: #334a62;--sidebar-muted: #6f8399;--sidebar-hover: rgba(255, 255, 255, .5);--sidebar-active: rgba(100, 116, 139, .2);--shadow-lg: 0 24px 50px rgba(30, 41, 59, .1);--shadow-md: 0 10px 28px rgba(30, 41, 59, .08)}[data-theme=dark]{--app-bg: #0f172a;--app-bg-spot-1: rgba(30, 41, 59, .55);--app-bg-spot-2: rgba(51, 65, 85, .45);--surface: #111b2f;--surface-soft: #162338;--surface-subtle: #1c2b43;--border: #2a3a55;--text-primary: #e5edf9;--text-secondary: #b5c1d5;--text-muted: #93a4bf;--accent: #60a5fa;--accent-strong: #3b82f6;--accent-soft: #1f3356;--accent-contrast: #ffffff;--success: #4ade80;--danger: #f87171;--sidebar-bg: #121b2c;--sidebar-bg-2: #0c1422;--sidebar-text: #e5edf9;--sidebar-muted: #97a8c1;--sidebar-hover: rgba(255, 255, 255, .09);--sidebar-active: rgba(96, 165, 250, .25);--shadow-lg: 0 24px 50px rgba(2, 6, 23, .45);--shadow-md: 0 10px 28px rgba(2, 6, 23, .35)}html,body,#app{min-height:100%}body{margin:0;color:var(--text-primary);background:var(--app-bg)}.app-shell{min-height:100vh;background:radial-gradient(circle at 14% 14%,var(--app-bg-spot-1),transparent 42%),radial-gradient(circle at 88% 12%,var(--app-bg-spot-2),transparent 37%),var(--app-bg)}.sidebar-shell{width:260px;color:var(--sidebar-text);background:var(--sidebar-bg);border-right:1px solid color-mix(in srgb,var(--border) 62%,white 38%);box-shadow:var(--shadow-md)}.sidebar-shell.desktop{transition:width .24s ease,opacity .24s ease,border-color .24s ease,box-shadow .24s ease}.sidebar-shell.desktop.collapsed{width:0;opacity:0;overflow:hidden;border-right-color:transparent;box-shadow:none}.sidebar-shell.mobile{position:fixed;top:0;left:0;bottom:0;z-index:40;transform:translate(-100%);transition:transform .25s ease}.sidebar-shell.mobile.open{transform:translate(0)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0f172361}.brand-card{margin:16px;border-radius:14px;padding:10px 12px;background:linear-gradient(145deg,#ffffff2e,#ffffff14);border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 1px #ffffff2e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.brand-head{display:flex;align-items:center;gap:10px}.brand-logo-wrap{width:52px;height:52px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;background:#ffffffeb;border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 16px #10233529;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,filter .22s ease}.brand-logo{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scale(1.18);transition:transform .22s ease}.brand-logo-wrap:hover{transform:translateY(-1px) scale(1.06);border-color:#ffffffc7;box-shadow:0 12px 22px #10233538;filter:saturate(1.08)}.brand-logo-wrap:hover .brand-logo{transform:scale(1.24)}.brand-copy{min-width:0}.brand-title{margin:0;font-size:17px;font-weight:700;letter-spacing:.02em;line-height:1.15;color:color-mix(in srgb,var(--sidebar-text) 94%,white 6%)}.brand-sub{margin-top:0;font-size:15px;line-height:1.25;font-weight:600;letter-spacing:.01em;color:color-mix(in srgb,var(--text-primary) 82%,var(--sidebar-text) 18%)}.sidebar-system-name{position:relative;display:inline-block;overflow:hidden;isolation:isolate;transition:transform .2s ease,color .2s ease,text-shadow .2s ease}.sidebar-system-name:after{content:"";position:absolute;top:-45%;left:-70%;width:56%;height:190%;opacity:0;pointer-events:none;transform:skew(-24deg);background:linear-gradient(110deg,#fff0,#ffffffe6 48%,#fff0)}.sidebar-system-name:hover{color:color-mix(in srgb,var(--text-primary) 74%,var(--accent) 26%);transform:translateY(-1px);text-shadow:0 2px 10px color-mix(in srgb,var(--accent) 24%,transparent 76%)}.sidebar-system-name:hover:after{opacity:1;animation:sidebar-system-name-sweep .82s ease}@keyframes sidebar-system-name-sweep{0%{left:-70%}to{left:125%}}.menu-group{margin:0;padding:6px 12px 14px;list-style:none}.menu-sub{margin-left:10px;padding-left:10px;border-left:1px solid color-mix(in srgb,var(--sidebar-text) 18%,transparent 82%)}.menu-link{display:flex;align-items:center;gap:8px;border-radius:10px;padding:9px 11px;color:var(--sidebar-text);text-decoration:none;font-size:14px;font-weight:500;transition:background .18s ease,color .18s ease}.menu-link:hover{background:var(--sidebar-hover)}.menu-link.active{background:var(--sidebar-active);color:var(--sidebar-text)}.menu-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;border-radius:10px;padding:9px 11px;color:var(--sidebar-text);background:transparent;font-size:14px;font-weight:600;text-align:left;cursor:pointer;transition:background .18s ease,color .18s ease}.menu-toggle-main{display:inline-flex;align-items:center;gap:8px}.menu-toggle:hover{background:var(--sidebar-hover)}.menu-toggle.active{background:color-mix(in srgb,var(--sidebar-active) 70%,transparent 30%);color:var(--sidebar-text)}.menu-chevron{font-size:13px;line-height:1;opacity:.8;transform:rotate(-90deg);transition:transform .2s ease}.menu-chevron.open{transform:rotate(0)}.menu-label{padding:8px 11px;font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--sidebar-muted);text-transform:uppercase}.menu-dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.6}.submenu-enter-active,.submenu-leave-active{transition:opacity .18s ease,transform .18s ease}.submenu-enter-from,.submenu-leave-to{opacity:0;transform:translateY(-4px)}.main-shell{min-height:100vh;flex:1;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:14px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 90%,white 10%);box-shadow:var(--shadow-md)}.topbar-left{display:flex;align-items:center;gap:10px;flex-shrink:0}.topbar-title{font-size:18px;font-weight:700;color:var(--text-primary)}.topbar-sub{margin-top:2px;font-size:12px;color:var(--text-muted)}.topbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.content-wrap{padding:0 14px 14px}.topbar-tabs-wrap{flex:1;min-width:0;padding:0 4px;display:flex;align-items:center;gap:8px}.tabs-shell{flex:1;min-width:0;display:flex;align-items:center;gap:8px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;will-change:scroll-position}.tabs-shell::-webkit-scrollbar{height:7px}.tabs-shell::-webkit-scrollbar-thumb{border-radius:999px;background:color-mix(in srgb,var(--text-muted) 38%,transparent 62%)}.tabs-nav-btn{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:.18s ease}.tabs-nav-btn:hover{background:var(--surface-subtle)}.tabs-nav-btn:disabled{opacity:.45;cursor:not-allowed}.tab-chip{display:inline-flex;align-items:center;gap:8px;border-radius:10px;border:1px solid var(--border);background:var(--surface-soft);color:var(--text-secondary);padding:7px 10px;font-size:13px;font-weight:600;white-space:nowrap;flex-shrink:0;cursor:pointer;transition:.18s ease}.tab-chip:hover{background:var(--surface-subtle)}.tab-chip.active{border-color:color-mix(in srgb,var(--accent) 55%,var(--border) 45%);background:color-mix(in srgb,var(--accent-soft) 82%,white 18%);color:var(--text-primary)}.tab-close{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;font-size:13px;line-height:1;color:var(--text-muted)}.tab-close:hover{background:#00000014;color:var(--text-primary)}.page-title{font-size:22px;font-weight:700;color:var(--text-primary)}.page-header{margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.kpi-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media(min-width:768px){.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.surface-card{border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface);box-shadow:var(--shadow-md)}.surface-card-soft{border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface-soft)}.kpi-label{font-size:13px;color:var(--text-secondary)}.kpi-value{margin-top:8px;font-size:24px;font-weight:700;color:var(--text-primary)}.button-primary,.button-ghost,.button-soft,.icon-btn,.button-ghost-sm{display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid transparent;font-weight:600;transition:.18s ease}.button-primary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent);padding:8px 14px;font-size:13px}.button-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.button-primary:disabled,.button-soft:disabled,.button-ghost:disabled{opacity:.65;cursor:not-allowed}.button-soft{background:var(--surface-subtle);color:var(--text-primary);border-color:var(--border);padding:8px 14px;font-size:13px}.button-soft:hover,.button-ghost:hover,.button-ghost-sm:hover,.icon-btn:hover{background:var(--surface-subtle)}.button-ghost{background:var(--surface);color:var(--text-secondary);border-color:var(--border);padding:8px 14px;font-size:13px}.button-ghost-sm{background:var(--surface);color:var(--text-secondary);border-color:var(--border);padding:4px 10px;font-size:12px}.icon-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--surface);border-color:var(--border)}.user-chip{border-radius:999px;border:1px solid var(--border);background:var(--accent-soft);color:var(--accent-strong);padding:6px 12px;font-size:13px;font-weight:600}.user-menu-wrap{position:relative}.user-chip-button{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.user-chip-button:hover{background:color-mix(in srgb,var(--accent-soft) 80%,white 20%)}.user-caret{font-size:12px;transform:rotate(0);transition:transform .18s ease}.user-caret.open{transform:rotate(180deg)}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);z-index:80;min-width:136px;padding:6px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 94%,white 6%);box-shadow:var(--shadow-md)}.user-dropdown-item{width:100%;display:flex;align-items:center;border:1px solid transparent;background:transparent;color:var(--text-secondary);border-radius:8px;padding:7px 10px;font-size:13px;font-weight:600;cursor:pointer}.user-dropdown-item:hover{background:var(--surface-subtle)}.user-dropdown-item.danger{color:var(--danger)}.table-shell{overflow:hidden;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-md)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead{background:var(--surface-soft);color:var(--text-secondary)}.data-table th,.data-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:color-mix(in srgb,var(--accent-soft) 38%,transparent 62%)}.tree-cell{display:flex;align-items:center;gap:8px}.tree-toggle,.tree-toggle-placeholder{width:18px;height:18px;flex-shrink:0}.tree-toggle{border:1px solid var(--border);border-radius:6px;background:var(--surface-soft);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s ease}.tree-toggle:hover{background:var(--surface-subtle)}.tree-toggle-placeholder{display:inline-block}.tree-toggle-icon{font-size:11px;line-height:1;transform:rotate(0);transition:transform .18s ease}.tree-toggle.open .tree-toggle-icon{transform:rotate(90deg)}.text-muted{color:var(--text-muted)}.status-active{color:var(--success);font-weight:600}.status-inactive{color:var(--danger);font-weight:600}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px;background:#0f172366;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-card{width:100%;max-height:calc(100vh - 36px);overflow:auto;border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-lg);padding:18px}.app-message-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:16px;background:#0c141f73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app-message-card{width:min(520px,calc(100vw - 32px));border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-lg);padding:18px}.app-message-card.is-success{border-color:color-mix(in srgb,var(--success) 45%,var(--border) 55%)}.app-message-card.is-warning{border-color:color-mix(in srgb,#ce8e2a 45%,var(--border) 55%)}.app-message-card.is-error{border-color:color-mix(in srgb,var(--danger) 50%,var(--border) 50%)}.app-message-header{display:flex;align-items:center;gap:10px}.app-message-icon{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.app-message-card.is-success .app-message-icon{color:var(--success);background:color-mix(in srgb,var(--success) 15%,white 85%)}.app-message-card.is-warning .app-message-icon{color:#ad6e0f;background:#fff2db}.app-message-card.is-error .app-message-icon{color:var(--danger);background:color-mix(in srgb,var(--danger) 15%,white 85%)}.app-message-title{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.app-message-text{margin:14px 0 0;line-height:1.6;white-space:pre-wrap;word-break:break-word;color:var(--text-secondary)}.app-message-actions{margin-top:18px;display:flex;justify-content:flex-end}.app-confirm-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:115;display:flex;align-items:center;justify-content:center;padding:16px;background:#0c141f6b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app-confirm-card{width:min(560px,calc(100vw - 32px));border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-lg);padding:18px}.app-confirm-card.is-warning{border-color:color-mix(in srgb,#ce8e2a 40%,var(--border) 60%)}.app-confirm-card.is-danger{border-color:color-mix(in srgb,var(--danger) 45%,var(--border) 55%)}.app-confirm-title{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.app-confirm-text{margin:12px 0 0;line-height:1.65;white-space:pre-wrap;word-break:break-word;color:var(--text-secondary)}.app-confirm-actions{margin-top:18px;display:flex;justify-content:flex-end;gap:10px}.message-pop-enter-active,.message-pop-leave-active{transition:opacity .2s ease}.message-pop-enter-from,.message-pop-leave-to{opacity:0}.modal-title{margin-bottom:12px;font-size:18px;font-weight:700;color:var(--text-primary)}.field-label{margin-bottom:6px;display:block;font-size:12px;color:var(--text-secondary);font-weight:600}.input-field,.select-field{width:100%;border-radius:10px;border:1px solid var(--border);background:var(--surface-soft);color:var(--text-primary);padding:8px 10px;font-size:13px;outline:none}.input-field:focus,.select-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent 82%)}.input-field:disabled{opacity:.7}.checkbox-row{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px}.menu-permission-box{max-height:260px;overflow:auto;border:1px solid var(--border);border-radius:10px;background:var(--surface-soft);padding:8px}.menu-tree-row{display:flex;align-items:center;min-height:30px;border-radius:8px}.menu-tree-row:hover{background:color-mix(in srgb,var(--accent-soft) 38%,transparent 62%)}.menu-tree-toggle,.menu-tree-spacer{width:20px;height:20px;flex-shrink:0}.menu-tree-toggle{border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;transition:.18s ease}.menu-tree-toggle:hover{background:var(--surface-subtle)}.menu-tree-toggle-icon{font-size:11px;line-height:1;transform:rotate(0);transition:transform .18s ease}.menu-tree-toggle.open .menu-tree-toggle-icon{transform:rotate(90deg)}.menu-tree-spacer{display:inline-block}.menu-tree-label{display:flex;align-items:center;gap:8px;width:100%;color:var(--text-primary);font-size:13px;padding:4px 8px 4px 2px}.menu-tree-name{line-height:1.4}.dialog-actions{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.upload-field-wrap{width:100%}.upload-dropzone{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px dashed color-mix(in srgb,var(--accent) 35%,var(--border) 65%);border-radius:12px;background:color-mix(in srgb,var(--surface-soft) 88%,white 12%);padding:14px;cursor:pointer;transition:.18s ease}.upload-dropzone:hover{border-color:color-mix(in srgb,var(--accent) 52%,var(--border) 48%);background:color-mix(in srgb,var(--accent-soft) 50%,var(--surface-soft) 50%)}.upload-dropzone.is-drag-over{border-style:solid;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent 82%);background:color-mix(in srgb,var(--accent-soft) 72%,white 28%)}.upload-dropzone.disabled{opacity:.72;cursor:not-allowed}.upload-dropzone-main{min-width:0}.upload-dropzone-title{margin:0;font-size:14px;font-weight:700;color:var(--text-primary)}.upload-dropzone-hint{margin-top:2px;font-size:12px;color:var(--text-muted)}.upload-select-btn{min-width:88px;pointer-events:none}.upload-preview-card{margin-top:10px;display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--surface-soft) 90%,white 10%);padding:10px}.upload-preview-image{width:72px;height:72px;border-radius:10px;border:1px solid var(--border);-o-object-fit:cover;object-fit:cover;background:var(--surface)}.upload-preview-meta{min-width:0;flex:1}.upload-preview-title{margin:0;font-size:13px;font-weight:700;color:var(--text-primary)}.upload-preview-url{margin-top:2px;font-size:12px;color:var(--text-muted);line-height:1.4;word-break:break-all}.theme-switcher{position:relative;display:inline-flex;align-items:center}.theme-current{display:inline-flex;align-items:center;gap:8px;border-radius:10px;border:1px solid var(--border);background:var(--surface-soft);color:var(--text-secondary);padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:.18s ease}.theme-current:hover{background:var(--surface-subtle)}.theme-current-name{white-space:nowrap}.theme-caret{font-size:12px;transform:rotate(0);transition:transform .18s ease}.theme-caret.open{transform:rotate(180deg)}.theme-popover{position:absolute;right:0;top:calc(100% + 8px);z-index:70;display:flex;flex-direction:column;align-items:stretch;gap:4px;min-width:140px;padding:6px;border-radius:10px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 94%,white 6%);box-shadow:var(--shadow-md)}.theme-item{display:flex;align-items:center;gap:8px;width:100%;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-secondary);padding:7px 10px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}.theme-item:hover{background:var(--surface-subtle)}.theme-item.active{border-color:color-mix(in srgb,var(--accent) 38%,var(--border) 62%);background:color-mix(in srgb,var(--accent-soft) 70%,white 30%);color:var(--text-primary)}.theme-dot{width:12px;height:12px;border-radius:3px}.theme-dot.current{width:13px;height:13px;border-radius:4px}.theme-switcher.compact .theme-current{padding:6px 10px}.theme-switcher.compact .theme-popover{min-width:130px;padding:5px}.theme-switcher.compact .theme-item{padding:7px 9px}.theme-pop-enter-active,.theme-pop-leave-active{transition:opacity .14s ease,transform .14s ease}.theme-pop-enter-from,.theme-pop-leave-to{opacity:0;transform:translateY(-4px)}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px}.login-card{width:100%;max-width:420px;border-radius:16px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 90%,white 10%);box-shadow:var(--shadow-lg);padding:24px}.login-brand{margin-bottom:16px;text-align:center}.login-title{margin:6px 0 0;font-size:26px;font-weight:700;color:var(--text-primary)}.login-subtitle{margin-top:4px;font-size:13px;color:var(--text-secondary)}.login-brand-row{display:inline-flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:var(--text-primary)}.login-brand-row .brand-logo-wrap{width:40px;height:40px;border-radius:12px}.login-system-name{position:relative;display:inline-block;overflow:hidden;isolation:isolate;transition:transform .2s ease,color .2s ease,text-shadow .2s ease}.login-system-name:after{content:"";position:absolute;top:-45%;left:-70%;width:56%;height:190%;opacity:0;pointer-events:none;transform:skew(-24deg);background:linear-gradient(110deg,#fff0,#ffffffe6 48%,#fff0)}.login-system-name:hover{color:color-mix(in srgb,var(--text-primary) 76%,var(--accent) 24%);transform:translateY(-1px);text-shadow:0 2px 10px color-mix(in srgb,var(--accent) 24%,transparent 76%)}.login-system-name:hover:after{opacity:1;animation:login-system-name-sweep .82s ease}@keyframes login-system-name-sweep{0%{left:-70%}to{left:125%}}.login-brand-chip{border-radius:8px;background:var(--accent);color:var(--accent-contrast);padding:4px 8px}.login-actions{margin-top:14px}.page-error{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}@media(max-width:1023px){.topbar{flex-wrap:wrap}.topbar-right{flex-wrap:wrap;justify-content:flex-end}.topbar-tabs-wrap{order:3;width:100%;padding:0}.content-wrap{padding-top:0}.upload-dropzone{align-items:flex-start;flex-direction:column}.upload-select-btn{width:100%}.upload-preview-card{align-items:flex-start;flex-direction:column}}
