/* ============================================================
   Паспорта качества EFELE — дизайн-система
   Токены: шкала отступов 4px, 3 радиуса, 3 тени, рамп бренда.
   Красный — только статусы/CTA/активные состояния (≤10% экрана).
   ============================================================ */
:root{
  /* бренд EFELE (красный из фирменного логотипа: #C40007) */
  --efele-50:#fdf1f1; --efele-100:#fbe1e1; --efele-200:#f6c3c4;
  --efele-600:#c40007; --efele-700:#9e0006; --efele-800:#7d0005;
  /* серые */
  --g-25:#fcfcfd; --g-50:#f9fafb; --g-100:#f2f4f7; --g-200:#e4e7ec;
  --g-300:#d0d5dd; --g-400:#98a2b3; --g-500:#667085; --g-700:#344054; --g-900:#101828;
  /* роли */
  --bg:#f5f6f8; --panel:#fff; --line:var(--g-200);
  --txt:var(--g-900); --muted:var(--g-500);
  --ok:#067647; --ok-bg:#ecfdf3; --ok-line:#abefc6;
  --warn:#b54708; --warn-bg:#fffaeb; --warn-line:#fedf89;
  --bad:#b42318; --bad-bg:#fef3f2; --bad-line:#fecdca;
  /* геометрия */
  --r-sm:8px; --r-md:12px; --r-lg:16px;
  --sh-sm:0 1px 2px rgb(16 24 40 / .05);
  --sh-md:0 4px 8px -2px rgb(16 24 40 / .08), 0 2px 4px -2px rgb(16 24 40 / .04);
  --sh-lg:0 20px 40px -8px rgb(16 24 40 / .14), 0 8px 16px -6px rgb(16 24 40 / .06);
  --ring:0 0 0 3px rgb(214 0 28 / .10);
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 -apple-system,"SF Pro Text","Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--txt);-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
.muted{color:var(--muted)}
code{font:12px/1.4 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:var(--g-100);
  padding:1px 5px;border-radius:4px}

.ic{width:16px;height:16px;flex:none;vertical-align:-3px}

/* ---------------- кнопки ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;
  border:1px solid var(--g-300);background:#fff;color:var(--g-700);
  padding:8px 14px;border-radius:var(--r-sm);font-weight:600;font-size:14px;cursor:pointer;
  box-shadow:var(--sh-sm);
  transition:background-color .15s ease,border-color .15s ease,box-shadow .15s ease,color .15s ease}
.btn:hover{background:var(--g-50);border-color:var(--g-400)}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn.primary{background:var(--efele-600);border-color:var(--efele-600);color:#fff;
  box-shadow:inset 0 1px 0 rgb(255 255 255/.12),0 1px 2px rgb(214 0 28/.3)}
.btn.primary:hover{background:var(--efele-700);border-color:var(--efele-700)}
.btn.primary:active{background:var(--efele-800)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted);box-shadow:none}
.btn.ghost:hover{background:var(--g-100);color:var(--g-700)}
.btn.sm{padding:4px 10px;font-size:12.5px;gap:5px;box-shadow:none}
.btn:disabled{opacity:.55;cursor:wait;pointer-events:none}
.btn .spin{animation:rot 0.9s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}

/* стилизованный file-input */
.file-btn{position:relative;overflow:hidden}
.file-btn input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.file-name{font-size:12.5px;color:var(--muted);max-width:260px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}

/* ---------------- логин ---------------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:
    radial-gradient(900px 480px at 85% -10%, var(--efele-100) 0%, transparent 55%),
    radial-gradient(700px 420px at -10% 105%, #e8ecf3 0%, transparent 55%),
    var(--bg)}
.login-wrap.over{position:fixed;inset:0;z-index:40;background:rgb(16 24 40/.45);
  backdrop-filter:blur(3px)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:36px 32px 28px;width:384px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--sh-lg)}
.login-card .brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:8px}
.logo-login{width:188px;height:44px;color:var(--efele-600)}
.logo-head{width:81px;height:19px;color:var(--efele-600);flex:none}
.login-card .sub{color:var(--muted);font-size:13px}
.login-card label{display:flex;flex-direction:column;gap:6px}
.login-card input{padding:10px 12px;border:1px solid var(--g-300);border-radius:var(--r-sm);
  font-size:15px;transition:border-color .15s ease,box-shadow .15s ease}
.login-card input:focus{outline:none;border-color:var(--efele-600);box-shadow:var(--ring)}
.err{color:var(--bad);font-size:13px;min-height:18px;text-align:center}

/* лейблы полей */
.fld{display:flex;flex-direction:column;gap:6px}
.fld,.login-card label{font-size:11px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted)}
.fld input,.fld select{padding:9px 12px;border:1px solid var(--g-300);border-radius:var(--r-sm);
  font-size:14px;background:#fff;color:var(--txt);font-weight:400;letter-spacing:normal;
  transition:border-color .15s ease,box-shadow .15s ease}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--efele-600);box-shadow:var(--ring)}
