/* ===== subsfin — светлый минимал SaaS ===== */
:root{
  --bg:#f5f6f8; --surface:#ffffff; --border:#eceef2; --border-strong:#e2e5ea;
  --text:#171a21; --muted:#6b7280; --muted-2:#9aa1ac;
  --accent:#4f46e5; --accent-hover:#4338ca; --accent-soft:#eef2ff;
  --red:#e11d48; --red-soft:#fff1f3;
  --blue:#2563eb; --blue-soft:#eff6ff;
  --green:#059669; --green-soft:#ecfdf5;
  --amber:#d97706; --amber-soft:#fffbeb;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
  --shadow-md:0 4px 14px rgba(16,24,40,.08);
  --radius:16px; --radius-sm:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--text); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:650;letter-spacing:-.01em}

/* ---- layout ---- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:236px;flex:0 0 236px;background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:9px;font-weight:750;font-size:1.15rem;padding:6px 10px 22px;letter-spacing:-.02em}
.nav{display:flex;flex-direction:column;gap:3px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--muted);font-weight:550;transition:.15s}
.nav-item svg{width:18px;height:18px;opacity:.85}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item.active{background:var(--accent-soft);color:var(--accent)}
.nav-item.active svg{opacity:1}
.sidebar .spacer{flex:1}
.logout{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--muted-2);font-weight:550}
.logout:hover{background:var(--bg);color:var(--red)}
.logout svg{width:18px;height:18px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:22px 34px 10px}
.topbar h1{font-size:1.5rem}
.topbar .sub{color:var(--muted);font-size:.9rem;font-weight:500}
.content{padding:14px 34px 48px;max-width:1120px;width:100%}

/* ---- card ---- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.card-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:14px}
.grid-2{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;margin-bottom:18px}
.section-gap{margin-bottom:18px}

/* ---- KPI ---- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-bottom:18px}
.kpi{display:flex;flex-direction:column;gap:12px;transition:.18s}
.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kpi-top{display:flex;align-items:center;gap:10px}
.chip{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:1rem}
.chip-red{background:var(--red-soft)} .chip-blue{background:var(--blue-soft)}
.chip-green{background:var(--green-soft)} .chip-amber{background:var(--amber-soft)}
.kpi-label{font-size:.83rem;color:var(--muted);font-weight:550}
.kpi-value{font-size:1.9rem;font-weight:730;letter-spacing:-.02em;line-height:1}

/* ---- table ---- */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.9rem}
thead th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-2);font-weight:600;padding:0 14px 10px}
tbody td{padding:13px 14px;border-top:1px solid var(--border)}
tbody tr:hover{background:#fafbfc}
td .muted{color:var(--muted-2);font-size:.8rem}
td strong{font-weight:600}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:.76rem;font-weight:600;white-space:nowrap}
.b-green{background:var(--green-soft);color:var(--green)}
.b-amber{background:var(--amber-soft);color:var(--amber)}
.b-red{background:var(--red-soft);color:var(--red)}
.b-gray{background:#f1f3f5;color:var(--muted)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:10px;font-weight:600;font-size:.9rem;border:1px solid transparent;cursor:pointer;transition:.15s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover)}
.btn-ghost{background:var(--surface);border-color:var(--border-strong);color:var(--text)}
.btn-ghost:hover{background:var(--bg)}
.icon-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--muted-2);display:inline-grid;place-items:center;transition:.15s}
.icon-btn:hover{background:var(--bg);color:var(--text)}
.icon-btn.danger:hover{background:var(--red-soft);color:var(--red)}
.icon-btn.pay:hover{background:var(--green-soft);color:var(--green)}
.actions{display:flex;gap:2px;justify-content:flex-end}
.actions form{margin:0}

/* ---- forms ---- */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px}
label{display:block;font-size:.83rem;font-weight:550;color:var(--muted);margin-bottom:6px}
input,select{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:10px;font:inherit;font-size:.9rem;background:var(--surface);color:var(--text);transition:.15s}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.check{display:flex;align-items:center;gap:9px;font-weight:500;color:var(--text);margin:0 0 10px}
.check input{width:auto}
.form-actions{display:flex;gap:10px;margin-top:6px}

/* ---- misc ---- */
canvas{max-height:270px}
.empty{color:var(--muted);text-align:center;padding:26px}
@media(max-width:820px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;flex-direction:row;align-items:center;position:static;padding:10px 14px;gap:6px;overflow-x:auto}
  .brand{padding:0 12px 0 4px} .nav{flex-direction:row} .sidebar .spacer{flex:0}
  .grid-2{grid-template-columns:1fr}
  .topbar,.content{padding-left:16px;padding-right:16px}
}
