/* Dashboard styling pass — tokens + light/dark. Visual only; no behaviour change. */
:root{
  --bg-page:#ffffff; --bg-surface:#faf9f7; --bg-raised:#ffffff;
  --text-primary:#1d1d1b; --text-secondary:#5f5e5a; --text-tertiary:#888780;
  --border:rgba(0,0,0,.12); --border-strong:rgba(0,0,0,.22);
  --accent:#185fa5; --accent-bg:#e6f1fb; --accent-text:#042c53;
  --ok:#639922; --ok-bg:#eaf3de; --ok-text:#173404;
  --warn:#ef9f27; --warn-bg:#faeeda; --warn-text:#412402;
  --bad:#e24b4a; --bad-bg:#fcebeb; --bad-text:#501313;
  --neutral-bg:#f1efe8; --neutral-text:#2c2c2a;
  --radius:8px; --radius-lg:12px;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg-page:#1a1a18; --bg-surface:#222220; --bg-raised:#262624;
    --text-primary:#ededea; --text-secondary:#b4b2a9; --text-tertiary:#888780;
    --border:rgba(255,255,255,.14); --border-strong:rgba(255,255,255,.24);
    --accent:#85b7eb; --accent-bg:#0c2740; --accent-text:#cfe4f7;
    --ok-bg:#15240a; --ok-text:#c0dd97; --warn-bg:#2a1d05; --warn-text:#fac775;
    --bad-bg:#2a0d0d; --bad-text:#f7c1c1; --neutral-bg:#2c2c2a; --neutral-text:#d3d1c7;
  }
}

*{box-sizing:border-box}
body{margin:0;background:var(--bg-page);color:var(--text-primary);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  line-height:1.6;font-size:15px;font-weight:400}
a{color:var(--accent);text-decoration:none}
h1{font-size:20px;font-weight:500;margin:0 0 .25rem}
h2{font-size:15px;font-weight:500;margin:1.5rem 0 .5rem}
p{margin:.4rem 0}

/* ---- app bar ---- */
.appbar{display:flex;align-items:center;gap:.6rem;padding:.7rem 1.25rem;
  background:var(--bg-raised);border-bottom:.5px solid var(--border)}
.logo-tile{display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:6px;background:var(--accent-bg);color:var(--accent-text);
  font-weight:500;font-size:14px}
.logo-tile.lg{width:44px;height:44px;font-size:22px;border-radius:var(--radius)}
.appbar .product{font-weight:500}
.appbar .meta{color:var(--text-secondary);font-size:14px}
.appbar .spacer{flex:1}
.health-pill{font-size:11px;font-weight:500;padding:3px 10px;border-radius:var(--radius)}

/* ---- tab nav ---- */
.tabs{display:flex;align-items:center;gap:1.25rem;padding:0 1.25rem;
  background:var(--bg-raised);border-bottom:.5px solid var(--border)}
.tabs a{display:inline-block;padding:.6rem 0;color:var(--text-secondary);font-size:14px;
  border-bottom:2px solid transparent;margin-bottom:-.5px}
.tabs a.active{color:var(--text-primary);border-bottom-color:var(--text-primary)}
.tabs .spacer{flex:1}

/* ---- layout ---- */
.main{max-width:1100px;margin:0 auto;padding:1.5rem}
.caption{color:var(--text-tertiary);font-size:13px;margin:.1rem 0 1rem}
.muted{color:var(--text-secondary)}

/* ---- metric cards ---- */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin:1rem 0 1.5rem}
.metric{background:var(--bg-surface);border-radius:var(--radius);padding:.85rem 1rem}
.metric .label{color:var(--text-secondary);font-size:12px}
.metric .num{font-size:24px;font-weight:500;margin-top:.15rem}
.metric .num.accent{color:var(--accent)}
.metric .num.ok{color:var(--ok)}
.metric .num.warn{color:var(--warn)}
.metric .num.bad{color:var(--bad)}
@media (max-width:720px){.metrics{grid-template-columns:repeat(2,1fr)}}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse;background:var(--bg-raised);
  border:.5px solid var(--border);border-radius:var(--radius);overflow:hidden}
