/* VaultPRO — deep purple base, single amber accent (PRO only), tonal pills.
   Internal codebase name: BlueLion. */

@import url("https://fonts.googleapis.com/css2?family=Archivo+Black&family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap");

:root {
  /* one base, one elevation, one deep */
  --bg:           #0b0613;
  --bg-elev:      #160a2c;
  --bg-deep:      #050208;

  /* one primary, one accent (accent only used in wordmark) */
  --purple:       #7c3aed;
  --purple-hi:    #a78bfa;
  --amber:        #fbbf24;

  /* warm text on dark purple */
  --ink:          #f5f3ff;
  --ink-2:        #b7add0;
  --ink-3:        #7d7299;
  --line:         #2a1857;

  /* status — colored text + thin border, never full fills */
  --good:         #6ee7a7;
  --warn:         #fbbf24;
  --bad:          #fda4af;

  --rad:          10px;
  --rad-sm:       6px;
}

* { box-sizing: border-box; }
html, body { background: var(--bg); }
body {
  margin: 0;
  font: 15px/1.55 "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
  min-height: 100vh;
}
a { color: var(--purple-hi); text-decoration: none; }
a:hover { color: var(--ink); }

/* ------- header / brand ------- */
header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 18px 28px;
  background: var(--bg-deep);
  border-bottom: 1px solid var(--line);
}
.brand {
  display: flex; align-items: center; gap: 14px;
  color: var(--ink); text-decoration: none;
}
.brand .mark {
  width: 42px; height: 42px;
  flex-shrink: 0;
  position: relative;
  display: grid; place-items: center;
}
.brand .mark::before {
  content: attr(data-letter);
  position: absolute; inset: 0;
  border: 1.5px solid var(--ink-3);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--ink-3);
  font-family: "Archivo Black", sans-serif;
  font-size: 15px;
  letter-spacing: -0.02em;
}
.brand .mark:has(img)::before { display: none; }
.brand .mark img {
  width: 100%; height: 100%;
  object-fit: contain;
}
.brand .wordmark {
  font-family: "Archivo Black", system-ui, sans-serif;
  font-weight: 900;
  font-size: 22px;
  letter-spacing: 0.005em;
  line-height: 1;
}
.brand .wordmark .pro { color: var(--amber); }
.brand .kicker {
  font-family: "Space Grotesk", sans-serif;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 4px;
  display: block;
}
header h1 { margin: 0; font-size: 0; line-height: 1; }
header h1 a { color: inherit; text-decoration: none; }

.topnav { display: flex; gap: 10px; align-items: center; font-size: 13px; color: var(--ink-3); }
.topnav span { color: var(--ink-3); }
.topnav code {
  background: transparent;
  color: var(--ink-2);
  border: 1px solid var(--line);
  padding: 2px 9px;
  border-radius: 4px;
  font-family: "Space Grotesk", monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.topnav button, .topnav a {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  padding: 7px 14px; border-radius: var(--rad-sm);
  background: transparent; color: var(--ink-2);
  border: 1px solid var(--line);
  cursor: pointer; text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.topnav button:hover, .topnav a:hover { color: var(--ink); border-color: var(--ink-3); }

/* ------- layout ------- */
main { padding: 32px 28px; max-width: 1200px; margin: 0 auto; }
.tag { color: var(--ink-3); font-size: 14px; margin: -12px auto 32px; max-width: 1100px; padding: 0 28px; }

h2 {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700; font-size: 20px;
  margin: 28px 0 14px;
  letter-spacing: -0.005em;
  color: var(--ink);
}
h3 {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600; font-size: 14px;
  margin: 28px 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-3);
}

/* ------- cards (home page entity tiles) ------- */
.cards {
  list-style: none; padding: 0;
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  overflow: hidden;
  transition: border-color 0.12s, transform 0.12s;
}
.card:hover { border-color: var(--purple); transform: translateY(-1px); }
.card a { display: block; padding: 16px 18px; color: var(--ink); text-decoration: none; }
.card.retired { opacity: 0.45; }
.card .title { font-weight: 600; font-size: 15px; }
.card .meta { color: var(--ink-3); font-size: 12px; margin-top: 6px; font-family: "Space Grotesk", monospace; }
.empty { color: var(--ink-3); font-style: italic; padding: 16px; }

/* ------- chain status pill ------- */
.chain {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 32px; padding: 10px 16px;
  border-radius: var(--rad);
  background: transparent;
  border: 1px solid var(--line);
  font-family: "Space Grotesk", sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-2);
}
.chain::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--good);
  box-shadow: 0 0 12px var(--good);
}
.chain.bad { color: var(--bad); }
.chain.bad::before { background: var(--bad); box-shadow: 0 0 12px var(--bad); }

