/* ============================================================
   backlinks.rodz.io — design system v3
   Refined SaaS, on-brand. Rodz violet/lime/aubergine + Bai Jamjuree.
   ============================================================ */

@import url('https://api.fontshare.com/v2/css?f[]=clash-display@500,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Bai+Jamjuree:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500;1,600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Geist+Mono:wght@300..700&display=swap');

:root {
  /* Brand */
  --aubergine: #200c35;
  --violet:    #7100e8;
  --violet-2:  #b991f2;
  --violet-3:  #f3eefb;   /* tint for hover surfaces */
  --violet-4:  #faf7ff;   /* even lighter tint */
  --lime:      #c1ef43;
  --lime-pale: #e6f2b8;

  /* Surface */
  --paper:     #ffffff;
  --paper-2:   #fafafd;   /* page bg */
  --paper-3:   #f4f3f8;   /* inset blocks */

  /* Ink scale */
  --ink:    var(--aubergine);
  --ink-2:  #2a1f44;
  --ink-3:  #5a4d77;
  --ink-4:  #8c84a6;
  --ink-5:  #c0bccd;       /* divider tint */

  /* Functional */
  --border:        1px solid #e6e1ee;
  --border-strong: 1px solid #d3cce0;

  /* Alerts */
  --alert: #c8276b;
  --warn:  #c97000;
  --ok:    var(--violet);

  /* Type */
  --font-display: 'Clash Display', 'Inter', -apple-system, system-ui, sans-serif;
  --font-body:    'Bai Jamjuree', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:    'Geist Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Geometry */
  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 14px;
  --shadow-sm: 0 1px 2px rgba(32,12,53,0.04), 0 1px 1px rgba(32,12,53,0.06);
  --shadow:    0 4px 12px -4px rgba(32,12,53,0.10), 0 2px 4px -2px rgba(32,12,53,0.06);
  --shadow-lg: 0 12px 32px -8px rgba(113,0,232,0.18), 0 4px 8px -4px rgba(32,12,53,0.08);
  --ring: 0 0 0 3px rgba(113,0,232,0.18);

  --topbar-h: 56px;
}

[data-theme="dark"] {
  /* Dark mode: aubergine-deep ground with brightened violet accent.
     Violet is lifted from #7100e8 to #9b4dff so it doesn't crush against dark
     surfaces. Lime stays — it's already saturated enough. */
  --aubergine: #2a1450;
  --violet:    #9b4dff;
  --violet-2:  #7c3df0;
  --violet-3:  #2a1d4d;
  --violet-4:  #1d1338;

  --paper:     #14072a;   /* darkest surface */
  --paper-2:   #0c0420;   /* page bg */
  --paper-3:   #1d1038;   /* inset blocks */

  --ink:    #f0eaff;
  --ink-2:  #d6cdec;
  --ink-3:  #9b91b4;
  --ink-4:  #6f6688;
  --ink-5:  #3f365e;

  --border:        1px solid #2a1d4d;
  --border-strong: 1px solid #3a2a64;

  --alert: #ff3d80;
  --warn:  #ffa64d;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4), 0 1px 1px rgba(0,0,0,0.3);
  --shadow:    0 4px 16px -4px rgba(0,0,0,0.5), 0 2px 4px -2px rgba(0,0,0,0.4);
  --shadow-lg: 0 16px 40px -8px rgba(155,77,255,0.30), 0 6px 12px -4px rgba(0,0,0,0.4);
  --ring: 0 0 0 3px rgba(155,77,255,0.32);
}

[data-theme="dark"] body {
  background:
    radial-gradient(circle at 12% 100%, rgba(155,77,255,0.10) 0%, transparent 50%),
    radial-gradient(circle at 88% 0%, rgba(193,239,67,0.06) 0%, transparent 45%),
    var(--paper-2);
}

[data-theme="dark"] .topbar { background: var(--paper); border-bottom-color: var(--border); }
[data-theme="dark"] .topbar nav a:hover { background: var(--paper-3); }
[data-theme="dark"] .topbar nav a.active { background: var(--violet-3); color: var(--violet); }
[data-theme="dark"] .topbar .avatar { background: var(--violet); color: var(--paper-2); }

