*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f2f5;color:#262626;font-size:14px;line-height:1.5715}.app{min-height:100vh;background-color:#f0f2f5;display:flex;flex-direction:column}.app-body{display:flex;flex:1;min-height:calc(100vh - 64px)}.app-header{height:64px;background:#001529;color:#fff;padding:0 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000026;position:relative;z-index:10;flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:16px;flex:1}.app-logo{font-size:20px;font-weight:600;color:#fff;display:flex;align-items:center;gap:10px;letter-spacing:1px}.app-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#1890ff,#096dd9);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.app-system-name{font-size:16px;font-weight:500}.app-header-search{flex:1;max-width:400px;margin-left:32px}.app-header-search input{width:100%;padding:8px 16px;border:none;border-radius:6px;background:#ffffff1a;color:#fff;font-size:14px;transition:all .2s}.app-header-search input::placeholder{color:#ffffff80}.app-header-search input:focus{outline:none;background:#ffffff26;box-shadow:0 0 0 2px #1890ff33}.app-header-right{display:flex;align-items:center;gap:20px}.header-badge{display:flex;align-items:center;gap:6px;padding:4px 12px;background:#ffffff1a;border-radius:12px;font-size:13px;cursor:pointer;transition:background .2s}.header-badge:hover{background:#ffffff26}.header-user{display:flex;align-items:center;gap:10px;padding:6px 12px;background:#ffffff1a;border-radius:20px;cursor:pointer;transition:background .2s}.header-user:hover{background:#ffffff26}.header-user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#1890ff,#096dd9);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500}.header-user-name{font-size:13px;color:#fff}.sidebar{width:232px;background:#fff;border-right:1px solid #f0f0f0;flex-shrink:0;overflow-y:auto;overflow-x:hidden;box-shadow:2px 0 8px #00000008}.sidebar-group{padding:12px 0;border-bottom:1px solid #f5f5f5}.sidebar-group:last-child{border-bottom:none}.sidebar-group-title{padding:8px 24px;font-size:12px;font-weight:600;color:#8c8c8c;letter-spacing:.5px;text-transform:uppercase}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 24px;cursor:pointer;transition:all .2s;color:#262626;font-size:14px;border-left:3px solid transparent;position:relative}.sidebar-item:hover{background:#e6f7ff;color:#1890ff}.sidebar-item.active{background:#e6f7ff;color:#1890ff;border-left-color:#1890ff;font-weight:500}.sidebar-item-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}.sidebar-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item-count{background:#ff4d4f;color:#fff;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:500;min-width:20px;text-align:center}.main-content{flex:1;padding:24px;overflow:auto;min-width:0}.breadcrumb{font-size:13px;color:#8c8c8c;margin-bottom:16px;display:flex;align-items:center;gap:6px}.breadcrumb-separator{color:#bfbfbf;margin:0 4px}.breadcrumb-current{color:#262626;font-weight:500}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.page-title{font-size:20px;font-weight:600;color:#262626}.page-subtitle{font-size:13px;color:#8c8c8c;margin-top:4px}.page-actions{display:flex;gap:8px}.card{background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;overflow:hidden}.card-header{padding:16px 24px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.card-title{font-size:16px;font-weight:600;color:#262626}.card-body{padding:24px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;transition:all .2s;cursor:pointer;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:#1890ff}.kpi-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.kpi-card.success:before{background:#52c41a}.kpi-card.warning:before{background:#faad14}.kpi-card.danger:before{background:#ff4d4f}.kpi-card.info:before{background:#1890ff}.kpi-card.purple:before{background:#722ed1}.kpi-card.cyan:before{background:#13c2c2}.kpi-icon{font-size:24px;margin-bottom:8px}.kpi-title{font-size:13px;color:#8c8c8c;margin-bottom:8px}.kpi-value{font-size:28px;font-weight:600;color:#262626;margin-bottom:8px;line-height:1.2}.kpi-value.success{color:#52c41a}.kpi-value.warning{color:#faad14}.kpi-value.danger{color:#ff4d4f}.kpi-value.info{color:#1890ff}.kpi-detail{font-size:12px;color:#8c8c8c}.kpi-trend{display:inline-block;font-size:12px;padding:2px 6px;border-radius:4px;margin-left:6px}.kpi-trend.up{background:#f6ffed;color:#52c41a}.kpi-trend.down{background:#fff1f0;color:#ff4d4f}.btn{padding:6px 16px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;color:#262626;cursor:pointer;font-size:14px;font-weight:400;transition:all .2s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn:hover{border-color:#40a9ff;color:#40a9ff}.btn-primary{background:#1890ff;border-color:#1890ff;color:#fff}.btn-primary:hover{background:#40a9ff;border-color:#40a9ff;color:#fff}.btn-danger{background:#ff4d4f;border-color:#ff4d4f;color:#fff}.btn-danger:hover{background:#ff7875;border-color:#ff7875;color:#fff}.btn-success{background:#52c41a;border-color:#52c41a;color:#fff}.btn-success:hover{background:#73d13d;border-color:#73d13d;color:#fff}.btn-warning{background:#faad14;border-color:#faad14;color:#fff}.btn-warning:hover{background:#ffc53d;border-color:#ffc53d;color:#fff}.btn-sm{padding:4px 12px;font-size:13px}.btn-lg{padding:10px 24px;font-size:16px}.search-bar{background:#fff;border-radius:8px;padding:16px 24px;margin-bottom:16px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.search-input{padding:6px 12px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;width:200px;transition:all .2s}.search-input:focus{outline:none;border-color:#40a9ff;box-shadow:0 0 0 2px #1890ff1a}.search-select{padding:6px 12px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s}.search-select:focus{outline:none;border-color:#40a9ff}.search-bar-label{font-size:13px;color:#595959;margin-right:4px}.data-table-wrapper{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background:#fafafa}.data-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:13px;color:#595959;border-bottom:1px solid #f0f0f0;white-space:nowrap}.data-table td{padding:14px 16px;border-bottom:1px solid #f5f5f5;color:#262626}.data-table tbody tr:hover{background:#fafafa}.data-table tbody tr:last-child td{border-bottom:none}.table-footer{padding:16px 24px;display:flex;justify-content:space-between;align-items:center;background:#fafafa;border-top:1px solid #f0f0f0;font-size:13px;color:#8c8c8c}.status-tag{display:inline-block;padding:2px 10px;border-radius:4px;font-size:12px;font-weight:500;line-height:20px;border:1px solid}.status-success{background:#f6ffed;color:#52c41a;border-color:#b7eb8f}.status-info{background:#e6f7ff;color:#1890ff;border-color:#91d5ff}.status-warning{background:#fffbe6;color:#faad14;border-color:#ffe58f}.status-error{background:#fff1f0;color:#ff4d4f;border-color:#ffa39e}.status-default{background:#fafafa;color:#8c8c8c;border-color:#d9d9d9}.row-actions{display:flex;gap:6px;flex-wrap:wrap}.row-action-btn{padding:4px 10px;font-size:12px;background:transparent;color:#1890ff;border:1px solid #91d5ff;border-radius:4px;cursor:pointer;transition:all .2s}.row-action-btn:hover{background:#1890ff;color:#fff;border-color:#1890ff}.row-action-btn.danger{color:#ff4d4f;border-color:#ffa39e}.row-action-btn.danger:hover{background:#ff4d4f;border-color:#ff4d4f;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background-color:#fff;border-radius:8px;width:520px;max-width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 6px 16px #00000014,0 3px 6px #0000001f;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:16px 24px;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.modal-title{margin:0;font-size:16px;font-weight:600;color:#262626}.modal-close{background:none;border:none;font-size:20px;color:#8c8c8c;cursor:pointer;padding:0 8px;line-height:1;transition:color .2s}.modal-close:hover{color:#262626}.modal-body{padding:24px}.modal-footer{padding:12px 24px;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end;gap:8px;background:#fafafa;border-radius:0 0 8px 8px}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-label{display:block;margin-bottom:6px;font-weight:500;font-size:13px;color:#262626}.form-label.required:before{content:"*";color:#ff4d4f;margin-right:4px}.form-input,.form-textarea,.form-select{width:100%;padding:8px 12px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s;background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#40a9ff;box-shadow:0 0 0 2px #1890ff1a}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.state-container{text-align:center;padding:60px 20px;color:#8c8c8c}.state-icon{font-size:48px;margin-bottom:16px}.state-text{font-size:14px;color:#8c8c8c;margin-bottom:16px}.loading-spinner{display:inline-block;width:32px;height:32px;border:3px solid #f0f0f0;border-top-color:#1890ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#fff1f0;border:1px solid #ffa39e;border-radius:6px;padding:12px 16px;color:#ff4d4f;font-size:14px;margin-bottom:16px}.list-item-card{background:#fff;border-radius:8px;padding:20px;margin-bottom:12px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;transition:all .2s}.list-item-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#e0e0e0}.list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.list-item-title{font-size:16px;font-weight:600;color:#262626}.list-item-meta{font-size:13px;color:#8c8c8c;margin-bottom:8px}.list-item-description{font-size:14px;color:#595959;line-height:1.6}.chart-container{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;margin-bottom:24px}.chart-title{font-size:16px;font-weight:600;margin-bottom:20px;color:#262626}.gantt-container{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;overflow-x:auto}.gantt-row{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid #f5f5f5}.gantt-row:last-child{border-bottom:none}.gantt-label{width:200px;font-size:13px;color:#262626;flex-shrink:0}.gantt-bar-area{flex:1;height:28px;background:#fafafa;border-radius:4px;position:relative;min-width:400px}.gantt-bar{position:absolute;height:24px;top:2px;border-radius:4px;display:flex;align-items:center;padding:0 8px;font-size:12px;color:#fff;font-weight:500;overflow:hidden;transition:all .2s}.gantt-bar:hover{filter:brightness(1.1)}.gantt-progress{position:absolute;left:0;top:0;bottom:0;background:#ffffff4d;border-radius:4px 0 0 4px}.radar-container{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 4px #0000000f;border:1px solid #f0f0f0;text-align:center}.progress-bar{width:100%;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.progress-fill.success{background:#52c41a}.progress-fill.warning{background:#faad14}.progress-fill.danger{background:#ff4d4f}.progress-fill.info{background:#1890ff}.sub-tabs{display:flex;gap:0;border-bottom:1px solid #f0f0f0;margin-bottom:20px}.sub-tab{padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;color:#595959;font-size:14px;cursor:pointer;transition:all .2s}.sub-tab:hover{color:#1890ff}.sub-tab.active{color:#1890ff;border-bottom-color:#1890ff;font-weight:500}.flex-row{display:flex;align-items:center;gap:8px}.flex-between{display:flex;justify-content:space-between;align-items:center}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.text-success{color:#52c41a}.text-warning{color:#faad14}.text-danger{color:#ff4d4f}.text-info{color:#1890ff}.text-muted{color:#8c8c8c}.text-sm{font-size:13px}.text-lg{font-size:18px}.text-xl{font-size:24px}.text-bold{font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#fafafa}::-webkit-scrollbar-thumb{background:#d9d9d9;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#bfbfbf}@media (max-width: 768px){.sidebar{width:60px}.sidebar-item-label,.sidebar-group-title,.sidebar-item-count{display:none}.kpi-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.app-header-search{display:none}}
