:root {
  --bg:        #0a0d12;
  --bg-2:      #0d1118;
  --surface:   #141a26;
  --surface-2: #1a2230;
  --border:    rgba(120, 200, 220, 0.12);
  --border-soft: rgba(120, 200, 220, 0.06);
  --text:      #e8edf3;
  --text-soft: #aab3c1;
  --muted:     #6c7787;
  --dim:       #424c5c;
  --accent:    #0fdcb1;
  --accent-2:  #46f0c9;
  --accent-warm: #ff8540;
  --accent-soft: rgba(15, 220, 177, 0.12);
  --accent-glow: rgba(70, 240, 201, 0.35);
  --danger:    #f6486f;
  --warn:      #ffaa3a;
  --ok:        #0fdcb1;
}
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: "Poppins", system-ui, sans-serif;
  background: radial-gradient(ellipse 80% 60% at 50% -10%, rgba(15,220,177,0.04), transparent 70%), var(--bg);
  color: var(--text);
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
::selection { background: var(--accent); color: var(--bg); }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code, .mono { font-family: "JetBrains Mono", monospace; }

h1, h2, h3, h4 { font-weight: 900; letter-spacing: -0.02em; line-height: 1.15; }
h1 { font-size: 28px; }
h2 { font-size: 18px; }
h3 { font-size: 15px; }
.muted { color: var(--text-soft); }
.num { text-align: right; font-variant-numeric: tabular-nums; }

/* topbar */
.topbar {
  display: flex; align-items: center; gap: 28px;
  padding: 14px 32px;
  border-bottom: 1px solid var(--border);
  background: rgba(10, 13, 18, 0.7);
  backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 10;
}
.brand {
  font-family: "JetBrains Mono", monospace;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.06em;
}
.brand-mark { color: var(--accent); }
.brand:hover { text-decoration: none; color: var(--accent); }
.nav { display: flex; gap: 24px; flex: 1; }
.nav a {
  font-size: 13px;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
}
.nav a:hover { color: var(--text); text-decoration: none; }
.nav a.active { color: var(--accent); border-bottom-color: var(--accent); }
.me { display: flex; align-items: center; gap: 18px; font-size: 12px; color: var(--text-soft); }
.who { font-family: "JetBrains Mono", monospace; }
.role { color: var(--accent); margin-left: 6px; font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; padding: 2px 6px; border: 1px solid var(--accent); border-radius: 3px; }
.logout-form { display: inline; }
.btn-link { background: none; border: none; color: var(--text-soft); cursor: pointer; font: inherit; }
.btn-link:hover { color: var(--text); }

/* page wrapper */
.page {
  flex: 1;
  max-width: 1280px;
  margin: 0 auto;
  padding: 40px 32px;
  width: 100%;
}
.page-head { margin-bottom: 32px; }
.page-head h1 { margin-bottom: 6px; }
.foot {
  border-top: 1px solid var(--border-soft);
  padding: 18px 32px;
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.08em;
}

/* anonymous (login) layout */
body.is-anon { justify-content: center; }
.login-wrap { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: 24px; }
.login-card {
  width: 100%; max-width: 420px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 36px 32px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.login-head { margin-bottom: 24px; }
.login-mark {
  font-family: "JetBrains Mono", monospace;
  color: var(--accent);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}
.login-head h1 { margin: 8px 0 6px; font-size: 32px; }
.login-sub { color: var(--text-soft); font-size: 14px; }

/* forms */
.form { display: flex; flex-direction: column; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field > span { font-size: 12px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }
.field input, .field select, .field textarea {
  background: var(--bg-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 12px;
  font: inherit;
  font-size: 14px;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.btn {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  font: inherit;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.12s, border-color 0.12s;
}
.btn:hover { border-color: var(--accent); background: var(--accent-soft); text-decoration: none; }
.btn-primary {
  background: var(--accent);
  color: #00231b;
  border-color: var(--accent);
  font-weight: 600;
}
.btn-primary:hover { background: var(--accent-2); border-color: var(--accent-2); color: #00231b; }

/* flash */
.flash { padding: 10px 14px; border-radius: 6px; margin-bottom: 18px; font-size: 14px; border: 1px solid; }
.flash-ok    { color: var(--ok);     border-color: var(--ok);     background: rgba(15,220,177,0.08); }
.flash-error { color: var(--danger); border-color: var(--danger); background: rgba(246,72,111,0.08); }
.flash-warn  { color: var(--warn);   border-color: var(--warn);   background: rgba(255,170,58,0.08); }

/* kpis */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 32px; }
.kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.kpi-k { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 500; }
.kpi-v { font-size: 32px; font-weight: 900; letter-spacing: -0.02em; color: var(--text); font-variant-numeric: tabular-nums; }

/* cards / grid */
.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 18px; }
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
}
.card-title { margin-bottom: 16px; }

/* tables */
.data-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.data-table th, .data-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border-soft); }
.data-table th { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }
.data-table tr:last-child td { border-bottom: none; }

