:root{--primary-color: #2c3e50;--primary-light: #34495e;--primary-lighter: #7f8c8d;--secondary-color: #3498db;--secondary-light: #5dade2;--secondary-lighter: #85c1e9;--success-color: #27ae60;--warning-color: #f39c12;--error-color: #e74c3c;--info-color: #17a2b8;--text-primary: #2c3e50;--text-secondary: #7f8c8d;--text-disabled: #bdc3c7;--border-color: #e9ecef;--background-color: #f8f9fa;--white: #ffffff;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-success: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--gradient-card: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);--gradient-header: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--font-family-primary: "Helvetica Neue", Helvetica, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", Arial, sans-serif;--font-family-mono: "Fira Code", "Monaco", "Consolas", monospace;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 30px;--font-size-4xl: 36px;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-base: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--border-radius-sm: 4px;--border-radius-base: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-base: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .15);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease;--sidebar-width: 250px;--header-height: 60px;--content-padding: var(--spacing-xl)}@media (max-width: 768px){:root{--sidebar-width: 0px;--content-padding: var(--spacing-base)}}@media (min-width: 769px) and (max-width: 1024px){:root{--sidebar-width: 200px}}@media (min-width: 1025px){:root{--sidebar-width: 250px}}html,body{margin:0;padding:0;font-family:var(--font-family-primary);font-size:var(--font-size-base);line-height:1.6;color:var(--text-primary);background-color:var(--background-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar-track{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb{background:var(--primary-lighter);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary-light)}a{color:var(--secondary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--secondary-light)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-base)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background:var(--secondary-light)}.card{background:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-base);padding:var(--spacing-xl);transition:all var(--transition-base)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-header{border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-base);margin-bottom:var(--spacing-lg)}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}.page-header{text-align:center;margin-bottom:var(--spacing-2xl);background:var(--gradient-primary);color:#fff;padding:var(--spacing-2xl);border-radius:var(--border-radius-lg)}.page-header h1{margin:0 0 var(--spacing-base) 0;font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold)}.page-header p{margin:0;opacity:.9;font-size:var(--font-size-lg)}.kpi-card{background:var(--gradient-card);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);box-shadow:var(--shadow-base);transition:transform var(--transition-base)}.kpi-card:hover{transform:translateY(-4px)}.kpi-icon{font-size:var(--font-size-3xl);color:var(--secondary-color)}.kpi-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.kpi-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.loading{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--secondary-color);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-enter-active,.page-leave-active{transition:all var(--transition-base)}.page-enter-from{opacity:0;transform:translate(30px)}.page-leave-to{opacity:0;transform:translate(-30px)}.hidden-mobile{display:block}.hidden-desktop{display:none}@media (max-width: 768px){.hidden-mobile{display:none}.hidden-desktop{display:block}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.text-error{color:var(--error-color)}.m-0{margin:0}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-3{margin:var(--spacing-base)}.m-4{margin:var(--spacing-lg)}.m-5{margin:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-base)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.grouped-sidebar[data-v-a7371faf]{background-color:#2c3e50;min-height:100vh;box-shadow:2px 0 8px #0000001a;display:flex;flex-direction:column}.sidebar-logo[data-v-a7371faf]{padding:20px;text-align:center;border-bottom:1px solid rgba(236,240,241,.1)}.sidebar-logo h3[data-v-a7371faf]{margin:0;color:#ecf0f1;font-size:20px;font-weight:600;letter-spacing:1px}.sidebar-logo p[data-v-a7371faf]{margin:5px 0 0;color:#95a5a6;font-size:12px}.menu-scrollbar[data-v-a7371faf]{flex:1;overflow-y:auto}.menu-groups[data-v-a7371faf]{padding:10px 0}.menu-group[data-v-a7371faf]{margin-bottom:4px}.group-header[data-v-a7371faf]{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;cursor:pointer;transition:all .3s ease;user-select:none}.group-header[data-v-a7371faf]:hover{background-color:#3498db1a}.group-title[data-v-a7371faf]{display:flex;align-items:center;gap:10px;flex:1}.group-icon[data-v-a7371faf]{font-size:18px;color:#3498db}.group-text[data-v-a7371faf]{color:#ecf0f1;font-size:14px;font-weight:600;letter-spacing:.5px}.core-badge[data-v-a7371faf]{margin-left:8px;font-size:10px;padding:0 6px;height:18px;line-height:18px}.expand-icon[data-v-a7371faf]{font-size:14px;color:#95a5a6;transition:transform .3s ease}.expand-icon.is-rotated[data-v-a7371faf]{transform:rotate(90deg)}.group-items[data-v-a7371faf]{padding-left:10px;background-color:#0000001a}.group-menu[data-v-a7371faf]{border:none}.group-menu-item[data-v-a7371faf]{padding-left:40px!important;height:45px;line-height:45px;position:relative}.group-menu-item[data-v-a7371faf]:before{content:"";position:absolute;left:25px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background-color:#95a5a6}.group-menu-item.is-active[data-v-a7371faf]:before{background-color:#3498db}.item-icon[data-v-a7371faf]{font-size:16px;margin-right:8px}.item-text[data-v-a7371faf]{font-size:14px}.route-badge[data-v-a7371faf]{margin-left:auto;margin-right:8px}.sidebar-footer[data-v-a7371faf]{padding:15px 20px;border-top:1px solid rgba(236,240,241,.1);background-color:#0000001a}.system-info[data-v-a7371faf]{display:flex;flex-direction:column;gap:8px}.info-item[data-v-a7371faf]{display:flex;justify-content:space-between;align-items:center;font-size:12px}.info-item .label[data-v-a7371faf]{color:#95a5a6}.info-item .value[data-v-a7371faf]{color:#ecf0f1;font-weight:500}.status-online[data-v-a7371faf]{color:#2ecc71}[data-v-a7371faf] .el-scrollbar__wrap{overflow-x:hidden}[data-v-a7371faf] .el-scrollbar__bar.is-vertical{width:6px}[data-v-a7371faf] .el-scrollbar__thumb{background-color:#9093994d}[data-v-a7371faf] .el-scrollbar__thumb:hover{background-color:#90939980}.simple-account-switcher[data-v-34fa9ac7]{display:flex;align-items:center}.account-trigger[data-v-34fa9ac7]{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .3s ease;background:rgba(255,255,255,.1)}.account-trigger[data-v-34fa9ac7]:hover{background:rgba(255,255,255,.2)}.account-name[data-v-34fa9ac7]{color:#fff;font-size:14px;font-weight:500}.dropdown-icon[data-v-34fa9ac7]{color:#fff;font-size:12px;transition:transform .3s ease}.dropdown-label[data-v-34fa9ac7]{padding:8px 16px;font-size:12px;color:#909399;cursor:default}.active-role[data-v-34fa9ac7]{background-color:#ecf5ff;color:#409eff}[data-v-34fa9ac7] .el-dropdown-menu__item{display:flex;align-items:center;gap:8px}[data-v-34fa9ac7] .el-dropdown-menu__item .el-icon{font-size:16px}.notification-badge[data-v-a45e60e9]{margin-right:8px}.notification-button[data-v-a45e60e9]{background-color:#ffffff1a;border:none;color:#fff;transition:all .3s}.notification-button[data-v-a45e60e9]:hover{background-color:#fff3;color:#fff}.notification-button.has-unread[data-v-a45e60e9]{animation:pulse-a45e60e9 2s infinite}@keyframes pulse-a45e60e9{0%{box-shadow:0 0 #fff6}70%{box-shadow:0 0 0 10px #fff0}to{box-shadow:0 0 #fff0}}.notification-panel[data-v-a45e60e9]{display:flex;flex-direction:column;max-height:480px}.panel-header[data-v-a45e60e9]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #ebeef5}.panel-header .title[data-v-a45e60e9]{font-size:16px;font-weight:600;color:#303133}.notification-list[data-v-a45e60e9]{flex:1;overflow-y:auto;max-height:360px;min-height:100px}.notification-item[data-v-a45e60e9]{display:flex;align-items:flex-start;padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f2f3f5;position:relative}.notification-item[data-v-a45e60e9]:hover{background-color:#f5f7fa}.notification-item.unread[data-v-a45e60e9]{background-color:#ecf5ff}.notification-item.unread[data-v-a45e60e9]:hover{background-color:#d9ecff}.notification-icon[data-v-a45e60e9]{width:36px;height:36px;border-radius:50%;background-color:#e6e8eb;display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0}.notification-item.unread .notification-icon[data-v-a45e60e9]{background-color:#409eff;color:#fff}.notification-content[data-v-a45e60e9]{flex:1;min-width:0}.notification-title[data-v-a45e60e9]{font-size:14px;font-weight:500;color:#303133;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-text[data-v-a45e60e9]{font-size:12px;color:#909399;line-height:1.4;margin-bottom:4px}.notification-time[data-v-a45e60e9]{font-size:11px;color:#c0c4cc}.notification-actions[data-v-a45e60e9]{display:flex;gap:8px;margin-top:8px}.notification-actions .el-button[data-v-a45e60e9]{padding:4px 10px;font-size:12px}.unread-dot[data-v-a45e60e9]{width:8px;height:8px;border-radius:50%;background-color:#409eff;margin-left:8px;flex-shrink:0;margin-top:6px}.empty-state[data-v-a45e60e9]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#909399}.empty-state p[data-v-a45e60e9]{margin-top:12px;font-size:14px}.panel-footer[data-v-a45e60e9]{padding:12px 16px;border-top:1px solid #ebeef5;text-align:center}.notification-popover{padding:0!important}.notification-popover .el-popover__title{display:none}.header[data-v-f6f4aa8a]{background:var(--gradient-header);color:#fff;display:flex;align-items:center;padding:0 var(--spacing-xl);box-shadow:var(--shadow-base);height:var(--header-height)}.header-content[data-v-f6f4aa8a]{display:flex;justify-content:space-between;align-items:center;width:100%}.header-title h2[data-v-f6f4aa8a]{margin:0;font-weight:var(--font-weight-semibold);font-size:var(--font-size-2xl)}.header-actions[data-v-f6f4aa8a]{display:flex;gap:var(--spacing-base);align-items:center}.user-dropdown[data-v-f6f4aa8a]{color:#fff;padding:var(--spacing-sm) var(--spacing-base);border-radius:var(--border-radius-base);transition:background-color var(--transition-fast)}.user-dropdown[data-v-f6f4aa8a]:hover{background-color:#ffffff1a}.user-dropdown .el-icon[data-v-f6f4aa8a]{margin-right:var(--spacing-xs)}.user-dropdown .el-icon--right[data-v-f6f4aa8a]{margin-left:var(--spacing-xs);margin-right:0}.icp-footer[data-v-2afb24af]{text-align:left;font-size:12px;color:#666;line-height:1.6;padding:8px 12px}.icp-footer--fixed[data-v-2afb24af]{position:fixed;bottom:0;left:0;right:auto;z-index:100;background:rgba(255,255,255,.95);box-shadow:0 -1px #0000000d}.icp-footer__inner[data-v-2afb24af]{padding:0 16px}.icp-footer__company[data-v-2afb24af]{margin:0 0 2px;font-size:12px;color:#888}.icp-footer__icp[data-v-2afb24af]{margin:0}.icp-footer__link[data-v-2afb24af]{color:#666;text-decoration:none}.icp-footer__link[data-v-2afb24af]:hover{text-decoration:underline;color:#333}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Helvetica Neue,Helvetica,PingFang SC,Hiragino Sans GB,Microsoft YaHei,微软雅黑,Arial,sans-serif;font-size:16px;line-height:1.6;color:#2c3e50;background-color:#f8f9fa;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;min-height:100vh}.sidebar{width:250px;background-color:#2c3e50;color:#fff;display:flex;flex-direction:column}.logo{height:60px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1)}.menu{flex:1;padding:20px 0}.menu-item{padding:15px 20px;cursor:pointer;transition:background-color .3s;border-bottom:1px solid rgba(255,255,255,.05)}.menu-item:hover{background-color:#34495e}.menu-item.active{background-color:#3498db}.main-container{flex:1;display:flex;flex-direction:column}.main-content{flex:1;background-color:#f5f7fa;padding:20px;overflow-y:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#e9ecef;border-radius:3px}::-webkit-scrollbar-thumb{background:#7f8c8d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#34495e}
