:root{font-family:Microsoft YaHei,PingFang SC,Noto Sans CJK SC,sans-serif;color:#606266;background:#f2f6fb;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:1180px;background:#f2f6fb;font-size:14px}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:flex;min-height:100vh}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;width:238px;height:100vh;color:#b9c5d4;background:#304156;transition:width .2s ease}.sidebar.collapsed{width:78px}.brand{display:flex;align-items:center;gap:10px;height:54px;padding:0 14px;color:#fff;background:#263445}.brand-mark{display:grid;width:30px;height:30px;place-items:center;border:1px solid rgba(64,158,255,.72);border-radius:4px;color:#409eff;font-weight:800}.brand-text{display:flex;flex-direction:column;gap:2px;white-space:nowrap}.brand-text span{color:#9fb0c4;font-size:12px}.collapsed .brand-text,.collapsed .menu-parent strong,.collapsed .menu-child{display:none}.menu-scroll{flex:1;overflow:auto;padding:8px 0 14px;scrollbar-width:thin;scrollbar-color:rgba(160,175,195,.35) transparent}.menu-scroll::-webkit-scrollbar{width:6px}.menu-scroll::-webkit-scrollbar-thumb{border-radius:999px;background:#a0afc357}.menu-parent,.menu-child{width:100%;border:0;background:transparent;text-align:left}.menu-parent{display:flex;align-items:center;gap:10px;min-height:46px;padding:0 14px;color:#b9c5d4;font-size:15px}.menu-parent.single.active,.menu-child.active{color:#409eff;background:#263445;box-shadow:inset 3px 0 #409eff}.menu-child{height:42px;padding:0 18px 0 42px;color:#b9c5d4;font-size:14px}.menu-child:hover,.menu-parent.single:hover{color:#fff;background:#263445}.collapse-btn{height:40px;border:0;border-top:1px solid rgba(255,255,255,.08);color:#b9c5d4;background:#263445}.main{flex:1;min-width:0}.topbar{display:flex;align-items:center;justify-content:flex-end;min-height:42px;padding:6px 20px;color:#606266;background:#fff;border-bottom:1px solid #dfe6ec;box-shadow:0 1px 4px #00152914}.top-actions{display:flex;align-items:center;gap:8px}.icon-btn,.role-chip,.logout-btn{position:relative;height:30px;border:1px solid #dcdfe6;border-radius:3px;color:#606266;background:#fff}.icon-btn{width:32px;border:0;font-size:17px}.icon-btn i{position:absolute;top:0;right:0;display:grid;width:16px;height:16px;place-items:center;border-radius:50%;color:#fff;background:#f56c6c;font-size:11px;font-style:normal}.role-chip,.logout-btn{padding:0 12px}.tabs{display:flex;gap:4px;height:42px;padding:7px 12px 0;border-bottom:1px solid #dfe6ec;background:#fff}.tabs button{min-width:110px;height:35px;padding:0 12px;border:1px solid #dfe6ec;border-bottom:0;border-radius:3px 3px 0 0;color:#606266;background:#fff}.tabs button.active{color:#fff;background:#409eff;border-color:#409eff}.tabs span{margin-left:8px}.dashboard,.content{padding:14px}.overview-strip,.panel,.filter-panel,.toolbar,.table-wrap{border:1px solid #dfe6ec;border-radius:3px;background:#fff}.overview-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px;padding:14px}.overview-strip button{display:grid;gap:6px;min-height:84px;border:0;border-radius:4px;background:#f8fafc;text-align:left}.overview-strip strong,.panel h2{color:#303133}.overview-strip span{color:#409eff;font-size:24px;font-weight:800}.overview-strip small,.stat-card small{color:#909399}.panel{margin-bottom:14px;padding:16px}.panel h2{margin:0 0 14px;padding-left:10px;border-left:3px solid #409eff;font-size:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{display:grid;gap:8px;min-height:118px;padding:14px;border:0;border-radius:4px;background:#f7f9fc;text-align:left}.stat-card strong{color:#409eff;font-size:28px}.stat-card.danger strong{color:#f56c6c}.stat-card.warning strong{color:#e6a23c}.stat-card.success strong{color:#67c23a}.flow-line{display:flex;flex-wrap:wrap;gap:8px}.flow-line span{position:relative;padding:8px 12px;border-radius:3px;color:#409eff;background:#ecf5ff;font-weight:600}.flow-line.compact span{font-size:12px}.dashboard-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}.chart-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;height:230px;align-items:end}.bar-item{display:grid;justify-items:center;gap:6px;color:#909399}.bar-item i{width:34px;min-height:28px;border-radius:4px 4px 0 0;background:linear-gradient(180deg,#409eff,#67c23a)}.bar-item strong{color:#303133}.todo-list{display:grid;gap:10px}.todo-list button{display:flex;justify-content:space-between;min-height:48px;padding:12px;border:1px solid #ebeef5;border-radius:3px;background:#fff;text-align:left}.todo-list span{color:#909399}.filter-panel{display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));gap:16px 20px;margin-bottom:12px;padding:18px 22px}.filter-panel label,.form-grid label{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:10px}.filter-panel label>span,.form-grid label>span{color:#606266;font-weight:600}.filter-panel .wide{grid-column:span 2}input,select,textarea,.readonly-field{width:100%;min-height:38px;border:1px solid #dcdfe6;border-radius:3px;color:#606266;background:#fff;padding:0 12px}input[type=checkbox],input[type=radio]{width:14px;height:14px;min-height:0;margin:0;padding:0;border-radius:2px;accent-color:#409eff}textarea{min-height:96px;padding:10px 12px;resize:vertical}.readonly-field{display:flex;align-items:center;background:#f5f7fa}.range-control,.suffix-control,.choice-row{display:flex;align-items:center;gap:8px}.range-control input{min-width:0}.range-control em{color:#909399;font-style:normal}.choice-row label{display:inline-flex;grid-template-columns:auto auto;width:auto;gap:6px}.suffix-control b{color:#606266;white-space:nowrap}.filter-actions{display:flex;gap:10px}.toolbar{display:flex;gap:10px;margin-bottom:12px;padding:12px 16px}.form-grid footer button.primary,.toolbar button.primary,.filter-actions .primary{border-color:#409eff;color:#fff;background:#409eff}.toolbar button,.filter-actions button,.pagination button,.pagination select,.form-grid footer button{min-height:36px;padding:0 14px;border:1px solid #dcdfe6;border-radius:3px;color:#606266;background:#fff}.table-wrap{overflow:auto}table{width:100%;min-width:1120px;border-collapse:collapse}th,td{height:52px;padding:0 14px;border:1px solid #ebeef5;text-align:left;white-space:nowrap}th{color:#606266;background:#f5f7fa;font-weight:700}.cell-text.is-success,.cell-text.is-warning,.cell-text.is-danger{display:inline-flex;min-height:24px;align-items:center;padding:0 8px;border-radius:3px}.cell-text.is-success{color:#67c23a;background:#f0f9eb}.cell-text.is-warning{color:#e6a23c;background:#fdf6ec}.cell-text.is-danger{color:#f56c6c;background:#fef0f0}.action-col{min-width:170px}.actions{display:flex;align-items:center;gap:10px}.actions button{border:0;color:#409eff;background:transparent;padding:0}.actions button:first-child{color:#67c23a}.pagination{display:flex;justify-content:flex-end;align-items:center;flex-wrap:nowrap;gap:8px;width:100%;padding:16px 16px 0 0;white-space:nowrap}.pagination span{white-space:nowrap}.pagination button{min-width:36px;padding:0 10px}.pagination select{width:92px;min-width:92px;padding:0 8px}.pagination .active{border-color:#409eff;color:#fff;background:#409eff}.overlay{position:fixed;inset:0;z-index:40;display:grid;place-items:center;background:#0f172a8c}.modal{width:min(900px,calc(100vw - 48px));max-height:calc(100vh - 80px);overflow:auto;border-radius:4px;background:#fff;box-shadow:0 18px 50px #00152942}.modal header,.drawer header{display:flex;align-items:center;justify-content:space-between;min-height:56px;padding:0 20px;color:#fff;background:#409eff}.modal h3,.drawer h3{margin:0;font-size:18px}.modal header button,.drawer header button{display:grid;width:32px;height:32px;place-items:center;border:1px solid rgba(255,255,255,.8);border-radius:50%;color:#fff;background:transparent;font-size:20px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 20px;padding:22px}.form-grid h4{grid-column:1 / -1;margin:0;padding:0 0 10px;border-bottom:1px solid #ebeef5;color:#303133;font-size:16px}.form-grid i{margin-right:4px;color:#f56c6c;font-style:normal}.form-grid .full,.form-grid footer{grid-column:1 / -1}.form-grid footer{display:flex;justify-content:flex-end;gap:12px;padding-top:8px}.drawer{position:fixed;top:0;right:0;z-index:35;width:min(620px,92vw);height:100vh;background:#fff;box-shadow:-14px 0 40px #10213338}.drawer-body{display:grid;gap:14px;max-height:calc(100vh - 56px);overflow:auto;padding:16px}.detail-list{display:grid;border:1px solid #ebeef5;border-bottom:0}.detail-list div{display:grid;grid-template-columns:128px 1fr;min-height:46px;border-bottom:1px solid #ebeef5;background:#fff}.detail-list span{display:flex;align-items:center;padding:0 14px;color:#606266;background:#f5f7fa;font-weight:600}.detail-list strong{display:flex;align-items:center;padding:0 14px;color:#303133;font-weight:500}.detail-section{padding:14px;border:1px solid #ebeef5;border-radius:3px}.detail-section h4{margin:0 0 12px;color:#303133}.detail-section p{margin:12px 0 0;color:#606266;line-height:1.7}.mini-record-list{display:grid;gap:12px}.mini-record{display:grid;gap:6px;padding:14px;border:1px solid #ebeef5;border-radius:3px;background:#f8f9fb}.mini-record strong{color:#303133}.mini-record span{color:#606266}.mini-table{min-width:0}.mini-table th,.mini-table td{height:42px}.toast{position:fixed;top:74px;left:50%;z-index:60;transform:translate(-50%);min-width:220px;padding:10px 16px;border-radius:4px;color:#fff;background:#304156f5;text-align:center;box-shadow:0 8px 24px #00152938}