/* bars */
.bar { width: 100%; min-width: 80px; height: 6px; background: var(--bg-2); border-radius: 3px; overflow: hidden; }
.bar-fill { height: 100%; background: var(--accent); }
.bar-fill.warm { background: var(--accent-warm); }

/* responsive */
@media (max-width: 720px) {
  .topbar { flex-wrap: wrap; gap: 12px; padding: 12px 18px; }
  .nav { order: 3; width: 100%; gap: 16px; }
  .page { padding: 24px 18px; }
}
/* phase 2 additions */

.page-head-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.page-head-row .actions { display: flex; gap: 10px; align-items: center; }
.crumb { font-family: "JetBrains Mono", monospace; font-size: 12px; margin-bottom: 8px; }
.crumb a { color: var(--text-soft); }

/* filter bar */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 22px;
}
.field-inline { display: flex; flex-direction: column; gap: 4px; min-width: 160px; }
.field-inline > span { font-size: 11px; color: var(--text-soft); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }
.field-inline select, .field-inline input { font: inherit; font-size: 14px; padding: 8px 10px; background: var(--bg-2); color: var(--text); border: 1px solid var(--border); border-radius: 6px; }
.field-inline select:focus, .field-inline input:focus { outline: none; border-color: var(--accent); }

/* sortable headers */
.sortable .th-sort { color: inherit; text-decoration: none; }
.sortable .th-sort:hover { color: var(--accent); }
.data-table th { user-select: none; }
.data-table .truncate { max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.data-table td.small { font-size: 12px; }
.data-table .strain-link { color: var(--text); border-bottom: 1px solid var(--border); }
.data-table .strain-link:hover { color: var(--accent); border-bottom-color: var(--accent); text-decoration: none; }
.data-table .mono { font-family: "JetBrains Mono", monospace; font-size: 13px; }

/* failure-type badge */
.ft-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  padding: 3px 8px 3px 6px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--ft-color, var(--accent)) 14%, transparent);
  color: var(--ft-color, var(--accent));
  border: 1px solid color-mix(in srgb, var(--ft-color, var(--accent)) 35%, transparent);
  font-weight: 500;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.ft-badge::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ft-color, var(--accent));
}

