*{box-sizing:border-box}body,html{padding:0;margin:0}body{background:#f4f6f9;color:#1f2d3d}a{color:inherit;text-decoration:none}@import url("https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&display=swap");:root{--primary:#1d4e89;--primary-dark:#102a43;--primary-700:#2a63a8;--primary-100:#e8f0fa;--accent:#c0322b;--success:#2e7d32;--warning:#e08600;--error:#c0322b;--info:#1d6fb8;--bg:#f4f6f9;--surface:#fff;--border:#e3e8ef;--text:#1f2a37;--text-2:#5b6b7f;--text-3:#8a98a9;--st-draft:#94a3b8;--st-appraise:#e08600;--st-waiting:#1d6fb8;--st-approved:#2e7d32;--st-returned:#d9480f;--st-cancel:#c0322b;--radius:6px;--radius-lg:10px;--shadow-sm:0 1px 2px rgba(16,35,60,.06);--shadow:0 2px 8px rgba(16,35,60,.08);--sidebar-w:256px;--header-h:56px}body{font-family:Be Vietnam Pro,Inter,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--primary-dark);color:#cdd9ea;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:#20405f;border-radius:8px}.brand{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid hsla(0,0%,100%,.08)}.brand .logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--primary),#2f80ed);display:grid;place-items:center}.brand .logo,.brand .name{color:#fff;font-weight:700}.brand .name{font-size:15px;line-height:1.1}.brand .sub{color:#8fa6c4;font-size:11px}.nav{padding:8px 0 24px}.nav .group{color:#6f87a8;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:12px 18px 4px}.nav .navlink{display:flex;align-items:center;gap:10px;padding:9px 18px;color:#cdd9ea;font-size:13.5px;cursor:pointer;width:100%;background:none;border:0;border-left:3px solid transparent;text-align:left}.nav .navlink .ic{width:18px;text-align:center;opacity:.9}.nav .navlink:hover{background:hsla(0,0%,100%,.05);color:#fff}.nav .navlink.active{background:rgba(22,89,168,.35);color:#fff;border-left-color:#5aa0ec;font-weight:600}.nav .badge-dot{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;border-radius:10px;padding:0 6px}.main{display:flex;flex-direction:column;min-width:0}.header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);gap:16px;padding:0 18px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.header,.search{display:flex;align-items:center}.search{flex:1 1;max-width:460px;gap:8px;background:#f1f4f8;border-radius:8px;padding:7px 12px;color:var(--text-3)}.search input{border:0;background:transparent;outline:none;width:100%;font-size:13.5px;color:var(--text)}.header .spacer{flex:1 1}.header .h-actions{display:flex;align-items:center;gap:14px;color:var(--text-2)}.header .pill{display:flex;align-items:center;gap:8px;background:#f1f4f8;border-radius:20px;padding:4px 12px;font-size:13px;cursor:pointer}.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.icon-btn{position:relative;width:34px;height:34px;border-radius:8px;display:grid;place-items:center;cursor:pointer}.icon-btn:hover{background:#f1f4f8}.icon-btn .dot{position:absolute;top:6px;right:7px;width:8px;height:8px;background:var(--accent);border-radius:50%;border:2px solid #fff}.content{padding:18px 22px}.breadcrumb{color:var(--text-3);font-size:13px;margin-bottom:10px}.breadcrumb b{color:var(--text-2);font-weight:500}.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.page-head h1{font-size:20px;margin:0}.page-head .desc{color:var(--text-2);font-size:13px}.page-head .ph-actions{margin-left:auto;display:flex;gap:8px}.grid{display:grid;grid-gap:16px;gap:16px}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.mc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.mc .mc-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);font-weight:600}.mc .mc-head .more{margin-left:auto;color:var(--text-3);font-weight:400;font-size:13px}.kpi,.mc .mc-body{padding:16px}.kpi{cursor:pointer;transition:box-shadow .15s,transform .15s}.kpi:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.kpi .kpi-top{display:flex;align-items:center;justify-content:space-between}.kpi .kpi-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:18px}.kpi .kpi-label{color:var(--text-2);font-size:13px}.kpi .kpi-value{font-size:24px;font-weight:700;margin-top:6px;letter-spacing:-.02em}.kpi .kpi-trend{font-size:12px;margin-top:4px}.up{color:var(--success)}.down{color:var(--error)}.tint-blue{background:var(--primary-100);color:var(--primary)}.tint-green{background:#e3f6ea;color:var(--success)}.tint-amber{background:#fdf0db;color:var(--warning)}.tint-red{background:#fbe3e3;color:var(--error)}.tint-teal{background:#d9f0f2;color:#0f7b8a}.tag,.tint-gray{background:#eef2f7;color:var(--text-2)}.tag{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:500;line-height:1.7}.tag:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.tag.draft{background:#eef2f6;color:var(--st-draft)}.tag.appraise{background:#fdf0db;color:var(--st-appraise)}.tag.waiting{background:#e7eefb;color:var(--st-waiting)}.tag.approved{background:#e3f6ea;color:var(--st-approved)}.tag.returned{background:#fdeadf;color:var(--st-returned)}.tag.cancel{background:#fbe3e3;color:var(--st-cancel)}.chip{display:inline-block;padding:1px 8px;border-radius:6px;font-size:12px;background:var(--primary-100);color:var(--primary);font-weight:500}.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--text-2)}.legend i{width:10px;height:10px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:middle}.muted{color:var(--text-3)}.bars{display:flex;align-items:flex-end;gap:14px;height:170px;padding-top:10px}.bars .bcol{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.bars .bar{width:60%;background:var(--primary);border-radius:4px 4px 0 0}.bars .bar.plan{background:#c7d6ea}.bars .blabel{font-size:11.5px;color:var(--text-3)}.donut{width:150px;height:150px;place-items:center}.donut,.donut .hole{border-radius:50%;display:grid}.donut .hole{width:96px;height:96px;background:#fff;place-items:center;text-align:center}.ant-card{border:1px solid var(--border)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-sm)}.ant-card-head{min-height:48px;border-bottom:1px solid var(--border);font-weight:600}.ant-card-head-title{font-size:14.5px}.ant-table-thead>tr>th{background:#eef2f7!important;color:#314158!important;font-weight:600!important}.ant-table-tbody>tr.ant-table-row:hover>td{background:#f5f8fc!important}.ant-table-wrapper .ant-table,.ant-tabs-tab{font-size:13.5px}.ant-tabs-tab{color:var(--text-2)}.ant-tabs-tab.ant-tabs-tab-active .ant-tabs-tab-btn{color:var(--primary);font-weight:600}.ant-tabs-ink-bar{background:var(--primary)}.ant-drawer-header{border-bottom:1px solid var(--border)}.ant-drawer-title{font-weight:600}.ant-modal-header{border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:4px}.ant-btn-primary{box-shadow:none}.ant-statistic-title{color:var(--text-2)}@media (max-width:1080px){.app{grid-template-columns:1fr}.sidebar{position:fixed;z-index:50;width:var(--sidebar-w);transform:translateX(-100%);transition:transform .2s;box-shadow:var(--shadow-lg,0 8px 24px rgba(16,35,60,.12))}.sidebar.open{transform:translateX(0)}.mobile-toggle{display:grid!important}.cols-4{grid-template-columns:repeat(2,1fr)}.cols-2,.cols-3{grid-template-columns:1fr}}.mobile-toggle{display:none}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);background:#fff;color:var(--text);font-size:13.5px;font-weight:500;cursor:pointer;white-space:nowrap}.btn:hover{border-color:#c4cdd9}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-700)}.btn.sm{padding:5px 10px;font-size:12.5px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card .card-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);font-weight:600}.card .card-body{padding:16px}.toolbar{display:flex;align-items:center;gap:8px;padding:10px 12px;flex-wrap:wrap}.toolbar .filter{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;color:var(--text-2);background:#fff;cursor:pointer}.toolbar .spacer{flex:1 1}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}table.tbl thead th{text-align:left;background:#eef2f7;color:#314158;font-weight:600;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}table.tbl tbody td{padding:11px 12px;border-bottom:1px solid #eef1f5}table.tbl tbody tr:hover{background:#f5f8fc}table.tbl .muted{color:var(--text-3)}.pagination{display:flex;align-items:center;gap:6px;padding:12px;color:var(--text-2);font-size:13px}.pagination .pg{min-width:30px;height:30px;border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;cursor:pointer}.pagination .pg.active{background:var(--primary);color:#fff;border-color:var(--primary)}.help{color:var(--text-3);font-size:12px;margin-top:4px}.tree{font-size:13px}.tree .node{padding:6px 8px;border-radius:6px;display:flex;align-items:center;gap:8px;cursor:pointer}.tree .node:hover{background:#f1f4f8}.tree .node.sel{background:var(--primary-100);color:var(--primary);font-weight:600}.small{font-size:12.5px}.b{font-weight:600}.divider{height:1px;background:var(--border);margin:14px 0}.alert{display:flex;gap:10px;padding:11px 14px;border-radius:var(--radius);font-size:13px}.alert.info{background:#eaf1fb;border:1px solid #cfe0f6;color:#14508f}.alert.warn{background:#fdf6e7;border:1px solid #f3e0b5;color:#8a6100}.tag.plain:before{display:none}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.flex{display:flex}.flex.center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}