/* Alerts Management — baseline styles. */
:root {
    --bg: #0f1117;
    --panel: #171a21;
    --panel-2: #1f232c;
    --text: #e7ebf0;
    --muted: #8b93a1;
    --accent: #4a9eff;
    --red: #ff5858;
    --orange: #ff9844;
    --yellow: #ffd460;
    --blue: #4a9eff;
    --grey: #6b7280;
    --border: #2a2f3a;
}
* { box-sizing: border-box; }
body {
    margin: 0;
    font: 14px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    background: var(--bg);
    color: var(--text);
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.topbar {
    display: flex; align-items: center; gap: 20px;
    padding: 10px 20px;
    background: var(--panel);
    border-bottom: 1px solid var(--border);
}
.topbar .brand { font-weight: 700; font-size: 16px; }
.topbar nav { display: flex; gap: 16px; }
.topbar .user { margin-left: auto; display: flex; gap: 12px; align-items: center; color: var(--muted); }
.tz-badge { font-size: 11px; color: var(--muted); background: var(--panel-2); padding: 2px 8px; border-radius: 10px; border: 1px solid var(--border); cursor: help; }
time.ts { font-variant-numeric: tabular-nums; }
time.ts-stale { color: var(--orange); }
time.ts-fresh { color: var(--muted); }
.ts-empty { color: var(--muted); }
main { max-width: 1200px; margin: 0 auto; padding: 24px; }
h1 { font-weight: 600; margin-top: 0; }
.flash { padding: 10px 20px; background: #2d3a4e; color: var(--text); border-bottom: 1px solid var(--border); }
.flash-error { background: #4e2d2d; }
.flash-ok    { background: #2d4e35; }
.error { color: var(--red); margin-bottom: 12px; }
.banner { padding: 12px 16px; border-radius: 6px; margin: 12px 0 20px; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.banner-warn { background: #5b4420; border: 1px solid #8a6a2d; color: #f3dca0; }
.banner .btn { margin-left: auto; }
.login-card {
    max-width: 360px; margin: 60px auto; padding: 24px;
    background: var(--panel); border: 1px solid var(--border); border-radius: 8px;
}
.login-card label { display: block; margin-bottom: 12px; color: var(--muted); }
.login-card input {
    width: 100%; margin-top: 4px; padding: 8px 10px;
    background: var(--panel-2); color: var(--text);
    border: 1px solid var(--border); border-radius: 4px;
}
.login-card button, .btn {
    padding: 8px 16px; background: var(--accent); color: #fff;
    border: 0; border-radius: 4px; cursor: pointer; font-size: 14px;
}
.home-links { list-style: none; padding: 0; display: flex; gap: 12px; }
.home-links a { display: inline-block; padding: 8px 14px; background: var(--panel); border: 1px solid var(--border); border-radius: 4px; }
.system { color: var(--muted); font-size: 12px; }
table.data { width: 100%; border-collapse: collapse; background: var(--panel); }
table.data th, table.data td { padding: 8px 10px; border-bottom: 1px solid var(--border); text-align: left; vertical-align: top; }
table.data th { background: var(--panel-2); font-weight: 600; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.pill { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 11px; background: var(--panel-2); color: var(--muted); }
.pill-critical { background: var(--red); color: #fff; }
.pill-high     { background: var(--orange); color: #fff; }
.pill-medium   { background: var(--yellow); color: #000; }
.pill-low      { background: var(--blue); color: #fff; }
.form-grid { display: grid; grid-template-columns: 200px 1fr; gap: 10px 12px; max-width: 720px; }
.form-grid label { color: var(--muted); align-self: center; }
.form-grid input[type=text],
.form-grid input[type=email],
.form-grid input[type=password],
.form-grid select,
.form-grid textarea {
    width: 100%; padding: 6px 8px;
    background: var(--panel-2); color: var(--text);
    border: 1px solid var(--border); border-radius: 4px;
}
.toolbar { display: flex; gap: 8px; align-items: center; margin: 12px 0; flex-wrap: wrap; }
.btn-muted { background: var(--panel-2); color: var(--text); border: 1px solid var(--border); }
.action-grid form { display: flex; gap: 6px; flex-wrap: wrap; }
.rule-form fieldset { border: 1px solid var(--border); border-radius: 6px; padding: 16px 20px; margin: 16px 0; background: var(--panel); }
.rule-form legend { padding: 0 8px; color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .06em; }
.rule-form textarea { padding: 6px 8px; background: var(--panel-2); color: var(--text); border: 1px solid var(--border); border-radius: 4px; font: inherit; }
.rule-form .form-grid label { white-space: nowrap; }
.note-form { display: flex; flex-direction: column; gap: 6px; max-width: 720px; }
.note-form textarea { padding: 8px; background: var(--panel-2); color: var(--text); border: 1px solid var(--border); border-radius: 4px; font: inherit; }
.raw-row pre { white-space: pre-wrap; background: var(--panel-2); padding: 10px; border-radius: 4px; max-height: 400px; overflow: auto; }
table.data pre { white-space: pre-wrap; margin: 0; font-size: 12px; }
table.sortable th a { color: var(--muted); text-decoration: none; display: block; }
table.sortable th a:hover { color: var(--text); }
table.sortable th.sort-active a { color: var(--accent); }
.admin-nav { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.admin-nav a { padding: 6px 12px; background: var(--panel); border: 1px solid var(--border); border-radius: 4px; }
.admin-nav a.active { background: var(--accent); border-color: var(--accent); color: #fff; }
