:root{font-family:Inter,Microsoft YaHei,PingFang SC,Arial,sans-serif;color:#191c1e;background:#f4f5f7;font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}body{margin:0;min-width:1180px}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.56}.app{display:flex;min-height:100vh;background:#f4f5f7}.sidebar{position:fixed;inset:0 auto 0 0;width:240px;background:#172b4d;color:#f5f7fb;display:flex;flex-direction:column;padding:24px 16px}.brand{display:flex;gap:12px;align-items:center;margin-bottom:32px}.brand-mark{width:38px;height:38px;display:grid;place-items:center;background:#0052cc;border-radius:6px;font-weight:800}.brand h1{margin:0;font-size:18px;line-height:24px}.brand p{margin:2px 0 0;color:#b9c4d6;font-size:12px}.nav{display:grid;gap:6px}.nav-item{border:0;background:transparent;color:#ccd6e7;display:flex;align-items:center;gap:10px;height:40px;padding:0 12px;border-radius:4px;text-align:left}.nav-item.active{background:#0052cc;color:#fff;font-weight:700}.profile{margin-top:auto;display:flex;gap:10px;align-items:center;padding:12px;background:#ffffff14;border-radius:6px}.avatar{display:grid;place-items:center;border-radius:50%;background:#dbe6ff;color:#003d9b;font-weight:800;flex:none}.avatar.small{width:30px;height:30px}.avatar.large{width:54px;height:54px;font-size:22px}.profile .avatar{width:36px;height:36px}.profile-copy{display:grid;gap:2px;min-width:0}.profile-copy strong{font-size:13px}.profile-copy span{font-size:12px;color:#b9c4d6}.role-switch{margin-top:8px;height:36px;border:1px solid rgba(255,255,255,.18);background:#ffffff1a;color:#f5f7fb;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 12px;border-radius:4px;font-weight:800;font-size:13px}.role-switch:hover{background:#ffffff29}.logout{margin-top:10px;height:38px;border:0;background:transparent;color:#cdd7e8;display:flex;align-items:center;gap:8px;padding:0 12px;border-radius:4px}.logout:hover,.nav-item:hover{background:#ffffff1a}.main{margin-left:240px;width:calc(100% - 240px);min-height:100vh}.api-banner{margin:16px 24px 0;padding:12px 14px;border:1px solid #ffbdad;background:#ffebe6;color:#9a1b1b;border-radius:4px;display:grid;gap:4px;font-size:13px}.api-banner span{color:#6b2b22;word-break:break-word}.notice-banner{margin:16px 24px 0;padding:12px 14px;border-radius:4px;display:grid;gap:4px;font-size:13px}.notice-banner.success{border:1px solid #abf5d1;background:#dcfff1;color:#064}.notice-banner.error{border:1px solid #ffbdad;background:#ffebe6;color:#9a1b1b}.notice-banner span{color:#164b35}.notice-banner.error span{color:#6b2b22}.api-loading{margin:16px 24px 0;padding:10px 14px;border:1px solid #cfe0ff;background:#f4f8ff;color:#003d9b;border-radius:4px;font-weight:700;font-size:13px}.page{padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h2{margin:0;font-size:28px;letter-spacing:0;line-height:36px}.page-header p{margin:4px 0 0;color:#5f6b7a;font-size:14px}.header-actions{display:flex;gap:10px;align-items:center}.btn{height:36px;border-radius:4px;padding:0 14px;border:1px solid #dfe1e6;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:13px}.btn.primary{background:#0052cc;border-color:#0052cc;color:#fff}.btn.secondary{background:#fff;color:#172b4d}.btn.danger{background:#ba1a1a;border-color:#ba1a1a;color:#fff}.metrics{display:grid;gap:16px;margin-bottom:16px}.metrics.four{grid-template-columns:repeat(4,1fr)}.metrics.five{grid-template-columns:repeat(5,1fr)}.metric,.panel{background:#fff;border:1px solid #dfe1e6;border-radius:6px}.metric{padding:16px;min-height:116px;position:relative}.metric-icon{position:absolute;right:16px;top:16px;color:#0052cc}.metric span{color:#5f6b7a;font-size:12px;font-weight:700}.metric strong{display:block;font-size:28px;margin:14px 0 4px}.metric small{color:#1f845a;font-weight:700}.metric.orange .metric-icon,.metric.orange small{color:#a15c00}.metric.purple .metric-icon,.metric.purple small{color:#6e3fc4}.metric.red .metric-icon,.metric.red small{color:#ba1a1a}.content-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(300px,1fr);gap:16px;margin-bottom:16px}.approval-grid{align-items:start}.panel{padding:16px;min-width:0}.panel.wide{min-height:340px}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel h3{margin:0;font-size:16px}table{width:100%;border-collapse:collapse;font-size:13px}th{color:#5f6b7a;background:#f4f5f7;text-align:left;font-size:12px;height:36px;padding:0 12px}td{border-bottom:1px solid #eef0f3;height:52px;padding:0 12px;color:#2f3a4a}tr:hover td{background:#f8fbff}.badge{display:inline-flex;align-items:center;height:24px;border-radius:3px;padding:0 8px;font-weight:800;font-size:12px}.badge.blue{color:#003d9b;background:#dae6ff}.badge.orange{color:#8f4f00;background:#fff1d6}.badge.purple{color:#5d32a8;background:#efe6ff}.badge.green{color:#064;background:#dcfff1}.badge.red{color:#9a1b1b;background:#ffebe6}.badge.gray{color:#44546f;background:#f1f2f4}.link-button{border:0;background:transparent;color:#0052cc;font-weight:800;padding:0}.link-button:disabled{color:#6b778c}.actions{display:flex;gap:8px;align-items:center}.icon-ok,.icon-danger{width:28px;height:28px;border:0;border-radius:4px;display:inline-grid;place-items:center}.icon-ok{color:#1f845a;background:#dcfff1}.icon-danger{color:#ba1a1a;background:#ffebe6}.empty-state{min-height:240px;display:grid;place-items:center;align-content:center;gap:8px;color:#6b778c;text-align:center}.empty-state svg{color:#0052cc}.empty-state strong{color:#172b4d;font-size:16px}.empty-state span{font-size:13px}.activity{width:100%;display:flex;gap:10px;padding:12px 0;border:0;border-bottom:1px solid #eef0f3;background:transparent;text-align:left;color:inherit}.activity:hover{background:#f8fbff}.activity:last-child{border-bottom:0}.activity-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:4px;background:#edf3ff;color:#0052cc;flex:none}.activity strong,.todo strong{display:block;font-size:13px}.activity span,.todo span,.user-cell span{color:#6b778c;font-size:12px;margin-top:3px;display:block}.submit-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;margin-bottom:72px}.side-stack{display:grid;gap:16px;align-content:start}.task-card{border:1px solid #dfe1e6;border-radius:6px;padding:14px;margin-bottom:14px;background:#fbfcfe}.task-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.form-grid label{color:#5f6b7a;font-size:12px;font-weight:800;display:grid;gap:6px}.form-grid .full{grid-column:1 / -1}input,select,textarea{width:100%;border:1px solid #dfe1e6;border-radius:4px;padding:0 10px;background:#fff;color:#172b4d}input,select{height:36px}textarea{min-height:72px;padding-top:10px;resize:vertical}.flow{display:flex;gap:10px;position:relative;padding-bottom:18px}.flow:not(.last):before{content:"";position:absolute;left:6px;top:17px;bottom:0;width:2px;background:#dfe1e6}.flow .dot{width:14px;height:14px;border-radius:50%;background:#0052cc;margin-top:2px;z-index:1}.flow strong{display:block;font-size:13px}.flow span{color:#6b778c;font-size:12px}.time-chip,.note{background:#f4f8ff;color:#003d9b;border:1px solid #cfe0ff;padding:10px;border-radius:4px;font-size:13px;font-weight:700}.bottom-bar{position:fixed;left:240px;right:0;bottom:0;height:64px;background:#fffffff5;border-top:1px solid #dfe1e6;display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:0 24px}.tabs{display:flex;background:#e9edf3;border-radius:4px;padding:3px}.tab{border:0;background:transparent;height:30px;padding:0 14px;border-radius:3px;font-weight:800;color:#5f6b7a}.tab.active{background:#fff;color:#0052cc}.mini-stat{display:flex;justify-content:space-between;align-items:center;height:40px;border-bottom:1px solid #eef0f3}.mini-stat:last-child{border-bottom:0}.mini-stat span{color:#5f6b7a;font-size:13px}.mini-stat strong{color:#172b4d}.user-cell{display:flex;align-items:center;gap:10px}.modal{position:fixed;inset:0 0 0 240px;display:grid;place-items:center;background:#172b4d3d;pointer-events:none}.modal-card{width:560px;background:#fff;border-radius:8px;border:1px solid #dfe1e6;box-shadow:0 18px 40px #091e422e;pointer-events:auto;overflow:hidden}.modal-header,.modal-actions{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eef0f3}.modal-header button{border:0;background:transparent;color:#6b778c}.detail-list{max-height:460px;overflow:auto}.detail-profile{display:flex;align-items:center;gap:14px;padding:16px;background:#f4f5f7}.detail-profile h3{margin:0}.detail-profile p{margin:4px 0 0;color:#6b778c}.detail-block{padding:14px 16px}.detail-block span{color:#6b778c;display:block;font-size:12px;font-weight:800;margin-bottom:6px}.detail-block p{margin:0;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;border-bottom:0;border-top:1px solid #eef0f3}.filters{display:flex;gap:10px;margin-bottom:16px}.filters select{width:148px}.search{width:260px;height:36px;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #dfe1e6;border-radius:4px;padding:0 10px;color:#6b778c}.search input{border:0;padding:0;height:32px}.progress-cell{display:flex;align-items:center;gap:10px}.progress{width:120px;height:8px;background:#edf0f4;border-radius:99px;overflow:hidden}.progress span{display:block;height:100%;background:#0052cc;border-radius:inherit}.todo{display:flex;gap:10px;align-items:flex-start;padding:12px 0;border-bottom:1px solid #eef0f3}.todo:last-child{border-bottom:0}.charts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.chart-bars{height:160px;display:flex;align-items:end;gap:12px;padding:16px 8px 4px}.chart-bars span{flex:1;min-width:18px;background:linear-gradient(180deg,#0052cc,#79a7ff);border-radius:4px 4px 0 0}
