:root{
  --bg:#0d0f12; --bg2:#13161b; --panel:#181c22; --panel2:#1e232b;
  --line:#2a313b; --line2:#363f4b;
  --ink:#e7ecf2; --ink2:#9aa6b4; --ink3:#667081;
  --amber:#f2a900; --amber2:#ffc54d;
  --green:#35c98a; --red:#ff5c6c; --blue:#4ea3ff; --slate:#7d8aa0;
  --mono:'IBM Plex Mono',ui-monospace,monospace; --sans:'IBM Plex Sans',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(1200px 600px at 85% -10%,rgba(242,169,0,.06),transparent 60%),
             repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.012) 3px)}
a{color:inherit}
button{font-family:var(--sans);cursor:pointer}
.mono{font-family:var(--mono)}

/* ---------- login ---------- */
.login{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:30px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.brand .dot{width:11px;height:11px;border-radius:3px;background:var(--amber);box-shadow:0 0 14px var(--amber)}
.brand b{font-family:var(--mono);letter-spacing:.14em;font-size:13px;text-transform:uppercase}
.login h1{font-size:21px;margin:14px 0 2px}
.login p.sub{color:var(--ink3);margin:0 0 22px;font-size:13px}
label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin:14px 0 6px}
input,textarea,select{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:11px 12px;font-family:var(--mono);font-size:13px;outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(242,169,0,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:8px;
  padding:11px 16px;font-weight:600;font-size:13px;background:var(--amber);color:#1a1300;width:100%;margin-top:20px}
.btn:hover{background:var(--amber2)}
.btn.ghost{background:transparent;border:1px solid var(--line2);color:var(--ink);width:auto}
.btn.ghost:hover{border-color:var(--amber);color:var(--amber)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.hint{margin-top:16px;font-size:11px;color:var(--ink3);line-height:1.7;border-top:1px solid var(--line);padding-top:14px}
.hint code{color:var(--amber)}
.err{color:var(--red);font-size:12px;margin-top:10px;min-height:14px}

/* ---------- shell ---------- */
.shell{position:relative;z-index:1;display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.side{background:var(--bg2);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:4px}
.side .brand{padding:6px 8px 18px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--ink2);
  font-size:13px;font-weight:500;text-decoration:none;border:1px solid transparent}
.nav a:hover{background:var(--panel);color:var(--ink)}
.nav a.active{background:var(--panel2);color:var(--amber);border-color:var(--line2)}
.nav .ico{width:16px;text-align:center;font-family:var(--mono);opacity:.8}
.side .who{margin-top:auto;padding:12px;border:1px solid var(--line);border-radius:10px;background:var(--panel)}
.side .who .em{font-family:var(--mono);font-size:11px;color:var(--ink);word-break:break-all}
.role-pill{display:inline-block;margin-top:6px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;border:1px solid var(--line2);color:var(--amber)}
.side .who .lo{margin-top:10px;font-size:12px;color:var(--ink3);background:none;border:none;padding:0}
.side .who .lo:hover{color:var(--red)}

main{padding:26px 30px;overflow:auto;max-height:100vh}
.head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.head h2{margin:0;font-size:22px;letter-spacing:-.01em}
.head .env{font-family:var(--mono);font-size:11px;color:var(--amber);border:1px solid var(--line2);padding:4px 9px;border-radius:6px}
.muted{color:var(--ink3)}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px}
.stat .n{font-family:var(--mono);font-size:26px;font-weight:600}
.stat .l{font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);margin-top:4px}
.stat.q .n{color:var(--slate)} .stat.p .n{color:var(--blue)} .stat.c .n{color:var(--green)} .stat.f .n{color:var(--red)}

/* ---------- table ---------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;padding:12px 14px;border-bottom:1px solid var(--line);align-items:center}
.toolbar input,.toolbar select{width:auto;flex:0 0 auto;padding:8px 10px}
.toolbar .grow{flex:1}
table{width:100%;border-collapse:collapse}
th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);text-align:left;
  padding:11px 14px;border-bottom:1px solid var(--line);font-weight:600}
td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr{cursor:pointer}
tbody tr:hover{background:var(--panel2)}
td.mono{font-family:var(--mono);font-size:12px;color:var(--ink2)}
.empty{padding:40px;text-align:center;color:var(--ink3)}

/* ---------- status pills ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;
  padding:4px 9px;border-radius:999px;border:1px solid;text-transform:lowercase}
.pill::before{content:"";width:6px;height:6px;border-radius:50%}
.pill.queued{color:var(--slate);border-color:#3a4452}.pill.queued::before{background:var(--slate)}
.pill.processing{color:var(--blue);border-color:#27425f}.pill.processing::before{background:var(--blue);animation:bl 1s infinite}
.pill.completed{color:var(--green);border-color:#1f5340}.pill.completed::before{background:var(--green)}
.pill.failed{color:var(--red);border-color:#5a2730}.pill.failed::before{background:var(--red)}
@keyframes bl{50%{opacity:.3}}

/* ---------- detail / timeline ---------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.card h3{margin:0 0 14px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.kv{display:grid;grid-template-columns:130px 1fr;gap:6px 12px;font-size:13px}
.kv .k{color:var(--ink3)} .kv .v{font-family:var(--mono);color:var(--ink);word-break:break-word}
.timeline{position:relative;padding-left:22px}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--line2)}
.tl{position:relative;padding:8px 0}
.tl::before{content:"";position:absolute;left:-19px;top:13px;width:11px;height:11px;border-radius:50%;
  background:var(--bg);border:2px solid var(--slate)}
.tl.success::before{border-color:var(--green);background:var(--green)}
.tl.error::before{border-color:var(--red);background:var(--red)}
.tl.info::before{border-color:var(--blue)}
.tl.debug::before{border-color:var(--amber)}
.tl .step{font-family:var(--mono);font-size:12px;font-weight:600}
.tl .det{font-size:12px;color:var(--ink2);margin-top:2px}
.tl .t{font-family:var(--mono);font-size:10px;color:var(--ink3);float:right}
.tag-debug{font-size:9px;color:var(--amber);border:1px solid var(--line2);border-radius:4px;padding:1px 5px;margin-left:6px}

/* ---------- test console ---------- */
.console{display:grid;grid-template-columns:380px 1fr;gap:16px}
.preset{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.chip{font-family:var(--mono);font-size:11px;padding:6px 9px;border-radius:6px;background:var(--bg2);
  border:1px solid var(--line);color:var(--ink2)}
.chip:hover{border-color:var(--amber);color:var(--amber)}
.console textarea{min-height:340px;line-height:1.5;resize:vertical}
.stream{background:#0a0c0f;border:1px solid var(--line);border-radius:12px;padding:14px;font-family:var(--mono);
  font-size:12px;overflow:auto;max-height:560px}
.ln{padding:3px 0;border-bottom:1px solid rgba(255,255,255,.03);display:flex;gap:10px;align-items:baseline}
.ln .ts{color:var(--ink3);flex:0 0 auto}
.ln .lv{flex:0 0 64px;text-transform:uppercase;font-size:10px;letter-spacing:.06em}
.ln.success .lv{color:var(--green)} .ln.error .lv{color:var(--red)} .ln.info .lv{color:var(--blue)} .ln.debug .lv{color:var(--amber)}
.ln .msg{color:var(--ink);flex:1}
.flash{padding:10px 12px;border-radius:8px;font-family:var(--mono);font-size:12px;margin-bottom:10px}
.flash.ok{background:rgba(53,201,138,.1);border:1px solid #1f5340;color:var(--green)}
.flash.bad{background:rgba(255,92,108,.1);border:1px solid #5a2730;color:var(--red)}

@media(max-width:860px){
  .shell{grid-template-columns:1fr}.side{flex-direction:row;align-items:center;overflow-x:auto}
  .nav{flex-direction:row}.side .who,.side .brand{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}.grid2,.console{grid-template-columns:1fr}
}

/* ---- audit artifacts ---- */
.shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.shot{display:block;border:1px solid var(--line);border-radius:8px;overflow:hidden;text-decoration:none;background:var(--bg2)}
.shot img{width:100%;height:96px;object-fit:cover;display:block;border-bottom:1px solid var(--line)}
.shot span{display:block;padding:6px 8px;font-family:var(--mono);font-size:10px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shot:hover{border-color:var(--amber)}
.files{display:flex;flex-direction:column;gap:6px}
.filelink{font-family:var(--mono);font-size:12px;color:var(--amber);text-decoration:none;padding:6px 0}
.filelink.muted{color:var(--ink3)}

/* ===== status + system ===== */
.hb{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle}
.hb.on{background:var(--green);box-shadow:0 0 8px var(--green)}
.hb.off{background:var(--red);box-shadow:0 0 8px var(--red)}
.srow{display:grid;grid-template-columns:18px minmax(160px,260px) 1fr;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.srow:last-child{border-bottom:none}
.srow .sl{font-weight:500}
.srow .sd{color:var(--ink2);font-size:12px}
/* billing fault rows: simple 2-col, no dot */
.srow.kv2{grid-template-columns:1fr auto}
.srow.kv2 .sl{font-weight:500}

/* ===== settings: FIS credential rows ===== */
.fisrow-head{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1fr;gap:10px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);padding-bottom:8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.fisacct{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1fr;gap:10px;align-items:start;padding:12px 0;border-bottom:1px solid var(--line)}
.fisacct:last-child{border-bottom:none}
.fisacct .al{grid-column:1 / -1;font-size:13px;color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.fisacct input{font-size:13px;padding:9px 11px;margin-top:0}
.fisacct .al .hb{width:9px;height:9px}
.card h3{color:var(--ink2);font-size:13px;letter-spacing:.06em}
label{color:var(--ink2)}

/* inline input+button rows (FIS password page) — button must NOT be full width */
.row{display:flex;gap:10px;align-items:center}
.row input{flex:1;margin-top:0}
.row .btn{width:auto;margin-top:0;white-space:nowrap;flex:0 0 auto;padding:10px 18px}

/* ===== pills (billing/status badges) ===== */
/* billing/fault pills are flat (no status dot); status pills keep their dot */
.pill.bill,.pill.nobill,.pill.fault-caller,.pill.fault-system{
  display:inline-block;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:600;
  letter-spacing:.03em;border:none;text-transform:none;font-family:inherit}
.pill.bill::before,.pill.nobill::before,.pill.fault-caller::before,.pill.fault-system::before{display:none;content:none}
.pill.bill{background:rgba(43,176,99,.16);color:var(--green)}
.pill.nobill{background:rgba(140,140,150,.16);color:var(--ink2)}
.pill.fault-caller{background:rgba(224,168,42,.16);color:var(--amber2)}
.pill.fault-system{background:rgba(224,74,74,.16);color:var(--red)}

/* ===== tables (billing/users) ===== */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--ink3);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:9px 10px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:9px 10px;border-bottom:1px solid var(--line2);vertical-align:middle}

/* ===== user management ===== */
.newuser{display:grid;grid-template-columns:repeat(6,1fr) auto;gap:8px;align-items:center}
.newuser input,.newuser select{font-size:13px;padding:9px 11px;margin-top:0}
.newuser .btn{width:auto;margin-top:0;white-space:nowrap;padding:10px 16px}
.ok-msg{color:var(--green);font-size:13px}
.bad-msg{color:var(--red);font-size:13px}
.btn.ghost.sm{padding:5px 12px;font-size:12px;width:auto;margin-top:0}

/* ===== lock banner ===== */
.lockbar{background:rgba(224,74,74,.15);border-bottom:1px solid var(--red);color:var(--ink);padding:10px 18px;font-size:13px;text-align:center}
.lockbar a{color:var(--amber);font-weight:600;text-decoration:none}

/* ===== screenshots grid ===== */
.shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}

/* ===== logo: keep on one line ===== */
.brand b{white-space:nowrap;letter-spacing:.10em}

/* ===== responsive ===== */
@media(max-width:860px){
  .fisrow-head{display:none}
  .fisacct{grid-template-columns:1fr;gap:8px}
  .newuser{grid-template-columns:1fr}
  .newuser .btn{width:100%}
  .srow{grid-template-columns:18px 1fr;gap:8px}
  .srow .sd{grid-column:2}
  .srow.kv2{grid-template-columns:1fr auto}
  .card{overflow-x:auto}
  .tbl{font-size:12px;min-width:520px}
  .tbl th,.tbl td{padding:7px 6px;white-space:nowrap}
  .row{flex-wrap:wrap}
  .row .btn{width:100%}
}

/* ===== FIS Credentials page: 2x2 field grid per account ===== */
.fiscred{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}
.fiscred label{display:block;font-size:11px;color:var(--ink3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}
.fiscred input{margin-top:0;font-size:13px;padding:9px 11px}
.savemsg{font-size:13px}
@media(max-width:860px){ .fiscred{grid-template-columns:1fr} }

/* ===== FIS credential "saved" indicators ===== */
.saved-tag{color:var(--green);font-size:10px;font-weight:600;margin-left:6px;letter-spacing:.02em}
.unset-tag{color:var(--ink3);font-size:10px;font-weight:600;margin-left:6px;letter-spacing:.02em}
.fiscred input.is-set{border-color:rgba(43,176,99,.45);background:rgba(43,176,99,.05)}
.fiscred input.is-set::placeholder{color:var(--ink3)}

/* ===== account actions + change-password modal ===== */
.acct-actions{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.acct-actions .lo{text-align:left}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(2px)}
.modal-card{background:var(--panel,#161b22);border:1px solid var(--line2,#2a3038);border-radius:12px;padding:24px;width:min(380px,92vw);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-card h3{margin:0 0 16px;color:var(--ink);font-size:16px;letter-spacing:0}
.modal-card label{display:block;font-size:12px;color:var(--ink2);margin:12px 0 4px}
.modal-card input{width:100%;padding:10px 12px;font-size:14px;margin-top:0}
.cpw-msg{min-height:18px;margin-top:10px;font-size:13px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.modal-actions .btn{width:auto;margin-top:0;padding:9px 16px}

/* ===== login password show/hide ===== */
.pw-wrap{position:relative;display:flex;align-items:center}
.pw-wrap input{flex:1;padding-right:54px}
.pw-eye{position:absolute;right:8px;background:transparent;border:none;color:var(--ink3);font-size:11px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;padding:4px 8px}
.pw-eye:hover{color:var(--amber)}
