/* Masar Control — admin UI styles. Single stylesheet, no build step. */
:root{
  --bg:#0f1217; --panel:#171b22; --panel2:#1d222b; --line:#2a313c;
  --ink:#e6eaf0; --muted:#8b95a5; --brand:#5b9dff; --brand2:#7c5cff;
  --ok:#34d399; --warn:#fbbf24; --bad:#f87171; --busy:#60a5fa; --mute:#6b7280;
  --radius:10px; --shadow:0 1px 3px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
code,.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.small{font-size:12px}
.muted{color:var(--muted)}
.center{text-align:center}
.mt{margin-top:28px}

/* top bar */
.topbar{display:flex;align-items:center;gap:24px;padding:0 24px;height:56px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand a{color:var(--ink);font-weight:700;font-size:17px}
.brand span{color:var(--brand)}
.mainnav{display:flex;gap:4px;flex:1}
.mainnav a{color:var(--muted);padding:8px 12px;border-radius:8px;font-weight:500}
.mainnav a:hover{color:var(--ink);background:var(--panel2);text-decoration:none}
.mainnav a.active{color:var(--ink);background:var(--panel2)}
.userbox{display:flex;align-items:center;gap:12px}
.uname{font-size:13px;color:var(--muted)}
.linkbtn{background:none;border:none;color:var(--brand);cursor:pointer;font:inherit;padding:0}
.linkbtn:hover{text-decoration:underline}
.inline{display:inline}

.wrap{max-width:1180px;margin:0 auto;padding:24px}
.foot{max-width:1180px;margin:24px auto;padding:0 24px;color:var(--muted);font-size:12px}

.pagehead{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.pagehead h1{font-size:22px;margin:0}

/* flashes */
.flash{padding:10px 14px;border-radius:8px;margin-bottom:14px;border:1px solid var(--line)}
.flash-ok{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.4)}
.flash-warn{background:rgba(251,191,36,.12);border-color:rgba(251,191,36,.4)}
.flash-bad{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.4)}

/* queue pill */
.queuepill{background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:13px;color:var(--muted)}
.queuepill strong{color:var(--ink)}
.queuepill.bad{border-color:rgba(248,113,113,.5);color:var(--bad)}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card h2,.card h3{margin:0 0 12px}
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.cols{grid-template-columns:1fr}}

.tenantcard{padding:0;overflow:hidden;display:flex;flex-direction:column}
.tenantcard .tc-head{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 16px 8px}
.tenantcard h3{margin:0;font-size:16px}
.tc-body{padding:4px 16px 12px}
.tc-foot{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px;background:var(--panel2);border-top:1px solid var(--line);margin-top:auto}
.slug{color:var(--muted);font-weight:400;font-size:13px}

.kv{display:flex;justify-content:space-between;gap:12px;padding:3px 0;font-size:13px;border-bottom:1px dotted rgba(255,255,255,.05)}
.kv span{color:var(--muted)}
.kv strong{font-weight:600;text-align:right}

/* status dots + state colors */
.dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex:0 0 auto;margin-top:4px}
.dot-ok{background:var(--ok)}.dot-warn{background:var(--warn)}.dot-bad{background:var(--bad)}
.dot-busy{background:var(--busy)}.dot-muted{background:var(--mute)}
.state-ok{color:var(--ok)}.state-warn{color:var(--warn)}.state-bad{color:var(--bad)}
.state-busy{color:var(--busy)}.state-muted{color:var(--muted)}

/* badges */
.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:600;border:1px solid transparent}
.badge-ok{background:rgba(52,211,153,.15);color:var(--ok)}
.badge-warn{background:rgba(251,191,36,.15);color:var(--warn)}
.badge-bad{background:rgba(248,113,113,.15);color:var(--bad)}
.badge-busy{background:rgba(96,165,250,.15);color:var(--busy)}
.badge-muted{background:rgba(107,114,128,.15);color:var(--muted)}

/* tenant status chips */
.tstatus{font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:2px 7px;border-radius:6px;background:var(--panel2);color:var(--muted)}
.tstatus-active{color:var(--ok)}.tstatus-paused{color:var(--warn)}
.tstatus-onboarding{color:var(--busy)}.tstatus-archived{color:var(--mute)}

/* roles */
.role{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:5px;background:var(--panel2)}
.role-admin{color:var(--brand2)}.role-operator{color:var(--brand)}.role-viewer{color:var(--muted)}

/* buttons */
.btn{display:inline-block;background:var(--panel2);border:1px solid var(--line);color:var(--ink);
  padding:7px 13px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;line-height:1.2}
.btn:hover{border-color:#3a434f;text-decoration:none}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#0b1220}
.btn-primary:hover{background:#74acff}
.btn-danger{background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.5);color:var(--bad)}
.btn-ghost{background:none}

/* tables */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
table.grid{width:100%;border-collapse:collapse;font-size:13.5px}
table.grid th{text-align:left;padding:10px 12px;color:var(--muted);font-weight:600;font-size:12px;
  text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--line);white-space:nowrap}
table.grid td{padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
table.grid tr:last-child td{border-bottom:none}
table.grid tbody tr:hover{background:var(--panel2)}
.rowactions{display:flex;gap:6px;flex-wrap:wrap}
.detailcell{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* forms */
.filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formgrid .wide{grid-column:1/-1}
.formsection{grid-column:1/-1;font-weight:600;color:var(--muted);border-bottom:1px solid var(--line);padding-bottom:6px;margin-top:6px;font-size:13px;text-transform:uppercase;letter-spacing:.03em}
.formactions{grid-column:1/-1;display:flex;gap:10px;margin-top:6px}
.checkrow{display:flex;align-items:center;gap:8px;flex-direction:row!important}
@media(max-width:640px){.formgrid{grid-template-columns:1fr}}
label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}
input,select,textarea{background:var(--bg);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:8px 10px;font:inherit;font-size:14px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand)}
.stack{display:flex;flex-direction:column;gap:14px}
.actions{display:flex;gap:8px}

/* log box */
.logbox{background:#0b0e13;border:1px solid var(--line);border-radius:var(--radius);padding:14px;
  font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;
  white-space:pre-wrap;word-break:break-word;max-height:480px;overflow:auto;color:#c9d4e3}

/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:
  radial-gradient(1200px 600px at 50% -10%,rgba(91,157,255,.12),transparent),var(--bg)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:32px;width:360px;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.login-brand{font-size:22px;font-weight:700;text-align:center}
.login-brand span{color:var(--brand)}
