:root{
  --bg:#0e1620;--panel:#16212e;--panel2:#1d2b3a;--panel3:#22344a;--line:#2b3d50;
  --ink:#e8eef5;--muted:#93a4b8;--faint:#6f8197;
  /* North Star: navy brand + star-blue interactive accent + red accent */
  --brand:#16356E;--brandred:#B0202F;
  --accent:#4f86c6;--accent2:#7db0e6;--warn:#f0a93b;--bad:#d8434f;--good:#46b06a;--info:#5b9bd5;
  --shadow:0 6px 24px rgba(0,0,0,.32);
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,#16273a 0,var(--bg) 60%);color:var(--ink);
  font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:15px;line-height:1.45}
a{color:var(--accent);text-decoration:none;cursor:pointer}
header{position:sticky;top:0;z-index:20;background:rgba(16,23,33,.88);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:10px 16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
header img{height:30px;width:auto;border-radius:5px}
header b{color:var(--accent);letter-spacing:.5px}.sp{flex:1}
.wrap{max-width:1180px;margin:0 auto;padding:18px}
.crumb{color:var(--muted);font-size:13px;margin-bottom:4px}
h1{font-size:24px;margin:2px 0}h2{font-size:18px;margin:4px 0}
h3{font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.8px;margin:22px 0 8px}
.muted{color:var(--muted)}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.col{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.btn{border:1px solid var(--line);background:var(--panel2);color:var(--ink);padding:8px 12px;border-radius:9px;font-weight:600;cursor:pointer;font-size:14px}
.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
input{background:#0c151e;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 11px;font-size:15px;width:100%}
input:focus{outline:none;border-color:var(--accent)}
.card{background:linear-gradient(180deg,var(--panel) 0,#142030 100%);border:1px solid var(--line);border-radius:14px;padding:16px;margin:12px 0;box-shadow:var(--shadow)}
#login{max-width:340px;margin:60px auto}
/* ---- nav: desktop left sidebar + mobile top dropdown ---- */
.layout{display:flex;align-items:flex-start;max-width:1240px;margin:0 auto}
#side{flex:0 0 210px;border-right:1px solid var(--line);min-height:calc(100vh - 53px);padding:14px 8px;position:sticky;top:53px}
.layout #app{flex:1;min-width:0;max-width:none;margin:0}
.navlinks{display:flex;flex-direction:column;gap:2px}
.navitem{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:var(--ink);font-weight:600;font-size:14px;cursor:pointer;text-decoration:none}
.navitem:hover{background:var(--panel2)}
.navitem.on{background:var(--panel2);color:var(--accent)}
.navitem .ic{width:18px;text-align:center;opacity:.9}
.navfoot{margin-top:14px;border-top:1px solid var(--line);padding-top:8px}
.iconbtn{background:none;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:4px 10px;font-size:16px;cursor:pointer;line-height:1.2}
.menubtn{display:none}
#menu{display:none}
.form{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
select{background:#0c151e;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 11px;font-size:15px;width:100%}
select:focus{outline:none;border-color:var(--accent)}
@media (max-width:760px){
  .layout{display:block}
  #side{display:none}
  body.authed .menubtn{display:inline-block}
  body.authed.menu-open #menu{display:block;background:#13202c;border-bottom:1px solid var(--line);padding:8px 12px}
  #menu .navfoot{margin-top:8px}
  .hide-sm{display:none}
}
.grid{display:grid;gap:14px}
.g-kpi{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.pgrid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.kpi{display:flex;flex-direction:column;gap:2px}.kpi .v{font-size:26px;font-weight:700;line-height:1.1}
.kpi .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.kpi .d{font-size:12px;color:var(--muted)}
.pill{display:inline-block;background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:2px 9px;font-size:12px;color:var(--muted)}
.sev-High,.sev-Critical{color:var(--bad);font-weight:700}.sev-Medium{color:var(--warn)}.sev-Low{color:var(--muted)}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--faint);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.bcard{padding:0;overflow:hidden;cursor:pointer;transition:transform .12s,border-color .12s;display:block}
.bcard:hover{transform:translateY(-2px);border-color:var(--accent)}
.cover{position:relative;height:150px;background:#1c2a3a;background-size:cover;background-position:center}
.cover.empty{display:grid;place-items:center;background:linear-gradient(135deg,#1c2a3a,#243b52)}
.cover .glyph{font-size:40px;opacity:.5}
.cover .ov{position:absolute;left:0;right:0;bottom:0;padding:22px 13px 11px;background:linear-gradient(transparent,rgba(8,13,20,.9))}
.cover .ov b{font-size:16px;display:block}.cover .ov .muted{font-size:12px}
.bmeta{padding:12px 14px;display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:13px;color:var(--ink)}
.emsbtn{display:inline-block;background:rgba(91,155,213,.14);border:1px solid rgba(91,155,213,.5);color:#9ecbf2;padding:7px 12px;border-radius:9px;font-weight:600;font-size:13px}
.emsbtn:hover{border-color:var(--info);color:#cfe6fb}
.gal{display:flex;flex-wrap:wrap;gap:8px}.gal a{display:block;width:110px}
.gal img{width:110px;height:110px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.gal .cap{font-size:11px;color:var(--muted);text-align:center;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.st{font-size:11px;font-weight:700;border-radius:5px;padding:1px 8px;border:1px solid}
.st-open,.st-pending{color:var(--muted);border-color:var(--line);background:var(--panel2)}
.st-proposed{color:#ffc66d;border-color:rgba(240,169,59,.5);background:rgba(240,169,59,.12)}
.st-Pending{color:#9ecbf2;border-color:rgba(91,155,213,.5);background:rgba(91,155,213,.12)}
.st-closed{color:#86d6a1;border-color:rgba(70,176,106,.5);background:rgba(70,176,106,.12)}
@media (max-width:640px){
  body{font-size:16px}header{flex-wrap:wrap;padding:8px 12px}.wrap{padding:12px 10px}
  table,thead,tbody,tr,th,td{display:block;width:100%}
  thead{position:absolute;left:-9999px}
  tbody tr{border:1px solid var(--line);border-radius:10px;margin:0 0 10px;padding:4px 6px;background:var(--panel2)}
  td{border:none;padding:7px 8px;display:flex;justify-content:space-between;gap:12px;align-items:baseline;text-align:right}
  td::before{content:attr(data-label);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:600;text-align:left}
  td:empty{display:none}.gal a,.gal img{width:30vw;max-width:140px}.gal img{height:30vw;max-height:140px}
}
/* ---- equipment intake: clickable rows + add/edit modal ---- */
.erow{cursor:pointer}.erow:hover td{background:var(--panel2)}
.btn.danger{border-color:rgba(226,87,76,.5);color:#f0a59d;background:rgba(226,87,76,.1)}
.btn.danger:hover{border-color:var(--bad);color:#fff;background:var(--bad)}
.modal-bg{position:fixed;inset:0;z-index:60;background:rgba(6,10,15,.66);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:30px 14px;overflow-y:auto}
.modal{background:linear-gradient(180deg,var(--panel) 0,#142030 100%);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);width:100%;max-width:620px;padding:16px 18px;margin:auto 0}
.modal-h{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:4px}
.modal-h b{font-size:17px}
.g-fields{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;margin-top:6px}
textarea{background:#0c151e;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:9px 11px;font-size:15px;width:100%;font-family:inherit;resize:vertical}
textarea:focus{outline:none;border-color:var(--accent)}
.ef-grp{grid-column:1/-1;color:var(--faint);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;border-top:1px solid var(--line);padding-top:10px;margin-top:4px}
.ef-full{grid-column:1/-1}
.req{color:var(--brandred)}
.fh{font-size:11px;color:var(--muted);margin-top:2px}
/* ---- North Star brand bits ---- */
.brandword{color:var(--ink);letter-spacing:1.5px;font-weight:800}
.brandlogo{border-radius:7px}
#login{text-align:center;margin:18px auto 60px}
.login-hero{display:block;margin:30px auto 0;width:auto;height:auto;max-height:320px;max-width:92%;border-radius:18px;box-shadow:var(--shadow)}
#login h2{margin-bottom:10px}
/* ---- health ring + bars + hero (dashboard polish) ---- */
.ring{border-radius:50%;display:grid;place-items:center;position:relative;flex:0 0 auto}
.ring::after{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--panel)}
.ring-h{position:relative;z-index:1;font-weight:800;font-size:22px;line-height:1}
.ring-h small{display:block;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.5px}
.hbar{height:8px;border-radius:6px;background:var(--panel3);overflow:hidden;min-width:90px;flex:1}
.hbar i{display:block;height:100%;border-radius:6px}
.ring-badge{position:absolute;top:10px;right:10px;z-index:2}
.ring-badge .ring::after{background:#16202c}
.hero{display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.hero .htext h1{margin:0}
.syshealth{display:flex;flex-direction:column;gap:10px}
.sysrow{display:grid;grid-template-columns:140px 1fr auto;gap:12px;align-items:center;font-size:14px}
.sysrow .sn{font-weight:600}.sysrow .sx{color:var(--muted);font-size:12px;white-space:nowrap}
@media (max-width:560px){.sysrow{grid-template-columns:1fr auto;gap:6px}.sysrow .hbar{grid-column:1/-1}}