[data-theme="dark"] .pill.live { background: rgba(193,239,67,0.18); color: #d3ff5e; }
[data-theme="dark"] .pill.live::before { background: var(--lime); }
[data-theme="dark"] .pill.alert { background: rgba(255,61,128,0.16); color: #ff8db1; }
[data-theme="dark"] .pill.warn { background: rgba(255,166,77,0.16); color: #ffc78a; }
[data-theme="dark"] .pill.muted { background: var(--paper-3); color: var(--ink-3); }

[data-theme="dark"] .login-shell {
  background:
    radial-gradient(circle at 12% 100%, rgba(155,77,255,0.18) 0%, transparent 50%),
    radial-gradient(circle at 88% 0%, rgba(193,239,67,0.08) 0%, transparent 45%),
    var(--paper-2);
}
[data-theme="dark"] .login-card .err { background: rgba(255,61,128,0.10); }
[data-theme="dark"] .warn-line { background: rgba(255,61,128,0.10); }

[data-theme="dark"] form.app input,
[data-theme="dark"] form.app textarea,
[data-theme="dark"] form.app select {
  background: var(--paper-3);
  color: var(--ink);
}
[data-theme="dark"] form.app select {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--ink-3) 50%),
    linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position: calc(100% - 14px) center, calc(100% - 8px) center;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

[data-theme="dark"] table.app thead { background: var(--paper-3); }
[data-theme="dark"] table.app tbody tr:hover { background: var(--violet-4); }

[data-theme="dark"] .proof-pre { background: var(--paper-3); color: var(--ink); }

[data-theme="dark"] .pipeline-step.done,
[data-theme="dark"] .pipeline-step.active { background: var(--paper-3); }

[data-theme="dark"] .commentbox { background: var(--paper-3); border-left-color: var(--violet); }

[data-theme="dark"] .anchor-bar .bar { background: var(--paper-3); }

/* Theme toggle button (auto-injected by /theme.js) */
.theme-toggle {
  background: transparent;
  border: var(--border-strong);
  color: var(--ink-3);
  width: 32px; height: 32px;
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  cursor: pointer;
  font-size: 0.95rem;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
  font-family: var(--font-body);
}
.theme-toggle:hover { background: var(--violet-3); color: var(--violet); border-color: var(--violet); }
.theme-toggle:focus-visible { outline: 0; box-shadow: var(--ring); }

* { box-sizing: border-box; }

html, body {
  background: var(--paper-2);
  color: var(--ink);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
  font-variant-numeric: tabular-nums lining-nums;
}

a { color: var(--violet); text-decoration: none; }
a:hover { color: var(--aubergine); }

/* ----- Top app bar ---------------------------------------- */
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--paper);
  border-bottom: var(--border);
  height: var(--topbar-h);
  padding: 0 1.5rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.5rem;
}
.topbar .brand {
  display: flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.topbar .brand-mark {
  width: 22px; height: 22px;
  background: var(--violet);
  border-radius: 5px;
  position: relative;
  flex: 0 0 auto;
}
.topbar .brand-mark::after {
  content: '';
  position: absolute;
  inset: 5px;
  background: var(--lime);
  border-radius: 2px;
}
.topbar .brand .sub {
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--ink-3);
  font-size: 0.85rem;
  letter-spacing: 0;
}
.topbar nav {
  display: flex;
  gap: 0.25rem;
}
.topbar nav a {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--ink-3);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-sm);
  transition: background 0.12s, color 0.12s;
}
.topbar nav a:hover { background: var(--violet-4); color: var(--ink); }
.topbar nav a.active {
  background: var(--violet-3);
  color: var(--violet);
  font-weight: 600;
}
.topbar .userpill {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.topbar .userpill a { color: var(--ink-3); }
.topbar .userpill a:hover { color: var(--violet); }
.topbar .avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--violet);
  color: var(--paper);
  font-weight: 600;
  font-size: 0.78rem;
  display: grid; place-items: center;
}

/* ----- Page shell ----------------------------------------- */
.page { max-width: 1200px; margin: 0 auto; padding: 2rem 1.5rem 4rem; }
.page-narrow { max-width: 760px; }

.page-head { margin-bottom: 1.5rem; }
.page-head h1 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.6rem;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 0 0 0.25rem;
}
.page-head .subtitle {
  font-family: var(--font-body);
  color: var(--ink-3);
  font-size: 0.92rem;
  margin: 0;
  max-width: 70ch;
}
.page-head .row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
}

/* ----- Cards ---------------------------------------------- */
.card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  padding: 1.25rem 1.5rem;
}
.card + .card { margin-top: 1rem; }
.card-pad-sm { padding: 1rem 1.25rem; }
.card-pad-lg { padding: 1.75rem 2rem; }
.card.elevated { box-shadow: var(--shadow-sm); border-color: transparent; }
.card .card-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0 0 0.25rem;
}
.card .card-subtitle {
  color: var(--ink-3);
  font-size: 0.85rem;
  margin: 0 0 1rem;
}