/* form layout */
.form-grid { padding: 28px; max-width: 720px; }
.form-grid .field { gap: 6px; }
.field .req { color: var(--accent-warm); }
.field .err { color: var(--danger); font-size: 12px; font-style: normal; }
.field .hint { color: var(--muted); font-size: 12px; font-style: normal; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-actions { display: flex; gap: 10px; padding-top: 8px; }
.btn-danger { background: var(--danger); color: #1a0008; border-color: var(--danger); font-weight: 600; }
.btn-danger:hover { background: var(--danger); filter: brightness(1.15); }

/* card variations */
.card.empty { padding: 40px; text-align: center; }
.card.no-pad { padding: 0; overflow: hidden; }
.card.no-pad .data-table { margin: 0; }
.card-head { padding: 18px 22px; border-bottom: 1px solid var(--border-soft); }

/* detail page */
.detail-grid dl { display: grid; grid-template-columns: 180px 1fr; gap: 12px 24px; }
.detail-grid dt { color: var(--text-soft); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; padding-top: 4px; }
.detail-grid dd { color: var(--text); }
.detail-grid dd.notes { white-space: pre-wrap; }

.kv-list { display: grid; grid-template-columns: 1fr auto; gap: 10px 24px; align-items: baseline; }
.kv-list dt { color: var(--text-soft); font-size: 13px; }
.kv-list dd { font-weight: 600; font-variant-numeric: tabular-nums; }

/* period selector */
.period-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 22px; }
.period-label { color: var(--text-soft); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.period-chip {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-soft);
  font-size: 13px;
  text-decoration: none;
  transition: all 0.12s;
}
.period-chip:hover { color: var(--text); border-color: var(--accent-soft); text-decoration: none; }
.period-chip.active { background: var(--accent); color: #00231b; border-color: var(--accent); font-weight: 600; }

/* chart / donut */
.chart-card { display: flex; flex-direction: column; }
.chart-wrap { display: grid; grid-template-columns: 240px 1fr; gap: 32px; align-items: center; }
.donut { width: 240px; height: 240px; flex-shrink: 0; }
.legend { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.legend li { display: grid; grid-template-columns: 14px 1fr auto auto; gap: 10px; align-items: baseline; font-size: 13px; }
.legend-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; align-self: center; }
.legend-name { color: var(--text); }
.legend-pct { color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; }
.legend-cnt { font-size: 12px; }

@media (max-width: 720px) {
  .chart-wrap { grid-template-columns: 1fr; gap: 20px; justify-items: center; }
  .donut { width: 200px; height: 200px; }
  .field-row { grid-template-columns: 1fr; }
  .detail-grid dl { grid-template-columns: 1fr; }
  .detail-grid dt { padding-top: 12px; }
}
/* phase 2.1 — modal */

/* topbar CTA button */
.nav-cta {
  background: var(--accent);
  color: #00231b;
  border: 1px solid var(--accent);
  border-radius: 6px;
  padding: 6px 14px;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 0.12s, border-color 0.12s;
}
.nav-cta:hover { background: var(--accent-2); border-color: var(--accent-2); }

/* modal */
dialog.modal {
  border: none;
  background: transparent;
  color: var(--text);
  padding: 0;
  max-width: 100%;
  max-height: 100vh;
  margin: auto;
  inset: 0;
  position: fixed;
}
dialog.modal::backdrop {
  background: rgba(5, 8, 12, 0.78);
  backdrop-filter: blur(4px);
  animation: modalFadeIn 0.18s ease;
}
dialog.modal[open] { animation: modalCardIn 0.22s cubic-bezier(.2,.8,.2,1); }
@keyframes modalFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalCardIn {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.modal-card {
  width: min(640px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(15,220,177,0.06);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.modal-head {
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.modal-title { font-size: 18px; }
.modal-close {
  background: transparent;
  border: none;
  color: var(--text-soft);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
  transition: color 0.12s;
}
.modal-close:hover { color: var(--text); }
.modal-body {
  padding: 22px;
  overflow-y: auto;
}
.modal-loading {
  color: var(--muted);
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  text-align: center;
  padding: 24px;
  letter-spacing: 0.08em;
}
.modal-form { gap: 14px; }
.modal-form .form-actions { padding-top: 4px; }

@media (max-width: 720px) {
  .modal-card {
    width: 100vw;
    max-height: 100vh;
    border-radius: 0;
    height: 100vh;
  }
}
/* phase 3 — admin / acp */

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

/* admin landing */
.admin-nav {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  margin-bottom: 32px;
}
.admin-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px;
  text-decoration: none;
  color: var(--text);
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color 0.12s, transform 0.12s;
}
.admin-card:hover { border-color: var(--accent); transform: translateY(-2px); text-decoration: none; }
.admin-card-tag { font-family: "JetBrains Mono", monospace; font-size: 11px; color: var(--accent); letter-spacing: 0.12em; text-transform: uppercase; }
.admin-card-title { font-weight: 700; font-size: 18px; }
.admin-card-num { font-size: 32px; font-weight: 900; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; margin-top: 4px; }
.admin-card-sub { font-size: 12px; color: var(--text-soft); }

/* admin tables */
.admin-table th { white-space: nowrap; }
.admin-table tr.inactive { opacity: 0.55; }
.admin-table .inline-form { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0; }
.admin-table .inline-form.vert { flex-direction: column; align-items: flex-start; gap: 6px; }
.admin-table .inline-form input[type="text"],
.admin-table .inline-form input[type="email"],
.admin-table .inline-form input[type="number"],
.admin-table .inline-form select {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text);
  padding: 5px 8px;
  font: inherit;
  font-size: 13px;
}
.admin-table .inline-form input:focus,
.admin-table .inline-form select:focus { outline: none; border-color: var(--accent); }
.admin-table .rename-input { min-width: 220px; }
.admin-table .ft-sort-input { width: 70px; }
.admin-table .ft-color-row { display: flex; align-items: center; gap: 8px; }
.admin-table .ft-color-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.admin-table .ft-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.admin-table td { vertical-align: middle; padding: 12px; }
.admin-table .checkbox { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-soft); cursor: pointer; }
.admin-table .checkbox input { accent-color: var(--accent); }

/* small button */
.btn-sm { padding: 5px 11px; font-size: 12px; }

/* status dots */
.dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; }
.dot-ok  { background: var(--ok); box-shadow: 0 0 8px rgba(15,220,177,0.5); }
.dot-off { background: var(--dim); }

/* badges */
.badge-me, .badge-warn {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  letter-spacing: 0.12em;
  padding: 2px 6px;
  border-radius: 3px;
  margin-left: 6px;
  text-transform: uppercase;
  font-weight: 600;
  vertical-align: middle;
}
.badge-me   { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent); }
.badge-warn { background: rgba(255,170,58,0.12); color: var(--warn); border: 1px solid var(--warn); }

/* create-block (collapsible) */
.create-block {
  margin-bottom: 18px;
  padding: 0;
  overflow: hidden;
}
.create-block summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 22px;
  background: var(--surface);
  font-size: 14px;
  user-select: none;
  transition: background 0.12s;
}
.create-block summary::-webkit-details-marker { display: none; }
.create-block summary::before { content: "▸ "; color: var(--accent); font-family: "JetBrains Mono", monospace; }
.create-block[open] summary::before { content: "▾ "; }
.create-block summary:hover { background: var(--surface-2); }
.create-block .form { padding: 18px 22px 22px; border-top: 1px solid var(--border-soft); }