/* ------- record viewer ------- */
.record {
  background: var(--bg-elev);
  padding: 32px 36px;
  border: 1px solid var(--line);
  border-radius: var(--rad);
}
.record-head {
  display: flex; justify-content: space-between; gap: 32px;
  align-items: flex-start;
  padding-bottom: 24px; border-bottom: 1px solid var(--line);
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.record-id { display: flex; gap: 24px; align-items: flex-start; }

/* photo slot — shows the photo if one exists, placeholder otherwise */
.record-photo {
  width: 132px; height: 132px;
  flex-shrink: 0;
  position: relative;
  border-radius: var(--rad-sm);
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--bg-deep);
}
.record-photo img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.photo-ph {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  color: var(--ink-3);
}
.photo-ph svg { width: 52px; height: 52px; }
.photo-ph span {
  font-family: "Space Grotesk", sans-serif;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}
.record-photo:has(img) .photo-ph { display: none; }
.record-head h2 {
  margin: 8px 0 18px;
  font-size: 34px;
  font-family: "Archivo Black", sans-serif;
  font-weight: 900;
  letter-spacing: -0.015em;
  line-height: 1.05;
}
.kicker {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 11px;
  color: var(--ink-3);
}
.record dl {
  display: grid; grid-template-columns: max-content 1fr;
  gap: 8px 24px; margin: 0; font-size: 14px;
}
.record dt {
  color: var(--ink-3);
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 11px;
  align-self: center;
}
.qr {
  width: 168px; height: 168px;
  padding: 8px;
  background: white;
  border-radius: var(--rad-sm);
  border: 1px solid var(--line);
}

/* ------- tables ------- */
table { width: 100%; border-collapse: collapse; margin-top: 8px; }
th, td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--line); font-size: 13px; }
th {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 10px;
  background: transparent;
}
tr.superseded { opacity: 0.35; text-decoration: line-through; }
table code {
  background: transparent;
  color: var(--ink-2);
  padding: 1px 0;
  font-family: "Space Grotesk", monospace;
  font-size: 12px;
}

/* ------- pills: neutral bg, colored text + thin border ------- */
.status, .src {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink-3);
}
.status-current { color: var(--good); border-color: rgba(110, 231, 167, 0.3); }
.status-expiring, .status-due_soon { color: var(--warn); border-color: rgba(251, 191, 36, 0.3); }
.status-expired, .status-overdue { color: var(--bad); border-color: rgba(253, 164, 175, 0.35); }
.status-no_expiry, .status-no_due_date { color: var(--ink-2); border-color: var(--line); }
.src-manual { color: var(--purple-hi); border-color: rgba(167, 139, 250, 0.3); }
.src-servicepro { color: var(--amber); border-color: rgba(251, 191, 36, 0.3); }

/* ------- raw event log inside record viewer ------- */
.events { list-style: none; padding-left: 0; max-height: 400px; overflow: auto; }
.events li { border-bottom: 1px solid var(--line); padding: 10px 0; font-size: 12px; }
.events code {
  background: transparent;
  color: var(--ink-2);
  padding: 1px 0;
  font-family: "Space Grotesk", monospace;
  font-size: 11px;
}
.events pre {
  background: var(--bg-deep);
  border: 1px solid var(--line);
  padding: 10px;
  border-radius: var(--rad-sm);
  overflow: auto;
  font-size: 11px;
  color: var(--ink-2);
  font-family: "Space Grotesk", monospace;
}
details > summary {
  cursor: pointer;
  margin: 20px 0 8px;
  color: var(--ink-3);
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 11px;
  font-weight: 600;
}

/* ------- generic helpers ------- */
.muted { color: var(--ink-3); }
.small { font-size: 12px; }
.error {
  background: transparent;
  color: var(--bad);
  padding: 10px 14px;
  border-radius: var(--rad-sm);
  border: 1px solid rgba(253, 164, 175, 0.35);
}

