*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;font-size:14px;color:#303133;-webkit-font-smoothing:antialiased}#app{height:100%;width:100%}.login-page{height:100%;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.app-page{position:fixed;top:0;left:0;right:0;bottom:0;background:#f5f7fa;overflow:hidden;display:flex;flex-direction:column}.topbar{flex:0 0 auto;height:60px;width:100%;background:#fff;border-bottom:1px solid #ebeef5;box-shadow:0 1px 4px #0015290f;display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:1000}.topbar-left{display:flex;align-items:center;flex:1;min-width:0}.brand-box{display:flex;align-items:center;margin-right:16px}.brand-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#409eff,#66b1ff);color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-right:10px;flex-shrink:0}.brand-text{display:flex;flex-direction:column}.brand-title{font-size:15px;font-weight:600;color:#303133;line-height:1.2}.brand-subtitle{font-size:11px;color:#909399}.menu-toggle{width:36px;height:36px;border:none;background:transparent;color:#606266;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;margin-right:12px;flex-shrink:0}.menu-toggle:hover{background:#ecf5ff;color:#409eff}.breadcrumb{display:flex;align-items:center;color:#606266;font-size:13px;overflow:hidden;white-space:nowrap}.crumb{cursor:pointer;color:#409eff}.crumb:hover{text-decoration:underline}.crumb-item{display:flex;align-items:center;margin-left:4px}.crumb-sep{margin:0 4px;color:#c0c4cc}.topbar-right{display:flex;align-items:center;margin-left:16px;flex-shrink:0}.top-btn{width:36px;height:36px;border:none;background:transparent;color:#606266;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;position:relative;flex-shrink:0}.top-btn:hover{background:#ecf5ff;color:#409eff}.badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:#f56c6c;color:#fff;font-size:11px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.divider{width:1px;height:20px;background:#e4e7ed;margin:0 8px}.user-menu{display:flex;align-items:center;padding:4px 12px 4px 4px;border-radius:20px;cursor:pointer;transition:background .2s}.user-menu:hover{background:#f2f6fc}.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#409eff,#66b1ff);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;margin-right:8px;flex-shrink:0}.user-name{font-size:14px;color:#303133}.dropdown-panel{position:fixed;top:68px;right:16px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #0000001a;min-width:180px;z-index:999}.dropdown-header{padding:12px 16px;font-weight:600;color:#303133;border-bottom:1px solid #ebeef5}.dropdown-item{padding:12px 16px;color:#606266;cursor:pointer;transition:background .2s}.dropdown-item:hover{background:#f5f7fa}.dropdown-footer{color:#409eff;border-top:1px solid #ebeef5}.layout-body{flex:1 1 auto;display:flex;min-height:0;overflow:hidden}.sidebar{flex:0 0 240px;width:240px;background:#fff;border-right:1px solid #ebeef5;overflow-y:auto;overflow-x:hidden;transition:width .28s ease,flex-basis .28s ease;scrollbar-width:thin;scrollbar-color:#c0c4cc transparent}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:#c0c4cc;border-radius:3px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar.collapsed{width:64px;flex-basis:64px}.menu{padding:12px 0}.menu-group-title{display:flex;align-items:center;padding:10px 16px;cursor:pointer;color:#303133;transition:background .2s;-webkit-user-select:none;user-select:none;gap:10px}.menu-group-title .menu-icon{flex:0 0 20px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#606266}.menu-group-title:hover{background:#f5f7fa}.menu-group-title:hover .menu-icon{color:#409eff}.menu-group-items{background:#fafafa}.menu-item{display:flex;align-items:center;padding:10px 16px;color:#303133;text-decoration:none;transition:all .2s;cursor:pointer;gap:10px}.menu-item .menu-icon{flex:0 0 20px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#606266}.menu-item:hover{background:#ecf5ff;color:#409eff}.menu-item:hover .menu-icon{color:#409eff}.menu-item.active{background:#ecf5ff;color:#409eff;border-left:3px solid #409eff}.menu-item.active .menu-icon{color:#409eff}.menu-text{flex:1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-arrow{font-size:12px;transition:transform .2s;color:#909399}.menu-arrow.expanded{transform:rotate(90deg)}.menu-group-items .menu-item{padding-left:48px}.sidebar.collapsed .menu-group-title{justify-content:center;padding:12px 0}.sidebar.collapsed .menu-group-title .menu-text,.sidebar.collapsed .menu-group-title .menu-arrow,.sidebar.collapsed .menu-group-items{display:none}.sidebar.collapsed .menu-item{justify-content:center;padding:12px 0}.sidebar.collapsed .menu-item .menu-text{display:none}.sidebar.collapsed .menu-icon{flex:0 0 auto;width:22px;height:22px}.main-content{flex:1 1 auto;min-width:0;padding:20px;overflow-y:auto;overflow-x:hidden;background:#f5f7fa}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}@media(max-width:900px){.brand-subtitle,.breadcrumb,.user-name{display:none}.user-menu{padding:4px}}.stats-grid,.charts-container{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:16px!important;margin-bottom:20px!important}.chart-card{min-height:300px!important}.chart-card.wide{grid-column:span 2!important}.pie-chart{display:flex!important;flex-direction:column!important;align-items:center!important;gap:12px!important;width:100%!important}.pie-svg{width:160px!important;height:160px!important;flex-shrink:0!important}.pie-legend{display:flex!important;flex-wrap:wrap!important;justify-content:center!important;gap:8px 14px!important}@media(max-width:1400px){.stats-grid,.charts-container{grid-template-columns:repeat(3,1fr)!important}}@media(max-width:1100px){.stats-grid,.charts-container{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:760px){.stats-grid,.charts-container{grid-template-columns:1fr!important}.chart-card.wide{grid-column:span 1!important}}.el-table .el-table__body-wrapper .el-table__cell .cell .el-button+.el-button{margin-left:6px}.el-table .el-table__body-wrapper .el-table__cell .cell .el-button{white-space:nowrap}.el-table .el-table__body-wrapper .el-table__cell .cell{white-space:nowrap;line-height:1}.el-table .el-table__body-wrapper .el-table__cell .cell .el-button--small{padding:7px 11px;font-size:12px}.op-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:18px;line-height:1;margin:0 3px;transition:background .2s,transform .1s;vertical-align:middle;-webkit-user-select:none;user-select:none}.op-icon:hover{transform:translateY(-1px)}.op-primary{color:#409eff}.op-primary:hover{background:#409eff1f}.op-danger{color:#f56c6c}.op-danger:hover{background:#f56c6c1f}.op-warning{color:#e6a23c}.op-warning:hover{background:#e6a23c1f}.op-success{color:#67c23a}.op-success:hover{background:#67c23a1f}.op-info{color:#909399}.op-info:hover{background:#9093991f}
