:root {
    --bg: #f4f5fb; --surface: #fff; --surface-2: #fafbff; --ink: #14152b; --ink-soft: #5b6080; --ink-faint: #9498b8;
    --line: #ecedf5; --line-2: #f4f5fa; --brand: #6161ff; --brand-soft: #eeeeff;
    --green: #00b884; --green-soft: #e0f7f0; --amber: #f5a623; --amber-soft: #fdf0db;
    --red: #e54d6a; --red-soft: #fde8ec; --purple: #9b5de5; --purple-soft: #f1e8fc; --teal: #00c2cb;
    --shadow-sm: 0 1px 2px rgba(20,21,43,.04), 0 1px 3px rgba(20,21,43,.06); --r: 16px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Figtree', system-ui, sans-serif; background: var(--bg); color: var(--ink); -webkit-font-smoothing: antialiased; line-height: 1.5; }
a { color: inherit; }
.mono { font-family: 'JetBrains Mono', monospace; font-feature-settings: "tnum"; letter-spacing: -.5px; }
.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.sidebar { background: var(--surface); border-right: 1px solid var(--line); padding: 22px 16px; display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; }
.brand { display: flex; align-items: center; gap: 11px; padding: 4px 8px 26px; }
.brand-mark { width: 34px; height: 34px; border-radius: 10px; background: linear-gradient(135deg,#6161ff,#8b7bff); display: grid; place-items: center; color: #fff; box-shadow: 0 4px 12px rgba(97,97,255,.35); }
.brand-name { font-weight: 800; font-size: 17px; letter-spacing: -.4px; }
.brand-name small { display: block; font-weight: 600; font-size: 10.5px; color: var(--ink-faint); }
nav { display: flex; flex-direction: column; gap: 3px; }
.nav-item { display: flex; align-items: center; gap: 11px; padding: 9px 11px; border-radius: 10px; color: var(--ink-soft); font-size: 14px; font-weight: 600; text-decoration: none; }
.nav-item svg { width: 18px; height: 18px; }
.nav-item:hover { background: var(--surface-2); color: var(--ink); }
.nav-item.active { background: var(--brand-soft); color: var(--brand); }
.nav-sec { font-size: 10px; font-weight: 700; color: var(--ink-faint); text-transform: uppercase; letter-spacing: .7px; padding: 14px 11px 6px; }
.side-foot { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--line); }
.user-chip { display: flex; align-items: center; gap: 10px; padding: 8px; border-radius: 10px; }
.avatar { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 13px; flex-shrink: 0; background: linear-gradient(135deg,#6161ff,#8b7bff); }
.user-chip .name { font-size: 13.5px; font-weight: 700; }
.user-chip .role { font-size: 11.5px; color: var(--ink-faint); font-weight: 600; }
.logout { display: block; margin-top: 8px; font-size: 12.5px; font-weight: 600; color: var(--red); text-decoration: none; padding: 6px 8px; border-radius: 8px; }
.logout:hover { background: var(--red-soft); }
.main { padding: 26px 34px 60px; max-width: 1280px; }
.page-title { font-size: 27px; font-weight: 800; letter-spacing: -.7px; margin-bottom: 4px; }
.page-sub { color: var(--ink-soft); font-size: 14px; font-weight: 500; margin-bottom: 24px; }
.flash { background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; padding: 12px 16px; border-radius: 12px; font-size: 14px; font-weight: 600; margin-bottom: 20px; }
.kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-bottom: 22px; }
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow-sm); }
.kpi { padding: 18px 20px; }
.kpi .k-label { font-size: 12.5px; font-weight: 700; color: var(--ink-soft); display: flex; align-items: center; gap: 8px; }
.kpi .k-ico { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; }
.kpi .k-ico svg { width: 16px; height: 16px; }
.kpi .k-val { font-size: 26px; font-weight: 700; margin-top: 12px; }
.card-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px 6px; }
.card-title { font-size: 16px; font-weight: 800; letter-spacing: -.3px; }
.card-title .sub { display: block; font-size: 12.5px; color: var(--ink-faint); font-weight: 600; margin-top: 2px; }
.tbl { width: 100%; border-collapse: collapse; }
.tbl th { text-align: left; font-size: 11px; font-weight: 700; color: var(--ink-faint); text-transform: uppercase; letter-spacing: .5px; padding: 13px 18px; border-bottom: 1px solid var(--line); }
.tbl th.r, .tbl td.r { text-align: right; }
.tbl td { padding: 13px 18px; border-bottom: 1px solid var(--line-2); font-size: 13.5px; font-weight: 600; vertical-align: middle; }
.tbl tr:last-child td { border-bottom: none; }
.tbl tbody tr:hover td { background: var(--surface-2); }
.pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 700; padding: 4px 11px; border-radius: 20px; }
.pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.pill.green { color: #07875c; background: var(--green-soft); }
.pill.amber { color: #b3700c; background: var(--amber-soft); }
.pill.blue { color: #1c5fac; background: #e6f1fd; }
.pill.grey { color: #5b6080; background: #eef0f6; }
.pill.violet { color: #4b3fd6; background: var(--brand-soft); }
.pill.red { color: #c0364f; background: var(--red-soft); }
.firm-badge { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 7px; }
.firm-trifox { background: var(--brand-soft); color: var(--brand); }
.firm-softsystems { background: #e3f7f8; color: #0a8a91; }
select, input { font-family: inherit; font-size: 13px; font-weight: 600; color: var(--ink); padding: 7px 9px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface-2); outline: none; }
select:focus, input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); background: #fff; }
.btn { display: inline-flex; align-items: center; gap: 7px; border: none; cursor: pointer; font-family: inherit; font-weight: 700; font-size: 13px; padding: 8px 14px; border-radius: 10px; }
.btn-primary { background: var(--brand); color: #fff; }
.btn-primary:hover { filter: brightness(1.05); }
/* login */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 20px; }
.login-card { background: var(--surface); border: 1px solid var(--line); border-radius: 22px; padding: 44px 40px; width: 100%; max-width: 410px; box-shadow: 0 25px 50px -12px rgba(20,21,43,.12); }
.login-card h1 { font-size: 24px; font-weight: 800; letter-spacing: -.4px; margin: 18px 0 4px; }
.login-card p.s { color: var(--ink-faint); font-size: 14px; font-weight: 500; margin-bottom: 26px; }
.fld { margin-bottom: 16px; }
.fld label { display: block; font-size: 12.5px; font-weight: 700; color: var(--ink-soft); margin-bottom: 7px; }
.fld input { width: 100%; padding: 11px 13px; font-size: 14.5px; }
.alert-err { background: var(--red-soft); color: #a3243a; border: 1px solid #f5c2cc; padding: 11px 14px; border-radius: 10px; font-size: 13.5px; font-weight: 600; margin-bottom: 18px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
