/* Сервис ввода данных Систематики — дизайн-система мокапов v2.
   Стиль: Data-Dense Dashboard (ui-ux-pro-max) + bold-минимализм/токены (modern-web-design).
   Палитра дашборда Совета, Montserrat, стандарт Кирилла. Светлая тема. */
@import url('fonts/montserrat.css');

:root{
  /* поверхности / текст */
  --bg:#F1EFEC; --panel:#FFFFFF; --panel-2:#FAF9F7;
  --ink:#14233A; --ink-2:#5C6675; --ink-3:#949BA6;
  /* бренд: яркий акцент для активных состояний/иконок; -ink для текста-на-синем (контраст ≥4.5) */
  --accent:#4C8DD3; --accent-ink:#2C6DB5; --accent-press:#255E9C;
  --accent-soft:rgba(76,141,211,.10); --accent-soft-2:rgba(76,141,211,.18);
  --border:#E7E3DD; --border-2:#F0ECE6;
  /* семантика статусов (контраст текста ≥4.5 на soft-фоне) */
  --ok:#1F8A5B; --ok-soft:rgba(31,138,91,.12);
  --warn:#B7791F; --warn-soft:rgba(183,121,31,.13);
  --bad:#C53A36; --bad-soft:rgba(197,58,54,.10);
  --info:#2C6DB5; --info-soft:rgba(44,109,181,.10);
  /* радиусы / тени (elevation scale) / motion-токены */
  --r:18px; --r-sm:12px; --r-xs:9px;
  --e1:0 1px 2px rgba(20,35,58,.05); --e2:0 4px 16px rgba(20,35,58,.07);
  --e3:0 14px 38px rgba(20,35,58,.12);
  --dur-fast:150ms; --dur:230ms; --ease:cubic-bezier(.4,0,.2,1); --ease-spring:cubic-bezier(.34,1.56,.64,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Montserrat',system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
.muted{color:var(--ink-2)} .small{font-size:12px} .tnum{font-variant-numeric:tabular-nums}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
svg{display:block} .ico{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;flex:none}

/* ---- бренд ---- */
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15.5px;letter-spacing:-.2px}
.brand .logo{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent-press));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;box-shadow:var(--e1)}
.sys-cap{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;color:var(--ink-2);background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:5px 11px;box-shadow:var(--e1)}
.sys-cap .dot{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-press))}

