/* Backblaze Backup Controller — admin UI styles */
:root{
  --bg:#0f1320; --panel:#171c2c; --panel2:#1d2336; --line:#2a3148;
  --text:#e6e9f2; --muted:#8b93a7; --accent:#3b82f6; --accent2:#2563eb;
  --ok:#16a34a; --warn:#d97706; --bad:#dc2626; --off:#6b7280;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.45}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:rgba(255,255,255,.06);padding:1px 5px;border-radius:4px}

.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--panel);
  padding:12px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700}
.topbar nav{display:flex;align-items:center;gap:16px}
.topbar nav .who{color:var(--muted);font-size:12px}
.topbar nav .logout{color:var(--muted)}

.wrap{max-width:1560px;margin:24px auto;padding:0 20px}
.foot{max-width:1560px;margin:20px auto 40px;padding:0 20px;color:var(--muted);font-size:12px;text-align:center}

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

.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:20px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.hint{color:var(--muted);font-size:12px;margin:10px 0 0}
.muted{color:var(--muted)}
.err{color:#fca5a5;font-size:12px}

.btn{display:inline-block;background:var(--panel2);color:var(--text);border:1px solid var(--line);
  border-radius:7px;padding:7px 12px;cursor:pointer;font-size:13px}
.btn:hover{border-color:var(--accent);text-decoration:none}
.btn.primary{background:var(--accent2);border-color:var(--accent2)}
.btn.primary:hover{background:var(--accent)}
.btn.small{padding:4px 9px;font-size:12px}
.btn.danger{color:#fecaca;border-color:#7f1d1d}
.btn.danger:hover{background:#7f1d1d}
.actions-row{display:flex;gap:10px;flex-wrap:wrap}
.inline{display:inline}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}

table.grid{width:100%;border-collapse:collapse}
table.grid th,table.grid td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
table.grid thead th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
table.grid.compact th,table.grid.compact td{padding:5px 8px;font-size:12.5px}
table.grid tr.row-bad{background:rgba(220,38,38,.08)}
.nowrap{white-space:nowrap}
.path{font-family:ui-monospace,monospace;font-size:12px;word-break:break-all}

/* Friendly date: prominent date line, smaller muted time/relative line. */
.fdate{display:block;font-size:14.5px;font-weight:600;white-space:nowrap}
.fmeta{display:block;font-size:11.5px;color:var(--muted);white-space:nowrap;margin-top:1px}

/* Instant CSS tooltip (more reliable than the native title="" attribute).
   Any element with data-tip shows it on hover/focus. */
[data-tip]{position:relative}
td[data-tip]{cursor:help}
[data-tip]:hover::after,[data-tip]:focus::after{
  content:attr(data-tip);
  position:absolute;left:50%;top:calc(100% + 9px);transform:translateX(-50%);
  width:max-content;max-width:280px;white-space:normal;text-align:left;
  text-transform:none;letter-spacing:normal;font-weight:400;font-size:12px;line-height:1.45;
  color:var(--text);background:#0b0e18;border:1px solid var(--line);border-radius:8px;
  padding:9px 11px;box-shadow:0 10px 28px rgba(0,0,0,.5);z-index:50;pointer-events:none}
[data-tip]:hover::before,[data-tip]:focus::before{
  content:"";position:absolute;left:50%;top:calc(100% + 3px);transform:translateX(-50%);
  border:6px solid transparent;border-bottom-color:var(--line);z-index:51;pointer-events:none}

/* Header help icon (the round "?"). */
.help{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;
  margin-left:5px;border:1px solid var(--line);border-radius:50%;color:var(--muted);
  font-size:10px;font-weight:700;line-height:1;cursor:help;vertical-align:middle;text-transform:none}
.help:hover,.help:focus{border-color:var(--accent);color:var(--text);outline:none}

table.kv{border-collapse:collapse}
table.kv th{text-align:left;color:var(--muted);font-weight:600;padding:6px 14px 6px 0;white-space:nowrap;vertical-align:top}
table.kv td{padding:6px 0}

/* Compact horizontal stat strip (e.g. Archive catalog summary). */
.stats{display:flex;flex-wrap:wrap;gap:10px}
.stat{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:7px 16px;min-width:92px}
.stat .num{font-size:20px;font-weight:700;line-height:1.15}
.stat .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.stat.stat-bad{border-color:#7f1d1d;background:rgba(220,38,38,.1)}
.stat.stat-bad .num{color:#fca5a5}

.pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}
.pill.ok{background:rgba(22,163,74,.18);color:#86efac}
.pill.warn{background:rgba(217,119,6,.18);color:#fcd34d}
.pill.bad{background:rgba(220,38,38,.18);color:#fca5a5}
.pill.off{background:rgba(107,114,128,.2);color:#cbd5e1}

.alert{border-radius:8px;padding:12px 14px;margin-bottom:16px}
.alert.ok{background:rgba(22,163,74,.12);border:1px solid rgba(22,163,74,.4)}
.alert.error{background:rgba(220,38,38,.12);border:1px solid rgba(220,38,38,.4)}
.alert ul{margin:0;padding-left:18px}
pre.msg{white-space:pre-wrap;word-break:break-word;margin:0;font-family:ui-monospace,monospace;font-size:12.5px}

/* Forms */
.form-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 18px 18px}
fieldset{border:1px solid var(--line);border-radius:8px;margin:16px 0;padding:14px 16px}
legend{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:0 6px}
label{display:block;margin:10px 0;font-size:13px;color:var(--muted)}
label.check{display:flex;align-items:center;gap:8px;color:var(--text)}
input[type=text],input[type=password],input[type=number],select{
  display:block;width:100%;margin-top:5px;background:var(--bg);color:var(--text);
  border:1px solid var(--line);border-radius:7px;padding:8px 10px;font-size:14px}
input:focus,select:focus{outline:none;border-color:var(--accent)}
.form-actions{display:flex;gap:10px;margin-top:8px}

/* Login */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:28px;width:340px;max-width:90vw}
.login-card h1{margin:0;font-size:20px}
.login-card .subtitle{color:var(--muted);margin:4px 0 18px;font-size:13px}
.login-card .btn{width:100%;margin-top:8px;text-align:center}
