:root{--brand-600: #1d4ed8;--brand-700: #1e40af;--brand-50: #eff6ff;--bg: #f6f7f9;--surface: #fff;--surface-2: #f9fafb;--border: #e5e7eb;--text: #0f172a;--text-muted: #475569;--text-subtle: #64748b;--s-success-fg: #047857;--s-success-bg: #ecfdf5;--s-pending-fg: #b45309;--s-pending-bg: #fffbeb;--s-cancel-fg: #9f1239;--s-cancel-bg: #fff1f2;--s-error-fg: #b91c1c;--s-error-bg: #fef2f2;--s-draft-fg: #475569;--s-draft-bg: #f1f5f9;--s-offline-fg: #6d28d9;--s-offline-bg: #f5f3ff;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--e-1: 0 1px 2px rgba(16, 24, 40, .06);--e-2: 0 4px 12px rgba(16, 24, 40, .1);--e-3: 0 16px 40px rgba(16, 24, 40, .18);--mono: "JetBrains Mono", ui-monospace, monospace}[data-theme=dark]{--brand-600: #3b82f6;--brand-700: #2563eb;--brand-50: #172554;--bg: #0b0f17;--surface: #111722;--surface-2: #161d2b;--border: #222b3a;--text: #e6eaf2;--text-muted: #9aa7bd;--text-subtle: #6b7890;--s-success-bg: #06281d;--s-pending-bg: #2a2008;--s-cancel-bg: #2a0f17;--s-error-bg: #2a0f0f;--s-draft-bg: #1b2433;--s-offline-bg: #1e1733;--s-success-fg: #34d399;--s-pending-fg: #fbbf24;--s-cancel-fg: #fb7185;--s-error-fg: #f87171;--s-draft-fg: #94a3b8;--s-offline-fg: #a78bfa}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit}.tnum{font-feature-settings:"tnum" 1;font-variant-numeric:tabular-nums}.mono{font-family:var(--mono)}.muted{color:var(--text-subtle)}button{font-family:inherit;cursor:pointer}::selection{background:var(--brand-50)}:focus-visible{outline:3px solid color-mix(in srgb,var(--brand-600) 45%,transparent);outline-offset:1px}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;font-weight:700;font-size:15px;letter-spacing:-.01em}.brand .mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand-600),var(--brand-700));display:grid;place-items:center;color:#fff}.nav{padding:6px 10px;overflow:auto;flex:1}.nav .group{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-subtle);padding:14px 10px 6px}.nav a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);color:var(--text-muted);text-decoration:none;font-weight:500;font-size:13.5px;position:relative}.nav a:hover{background:var(--surface-2);color:var(--text)}.nav a.active{background:var(--brand-50);color:var(--brand-600)}.nav a.active:before{content:"";position:absolute;left:-10px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--brand-600)}.nav a svg{width:17px;height:17px}.nav a .badge{margin-left:auto;font-size:11px;background:var(--s-pending-bg);color:var(--s-pending-fg);padding:1px 7px;border-radius:99px;font-weight:600}.nav a.locked{opacity:.55}.nav a.locked svg.lock{width:13px;margin-left:auto}.main{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--surface) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:10px 22px}.tenant{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 10px;font-weight:600;font-size:13px;background:var(--surface)}.tenant .tin{color:var(--text-subtle);font-weight:500}.spacer{flex:1}.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:99px;border:1px solid transparent}.pill svg{width:13px;height:13px}.pill.online{background:var(--s-success-bg);color:var(--s-success-fg)}.pill.warn{background:var(--s-pending-bg);color:var(--s-pending-fg)}.pill.offline{background:var(--s-error-bg);color:var(--s-error-fg)}.iconbtn{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-sm);color:var(--text-muted)}.iconbtn:hover{color:var(--text);background:var(--surface-2)}.avatar{width:34px;height:34px;border-radius:99px;background:var(--brand-600);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.content{padding:22px;max-width:1440px;width:100%}.pagehead{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px}.pagehead h1{font-size:24px;font-weight:600;letter-spacing:-.02em}.crumb{font-size:12.5px;color:var(--text-subtle);margin-bottom:4px;display:flex;gap:6px;align-items:center}.crumb svg{width:13px;height:13px}.btn{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:13px;border-radius:var(--r-md);padding:9px 14px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.btn svg{width:16px;height:16px}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--brand-600);border-color:var(--brand-600);color:#fff}.btn.primary:hover{background:var(--brand-700)}.btn.danger{background:var(--s-error-bg);border-color:transparent;color:var(--s-error-fg)}.btn.ghost{border-color:transparent;background:transparent;color:var(--text-muted)}.btn.sm{padding:6px 10px;font-size:12.5px}.btn.block{width:100%;justify-content:center}.grid{display:grid;gap:16px}.kpis{grid-template-columns:repeat(4,1fr)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--e-1)}.card.pad{padding:18px}.kpi .lbl{font-size:12.5px;color:var(--text-muted);font-weight:500;display:flex;align-items:center;gap:7px}.kpi .lbl svg{width:15px;height:15px}.kpi .val{font-size:28px;font-weight:600;letter-spacing:-.02em;margin-top:8px}.kpi .sub{font-size:12px;color:var(--text-subtle);margin-top:3px}.panel-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:12px}.panel-title svg{width:16px;height:16px;color:var(--brand-600)}.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 9px 3px 7px;border-radius:99px;white-space:nowrap}.chip svg{width:13px;height:13px}.chip.success{background:var(--s-success-bg);color:var(--s-success-fg)}.chip.pending{background:var(--s-pending-bg);color:var(--s-pending-fg)}.chip.cancel{background:var(--s-cancel-bg);color:var(--s-cancel-fg)}.chip.error{background:var(--s-error-bg);color:var(--s-error-fg)}.chip.draft{background:var(--s-draft-bg);color:var(--s-draft-fg)}.chip.offline{background:var(--s-offline-bg);color:var(--s-offline-fg)}.formgrid{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}.field{margin-bottom:14px}.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}.field .req{color:var(--s-error-fg)}.field .hint{font-size:12px;color:var(--text-subtle);margin-top:5px}.field .err{font-size:12px;color:var(--s-error-fg);margin-top:5px;display:flex;align-items:center;gap:5px}.field .err svg{width:13px;height:13px}input.ctl,select.ctl{width:100%;font-family:inherit;font-size:14px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 11px;outline:none}input.ctl:focus,select.ctl:focus{border-color:var(--brand-600);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-600) 18%,transparent)}input.ctl.invalid{border-color:var(--s-error-fg)}input.ctl[readonly]{background:var(--surface-2);color:var(--text-muted)}.twocol{display:grid;grid-template-columns:1fr 1fr;gap:12px}.kv{display:grid;grid-template-columns:130px 1fr;gap:8px 14px;font-size:13px}.kv dt{color:var(--text-subtle);font-weight:500}.kv dd{font-weight:500}.banner{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500;margin-bottom:16px}.banner svg{width:17px;height:17px;flex:none}.banner.warn{background:var(--s-pending-bg);color:var(--s-pending-fg)}.banner.error{background:var(--s-error-bg);color:var(--s-error-fg)}.banner.info{background:var(--brand-50);color:var(--brand-600)}.banner.success{background:var(--s-success-bg);color:var(--s-success-fg)}.empty{display:grid;place-items:center;text-align:center;padding:56px 24px;gap:10px}.empty .ico{width:46px;height:46px;border-radius:12px;background:var(--surface-2);display:grid;place-items:center;color:var(--text-subtle)}.empty .ico svg{width:24px;height:24px}.empty h3{font-size:16px;font-weight:600}.empty p{color:var(--text-subtle);max-width:440px}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,color-mix(in srgb,var(--brand-600) 10%,transparent),transparent),var(--bg)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--e-3);padding:28px}.login-brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:16px;margin-bottom:4px}.login-brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand-600),var(--brand-700));display:grid;place-items:center;color:#fff}.login-sub{color:var(--text-subtle);font-size:13px;margin-bottom:20px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spin{animation:none}}.toolbar{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.filter{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;color:var(--text-muted);border:1px solid var(--border);background:var(--surface);border-radius:var(--r-sm);padding:6px 10px;cursor:pointer}.filter:hover{background:var(--surface-2)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-subtle);padding:11px 16px;border-bottom:1px solid var(--border);background:var(--surface-2);position:sticky;top:0}thead th.num{text-align:right}tbody td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--surface-2)}td.num{text-align:right}.irn{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted)}.row-link{color:var(--brand-600);font-weight:600;text-decoration:none}.row-link:hover{text-decoration:underline}.summary .line{display:flex;justify-content:space-between;padding:7px 0;font-size:13px;color:var(--text-muted)}.summary .line .v{color:var(--text);font-weight:500}.summary .total{display:flex;justify-content:space-between;padding:12px 0 0;margin-top:6px;border-top:1px solid var(--border);font-size:17px;font-weight:700}.detailgrid{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}.qr{width:180px;height:180px;border-radius:var(--r-md);border:1px solid var(--border);display:grid;place-items:center;background:#fff;margin:0 auto;color:#0f172a}.timeline{position:relative;padding-left:22px}.timeline:before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--border)}.tl{position:relative;padding:0 0 18px}.tl:last-child{padding-bottom:0}.tl:before{content:"";position:absolute;left:-19px;top:2px;width:12px;height:12px;border-radius:99px;background:var(--surface);border:2px solid var(--brand-600)}.tl.done:before{background:var(--s-success-fg);border-color:var(--s-success-fg)}.tl.pending:before{background:var(--surface);border-color:var(--border)}.tl .t{font-weight:600;font-size:13px}.tl .d{font-size:12px;color:var(--text-subtle);margin-top:2px}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px;gap:3px}.seg button{border:0;background:none;padding:7px 14px;border-radius:5px;font-weight:600;font-size:13px;color:var(--text-muted)}.seg button.on{background:var(--surface);color:var(--brand-600);box-shadow:var(--e-1)}input.cell{width:100%;font-family:inherit;font-size:13px;color:var(--text);background:var(--surface);border:1px solid transparent;border-radius:var(--r-sm);padding:6px 8px;outline:none;text-align:right}input.cell:focus{border-color:var(--brand-600)}input.cell.text{text-align:left}.meter{height:8px;border-radius:99px;background:var(--surface-2);overflow:hidden;margin:6px 0}.meter>span{display:block;height:100%;background:var(--brand-600)}.meter.warn>span{background:var(--s-pending-fg)}.meter.over>span{background:var(--s-error-fg)}@media (max-width: 1080px){.kpis{grid-template-columns:repeat(2,1fr)}.formgrid,.detailgrid{grid-template-columns:1fr}}
