:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:#f5f7fa;min-width:1280px}body.login-page-body{min-width:0}h1,h2,p{margin:0}.workbench-shell{background:linear-gradient(#f3f6fb 0%,#eef2f7 100%);height:100vh;min-height:100vh;overflow:hidden}.workbench-sidebar{color:#dbeafe;background:linear-gradient(#0f172a 0%,#0b1220 100%);border-right:1px solid #162033;flex-direction:column;gap:16px;height:100vh;padding:20px 14px 16px;display:flex;position:sticky;top:0;overflow:hidden;box-shadow:inset -1px 0 #94a3b814}.workbench-sidebar-inner{flex-direction:column;flex:1;min-height:0;display:flex}.brand-block{border-bottom:1px solid #94a3b824;align-items:center;gap:12px;padding:10px 10px 18px;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:10px;place-items:center;width:42px;height:42px;font-weight:700;display:grid}.brand-title{color:#f8fafc;font-size:16px;font-weight:700}.brand-subtitle{color:#9fb0c9;margin-top:4px;font-size:12px}.sidebar-nav-region{flex-direction:column;flex:1;gap:18px;min-height:0;display:flex;overflow:auto}.workbench-sidebar .nav-menu{--el-menu-bg-color:transparent;--el-menu-text-color:#d4deee;--el-menu-hover-bg-color:#3b82f61f;--el-menu-active-color:#f8fbff;--el-menu-item-height:44px;flex-direction:column;flex:1;gap:4px;display:flex;background:0 0!important;border-right:none!important}.workbench-sidebar .nav-menu.el-menu{background:0 0!important}.workbench-sidebar .nav-menu .el-menu-item{color:#d4deee;border-radius:12px;height:44px;margin:0;transition:background-color .18s,color .18s,box-shadow .18s;background:0 0!important;padding:0 10px!important}.workbench-sidebar .nav-menu .el-menu-item:hover{color:#f8fbff;background:#3b82f61f}.workbench-sidebar .nav-menu .el-menu-item.is-active{color:#f8fbff;background:linear-gradient(#60a5fa38,#3b82f62e);box-shadow:inset 3px 0 #60a5fa}.sidebar-footer{color:#91a4c2;border-top:1px solid #94a3b81f;align-items:center;gap:8px;margin-top:auto;padding:12px 10px 0;font-size:13px;display:flex}.sidebar-nav-section{flex-direction:column;gap:4px;display:flex}.sidebar-nav-section__label{color:#91a4c2;letter-spacing:.08em;padding:0 10px;font-size:12px;font-weight:600}.workbench-main-shell{min-width:0;height:100vh;overflow:hidden}.workbench-header{z-index:5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffc7;border-bottom:1px solid #e2e8f0e6;justify-content:space-between;align-items:center;height:72px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 6px 18px #0f172a0a}.header-title{color:#111827;font-size:18px;font-weight:700}.header-subtitle{color:#6b7280;margin-top:4px;font-size:13px}.workbench-main,.workbench-main-scroll{background:linear-gradient(#f3f6fb 0%,#eef2f7 100%);min-height:0;padding:20px;overflow:auto}.nav-link{width:100%;min-height:44px;color:inherit;align-items:center;gap:10px;font-weight:500;text-decoration:none;display:inline-flex}.sidebar-nav-link{border-radius:12px;min-height:44px;padding:0 10px;transition:background-color .18s,color .18s,box-shadow .18s}.sidebar-nav-link:hover{color:#f8fbff;background:#3b82f61f}.sidebar-nav-link.is-active{color:#f8fbff;background:linear-gradient(#60a5fa38,#3b82f62e);box-shadow:inset 3px 0 #60a5fa}.nav-link:focus-visible{outline-offset:2px;border-radius:10px;outline:2px solid #93c5fd}.page-panel{flex-direction:column;gap:18px;display:flex}.page-header-block,.page-summary-block,.filter-block,.action-block,.table-block,.config-group-card,.feedback-strip{background:#fff;border:1px solid #e5e7eb;border-radius:14px}.page-header-block{justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px 16px;display:flex;box-shadow:0 10px 30px #0f172a0a}.page-summary-block{background:#f8fafc;padding:14px 24px}.page-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.summary-chip{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px}.summary-chip__label{color:#6b7280;font-size:12px}.summary-chip__value{color:#111827;margin-top:6px;font-size:16px;font-weight:700}.filter-block,.action-block,.table-block,.config-group-card{padding:18px 20px;box-shadow:0 10px 30px #0f172a0a}.feedback-strip{padding:12px 14px;font-size:13px;line-height:1.6}.config-group-stack{flex-direction:column;gap:18px;display:flex}.config-group-card__header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.config-group-card__body{flex-direction:column;gap:16px;display:flex}.config-group-card__footer{gap:12px;margin-top:16px;display:flex}.feedback-strip--success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.feedback-strip--warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.feedback-strip--danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toolbar-block{background:linear-gradient(#fffffff5,#f8fafceb);border:1px solid #e2e8f0;border-radius:16px;padding:18px 20px;box-shadow:0 8px 24px #0f172a08}.table-block,.placeholder-panel{background:#fffffff0;border:1px solid #e5e7eb;border-radius:16px;padding:18px 20px;box-shadow:0 10px 30px #0f172a0a}.panel-title-row,.action-bar,.pagination-row,.mapping-filter-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.panel-title-row{margin-bottom:18px}.panel-title-row p{color:#64748b;margin-top:6px;font-size:13px;line-height:1.6}.filter-form{flex-wrap:wrap;align-items:flex-end;gap:10px 12px;display:flex}.filter-form .el-form-item{margin-bottom:0}.filter-form .el-input,.filter-form .el-select,.filter-form .el-input-number{min-width:180px}.filter-form .el-button{min-height:34px}.action-bar{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;min-height:48px;margin-top:8px;padding:0 12px;font-size:14px}.list-workbench-summary{color:#0f172a;font-weight:600}.action-hint{color:#6b7280;margin-left:12px}.table-block .el-table{font-size:13px}.table-block .el-table td,.table-block .el-table th{padding:10px 0}.table-block .el-table th{background:#f8fafc}.pagination-row{margin-top:16px}.pagination-row .el-pagination{margin-left:auto}.table-tip{color:#6b7280;font-size:13px}.status-tag{border-radius:999px;font-weight:600}.drawer-stack{flex-direction:column;gap:16px;display:flex}.drawer-section+.drawer-section{margin-top:20px}.drawer-label{color:#6b7280;margin-bottom:8px;font-size:12px}.drawer-value{color:#111827;font-size:14px}.drawer-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.drawer-grid-wide{grid-template-columns:repeat(3,minmax(0,1fr))}.snapshot-block{color:#374151;white-space:pre-wrap;word-break:break-all;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;margin:0;padding:12px;font-size:12px;line-height:1.5;overflow-x:auto}.drawer-form .el-input,.drawer-form .el-select,.drawer-form .el-input-number{width:100%}.recognition-summary-row{flex-wrap:wrap;gap:8px;display:flex}.mapping-filter-row{justify-content:flex-start;margin-bottom:12px}.login-shell{background:linear-gradient(#eff6ff 0%,#f8fafc 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border:1px solid #dbe3ef;border-radius:18px;width:420px;padding:28px;box-shadow:0 20px 40px #0f172a14}.login-card__header{align-items:center;gap:14px;margin-bottom:24px;display:flex}.login-card__header h1{color:#111827;font-size:22px}.login-help{color:#6b7280;margin-top:4px;font-size:13px;line-height:1.6}.login-form{margin-bottom:16px}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin:0 0 16px;padding:10px 12px;font-size:13px;line-height:1.6}.login-submit{width:100%}.login-tips{color:#6b7280;font-size:12px}@media (width<=640px){.login-shell{padding:20px}.login-card{border-radius:16px;width:min(100%,420px);padding:24px 20px}.login-card__header{align-items:flex-start}}
