:root {
  --bg: #f7f7f9;
  --panel: #ffffff;
  --border: #e1e4e8;
  --text: #24292f;
  --muted: #6a737d;
  --accent: #0969da;
  --accent-hover: #0760c0;
  --ok: #1a7f37;
  --warn: #9a6700;
  --err: #cf222e;

  --disclosed-bg: #c6efce;
  --disclosed-fg: #276221;
  --partial-bg: #ffeb9c;
  --partial-fg: #9c6500;
  --notdisc-bg: #ffc7ce;
  --notdisc-fg: #9c0006;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.45;
}

.topbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 10px 16px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 10;
}
.brand { font-weight: 600; font-size: 16px; }
.patent-switcher { display: flex; gap: 8px; align-items: center; margin-left: auto; }
.patent-switcher input {
  min-width: 260px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font: inherit;
}
.patent-switcher select {
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--panel);
  /* Lange Patenttitel dürfen das Dropdown nicht über den rechten Rand dehnen. */
  max-width: 220px;
  text-overflow: ellipsis;
}

button, .file-label {
  padding: 6px 12px;
  border: 1px solid var(--accent);
  background: var(--accent);
  color: white;
  border-radius: 6px;
  font: inherit;
  cursor: pointer;
}
button:hover, .file-label:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
button.secondary, button.ghost {
  background: var(--panel);
  color: var(--text);
  border-color: var(--border);
}
button.secondary:hover, button.ghost:hover { background: #f3f4f6; }
button.danger {
  background: var(--panel);
  color: var(--err);
  border-color: var(--err);
}
button.danger:hover { background: var(--err); color: white; }
button.armed {
  background: var(--err) !important;
  color: white !important;
  border-color: var(--err) !important;
  animation: armedPulse 0.6s ease-in-out infinite alternate;
}
@keyframes armedPulse { from { opacity: 1; } to { opacity: 0.75; } }
button:disabled { opacity: 0.5; cursor: not-allowed; }
.file-label { display: inline-flex; align-items: center; gap: 6px; }
.file-label input[type=file] { display: none; }

main {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 16px;
}

.hidden { display: none !important; }

.empty-state {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 24px;
  color: var(--muted);
}
.empty-state h2 { margin-top: 0; color: var(--text); }

.tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.tab-btn {
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  padding: 8px 16px;
}
.tab-btn:hover { background: #eef0f3; color: var(--text); }
.tab-btn.active {
  background: var(--panel);
  color: var(--text);
  border-color: var(--border);
  border-bottom: 1px solid var(--panel);
  margin-bottom: -1px;
  font-weight: 600;
}
/* Tabs, die nicht zur aktiven Gruppe gehören, werden ausgeblendet. */
.tab-btn.off-group { display: none !important; }

/* --- Gruppen-Leiste (segmentierte Auswahl, oben zentriert) --- */
.tab-groups {
  display: flex;
  justify-content: center;
  margin: 6px 0 14px;
}
.tab-group-seg {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.04);
}
.tab-group-btn {
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  border-radius: 7px;
  padding: 7px 18px;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
}
.tab-group-btn:hover { color: var(--text); background: var(--panel); }
.tab-group-btn.active {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--panel);
}

.tab-panel { display: none; background: var(--panel); border: 1px solid var(--border); border-radius: 0 6px 6px 6px; padding: 20px; }
.tab-panel.active { display: block; }

.overview-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.overview-toolbar h2 { margin: 0; flex: 1; }
.overview-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 8px 24px;
  margin: 12px 0 20px;
}
.meta-grid > div { display: flex; flex-direction: column; padding: 6px 0; border-bottom: 1px solid var(--border); }
.meta-grid .k { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.abstract { white-space: pre-wrap; background: #fafbfc; padding: 12px; border-radius: 6px; border: 1px solid var(--border); }

/* Inline-edit inputs on the overview tab */
#tab-overview .edit-input {
  margin-top: 2px;
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  width: 100%;
}
#tab-overview textarea.edit-input { min-height: 120px; resize: vertical; }
#tab-overview textarea.edit-list-input { min-height: 60px; }
#tab-overview .edit-title-input {
  font-size: 1.5em;
  font-weight: 600;
  margin: 0 0 8px 0;
}
/* List-valued meta fields: render entries on separate lines. */
#tab-overview .meta-grid [data-kind="list"] { white-space: pre-line; }

.links { display: flex; gap: 16px; margin-top: 16px; }
.links a { color: var(--accent); text-decoration: none; }
.links a:hover { text-decoration: underline; }

/* Clickable patent-number chips (parent/divisional overview fields) */
.patent-link {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px dotted var(--accent);
}
.patent-link:hover { text-decoration: none; border-bottom-style: solid; }

.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.status { color: var(--muted); font-style: italic; }
.export-marks-label { display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; color: var(--muted); cursor: pointer; }
.toolbar-sep { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 1px; }
#pa-number-input { min-width: 280px; }
.runs-label { margin-left: auto; color: var(--muted); font-size: 12px; display: flex; align-items: center; gap: 6px; }
.runs-label select { padding: 4px 6px; border-radius: 4px; border: 1px solid var(--border); }