.fld input.invalid{border-color:var(--bad);box-shadow:0 0 0 3px rgb(180 35 24/.10)}
.req::after{content:" *";color:var(--efele-600)}

/* ---------------- шапка ---------------- */
.top{display:flex;align-items:center;gap:28px;height:56px;padding:0 24px;background:var(--panel);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.brand-sm{font-weight:700;font-size:15px;white-space:nowrap;display:flex;align-items:center;gap:10px}
.tabs{display:flex;gap:4px;height:100%;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{display:inline-flex;align-items:center;gap:7px;border:none;background:transparent;
  padding:0 12px;height:100%;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;
  color:var(--muted);font-weight:600;font-size:14px;white-space:nowrap;
  transition:color .15s ease,border-color .15s ease}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--efele-600);border-bottom-color:var(--efele-600)}
.who{margin-left:auto}

/* меню пользователя */
.umenu{position:relative}
.umenu summary{list-style:none;display:flex;align-items:center;gap:9px;cursor:pointer;
  padding:6px 10px;border-radius:var(--r-sm);font-size:13px;color:var(--g-700);
  transition:background-color .15s ease}
.umenu summary::-webkit-details-marker{display:none}
.umenu summary:hover{background:var(--g-100)}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--g-100);color:var(--g-700);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:none;
  border:1px solid var(--g-200)}
.uname{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ucode{color:var(--muted);font-size:12px}
.umenu-pop{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);
  border-radius:var(--r-md);box-shadow:var(--sh-lg);padding:6px;min-width:210px;z-index:20}
.umenu-pop button{display:flex;align-items:center;gap:9px;width:100%;border:none;background:none;
  text-align:left;padding:9px 10px;border-radius:var(--r-sm);font-size:13.5px;color:var(--g-700);cursor:pointer}
.umenu-pop button:hover{background:var(--g-50)}
.umenu-pop button.danger{color:var(--bad)}
.umenu-pop .usep{height:1px;background:var(--g-100);margin:4px 6px}

/* ---------------- контент ---------------- */
.tabpane{padding:24px;max-width:1120px;margin:0 auto}
.page-h{display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  flex-wrap:wrap;margin:2px 0 16px}
.page-h h2{margin:0;font-size:18px;font-weight:650;letter-spacing:-.01em}
.page-h .sub{color:var(--muted);font-size:13px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);
  padding:20px;margin-top:16px;box-shadow:var(--sh-sm)}
.card h3:first-child{margin-top:0}
h3{font-size:15px;font-weight:650;margin:24px 0 10px;letter-spacing:-.005em}
h3.danger{color:var(--bad)} h3.warnh{color:var(--warn)}

.prow{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.prow .fld{min-width:150px}
.grow{flex:1}
.actions{margin-top:18px;display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}
.actions .msg,.actions .file-name{align-self:center}
.msg{font-size:13px}
.msg.ok{color:var(--ok)}.msg.bad{color:var(--bad)}.msg.warn{color:var(--warn)}
.msg a{color:var(--efele-600);font-weight:600}

/* поиск продукта */
.col-search{position:relative;max-width:600px}
.col-search>.fld input{padding:11px 13px;font-size:15px}
.results{position:absolute;left:0;right:0;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-md);margin-top:6px;max-height:360px;overflow:auto;z-index:9;box-shadow:var(--sh-lg)}
.results:empty{display:none}
.ritem{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:12px;border-bottom:1px solid var(--g-100)}
.ritem:last-child{border-bottom:none}
.ritem:hover,.ritem.sel{background:var(--g-50)}
.ritem .rname{font-weight:600}
.ritem .rcat{color:var(--muted);font-size:12px;margin-left:6px}
.ritem.none{color:var(--muted);cursor:default;justify-content:center;padding:16px}

/* refbox: ключ-значение */
.refbox{display:flex;flex-wrap:wrap;gap:14px 36px;padding:14px 16px;border-radius:var(--r-sm);
  background:var(--g-25);border:1px solid var(--line);margin-bottom:16px}
.refbox:empty{display:none}
.refbox>div{display:flex;flex-direction:column;gap:3px;font-size:13.5px}
.refbox b{color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase}

/* пилюли статусов — с точкой */
.pill{display:inline-flex;align-items:center;gap:6px;padding:2px 10px 2px 8px;border-radius:999px;
  font-size:12px;font-weight:600;border:1px solid transparent;white-space:nowrap}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.pill.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-line)}
.pill.expiring{background:var(--warn-bg);color:var(--warn);border-color:var(--warn-line)}
.pill.expired,.pill.terminated{background:var(--bad-bg);color:var(--bad);border-color:var(--bad-line)}
.pill.unknown{background:var(--g-100);color:var(--g-500);border-color:var(--g-200)}
.pill.gray{background:var(--g-50);color:var(--g-500);border-color:var(--g-200)}

