.app-boot-shell{background:#f3f4f6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.boot-grid{opacity:.6;background-image:radial-gradient(#2d5f4f0f 1px,#0000 1px);background-size:18px 18px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0006,#0000 92%);mask-image:linear-gradient(#0006,#0000 92%)}.boot-orb{filter:blur(40px);opacity:.5;border-radius:8px;animation:12s ease-in-out infinite boot-float;position:absolute}.boot-orb-left{background:radial-gradient(circle,#2d5f4f1a,#0000 70%);width:360px;height:360px;top:-80px;left:-80px}.boot-orb-right{background:radial-gradient(circle,#a1620714,#0000 72%);width:430px;height:430px;animation-delay:-4s;bottom:-60px;right:-120px}.boot-card{z-index:1;text-align:center;background:#fff;border:1px solid #f3f4f6;border-radius:12px;width:min(440px,100vw - 32px);padding:32px;position:relative;box-shadow:0 8px 24px -12px #0f0f0f1a}.boot-chip{color:#2563eb;letter-spacing:.12em;text-transform:uppercase;background:#2d5f4f0f;border:1px solid #2d5f4f2e;border-radius:8px;align-items:center;height:28px;padding:0 12px;font-size:11px;font-weight:700;display:inline-flex}.boot-logo{color:#fff;background:radial-gradient(circle at 30% 30%,#ffffff1a,#0000 32%),linear-gradient(#2563eb 0%,#1d4ed8 100%);border-radius:8px;justify-content:center;align-items:center;width:72px;height:72px;margin:18px auto;display:flex;box-shadow:0 8px 24px -12px #0f0f0f2e}.boot-title{color:#111827;letter-spacing:-.01em;font-size:28px;font-weight:800}.boot-subtitle{color:#6b7280;margin-top:12px;font-size:14px;line-height:1.7}.boot-progress{background:#f3f4f6;border-radius:8px;height:6px;margin-top:24px;overflow:hidden}.boot-progress-bar{border-radius:inherit;background:linear-gradient(90deg,#2563eb,#3a7763);width:38%;height:100%;animation:1.25s ease-in-out infinite boot-progress;display:block}.app-layout{background:#f3f4f6;flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.app-layout--top{min-width:0}.fullscreen-layout{width:100vw;height:100vh;overflow:hidden}.route-progress{z-index:1200;pointer-events:none;opacity:0;transform-origin:0;background:linear-gradient(90deg,#2563eb 0% 100%);height:3px;transition:opacity .18s,transform .28s;position:absolute;top:0;left:0;right:0;transform:scaleX(.12)}.route-progress.active{opacity:1;transform:scaleX(.92)}@keyframes boot-float{0%,to{transform:translate(0,0)}50%{transform:translate(18px,-24px)}}@keyframes boot-progress{0%{transform:translate(-110%)}to{transform:translate(360%)}}.app-topbar{z-index:110;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff5;border-bottom:1px solid #e2e8f0e6;position:sticky;top:0;box-shadow:0 10px 24px #0f172a08}.portal-header-shell{width:min(1200px,100vw - 32px);margin:0 auto;padding:10px 0 8px}.portal-utilitybar{border-bottom:1px solid #e2e8f0a6;justify-content:space-between;align-items:center;gap:16px;min-height:28px;padding-bottom:8px;display:flex}.portal-utilitylinks{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.portal-utilitylink{color:#6b7280;cursor:pointer;background:0 0;border:0;border-radius:8px;height:24px;padding:0 8px;font-size:12px;transition:background-color .3s,color .3s}.portal-utilitylink:hover,.portal-utilitylink:focus-visible{color:#2563eb;background:#f1f5f9e6;outline:none}.portal-utilitymeta{color:#6b7280;white-space:nowrap;font-size:12px}.portal-mainbar{grid-template-columns:auto minmax(220px,520px) auto;align-items:center;gap:16px;padding:10px 0;display:grid}.app-brand{color:#111827;align-items:center;gap:8px;min-width:0;font-weight:800;text-decoration:none;display:inline-flex}.app-brand-icon{color:#fff;background:#2563eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex;box-shadow:inset 0 1px #ffffff14,0 1px 2px #0f0f0f0f}.app-brand-copy{flex-direction:column;min-width:0;display:flex}.app-brand-text{white-space:nowrap;font-size:16px}.app-brand-tagline{color:#6b7280;white-space:nowrap;margin-top:2px;font-size:12px}.portal-search-shell{width:min(520px,100%);min-width:0;position:relative}.portal-search{color:#6b7280;width:100%;min-width:0;height:40px;box-shadow:none;background:#fff;border:1px solid #f3f4f6;border-radius:8px;align-items:center;gap:10px;padding:0 14px;transition:border-color .3s,background-color .3s;display:inline-flex}.portal-search:focus-within{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2d5f4f1a}.portal-search-icon{color:#9ca3af;flex-shrink:0}.portal-search-input{color:#6b7280;background:0 0;border:0;outline:none;flex:1;min-width:0;font-size:14px}.portal-search-input::placeholder{color:#6b7280}.portal-search-button{color:#fff;cursor:pointer;background:#2563eb;border:0;border-radius:8px;height:28px;padding:0 14px;font-size:13px;font-weight:600;transition:background-color .3s}.portal-search-button:hover,.portal-search-button:focus-visible{background:#2563eb;outline:none}.portal-search-panel{z-index:40;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffffa;border:1px solid #94a3b83d;border-radius:14px;padding:12px;position:absolute;top:calc(100% + 10px);left:0;right:0;box-shadow:0 22px 54px #0f172a29}.portal-search-groups{flex-direction:column;gap:10px;max-height:min(70vh,520px);display:flex;overflow-y:auto}.portal-search-group{flex-direction:column;gap:6px;display:flex}.portal-search-group-header{color:#6b7280;justify-content:space-between;align-items:center;gap:8px;padding:2px 2px 0;font-size:12px;font-weight:600;display:flex}.portal-search-group-header strong{color:#111827;font-size:12px}.portal-search-item{text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:12px;grid-template-columns:32px minmax(0,1fr) auto;align-items:center;gap:10px;width:100%;padding:10px 12px;transition:background-color .15s,border-color .15s,transform .15s;display:grid}.portal-search-item:hover,.portal-search-item.is-active{background:#2d5f4f0f;border-color:#2d5f4f24;transform:none}.portal-search-item-icon{color:#2563eb;background:#2d5f4f14;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.portal-search-item-body{flex-direction:column;gap:4px;min-width:0;display:flex}.portal-search-item-title{color:#111827;font-size:14px;font-weight:600;line-height:1.35}.portal-search-item-subtitle,.portal-search-item-description{color:#6b7280;font-size:12px;line-height:1.5}.portal-search-item-badges{flex-wrap:wrap;gap:6px;display:flex}.portal-search-badge{color:#6b7280;background:#0f172a0d;border-radius:9999px;align-items:center;padding:2px 8px;font-size:11px;line-height:1.2;display:inline-flex}.portal-search-item-action{color:#2563eb;white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:600}.portal-search-state,.portal-search-footer{color:#6b7280;padding:6px 4px;font-size:12px;line-height:1.5}.portal-search-footer{border-top:1px solid #e2e8f0e6;padding-top:10px}.app-topbar-actions{flex-wrap:wrap;justify-self:end;align-items:center;gap:8px;display:flex}.top-user-profile{cursor:pointer;background:#f8fafcc2;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;max-width:180px;padding:4px 8px 4px 4px;transition:background-color .3s,border-color .3s,box-shadow .3s;display:inline-flex}.top-user-profile:hover,.top-user-profile:focus-visible{background:#fff;border-color:#e2e8f0e6;outline:none;box-shadow:0 1px 2px #0000000d}.user-avatar{color:#fff;background:#2563eb;border:2px solid #fff;flex-shrink:0;box-shadow:0 1px 2px #0f0f0f14}.top-user-copy{flex-direction:column;align-items:flex-start;min-width:0;display:flex}.user-name{color:#111827;white-space:nowrap;text-overflow:ellipsis;max-width:124px;font-size:14px;font-weight:700;overflow:hidden}.user-role{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;max-width:124px;font-size:12px;overflow:hidden}.portal-navrow{border-top:1px solid #e2e8f0a6;padding:6px 0 2px}.app-primary-nav{scrollbar-width:thin;align-items:center;gap:4px;min-width:0;padding:2px 0 6px;display:flex;overflow:auto hidden}.top-nav-item{color:#6b7280;border-radius:8px;flex:none;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-size:14px;font-weight:600;line-height:1;text-decoration:none;transition:background-color .3s,color .3s,box-shadow .3s;display:inline-flex}.top-nav-item:hover,.top-nav-item:focus-visible{color:#111827;background:#f3f4f6;outline:none}.top-nav-item.active{color:#fff;box-shadow:none;background:#111827}.top-nav-icon{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.top-nav-badge{color:#fff;background:#ef4444;border-radius:8px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 2px 6px #ef44444d}.main-container{z-index:5;flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;position:relative;overflow:hidden}.action-btn{color:#6b7280;background:0 0;border:1px solid #0000;transition:all .3s}.action-btn:hover{color:#2563eb;background:#fff;border-color:#e2e8f0cc;transform:translateY(-2px);box-shadow:0 1px 2px #0000000d}.action-link{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;text-decoration:none;display:inline-flex}.content-wrapper{flex:1;padding:0;position:relative;overflow-y:auto}.content-wrapper.no-scroll{overflow:hidden}.content-wrapper::-webkit-scrollbar{width:6px;height:6px}.app-primary-nav::-webkit-scrollbar{width:6px;height:6px}.content-wrapper::-webkit-scrollbar-track{background:0 0}.app-primary-nav::-webkit-scrollbar-track{background:0 0}.content-wrapper::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.app-primary-nav::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:3px}.content-wrapper::-webkit-scrollbar-thumb:hover{background:#94a3b880}.app-primary-nav::-webkit-scrollbar-thumb:hover{background:#94a3b880}.page-enter-active,.page-leave-active{transition:opacity .15s ease-out}.page-enter-from,.page-leave-to{opacity:0}@media (width<=767px){.boot-card{border-radius:8px;padding:28px 22px}.app-topbar{position:sticky}.portal-header-shell{width:calc(100vw - 24px);padding:8px 0 6px}.portal-utilitybar{flex-wrap:wrap;align-items:flex-start;gap:4px}.portal-utilitymeta{white-space:normal}.portal-mainbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.app-brand{flex:100%}.app-brand-tagline{white-space:normal}.portal-search-shell{flex:100%;width:100%}.portal-search-item{grid-template-columns:28px minmax(0,1fr)}.portal-search-item-action{display:none}.app-topbar-actions{justify-content:flex-end;width:100%}.portal-navrow{padding-top:4px}.app-primary-nav{padding-bottom:4px}.top-user-profile{padding-right:4px}.top-user-copy{display:none}}.hw-topbar{z-index:110;background:#fff;border-bottom:1px solid #eef0f5;position:sticky;top:0;box-shadow:0 1px 2px #0f172a0a}.hw-topbar-shell{align-items:center;gap:32px;width:min(1560px,100vw - 48px);margin:0 auto;padding:12px 0;display:flex}.hw-brand{color:#2a3142;flex-shrink:0;align-items:center;gap:14px;text-decoration:none;display:inline-flex}.hw-brand-icon{color:#fff;background:linear-gradient(135deg,#4c83f5 0%,#3a6fe0 100%);border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex;box-shadow:0 10px 20px #4c83f538}.hw-brand-copy{flex-direction:column;line-height:1.1;display:flex}.hw-brand-title{color:#2a3142;white-space:nowrap;font-size:18px;font-weight:700}.hw-brand-tagline{color:#8a93a1;white-space:nowrap;letter-spacing:.02em;margin-top:4px;font-size:12px}.hw-nav{scrollbar-width:none;flex:1;justify-content:center;align-items:center;gap:6px;min-width:0;display:flex;overflow-x:auto}.hw-nav::-webkit-scrollbar{display:none}.hw-nav-home{color:#4c83f5;white-space:nowrap;cursor:pointer;background:linear-gradient(#fff 0%,#f6f9ff 100%);border:1px solid #dfe6f3;border-radius:999px;justify-content:center;align-items:center;gap:6px;height:38px;margin-right:8px;padding:0 16px;font-size:14px;font-weight:600;transition:transform .18s,border-color .18s,color .18s,box-shadow .18s;display:inline-flex;box-shadow:0 8px 18px #b1c0e01f,inset 0 1px #fffffff0}.hw-nav-home:hover,.hw-nav-home:focus-visible{color:#2f6fe8;border-color:#c8d7f5;outline:none;transform:translateY(-1px);box-shadow:0 12px 24px #a7b8db29,inset 0 1px #fffffff5}.hw-nav-item{color:#5b6473;white-space:nowrap;align-items:center;gap:8px;padding:20px 16px;font-size:15px;font-weight:500;text-decoration:none;transition:color .18s;display:inline-flex;position:relative}.hw-nav-item:hover{color:#4c83f5}.hw-nav-item.active{color:#4c83f5;font-weight:600}.hw-nav-item.active:after{content:"";background:#4c83f5;border-radius:2px 2px 0 0;height:4px;position:absolute;bottom:0;left:16px;right:16px}.hw-nav-icon{color:inherit;align-items:center;display:inline-flex}.hw-nav-badge{color:#fff;background:#ff5c5c;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.hw-actions{flex-shrink:0;align-items:center;gap:6px;display:inline-flex}.hw-icon-btn{color:#6b7480;cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;text-decoration:none;transition:background-color .18s,color .18s;display:inline-flex}.hw-icon-btn:hover,.hw-icon-btn:focus-visible{color:#4c83f5;background:#f3f5fa;outline:none}.hw-user{cursor:pointer;background:0 0;border:0;border-radius:22px;align-items:center;gap:10px;margin-left:6px;padding:4px 12px 4px 4px;transition:background-color .18s;display:inline-flex}.hw-user:hover{background:#f3f5fa}.hw-user-avatar{color:#fff;background:linear-gradient(135deg,#4f86f5 0%,#2f6fe8 100%)}.hw-user-copy{text-align:left;flex-direction:column;line-height:1.1;display:flex}.hw-user-name{color:#2a3142;font-size:14px;font-weight:600}.hw-user-role{color:#8a93a1;margin-top:4px;font-size:12px}.hw-user-caret{color:#b8c0cc}@media (width<=1080px){.hw-brand-tagline{display:none}.hw-nav{gap:0}.hw-nav-home{height:34px;margin-right:6px;padding:0 14px;font-size:13px}.hw-nav-item{padding:18px 10px;font-size:14px}}@media (width<=880px){.hw-topbar-shell{gap:14px;width:calc(100vw - 28px);padding:10px 0}.hw-user-copy{display:none}.hw-nav{justify-content:flex-start}.hw-nav-home{height:32px;margin-right:4px;padding:0 12px;font-size:12px}.hw-nav-item{padding:14px 8px;font-size:13px}}:root{--color-primary:#2563eb;--color-secondary:#4b5563;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#6b7280;--gradient-primary:linear-gradient(180deg, #1860f5 0%, #0f4bd2 100%);--gradient-secondary:linear-gradient(180deg, #fff 0%, #f9fafb 100%);--gradient-success:linear-gradient(180deg, #1860f5 0%, #0f4bd2 100%);--gradient-warning:linear-gradient(180deg, #d97706 0%, #854d04 100%);--gradient-danger:linear-gradient(180deg, #dc2626 0%, #7a1d14 100%);--gradient-dark:linear-gradient(180deg, #374151 0%, #111827 100%);--el-color-primary:#1860f5;--el-color-primary-light-3:#5a91f7;--el-color-primary-light-5:#79a7f9;--el-color-primary-light-7:#a5c4fc;--el-color-primary-light-8:#c7dbfd;--el-color-primary-light-9:#e8f0ff;--el-color-primary-dark-2:#0f4bd2;--el-color-success:#10b981;--el-color-warning:#f59e0b;--el-color-danger:#ef4444;--el-color-info:#6b7280;--portal-font-family:PingFang SC, Source Han Sans SC, Microsoft YaHei UI, system-ui, sans-serif;--portal-brand-blue:#1860f5;--portal-brand-orange:#ff8f39;--portal-brand-green:#5dc879;--portal-page-bg:#f8faff;--portal-page-bg-soft:#f3f7ff;--portal-card-bg:#fff;--portal-text-title:#222;--portal-text-body:#333;--portal-text-muted:#666;--portal-action-bg:#f0f2f5;--portal-border-soft:#1860f514;--portal-border-neutral:#1f2a4414;--portal-shadow-soft:0 18px 40px #3448761f;--portal-shadow-hover:0 24px 48px #34487629;--portal-shadow-tint-blue:0 14px 30px #1860f524;--portal-shadow-tint-orange:0 14px 30px #ff8f392e;--portal-shadow-tint-green:0 14px 30px #5dc8792e;--portal-radius-control:18px;--portal-radius-panel:24px;--portal-radius-card:28px;--portal-content-max-width:1740px;--color-bg:#f3f4f6;--color-bg-light:#fff;--color-bg-glass:#fbfaf6d9;--color-bg-glass-dark:#1b1b1ac7;--text-primary:#111827;--text-regular:#374151;--text-secondary:#6b7280;--text-placeholder:#9ca3af;--text-light:#d1d5db;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 2px #0f0f0f0a;--shadow:0 1px 2px #0f0f0f0a;--shadow-lg:0 8px 24px -12px #0f0f0f1f;--shadow-xl:0 24px 48px -24px #0f0f0f2e;--shadow-colored:0 1px 2px #0f0f0f0f;--spacing-xs:4px;--spacing-sm:8px;--spacing:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--layout-max-width:1400px;--layout-max-width-narrow:1200px;--layout-sidebar-width:280px;--z-sticky:110;--z-modal:1000;--z-fullscreen:2000;--font-family-base:PingFang SC, Source Han Sans SC, Microsoft YaHei UI, system-ui, sans-serif;--font-family-mono:JetBrains Mono, Fira Code, Consolas, monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#111827;background:#f8faff;height:100%;margin:0;padding:0;font-family:PingFang SC,Source Han Sans SC,Microsoft YaHei UI,system-ui,sans-serif}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 24px}.container--narrow{max-width:1200px}.container--wide{max-width:1600px}.container--fluid{max-width:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.glass-panel{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fbfaf6cc;border:1px solid #e2ddd2b3;box-shadow:0 1px 2px #0f0f0f0a}.fade-enter-active,.fade-leave-active{transition:opacity .3s}.fade-enter-from,.fade-leave-to{opacity:0}.slide-up-enter-active,.slide-up-leave-active{transition:all .4s cubic-bezier(.4,0,.2,1)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(20px)}.el-button{border-radius:8px;font-weight:500;transition:background .18s cubic-bezier(.22,1,.36,1),border-color .18s cubic-bezier(.22,1,.36,1),color .18s cubic-bezier(.22,1,.36,1)}.el-button--primary:not(.is-plain):not(.is-text):not(.is-link){color:#fff;background:#2563eb;border-color:#2563eb;box-shadow:0 1px 2px #0f0f0f0f}.el-button--primary:not(.is-plain):not(.is-text):not(.is-link):hover{color:#fff;background:#2563eb;border-color:#2563eb}.el-button--primary:not(.is-plain):not(.is-text):not(.is-link):active{background:#1d4ed8;border-color:#1d4ed8}.el-button--primary.is-plain{color:#2563eb;box-shadow:none;background:#2d5f4f0f;border-color:#2d5f4f52}.el-button--primary.is-plain:hover{color:#2563eb;background:#2d5f4f1f;border-color:#2563eb}.modern-card{background:#fff;border:1px solid #f3f4f6;border-radius:12px;min-width:0;padding:24px;transition:border-color .18s cubic-bezier(.22,1,.36,1);box-shadow:0 1px 2px #0f0f0f0a}.modern-card:hover{border-color:#e5e7eb}.modern-card--accent{border-top:3px solid #2563eb}::selection{color:#111827;background:#2d5f4f33}
