/* Мобильный ЛК «Сфера Безопасности» — фирменные токены (из питч-деков SB). */
:root{
  --bg:#F2F4F8; --card:#FFFFFF; --panel:#F7F9FC; --hair:#E7ECF3; --grid:#D5DCE6;
  --brand:#0074DF; --brand-deep:#0A4F96; --brand-light:#7FB6EE;
  --ink:#0E1116; --text:#424B57; --muted:#9AA4B2;
  --red:#E5484D; --green:#2E9E63; --amber:#C77F12;
  --radius:14px; --shadow:0 1px 3px rgba(14,17,22,.08),0 4px 16px rgba(14,17,22,.05);
  --header-h:56px; --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--ink); overscroll-behavior-y:none;
}
#app{max-width:520px;margin:0 auto;min-height:100%;display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer;border:none}
.hidden{display:none!important}

/* Шапка */
.hdr{
  position:sticky;top:0;z-index:10;height:var(--header-h);
  display:flex;align-items:center;gap:12px;padding:0 14px;
  background:linear-gradient(180deg,#F7F9FC,#EEF2F8);
  border-bottom:1px solid var(--hair);
}
.hdr h1{font-size:18px;margin:0;font-weight:700;flex:1;text-align:center;letter-spacing:.2px}
.hdr .icon-btn{width:40px;height:40px;display:grid;place-items:center;background:none;border-radius:10px;color:var(--brand)}
.hdr .icon-btn:active{background:#e6eef8}
.hdr .icon-btn.on{background:#e6eef8;color:var(--brand-deep)}

/* Список объектов */
.list{padding:12px;display:flex;flex-direction:column;gap:10px}
.obj{
  background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:14px 14px 12px;display:flex;flex-direction:column;gap:8px;
  border-left:4px solid var(--brand);transition:transform .08s;
}
.obj:active{transform:scale(.99)}
.obj .row1{display:flex;align-items:center;gap:10px}
.obj .status-txt{font-weight:600;font-size:15px}
.chip-notest{font-size:11px;font-weight:600;color:#7A828E;background:#EEF1F5;
  border:1px solid var(--hair);border-radius:20px;padding:1px 8px;margin-left:6px;white-space:nowrap}
.obj .name{font-size:17px;font-weight:600;color:var(--ink)}
.obj .sub{font-size:13px;color:var(--muted);line-height:1.35;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Карточка объекта */
.detail-head{background:var(--card);padding:18px 16px 6px;text-align:center;border-bottom:1px solid var(--hair)}
.detail-head .name{font-size:20px;font-weight:700}
.detail-head .status-txt{font-size:16px;font-weight:600;margin-top:2px}
.detail-head .shield-big{margin:14px auto 8px;width:72px;height:72px}
.act-btn{
  display:block;width:calc(100% - 32px);margin:8px 16px 14px;padding:16px;
  border-radius:12px;font-size:17px;font-weight:700;color:#fff;letter-spacing:.3px;
  box-shadow:var(--shadow);
}
.act-btn.arm{background:var(--brand)}
.act-btn.disarm{background:var(--green)}
.act-btn:disabled{opacity:.6}

/* Вкладки */
.tabs{display:flex;background:var(--card);border-bottom:1px solid var(--hair);padding:0 6px}
.tabs .tab{flex:1;padding:13px 6px;background:none;font-size:14px;font-weight:600;color:var(--muted);
  border-bottom:2.5px solid transparent}
.tabs .tab.active{color:var(--ink);border-bottom-color:var(--brand)}

/* Лента событий */
.feed{padding:12px;display:flex;flex-direction:column;gap:10px}
.ev{background:var(--card);border-radius:12px;box-shadow:var(--shadow);
  padding:12px;display:flex;gap:12px;align-items:flex-start}
.ev .ev-ic{width:40px;height:40px;border-radius:9px;flex:none;display:grid;place-items:center}
.ev .ev-body{min-width:0;flex:1}
.ev .ev-title{font-size:15px;font-weight:600}
.ev .ev-desc{font-size:13px;color:var(--text);margin-top:1px}
.ev .ev-time{font-size:12px;color:var(--muted);margin-top:3px}

/* Логин */
.login{flex:1;display:flex;flex-direction:column;justify-content:center;padding:28px 22px;gap:14px}
.login .brand{text-align:center;margin-bottom:8px}
.login .brand .logo{width:76px;height:76px;margin:0 auto 10px}
.login .brand .t{font-size:20px;font-weight:700}
.login .brand .s{font-size:13px;color:var(--muted);margin-top:2px}
.login label{font-size:13px;color:var(--text);font-weight:600;margin-bottom:-6px}
.login input{padding:14px;border:1px solid var(--grid);border-radius:11px;font-size:16px;background:var(--card)}
.login input:focus{outline:none;border-color:var(--brand)}
.login .primary{background:var(--brand);color:#fff;padding:15px;border-radius:11px;font-size:16px;font-weight:700}
.login .err{color:var(--red);font-size:14px;text-align:center;min-height:18px}

/* Кадр камеры под событием */
.ev-frame{display:block;width:100%;margin-top:8px;border-radius:8px;border:1px solid var(--hair)}

/* Вкладка «Камеры» */
.cams{padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cam{background:var(--card);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
.cam-view{position:relative;aspect-ratio:16/9;background:#0E1116;cursor:pointer;display:grid;place-items:center}
.cam-view img{width:100%;height:100%;object-fit:cover}
.cam-ph{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted);font-size:12px}
.cam-live{position:absolute;top:6px;left:6px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px;background:rgba(14,17,22,.6);color:#fff}
.cam-live.on{color:#8ef0b8}
.cam-live.off{color:#f0b48e}
.cam-name{padding:8px 10px;font-size:13px;font-weight:600;color:var(--ink)}

.empty{padding:40px 20px;text-align:center;color:var(--muted)}
.toast{position:fixed;left:50%;bottom:calc(20px + var(--safe-b));transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:11px 18px;border-radius:22px;font-size:14px;z-index:50;
  box-shadow:var(--shadow);opacity:0;transition:opacity .2s}
.toast.show{opacity:.96}
