:root{--bg-main:#eef2f7;--bg-panel:#fff;--bg-dark:#121b2d;--bg-dark-soft:#1b2740;--bg-active:#2d5ea8;--line:#d7deea;--text:#243044;--text-soft:#66758f;--text-on-dark:#dbe7ff;--ok:#198754;--danger:#c9302c;--warn:#b57600;--shadow:0 10px 24px #10203c14}*{box-sizing:border-box}body{background:var(--bg-main);color:var(--text);margin:0;font-family:PingFang SC,Microsoft YaHei,Source Han Sans SC,sans-serif}#app{min-height:100vh}button,input,select,textarea{font:inherit}.console-shell{grid-template-columns:320px 1fr;min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, var(--bg-dark), #0f1728);color:var(--text-on-dark);border-right:1px solid #0a1120;flex-direction:column;display:flex}.sidebar-header{border-bottom:1px solid #bcd4ff24;align-items:center;gap:14px;padding:20px 18px;display:flex}.logo-mark{color:#fff;letter-spacing:1px;background:linear-gradient(145deg,#2d6edb,#19438a);border-radius:10px;place-items:center;width:42px;height:42px;font-weight:700;display:grid}.sidebar-header h2{color:#fff;margin:0;font-size:18px}.sidebar-header p{color:#9fb1d3;margin:4px 0 0;font-size:12px}.menu-scroll{padding:12px;overflow:auto}.menu-group{margin-bottom:14px}.menu-group h4{color:#9eb2da;letter-spacing:.4px;margin:0 0 8px;font-size:12px;font-weight:600}.menu-item{width:100%;color:var(--text-on-dark);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 10px;transition:background .2s,transform .2s;display:flex}.menu-item:hover{background:#5075b84d}.menu-item.active{background:var(--bg-active);color:#fff}.menu-badge{color:#ffcf6d;font-size:11px}.menu-badge.ready{color:#8dd6a6}.main-section{flex-direction:column;min-width:0;display:flex}.main-header{background:var(--bg-panel);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:16px 24px;display:flex;box-shadow:0 2px 8px #10203c0a}.main-header h3{margin:2px 0 0;font-size:22px}.breadcrumb{color:var(--text-soft);margin:0;font-size:13px}.header-actions{color:var(--text-soft);align-items:center;gap:12px;font-size:14px;display:flex}.main-panel{gap:14px;padding:18px 20px 24px;animation:.24s fade-in;display:grid}.hero-card{background:linear-gradient(135deg,#f7faff,#f0f5ff 55%,#edf7ff);border:1px solid #d2def4;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.hero-card h2{margin:4px 0}.hero-card p{color:var(--text-soft);margin:0}.hero-kicker{color:#2d5ea8;text-transform:uppercase;letter-spacing:.7px;margin:0;font-size:12px}.hero-actions{gap:8px;display:flex}.overview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.overview-card{background:var(--bg-panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:10px;padding:12px 14px}.overview-card p{color:var(--text-soft);margin:0;font-size:13px}.overview-card strong{margin-top:8px;font-size:20px;display:block}.table-card{background:var(--bg-panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.table-toolbar{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.table-toolbar strong{font-size:15px}.table-toolbar label{color:var(--text-soft);align-items:center;gap:8px;display:inline-flex}.table-wrap{overflow:auto}table{border-collapse:collapse;width:100%;min-width:980px}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid #edf1f7;padding:10px 12px;font-size:14px}th{color:#41516b;background:#f6f8fc;font-weight:600}.empty-cell,.empty-block{text-align:center;color:var(--text-soft);padding:20px}.action-row{flex-wrap:wrap;gap:6px;display:flex}.status-tag{border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-draft{color:#6a5a1d;background:#fff5d6}.status-approved{color:#1f5ea8;background:#e6f0ff}.status-posted{color:#13643f;background:#e2f6eb}.status-reconciled{color:#834d00;background:#ffefd8}.btn{color:var(--text);cursor:pointer;background:#fff;border:1px solid #0000;border-radius:8px;padding:7px 12px;transition:background .2s,transform .2s}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn.primary{color:#fff;background:#2d5ea8}.btn.ghost{border-color:var(--line);background:#fff}.btn.tiny{padding:4px 8px;font-size:12px}.btn.success{color:var(--ok);border-color:#b5dfc8}.btn.danger{color:var(--danger);border-color:#efc3c1}.btn.full{width:100%}input,select,textarea{width:100%;color:var(--text);background:#fff;border:1px solid #cfd8e8;border-radius:8px;padding:8px 10px}input:focus,select:focus,textarea:focus{border-color:#2d5ea8;outline:none;box-shadow:0 0 0 2px #2d5ea826}.modal{z-index:30;position:fixed;inset:0}.modal.hidden{display:none}.modal-backdrop{background:#09122180;position:absolute;inset:0}.modal-card{border:1px solid var(--line);background:#fff;border-radius:12px;width:min(820px,92vw);margin:56px auto 0;animation:.2s up-in;position:relative;box-shadow:0 22px 56px #0618344d}.modal-card header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.modal-card h3{margin:0}.modal-body{padding:14px}.icon-btn{cursor:pointer;color:var(--text-soft);background:0 0;border:none;font-size:24px;line-height:1}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-grid label{color:var(--text-soft);flex-direction:column;gap:6px;font-size:13px;display:flex}.full-width{grid-column:1/-1}.modal-footer{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.easy-list{gap:10px;padding:12px 14px;display:grid}.easy-list article{background:#f8fbff;border:1px dashed #c8d6ed;border-radius:10px;padding:10px 12px}.easy-list h4{margin:0;font-size:14px}.easy-list p{color:var(--text-soft);margin:4px 0 0;font-size:13px}.toast{color:#fff;z-index:40;background:#1e3f72;border-radius:8px;padding:9px 13px;position:fixed;bottom:20px;right:20px;box-shadow:0 8px 28px #00000040}.toast.error{background:#9f2f2b}.toast.hidden{display:none}.login-shell{background:radial-gradient(circle at 10% 20%,#dbe8ff 0%,#0000 35%),radial-gradient(circle at 90% 10%,#e3f2ff 0%,#0000 30%),linear-gradient(#eef4ff,#e9eef7);place-items:center;min-height:100vh;padding:18px;display:grid}.login-card{background:#fff;border:1px solid #d3def3;border-radius:14px;width:min(460px,100%);padding:22px 20px;box-shadow:0 18px 42px #142b5429}.login-brand{align-items:center;gap:12px;margin-bottom:16px;display:flex}.login-brand h1{margin:0;font-size:23px}.login-brand p{color:var(--text-soft);margin:4px 0 0;font-size:13px}.login-form{gap:10px;display:grid}.login-form label{color:var(--text-soft);gap:6px;font-size:13px;display:grid}.login-tip{color:var(--text-soft);margin:12px 0 0;font-size:12px}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes up-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=1200px){.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=980px){.console-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #0a1120;border-right:none}.menu-scroll{max-height:40vh}.main-header{padding:12px 14px}.header-actions{gap:8px;font-size:13px}.form-grid{grid-template-columns:1fr}}@media (width<=680px){.main-panel{padding:12px}.hero-card{flex-direction:column;align-items:flex-start}.hero-actions{width:100%}.hero-actions .btn{flex:1}.overview-grid{grid-template-columns:1fr}.main-header{flex-direction:column;align-items:flex-start;gap:8px}}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-right:12px;display:flex}.filter-bar label{color:var(--text-soft);align-items:center;gap:4px;font-size:13px;display:inline-flex}.filter-bar input,.filter-bar select{width:auto;padding:5px 8px;font-size:13px}.btn-sm{padding:5px 10px;font-size:13px}.checkbox-grid{grid-template-columns:repeat(2,1fr);gap:8px;max-height:420px;padding:4px 0;display:grid;overflow-y:auto}.checkbox-grid label{color:var(--text);cursor:pointer;border:1px solid var(--line);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:14px;transition:background .2s;display:flex}.checkbox-grid label:hover{background:#f6f8fc}.checkbox-grid input[type=checkbox]{width:auto;accent-color:var(--bg-active);flex-shrink:0;margin:0}
