/* iWiFi — кабинет партнёра (partner.iwifi.ru). Компактная тёмная тема. */
:root{--bg:#0d1420;--panel:#151d2a;--inset:#0b1220;--line:#263041;--fg:#e6edf3;--mut:#8aa0b4;--acc:#3b82f6;--acc2:#6366f1;--ok:#22c55e;--warn:#f59e0b;--danger:#ef4444}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased}
a{color:var(--acc);text-decoration:none}a:hover{text-decoration:underline}
.mut{color:var(--mut)}.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px}
code{background:var(--inset);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:12px}

/* топбар */
.topbar{display:flex;align-items:center;gap:14px;padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:800;display:flex;align-items:center;gap:9px;white-space:nowrap}
.brand .logo{width:26px;height:26px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;font-size:12px;font-weight:800}
.nav{display:flex;gap:3px;margin:0 auto 0 8px;flex:1}
.nav a{color:var(--mut);padding:8px 13px;border-radius:9px;font-weight:600;font-size:13.5px}
.nav a:hover{background:#1b2533;color:var(--fg);text-decoration:none}
.nav a.on{background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff}
.who{display:flex;align-items:center;gap:12px;color:var(--mut)}
.who-name{font-size:13px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logout{color:var(--mut)}.logout:hover{color:var(--danger);text-decoration:none}

main{max-width:1100px;margin:0 auto;padding:22px}
main.narrow{max-width:520px}
h1{font-size:22px;font-weight:800;margin:4px 0 18px}
h2{font-size:15px;margin:0 0 10px}
.cnt{background:var(--inset);color:var(--mut);border-radius:20px;padding:1px 10px;font-size:12px;font-weight:700;border:1px solid var(--line)}

/* KPI */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:13px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:17px}
.kpi-v{font-size:26px;font-weight:800;line-height:1.1}
.kpi-v.ok{color:var(--ok)}
.kpi-l{color:var(--mut);font-size:12.5px;margin-top:6px}
.kpi.money{background:linear-gradient(160deg,color-mix(in srgb,var(--acc) 16%,var(--panel)),var(--panel));border-color:color-mix(in srgb,var(--acc) 35%,var(--line))}
.kpi.money .kpi-v{color:var(--acc)}

/* карточки/формы */
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px}
.card label{display:flex;flex-direction:column;gap:6px;color:var(--mut);font-size:12px;margin-bottom:12px}
.card input,.card textarea{background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:11px;color:var(--fg);font-size:14px;font-family:inherit}
.card input:focus,.card textarea:focus{border-color:var(--acc);outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 18%,transparent)}
.card textarea{resize:vertical;min-height:64px}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:10px 16px;color:var(--fg);font-weight:600;font-size:14px;cursor:pointer;transition:filter .12s,background .12s}
.btn:hover{background:#1b2533}
.btn.primary{background:linear-gradient(135deg,var(--acc),var(--acc2));border-color:transparent;color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.ref-row{display:flex;gap:8px}
.ref-row input{flex:1;background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:11px;color:var(--fg);font-size:13px;font-family:ui-monospace,Menlo,Consolas,monospace}

/* таблицы */
.tbl-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px;background:var(--panel)}
table{border-collapse:collapse;width:100%;font-size:13px;white-space:nowrap}
thead th{background:var(--inset);color:var(--mut);text-align:left;padding:11px 13px;border-bottom:1px solid var(--line);font-weight:600;font-size:12px}
tbody td{padding:11px 13px;border-bottom:1px solid var(--line)}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#1b2533}
.chip{display:inline-block;border-radius:8px;padding:2px 9px;font-size:11.5px;font-weight:600;background:var(--line);color:var(--mut)}
.chip.ok{background:color-mix(in srgb,var(--ok) 16%,transparent);color:var(--ok)}
.chip.warn{background:color-mix(in srgb,var(--warn) 16%,transparent);color:var(--warn)}
.chip.acc{background:color-mix(in srgb,var(--acc) 16%,transparent);color:var(--acc)}
.chip.mut{background:var(--line);color:var(--mut)}
.terms{margin-top:14px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:color-mix(in srgb,var(--acc) 5%,transparent)}
.terms-t{font-weight:700;font-size:13px}

.empty{color:var(--mut);padding:20px;background:var(--panel);border:1px solid var(--line);border-radius:14px}
.error{background:color-mix(in srgb,var(--danger) 14%,var(--panel));border:1px solid color-mix(in srgb,var(--danger) 40%,transparent);color:var(--danger);padding:10px 13px;border-radius:10px;margin-bottom:12px;font-size:13px}
.notice{background:color-mix(in srgb,var(--ok) 14%,var(--panel));border:1px solid color-mix(in srgb,var(--ok) 40%,transparent);color:var(--ok);padding:10px 13px;border-radius:10px;margin-bottom:12px;font-size:13px}

/* вход */
.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:16px;background:radial-gradient(1000px 400px at 50% -10%,color-mix(in srgb,var(--acc) 14%,transparent),transparent)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;width:350px;display:flex;flex-direction:column;gap:13px;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.login-card .brand{font-size:16px;justify-content:center;margin-bottom:4px}
.login-card label{display:flex;flex-direction:column;gap:6px;color:var(--mut);font-size:12px}
.login-card input{background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:11px;color:var(--fg);font-size:14px}
.login-card input:focus{border-color:var(--acc);outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 18%,transparent)}
.login-card button{background:linear-gradient(135deg,var(--acc),var(--acc2));border:0;border-radius:10px;padding:12px;color:#fff;font-weight:700;cursor:pointer;font-size:14px}
.login-card .hint{color:var(--mut);font-size:11px;text-align:center;line-height:1.5}

@media (max-width:640px){
  main{padding:14px}
  .topbar{flex-wrap:wrap;gap:8px 10px}
  .nav{order:3;flex-basis:100%;margin:0;overflow-x:auto}
  .who-name{display:none}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  input,textarea{font-size:16px}
}