/* ------- login ------- */
.login-wrap { max-width: 440px; margin: 80px auto; padding: 0 24px; }
.card-form {
  background: var(--bg-elev);
  padding: 32px;
  border-radius: var(--rad);
  border: 1px solid var(--line);
}
.card-form h2 {
  margin: 0 0 16px;
  font-family: "Archivo Black", sans-serif;
  font-size: 24px;
  letter-spacing: -0.015em;
}
.card-form label, .forms label, .filters label, .horizon label {
  display: block;
  margin: 14px 0 4px;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-3);
}
.card-form input, .card-form select, .card-form textarea,
.forms input, .forms select, .forms textarea,
.filters input, .filters select, .horizon input {
  display: block; width: 100%;
  margin-top: 4px; padding: 11px 13px;
  border: 1px solid var(--line);
  border-radius: var(--rad-sm);
  font: inherit;
  font-size: 14px;
  background: var(--bg-deep);
  color: var(--ink);
  transition: border-color 0.15s;
}
.card-form input:focus, .card-form select:focus, .card-form textarea:focus,
.forms input:focus, .forms select:focus, .forms textarea:focus,
.filters input:focus, .filters select:focus, .horizon input:focus {
  outline: none; border-color: var(--purple);
}
.card-form button, .forms button, .filters button, .horizon button {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.14em;
  padding: 13px;
  background: var(--purple);
  color: var(--ink);
  border: 0; border-radius: var(--rad-sm);
  cursor: pointer;
  transition: background 0.15s;
}
.card-form button { width: 100%; margin-top: 18px; }
.card-form button:hover, .forms button:hover, .filters button:hover, .horizon button:hover {
  background: var(--purple-hi);
}

/* ------- admin shell + tabs ------- */
.admin { padding: 32px 28px; max-width: 1280px; margin: 0 auto; }
.tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--line);
  margin-bottom: 28px;
}
.tab {
  background: transparent; border: 0;
  padding: 14px 20px; cursor: pointer;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-3);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.15s;
}
.tab:hover { color: var(--ink-2); }
.tab.active { color: var(--ink); border-bottom-color: var(--purple); }

.two-col { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; }
.two-col table {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  overflow: hidden;
}
.forms details {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  margin-bottom: 14px;
  padding: 14px 18px;
}
.forms details > summary {
  margin: 0;
  color: var(--ink);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-family: "Space Grotesk", sans-serif;
}
.forms textarea { min-height: 70px; resize: vertical; }
.forms button { padding: 10px 16px; font-size: 11px; }

/* ------- flash toast ------- */
.flash {
  position: fixed; bottom: 24px; right: 24px;
  padding: 12px 18px;
  border-radius: var(--rad);
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  color: var(--ink-2);
}
.flash-ok { color: var(--good); border-color: rgba(110, 231, 167, 0.3); }
.flash-bad { color: var(--bad); border-color: rgba(253, 164, 175, 0.35); }

/* ------- expiring dashboard ------- */
.expiring { padding: 32px 28px; max-width: 1150px; margin: 0 auto; }
.horizon { display: flex; align-items: end; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }
.horizon input { width: 110px; }
.horizon button { padding: 10px 16px; font-size: 11px; }

