/* ФАРМАК ACVS — світла клінічна тема у фірмових кольорах Farmak ------------ */
/* Основний бренд-колір: #0D59B1 (digital-синій Farmak) + серо-блакитна гама. */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  --bg:#eaf1f8;
  --bg-1:#ffffff;
  --bg-2:#f3f7fc;
  --bg-3:#f7fafe;
  --line:#dde6f1;
  --line-2:#c3d3e6;
  --txt:#13283f;
  --txt-dim:#5a6e86;
  --txt-faint:#8a9bb1;
  --accent:#0d59b1;          /* Farmak blue */
  --accent-dim:#3a82c9;      /* світліший блакитний для фокуса/обведень */
  --accent-soft:#e6f0fa;     /* дуже світла заливка акценту */
  --low:#1f9254;
  --substantial:#bd7c08;
  --critical:#d23a2c;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --shadow:0 1px 2px rgba(19,40,63,.04),0 4px 16px rgba(19,40,63,.06);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--txt);
  font-size:14px;
  line-height:1.45;
  background-image:
    linear-gradient(rgba(13,89,177,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(13,89,177,.035) 1px,transparent 1px);
  background-size:48px 48px;
  background-position:-1px -1px;
}
.hidden{display:none !important}

/* --- логін --------------------------------------------------------------- */
#login-screen{
  position:fixed;inset:0;display:grid;place-items:center;z-index:50;
  background:radial-gradient(120% 90% at 50% -10%,#dfeaf7 0%,#eef3f9 55%,#e7eef6 100%);
}
.login-box{
  width:384px;border:1px solid var(--line-2);background:var(--bg-1);
  border-radius:10px;box-shadow:0 18px 50px rgba(13,89,177,.14),0 2px 6px rgba(19,40,63,.06);
  overflow:hidden;
}
.login-head{
  padding:20px 22px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;
  background:linear-gradient(180deg,#f5f9fd,#ffffff);
}
.login-mark{
  width:36px;height:36px;border-radius:8px;
  background:var(--accent);color:#fff;
  display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:16px;
  box-shadow:0 4px 12px rgba(13,89,177,.3);
}
.login-head h1{font-size:15px;letter-spacing:.16em;font-weight:700;text-transform:uppercase;color:var(--accent)}
.login-head .sub{font-family:var(--mono);font-size:10px;color:var(--txt-dim);letter-spacing:.08em}
.login-body{padding:22px}
.login-body label{
  display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--txt-dim);margin:14px 0 5px;
}
.login-body label:first-child{margin-top:0}
input,select,textarea{
  width:100%;background:var(--bg-1);border:1px solid var(--line-2);color:var(--txt);
  font-family:var(--mono);font-size:13px;padding:9px 11px;outline:none;border-radius:6px;transition:.12s;
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.btn{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  background:var(--bg-1);color:var(--txt);border:1px solid var(--line-2);
  padding:9px 16px;cursor:pointer;transition:.12s;border-radius:6px;
}
.btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(13,89,177,.25)}
.btn.primary:hover{background:#0a4a96;border-color:#0a4a96;color:#fff}
.btn.danger:hover{border-color:var(--critical);color:var(--critical);background:#fbecea}
.btn.go:hover{border-color:var(--low);color:var(--low);background:#e9f6ef}
.btn-row{display:flex;gap:8px;margin-top:18px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.creds{
  margin-top:18px;padding-top:14px;border-top:1px dashed var(--line-2);
  font-family:var(--mono);font-size:10px;color:var(--txt-faint);line-height:1.8;
}
.creds b{color:var(--txt-dim)}
.err{color:var(--critical);font-family:var(--mono);font-size:11px;margin-top:10px;min-height:14px}

/* --- каркас додатку ------------------------------------------------------ */
#app{display:grid;grid-template-rows:auto 1fr;height:100vh}
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:0 18px;height:52px;border-bottom:1px solid var(--line-2);
  background:#fff;box-shadow:0 1px 3px rgba(19,40,63,.05);z-index:10;
}
.topbar .mark{
  font-family:var(--mono);font-weight:600;color:#fff;letter-spacing:.1em;
  background:var(--accent);padding:5px 10px;font-size:12px;border-radius:6px;
  box-shadow:0 2px 6px rgba(13,89,177,.25);
}
.topbar .ctx{font-family:var(--mono);font-size:11px;color:var(--txt-dim);letter-spacing:.04em}
.topbar .ctx b{color:var(--txt)}
.topbar .spacer{flex:1}
.live-dot{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--txt-dim)}
.live-dot i{width:8px;height:8px;border-radius:50%;background:var(--low);box-shadow:0 0 0 3px rgba(31,146,84,.18);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.who{font-family:var(--mono);font-size:11px;text-align:right;line-height:1.3}
.who .role{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;font-size:10px;font-weight:600}

.layout{display:grid;grid-template-columns:212px 1fr;overflow:hidden}
.nav{border-right:1px solid var(--line);background:#fff;padding:10px 0;overflow:auto}
.nav button{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:none;border-left:3px solid transparent;
  color:var(--txt-dim);font-family:var(--mono);font-size:12px;letter-spacing:.02em;
  padding:10px 16px;cursor:pointer;transition:.1s;
}
.nav button:hover{color:var(--txt);background:var(--bg-2)}
.nav button.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-soft);font-weight:600}
.nav button .k{font-size:9px;color:var(--txt-faint);margin-left:auto}
.nav .sect{font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:var(--txt-faint);
  text-transform:uppercase;padding:16px 16px 6px}

.main{overflow:auto;padding:22px 26px}
.view-head{display:flex;align-items:baseline;gap:14px;margin-bottom:16px}
.view-head h2{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--txt)}
.view-head .desc{font-family:var(--mono);font-size:11px;color:var(--txt-dim)}
.view-head .spacer{flex:1}

/* --- картки / панелі ----------------------------------------------------- */
.grid{display:grid;gap:14px}
.cards{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.card{
  border:1px solid var(--line);background:#fff;padding:15px 17px;position:relative;
  border-radius:10px;box-shadow:var(--shadow);overflow:hidden;
}
.card .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt-dim)}
.card .num{font-family:var(--mono);font-size:32px;font-weight:600;margin-top:6px;color:var(--accent);line-height:1}
.card.t-critical .num{color:var(--critical)}
.card.t-substantial .num{color:var(--substantial)}
.card.t-low .num{color:var(--low)}
.card .foot{font-family:var(--mono);font-size:10px;color:var(--txt-faint);margin-top:6px}
.card .bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.card.t-critical .bar{background:var(--critical)}
.card.t-substantial .bar{background:var(--substantial)}
.card.t-low .bar{background:var(--low)}

