:root {
  --bg: #0e0f12;
  --bg-2: #15171c;
  --bg-3: #1c1f26;
  --fg: #e5e7eb;
  --fg-dim: #8b91a0;
  --accent: #c9a86a;
  --accent-dim: #826b3f;
  --err: #ef4444;
  --warn: #f59e0b;
  --ok: #34d399;
  --border: #2a2e38;
  --radius: 6px;
  --mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  min-height: 100vh;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

main { max-width: 1280px; margin: 0 auto; padding: 24px 28px 64px; }

h1 { font-size: 22px; font-weight: 600; margin: 0 0 24px; letter-spacing: -0.01em; }
h2 { font-size: 16px; font-weight: 600; margin: 32px 0 12px; color: var(--fg-dim); text-transform: uppercase; letter-spacing: 0.06em; }
h2 + table.data { margin-top: 0; }

.dim { color: var(--fg-dim); }
.err { color: var(--err); }
.hl  { color: var(--warn); }

/* Topnav */
.topnav {
  display: flex; align-items: center; gap: 24px;
  padding: 12px 28px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
}
.topnav .brand { font-family: var(--mono); font-size: 14px; color: var(--accent); letter-spacing: 0.1em; }
.topnav .nav-links { display: flex; gap: 16px; flex: 1; }
.topnav .nav-links a { color: var(--fg); font-weight: 500; }
.topnav .nav-links a:hover { color: var(--accent); text-decoration: none; }
.topnav .logout { display: flex; align-items: center; gap: 12px; margin: 0; }
.topnav .user { color: var(--fg-dim); font-family: var(--mono); font-size: 12px; }
.btn-link { background: none; border: none; color: var(--fg-dim); cursor: pointer; padding: 0; font: inherit; }
.btn-link:hover { color: var(--err); }

/* Auth-Card */
.auth-card {
  max-width: 380px; margin: 64px auto;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 32px;
}
.auth-card h1 { font-family: var(--mono); font-size: 18px; color: var(--accent); margin-bottom: 24px; }
.auth-card .hint { color: var(--fg-dim); font-size: 13px; margin-bottom: 16px; }
.auth-card .error {
  background: rgba(239,68,68,0.1); color: var(--err);
  padding: 8px 12px; border-radius: var(--radius); margin-bottom: 16px;
  font-size: 13px;
}
.auth-card form { display: flex; flex-direction: column; gap: 14px; }
.auth-card label { display: flex; flex-direction: column; gap: 6px; font-size: 12px; color: var(--fg-dim); text-transform: uppercase; letter-spacing: 0.05em; }
.auth-card input {
  background: var(--bg-3); border: 1px solid var(--border); color: var(--fg);
  padding: 10px 12px; border-radius: var(--radius); font: inherit;
}
.auth-card input:focus { outline: none; border-color: var(--accent); }
.auth-card button {
  background: var(--accent); color: var(--bg);
  border: none; padding: 10px; border-radius: var(--radius);
  font-weight: 600; cursor: pointer; margin-top: 8px;
}
.auth-card button:hover { background: var(--accent-dim); color: var(--fg); }

/* KPI-Grid */
.kpi-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px; margin-bottom: 32px;
}
.kpi {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px;
}
.kpi-label { font-size: 11px; color: var(--fg-dim); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.kpi-value { font-size: 24px; font-weight: 600; font-family: var(--mono); }

/* Tables */
table.data {
  width: 100%; border-collapse: collapse; margin: 16px 0;
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden;
}
table.data th, table.data td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border); }
table.data th { background: var(--bg-3); color: var(--fg-dim); font-weight: 500; font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
table.data tr:last-child td { border-bottom: none; }
table.data tr:hover { background: rgba(201,168,106,0.04); }
table.data code { font-family: var(--mono); font-size: 12px; color: var(--fg-dim); }

/* Badges */
.badge {
  font-size: 11px; padding: 2px 8px; border-radius: 999px;
  border: 1px solid var(--border); display: inline-block;
}
.badge.inbound { background: rgba(52,211,153,0.1); color: var(--ok); border-color: var(--ok); }
.badge.outbound { background: rgba(245,158,11,0.1); color: var(--warn); border-color: var(--warn); }

/* Status colors */
.status-new, .status-received, .status-pending { color: var(--fg-dim); }
.status-running, .status-review, .status-drafted { color: var(--warn); }
.status-approved, .status-done, .status-sent, .status-delivered, .status-published, .status-confirmed, .status-ok { color: var(--ok); }
.status-failed, .status-rejected, .status-error, .status-bounced, .status-unsubscribed { color: var(--err); }
.status-qualified, .status-customer, .status-opportunity { color: var(--accent); }

/* Detail-View */
.back { display: inline-block; margin-bottom: 12px; color: var(--fg-dim); }
dl.kv { display: grid; grid-template-columns: 140px 1fr; gap: 6px 16px; margin: 16px 0; max-width: 800px; }
dl.kv dt { color: var(--fg-dim); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; padding-top: 4px; }
dl.kv dd { margin: 0; }
pre.body-text, pre.json {
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px; overflow-x: auto; font-family: var(--mono); font-size: 12px; line-height: 1.6;
  white-space: pre-wrap; word-wrap: break-word;
}

/* Touchpoint-Detail */
.tp-head { margin-bottom: 24px; }
.tp-meta { display: flex; gap: 12px; align-items: center; font-size: 13px; }
.tp-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 32px; }
@media (max-width: 1000px) { .tp-grid { grid-template-columns: 1fr; } }

article.briefing {
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 28px 32px; line-height: 1.7;
}
article.briefing h1 { font-size: 18px; margin: 0 0 14px; color: var(--accent); }
article.briefing h2 { font-size: 14px; color: var(--fg); text-transform: none; letter-spacing: 0; margin: 22px 0 8px; }
article.briefing p  { margin: 0 0 12px; }
article.briefing strong { color: var(--accent); font-weight: 500; }
article.briefing ul, article.briefing ol { margin: 8px 0 14px; padding-left: 22px; }
article.briefing li { margin-bottom: 4px; }
article.briefing code { background: var(--bg-3); padding: 1px 6px; border-radius: 3px; font-size: 12px; }

.tech-tag {
  display: inline-block; background: var(--bg-3); border: 1px solid var(--border);
  padding: 2px 8px; border-radius: 999px; font-family: var(--mono); font-size: 11px;
  margin: 0 4px 4px 0; color: var(--fg-mute);
}

.findings { list-style: none; margin: 0 0 24px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.findings li {
  border-left: 3px solid var(--border);
  padding: 10px 14px; background: var(--bg-2); border-radius: 4px;
  font-size: 13px;
}
.findings li.f-block { border-left-color: var(--err); background: rgba(239,68,68,0.06); }
.findings li.f-warn  { border-left-color: var(--warn); background: rgba(245,158,11,0.06); }
.findings li.f-info  { border-left-color: var(--ok); }
.findings .lvl { font-family: var(--mono); font-size: 10px; padding: 2px 6px; border-radius: 3px;
                 background: var(--bg-3); margin-right: 8px; text-transform: uppercase; letter-spacing: 0.05em; }
.findings .cat { color: var(--fg-mute); margin-right: 8px; font-size: 12px; }
.findings .quote { color: var(--fg-mute); font-style: italic; margin-top: 4px; font-size: 12px; }

table.data.compact th, table.data.compact td { padding: 6px 10px; font-size: 12px; }

details.raw { margin-top: 32px; }
details.raw summary { cursor: pointer; color: var(--fg-mute); font-size: 12px; padding: 8px 0; }
details.raw[open] summary { color: var(--fg); }