.interp-meta { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
.interp-meta label { display: flex; flex-direction: column; flex: 1; min-width: 280px; font-size: 12px; color: var(--muted); }
.interp-meta input { margin-top: 4px; padding: 6px 8px; border: 1px solid var(--border); border-radius: 4px; font: inherit; }

.claim-block { border: 1px solid var(--border); border-radius: 6px; margin-bottom: 16px; }
.claim-header { padding: 8px 12px; background: #f3f4f6; border-bottom: 1px solid var(--border); font-weight: 600; display: flex; justify-content: space-between; }
.claim-header small { font-weight: normal; color: var(--muted); }

.feature-table { width: 100%; border-collapse: collapse; }
.feature-table th, .feature-table td {
  border: 1px solid var(--border);
  padding: 8px;
  vertical-align: top;
  text-align: left;
  font-size: 13px;
}
.feature-table th { background: #f6f8fa; font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); }
.feature-table textarea {
  width: 100%;
  min-height: 56px;
  box-sizing: border-box;
  padding: 6px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  resize: vertical;
  /* Voller Text sichtbar: Feld wächst mit Inhalt (Chromium); JS-Fallback sonst. */
  field-sizing: content;
  overflow: hidden;
}
.feature-table td.id-cell { width: 48px; text-align: center; font-weight: 600; }

.pa-card {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px;
  margin-bottom: 12px;
  background: #fafbfc;
}
.pa-card header { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.pa-card h4 { margin: 0; }
.pa-card .small { color: var(--muted); font-size: 12px; }

.chart-wrapper { margin-top: 16px; overflow-x: auto; }
.claim-chart { border-collapse: collapse; width: 100%; background: var(--panel); }
.claim-chart th, .claim-chart td {
  border: 1px solid var(--border);
  padding: 8px;
  font-size: 12.5px;
  vertical-align: top;
}
.claim-chart th { background: #f6f8fa; text-align: left; }
.claim-chart td.disclosed    { background: var(--disclosed-bg); color: var(--disclosed-fg); }
.claim-chart td.partial      { background: var(--partial-bg);   color: var(--partial-fg); }
.claim-chart td.not_disclosed{ background: var(--notdisc-bg);   color: var(--notdisc-fg); }
.claim-chart td .status-label { font-weight: 600; }
.claim-chart td .ref { display: block; margin-top: 4px; font-size: 11px; opacity: 0.8; }

.legal-block {
  margin-top: 16px;
  padding: 12px;
  background: #fafbfc;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
}
.legal-block h5 { margin: 0 0 6px 0; }
.legal-block dt { font-weight: 600; color: var(--muted); margin-top: 4px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.legal-block dd { margin: 0 0 4px 0; }

/* Prosecution (Erteilungsverfahren) tab */
.dropzone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 28px 20px;
  margin-bottom: 14px;
  border: 2px dashed var(--border);
  border-radius: 10px;
  background: var(--bg-alt, rgba(255,255,255,0.02));
  color: var(--muted);
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
}
.dropzone:hover,
.dropzone:focus-visible { border-color: var(--accent); color: var(--fg); outline: none; }
.dropzone.is-dragover {
  border-color: var(--accent);
  background: rgba(80,140,255,0.08);
  color: var(--fg);
}
.dropzone.is-busy { opacity: 0.6; pointer-events: none; }
.dropzone .dz-icon {
  font-size: 28px;
  line-height: 1;
  margin-bottom: 4px;
  opacity: 0.7;
}
.dropzone .dz-title { font-weight: 600; color: var(--fg); }
.dropzone .dz-sub { font-size: 12px; }
.dropzone .dz-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.pa-inputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 14px;
  align-items: stretch;
}
.pa-inputs > .dropzone { margin-bottom: 0; }
.pa-numbers {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-alt, rgba(255,255,255,0.02));
}
.pa-numbers-label { font-size: 13px; font-weight: 600; color: var(--fg); }
.pa-numbers textarea {
  flex: 1;
  min-height: 90px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--fg);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  resize: vertical;
}
.pa-numbers textarea:focus-visible { outline: 2px solid var(--accent); outline-offset: -1px; }
.pa-numbers-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.pros-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 16px;
}
.pros-layout h3 { margin-top: 0; font-size: 14px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.pros-files, .pros-runs {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 280px;
  overflow-y: auto;
  padding: 4px;
}
.pros-file, .pros-run {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fafbfc;
  gap: 8px;
}
.pros-file-info, .pros-run-info { flex: 1; min-width: 0; }
.pros-file-name {
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pros-run-actions { display: flex; gap: 8px; align-items: center; }
.pros-run-actions a {
  color: var(--accent);
  text-decoration: none;
  font-size: 12px;
}
.pros-run-actions a:hover { text-decoration: underline; }
.small.muted { color: var(--muted); }
.pros-block {
  margin-top: 20px;
  padding: 12px 16px;
  background: #fafbfc;
  border: 1px solid var(--border);
  border-radius: 6px;
}
.pros-block h3 { margin: 0 0 8px 0; color: var(--text); font-size: 15px; text-transform: none; letter-spacing: 0; }
.pros-block h4 { margin: 12px 0 6px 0; font-size: 14px; }
.pros-block h5 { margin: 8px 0 4px 0; font-size: 12px; text-transform: uppercase; color: var(--muted); letter-spacing: 0.04em; }
.pros-dl { display: grid; grid-template-columns: max-content 1fr; gap: 4px 12px; margin: 0; }
.pros-dl dt { font-weight: 600; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; align-self: start; padding-top: 2px; }
.pros-dl dd { margin: 0; }
.pros-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.pros-table th, .pros-table td {
  border: 1px solid var(--border);
  padding: 6px 8px;
  vertical-align: top;
  text-align: left;
}
.pros-table th { background: #f6f8fa; font-weight: 600; font-size: 11px; text-transform: uppercase; color: var(--muted); }
.pros-claim-cell { max-width: 320px; white-space: pre-wrap; }
.pros-bewertung { min-width: 200px; }
/* Added-Matter-Risiko der Änderung (linker Farbbalken). */
.pros-bewertung.pros-risk-gering { border-left: 3px solid var(--ok); }
.pros-bewertung.pros-risk-mittel { border-left: 3px solid var(--warn); }
.pros-bewertung.pros-risk-hoch   { border-left: 3px solid var(--err); background: rgba(207,34,46,0.05); }
.pros-round {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.pros-round-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pros-round-cols p { margin: 4px 0; }
.pros-round-cols ul { margin: 4px 0; padding-left: 20px; }
@media (max-width: 900px) {
  .pros-layout, .pros-round-cols, .pa-inputs { grid-template-columns: 1fr; }
}

.toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  padding: 12px 16px;
  background: var(--text);
  color: white;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  max-width: 360px;
  font-size: 13px;
  z-index: 20;
}
.toast.err { background: var(--err); }
.toast.ok { background: var(--ok); }

/* --- claim picker (interpretation tab) --- */
.claim-picker {
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 12px;
}
.claim-picker-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.claim-picker-actions a {
  color: var(--accent);
  text-decoration: none;
  font-size: 12px;
  cursor: pointer;
}
.claim-picker-actions a:hover { text-decoration: underline; }
.claim-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 360px;
  overflow-y: auto;
  padding-right: 4px;
}
.claim-list label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  background: #fafbfc;
}
.claim-list label:hover { background: #eef1f4; }
.claim-list input[type="checkbox"] { margin-top: 3px; flex-shrink: 0; }
.claim-list .claim-num { font-weight: 600; min-width: 28px; flex-shrink: 0; }
.claim-list .claim-text {
  color: var(--text);
  font-size: 12px;
  line-height: 1.5;
  flex: 1;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 7.5em;
  overflow-y: auto;
}
.claim-picker-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 6px;
}
.claim-picker-extra {
  margin-top: 6px;
}
.claim-picker-extra input {
  width: 100%;
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 13px;
}

/* --- Ansprüche tab (Merkmalsgliederung) ----------------------------- */
.claims-hint {
  background: #fff7d6;
  border: 1px solid #ecd97a;
  padding: 8px 12px;
  border-radius: 6px;
  margin-bottom: 12px;
  font-size: 13px;
}
.claim-feature-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px 14px;
  margin-bottom: 14px;
}
.claim-feature-header {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 8px;
}
.claim-feature-header .small {
  color: var(--muted);
  font-size: 12px;
}
.feature-id-input {
  width: 100%;
  padding: 3px 6px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-size: 12px;
}
.claim-number-input {
  width: 64px;
  padding: 3px 6px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  font-weight: 600;
}
.feature-verbatim {
  white-space: pre-wrap;
  font-size: 13px;
}
.feature-verbatim-edit {
  width: 100%;
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  resize: vertical;
}
.feature-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: stretch;
}
.small-btn {
  padding: 3px 8px;
  font-size: 12px;
}

