:root{
  --bg:#0d1014; --panel:#151a21; --panel2:#1b222c; --line:#262e3a;
  --txt:#dfe6ee; --muted:#7d8aa0; --accent:#3ddc84; --accent2:#4aa3ff;
  --red:#ff5c6c; --amber:#ffb02e; --chip:#222b38;
  --shadow:0 6px 24px rgba(0,0,0,.35);
  font-synthesis:none;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--txt);
  font:14px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted);font-weight:400}

/* ---------- login ---------- */
.login-body{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(1200px 600px at 50% -10%,#15212c,transparent),var(--bg)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:32px 28px;width:320px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.login-logo{font-size:26px;font-weight:800;letter-spacing:-.5px;text-align:center;margin-bottom:6px}
.login-logo span{color:var(--accent2)}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}
.login-card input{background:var(--panel2);border:1px solid var(--line);border-radius:9px;
  padding:11px 12px;color:var(--txt);font-size:14px;outline:none}
.login-card input:focus{border-color:var(--accent2)}
.login-card button{margin-top:6px;background:var(--accent2);color:#04101e;border:0;border-radius:9px;
  padding:12px;font-weight:700;font-size:14px;cursor:pointer}
.login-card button:hover{filter:brightness(1.06)}
.login-error{background:rgba(255,92,108,.12);border:1px solid rgba(255,92,108,.4);
  color:#ffb3bb;border-radius:9px;padding:9px 11px;font-size:13px;text-align:center}

/* ---------- layout ---------- */
.layout{display:grid;grid-template-columns:210px 1fr;min-height:100vh}
.sidebar{background:#0f141a;border-right:1px solid var(--line);padding:18px 14px;
  display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh}
.brand{font-size:20px;font-weight:800;letter-spacing:-.5px;padding:4px 6px}
.brand span{color:var(--accent2)}
.side-nav{display:flex;flex-direction:column;gap:2px}
.side-nav a{padding:9px 10px;border-radius:8px;color:var(--muted);font-weight:500}
.side-nav a.active{background:var(--panel2);color:var(--txt)}
.side-nav a[data-soon]{opacity:.45;cursor:not-allowed}
.side-nav a[data-soon]::after{content:" • скоро";font-size:10px}
.nav-spoiler summary{list-style:none;cursor:pointer;padding:9px 10px;border-radius:8px;
  color:var(--muted);font-weight:500;display:flex;align-items:center;gap:6px;user-select:none}
.nav-spoiler summary::-webkit-details-marker{display:none}
.nav-spoiler summary::before{content:"▸";font-size:10px;transition:transform .15s;color:var(--muted)}
.nav-spoiler[open] summary::before{transform:rotate(90deg)}
.nav-spoiler summary:hover{color:var(--txt)}
.nav-spoiler a{display:block;padding:8px 10px 8px 22px;border-radius:8px;color:var(--muted);font-weight:500}
.nav-spoiler a.active{background:var(--panel2);color:var(--txt)}
.logout{font-size:12px;color:var(--muted);padding:8px 6px;border-top:1px solid var(--line);margin-top:auto}
.logout:hover{color:var(--red)}

.main{padding:18px 22px 60px;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.btn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:9px;
  padding:8px 14px;font-weight:600;font-size:13px;cursor:pointer}
.btn:hover{border-color:var(--accent2)}

/* ---------- фильтры ---------- */
.filterbar{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:16px}
.fgroup{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.fgroup.fowner{margin-left:auto;padding-left:14px;border-left:1px solid var(--line)}
.fsep{width:1px;align-self:stretch;background:var(--line);margin:0 4px}
.fchip{background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:8px;
  padding:6px 11px;font-size:12.5px;font-weight:600;cursor:pointer;line-height:1;display:inline-flex;align-items:center;gap:4px}
.fchip:hover{border-color:var(--accent2);color:var(--txt)}
.fchip.on{background:var(--accent2);border-color:var(--accent2);color:#04101e}
.fchip.fsel{padding:6px 9px;appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 13px) 50%,calc(100% - 8px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:24px}
.fchip.fsel.on{background-image:linear-gradient(45deg,transparent 50%,#04101e 50%),linear-gradient(135deg,#04101e 50%,transparent 50%)}
.fchip.fsel option{background:var(--panel);color:var(--txt)}
.fchip.finput{cursor:text;min-width:280px;color:var(--txt)}
.fchip.finput::placeholder{color:var(--muted)}
.fchip.finput:focus{border-color:var(--accent2);outline:none}
.frange{font-size:12px}

/* ---------- kpis ---------- */
.kpis{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:10px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:12px 13px;min-width:0}
.kpi .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.kpi .val{font-size:21px;font-weight:800;margin-top:6px;letter-spacing:-.5px;white-space:nowrap}
.kpi .val.green{color:var(--accent)} .kpi .val.amber{color:var(--amber)}

/* ---------- panel + table ---------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.panel-head h2{margin:0;font-size:14px}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{position:sticky;top:0;background:#121821;text-align:left;padding:10px 12px;color:var(--muted);
  font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-bottom:1px solid var(--line)}
th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}
tbody td{padding:9px 12px;border-bottom:1px solid #1d2530;white-space:nowrap}
tbody tr:hover{background:var(--panel2)}
.tag{display:inline-block;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600;background:var(--chip);color:var(--txt)}
.t-sub{background:rgba(74,163,255,.16);color:var(--accent2)}
.t-don{background:rgba(61,220,132,.16);color:var(--accent)}
.t-dig{background:rgba(255,176,46,.16);color:var(--amber)}
.t-ref{color:var(--red);font-weight:600}
.acc{display:inline-block;border-radius:5px;padding:2px 9px;font-size:11px;font-weight:700;letter-spacing:.3px;background:var(--chip);color:var(--txt)}
.acc-yura{background:rgba(74,163,255,.16);color:var(--accent2)}
.acc-lena{background:rgba(61,220,132,.16);color:var(--accent)}
tr.tot td{font-weight:800;border-top:2px solid var(--line);background:#121821}
tr.grp[data-k]{cursor:pointer}
tr.grp .caret{display:inline-block;width:14px;color:var(--muted);font-size:10px;transition:transform .15s}
tr.grp.open .caret{transform:rotate(90deg)}
tr.sub{background:#11161d}
tr.sub td{color:var(--muted);font-size:12px;padding-top:6px;padding-bottom:6px}
tr.sub.hidden{display:none}
.acc-fd{background:rgba(168,130,255,.16);color:#b79bff}
.acc-rd{background:rgba(74,163,255,.16);color:var(--accent2)}
.acc-cancel{background:rgba(125,138,160,.16);color:var(--muted)}
.acc-old{background:rgba(90,200,180,.15);color:#5fd0bd}
.acc-new{background:rgba(255,176,46,.14);color:var(--amber)}
.pb-ok{background:rgba(61,220,132,.16);color:var(--accent)}
.pb-err{background:rgba(255,92,108,.16);color:var(--red)}
.btn:disabled{opacity:.5;cursor:default}
.pager{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--line)}
.pager.pager-top{border-top:0;border-bottom:1px solid var(--line)}
.pager.pager-top:empty{display:none}
.pager .muted{margin-right:auto;font-size:12px}
.pbtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:8px;
  padding:6px 11px;font-size:12.5px;font-weight:600;cursor:pointer}
.pbtn:hover:not(:disabled){border-color:var(--accent2)}
.pbtn:disabled{opacity:.4;cursor:default}
.ppos{font-size:12.5px;color:var(--muted);min-width:54px;text-align:center}