.section-divider { border: 0; border-top: var(--border); margin: 1.5rem 0; }

/* ----- Buttons -------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.875rem;
  letter-spacing: 0;
  padding: 0.55rem 1rem;
  border: 1px solid var(--violet);
  background: var(--violet);
  color: var(--paper);
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: transform 0.08s ease, box-shadow 0.12s ease, background 0.12s ease;
}
.btn:hover { background: var(--aubergine); border-color: var(--aubergine); box-shadow: var(--shadow-sm); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.45; cursor: progress; transform: none; box-shadow: none; }
.btn:focus-visible { outline: 0; box-shadow: var(--ring); }

.btn.lime {
  background: var(--lime);
  color: var(--ink);
  border-color: var(--ink);
  font-weight: 600;
}
.btn.lime:hover { background: var(--ink); color: var(--lime); border-color: var(--ink); }

.btn.ghost {
  background: transparent;
  color: var(--violet);
  border-color: var(--violet);
}
.btn.ghost:hover { background: var(--violet-3); color: var(--violet); border-color: var(--violet); }

.btn.subtle {
  background: var(--violet-3);
  color: var(--violet);
  border-color: transparent;
}
.btn.subtle:hover { background: var(--violet-2); color: var(--paper); border-color: transparent; }

.btn.sm { padding: 0.35rem 0.75rem; font-size: 0.8rem; }

/* ----- Forms ---------------------------------------------- */
form.app { display: grid; gap: 1.25rem; }
form.app .field { display: grid; gap: 0.4rem; }
form.app .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 640px) { form.app .field-row { grid-template-columns: 1fr; } }
form.app label {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.82rem;
  color: var(--ink-2);
}
form.app label .req { color: var(--violet); margin-left: 0.2em; font-weight: 600; }
form.app input,
form.app textarea,
form.app select {
  font-family: var(--font-body);
  font-size: 0.92rem;
  padding: 0.55rem 0.75rem;
  background: var(--paper);
  color: var(--ink);
  border: var(--border-strong);
  border-radius: var(--radius-sm);
  width: 100%;
  appearance: none;
}
form.app textarea { min-height: 90px; resize: vertical; line-height: 1.5; }
form.app input:focus,
form.app textarea:focus,
form.app select:focus {
  outline: 0;
  border-color: var(--violet);
  box-shadow: var(--ring);
}
form.app select {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--ink-3) 50%),
    linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position: calc(100% - 14px) center, calc(100% - 8px) center;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 28px;
}
form.app .help {
  font-size: 0.78rem;
  color: var(--ink-4);
  margin-top: 0.15rem;
}