.counts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  margin-bottom: 28px;
}
.count {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 22px;
  text-align: center;
}
.count .n {
  font-family: "Archivo Black", sans-serif;
  font-size: 44px; line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.count > div:last-child {
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 10px;
  margin-top: 10px;
  color: var(--ink-3);
}
.count-bad .n { color: var(--bad); }
.count-warn .n { color: var(--warn); }

#expiring-frame { width: 100%; height: 80vh; border: 0; border-radius: var(--rad); background: var(--bg); }

/* search results pager */
.pager { display: flex; align-items: center; gap: 14px; margin-top: 14px; }
.pager button[disabled] { opacity: 0.35; cursor: default; }

/* sortable table headers */
th.sortable { cursor: pointer; user-select: none; white-space: nowrap; }
th.sortable:hover { color: var(--ink-2); }
th.sorted { color: var(--amber); }

/* clickable cert-type rows */
tr.cert-row { cursor: pointer; }
tr.cert-row:hover td { background: rgba(168, 85, 247, 0.06); }

/* ------- audit pane (admin > audit tab) ------- */
.audit-header { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.sub-tabs { display: flex; gap: 6px; }
.sub-tab {
  background: transparent;
  border: 1px solid var(--line);
  padding: 8px 14px;
  border-radius: var(--rad-sm);
  cursor: pointer;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600; font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-3);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.sub-tab:hover { color: var(--ink-2); border-color: var(--ink-3); }
.sub-tab.active { background: var(--purple); color: var(--ink); border-color: var(--purple); }
.live {
  display: flex; align-items: center; gap: 6px;
  color: var(--ink-3); font-size: 10px;
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase; letter-spacing: 0.14em;
}
.ghost {
  background: transparent;
  border: 1px solid var(--line);
  padding: 7px 12px;
  border-radius: var(--rad-sm);
  cursor: pointer;
  font-family: "Space Grotesk", sans-serif;
  font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.14em;
  font-weight: 600;
  color: var(--ink-3);
  transition: color 0.15s, border-color 0.15s;
}
.ghost:hover { color: var(--ink); border-color: var(--ink-3); }
.audit-pane {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--rad);
  padding: 18px 20px;
}
.filters {
  display: flex; flex-wrap: wrap; gap: 14px; align-items: end;
  padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 14px;
}
.filters input, .filters select { padding: 8px 10px; font-size: 13px; }
.filters button { padding: 9px 14px; font-size: 10px; }
.entries { display: flex; flex-direction: column; gap: 6px; max-height: 72vh; overflow: auto; }
.entry {
  border: 1px solid var(--line);
  border-radius: var(--rad-sm);
  background: var(--bg-deep);
}
.entry > summary {
  display: grid;
  grid-template-columns: 95px 56px 1fr auto auto;
  gap: 10px; align-items: center;
  padding: 10px 14px;
  cursor: pointer; list-style: none;
  font-size: 13px;
  border-radius: var(--rad-sm);
}
.entry > summary::-webkit-details-marker, .entry > summary::marker { display: none; content: ""; }
.entry[open] > summary { border-bottom: 1px solid var(--line); border-radius: var(--rad-sm) var(--rad-sm) 0 0; }
.entry > summary code {
  background: transparent; padding: 0;
  color: var(--ink); font-family: "Space Grotesk", monospace; font-size: 12px;
}
.entry .ts, .entry .actor, .entry .dur {
  color: var(--ink-3); font-size: 11px;
  font-family: "Space Grotesk", monospace;
}
.entry .dur { text-align: right; }
.entry .msg {
  font-size: 12px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-family: "Space Grotesk", monospace;
  color: var(--ink-2);
}
.entry-error .msg { color: var(--bad); }
.entry .event-type {
  font-weight: 700;
  color: var(--amber);
  font-size: 10px;
  font-family: "Space Grotesk", sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.entry .status {
  font-family: "Space Grotesk", monospace;
  font-size: 10px; padding: 3px 8px;
  border-radius: 4px; text-align: center;
  letter-spacing: 0.05em;
  font-weight: 700;
  background: transparent;
  border: 1px solid var(--line);
}
.stat-2xx { color: var(--good); border-color: rgba(110, 231, 167, 0.3); }
.stat-3xx { color: var(--purple-hi); border-color: rgba(167, 139, 250, 0.3); }
.stat-4xx { color: var(--warn); border-color: rgba(251, 191, 36, 0.3); }
.stat-5xx { color: var(--bad); border-color: rgba(253, 164, 175, 0.35); }
.entry-error { border-color: rgba(253, 164, 175, 0.25); }
.entry dl {
  display: grid; grid-template-columns: max-content 1fr;
  gap: 4px 14px; padding: 0 18px 12px; margin: 12px 0 0; font-size: 12px;
}
.entry dt {
  color: var(--ink-3);
  font-family: "Space Grotesk", sans-serif;
  text-transform: uppercase; letter-spacing: 0.1em;
  font-size: 10px;
}
.entry .ua { word-break: break-all; }
.entry pre {
  margin: 0 14px 14px; padding: 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--rad-sm);
  font-family: "Space Grotesk", monospace;
  font-size: 11px;
  max-height: 320px; overflow: auto;
  color: var(--ink-2);
}
.entry .stack { color: var(--bad); }
.entry .hash { font-size: 10px; word-break: break-all; color: var(--purple-hi); }