/* ---- кнопки (tactile press) ---- */
.btn-primary,.btn-s,.btn-ai{font-family:inherit;font-weight:600;border-radius:11px;cursor:pointer;border:1px solid transparent;font-size:13.5px;display:inline-flex;align-items:center;gap:7px;transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease);min-height:40px}
.btn-primary{background:var(--accent-ink);color:#fff;padding:0 17px;box-shadow:var(--e1)}
.btn-primary:hover{background:var(--accent-press);box-shadow:var(--e2)}
.btn-primary:active{transform:scale(.97)}
.btn-s{background:var(--panel);color:var(--ink);border-color:var(--border);padding:0 14px}
.btn-s:hover{border-color:var(--accent);color:var(--accent-ink)}
.btn-ai{background:linear-gradient(135deg,#7C5CFF,#E36BB0);color:#fff;padding:0 14px}
.btn-ghost{background:transparent;border:none;color:var(--ink-2);cursor:pointer;font:inherit;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{color:var(--accent-ink)}

/* ---- поля формы ---- */
.field{display:block;margin-bottom:15px}
.field label{display:flex;gap:4px;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.field label .req{color:var(--bad)}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:var(--panel);border:1px solid var(--border);border-radius:11px;padding:11px 13px;transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field input::placeholder{color:var(--ink-3)}
.field .help{font-size:11.5px;color:var(--ink-3);margin-top:5px}
.field.err input{border-color:var(--bad);box-shadow:0 0 0 3px var(--bad-soft)}
.field .err-msg{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--bad);margin-top:5px;font-weight:500}
.field.ok input{border-color:var(--ok)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.input-icon{position:relative} .input-icon .ico{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--ink-3);cursor:pointer}

/* ---- каркас ---- */
.app{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column}
.side-brand{padding:4px 8px 18px}
.nav-group{margin-top:12px}
.nav-cap{font-size:10.5px;font-weight:700;letter-spacing:.8px;color:var(--ink-3);padding:0 10px 7px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:11px;font-size:13.5px;font-weight:500;color:var(--ink-2);cursor:pointer;margin-bottom:2px;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease);position:relative}
.nav-item:hover{background:var(--panel-2);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-14px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.nav-item .badge{margin-left:auto;font-size:11px;font-weight:700;color:var(--ink-3)}
.nav-item.active .badge{color:var(--accent-ink)}
.side-foot{margin-top:auto;border-top:1px solid var(--border-2);padding-top:13px;display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:10px;background:var(--accent-soft-2);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none}

/* ---- основная область ---- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:17px 28px;border-bottom:1px solid var(--border);background:var(--panel)}
.topbar .tt{display:flex;flex-direction:column;gap:2px}
.crumb{font-size:11.5px;font-weight:600;color:var(--ink-3)}
.topbar h2{font-size:19px;font-weight:700;letter-spacing:-.3px}
.topbar .right{display:flex;align-items:center;gap:11px}
.role-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--ink-2);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:6px 12px}
.role-pill .d{width:7px;height:7px;border-radius:50%;background:var(--ok)}
.content{padding:22px 28px;display:flex;flex-direction:column;gap:20px}

/* ---- KPI ---- */
.section-grid{display:grid;gap:14px}
.sg-3{grid-template-columns:repeat(3,1fr)} .sg-4{grid-template-columns:repeat(4,1fr)}
.kpi-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--e1);padding:15px 18px;transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}
.kpi-card:hover{box-shadow:var(--e2);transform:translateY(-2px)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.kpi-ico{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent-ink)}
.kpi-ico.g{background:var(--ok-soft);color:var(--ok)} .kpi-ico.w{background:var(--warn-soft);color:var(--warn)}
.kpi-card .lab{font-size:12px;font-weight:600;color:var(--ink-2)}
.kpi-card .val{font-size:26px;font-weight:700;letter-spacing:-.6px;line-height:1.1}
.kpi-card .suf{font-size:13px;font-weight:600;color:var(--ink-3);margin-left:3px}

/* ---- панель / таблица ---- */
.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--e1);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--border-2)}
.panel-head h3{font-size:14.5px;font-weight:700}
.panel-head .tools{display:flex;gap:9px}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-3);padding:11px 20px;border-bottom:1px solid var(--border-2);white-space:nowrap;cursor:pointer;user-select:none}
th .sort{opacity:.5;margin-left:3px}
th.up .sort,th.down .sort{opacity:1;color:var(--accent-ink)}
td{padding:13px 20px;border-bottom:1px solid var(--border-2);color:var(--ink);vertical-align:middle}
tbody tr{transition:background var(--dur-fast) var(--ease)}
tbody tr:hover{background:var(--panel-2)}
tr:last-child td{border-bottom:none}
.co{font-weight:600} .sub-2{color:var(--ink-2);font-size:12px;margin-top:1px}
.num{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}
.chip .d{width:6px;height:6px;border-radius:50%;background:currentColor}
.chip.ok{background:var(--ok-soft);color:var(--ok)} .chip.warn{background:var(--warn-soft);color:var(--warn)}
.chip.info{background:var(--info-soft);color:var(--info)} .chip.muted{background:var(--border-2);color:var(--ink-2)}
.tag{display:inline-flex;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:7px;background:var(--panel-2);border:1px solid var(--border);color:var(--ink-2)}
.link{color:var(--accent-ink);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.exp{display:inline-flex;align-items:center;gap:9px;cursor:pointer}
.exp .caret{color:var(--ink-3);transition:transform var(--dur-fast) var(--ease)}
.exp.open .caret{transform:rotate(90deg);color:var(--accent-ink)}
.child td{background:var(--panel-2);padding-left:42px}
.child .co{font-weight:500}
.corner{position:fixed;right:18px;bottom:16px}

/* ---- модалка/панель формы ---- */
.scrim{position:fixed;inset:0;background:rgba(20,35,58,.45);display:flex;align-items:center;justify-content:center}
.modal{width:520px;background:var(--panel);border-radius:var(--r);box-shadow:var(--e3);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-2)}
.modal-head h3{font-size:16px;font-weight:700}
.modal-head .x{color:var(--ink-3);cursor:pointer}
.modal-body{padding:20px 22px;max-height:70vh;overflow:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:15px 22px;border-top:1px solid var(--border-2);background:var(--panel-2)}
.sect-lab{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-3);margin:4px 0 11px}

/* ---- права: переключатели/чекбоксы ---- */
.seg{display:inline-flex;background:var(--panel-2);border:1px solid var(--border);border-radius:11px;padding:3px;gap:2px}
.seg .opt{padding:7px 14px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--ink-2);cursor:pointer}
.seg .opt.on{background:var(--panel);color:var(--accent-ink);box-shadow:var(--e1)}
.perm{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-2)}
.perm:last-child{border-bottom:none}
.perm .t{font-size:13.5px;font-weight:600} .perm .s{font-size:11.5px;color:var(--ink-3)}
.switch{width:42px;height:24px;border-radius:999px;background:var(--accent);position:relative;flex:none}
.switch::after{content:"";position:absolute;top:3px;left:21px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--e1)}
.switch.off{background:var(--border)} .switch.off::after{left:3px}