/* --- таблиці ------------------------------------------------------------- */
.panel{border:1px solid var(--line);background:#fff;border-radius:10px;box-shadow:var(--shadow);overflow:hidden}
.panel-head{padding:12px 15px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;background:var(--bg-2)}
.panel-head h3{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--txt)}
.panel-head .spacer{flex:1}
table{width:100%;border-collapse:collapse;font-size:12.5px}
thead th{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--txt-dim);text-align:left;padding:10px 13px;border-bottom:1px solid var(--line-2);
  position:sticky;top:0;background:var(--bg-2);
}
tbody td{padding:10px 13px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bg-3)}
td.mono,.mono-cell{font-family:var(--mono);font-size:11.5px;color:var(--txt-dim)}
.empty{padding:30px;text-align:center;color:var(--txt-faint);font-family:var(--mono);font-size:11px}

/* --- бейджі риск-тірів ---------------------------------------------------- */
.tier{
  display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);
  font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border:1px solid;border-radius:20px;
}
.tier::before{content:"";width:6px;height:6px;border-radius:50%}
.tier.critical{color:var(--critical);border-color:#f0c4bf;background:#fbecea}
.tier.critical::before{background:var(--critical)}
.tier.substantial{color:#9a6606;border-color:#ecdcb4;background:#fbf3e0}
.tier.substantial::before{background:var(--substantial)}
.tier.low{color:#157a44;border-color:#bfe3cd;background:#eaf7f0}
.tier.low::before{background:var(--low)}

.pill{font-family:var(--mono);font-size:10px;padding:3px 8px;border:1px solid var(--line-2);color:var(--txt-dim);text-transform:uppercase;letter-spacing:.04em;border-radius:20px;background:var(--bg-2)}
.pill.candidate{color:var(--accent);border-color:#bcd6ef;background:var(--accent-soft)}
.pill.confirmed{color:var(--critical);border-color:#f0c4bf;background:#fbecea}
.pill.rejected{color:var(--txt-faint)}
.pill.approved{color:#157a44;border-color:#bfe3cd;background:#eaf7f0}
.pill.retired{color:var(--txt-faint)}

.resp-chip{font-family:var(--mono);font-size:9px;padding:2px 7px;border:1px solid var(--line-2);color:var(--txt-dim);margin-right:4px;letter-spacing:.02em;border-radius:4px;background:var(--bg-2)}
.resp-chip.audible{color:var(--critical);border-color:#f0c4bf;background:#fbecea}
.resp-chip.light_tower{color:#9a6606;border-color:#ecdcb4;background:#fbf3e0}

/* --- модал --------------------------------------------------------------- */
.overlay{position:fixed;inset:0;background:rgba(19,40,63,.34);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:80}
.modal{width:564px;max-width:94vw;border:1px solid var(--line-2);background:#fff;border-radius:12px;box-shadow:0 24px 70px rgba(19,40,63,.28);overflow:hidden}
.modal-head{padding:15px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;background:var(--bg-2)}
.modal-head h3{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt)}
.modal-head .spacer{flex:1}
.modal-head .x{cursor:pointer;color:var(--txt-dim);font-family:var(--mono);font-size:16px;line-height:1}
.modal-head .x:hover{color:var(--critical)}
.modal-body{padding:18px;max-height:70vh;overflow:auto}
.kv{display:grid;grid-template-columns:140px 1fr;gap:7px 12px;font-size:12.5px;margin-bottom:16px}
.kv dt{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-dim);padding-top:2px}
.kv dd{font-family:var(--mono);font-size:12px;color:var(--txt)}
.seg{display:flex;gap:0;margin:6px 0 14px;border:1px solid var(--line-2);border-radius:6px;overflow:hidden}
.seg button{flex:1;background:#fff;border:none;border-right:1px solid var(--line-2);
  color:var(--txt-dim);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  padding:10px;cursor:pointer;transition:.1s}
.seg button:last-child{border-right:none}
.seg button:hover{background:var(--bg-2)}
.seg button.sel-confirm{background:#fbecea;color:var(--critical);font-weight:600}
.seg button.sel-reject{background:var(--bg-2);color:var(--txt);font-weight:600}
.seg button.sel-reclassify{background:#fbf3e0;color:#9a6606;font-weight:600}
textarea{min-height:66px;resize:vertical;margin-bottom:10px}
.modal-body input{margin-bottom:10px}
.esign-note{font-family:var(--mono);font-size:10px;color:var(--txt-dim);margin-top:8px;line-height:1.7;
  border-left:3px solid var(--accent);padding:8px 0 8px 11px;background:var(--accent-soft);border-radius:0 6px 6px 0}

/* --- скрипти ------------------------------------------------------------- */
.script{border:1px solid var(--line);background:#fff;margin-bottom:12px;border-radius:10px;box-shadow:var(--shadow);overflow:hidden}
.script-h{padding:12px 15px;border-bottom:1px solid var(--line);display:flex;gap:12px;align-items:center;background:var(--bg-2)}
.script-h .t{font-weight:600;color:var(--txt)}
.steps{display:flex;flex-wrap:wrap;gap:8px;padding:15px;align-items:center}
.step{display:flex;align-items:center;gap:8px;border:1px solid var(--line-2);background:var(--bg-3);padding:8px 11px;border-radius:8px}
.step .no{font-family:var(--mono);font-size:10px;color:#fff;background:var(--accent);
  width:19px;height:19px;display:grid;place-items:center;border-radius:50%}
.step .ac{font-family:var(--mono);font-size:11px;color:var(--txt)}
.step .to{font-family:var(--mono);font-size:9px;color:var(--txt-faint)}
.step.opt{opacity:.65;border-style:dashed}
.arrow{color:var(--txt-faint);font-family:var(--mono)}

/* --- audit / integrity --------------------------------------------------- */
.integrity{display:flex;align-items:center;gap:12px;padding:15px 17px;border:1px solid;margin-bottom:14px;font-family:var(--mono);font-size:12px;border-radius:10px}
.integrity.ok{border-color:#bfe3cd;color:#157a44;background:#eaf7f0}
.integrity.bad{border-color:#f0c4bf;color:var(--critical);background:#fbecea}
.integrity .big{font-size:13px;font-weight:600;letter-spacing:.04em}
.hash{font-family:var(--mono);font-size:10px;color:var(--txt-faint)}

.note{font-family:var(--mono);font-size:10px;color:var(--txt-faint);margin-top:8px;line-height:1.6}
.banner{border:1px solid #bcd6ef;background:var(--accent-soft);padding:12px 15px;border-radius:10px;
  font-family:var(--mono);font-size:11px;color:var(--txt-dim);margin-bottom:16px;line-height:1.7}
.banner b{color:var(--accent)}
.toast{position:fixed;bottom:22px;right:22px;background:#fff;border:1px solid var(--low);
  color:#157a44;font-family:var(--mono);font-size:12px;padding:13px 17px;z-index:200;border-radius:8px;
  box-shadow:0 10px 30px rgba(19,40,63,.18);animation:slidein .2s}
.toast.err{border-color:var(--critical);color:var(--critical)}
@keyframes slidein{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#c8d6e6;border:3px solid var(--bg);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#a9bdd4}

/* --- відеоспостереження: компактна 2-колонкова розкладка --- */
.live-toolbar { display:flex; flex-wrap:wrap; gap:8px 14px; align-items:center;
  background:var(--surface,#fff); border:1px solid var(--line,#e5e9f0); border-radius:10px;
  padding:8px 12px; margin:8px 0 12px; }
.live-toolbar > div { margin:0 !important; }
.live-grid { display:grid; grid-template-columns:1.5fr 1fr; gap:14px; align-items:start; }
.live-right { display:flex; flex-direction:column; gap:12px; }
.live-right .panel { margin:0 !important; }
.live-video { width:100%; max-height:420px; object-fit:contain; border-radius:8px;
  display:block; background:#0e1622; }
.cam-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:8px; margin-top:10px; }
.cam-tile { border:2px solid var(--line-2,#dfe5ee); border-radius:8px; overflow:hidden;
  cursor:pointer; background:#0e1622; position:relative; transition:border-color .15s; }
.cam-tile.active { border-color:var(--accent,#0d59b1); }
.cam-tile img { width:100%; height:90px; object-fit:cover; display:block; }
.cam-tile .cap { font-size:10px; font-family:var(--mono); padding:3px 6px; color:#cbd5e1;
  background:#1a2433; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
@media (max-width:1000px){ .live-grid { grid-template-columns:1fr; } }

/* операторський режим: на вузькому екрані — один стовпець */
@media (max-width:900px){ .op-grid{ grid-template-columns:1fr !important; } }

.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:13px 18px;border-top:1px solid var(--line);background:var(--bg-2)}