/* ----- Status pills --------------------------------------- */
.pill {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.18em 0.6em;
  border-radius: 999px;
  background: var(--violet-3);
  color: var(--violet);
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
}
.pill::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--violet);
}
.pill.live { background: #eaffb4; color: #355d00; }
.pill.live::before { background: #87b800; }
.pill.alert { background: #fde4ed; color: var(--alert); }
.pill.alert::before { background: var(--alert); }
.pill.warn { background: #fde9d2; color: var(--warn); }
.pill.warn::before { background: var(--warn); }
.pill.muted { background: #efeef4; color: var(--ink-3); }
.pill.muted::before { background: var(--ink-4); }

/* ----- Tables --------------------------------------------- */
.table-wrap {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
table.app {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}
table.app thead {
  background: var(--paper-3);
  border-bottom: var(--border);
}
table.app th {
  text-align: left;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--ink-3);
  padding: 0.65rem 1rem;
  letter-spacing: 0.01em;
}
table.app td {
  padding: 0.7rem 1rem;
  border-bottom: var(--border);
  vertical-align: middle;
}
table.app tbody tr:last-child td { border-bottom: 0; }
table.app tbody tr { cursor: pointer; transition: background 0.1s; }
table.app tbody tr:hover { background: var(--violet-4); }
table.app td.col-keyword { font-weight: 500; color: var(--ink); }
table.app td.col-mono { font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink-3); }
table.app td.col-num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink-2); }
table.app td a { color: inherit; }
table.app td .pill { vertical-align: middle; }
.empty-row {
  padding: 3.5rem 1rem;
  text-align: center;
  color: var(--ink-4);
}

/* ----- Toolbar / filter bar ------------------------------- */
.toolbar {
  display: flex; gap: 0.75rem; align-items: center;
  margin-bottom: 1rem; flex-wrap: wrap;
}
.toolbar input[type=search] {
  flex: 1; min-width: 220px;
  padding: 0.5rem 0.75rem;
  background: var(--paper);
  color: var(--ink);
  border: var(--border-strong);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.9rem;
}
.toolbar input[type=search]:focus { outline: 0; border-color: var(--violet); box-shadow: var(--ring); }
.toolbar .info { color: var(--ink-4); font-size: 0.82rem; }

/* ----- Stat blocks (reports) ------------------------------ */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.stat {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
}
.stat .label {
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--ink-3);
  margin-bottom: 0.35rem;
}
.stat .value {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.9rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.05;
}

/* ----- Pipeline (horizontal stepper at top of article) ---- */
.pipeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin: 1rem 0 1.5rem;
}
.pipeline-step {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius-sm);
  padding: 0.7rem 0.9rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.55rem;
  align-items: center;
}
.pipeline-step .num {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  background: var(--violet-3);
  color: var(--violet);
  font-weight: 600;
}
.pipeline-step .text { display: grid; gap: 0.05rem; }
.pipeline-step .name {
  font-weight: 500; font-size: 0.85rem; color: var(--ink-2);
}
.pipeline-step .meta {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  color: var(--ink-4);
  text-transform: uppercase;
}
.pipeline-step.done { background: var(--violet-4); border-color: var(--violet-2); }
.pipeline-step.done .num { background: var(--violet); color: var(--paper); }
.pipeline-step.done .num::after { content: ''; }
.pipeline-step.done .name { color: var(--ink); }
.pipeline-step.active { border-color: var(--violet); background: var(--violet-4); }
.pipeline-step.active .num { background: var(--violet); color: var(--paper); }
.pipeline-step.active .name { color: var(--violet); font-weight: 600; }
.pipeline-step.active .meta { color: var(--violet); }
@media (max-width: 760px) { .pipeline { grid-template-columns: 1fr 1fr; } }

/* ----- Article body --------------------------------------- */
.proof {
  font-family: var(--font-body);
  font-size: 0.96rem;
  line-height: 1.65;
  color: var(--ink);
}
.proof h1 { font-family: var(--font-display); font-weight: 600; font-size: 1.7rem; letter-spacing: -0.018em; margin: 0 0 0.75rem; color: var(--ink); }
.proof h2 { font-family: var(--font-display); font-weight: 600; font-size: 1.25rem; letter-spacing: -0.012em; margin: 1.5rem 0 0.5rem; color: var(--ink); }
.proof h3 { font-family: var(--font-display); font-weight: 500; font-size: 1.05rem; margin: 1.1rem 0 0.4rem; color: var(--ink); }
.proof p { margin: 0 0 0.85rem; }
.proof a { color: var(--violet); border-bottom: 1px solid var(--violet-2); }
.proof a:hover { color: var(--aubergine); border-bottom-color: var(--aubergine); }
.proof code { font-family: var(--font-mono); font-size: 0.86em; background: var(--paper-3); padding: 0.1em 0.3em; border-radius: 3px; }
.proof ul, .proof ol { padding-left: 1.4rem; margin: 0 0 0.85rem; }
.proof li { margin: 0.2rem 0; }
.proof blockquote { margin: 0.85rem 0; padding: 0.6rem 1rem; border-left: 3px solid var(--violet); background: var(--violet-4); color: var(--ink-2); }