/* ---------------- таблицы ---------------- */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;overflow-x:auto;margin-top:12px;box-shadow:var(--sh-sm)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.05em;
  text-transform:uppercase;padding:10px 14px;border-bottom:1px solid var(--line);
  background:var(--g-25);white-space:nowrap}
.fld-hint{font-size:11px;font-weight:500;letter-spacing:normal;text-transform:none;
  color:var(--muted);min-height:14px}
.chk{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--txt);
  cursor:pointer;user-select:none;padding-bottom:10px}
.chk input{accent-color:var(--efele-600);width:15px;height:15px}
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--txt)}
th.sortable::after{content:"↕";display:inline-block;width:12px;margin-left:4px;
  opacity:.35;font-size:10px;text-align:center}
th.sortable.sort-desc::after{content:"↓";opacity:1;color:var(--efele-600)}
th.sortable.sort-asc::after{content:"↑";opacity:1;color:var(--efele-600)}

/* журнал: фиксированная сетка (вёрстка не скачет при сортировке), детали по клику */
table.jt{table-layout:fixed;min-width:760px}
table.jt td{vertical-align:middle}
td.ell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dim{color:var(--g-300)}
.pill.webp{background:var(--efele-50);color:var(--efele-700);border-color:var(--efele-200)}
tr.jrow{cursor:pointer}
tr.jrow.sel td{background:var(--g-25);border-bottom-color:transparent}
tr.jdetail td{background:var(--g-25);padding:2px 14px 12px;border-bottom:1px solid var(--g-100)}
.jd{display:flex;flex-wrap:wrap;gap:6px 28px;font-size:13px}
.jd-item span{display:block;font-size:10.5px;font-weight:600;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);margin-bottom:1px}
td{padding:9px 14px;border-bottom:1px solid var(--g-100);vertical-align:top;
  font-variant-numeric:tabular-nums}
td.nw{white-space:nowrap}
td .pill{vertical-align:1px}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--g-25)}
td .dl{color:var(--efele-600);font-weight:600;text-decoration:none}
td .dl:hover{text-decoration:underline}
.empty td{padding:36px 16px;text-align:center;color:var(--muted);font-size:13.5px}
.tfoot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;
  border-top:1px solid var(--g-100);color:var(--muted);font-size:13px;background:var(--g-25)}

/* показатели качества */
.indicators td.fact,.indicators th.fact{background:var(--efele-50)}
.indicators td.fact input{width:100%;min-width:96px;padding:6px 9px;border:1px solid var(--g-300);
  border-radius:6px;transition:border-color .15s ease,box-shadow .15s ease}
.indicators td.fact input:focus{outline:none;border-color:var(--efele-600);box-shadow:var(--ring)}

/* ---------------- тост / диалоги ---------------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(48px);
  background:var(--g-900);color:#fff;padding:11px 20px;border-radius:var(--r-md);opacity:0;
  transition:opacity .22s ease,transform .22s ease;pointer-events:none;z-index:60;max-width:80vw;
  box-shadow:var(--sh-lg);font-size:13.5px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

dialog{border:none;border-radius:var(--r-lg);padding:24px;width:min(430px,92vw);
  box-shadow:var(--sh-lg);color:var(--txt)}
dialog::backdrop{background:rgb(16 24 40/.45)}
dialog h3{margin:0 0 10px;font-size:16px}
dialog p{margin:0 0 6px;font-size:14px;color:var(--g-700);white-space:pre-line}
.dlg-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
dialog .fld{margin-top:12px}

/* ---------------- прочие модули ---------------- */
.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;
  padding:1px 6px;border-radius:999px;background:var(--warn);color:#fff;font-size:11px;font-weight:700}
.badge.red{background:var(--efele-600)}

.links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;margin-top:14px}
.lgroup{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);
  padding:16px 18px;box-shadow:var(--sh-sm)}
.lgroup h4{margin:0 0 8px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.lgroup a{display:flex;align-items:center;gap:7px;padding:7px 0;color:var(--g-700);
  text-decoration:none;border-bottom:1px solid var(--g-100);font-size:13.5px}
.lgroup a:last-child{border-bottom:none}
.lgroup a:hover{color:var(--efele-600)}
.lgroup a .ic{color:var(--g-400);width:13px;height:13px;margin-left:auto}
.lnote{color:var(--muted);font-size:11px}

/* пользователи (админ) */
.user-inactive td{color:var(--g-400)}
.role-chip{font-size:11px;font-weight:700;padding:1px 8px;border-radius:999px;
  background:var(--g-100);color:var(--g-500)}
.role-chip.admin{background:var(--efele-50);color:var(--efele-700)}

@media (max-width:900px){
  .top{gap:14px;padding:0 14px}
  .brand-sm span.btxt{display:none}
  .uname{display:none}
  .tabpane{padding:14px}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}