th,td{text-align:left;padding:.6rem .75rem;border-bottom:.5px solid var(--border);vertical-align:top}
th{background:var(--bg-surface);font-size:12px;font-weight:500;color:var(--text-secondary)}
tr:last-child td{border-bottom:none}
.bar{height:5px;border-radius:3px;background:var(--neutral-bg);overflow:hidden;width:120px;display:inline-block;
  vertical-align:middle;margin-right:.5rem}
.bar > span{display:block;height:100%}
.bar.ok > span{background:var(--ok)}
.bar.warn > span{background:var(--warn)}
.bar.bad > span{background:var(--bad)}

/* ---- pills ---- */
.pill{display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--radius)}
.pill-accent{background:var(--accent-bg);color:var(--accent-text)}
.pill-ok{background:var(--ok-bg);color:var(--ok-text)}
.pill-warn{background:var(--warn-bg);color:var(--warn-text)}
.pill-bad{background:var(--bad-bg);color:var(--bad-text)}
.pill-neutral{background:var(--neutral-bg);color:var(--neutral-text)}

/* ---- cards ---- */
.card{background:var(--bg-raised);border:.5px solid var(--border);border-radius:var(--radius);
  padding:1rem;margin-bottom:1rem}
.row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.row .spacer{flex:1}

/* ---- buttons ---- */
button,.btn{font:inherit;font-weight:500;padding:.45rem .9rem;border:.5px solid var(--border-strong);
  border-radius:var(--radius);background:transparent;color:var(--text-primary);cursor:pointer}
button:hover,.btn:hover{background:var(--bg-surface)}
button:active,.btn:active{transform:scale(.98)}
button.primary,.btn.primary{background:var(--accent-bg);color:var(--accent-text);border-color:transparent}

/* ---- forms ---- */
input,select,textarea{font:inherit;width:100%;padding:0 .6rem;height:36px;
  border:.5px solid var(--border);border-radius:var(--radius);background:var(--bg-raised);
  color:var(--text-primary)}
textarea{height:auto;min-height:96px;padding:.5rem .6rem;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:13px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-bg)}
label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:.5rem}
form.inline{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
form.inline input,form.inline select{width:auto}

/* ---- monospace body (DSN / inbox text) ---- */
.dsn{white-space:pre-wrap;font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:13px;
  background:var(--bg-surface);padding:.6rem;border-radius:var(--radius);
  border:.5px solid var(--border);max-height:280px;overflow:auto}
.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px}
details summary{cursor:pointer;color:var(--accent);font-size:13px}

/* ---- wide / scrollable tables ---- */
.table-scroll{overflow:auto;border:.5px solid var(--border);border-radius:var(--radius)}
.table-scroll table{border:none;border-radius:0}
.table-scroll td,.table-scroll th{white-space:nowrap;max-width:280px;overflow:hidden;text-overflow:ellipsis}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}
.grid2 .full{grid-column:1 / -1}
.field{margin-bottom:.6rem}
.section-head{display:flex;align-items:center;gap:.75rem;margin:1.5rem 0 .25rem}
.section-head h2{margin:0}
.notice{background:var(--accent-bg);color:var(--accent-text);font-size:13px;
  padding:.5rem .75rem;border-radius:var(--radius);margin-bottom:1rem;display:inline-block}

/* ---- pager ---- */
.pager{display:flex;align-items:center;gap:.5rem;margin:.75rem 0;font-size:13px}
.pager .muted{margin:0 .25rem}
.btn.sm,button.sm{padding:.2rem .55rem;font-size:12px}
.btn.danger,button.danger{color:var(--bad-text);border-color:var(--border)}
.btn.danger:hover,button.danger:hover{background:var(--bad-bg)}

/* ---- login ---- */
.login-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center}
.login-card{background:var(--bg-raised);border:.5px solid var(--border);border-radius:var(--radius-lg);
  padding:2rem;width:340px}
.login-card .logo-tile.lg{margin-bottom:1rem}
.err{color:var(--bad);font-size:13px;margin-bottom:.5rem}