/* ----- Article: tabbed step output ------------------------ */
.tabs {
  display: flex; gap: 0.25rem;
  border-bottom: var(--border);
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.tab {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.85rem;
  background: transparent;
  border: 0;
  padding: 0.55rem 0.9rem;
  color: var(--ink-3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}
.tab:hover { background: var(--violet-4); color: var(--ink); }
.tab.active { color: var(--violet); border-bottom-color: var(--violet); }
.tab:disabled { opacity: 0.35; cursor: not-allowed; }

.proof-pre {
  white-space: pre-wrap;
  word-break: break-word;
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.55;
  margin: 0;
  max-height: 65vh;
  overflow-y: auto;
  padding: 1rem 1.25rem;
  background: var(--paper-3);
  border-radius: var(--radius-sm);
  color: var(--ink);
}

/* ----- Article: sidebar metadata -------------------------- */
.layout-article {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 1.5rem;
  align-items: start;
}
@media (max-width: 960px) { .layout-article { grid-template-columns: 1fr; } }
.meta-card {
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
}
.meta-card .row {
  display: grid; grid-template-columns: auto 1fr; gap: 0.5rem 0.75rem;
  font-size: 0.85rem;
  margin-bottom: 0.4rem;
}
.meta-card .row .k { color: var(--ink-4); font-size: 0.78rem; }
.meta-card .row .v { color: var(--ink); word-break: break-word; }
.meta-card .row .v a { color: var(--violet); }

/* ----- Paragraph review ----------------------------------- */
.paragraphs { display: grid; gap: 0.4rem; }
.paragraph-row {
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.55;
  padding: 0.65rem 0.85rem;
  border: var(--border);
  border-radius: var(--radius-sm);
  background: var(--paper);
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s;
}
.paragraph-row:hover { background: var(--violet-4); border-color: var(--violet-2); }
.paragraph-row.active {
  background: var(--violet-4);
  border-color: var(--violet);
  box-shadow: 0 0 0 1px var(--violet) inset;
}

.commentbox {
  margin-top: 0.85rem;
  padding: 1rem 1.25rem;
  background: var(--violet-4);
  border: var(--border);
  border-left: 3px solid var(--violet);
  border-radius: var(--radius-sm);
}
.comment {
  padding: 0.5rem 0;
  border-bottom: var(--border);
  font-size: 0.9rem;
}
.comment:last-of-type { border-bottom: 0; }
.comment .who {
  font-family: var(--font-body);
  font-size: 0.72rem;
  color: var(--ink-3);
  margin-bottom: 0.15rem;
  font-weight: 500;
}

/* ----- Toasts --------------------------------------------- */
.toast {
  font-size: 0.82rem;
  margin-top: 0.5rem;
  color: var(--ink-3);
}
.toast.ok { color: var(--violet); font-weight: 500; }
.toast.err { color: var(--alert); font-weight: 500; }

/* ----- Anchor distribution bars (reports) ----------------- */
.anchor-bars { display: grid; gap: 0.55rem; margin-top: 0.5rem; }
.anchor-bar {
  display: grid; grid-template-columns: 110px 1fr 80px;
  gap: 0.75rem; align-items: center;
  font-size: 0.85rem;
}
.anchor-bar .label { color: var(--ink-3); }
.anchor-bar .bar { height: 10px; background: var(--paper-3); border-radius: 999px; overflow: hidden; }
.anchor-bar .bar > div { height: 100%; background: var(--violet); border-radius: 999px; }
.anchor-bar.exact .bar > div { background: var(--alert); }
.anchor-bar .count { text-align: right; color: var(--ink); font-variant-numeric: tabular-nums; }
.warn-line {
  margin-top: 0.75rem;
  font-size: 0.82rem;
  color: var(--alert);
  background: #fde4ed;
  padding: 0.55rem 0.8rem;
  border-radius: var(--radius-sm);
}

/* ----- Login ---------------------------------------------- */
.login-shell {
  min-height: 100vh;
  display: grid; place-items: center;
  background:
    radial-gradient(circle at 12% 90%, rgba(113,0,232,0.08) 0%, transparent 45%),
    radial-gradient(circle at 88% 5%, rgba(193,239,67,0.10) 0%, transparent 40%),
    var(--paper-2);
  padding: 1.5rem;
}
.login-card {
  width: 100%; max-width: 400px;
  background: var(--paper);
  border: var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 2rem 1.75rem;
  box-shadow: var(--shadow-lg);
}
.login-card .brand {
  display: flex; align-items: center; gap: 0.55rem;
  margin-bottom: 1.5rem;
}
.login-card .brand .brand-mark {
  width: 26px; height: 26px;
  background: var(--violet); border-radius: 6px; position: relative;
}
.login-card .brand .brand-mark::after {
  content: ''; position: absolute; inset: 6px;
  background: var(--lime); border-radius: 2px;
}
.login-card .brand .name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--ink);
  letter-spacing: -0.015em;
}
.login-card h1 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.4rem;
  margin: 0 0 0.25rem;
  letter-spacing: -0.018em;
  color: var(--ink);
}
.login-card .lede {
  color: var(--ink-3);
  font-size: 0.88rem;
  margin: 0 0 1.5rem;
}
.login-card .err {
  font-size: 0.82rem;
  color: var(--alert);
  background: #fde4ed;
  padding: 0.55rem 0.8rem;
  border-radius: var(--radius-sm);
  margin-bottom: 1rem;
}

/* ----- Misc ----------------------------------------------- */
.muted { color: var(--ink-4); }
.mono { font-family: var(--font-mono); }
.tabnums { font-variant-numeric: tabular-nums; }
::selection { background: var(--lime); color: var(--ink); }
.hidden { display: none !important; }
.flex-row { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }
