*{box-sizing:border-box}body{margin:0;background:#f3f4f6;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,Arial,sans-serif;font-size:14px}button,input,select,textarea{font-family:inherit}a{color:#1677ff;cursor:pointer;text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:188px;flex:0 0 188px;background:#f8f9fb;border-right:1px solid #e5e7eb;padding:22px 18px;position:fixed;inset:0 auto 0 0;overflow:auto}.brand{display:flex;align-items:center;justify-content:center;min-height:82px;margin:-2px -4px 22px;padding:8px 0 14px;border-bottom:1px solid #e6edf7}.brand-image{display:block;width:154px;max-width:100%;height:auto;object-fit:contain}.nav{display:flex;flex-direction:column;gap:5px}.nav button{width:100%;border:0;background:transparent;color:#222;min-height:34px;border-radius:6px;display:flex;align-items:center;gap:8px;padding:0 12px;text-align:left;cursor:pointer;font-size:13px}.nav button:hover{background:#edf4ff}.nav button.active{background:#1677ff;color:#fff}.nav-group{margin:20px 0 8px;padding-left:7px;color:#6b7280;font-size:12px}.nav-dot{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.4}.main{width:calc(100% - 188px);min-height:100vh;margin-left:188px;min-width:0}.topbar{height:44px;background:#f3f4f6;display:flex;justify-content:space-between;align-items:center;padding:0 28px}.topbar-user{display:flex;align-items:center;gap:9px;font-size:12px;color:#111827}.topbar-user select{height:26px;border:1px solid #d9dfe8;border-radius:4px;background:#fff;color:#374151;padding:0 8px;font-size:12px}.page{padding:14px 16px 28px}.page-title-row{display:flex;align-items:center;justify-content:space-between;margin:0 0 14px}h1{margin:0;font-size:24px;line-height:1.2;color:#111827}.card{background:#fff;border-radius:6px;padding:16px;border:1px solid #edf0f4;margin-bottom:16px;min-width:0}.card-title{margin:0 0 14px;font-size:15px;color:#111827}.dashboard-filters,.range-inline,.toolbar,.actions{display:flex;align-items:center;gap:8px}.dashboard-filters{min-width:460px}.toolbar{margin:12px 0;flex-wrap:wrap}.btn{height:32px;border:1px solid #d9dfe8;border-radius:5px;padding:0 12px;background:#fff;color:#1f2937;display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;white-space:nowrap}.btn.primary{border-color:#1677ff;background:#1677ff;color:#fff}.btn.danger{border-color:#ef4444;background:#fff5f5;color:#dc2626}.btn.ghost{border-color:transparent;background:transparent}.btn:disabled,.icon-btn:disabled{cursor:not-allowed;opacity:.45}.control{width:100%;height:34px;border:1px solid #d9dfe8;border-radius:5px;background:#fff;padding:0 10px;color:#1f2937;font-size:13px;min-width:0}select.control[multiple]{height:88px;padding:6px 8px}.textarea{height:80px;padding:8px 10px;resize:vertical;line-height:1.5}.field{display:grid;grid-template-columns:76px minmax(0,1fr);align-items:center;gap:8px;min-width:0}.field>span{color:#374151;font-size:13px;white-space:nowrap}.field b{color:#ef4444;margin-right:3px}.filter-grid,.form-grid{display:grid;gap:12px 16px}.filter-grid.three{grid-template-columns:repeat(3,minmax(220px,1fr))}.filter-grid.four{grid-template-columns:repeat(4,minmax(220px,1fr))}.filter-grid.five{grid-template-columns:repeat(5,minmax(190px,1fr))}.filter-grid.six{grid-template-columns:repeat(6,minmax(180px,1fr))}.form-grid.one{grid-template-columns:1fr}.form-grid.two{grid-template-columns:repeat(2,minmax(260px,1fr))}.form-grid.three{grid-template-columns:repeat(3,minmax(210px,1fr))}.form-grid.four{grid-template-columns:repeat(4,minmax(190px,1fr))}.form-grid.narrow{max-width:520px}.table-wrap{width:100%;overflow:auto;min-width:0}.data-table{width:100%;min-width:900px;border-collapse:collapse;table-layout:auto}.data-table.compact{min-width:0}.dashboard-grid .data-table{min-width:680px}.data-table th{background:#fafafa;color:#111827;font-weight:600;text-align:left;padding:12px 10px;border-bottom:1px solid #edf0f4;white-space:nowrap;font-size:13px}.data-table td{padding:11px 10px;border-bottom:1px solid #edf0f4;color:#1f2937;vertical-align:middle;font-size:13px}.empty-cell{text-align:center;color:#94a3b8;padding:40px 0!important}.pagination{display:flex;justify-content:flex-end;align-items:center;gap:8px;color:#6b7280;padding-top:12px;font-size:12px}.icon-btn{width:28px;height:28px;border:1px solid #d9dfe8;border-radius:5px;background:#fff;display:inline-grid;place-items:center;cursor:pointer;color:#374151}.page-pill{min-width:24px;height:24px;border:1px solid #1677ff;color:#1677ff;border-radius:50%;display:grid;place-items:center}.dots-btn,.link-btn{border:0;background:transparent;color:#1677ff;cursor:pointer;display:inline-flex;align-items:center;padding:0;font-size:13px}.link-btn:disabled{cursor:not-allowed;opacity:.45}.muted{color:#94a3b8}.row-actions{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.tag{display:inline-flex;align-items:center;min-height:22px;padding:0 7px;border-radius:4px;background:#eef6ff;color:#1677ff;font-size:12px}.tag.danger{background:#fff1f2;color:#dc2626}.tag.warning{background:#fffbeb;color:#d97706}.tag.success{background:#ecfdf5;color:#059669}.summary-line{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:#374151;padding:10px 0 0}.summary-line b{color:#16a34a}.overlay,.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0000006b}.drawer{position:fixed;inset:0 0 0 auto;width:min(760px,calc(100vw - 220px));background:#fff;box-shadow:-12px 0 28px #0f172a29;display:flex;flex-direction:column}.drawer.wide{width:min(980px,calc(100vw - 220px))}.drawer-header,.modal-header{min-height:56px;display:flex;align-items:center;gap:12px;padding:0 18px;border-bottom:1px solid #edf0f4}.drawer-header h2,.modal-header h2{margin:0;font-size:16px;flex:1}.drawer-actions{display:flex;gap:8px}.drawer-body{padding:22px 28px 36px;overflow:auto}.form-section{margin-bottom:24px}.form-section h3{margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid #edf0f4;font-size:15px}.info-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:13px 18px}.info-item{display:grid;grid-template-columns:100px minmax(0,1fr);gap:8px;line-height:1.6}.info-item span{color:#6b7280}.info-item strong{font-weight:500;color:#111827;word-break:break-word}.modal{width:min(540px,calc(100vw - 36px));background:#fff;border-radius:7px;box-shadow:0 24px 80px #0f172a38;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);overflow:hidden}.modal-body{padding:22px}.modal-footer{padding:14px 18px;border-top:1px solid #edf0f4;display:flex;justify-content:flex-end;gap:8px}.import-box{border:1px dashed #b6c2d2;border-radius:6px;padding:24px;display:grid;gap:12px;place-items:center;text-align:center;color:#4b5563}.upload-control{height:38px;min-width:180px;border:1px solid #d9dfe8;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;background:#fff}.upload-control input{display:none}.success-text{color:#16a34a;margin:0}.error-text{color:#dc2626;margin:0}.stats-strip{display:grid;grid-template-columns:repeat(6,1fr);padding:24px 12px}.stat{text-align:center}.stat strong{display:block;font-size:30px;color:#3f3f46;line-height:1.1}.stat span{display:block;margin-top:8px;color:#111827}.dashboard-grid{display:grid;gap:16px;min-width:0}.dashboard-grid>.card{min-width:0}.dashboard-grid.top{grid-template-columns:2fr 1fr}.dashboard-grid.charts{grid-template-columns:repeat(3,1fr)}.bar-chart{min-height:265px;display:flex;align-items:center}.bars{height:240px;width:100%;display:flex;align-items:flex-end;justify-content:space-around;gap:12px;border-bottom:1px solid #dfe5ef;background:linear-gradient(to top,transparent 0 24%,#eef2f7 24% 24.5%,transparent 24.5% 49%,#eef2f7 49% 49.5%,transparent 49.5% 74%,#eef2f7 74% 74.5%,transparent 74.5%);padding:10px 10px 0}.bar-item{height:100%;flex:1;min-width:34px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:6px}.bar-track{height:172px;width:44px;display:flex;align-items:flex-end}.bar-track span{width:100%;border-radius:3px 3px 0 0}.bar-item strong{font-size:12px}.bar-item small{color:#6b7280;white-space:nowrap;font-size:11px}.pie-layout{min-height:250px;display:flex;align-items:center;justify-content:center;gap:28px}.pie{width:160px;height:160px;border-radius:50%;display:grid;place-items:center;position:relative;flex:0 0 auto}.pie:after{content:"";width:82px;height:82px;border-radius:50%;background:#fff;position:absolute}.pie span{position:relative;z-index:1;font-size:18px;font-weight:700}.legend{display:grid;gap:6px;min-width:150px}.legend div{display:grid;grid-template-columns:10px minmax(0,1fr) auto;align-items:center;gap:8px;font-size:12px;color:#4b5563}.legend i{width:10px;height:10px;border-radius:2px}.legend span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid #edf0f4}.tabs button{border:0;background:transparent;padding:10px 16px;cursor:pointer;color:#4b5563;border-bottom:2px solid transparent}.tabs button.active{color:#1677ff;border-bottom-color:#1677ff}.summary-cards{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;padding-top:12px}.summary-cards div{background:#f8fbff;border:1px solid #e6efff;border-radius:6px;padding:14px;display:flex;flex-direction:column;gap:6px}.summary-cards strong{color:#1677ff}.assessment-form .field{grid-template-columns:90px minmax(0,1fr)}.assessment-select-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.8fr);gap:18px}.section-subhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;color:#374151}.section-subhead span{display:inline-flex;gap:12px;color:#6b7280;font-size:12px}.checkbox-panel{min-height:176px;max-height:224px;overflow:auto;border:1px solid #edf0f4;border-radius:6px;padding:10px;display:grid;grid-template-columns:repeat(4,minmax(100px,1fr));gap:8px 12px;background:#fbfcfe}.checkbox-panel label{display:inline-flex;align-items:center;gap:7px;min-width:0}.product-panel{min-height:86px;grid-template-columns:repeat(3,1fr)}.manual-ratio-grid{margin-top:14px;display:grid;gap:10px}.notice{border-radius:6px;padding:10px 12px;margin:10px 0 18px;font-size:13px}.notice.success{color:#047857;background:#ecfdf5;border:1px solid #bbf7d0}.notice.warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.notice.info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.dispatch-status-panel{display:grid;gap:8px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;padding:12px;margin:0 0 14px;font-size:13px}.dispatch-status-panel>div{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dispatch-status-panel p{margin:0;color:#4b5563}.dispatch-confirm-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:16px}.dispatch-confirm-summary>div{border:1px solid #e5e7eb;border-radius:6px;padding:10px;display:grid;gap:6px}.dispatch-confirm-summary span{color:#1677ff;font-weight:600}.dispatch-product-list,.dispatch-recipient-list{display:flex;gap:8px;flex-wrap:wrap}.confirm-row{display:flex;align-items:flex-start;gap:8px;color:#374151;font-size:13px}.switch-row{display:inline-flex;align-items:center;gap:7px;min-height:34px;color:#374151}.assessment-cards{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:12px;margin:16px 0 22px}.task-cards{grid-template-columns:repeat(5,minmax(140px,1fr))}.task-cards-six{grid-template-columns:repeat(6,minmax(120px,1fr))}.workbench-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:14px}.workbench-header h1,.workbench-hero h2{margin:3px 0 8px;font-size:22px;color:#111827}.workbench-header p,.workbench-hero p{margin:0;color:#4b5563}.eyebrow{margin:0;font-size:12px;color:#1677ff;font-weight:600}.workbench-viewer{min-width:240px;display:grid;gap:8px;justify-items:end}.workbench-viewer .field{width:100%}.workbench-notification-panel{border:1px solid #fde68a;background:#fffbeb;border-radius:6px;padding:12px;margin:10px 0 16px}.workbench-notification-head,.workbench-notification-item{display:flex;align-items:center;justify-content:space-between;gap:14px}.workbench-notification-head{margin-bottom:10px}.workbench-notification-list{display:grid;gap:10px}.workbench-notification-item{background:#fff;border:1px solid #fde68a;border-radius:6px;padding:10px}.workbench-notification-item p{margin:7px 0 4px;color:#4b5563}.workbench-notification-meta{color:#6b7280;font-size:12px}.workbench-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;background:#f8fbff;border:1px solid #e6efff;border-radius:6px;padding:16px;margin-bottom:14px}.workbench-cards{grid-template-columns:repeat(6,minmax(120px,1fr))}.product-progress-grid{display:grid;grid-template-columns:repeat(3,minmax(160px,1fr));gap:12px}.product-progress{border:1px solid #e5e7eb;border-radius:6px;padding:12px;background:#fff}.product-progress>div:first-child{display:flex;justify-content:space-between;gap:12px}.product-progress strong{color:#111827}.product-progress span{color:#1677ff;font-weight:600}.product-progress p{margin:8px 0 0;color:#6b7280;font-size:12px}.progress-bar{height:7px;background:#eef2f7;border-radius:999px;overflow:hidden;margin-top:10px}.progress-bar i{display:block;height:100%;background:#1677ff}.workbench-todo-list{display:grid;gap:10px}.workbench-todo-item{display:flex;justify-content:space-between;gap:14px;align-items:center;border:1px solid #e5e7eb;border-radius:6px;padding:12px;background:#fff}.todo-title-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.workbench-todo-item p{margin:8px 0 4px;color:#4b5563}.workbench-todo-item span{color:#6b7280;font-size:12px}.agent-placeholder{background:#f9fafb;border:1px dashed #cbd5e1;border-radius:6px;padding:14px}.agent-placeholder p{margin:0 0 12px;color:#4b5563}.agent-actions{display:flex;flex-wrap:wrap;gap:8px}.agent-actions button{border:1px solid #d1d5db;background:#f3f4f6;color:#6b7280;border-radius:6px;padding:8px 10px}.metric-card{background:#f8fbff;border:1px solid #e6efff;border-radius:6px;padding:16px 12px;text-align:center}.metric-card strong{display:block;font-size:24px;color:#111827;line-height:1.2;margin-bottom:7px}.metric-card span{color:#4b5563;font-size:12px}.metric-card.green strong{color:#059669}.metric-card.yellow strong{color:#d97706}.metric-card.red strong{color:#dc2626}.metric-card.blue strong{color:#1677ff}.metric-grid{display:grid;gap:12px;margin:16px 0 22px}.metric-grid.seven{grid-template-columns:repeat(7,minmax(110px,1fr))}.knowledge-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:14px;margin-top:14px}.category-cloud{display:flex;flex-wrap:wrap;gap:8px}.article-body{margin-top:12px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#374151;line-height:1.7}.article-body p{margin:0 0 8px}.compact-list{margin:0;padding-left:18px;color:#4b5563;line-height:1.7}.related-knowledge-list{display:grid;gap:10px}.related-knowledge-list.compact{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.related-knowledge-item{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:12px;border:1px solid var(--border);border-radius:8px;background:#fff}.related-knowledge-item p{margin:5px 0 8px;color:var(--muted);line-height:1.5}.suggested-materials{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px}.suggested-materials.compact{margin-top:0}.knowledge-link{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid #bdd7ff;border-radius:999px;padding:3px 9px;background:#f5f9ff;color:var(--primary);font-size:12px;cursor:pointer}.agent-actions.disabled button{cursor:not-allowed;opacity:.78}.risk-tag{display:inline-flex;align-items:center;min-height:22px;border-radius:4px;padding:0 8px;font-size:12px}.risk-tag.green{background:#ecfdf5;color:#059669}.risk-tag.yellow{background:#fffbeb;color:#d97706}.risk-tag.red{background:#fff1f2;color:#dc2626}.risk-tag.unknown{background:#f3f4f6;color:#6b7280}.placeholder-panel{min-height:320px;display:grid;align-content:center;gap:12px}.placeholder-text{color:#6b7280}.settings-row{display:flex;align-items:center;gap:18px;margin-bottom:18px}.switch{position:relative;display:inline-flex;width:46px;height:24px}.switch input{display:none}.switch i{width:46px;height:24px;background:#cbd5e1;border-radius:999px;position:relative;transition:.2s}.switch i:after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;top:2px;left:2px;background:#fff;transition:.2s}.switch input:checked+i{background:#1677ff}.switch input:checked+i:after{transform:translate(22px)}.permission-layout,.dept-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px}.role-list{padding:0;overflow:hidden}.role-list button{width:100%;border:0;background:#fff;border-bottom:1px solid #edf0f4;padding:16px 18px;text-align:left;display:grid;gap:6px;cursor:pointer}.role-list button.active{background:#f5f9ff}.role-list span{color:#6b7280;font-size:12px}.role-list .add-role{color:#1677ff;font-weight:600}.permission-head{display:flex;align-items:center;gap:8px;margin-bottom:16px}.permission-head .btn{margin-left:10px}.warn-dot{width:12px;height:12px;border-radius:50%;background:#f59e0b}.permission-groups{display:grid;gap:18px}.permission-groups section{border:1px solid #edf0f4;border-radius:6px;padding:14px 16px}.permission-groups h3{margin:0 0 12px;font-size:14px}.permission-checks{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:9px 28px}.permission-checks label{display:inline-flex;align-items:center;gap:7px;color:#1f2937}.dept-tree{min-height:620px}.tree{margin-top:14px;display:grid;gap:4px}.tree button{border:0;background:#fff;min-height:34px;border-radius:5px;display:flex;align-items:center;gap:7px;cursor:pointer;color:#374151;text-align:left}.tree button.active{background:#edf4ff;color:#1677ff}.profile-layout{display:grid;gap:16px}.profile-score-row,.tag-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.profile-score-row strong{display:block;margin-top:6px;color:#1677ff;font-size:30px}.profile-summary{margin:10px 0 0;color:#1f2937;line-height:1.7}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag-list.compact{max-width:220px}.tag.large{font-size:13px;padding:4px 9px}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700}.status-pill.green{background:#ecfdf3;color:#15803d}.status-pill.yellow{background:#fffbeb;color:#b45309}.status-pill.red{background:#fef2f2;color:#dc2626}.status-pill.blue{background:#eff6ff;color:#1d4ed8}.insight-box,.compliance-note,.subtable-panel{border:1px solid #e5e7eb;border-radius:8px;background:#f8fafc;padding:12px;margin:10px 0}.compliance-note{color:#4b5563;font-size:13px}.inline-remove{border:0;background:transparent;color:inherit;cursor:pointer;font-size:14px;margin-left:5px;padding:0}.timeline{display:grid;gap:12px}.timeline .timeline-item{grid-template-columns:16px 1fr;align-items:start;padding-bottom:12px}.timeline-dot{width:8px;height:8px;border-radius:999px;background:#2f6fed;margin-top:6px}.compact-tabs{overflow-x:auto;white-space:nowrap}.tag-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:14px;margin-top:14px}.timeline-list{display:grid;gap:14px}.timeline-item{display:grid;grid-template-columns:170px 1fr;gap:14px;border-bottom:1px solid #edf0f4;padding-bottom:14px}.timeline-time,.muted{color:#6b7280;font-size:12px}.timeline-title{color:#111827;font-weight:700}.warning-text{margin:8px 0;color:#b45309;line-height:1.6}.error-text{margin:8px 0;color:#dc2626}.strategy-list{margin:0;padding-left:22px;color:#1f2937;line-height:1.8}.strategy-list li{margin:4px 0}.strategy-list.forbidden li{color:#991b1b}.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.link-btn.danger{color:#dc2626}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}@media (max-width: 1180px){.filter-grid.three,.filter-grid.four,.filter-grid.five,.filter-grid.six,.form-grid.four,.form-grid.three{grid-template-columns:repeat(2,minmax(220px,1fr))}.dashboard-grid.top,.dashboard-grid.charts,.permission-layout,.dept-layout,.assessment-select-grid{grid-template-columns:1fr}.assessment-cards{grid-template-columns:repeat(3,1fr)}.workbench-cards,.product-progress-grid,.tag-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.workbench-header,.workbench-hero,.workbench-todo-item,.workbench-notification-item{align-items:stretch;flex-direction:column}.workbench-viewer{justify-items:stretch;width:100%}.dispatch-confirm-summary{grid-template-columns:1fr}.stats-strip{grid-template-columns:repeat(3,1fr);gap:18px}}@media (max-width: 760px){.sidebar{position:static;width:100%;flex-basis:auto;max-height:320px;overflow:auto;border-bottom:1px solid #e5e7eb}.app-shell{display:block}.main{width:100%;margin-left:0}.filter-grid.four,.filter-grid.three,.filter-grid.five,.filter-grid.six,.form-grid.two,.form-grid.three,.form-grid.four,.summary-cards,.stats-strip,.assessment-cards,.workbench-cards,.product-progress-grid,.tag-grid,.checkbox-panel,.timeline-item{grid-template-columns:1fr}.field{grid-template-columns:1fr;gap:5px}.drawer,.drawer.wide{width:100vw}.dashboard-filters{min-width:0;width:100%;flex-wrap:wrap}.page-title-row{align-items:flex-start;flex-direction:column;gap:12px}}
