:root{--bg: #f4f6f8;--surface: #ffffff;--surface-2: #fafbfc;--border: #e3e6ea;--border-strong: #cdd2d8;--text: #1f2933;--text-muted: #5a6573;--text-subtle: #8a939e;--primary: #1d4ed8;--primary-hover: #1742b8;--primary-soft: #e7edfb;--success: #047857;--success-soft: #d6f3e5;--warning: #b45309;--warning-soft: #fdeed0;--danger: #b91c1c;--danger-soft: #fbe2e2;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 4px 12px rgba(15, 23, 42, .08);--radius: 6px;--radius-lg: 10px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit}table{border-collapse:collapse;width:100%}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#c0c8d2;border-radius:6px}::-webkit-scrollbar-track{background:transparent}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#0f172a;color:#cbd5e1;padding:18px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar h1{color:#fff;font-size:15px;margin:0 4px 4px;letter-spacing:.2px}.sidebar .org{color:#64748b;font-size:12px;margin:0 4px 18px}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);color:#cbd5e1;text-decoration:none;font-weight:500;margin:2px 0}.sidebar nav a:hover{background:#ffffff0f;color:#fff;text-decoration:none}.sidebar nav a.active{background:#3b82f62e;color:#fff}.sidebar .user{position:absolute;bottom:16px;left:14px;right:14px;font-size:12px;color:#94a3b8;border-top:1px solid #1e293b;padding-top:12px}.main{padding:24px 28px;min-width:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}.page-header h2{margin:0;font-size:20px;font-weight:600}.page-header .subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px}.card-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text)}.card-body{padding:18px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-sm)}.kpi .label{color:var(--text-muted);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.kpi .value{color:var(--text);font-size:24px;font-weight:700;margin-top:4px}.kpi .hint{color:var(--text-subtle);font-size:12px;margin-top:2px}.kpi.alert .value{color:var(--danger)}.kpi.warn .value{color:var(--warning)}.kpi.ok .value{color:var(--success)}.charts-row{display:grid;grid-template-columns:1.4fr 1fr;gap:14px;margin-bottom:18px}@media (max-width: 1100px){.charts-row{grid-template-columns:1fr}}.tbl{width:100%;font-size:13px}.tbl th{text-align:left;background:var(--surface-2);color:var(--text-muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.tbl td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}.tbl tr:nth-child(2n) td{background:var(--surface-2)}.tbl tr:hover td{background:#f0f4fa}.tbl .num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.2px;background:#eef2f7;color:#475569}.badge.success{background:var(--success-soft);color:var(--success)}.badge.warn{background:var(--warning-soft);color:var(--warning)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.primary{background:var(--primary-soft);color:var(--primary)}.input,.select{font:inherit;padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--radius);background:#fff;color:var(--text);width:100%;outline:none}.input:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1d4ed81f}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border:1px solid var(--border-strong);background:#fff;color:var(--text);border-radius:var(--radius);cursor:pointer;font-weight:500;font-size:13px;transition:background .12s,border-color .12s}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{background:var(--primary-hover)}.btn.ghost{border-color:transparent;color:var(--primary);background:transparent}.filters{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;gap:10px;margin-bottom:14px;align-items:end}@media (max-width: 1100px){.filters{grid-template-columns:1fr 1fr}}.field label{display:block;font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;margin-bottom:4px;letter-spacing:.3px}.empty-state{padding:32px;text-align:center;color:var(--text-muted);font-size:14px}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.detail-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:14px}@media (max-width: 1100px){.detail-grid{grid-template-columns:1fr}}.dl{display:grid;grid-template-columns:180px 1fr;gap:6px 14px;font-size:13px}.dl dt{color:var(--text-muted);font-weight:500}.dl dd{margin:0;color:var(--text)}.pdf-frame{width:100%;height:700px;border:1px solid var(--border);border-radius:var(--radius)}.pagination{display:flex;gap:8px;align-items:center;justify-content:flex-end;padding:12px 0 0;font-size:13px;color:var(--text-muted)}.login-card{max-width:380px;margin:80px auto;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:32px 28px;box-shadow:var(--shadow)}.login-card h1{margin:0 0 6px;font-size:19px}.login-card p{margin:0 0 20px;color:var(--text-muted)}.tag-list{display:flex;flex-wrap:wrap;gap:6px}