/* password display card (one-time reveal) */
.password-display { padding: 22px; margin-bottom: 22px; border: 1px solid var(--accent); background: rgba(15,220,177,0.04); }
.password-display .pw-label { font-size: 13px; color: var(--text-soft); margin-bottom: 10px; }
.password-display .pw-value {
  display: block;
  font-family: "JetBrains Mono", monospace;
  font-size: 22px;
  font-weight: 600;
  color: var(--accent);
  background: var(--bg);
  padding: 14px 18px;
  border-radius: 6px;
  margin-bottom: 10px;
  user-select: all;
  letter-spacing: 0.04em;
  border: 1px solid var(--border);
}
/* phase 4 — permissions matrix + audit log */

/* role pills */
.role-pill {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 4px;
  text-transform: uppercase;
}
.role-pill.role-admin  { background: rgba(15,220,177,0.14);  color: var(--accent);     border: 1px solid var(--accent); }
.role-pill.role-editor { background: rgba(70,240,201,0.10);  color: var(--accent-2);   border: 1px solid var(--accent-2); }
.role-pill.role-user   { background: rgba(255,170,58,0.10);  color: var(--warn);       border: 1px solid var(--warn); }
.role-pill.role-viewer { background: rgba(170,179,193,0.10); color: var(--text-soft);  border: 1px solid var(--dim); }

