:root{--canvas: #f6f8f7;--surface: #ffffff;--surface-muted: #f1f5f3;--surface-subtle: #eaf1ee;--surface-selected: #e7f3ec;--ink: #17211b;--text: #243027;--text-secondary: #5d6b61;--text-muted: #8a968e;--border: #dce4df;--border-strong: #b9c7bf;--primary: #1f7a4d;--primary-hover: #17663f;--primary-pressed: #0f4f31;--primary-soft: #ddf0e5;--accent-blue: #2f6f9f;--accent-blue-soft: #e1eef7;--accent-teal: #168c7a;--accent-teal-soft: #dff4f0;--accent-amber: #b7791f;--accent-amber-soft: #fff3d6;--accent-red: #b42318;--accent-red-soft: #fce4df;--accent-purple: #6d5bd0;--accent-purple-soft: #ece9ff;--disabled-bg: #eef2ef;--disabled-text: #9aa6a0;--focus-ring: #74b88e;--shadow-raised: 0 1px 2px rgba(20, 35, 28, .06), 0 0 0 1px #dce4df;--font-sans: "Inter", "PingFang SC", "Microsoft YaHei", "Noto Sans CJK SC", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Roboto Mono", "JetBrains Mono", "SFMono-Regular", Consolas, "Liberation Mono", monospace}*{box-sizing:border-box}html{color:var(--text);background:var(--canvas);font-family:var(--font-sans);font-size:14px;letter-spacing:0}body{margin:0;min-width:1120px}button,input,select,textarea{font:inherit}button{border:0}button:focus-visible,a:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.app-shell{display:grid;min-height:100vh;grid-template-columns:224px minmax(0,1fr);background:var(--canvas)}.side-nav{position:sticky;top:0;height:100vh;border-right:1px solid var(--border);background:var(--surface);padding:16px 12px}.brand-block{display:flex;align-items:center;gap:10px;height:48px;padding:0 6px 14px;border-bottom:1px solid var(--border);color:var(--ink)}.brand-block strong,.brand-block span{display:block}.brand-block strong{font-size:15px;line-height:20px;font-weight:600}.brand-block span{color:var(--text-secondary);font-size:12px;line-height:18px}.brand-mark{display:grid;width:32px;height:32px;place-items:center;border-radius:6px;background:var(--primary);color:#fff;font-weight:700}.side-nav nav{display:flex;flex-direction:column;gap:4px;margin-top:14px}.nav-button{position:relative;display:flex;align-items:center;gap:10px;min-height:48px;width:100%;padding:7px 10px;border-radius:6px;color:var(--text-secondary);background:transparent;text-align:left;cursor:pointer;transition:background .12s cubic-bezier(.2,0,0,1),color .12s cubic-bezier(.2,0,0,1)}.nav-button:hover{background:var(--surface-muted);color:var(--text)}.nav-button.active{background:var(--surface-selected);color:var(--primary)}.nav-button.active:before{position:absolute;left:0;width:3px;height:28px;border-radius:0 2px 2px 0;background:var(--primary);content:""}.nav-button strong,.nav-button small{display:block}.nav-button strong{color:inherit;font-size:14px;line-height:20px;font-weight:600}.nav-button small{color:var(--text-secondary);font-size:11px;line-height:16px}.app-main{min-width:0}.top-bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;height:56px;border-bottom:1px solid var(--border);background:#fffffff5;padding:0 20px}.top-search{display:flex;align-items:center;gap:8px;width:min(520px,48vw);height:32px;border:1px solid var(--border);border-radius:4px;background:var(--surface-muted);color:var(--text-muted);padding:0 10px}.top-actions{display:flex;align-items:center;gap:8px}.top-actions button,.icon-button{display:grid;width:32px;height:32px;place-items:center;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text-secondary);cursor:pointer}.top-actions button:hover,.icon-button:hover{background:var(--surface-muted);color:var(--text)}.user-chip{height:32px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);padding:6px 10px;line-height:18px}.content-shell{padding:20px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}.page-header p,.panel-header p,.kpi-card p,.exception-item p,.report-card p{margin:0;color:var(--text-secondary)}.page-header p{margin-bottom:4px;font-size:13px}.page-header h1{margin:0;color:var(--ink);font-size:24px;font-weight:600;line-height:32px}.header-actions,.toolbar-actions{display:flex;align-items:center;gap:8px}.primary-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;border-radius:4px;padding:0 12px;cursor:pointer;transition:background .12s cubic-bezier(.2,0,0,1),border-color .12s cubic-bezier(.2,0,0,1)}.primary-button{background:var(--primary);color:#fff}.primary-button:hover{background:var(--primary-hover)}.primary-button:active{background:var(--primary-pressed)}.ghost-button{border:1px solid var(--border);background:var(--surface);color:var(--text)}.ghost-button:hover{border-color:var(--border-strong);background:var(--surface-muted)}.page-stack{display:flex;flex-direction:column;gap:16px}.page-grid{display:grid;gap:16px}.detail-layout{grid-template-columns:minmax(0,1fr) 360px}.form-layout{grid-template-columns:minmax(0,1fr) 360px;align-items:start}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(360px,.7fr);gap:16px}.panel{min-width:0;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow-raised)}.main-panel,.trace-panel{align-self:start}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:56px;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-header h2{margin:0;color:var(--ink);font-size:18px;font-weight:600;line-height:26px}.panel-header p{margin-top:2px;font-size:12px;line-height:18px}.table-toolbar{min-height:58px}.tabbed-ledger{overflow:hidden}.ledger-tabs{display:flex;align-items:center;gap:4px;min-height:48px;border-bottom:1px solid var(--border);background:var(--surface-muted);padding:8px 12px 0;overflow-x:auto}.ledger-tab{display:inline-flex;align-items:center;gap:7px;height:40px;border:1px solid transparent;border-bottom:0;border-radius:6px 6px 0 0;background:transparent;color:var(--text-secondary);padding:0 12px;cursor:pointer;white-space:nowrap}.ledger-tab:hover{background:var(--surface-subtle);color:var(--text)}.ledger-tab.active{border-color:var(--border);background:var(--surface);color:var(--primary)}.ledger-tab span{font-weight:600}.ledger-tab b{display:grid;min-width:20px;height:20px;place-items:center;border-radius:9999px;background:var(--surface-subtle);color:var(--text-secondary);font-size:11px;font-weight:600;line-height:16px;padding:0 6px}.ledger-tab.active b{background:var(--primary-soft);color:var(--primary)}.secondary-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;min-height:64px;border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:12px 16px;box-shadow:var(--shadow-raised)}.secondary-header h2{margin:0;color:var(--ink);font-size:20px;font-weight:600;line-height:28px}.secondary-header p{margin:2px 0 0;color:var(--text-secondary);font-size:12px;line-height:18px}.document-detail-header{grid-template-columns:auto minmax(0,1fr) minmax(360px,auto)}.detail-module{display:block;margin-bottom:2px;color:var(--text-secondary);font-size:12px;line-height:18px}.detail-status-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0}.detail-actions,.row-actions{display:flex;align-items:center;gap:6px;min-width:0}.detail-actions{justify-content:flex-end;flex-wrap:wrap}.row-actions{justify-content:center}.table-action,.detail-action{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap}.table-action{min-width:48px;height:24px;padding:0 7px;font-size:12px;line-height:18px}.detail-action{height:32px;padding:0 12px;font-size:13px;line-height:20px}.table-action:hover,.detail-action:hover{border-color:var(--border-strong);background:var(--surface-muted)}.table-action.primary,.detail-action.primary{border-color:var(--primary);background:var(--primary);color:#fff}.table-action.primary:hover,.detail-action.primary:hover{background:var(--primary-hover)}.table-action.warning,.detail-action.warning{border-color:#ead3a6;background:var(--accent-amber-soft);color:var(--accent-amber)}.table-action.danger,.detail-action.danger{border-color:#efb9b0;background:var(--accent-red-soft);color:var(--accent-red)}.form-section{border-bottom:1px solid var(--border)}.form-section:last-child{border-bottom:0}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px 16px;padding:16px}.form-field{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:10px;min-width:0}.form-field>span{color:var(--text-secondary);font-size:13px;line-height:20px}.form-field b{margin-right:3px;color:var(--accent-red);font-weight:600}.field-box{min-width:0;height:32px;overflow:hidden;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);line-height:30px;padding:0 10px;text-overflow:ellipsis;white-space:nowrap}.field-box.readonly{background:var(--surface-muted);color:var(--text-secondary)}.line-total{display:flex;justify-content:flex-end;min-height:42px;border-top:1px solid var(--border);background:var(--surface-muted);color:var(--ink);font-size:13px;font-weight:600;line-height:20px;padding:10px 16px}.side-workspace{align-self:start;overflow:hidden}.rule-summary{padding:16px}.rule-summary h3{margin:0 0 12px;color:var(--ink);font-size:16px;font-weight:600;line-height:24px}.rule-item{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;border-bottom:1px solid var(--border);padding:10px 0}.rule-item:last-child{border-bottom:0}.rule-item p{margin:0;color:var(--text-secondary);font-size:12px;line-height:18px}.warning-alert{margin:0 16px 16px;border-color:#ead3a6;background:var(--accent-amber-soft);color:var(--accent-amber)}.field-check-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;padding:16px}.field-check-grid label{display:flex;align-items:center;gap:8px;min-height:32px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);padding:0 10px;font-size:13px}.field-check-grid input{width:14px;height:14px;accent-color:var(--primary)}.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.kpi-card,.report-card{min-width:0;border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:14px 16px;box-shadow:var(--shadow-raised)}.kpi-topline,.report-card-title,.exception-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.kpi-topline{color:var(--text-secondary);font-size:12px;line-height:18px}.kpi-value{margin-top:10px;color:var(--ink);font-size:28px;font-weight:650;line-height:34px;font-variant-numeric:tabular-nums}.kpi-value span,.report-card strong span{margin-left:4px;color:var(--text-secondary);font-size:13px;font-weight:500}.kpi-card p{margin-top:8px;min-height:36px;font-size:12px;line-height:18px}.kpi-pending,.kpi-warning{border-color:#ead3a6}.kpi-blocked{border-color:#efb9b0}.kpi-info{border-color:#bfd8e9}.status-tag{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:22px;max-width:100%;border:1px solid transparent;border-radius:4px;padding:0 7px;font-size:12px;font-weight:500;line-height:18px;white-space:nowrap}.status-tag.compact{height:20px;padding:0 6px;font-size:11px}.status-success,.status-approved{border-color:#bddfc9;background:var(--primary-soft);color:var(--primary)}.status-info,.status-submitted{border-color:#bdd6e8;background:var(--accent-blue-soft);color:var(--accent-blue)}.status-warning,.status-pending{border-color:#ead3a6;background:var(--accent-amber-soft);color:var(--accent-amber)}.status-blocked{border-color:#efb9b0;background:var(--accent-red-soft);color:var(--accent-red)}.status-draft,.status-voided{border-color:var(--border);background:var(--disabled-bg);color:var(--text-secondary)}.workflow-timeline{display:grid;grid-template-columns:repeat(7,minmax(112px,1fr));gap:0;overflow-x:auto;padding:16px}.workflow-node{position:relative;min-width:112px;padding-right:12px}.workflow-node:after{position:absolute;top:14px;left:32px;right:4px;height:1px;background:var(--border-strong);content:""}.workflow-node:last-child:after{display:none}.node-marker{position:relative;z-index:1;display:grid;width:28px;height:28px;place-items:center;border:1px solid var(--border-strong);border-radius:9999px;background:var(--surface);color:var(--text-secondary)}.node-done .node-marker{border-color:#bddfc9;background:var(--primary-soft);color:var(--primary)}.node-current .node-marker{border-color:var(--primary);background:var(--surface-selected);color:var(--primary)}.node-blocked .node-marker{border-color:#efb9b0;background:var(--accent-red-soft);color:var(--accent-red)}.node-body{margin-top:8px;padding-right:8px}.node-body strong,.node-body span,.node-body small{display:block}.node-body strong{color:var(--ink);font-size:13px;line-height:20px}.node-body span,.node-body small{color:var(--text-secondary);font-size:12px;line-height:18px}.table-wrap{overflow-x:auto}.data-table{width:100%;min-width:860px;border-collapse:collapse;table-layout:fixed;font-size:13px;line-height:20px}.data-table th,.data-table td{height:40px;border-bottom:1px solid var(--border);padding:8px 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-table th,.compact-table td{height:34px;padding:6px 8px}.data-table th{position:sticky;top:0;z-index:1;background:var(--surface-muted);color:var(--text-secondary);font-size:12px;font-weight:600}.data-table tbody tr:hover{background:var(--surface-muted)}.data-table tbody tr:last-child td{border-bottom:0}.align-left{text-align:left}.align-center{text-align:center}.align-right{text-align:right;font-variant-numeric:tabular-nums}.code-text{color:var(--ink);font-family:var(--font-mono);font-size:12px;font-variant-numeric:tabular-nums}.table-primary-text{color:var(--ink);font-weight:600}.exception-list{display:flex;flex-direction:column;padding:8px 12px 12px}.exception-item{display:grid;grid-template-columns:20px minmax(0,1fr);gap:8px;border-bottom:1px solid var(--border);padding:10px 4px}.exception-item:last-child{border-bottom:0}.exception-item>svg{margin-top:2px;color:var(--accent-amber)}.exception-title span:first-child{color:var(--ink);font-size:13px;font-weight:600;line-height:20px}.exception-item p{margin-top:2px;font-size:12px;line-height:18px}.document-heading{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:16px;border-bottom:1px solid var(--border)}.document-heading h2{margin:0;color:var(--ink);font-family:var(--font-mono);font-size:18px;font-weight:650;line-height:26px}.detail-list{display:grid;gap:0;margin:0;padding:0 16px}.detail-list div{display:grid;grid-template-columns:96px minmax(0,1fr);gap:12px;border-bottom:1px solid var(--border);padding:10px 0}.detail-list dt,.detail-list dd{margin:0;font-size:13px;line-height:20px}.detail-list dt{color:var(--text-secondary)}.detail-list dd{color:var(--ink);font-weight:500}.related-docs{padding:0 16px 16px}.detail-related-docs{border-top:1px solid var(--border);padding-top:14px}.related-docs h3{margin:0 0 10px;color:var(--ink);font-size:14px;line-height:22px}.related-docs button{display:block;width:100%;height:32px;margin-top:8px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);font-family:var(--font-mono);text-align:left;padding:0 10px;cursor:pointer}.related-docs button:hover{background:var(--surface-muted)}.trace-actions{border-top:1px solid var(--border);padding:12px 16px}.trace-actions .detail-actions{justify-content:stretch}.trace-actions .detail-action{flex:1}.inline-alert{display:flex;align-items:center;gap:8px;min-height:38px;border:1px solid #bddfc9;border-radius:6px;background:var(--primary-soft);color:var(--primary);padding:8px 12px;font-size:13px}.detail-rule-alert{margin:0 16px 16px}.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.report-card-title{color:var(--text-secondary);font-size:13px}.report-card strong{display:block;margin-top:12px;color:var(--ink);font-size:28px;font-weight:650;line-height:34px;font-variant-numeric:tabular-nums}.report-card p{margin-top:8px;font-size:12px;line-height:18px}.dept-sales{border-top:3px solid var(--accent-blue)}.dept-production{border-top:3px solid var(--accent-purple)}.dept-purchase{border-top:3px solid var(--accent-teal)}.dept-warehouse{border-top:3px solid var(--primary)}.dept-quality{border-top:3px solid var(--accent-red)}.dept-finance{border-top:3px solid var(--accent-amber)}.dept-masterData{border-top:3px solid var(--text-secondary)}.report-list{display:flex;flex-direction:column;padding:4px 16px 16px}.report-row{display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding:12px 0}.report-row:last-child{border-bottom:0}.report-row strong,.report-row span{display:block}.report-row strong{color:var(--ink);font-size:14px;line-height:22px}.report-row span{color:var(--text-secondary);font-size:12px;line-height:18px}@media(max-width:1439px){body{min-width:1024px}.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-layout,.form-layout,.dashboard-grid{grid-template-columns:1fr}.document-detail-header{grid-template-columns:auto minmax(0,1fr)}.detail-status-actions{grid-column:1 / -1;justify-content:flex-start}.trace-panel{order:-1}}@media(max-width:1180px){.app-shell{grid-template-columns:64px minmax(0,1fr)}.side-nav{padding:12px 8px}.brand-block{justify-content:center;padding:0 0 12px}.brand-block div:not(.brand-mark),.nav-button span{display:none}.nav-button{justify-content:center;min-height:42px;padding:8px}.nav-button.active:before{height:24px}.two-col,.form-grid,.report-grid{grid-template-columns:1fr}.field-check-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important}}
