*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{color:#1a1a1a;-webkit-font-smoothing:antialiased;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px}a{color:inherit;text-decoration:none}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-1{flex:1}.gap-10{gap:10px}.gap-20{gap:20px}.mt-10{margin-top:10px}.mt-20{margin-top:20px}.mb-10{margin-bottom:10px}.mb-20{margin-bottom:20px}.ml-10{margin-left:10px}.mr-10{margin-right:10px}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:12px}.text-gray{color:#888}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:#fafafa;border-right:1px solid #eee;flex-direction:column;flex-shrink:0;width:200px;transition:width .25s;display:flex;overflow:hidden}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-logo .logo-text{font-size:18px}.sidebar.collapsed .nav-item{justify-content:center;padding:0}.sidebar.collapsed .nav-label{display:none}.sidebar-logo{cursor:pointer;border-bottom:1px solid #eee;justify-content:center;align-items:center;height:56px;display:flex}.sidebar-logo .logo-text{letter-spacing:-.5px;color:#111;font-size:20px;font-weight:700}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:0}.nav-item{cursor:pointer;color:#555;border-left:3px solid #0000;align-items:center;gap:10px;height:42px;padding:0 20px;font-size:13px;transition:all .15s;display:flex}.nav-item:hover{color:#111;background:#f0f0f0}.nav-item.active{color:#111;background:#f0f0f0;border-left-color:#111;font-weight:600}.nav-item .el-icon{flex-shrink:0}.nav-group-title{cursor:pointer;color:#999;text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;height:36px;margin-top:6px;padding:0 20px;font-size:12px;font-weight:500;transition:color .15s;display:flex}.nav-group-title:hover{color:#555}.nav-group-icon{color:#999;cursor:pointer;justify-content:center;align-items:center;height:36px;margin-top:6px;display:flex}.nav-group-icon:hover{color:#555}.nav-children .nav-child{height:36px;padding-left:46px;font-size:13px}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.header{background:#fff;border-bottom:1px solid #eee;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex}.header-left{align-items:center;gap:16px;display:flex}.header-left .toggle-btn{cursor:pointer;color:#666;align-items:center;display:flex}.header-left .toggle-btn:hover{color:#111}.header-left .page-title{color:#111;font-size:16px;font-weight:600}.header-right{align-items:center;display:flex}.user-block{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:4px 8px;transition:background .15s;display:flex}.user-block:hover{background:#f5f5f5}.user-block .user-name{color:#333;font-size:13px}.content{background:#fff;flex:1;padding:24px;overflow-y:auto}.page-card{background:#fff;border:1px solid #eee;border-radius:8px;padding:24px}.page-card+.page-card{margin-top:16px}.page-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.page-header h2{color:#111;font-size:16px;font-weight:600}.section-title{color:#111;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f0f0f0;margin:24px 0 12px;padding-bottom:8px;font-size:13px;font-weight:600}.table-header-action{align-items:center;gap:10px;margin-bottom:16px;display:flex}.table-header-action .search-input{width:240px}.pagination-wrap{justify-content:flex-end;margin-top:20px;display:flex}.login-container{background:#fafafa;justify-content:center;align-items:center;height:100vh;display:flex}.login-container .login-box{background:#fff;border:1px solid #eee;border-radius:12px;width:380px;padding:48px 36px}.login-container .login-box .login-title{text-align:center;margin-bottom:36px}.login-container .login-box .login-title h1{color:#111;font-size:22px;font-weight:700}.login-container .login-box .login-title p{color:#888;margin-top:8px;font-size:13px}.login-container .login-box .el-form-item{margin-bottom:20px}.login-container .login-box .login-btn{width:100%;height:40px;font-size:14px}.dashboard .stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.dashboard .stats-grid .stat-card{border:1px solid #eee;border-radius:8px;align-items:center;gap:16px;padding:20px;display:flex}.dashboard .stats-grid .stat-card .stat-icon{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.dashboard .stats-grid .stat-card .stat-info h3{color:#111;margin-bottom:4px;font-size:22px;font-weight:700}.dashboard .stats-grid .stat-card .stat-info p{color:#888;font-size:12px}.dashboard .chart-grid{grid-template-columns:2fr 1fr;gap:16px;display:grid}.dashboard .chart-grid .chart-card{border:1px solid #eee;border-radius:8px;padding:20px}.dashboard .chart-grid .chart-card h3{color:#111;margin-bottom:16px;font-size:14px;font-weight:600}.page-editor{height:calc(100vh - 56px);margin:-24px;display:flex;overflow:hidden}.page-editor .editor-left{background:#fafafa;border-right:1px solid #eee;width:240px;padding:16px;overflow-y:auto}.page-editor .editor-left .component-group h4{color:#888;text-transform:uppercase;letter-spacing:.5px;padding:8px 0;font-size:11px}.page-editor .editor-left .component-group .component-list{grid-template-columns:1fr 1fr;gap:6px;display:grid}.page-editor .editor-left .component-group .component-list .component-item{text-align:center;cursor:grab;color:#555;background:#fff;border:1px solid #eee;border-radius:6px;padding:10px 4px;font-size:11px;transition:all .15s}.page-editor .editor-left .component-group .component-list .component-item:hover{color:#111;border-color:#111}.page-editor .editor-left .component-group .component-list .component-item i{margin-bottom:4px;font-size:20px;display:block}.page-editor .editor-canvas{background:#f5f5f5;flex:1;padding:24px;overflow-y:auto}.page-editor .editor-canvas .canvas-area{background:#fff;border:2px dashed #ddd;border-radius:8px;min-height:600px}.page-editor .editor-canvas .canvas-area .canvas-component{cursor:move;border:1px dashed #0000;position:relative}.page-editor .editor-canvas .canvas-area .canvas-component:hover{border-color:#999}.page-editor .editor-canvas .canvas-area .canvas-component.selected{background:#00000005;border-color:#111}.page-editor .editor-canvas .canvas-area .canvas-component .component-actions{gap:4px;display:none;position:absolute;top:-28px;right:0}.page-editor .editor-canvas .canvas-area .canvas-component.selected .component-actions{display:flex}.page-editor .editor-canvas .canvas-area .canvas-component .component-label{color:#fff;background:#111;border-radius:2px;padding:2px 6px;font-size:10px;position:absolute;top:0;left:0}.page-editor .editor-right{background:#fafafa;border-left:1px solid #eee;width:280px;overflow-y:auto}.page-editor .editor-right .prop-group{border-bottom:1px solid #eee;padding:16px}.page-editor .editor-right .prop-group h4{color:#111;margin-bottom:12px;font-size:13px;font-weight:600}.page-editor .editor-toolbar{color:#fff;z-index:100;background:#111;border-radius:24px;gap:10px;padding:8px 20px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000026}.el-button--primary{--el-button-bg-color:#111;--el-button-border-color:#111;--el-button-hover-bg-color:#333;--el-button-hover-border-color:#333;--el-button-active-bg-color:#000;--el-button-active-border-color:#000}.el-menu{border-right:none!important}.el-table{--el-table-border-color:#f0f0f0;--el-table-header-bg-color:#fafafa}.el-tabs__item.is-active{font-weight:600;color:#111!important}.el-tabs__active-bar{background-color:#111!important}