/* perms matrix */
.perms-matrix th, .perms-matrix td { vertical-align: middle; }
.perms-matrix .perm-col { min-width: 280px; }
.perms-matrix .role-col { width: 140px; text-align: center; }
.perms-matrix .perm-cell { text-align: center; padding: 12px; }
.perms-matrix .perm-cell.admin { background: rgba(15,220,177,0.04); }
.perm-fixed { color: var(--accent); font-weight: 700; font-size: 16px; }
.perms-matrix .cat-row td {
  background: var(--bg-2);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.perms-actions {
  padding: 18px 22px;
  border-top: 1px solid var(--border-soft);
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

/* fancy toggle checkbox */
.perm-toggle { display: inline-block; cursor: pointer; }
.perm-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.perm-toggle span {
  display: inline-block;
  width: 36px; height: 20px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 11px;
  position: relative;
  transition: all 0.15s;
  vertical-align: middle;
}
.perm-toggle span::before {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--dim);
  top: 2px; left: 2px;
  transition: all 0.15s;
}
.perm-toggle input:checked + span {
  background: var(--accent-soft);
  border-color: var(--accent);
}
.perm-toggle input:checked + span::before {
  background: var(--accent);
  left: 18px;
  box-shadow: 0 0 8px var(--accent-glow);
}
.perm-toggle:hover span { border-color: var(--accent-2); }
.perm-toggle input:focus-visible + span { box-shadow: 0 0 0 3px var(--accent-soft); }

/* audit log */
.audit-table td { padding: 10px 12px; vertical-align: top; }
.audit-table .audit-date { display: block; color: var(--text); }
.audit-action {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 3px;
  background: color-mix(in srgb, var(--ac) 14%, transparent);
  color: var(--ac);
  border: 1px solid color-mix(in srgb, var(--ac) 35%, transparent);
  font-weight: 500;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.audit-details { max-width: 360px; }
.audit-kv {
  display: inline-block;
  margin-right: 10px;
  padding: 1px 6px;
  background: var(--bg-2);
  border-radius: 3px;
  font-size: 11px;
}
.audit-kv .muted { font-weight: 600; }

/* pager */
.pager { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; gap: 14px; }
/* row actions in cases list */

.row-actions-col { width: 110px; text-align: right; }
.row-actions {
  display: flex;
  gap: 4px;
  justify-content: flex-end;
  align-items: center;
}
.row-act-form { display: inline; margin: 0; }
.row-act {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: var(--bg-2);
  color: var(--text-soft);
  font-size: 13px;
  text-decoration: none;
  cursor: pointer;
  font-family: inherit;
  padding: 0;
  transition: all 0.12s;
}
.row-act:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
  text-decoration: none;
}
.row-act-danger:hover {
  background: rgba(246,72,111,0.12);
  border-color: var(--danger);
  color: var(--danger);
}
/* row-btn: replaces row-act with proper button styling */

.row-actions-col { width: 1%; white-space: nowrap; text-align: right; }
.row-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: nowrap;
}
.row-btn-form { display: inline; margin: 0; }

.row-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 8px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-soft);
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.12s ease;
  line-height: 1;
  letter-spacing: 0.01em;
}
.row-btn svg {
  width: 13px;
  height: 13px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.row-btn:hover {
  background: var(--surface-2);
  border-color: color-mix(in srgb, var(--text-soft) 40%, transparent);
  color: var(--text);
  text-decoration: none;
}
.row-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--accent-soft);
  border-color: var(--accent);
}

/* edit variant: warm accent on hover */
.row-btn-edit:hover {
  background: rgba(255,170,58,0.10);
  border-color: var(--warn);
  color: var(--warn);
}

/* delete variant: red on hover */
.row-btn-delete:hover {
  background: rgba(246,72,111,0.10);
  border-color: var(--danger);
  color: var(--danger);
}

/* compact on small screens: icon-only */
@media (max-width: 880px) {
  .row-btn span { display: none; }
  .row-btn { padding: 6px; }
}

/* legacy classes kept for any other view that might still use them */
.row-act-form { display: inline; }