/* picker tags + slot-filling for type indicator */
.claim-pick-item {
  display: grid;
  grid-template-columns: auto auto auto 1fr;
  gap: 6px 10px;
  align-items: baseline;
  padding: 4px 6px;
  border-radius: 4px;
}
.claim-pick-item:hover { background: rgba(9, 105, 218, 0.06); }
.claim-pick-tag {
  display: inline-block;
  padding: 1px 6px;
  font-size: 11px;
  border-radius: 3px;
  background: #eef2f7;
  color: var(--muted);
  white-space: nowrap;
}
.claim-pick-tag.dep { background: #fff0d0; color: #8a5b00; }
.claim-pick-tag.ind { background: #d8eedd; color: var(--ok); }

/* --- Claim-Highlight-Feature ----------------------------------------- */
.hl-palette {
  position: absolute;
  display: none;
  background: #ffffff;
  border: 1px solid #999;
  border-radius: 6px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  padding: 6px;
  z-index: 9999;
  gap: 4px;
}
.hl-palette.show { display: flex; }
.hl-swatch {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #666;
  cursor: pointer;
  box-sizing: border-box;
  transition: transform 0.08s ease;
}
.hl-swatch:hover { transform: scale(1.18); }
.hl-clear {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #666;
  cursor: pointer;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: #c00;
  font-weight: bold;
  line-height: 1;
  box-sizing: border-box;
}
.hl-clear:hover { background: #ffe5e5; }
span.hl {
  border-radius: 2px;
  padding: 0 1px;
}
td.verbatim-cell { cursor: text; }

/* --- Setup-Tab + Workflow-Banner -------------------------------------- */

.setup-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 10px 0 14px;
  padding: 10px 14px;
  border-radius: 6px;
  background: #eef4ff;
  border: 1px solid #c7d8ff;
  color: var(--fg);
  font-size: 14px;
}
/* Patentnummer-Chip im Banner — in jedem Tab sichtbar. */
.banner-patent-no {
  font-family: ui-monospace, Menlo, monospace;
  font-weight: 700;
  font-size: 13px;
  color: var(--text);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 2px 8px;
  white-space: nowrap;
}
.banner-patent-no:empty { display: none; }
/* Externe Nachschlage-Links (EP-Register, Espacenet) — rechtsbündig im Banner. */
.banner-ext-links {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 12px;
}
.banner-ext-links:empty { display: none; }
.banner-ext-link {
  color: var(--accent, #0a66ff);
  text-decoration: none;
  font-size: 13px;
  white-space: nowrap;
}
.banner-ext-link:hover { text-decoration: underline; }
.setup-banner.warn {
  background: #fff5e0;
  border-color: #f0c987;
  color: #6b4500;
}
/* Hinweis-Banner im Erweiterung-Tab — normaler Textfluss (kein Flex). */
.am-note {
  display: block;
  margin: 10px 0 14px;
  padding: 10px 14px;
  border-radius: 6px;
  background: #eef4ff;
  border: 1px solid #c7d8ff;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.5;
}
.am-note.warn {
  background: #fff5e0;
  border-color: #f0c987;
  color: #6b4500;
}
.setup-banner .linklike {
  background: none;
  border: none;
  color: var(--accent, #0a66ff);
  cursor: pointer;
  text-decoration: underline;
  font: inherit;
  padding: 0;
}

.tab-step {
  display: inline-block;
  min-width: 18px;
  height: 18px;
  margin-right: 6px;
  padding: 0 5px;
  border-radius: 9px;
  background: rgba(0,0,0,0.08);
  color: inherit;
  font-size: 11px;
  line-height: 18px;
  text-align: center;
  font-weight: 600;
}
.tab-btn.active .tab-step {
  background: var(--accent, #0a66ff);
  color: #fff;
}

.setup-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}
.setup-field {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 14px;
  background: var(--panel);
}
.setup-field legend {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
  padding: 0 4px;
}
.setup-field label {
  display: block;
  margin: 6px 0;
  font-size: 14px;
}
.setup-field input[type="text"],
.setup-field select {
  width: 100%;
  padding: 5px 8px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font: inherit;
  background: #fff;
}
.setup-field input[type="radio"] {
  margin-right: 6px;
}
.setup-hint {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  color: var(--muted);
}
.setup-wide {
  grid-column: 1 / -1;
}
.setup-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.setup-row label {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 12px;
  color: var(--muted);
}
.setup-row label input {
  font-size: 14px;
  color: var(--fg);
}
.setup-wide-label {
  grid-column: 1 / -1;
  display: block;
}
.setup-wide-label input,
.setup-wide-label select {
  width: 100%;
  margin-top: 4px;
}
.setup-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 6px;
  flex-wrap: wrap;
}
.setup-inline-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.disabled-opt {
  color: var(--muted);
  cursor: not-allowed;
}
.disabled-opt input[disabled] {
  cursor: not-allowed;
}
.muted-tag {
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
}

.tab-btn-setup {
  margin-left: auto;
  opacity: 0.85;
}
.tab-btn-setup.active { opacity: 1; }

/* --- HTML-Artefakt-Tabs (Erweiterung / Ausführbarkeit / Priorität) --- */

.artifact-panel { padding-top: 12px; }
.artifact-intro {
  margin: 0 0 12px;
  padding: 10px 14px;
  background: #f4f6fa;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  color: var(--fg);
}
.artifact-intro strong { color: var(--text); }

.artifact-layout {
  display: grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap: 18px;
  margin-top: 14px;
}
.artifact-layout > div h3 {
  margin: 0 0 6px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
}
.artifact-frame-host {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  min-height: 600px;
  display: flex;
}
.artifact-iframe {
  width: 100%;
  height: 100%;
  min-height: 600px;
  border: 0;
  border-radius: 6px;
  background: #fff;
}
/* --- Kombinierter Erteilungsakte-Tab: aufklappbare Sektionen --- */
.akte-files-row { margin: 6px 0 16px; }
.akte-files-row h3 {
  margin: 0 0 6px; font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--muted);
}
.akte-section {
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 12px;
  background: var(--panel);
  overflow: hidden;
}
.akte-section > summary {
  cursor: pointer;
  list-style: none;
  padding: 12px 16px;
  font-weight: 600;
  font-size: 15px;
  background: #f6f8fa;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.akte-section > summary::-webkit-details-marker { display: none; }
.akte-section > summary::before { content: "▸"; color: var(--muted); font-size: 12px; }
.akte-section[open] > summary::before { content: "▾"; }
.akte-section[open] > summary { border-bottom: 1px solid var(--border); }
.akte-section-law { margin-left: auto; font-weight: 400; font-size: 12px; color: var(--muted); }
.akte-section-body { padding: 14px 16px; }
.akte-subhead {
  margin: 20px 0 8px;
  padding-top: 14px;
  border-top: 1px dashed var(--border);
  font-size: 14px;
}
.akte-source-hint { margin: 0 0 10px; font-size: 12.5px; color: var(--muted); }

/* --- Akten-Vorfilter: Klassifikations-Checkliste --- */
.akte-filter {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 16px;
  background: #fbfcfe;
}
.akte-filter-head { display: flex; align-items: center; gap: 12px; }
.akte-filter-head strong { font-size: 14px; }
.akte-filter-hint { font-size: 12.5px; color: var(--muted); margin: 6px 0 4px; }
.akte-filter-body { display: flex; gap: 14px; align-items: flex-start; }
.akte-filter-list { flex: 1; min-width: 0; margin-top: 10px; max-height: 460px; overflow-y: auto; border-top: 1px solid var(--border); }
.akte-filter-actions { padding: 8px 2px; font-size: 12.5px; position: sticky; top: 0; background: #fbfcfe; }
.akte-filter-actions a { color: var(--accent); cursor: pointer; }
.akte-doc {
  display: grid;
  grid-template-columns: 18px 160px 1fr auto auto;
  align-items: center;
  gap: 8px;
  padding: 5px 4px;
  border-bottom: 1px solid #eef0f3;
  font-size: 12.5px;
}
.akte-doc-label { display: contents; cursor: pointer; }
.akte-doc.previewing { background: #eef4ff; }
.akte-doc-view {
  background: transparent; border: 1px solid transparent; border-radius: 4px;
  cursor: pointer; font-size: 13px; padding: 1px 5px; line-height: 1;
}
.akte-doc-view:hover { background: #e7eefc; border-color: var(--border); }
.akte-doc.irr { opacity: 0.6; }

/* PDF-Vorschau-Pane */
.akte-filter-preview {
  flex: 1; min-width: 0; margin-top: 10px;
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: 6px; background: #fff;
  height: 460px;
}
.akte-filter-preview.hidden { display: none; }
.akte-preview-cap {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  font-size: 11.5px; color: var(--muted); padding: 5px 8px;
  border-bottom: 1px solid var(--border); word-break: break-all;
}
#akte-preview-frame { flex: 1; width: 100%; border: 0; border-radius: 0 0 6px 6px; }
.akte-doc-type {
  font-weight: 600;
  font-size: 11px;
  color: var(--text);
  background: #eef2f7;
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.akte-doc.irr .akte-doc-type { background: #f3f3f5; color: var(--muted); font-weight: 400; }
.akte-doc-name { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.akte-doc-reason { grid-column: 1 / -1; font-size: 11.5px; color: var(--muted); font-style: italic; padding-left: 26px; }
.akte-tag { font-size: 10.5px; padding: 1px 5px; border-radius: 4px; white-space: nowrap; }
.akte-tag.llm { background: #e7e0ff; color: #5b3ea8; }
.akte-tag.warn { background: #fff5e0; color: #6b4500; }
.akte-tag.learned { background: #dff3e6; color: #1a7f37; }

/* --- Prior-Art: Ansichts-Umschalter + Dokumentenliste --- */
.pa-view-toggle { display: flex; align-items: center; gap: 12px; margin: 4px 0 14px; }
.pa-view-btn {
  background: transparent; color: var(--muted); border: 1px solid transparent;
  border-radius: 7px; padding: 6px 14px; font-weight: 600; cursor: pointer;
}
.pa-view-btn:hover { color: var(--text); background: var(--panel); }
.pa-view-btn.active { color: var(--accent); border-color: var(--accent); background: var(--panel); }

.pa-doclist-head { margin: 0 0 10px; }
.pa-doclist-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.pa-doclist-table th, .pa-doclist-table td {
  border: 1px solid var(--border); padding: 5px 7px; vertical-align: top; text-align: left;
}
.pa-doclist-table th {
  background: #f6f8fa; font-weight: 600; font-size: 11px; text-transform: uppercase;
  color: var(--muted); white-space: nowrap;
}
.pa-doclist-table select, .pa-doclist-table input[type=date] {
  font: inherit; font-size: 12px; padding: 2px 4px; max-width: 150px;
  border: 1px solid var(--border); border-radius: 4px; background: var(--panel);
}
.pa-docnum { font-family: ui-monospace, Menlo, monospace; white-space: nowrap; }
.sdt-badge {
  display: inline-block; padding: 2px 7px; border-radius: 4px; font-weight: 600; font-size: 11.5px;
}
.sdt-542 { background: var(--notdisc-bg); color: var(--notdisc-fg); }   /* voller SdT — stärkste Gefahr */
.sdt-543 { background: #ffe0b2; color: #8a4b00; }                       /* nur Neuheit */
.sdt-none { background: #e6e9ee; color: #57606a; }                      /* kein SdT */
.sdt-unkl { background: var(--partial-bg); color: var(--partial-fg); }  /* unbestimmt */
.sdt-sub { font-size: 10.5px; color: var(--muted); margin: 3px 0; }
.pa-sdt select { margin-top: 4px; }
.prio-yes { color: var(--notdisc-fg); font-weight: 600; }

.empty-mini {
  font-size: 12px;
  color: var(--muted);
  font-style: italic;
  padding: 6px 0;
}
@media (max-width: 1100px) {
  .artifact-layout {
    grid-template-columns: 1fr;
  }
  .artifact-frame-host { min-height: 500px; }
}

/* --- Patent-Analyse-Netzwerk: Akten & Werkzeuge --------------------------- */

.brand { cursor: pointer; user-select: none; }
.main-nav { display: flex; gap: 6px; }
.navbtn {
  background: var(--panel);
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.navbtn:hover { background: #f3f4f6; color: var(--text); }
.navbtn.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.net-panel { display: flex; flex-direction: column; gap: 12px; }
.net-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.net-summary { color: var(--text); }
.net-summary code { color: var(--muted); }
.net-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.net-hint {
  background: #ddf4ff;
  border: 1px solid #b6e3ff;
  border-radius: 6px;
  padding: 10px 12px;
}
.net-foot { font-size: 12.5px; }
.muted { color: var(--muted); }

/* Akten-Karten */
.akten-list { display: flex; flex-direction: column; gap: 8px; }
.akte-card, .skill-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.akte-card > summary, .skill-card > summary {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  cursor: pointer;
  list-style: none;
  flex-wrap: wrap;
}
.akte-card > summary::-webkit-details-marker,
.skill-card > summary::-webkit-details-marker { display: none; }
.akte-card[open] > summary, .skill-card[open] > summary {
  border-bottom: 1px solid var(--border);
}
.akte-name { font-weight: 600; }
.akte-title { color: var(--muted); flex: 1; min-width: 180px; }
.akte-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.badge {
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 10px;
  background: #f3f4f6;
  border: 1px solid var(--border);
  white-space: nowrap;
}
.badge-epo { background: #ddf4ff; border-color: #b6e3ff; color: #0a558c; }
.badge-patg { background: #ffebe9; border-color: #ffc1bc; color: #a40e26; }
.badge-ok { background: var(--disclosed-bg); border-color: #a8dfb0; color: var(--disclosed-fg); }
.badge-muted { color: var(--muted); }

.akte-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 10px; }
.akte-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.akte-meta { display: flex; flex-direction: column; gap: 4px; }
.akte-meta .k {
  display: inline-block;
  min-width: 130px;
  color: var(--muted);
  font-size: 12.5px;
}
.akte-cov { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 6px; }
.cov-chip {
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 10px;
  border: 1px solid var(--border);
  color: var(--muted);
  background: var(--bg);
  white-space: nowrap;
}
.cov-chip.done {
  background: var(--disclosed-bg);
  border-color: #a8dfb0;
  color: var(--disclosed-fg);
}
.akte-counts { font-size: 12.5px; }
.outputs-head { font-weight: 600; margin-top: 2px; }
.out-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 3px 0;
}
.out-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.out-mtime { color: var(--muted); font-size: 12px; white-space: nowrap; }
.out-row button { padding: 3px 10px; font-size: 12.5px; }
.akte-actions { display: flex; gap: 8px; flex-wrap: wrap; border-top: 1px solid var(--border); padding-top: 10px; }

/* Werkzeuge */
.tools-workdir-label { display: flex; align-items: center; gap: 8px; }
.tools-workdir-label select {
  padding: 6px 8px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--panel);
  max-width: 320px;
}
.tools-workdir-custom {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font: inherit;
}
.fw-head { margin: 14px 0 8px; }
.skill-card { margin-bottom: 8px; }
.skill-desc-short { color: var(--muted); flex: 1; min-width: 200px; font-size: 12.5px; }
.skill-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.skill-body p { margin: 0; }
.task-area {
  width: 100%;
  font: inherit;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  resize: vertical;
}
.skill-actions { display: flex; gap: 8px; }
.sk-cmd-pre {
  background: #f6f8fa;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px;
  font-size: 12px;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-all;
  margin: 0;
}
.agents-head { margin: 18px 0 8px; }

@media (max-width: 900px) {
  .akte-grid { grid-template-columns: 1fr; }
}

/* --- Vereinte Patent-Übersicht (Startseite) -------------------------------- */

.pat-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.pat-card:hover {
  border-color: var(--accent);
  box-shadow: 0 2px 10px rgba(9, 105, 218, 0.12);
}
.pat-head {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.pat-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
  flex-wrap: wrap;
}
.pat-foot .akte-cov { margin-bottom: 0; }
.pat-open { white-space: nowrap; font-size: 12.5px; }
.badge-wb { background: #fbefff; border-color: #ecd8ff; color: #6639ba; }
.badge-akte { background: #fff8c5; border-color: #eed888; color: #7d4e00; }

/* --- Akte-Tab & Strips in der Workbench ------------------------------------ */

.akte-panel {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
}
.akte-strip {
  background: #fff8c5;
  border: 1px solid #eed888;
  border-radius: 8px;
  padding: 8px 12px;
  margin-bottom: 14px;
}
.akte-strip-head {
  font-weight: 600;
  font-size: 12.5px;
  margin-bottom: 4px;
}
.akte-strip .out-row { padding: 2px 0; }

/* --- Anspruchsvergleich (cross-patent) ----------------------------------- */

.sim-key { display: inline-block; padding: 0 6px; border-radius: 3px; font-size: 12px; margin: 0 2px; }
.sim-key.sim-same { background: var(--disclosed-bg); color: var(--disclosed-fg); }
.sim-key.sim-related { background: var(--partial-bg); color: var(--partial-fg); }

/* saved list */
.compare-saved { margin: 8px 0 18px; }
.compare-saved-row {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 12px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--panel); margin-bottom: 6px;
}
.compare-saved-row .compare-open { font-weight: 600; font-size: 14px; }
.compare-saved-cols { flex: 1; font-size: 12px; }
.compare-saved-row .compare-del { padding: 2px 8px; }

/* builder */
.compare-builder { border-top: 1px solid var(--border); padding-top: 14px; }
.compare-cols { display: flex; gap: 14px; flex-wrap: wrap; align-items: flex-start; }
.cmp-card {
  flex: 1 1 280px; min-width: 260px; max-width: 380px;
  border: 1px solid var(--border); border-radius: 8px; padding: 12px;
  background: var(--panel);
}
.cmp-card-ref { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.cmp-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.cmp-card-head .danger { padding: 1px 8px; }
.cmp-src { display: flex; gap: 14px; font-size: 13px; margin-bottom: 8px; }
.cmp-src label { display: flex; align-items: center; gap: 4px; cursor: pointer; }
.cmp-src-number input, .cmp-src-raw input, .cmp-src-raw textarea {
  width: 100%; padding: 6px 8px; border: 1px solid var(--border); border-radius: 5px;
  font: inherit; margin-bottom: 6px;
}
.cmp-src-raw textarea { resize: vertical; }
.cmp-load { width: 100%; margin-top: 4px; }
.cmp-resolved { margin-top: 10px; border-top: 1px dashed var(--border); padding-top: 8px; }
.cmp-claim-pick { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); }
.cmp-claim-pick select { padding: 4px 6px; border-radius: 4px; border: 1px solid var(--border); font: inherit; }
.cmp-base-pick { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); margin-top: 8px; }
.cmp-base-pick select { padding: 4px 6px; border-radius: 4px; border: 1px solid var(--border); font: inherit; }
.cmp-preview { list-style: none; margin: 8px 0 0; padding: 0; max-height: 150px; overflow-y: auto; }
.cmp-preview li { font-size: 12px; padding: 3px 0; border-bottom: 1px solid #f0f1f3; }
.cmp-fid {
  display: inline-block; font-weight: 700; font-size: 11px; color: var(--accent);
  background: #eef4fc; border-radius: 3px; padding: 0 4px; margin-right: 5px;
}
.compare-build-actions { display: flex; gap: 10px; align-items: center; margin-top: 14px; flex-wrap: wrap; }
#compare-title { flex: 1; min-width: 220px; padding: 7px 10px; border: 1px solid var(--border); border-radius: 5px; font: inherit; }

/* result matrix */
.compare-result { margin-top: 18px; }
.cmp-result-bar { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; flex-wrap: wrap; }
.cmp-result-bar h3 { margin: 0; }
#cmp-title-edit { flex: 1; min-width: 240px; padding: 6px 10px; border: 1px solid var(--border); border-radius: 5px; font: inherit; font-size: 16px; }
.cmp-result-actions { margin-left: auto; display: flex; gap: 8px; }
.cmp-edit-hint { margin: 0 0 10px; font-size: 12.5px; }

.cmp-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 8px; }
.cmp-matrix { border-collapse: collapse; width: 100%; background: var(--panel); table-layout: fixed; }
.cmp-matrix th, .cmp-matrix td {
  border: 1px solid var(--border); vertical-align: top; padding: 0;
  width: 320px; min-width: 240px;
}
.cmp-matrix th {
  background: #f6f8fa; font-size: 13px; padding: 8px 10px; text-align: left;
  position: sticky; top: 0; z-index: 1;
}
.cmp-th-ref { background: #eef4fc !important; }
.cmp-th-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 6px; }
.cmp-th-label { font-weight: 600; }
.cmp-col-remove {
  flex: none; border: 1px solid var(--border); background: var(--panel);
  color: var(--muted); border-radius: 5px; width: 22px; height: 22px; padding: 0;
  line-height: 1; font-size: 12px; cursor: pointer;
}
.cmp-col-remove:hover { background: var(--err); border-color: var(--err); color: #fff; }
.cmp-th-base {
  margin-top: 4px; font-size: 11px; font-weight: 400; color: var(--muted);
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.cmp-th-base select {
  padding: 2px 4px; border-radius: 4px; border: 1px solid var(--border);
  font: inherit; font-size: 11px; max-width: 160px;
}
.cmp-badge {
  display: inline-block; font-size: 10px; text-transform: uppercase; letter-spacing: 0.04em;
  background: var(--accent); color: #fff; border-radius: 3px; padding: 1px 5px; margin-right: 6px;
}
.cmp-cell { padding: 0; }
.cmp-cell.cmp-empty { background: #fbfbfc; }
.cmp-feat {
  padding: 8px 10px; border-bottom: 1px dashed #e6e8eb; font-size: 13px; line-height: 1.4;
}
.cmp-feat:last-child { border-bottom: none; }
.cmp-feat.sim-same { background: var(--disclosed-bg); }
.cmp-feat.sim-related { background: var(--partial-bg); }
.cmp-feat.sim-none { background: #fff; }
.cmp-feat.sim-ref { background: #fbfdff; }
.cmp-vtext { display: inline; }
.cmp-ctrls { margin-top: 6px; display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.cmp-ctrls select {
  font-size: 11px; padding: 2px 4px; border: 1px solid var(--border);
  border-radius: 4px; background: #fff; max-width: 100%;
}
.cmp-tool {
  font-size: 12px; line-height: 1; padding: 3px 6px; border: 1px solid var(--border);
  border-radius: 4px; background: #fff; color: var(--text); cursor: pointer;
}
.cmp-tool:hover { background: #eef4ff; border-color: var(--accent); }
.cmp-split { margin-top: 6px; padding: 6px; border: 1px dashed var(--accent); border-radius: 6px; background: #f7faff; }
.cmp-split-ta {
  width: 100%; min-height: 64px; font: inherit; font-size: 12px; line-height: 1.4;
  border: 1px solid var(--border); border-radius: 4px; padding: 5px; resize: vertical; background: #fff;
}
.cmp-split-actions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-top: 5px; font-size: 11px; }

/* track-changes redline inside cells */
.cmp-feat del {
  color: var(--err); text-decoration: line-through;
  text-decoration-color: var(--err); text-decoration-thickness: 1px;
}
.cmp-feat ins {
  color: var(--ok); text-decoration: underline; text-decoration-thickness: 1px;
  background: rgba(26, 127, 55, 0.10); border-radius: 2px;
}
/* When track-changes is on, soften the row-level tint so the inline redline
   carries the signal and stays legible. */
.cmp-feat.cmp-tc.sim-same { background: #eefaf0; }
.cmp-feat.cmp-tc.sim-related { background: #fffbe9; }
.cmp-tc-legend { margin: 0 0 8px; font-size: 12.5px; }
.cmp-tc-legend del { color: var(--err); }
.cmp-tc-legend ins { color: var(--ok); background: rgba(26,127,55,0.10); }

/* in-result "add another patent" panel */
.cmp-addcol {
  border: 1px solid var(--accent); border-radius: 8px; padding: 12px;
  margin-bottom: 14px; max-width: 420px; background: #fbfdff;
}
.cmp-addcol-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.cmp-addcol-head .secondary { padding: 1px 8px; }
.cmp-addcol .cmp-claim-pick { margin-top: 10px; }
.cmp-addcol [data-action="add-commit"] { margin-top: 10px; }

/* --- Erwiderung (Analyse der gegnerischen Erwiderung) ------------------- */
.erw-legend { margin-top: 10px; font-size: 12px; color: var(--muted); display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.erw-sound { padding: 2px 8px; border-radius: 10px; font-weight: 600; }
.erw-sound.strong  { background: var(--notdisc-bg);   color: var(--notdisc-fg); }
.erw-sound.partial { background: var(--partial-bg);   color: var(--partial-fg); }
.erw-sound.weak    { background: var(--disclosed-bg); color: var(--disclosed-fg); }

.erw-uploads { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 12px 0; }
.erw-upload-col h3 { margin: 0 0 6px; font-size: 14px; }
.erw-upload-col .dropzone { margin-bottom: 8px; }
@media (max-width: 760px) { .erw-uploads { grid-template-columns: 1fr; } }

.erw-file-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 4px 0; border-bottom: 1px solid var(--border); }
.erw-file-row .danger { padding: 2px 8px; }

.erw-overview { margin: 8px 0; }
.erw-readonly-note { margin-bottom: 8px; }
.erw-docs { margin: 10px 0; }
.erw-docs h4 { margin: 0 0 4px; }
.erw-docs ul { margin: 0; padding-left: 18px; }
.erw-docs li { font-size: 13px; color: var(--fg); }

.erw-ground { margin-top: 18px; }
.erw-ground > h4 { margin: 0 0 4px; }

/* Spaltenbreiten kommen aus dem <colgroup> je Tabelle (6- bzw. 7-spaltig). */
.erw-matrix { border-collapse: collapse; width: 100%; min-width: 920px; background: var(--panel); table-layout: fixed; }
.erw-matrix th, .erw-matrix td {
  border: 1px solid var(--border); padding: 6px 8px; vertical-align: top; font-size: 13px;
  overflow-wrap: anywhere; word-break: normal;   /* lange Tokens umbrechen, nicht überlaufen */
}
.erw-matrix th { background: #f6f8fa; text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); }
.erw-matrix td.id-cell { text-align: center; font-weight: 600; }
.erw-matrix .erw-verbatim { white-space: pre-wrap; color: var(--muted); }
/* Lese-Ansicht: voller Text bricht um (kein Abschneiden). */
.erw-matrix td > div { white-space: pre-wrap; }
.erw-matrix td.strong,  .erw-matrix td.danger-high   { background: var(--notdisc-bg);   color: var(--notdisc-fg); }
.erw-matrix td.partial, .erw-matrix td.danger-medium { background: var(--partial-bg);   color: var(--partial-fg); }
.erw-matrix td.weak,    .erw-matrix td.danger-low    { background: var(--disclosed-bg); color: var(--disclosed-fg); }
.erw-matrix td .status-label { font-weight: 700; display: block; margin-bottom: 4px; }
/* Edit-Ansicht: Textfelder wachsen mit dem Inhalt, damit voller Text sichtbar
   bleibt — `field-sizing` in Chromium, sonst per JS (_erwAutogrow). */
.erw-matrix textarea {
  width: 100%; box-sizing: border-box; min-height: 44px; resize: vertical;
  field-sizing: content; overflow: hidden;
  border: 1px solid var(--border); border-radius: 4px; padding: 4px 6px;
  font: inherit; font-size: 12px; background: var(--panel); color: var(--fg);
}
.erw-matrix select, .erw-principle-input, .erw-basis-input {
  width: 100%; box-sizing: border-box; margin-top: 4px; padding: 3px 6px;
  border: 1px solid var(--border); border-radius: 4px; font: inherit; font-size: 12px;
  background: var(--panel); color: var(--fg);
}
.erw-cite { color: var(--muted); margin-top: 4px; }

.erw-counters { display: flex; flex-direction: column; gap: 8px; }
.erw-counter { border-left: 3px solid var(--border); padding-left: 6px; }
.erw-ca-add, .erw-ca-rm { font-size: 11px; margin-top: 4px; }

.erw-overall { margin-top: 18px; padding: 10px 12px; background: #f6f8fa; border-radius: 6px; }
.erw-overall h4 { margin: 0 0 4px; }

/* --- Erwiderung: Gefahr-Achse (Farbe) + Stichhaltigkeit (Tag) ----------- */
.erw-sound.danger-high,   .erw-matrix td.danger-high   { background: var(--notdisc-bg);   color: var(--notdisc-fg); }
.erw-sound.danger-medium, .erw-matrix td.danger-medium { background: var(--partial-bg);   color: var(--partial-fg); }
.erw-sound.danger-low,    .erw-matrix td.danger-low    { background: var(--disclosed-bg); color: var(--disclosed-fg); }
.erw-sound-tag { display: inline-block; margin: 2px 0 4px; padding: 0 6px; border-radius: 8px;
  background: rgba(0,0,0,0.06); color: var(--muted); font-weight: 600; }
.erw-legend-note { flex-basis: 100%; color: var(--muted); font-style: italic; margin-top: 2px; }
.erw-matrix td select[data-field="danger"] { font-weight: 600; }

/* --- Standard-Mapping (Essentialität) ----------------------------------- */
.sm-suggest { margin: 8px 0 12px; }
.sm-suggestion-box { margin-top: 8px; padding: 8px 12px; background: #f6f8fa; border: 1px solid var(--border); border-radius: 6px; }
.sm-suggestion-box h4 { margin: 0 0 4px; }
.sm-suggestion-box ul { margin: 4px 0 0; padding-left: 18px; }
.sm-suggestion-box li { margin-bottom: 6px; }
.sm-upload { margin: 8px 0 12px; }
.sm-upload-fields { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 8px; }
.sm-upload-fields label { display: flex; flex-direction: column; font-size: 12px; color: var(--muted); gap: 3px; }
.sm-upload-fields input { padding: 4px 6px; border: 1px solid var(--border); border-radius: 4px; font: inherit; min-width: 200px; }
.sm-conclusion { margin: 12px 0 4px; padding: 6px 10px; background: #f6f8fa; border-left: 3px solid var(--accent); border-radius: 4px; font-size: 13px; }

/* --- Familie (Abhängigkeiten / Prioritäten / Graph) -------------------- */
.patent-chip { color: var(--accent); cursor: pointer; text-decoration: none; }
.patent-chip:hover { text-decoration: underline; }

.family-summary { margin: 10px 0 4px; }

.family-scope-seg { display: inline-flex; gap: 0; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.family-scope-btn {
  border: none; background: var(--bg); color: var(--muted);
  padding: 5px 12px; font-size: 13px; cursor: pointer; border-right: 1px solid var(--border);
}
.family-scope-btn:last-child { border-right: none; }
.family-scope-btn:hover { color: var(--text); background: var(--panel); }
.family-scope-btn.active { color: var(--accent); background: var(--panel); font-weight: 600; }

.badge.root { background: #ddf4ff; border-color: #b6e3ff; color: #0a558c; }
.badge.granted { background: #d8f3df; border-color: #74c98a; color: #1a7f37; }
.badge.ok { background: var(--disclosed-bg); border-color: #a8dfb0; color: var(--disclosed-fg); }
.badge.muted { color: var(--muted); }

.family-table-wrap { overflow-x: auto; margin: 6px 0 18px; }
.family-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.family-table th, .family-table td {
  text-align: left; padding: 6px 10px; border-bottom: 1px solid var(--border); vertical-align: top;
}
.family-table th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); font-weight: 600; }
.family-table tr.fam-row-root { background: #f2f9ff; }

/* graph */
.family-graph-wrap { margin: 8px 0 20px; border: 1px solid var(--border); border-radius: 10px; background: var(--panel); }
.family-graph-head {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
}
.family-graph-head h3 { margin: 0; font-size: 14px; }
.family-legend { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; font-size: 11px; color: var(--muted); }
.family-legend .lg { padding: 1px 8px; border-radius: 8px; border: 1px solid var(--border); }
.family-legend .lg-root { background: #ddf4ff; border-color: #8fc8f5; color: #0a558c; }
.family-legend .lg-prio { background: #fff5d6; border-color: #ecd58a; color: var(--warn); }
.family-legend .lg-gen0 { background: #efe2ff; border-color: #b794e6; color: #6639ba; }
.family-legend .lg-gen1 { background: #d8f3df; border-color: #74c98a; color: #1a7f37; }
.family-legend .lg-gen2 { background: #ffe7c2; border-color: #f0b860; color: #8a5a00; }
.family-legend .lg-pct { background: #e0f7fa; border-color: #7dd3e0; color: #0e6e7d; }
.family-legend .lg-member { background: #f3f4f6; }
.family-legend .lg-edge { display: inline-flex; align-items: center; gap: 4px; }
.family-legend .lg-edge i { width: 18px; height: 0; border-top: 2px solid var(--muted); display: inline-block; }
.family-legend .lg-edge i.e-prio { border-color: #6a737d; }
.family-legend .lg-edge i.e-natphase { border-top-style: dashed; border-color: #14919b; }
.family-legend .lg-edge i.e-div { border-top-style: solid; border-color: #6639ba; }

.family-graph-controls { margin-left: auto; display: flex; gap: 4px; }
.family-graph-controls button { min-width: 30px; padding: 3px 8px; }

.family-graph { width: 100%; height: 460px; overflow: hidden; background:
  repeating-linear-gradient(0deg, #fafbfc, #fafbfc 23px, #f1f3f5 24px),
  repeating-linear-gradient(90deg, #fafbfc, #fafbfc 23px, #f1f3f5 24px);
  cursor: grab;
}
.family-graph:active { cursor: grabbing; }
#family-svg { width: 100%; height: 100%; display: block; }
.fg-empty { fill: var(--muted); font-size: 13px; }
.family-graph-hint { padding: 6px 12px; margin: 0; font-size: 11px; border-top: 1px solid var(--border); }

/* edges */
/* Hintergrund-Kanten gedimmt; die Streitpatent-Kette (.lineage) und Hover
   (.hot) stehen voll im Vordergrund — entwirrt große Familien optisch. */
.fg-edge { fill: none; stroke: #9aa3ab; stroke-width: 1.6; opacity: 0.22; transition: opacity .12s; }
.fg-edge.e-prio { stroke: #8a929a; }
.fg-edge.e-prio.inactive { stroke-dasharray: 5 4; stroke: #b9c0c7; }
.fg-edge.e-div { stroke: #8f63d6; stroke-width: 1.8; }
.fg-edge.e-natphase { stroke: #14919b; stroke-width: 1.8; stroke-dasharray: 6 4; }
.fg-edge.lineage { opacity: 1; }
.fg-edge.hot { stroke: var(--accent); stroke-width: 2.6; opacity: 1; }
.fg-arrowhead.e-prio { fill: #8a929a; }
.fg-arrowhead.e-div { fill: #8f63d6; }
.fg-arrowhead.e-natphase { fill: #14919b; }

/* nodes */
.fnode .fg-box { fill: #f3f4f6; stroke: #cfd4d9; stroke-width: 1.4; }
.fnode .fg-label { text-anchor: middle; font-size: 12.5px; font-weight: 600; fill: var(--text); }
.fnode .fg-sublabel { text-anchor: middle; font-size: 10px; fill: var(--muted); }
.fnode .fg-star { font-size: 13px; fill: #d4a200; }
.fnode .fg-granted { font-size: 11px; font-weight: 700; fill: #1a7f37; text-anchor: middle; }
.fnode.granted .fg-box { stroke-width: 2; }  /* erteilt = endgültige Fassung */
.fnode:hover .fg-box { stroke: var(--accent); }
.fnode.root .fg-box { fill: #ddf4ff; stroke: #2188ff; stroke-width: 2; }
.fnode.prio .fg-box { fill: #fff5d6; stroke: #ecd58a; }
.fnode.parent .fg-box { fill: #fbefff; stroke: #c9a8ef; }
.fnode.div .fg-box { fill: var(--disclosed-bg); stroke: #a8dfb0; }
.fnode.pct .fg-box { fill: #e0f7fa; stroke: #7dd3e0; }
/* Teilanmeldungs-Generationen: 0 = Stammanmeldung, 1./2./3.+ Generation. */
.fnode.gen0 .fg-box { fill: #efe2ff; stroke: #b794e6; }
.fnode.gen1 .fg-box { fill: #d8f3df; stroke: #74c98a; }
.fnode.gen2 .fg-box { fill: #ffe7c2; stroke: #f0b860; }
.fnode.gen3 .fg-box { fill: #ffd9e6; stroke: #ef8fb6; }
/* Knoten außerhalb der Streitpatent-Kette dezent zurücknehmen; Hover voll. */
.fnode.dim { opacity: 0.25; transition: opacity .12s; }
.fnode.dim:hover { opacity: 1; }
/* Fokus aus → volle Familie: nichts dimmen. */
#family-svg.focus-off .fnode.dim { opacity: 1; }
#family-svg.focus-off .fg-edge { opacity: 1; }
.fam-focus-toggle { font-size: 12px; color: var(--muted); display: inline-flex; align-items: center; gap: 5px; cursor: pointer; white-space: nowrap; }
.fam-focus-toggle input { cursor: pointer; }
.family-juris { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.family-juris-label { font-size: 12px; color: var(--muted); white-space: nowrap; }
.family-juris-chip {
  border: 1px solid var(--border); background: var(--bg); color: var(--muted);
  padding: 3px 9px; font-size: 12px; border-radius: 999px; cursor: pointer; line-height: 1.4;
}
.family-juris-chip:hover { color: var(--text); border-color: var(--accent); }
.family-juris-chip.active { color: var(--accent); border-color: var(--accent); background: var(--panel); font-weight: 600; }
.family-juris-chip .cnt { opacity: .6; font-weight: 400; }

/* --- Ansprüche: Begriff-Markierungen (Highlights) --------------------- */
.hl-toolbar {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
  padding: 8px 10px; margin: 0 0 12px; border: 1px solid var(--border);
  border-radius: 8px; background: var(--bg);
}
.hl-toolbar.hidden { display: none; }
.hl-toolbar-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.hl-swatches { display: inline-flex; gap: 6px; }
.hl-swatch {
  width: 22px; height: 22px; border-radius: 50%; border: 2px solid #d0d7de;
  cursor: pointer; padding: 0; line-height: 1; font-size: 12px; color: var(--muted);
  display: inline-flex; align-items: center; justify-content: center;
}
.hl-swatch:hover { transform: scale(1.1); }
.hl-swatch.active { border-color: var(--text); box-shadow: 0 0 0 2px var(--panel), 0 0 0 3px var(--text); }
.hl-swatch.hl-eraser { background: var(--panel); border-radius: 6px; width: 26px; }
.hl-swatch.hl-exclude { background: var(--panel); border-radius: 6px; width: 26px; color: var(--muted); }
.hl-swatch.hl-yellow { background: #ffe066; }
.hl-swatch.hl-green  { background: #b2f2bb; }
.hl-swatch.hl-blue   { background: #a5d8ff; }
.hl-swatch.hl-purple { background: #eebefa; }
.hl-swatch.hl-orange { background: #ffd8a8; }
.hl-swatch.hl-pink   { background: #fcc2d7; }
.hl-swatch.hl-red    { background: #ffc9c9; }
.hl-swatch.hl-indigo { background: #bac8ff; }
.hl-swatch.hl-cyan   { background: #99e9f2; }
.hl-swatch.hl-teal   { background: #96f2d7; }
.hl-swatch.hl-lime   { background: #d8f5a2; }
.hl-swatch.hl-gray   { background: #dee2e6; }

.hl-scope-seg { display: inline-flex; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.hl-scope-btn {
  border: none; background: var(--panel); color: var(--muted);
  padding: 5px 12px; font-size: 13px; cursor: pointer; border-right: 1px solid var(--border);
}
.hl-scope-btn:last-child { border-right: none; }
.hl-scope-btn:hover { color: var(--text); }
.hl-scope-btn.active { color: var(--accent); font-weight: 600; background: #eef6ff; }
.hl-hint { font-size: 11px; }

/* the marks themselves */
mark.hl { padding: 0.05em 0.1em; border-radius: 3px; color: inherit; }
mark.hl-yellow { background: #ffe066; }
mark.hl-green  { background: #b2f2bb; }
mark.hl-blue   { background: #a5d8ff; }
mark.hl-purple { background: #eebefa; }
mark.hl-orange { background: #ffd8a8; }
mark.hl-pink   { background: #fcc2d7; }
mark.hl-red    { background: #ffc9c9; }
mark.hl-indigo { background: #bac8ff; }
mark.hl-cyan   { background: #99e9f2; }
mark.hl-teal   { background: #96f2d7; }
mark.hl-lime   { background: #d8f5a2; }
mark.hl-gray   { background: #dee2e6; }
.feature-verbatim { cursor: text; }

/* --- User-Management: Login-Overlay, Account-Leiste, Admin-Modal --------- */

.account-bar { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.account-user { font-size: 13px; color: var(--muted); font-weight: 600; }
.account-user::before { content: "👤 "; }

.login-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
}
.login-card {
  width: 360px; max-width: calc(100vw - 32px);
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 28px 26px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.10);
}
.login-brand { font-size: 18px; font-weight: 700; text-align: center; margin-bottom: 18px; }
.login-tabs { display: flex; gap: 4px; margin-bottom: 16px; border-bottom: 1px solid var(--border); }
.login-tab {
  flex: 1; background: none; border: none; padding: 8px 4px;
  color: var(--muted); font-weight: 600; cursor: pointer;
  border-bottom: 2px solid transparent; border-radius: 0;
}
.login-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.login-form { display: flex; flex-direction: column; gap: 10px; }
.login-form input {
  padding: 9px 11px; border: 1px solid var(--border); border-radius: 7px;
  font-size: 14px;
}
.login-form button[type="submit"] {
  margin-top: 4px; padding: 9px; background: var(--accent); color: #fff;
  border: none; border-radius: 7px; font-weight: 600; cursor: pointer;
}
.login-form button[type="submit"]:hover { background: var(--accent-hover); }
.login-msg { font-size: 13px; min-height: 18px; }
.login-msg.err { color: var(--err); }
.login-msg.ok { color: var(--ok); }

.modal-overlay {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(0,0,0,0.35);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 48px 16px; overflow-y: auto;
}
.modal-card {
  width: 760px; max-width: 100%;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 10px 40px rgba(0,0,0,0.18);
}
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.modal-head h2 { margin: 0; font-size: 17px; }
.icon-btn { background: none; border: none; font-size: 16px; cursor: pointer; color: var(--muted); }
.icon-btn:hover { color: var(--text); }
.modal-body { padding: 18px 20px; }

.users-settings {
  display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 14px;
  padding: 10px 12px; background: var(--bg); border-radius: 8px; font-size: 13px;
}
.users-settings label { display: flex; align-items: center; gap: 6px; cursor: pointer; }
.users-table-wrap { overflow-x: auto; }
.users-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.users-table th, .users-table td {
  text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.users-table th { color: var(--muted); font-weight: 600; }
.users-feature-chips { display: flex; flex-wrap: wrap; gap: 4px 10px; }
.users-feature-chips label { display: flex; align-items: center; gap: 4px; font-size: 12px; white-space: nowrap; }
.user-role-badge {
  display: inline-block; padding: 1px 8px; border-radius: 10px; font-size: 11px; font-weight: 600;
}
.user-role-badge.admin { background: #ddf4ff; color: var(--accent); }
.user-role-badge.user  { background: #eef1f4; color: var(--muted); }
.user-pending { color: var(--warn); font-size: 11px; }
.users-row-actions { display: flex; gap: 6px; white-space: nowrap; }
.users-row-actions button { padding: 3px 8px; font-size: 12px; }
.inline-check { display: inline-flex; align-items: center; gap: 5px; }
.users-create { margin-top: 16px; }
.users-create > summary { cursor: pointer; font-weight: 600; color: var(--accent); }
.users-create-form { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; align-items: center; }
.users-create-form input, .users-create-form select { padding: 7px 9px; border: 1px solid var(--border); border-radius: 6px; font-size: 13px; }
.users-create-form button { padding: 7px 14px; }

/* --- Parallelverfahren-Tab ------------------------------------------- */
.pv-head { margin-bottom: 14px; }
.pv-warn { color: var(--err); font-weight: 600; }
.pv-panel { border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; margin-bottom: 18px; background: var(--panel); }
.pv-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.pv-panel-head h3 { margin: 0; font-size: 15px; }
.pv-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.pv-note { font-size: 12.5px; margin: 6px 0 10px; }
.pv-status { font-size: 13px; margin: 8px 0; min-height: 18px; }
.pv-cmp-block { margin: 14px 0; }
.pv-cmp-title { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; font-weight: 600; margin-bottom: 6px; }
.pv-cmp-title .pv-open { font-weight: 400; font-size: 12.5px; white-space: nowrap; }
.pv-matrix-scroll { overflow-x: auto; border: 1px solid var(--border); border-radius: 8px; }
.pv-matrix { min-width: 720px; }
.pv-matrix th.pv-th-ref { background: #eaf2fb; color: var(--text); }
.pv-simtag { display: inline-block; margin-left: 6px; font-size: 10.5px; font-style: italic; color: var(--muted); }
.pv-unavail { margin-top: 12px; padding: 10px 12px; border: 1px dashed var(--border); border-radius: 8px; background: #fcfcfd; font-size: 13px; }
.pv-chip { display: inline-block; padding: 1px 7px; margin: 2px; border: 1px solid var(--border); border-radius: 999px; font-size: 11.5px; color: var(--muted); }
.pv-cit-table { border-collapse: collapse; width: 100%; font-size: 13px; }
.pv-cit-table th, .pv-cit-table td { border-bottom: 1px solid var(--border); padding: 6px 8px; text-align: left; vertical-align: top; }
.pv-cit-table th { background: var(--bg); font-size: 12px; color: var(--muted); }
.pv-cit-sel { width: 26px; }
.pv-cit-n { text-align: center; width: 34px; color: var(--muted); }
.pv-cit-cat { white-space: nowrap; width: 92px; }
.pv-cit-who { color: var(--muted); font-size: 12px; }
.pv-npl { font-style: italic; color: var(--muted); }
.pv-cat { display: inline-block; min-width: 16px; text-align: center; padding: 0 5px; border-radius: 4px; font-size: 11px; font-weight: 700; border: 1px solid transparent; }
.pv-cat-X { background: var(--err); color: #fff; }
.pv-cat-Y { background: #f59e0b; color: #fff; }
.pv-cat-A { background: var(--border); color: var(--text); }
.pv-cat-I, .pv-cat-E { background: #fde68a; color: #7c5800; }
.pv-cat-D, .pv-cat-L, .pv-cat-O, .pv-cat-P, .pv-cat-T { background: #eef0f3; color: var(--muted); }
